Ensure days + exercises are selected for new plan

This commit is contained in:
Brandon Presley 2023-11-30 13:10:28 +13:00
parent 9aed2b3ac1
commit 8678e935df

View File

@ -78,7 +78,8 @@ class _EditPlanPageState extends State<EditPlanPage> {
Widget build(BuildContext context) { Widget build(BuildContext context) {
List<Widget> actions = []; List<Widget> actions = [];
if (widget.plan.id.present) if (widget.plan.id.present)
actions.add(IconButton( actions.add(
IconButton(
onPressed: () async { onPressed: () async {
bool? confirm = await _showConfirmationDialog(context); bool? confirm = await _showConfirmationDialog(context);
if (!confirm!) return; if (!confirm!) return;
@ -86,47 +87,63 @@ class _EditPlanPageState extends State<EditPlanPage> {
if (!mounted) return; if (!mounted) return;
Navigator.pop(context); Navigator.pop(context);
}, },
icon: const Icon(Icons.delete),),); icon: const Icon(Icons.delete),
),
);
return SafeArea( return SafeArea(
child: Scaffold( child: Scaffold(
appBar: AppBar(title: const Text('Edit Plan'), actions: actions), appBar: AppBar(title: const Text('Edit Plan'), actions: actions),
body: Padding( body: Padding(
padding: const EdgeInsets.all(16.0), padding: const EdgeInsets.all(16.0),
child: material.Column( child: material.Column(
crossAxisAlignment: CrossAxisAlignment.start, crossAxisAlignment: CrossAxisAlignment.start,
children: getChildren, children: getChildren,
),
),
floatingActionButton: FloatingActionButton(
onPressed: () async {
final days = [];
for (int i = 0; i < daySelections!.length; i++) {
if (daySelections![i]) days.add(weekdayNames[i]);
}
if (days.isEmpty) {
ScaffoldMessenger.of(context).showSnackBar(
const SnackBar(content: Text('Select days first')),
);
return;
}
final exercises = [];
for (int i = 0; i < exerciseSelections!.length; i++) {
if (exerciseSelections![i]) exercises.add(names[i]);
}
if (exercises.isEmpty) {
ScaffoldMessenger.of(context).showSnackBar(
const SnackBar(content: Text('Select exercises first')),
);
return;
}
var newPlan = widget.plan.copyWith(
days: Value(days.join(',')),
exercises: Value(exercises.join(',')),
);
if (widget.plan.id.present)
await db.update(db.plans).replace(newPlan);
else {
final id = await db.into(db.plans).insert(newPlan);
newPlan = newPlan.copyWith(id: Value(id));
}
if (!mounted) return;
Navigator.pop(context);
},
child: const Icon(Icons.check),
), ),
), ),
floatingActionButton: FloatingActionButton( );
onPressed: () async {
final days = [];
for (int i = 0; i < daySelections!.length; i++) {
if (daySelections![i]) days.add(weekdayNames[i]);
}
final exercises = [];
for (int i = 0; i < exerciseSelections!.length; i++) {
if (exerciseSelections![i]) exercises.add(names[i]);
}
var newPlan = widget.plan.copyWith(
days: Value(days.join(',')),
exercises: Value(exercises.join(',')),);
if (widget.plan.id.present)
await db.update(db.plans).replace(newPlan);
else {
final id = await db.into(db.plans).insert(newPlan);
newPlan = newPlan.copyWith(id: Value(id));
}
if (!mounted) return;
Navigator.pop(context);
},
child: const Icon(Icons.check),
),
),);
} }
List<Widget> get getChildren { List<Widget> get getChildren {
@ -166,9 +183,10 @@ class _EditPlanPageState extends State<EditPlanPage> {
return [ return [
Expanded( Expanded(
child: ListView( child: ListView(
children: children, children: children,
),), ),
),
]; ];
} }
} }