mirror of
https://github.com/ente-io/ente.git
synced 2025-08-06 22:52:45 +00:00
[mob][photos] Create AppliedFilters widget
This commit is contained in:
parent
98aca5090b
commit
2b5bb5f338
@ -0,0 +1,72 @@
|
||||
import "package:flutter/material.dart";
|
||||
import "package:photos/models/search/hierarchical/hierarchical_search_filter.dart";
|
||||
import "package:photos/ui/components/buttons/chip_button_widget.dart";
|
||||
import "package:photos/ui/viewer/gallery/state/inherited_search_filter_data.dart";
|
||||
import "package:photos/ui/viewer/gallery/state/search_filter_data_provider.dart";
|
||||
|
||||
class AppliedFilters extends StatefulWidget {
|
||||
const AppliedFilters({super.key});
|
||||
|
||||
@override
|
||||
State<AppliedFilters> createState() => _AppliedFiltersState();
|
||||
}
|
||||
|
||||
class _AppliedFiltersState extends State<AppliedFilters> {
|
||||
late SearchFilterDataProvider _searchFilterDataProvider;
|
||||
late List<HierarchicalSearchFilter> _appliedFilters;
|
||||
|
||||
@override
|
||||
void didChangeDependencies() {
|
||||
super.didChangeDependencies();
|
||||
final temp = InheritedSearchFilterData.of(context).searchFilterDataProvider;
|
||||
assert(temp != null, "SearchFilterDataProvider is null");
|
||||
_searchFilterDataProvider = temp!;
|
||||
_appliedFilters = _searchFilterDataProvider.appliedFilters;
|
||||
|
||||
_searchFilterDataProvider.removeListener(
|
||||
fromApplied: true,
|
||||
listener: onAppliedFiltersUpdate,
|
||||
);
|
||||
_searchFilterDataProvider.addListener(
|
||||
toApplied: true,
|
||||
listener: onAppliedFiltersUpdate,
|
||||
);
|
||||
}
|
||||
|
||||
@override
|
||||
void dispose() {
|
||||
_searchFilterDataProvider.removeListener(
|
||||
fromApplied: true,
|
||||
listener: onAppliedFiltersUpdate,
|
||||
);
|
||||
super.dispose();
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return ListView.builder(
|
||||
itemBuilder: (context, index) {
|
||||
return Padding(
|
||||
padding: const EdgeInsets.symmetric(horizontal: 4),
|
||||
child: ChipButtonWidget(
|
||||
_appliedFilters[index].name(),
|
||||
leadingIcon: _appliedFilters[index].icon(),
|
||||
onTap: () {
|
||||
_searchFilterDataProvider
|
||||
.removeAppliedFilters([_appliedFilters[index]]);
|
||||
},
|
||||
),
|
||||
);
|
||||
},
|
||||
scrollDirection: Axis.horizontal,
|
||||
itemCount: _appliedFilters.length,
|
||||
padding: const EdgeInsets.symmetric(horizontal: 4),
|
||||
);
|
||||
}
|
||||
|
||||
void onAppliedFiltersUpdate() {
|
||||
setState(() {
|
||||
_appliedFilters = _searchFilterDataProvider.appliedFilters;
|
||||
});
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user