|
|
|
@ -1,65 +1,26 @@
|
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
import 'package:meals/screens/tabs.dart';
|
|
|
|
|
import 'package:meals/widgets/main_drawer.dart';
|
|
|
|
|
|
|
|
|
|
enum Filter {
|
|
|
|
|
glutenFree,
|
|
|
|
|
lactoseFree,
|
|
|
|
|
veggie,
|
|
|
|
|
vegan,
|
|
|
|
|
}
|
|
|
|
|
import 'dart:developer';
|
|
|
|
|
|
|
|
|
|
class FiltersScreen extends StatefulWidget {
|
|
|
|
|
final Map<Filter, bool> currentFilters;
|
|
|
|
|
|
|
|
|
|
const FiltersScreen({Key? key, required this.currentFilters})
|
|
|
|
|
: super(key: key);
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
State<FiltersScreen> createState() => _FiltersScreenState();
|
|
|
|
|
}
|
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
|
|
|
|
|
|
|
|
|
class _FiltersScreenState extends State<FiltersScreen> {
|
|
|
|
|
bool _glutenFreeFilterSet = false;
|
|
|
|
|
bool _lactoseFreeFilterSet = false;
|
|
|
|
|
bool _veggieFilterSet = false;
|
|
|
|
|
bool _veganFilterSet = false;
|
|
|
|
|
import '../providers/filters_provider.dart';
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
void initState() {
|
|
|
|
|
super.initState();
|
|
|
|
|
setState(() {
|
|
|
|
|
_glutenFreeFilterSet = widget.currentFilters[Filter.glutenFree]!;
|
|
|
|
|
_lactoseFreeFilterSet = widget.currentFilters[Filter.lactoseFree]!;
|
|
|
|
|
_veggieFilterSet = widget.currentFilters[Filter.veggie]!;
|
|
|
|
|
_veganFilterSet = widget.currentFilters[Filter.vegan]!;
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
class FiltersScreen extends ConsumerWidget {
|
|
|
|
|
const FiltersScreen({Key? key}) : super(key: key);
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
|
Widget build(BuildContext context, WidgetRef ref) {
|
|
|
|
|
return Scaffold(
|
|
|
|
|
appBar: AppBar(
|
|
|
|
|
title: const Text('Your filters'),
|
|
|
|
|
),
|
|
|
|
|
body: WillPopScope(
|
|
|
|
|
onWillPop: () async {
|
|
|
|
|
Navigator.of(context).pop({
|
|
|
|
|
Filter.glutenFree: _glutenFreeFilterSet,
|
|
|
|
|
Filter.lactoseFree: _lactoseFreeFilterSet,
|
|
|
|
|
Filter.veggie: _veggieFilterSet,
|
|
|
|
|
Filter.vegan: _veganFilterSet,
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
},
|
|
|
|
|
child: Column(
|
|
|
|
|
body: Column(
|
|
|
|
|
children: [
|
|
|
|
|
SwitchListTile(
|
|
|
|
|
value: _glutenFreeFilterSet,
|
|
|
|
|
onChanged: (checked) => setState(() {
|
|
|
|
|
_glutenFreeFilterSet = checked;
|
|
|
|
|
}),
|
|
|
|
|
value: ref.watch(filtersProvider)[Filter.glutenFree]!,
|
|
|
|
|
onChanged: (checked) => ref
|
|
|
|
|
.read(filtersProvider.notifier)
|
|
|
|
|
.setFilter(Filter.glutenFree, checked),
|
|
|
|
|
title: Text(
|
|
|
|
|
'Gluten free',
|
|
|
|
|
style: Theme.of(context).textTheme.titleLarge!.copyWith(
|
|
|
|
@ -74,10 +35,10 @@ class _FiltersScreenState extends State<FiltersScreen> {
|
|
|
|
|
contentPadding: const EdgeInsets.only(left: 34, right: 22),
|
|
|
|
|
),
|
|
|
|
|
SwitchListTile(
|
|
|
|
|
value: _lactoseFreeFilterSet,
|
|
|
|
|
onChanged: (checked) => setState(() {
|
|
|
|
|
_lactoseFreeFilterSet = checked;
|
|
|
|
|
}),
|
|
|
|
|
value: ref.watch(filtersProvider)[Filter.lactoseFree]!,
|
|
|
|
|
onChanged: (checked) => ref
|
|
|
|
|
.read(filtersProvider.notifier)
|
|
|
|
|
.setFilter(Filter.lactoseFree, checked),
|
|
|
|
|
title: Text(
|
|
|
|
|
'Lactose free',
|
|
|
|
|
style: Theme.of(context).textTheme.titleLarge!.copyWith(
|
|
|
|
@ -92,10 +53,10 @@ class _FiltersScreenState extends State<FiltersScreen> {
|
|
|
|
|
contentPadding: const EdgeInsets.only(left: 34, right: 22),
|
|
|
|
|
),
|
|
|
|
|
SwitchListTile(
|
|
|
|
|
value: _veggieFilterSet,
|
|
|
|
|
onChanged: (checked) => setState(() {
|
|
|
|
|
_veggieFilterSet = checked;
|
|
|
|
|
}),
|
|
|
|
|
value: ref.watch(filtersProvider)[Filter.veggie]!,
|
|
|
|
|
onChanged: (checked) => ref
|
|
|
|
|
.read(filtersProvider.notifier)
|
|
|
|
|
.setFilter(Filter.veggie, checked),
|
|
|
|
|
title: Text(
|
|
|
|
|
'Veggie',
|
|
|
|
|
style: Theme.of(context).textTheme.titleLarge!.copyWith(
|
|
|
|
@ -110,10 +71,10 @@ class _FiltersScreenState extends State<FiltersScreen> {
|
|
|
|
|
contentPadding: const EdgeInsets.only(left: 34, right: 22),
|
|
|
|
|
),
|
|
|
|
|
SwitchListTile(
|
|
|
|
|
value: _veganFilterSet,
|
|
|
|
|
onChanged: (checked) => setState(() {
|
|
|
|
|
_veganFilterSet = checked;
|
|
|
|
|
}),
|
|
|
|
|
value: ref.watch(filtersProvider)[Filter.vegan]!,
|
|
|
|
|
onChanged: (checked) => ref
|
|
|
|
|
.read(filtersProvider.notifier)
|
|
|
|
|
.setFilter(Filter.vegan, checked),
|
|
|
|
|
title: Text(
|
|
|
|
|
'Vegan',
|
|
|
|
|
style: Theme.of(context).textTheme.titleLarge!.copyWith(
|
|
|
|
@ -128,7 +89,6 @@ class _FiltersScreenState extends State<FiltersScreen> {
|
|
|
|
|
contentPadding: const EdgeInsets.only(left: 34, right: 22),
|
|
|
|
|
)
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|