2024-09-08 15:07:39 +02:00
|
|
|
import 'package:calorimeter/utils/enter_food_controller.dart';
|
2024-09-06 19:00:25 +02:00
|
|
|
import 'package:calorimeter/storage/storage.dart';
|
2024-05-30 00:58:26 +02:00
|
|
|
import 'package:flutter/material.dart';
|
2024-09-06 19:00:25 +02:00
|
|
|
import 'package:calorimeter/food_entry/food_entry_bloc.dart';
|
2024-09-06 18:51:24 +02:00
|
|
|
import 'package:calorimeter/utils/row_with_spacers_widget.dart';
|
2024-09-07 00:02:01 +02:00
|
|
|
import 'package:provider/provider.dart';
|
2024-05-30 00:58:26 +02:00
|
|
|
|
|
|
|
class EnterFoodWidget extends StatefulWidget {
|
2024-06-09 19:06:10 +02:00
|
|
|
final Function(BuildContext context, FoodEntry entry) onAdd;
|
|
|
|
|
|
|
|
const EnterFoodWidget({super.key, required this.onAdd});
|
2024-05-30 00:58:26 +02:00
|
|
|
|
|
|
|
@override
|
|
|
|
State<EnterFoodWidget> createState() => _EnterFoodWidgetState();
|
|
|
|
}
|
|
|
|
|
|
|
|
class _EnterFoodWidgetState extends State<EnterFoodWidget> {
|
2024-09-07 00:02:01 +02:00
|
|
|
late TextEditingController nameController;
|
|
|
|
late TextEditingController massController;
|
|
|
|
late TextEditingController kcalPerMassController;
|
|
|
|
late Map<String, double> suggestions;
|
2024-09-04 22:47:32 +02:00
|
|
|
|
|
|
|
@override
|
|
|
|
void initState() {
|
2024-09-07 00:02:01 +02:00
|
|
|
nameController = TextEditingController();
|
|
|
|
massController = TextEditingController();
|
|
|
|
kcalPerMassController = TextEditingController();
|
2024-09-04 22:47:32 +02:00
|
|
|
suggestions = FoodStorage.getInstance().getFoodEntryLookupDatabase;
|
2024-09-07 00:02:01 +02:00
|
|
|
|
2024-09-04 22:47:32 +02:00
|
|
|
super.initState();
|
|
|
|
}
|
2024-06-01 12:41:58 +02:00
|
|
|
|
2024-05-30 00:58:26 +02:00
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
2024-09-07 01:38:03 +02:00
|
|
|
return Consumer<EnterFoodController>(
|
2024-09-07 00:02:01 +02:00
|
|
|
builder: (context, food, child) {
|
|
|
|
nameController.text = food.name;
|
|
|
|
kcalPerMassController.text = food.kcalPer100g;
|
|
|
|
|
|
|
|
return Padding(
|
|
|
|
padding: const EdgeInsets.symmetric(horizontal: 8.0),
|
|
|
|
child: RowWidget(
|
|
|
|
Autocomplete<String>(
|
|
|
|
optionsViewOpenDirection: OptionsViewOpenDirection.down,
|
|
|
|
fieldViewBuilder:
|
|
|
|
(context, controller, focusNode, onSubmitted) {
|
|
|
|
nameController = controller;
|
|
|
|
return TextFormField(
|
|
|
|
controller: controller,
|
|
|
|
focusNode: focusNode,
|
|
|
|
decoration: const InputDecoration(
|
|
|
|
label: Text("Name"),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
},
|
|
|
|
optionsBuilder: (TextEditingValue textEditingValue) {
|
|
|
|
if (textEditingValue.text == '') {
|
|
|
|
return const Iterable<String>.empty();
|
|
|
|
}
|
|
|
|
|
|
|
|
return suggestions.keys.where(
|
|
|
|
(name) {
|
|
|
|
return name
|
|
|
|
.toLowerCase()
|
|
|
|
.contains(textEditingValue.text.toLowerCase());
|
|
|
|
},
|
|
|
|
);
|
|
|
|
},
|
|
|
|
onSelected: (selectedFood) {
|
|
|
|
double kcalPerMassForSelectedFood =
|
|
|
|
suggestions[selectedFood]!;
|
|
|
|
context
|
2024-09-07 01:38:03 +02:00
|
|
|
.read<EnterFoodController>()
|
2024-09-07 00:02:01 +02:00
|
|
|
.set(selectedFood, kcalPerMassForSelectedFood.toString());
|
|
|
|
}),
|
|
|
|
TextField(
|
|
|
|
textAlign: TextAlign.end,
|
|
|
|
decoration: const InputDecoration(
|
|
|
|
label: Align(
|
|
|
|
alignment: Alignment.centerRight, child: Text("Menge")),
|
|
|
|
),
|
|
|
|
keyboardType: TextInputType.number,
|
|
|
|
controller: massController,
|
|
|
|
onSubmitted: (value) => onSubmitAction(),
|
2024-09-06 02:23:47 +02:00
|
|
|
),
|
2024-09-07 00:02:01 +02:00
|
|
|
TextField(
|
|
|
|
textAlign: TextAlign.end,
|
|
|
|
decoration: const InputDecoration(
|
|
|
|
label: Align(
|
|
|
|
alignment: Alignment.centerRight,
|
|
|
|
child: Text("kcal pro"))),
|
|
|
|
keyboardType: TextInputType.number,
|
|
|
|
controller: kcalPerMassController,
|
|
|
|
onSubmitted: (value) => onSubmitAction(),
|
|
|
|
),
|
|
|
|
Padding(
|
|
|
|
padding: const EdgeInsets.only(left: 16.0),
|
|
|
|
child: ElevatedButton(
|
|
|
|
style: ElevatedButton.styleFrom(
|
|
|
|
padding: EdgeInsets.zero,
|
|
|
|
),
|
|
|
|
onPressed: () => onSubmitAction(),
|
|
|
|
child: const Icon(Icons.add)),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
},
|
2024-05-30 00:58:26 +02:00
|
|
|
);
|
|
|
|
}
|
2024-09-06 02:23:47 +02:00
|
|
|
|
|
|
|
void onSubmitAction() {
|
|
|
|
double massAsNumber = 0.0;
|
|
|
|
double kcalPerMassAsNumber = 0.0;
|
|
|
|
|
|
|
|
try {
|
|
|
|
massAsNumber = double.parse(massController.text.replaceAll(",", "."));
|
|
|
|
} catch (e) {
|
|
|
|
var snackbar = const SnackBar(content: Text("Menge muss eine Zahl sein"));
|
|
|
|
ScaffoldMessenger.of(context).clearSnackBars();
|
|
|
|
ScaffoldMessenger.of(context).showSnackBar(snackbar);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
kcalPerMassAsNumber =
|
|
|
|
double.parse(kcalPerMassController.text.replaceAll(",", "."));
|
|
|
|
} catch (e) {
|
|
|
|
var snackbar =
|
|
|
|
const SnackBar(content: Text("'kcal pro 100g' muss eine Zahl sein"));
|
|
|
|
ScaffoldMessenger.of(context).clearSnackBars();
|
|
|
|
ScaffoldMessenger.of(context).showSnackBar(snackbar);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
var entry = FoodEntry(
|
|
|
|
name: nameController.text,
|
|
|
|
mass: massAsNumber,
|
|
|
|
kcalPerMass: kcalPerMassAsNumber);
|
|
|
|
|
|
|
|
widget.onAdd(context, entry);
|
2024-09-07 01:38:03 +02:00
|
|
|
context.read<EnterFoodController>().set("", "");
|
2024-09-06 02:23:47 +02:00
|
|
|
}
|
2024-05-30 00:58:26 +02:00
|
|
|
}
|