diameter/lib/screens/meal/meal_category_detail.dart

153 lines
4.4 KiB
Dart
Raw Normal View History

2021-10-22 23:08:09 +00:00
import 'package:diameter/components/detail.dart';
import 'package:diameter/utils/dialog_utils.dart';
import 'package:diameter/components/forms/form_wrapper.dart';
import 'package:diameter/models/settings.dart';
2021-10-22 23:08:09 +00:00
import 'package:diameter/navigation.dart';
import 'package:flutter/material.dart';
import 'package:diameter/models/meal_category.dart';
class MealCategoryDetailScreen extends StatefulWidget {
static const String routeName = '/meal-category';
final int id;
2021-10-22 23:08:09 +00:00
const MealCategoryDetailScreen({Key? key, this.id = 0}) : super(key: key);
2021-10-22 23:08:09 +00:00
@override
_MealCategoryDetailScreenState createState() =>
_MealCategoryDetailScreenState();
}
class _MealCategoryDetailScreenState extends State<MealCategoryDetailScreen> {
MealCategory? _mealCategory;
bool _isNew = true;
2021-10-22 23:08:09 +00:00
final GlobalKey<FormState> _mealCategoryForm = GlobalKey<FormState>();
2021-12-09 05:14:55 +00:00
final ScrollController _scrollController = ScrollController();
2021-10-22 23:08:09 +00:00
final _valueController = TextEditingController(text: '');
final _notesController = TextEditingController(text: '');
@override
void initState() {
super.initState();
reload();
if (_mealCategory != null) {
_valueController.text = _mealCategory!.value;
_notesController.text = _mealCategory!.notes ?? '';
2021-10-22 23:08:09 +00:00
}
}
@override
void dispose() {
_scrollController.dispose();
_valueController.dispose();
_notesController.dispose();
super.dispose();
}
2021-12-09 05:14:55 +00:00
void reload({String? message}) {
if (widget.id != 0) {
setState(() {
_mealCategory = MealCategory.get(widget.id);
});
}
_isNew = _mealCategory == null;
2021-12-09 05:14:55 +00:00
setState(() {
if (message != null) {
var snackBar = SnackBar(
content: Text(message),
duration: const Duration(seconds: 2),
);
ScaffoldMessenger.of(context)
..removeCurrentSnackBar()
..showSnackBar(snackBar);
}
});
}
2021-10-22 23:08:09 +00:00
void handleSaveAction() async {
if (_mealCategoryForm.currentState!.validate()) {
2021-12-09 05:14:55 +00:00
MealCategory mealCategory = MealCategory(
id: widget.id,
value: _valueController.text,
2021-12-09 05:14:55 +00:00
notes: _notesController.text,
);
MealCategory.put(mealCategory);
Navigator.pop(context, [
'${_isNew ? 'New' : ''} Meal Category saved', mealCategory
]);
2021-10-22 23:08:09 +00:00
}
}
void handleCancelAction() {
if (Settings.get().showConfirmationDialogOnCancel &&
(_isNew &&
2021-10-22 23:08:09 +00:00
(_valueController.text != '' || _notesController.text != '')) ||
(!_isNew &&
(_mealCategory!.value != _valueController.text ||
(_mealCategory!.notes ?? '') != _notesController.text))) {
DialogUtils.showCancelConfirmationDialog(
2021-10-22 23:08:09 +00:00
context: context,
isNew: _isNew,
2021-10-22 23:08:09 +00:00
onSave: handleSaveAction,
);
} else {
Navigator.pop(context);
}
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(_isNew ? 'New Meal Category' : _mealCategory!.value),
2021-10-22 23:08:09 +00:00
),
drawer:
const Navigation(currentLocation: MealCategoryDetailScreen.routeName),
2021-12-09 05:14:55 +00:00
body: Scrollbar(
controller: _scrollController,
child: SingleChildScrollView(
controller: _scrollController,
child: Column(
crossAxisAlignment: CrossAxisAlignment.stretch,
children: <Widget>[
FormWrapper(
formState: _mealCategoryForm,
fields: [
TextFormField(
controller: _valueController,
decoration: const InputDecoration(
labelText: 'Name',
),
validator: (value) {
if (value!.trim().isEmpty) {
return 'Empty name';
}
return null;
},
2021-10-22 23:08:09 +00:00
),
2021-12-09 05:14:55 +00:00
TextFormField(
controller: _notesController,
decoration: const InputDecoration(
labelText: 'Notes',
),
keyboardType: TextInputType.multiline,
minLines: 2,
maxLines: 5,
2021-10-22 23:08:09 +00:00
),
2021-12-09 05:14:55 +00:00
],
),
],
),
2021-10-22 23:08:09 +00:00
),
),
bottomNavigationBar: DetailBottomRow(
onCancel: handleCancelAction,
2021-12-10 05:42:20 +00:00
onAction: handleSaveAction,
2021-10-22 23:08:09 +00:00
),
);
}
}