2023-07-29 19:21:02 +02:00
|
|
|
import 'package:flutter/material.dart';
|
2023-07-30 15:31:36 +02:00
|
|
|
import 'package:fooder/models/diary.dart';
|
|
|
|
import 'package:fooder/widgets/meal.dart';
|
|
|
|
import 'package:fooder/widgets/macro.dart';
|
|
|
|
import 'package:fooder/client.dart';
|
|
|
|
import 'package:fooder/screens/add_meal.dart';
|
2023-07-29 19:21:02 +02:00
|
|
|
import 'dart:core';
|
|
|
|
|
|
|
|
class DiaryWidget extends StatelessWidget {
|
|
|
|
final Diary diary;
|
2023-07-30 13:09:41 +02:00
|
|
|
final ApiClient apiClient;
|
|
|
|
final Function() refreshParent;
|
2023-07-29 19:21:02 +02:00
|
|
|
|
2023-08-28 14:45:32 +02:00
|
|
|
const DiaryWidget(
|
|
|
|
{super.key,
|
|
|
|
required this.diary,
|
|
|
|
required this.apiClient,
|
|
|
|
required this.refreshParent});
|
2023-07-29 19:21:02 +02:00
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return Container(
|
|
|
|
padding: const EdgeInsets.all(8),
|
2023-07-30 13:09:41 +02:00
|
|
|
child: CustomScrollView(
|
|
|
|
slivers: <Widget>[
|
|
|
|
SliverAppBar(
|
2023-08-28 14:45:32 +02:00
|
|
|
title: Row(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
|
|
children: <Widget>[
|
|
|
|
const Spacer(),
|
|
|
|
Text(
|
|
|
|
"${diary.calories.toStringAsFixed(1)} kcal",
|
|
|
|
style: Theme.of(context)
|
|
|
|
.textTheme
|
|
|
|
.headlineLarge!
|
|
|
|
.copyWith(
|
|
|
|
color: Theme.of(context).colorScheme.onSecondary,
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
]),
|
|
|
|
expandedHeight: 150,
|
|
|
|
backgroundColor: Theme.of(context).colorScheme.secondary,
|
|
|
|
shape: RoundedRectangleBorder(
|
|
|
|
borderRadius: BorderRadius.circular(8),
|
|
|
|
),
|
|
|
|
floating: true,
|
|
|
|
flexibleSpace: FlexibleSpaceBar(
|
|
|
|
title: MacroWidget(
|
2023-07-30 14:40:45 +02:00
|
|
|
protein: diary.protein,
|
|
|
|
carb: diary.carb,
|
|
|
|
fat: diary.fat,
|
|
|
|
style: Theme.of(context).textTheme.bodyMedium!.copyWith(
|
2023-08-28 14:45:32 +02:00
|
|
|
color: Theme.of(context).colorScheme.onSecondary,
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
),
|
2023-07-30 13:09:41 +02:00
|
|
|
),
|
2023-08-28 14:45:32 +02:00
|
|
|
)),
|
2023-10-27 20:06:41 +02:00
|
|
|
SliverToBoxAdapter(
|
2023-10-27 20:16:16 +02:00
|
|
|
child: Container(
|
|
|
|
padding: const EdgeInsets.all(8),
|
2023-10-27 20:06:41 +02:00
|
|
|
child: TextButton(
|
|
|
|
onPressed: () {
|
|
|
|
Navigator.push(
|
|
|
|
context,
|
|
|
|
MaterialPageRoute(
|
|
|
|
builder: (context) => AddMealScreen(
|
|
|
|
apiClient: apiClient,
|
|
|
|
diary: diary,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
).then((_) {
|
|
|
|
refreshParent();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
child: const Text("Add Meal"),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
2023-07-30 13:09:41 +02:00
|
|
|
SliverList(
|
|
|
|
delegate: SliverChildListDelegate(
|
|
|
|
[
|
2024-03-29 16:47:25 +01:00
|
|
|
for (var (i, meal) in diary.meals.indexed)
|
2023-07-30 13:09:41 +02:00
|
|
|
MealWidget(
|
|
|
|
meal: meal,
|
|
|
|
apiClient: apiClient,
|
|
|
|
refreshParent: refreshParent,
|
2024-03-29 16:47:25 +01:00
|
|
|
initiallyExpanded: i == 0,
|
2023-08-28 14:45:32 +02:00
|
|
|
),
|
2023-07-30 13:09:41 +02:00
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
2023-07-29 19:21:02 +02:00
|
|
|
],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|