mirror of
https://github.com/wger-project/flutter.git
synced 2026-02-19 07:50:52 +01:00
145 lines
4.3 KiB
Dart
145 lines
4.3 KiB
Dart
/*
|
|
* This file is part of wger Workout Manager <https://github.com/wger-project>.
|
|
* Copyright (C) 2020, 2021 wger Team
|
|
*
|
|
* wger Workout Manager is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
import 'package:json_annotation/json_annotation.dart';
|
|
import 'package:powersync/powersync.dart';
|
|
import 'package:powersync/sqlite3.dart' as sqlite;
|
|
import 'package:wger/helpers/json.dart';
|
|
import 'package:wger/models/nutrition/ingredient.dart';
|
|
import 'package:wger/models/nutrition/ingredient_weight_unit.dart';
|
|
import 'package:wger/models/nutrition/meal_item.dart';
|
|
import 'package:wger/models/nutrition/nutritional_values.dart';
|
|
import 'package:wger/models/schema.dart';
|
|
import 'package:wger/powersync.dart';
|
|
|
|
part 'log.g.dart';
|
|
|
|
@JsonSerializable()
|
|
class Log {
|
|
@JsonKey(required: true)
|
|
String? id;
|
|
|
|
@JsonKey(required: false, name: 'meal')
|
|
String? mealId;
|
|
|
|
@JsonKey(required: true, name: 'plan')
|
|
String planId;
|
|
|
|
@JsonKey(required: true, toJson: dateToUtcIso8601)
|
|
late DateTime datetime;
|
|
|
|
String? comment;
|
|
|
|
@JsonKey(required: true, name: 'ingredient')
|
|
late int ingredientId;
|
|
|
|
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
late Ingredient ingredient;
|
|
|
|
@JsonKey(required: true, name: 'weight_unit')
|
|
int? weightUnitId;
|
|
|
|
@JsonKey(includeFromJson: false, includeToJson: false)
|
|
IngredientWeightUnit? weightUnitObj;
|
|
|
|
@JsonKey(required: true, fromJson: stringToNum)
|
|
late num amount;
|
|
|
|
Log({
|
|
this.id,
|
|
required this.mealId,
|
|
required this.ingredientId,
|
|
required this.weightUnitId,
|
|
required this.amount,
|
|
required this.planId,
|
|
required this.datetime,
|
|
this.comment,
|
|
});
|
|
|
|
Log.fromMealItem(MealItem mealItem, this.planId, this.mealId, [DateTime? dateTime]) {
|
|
ingredientId = mealItem.ingredientId;
|
|
ingredient = mealItem.ingredient;
|
|
weightUnitId = mealItem.weightUnitId;
|
|
datetime = dateTime ?? DateTime.now();
|
|
amount = mealItem.amount;
|
|
}
|
|
|
|
factory Log.fromRow(sqlite.Row row) {
|
|
return Log(
|
|
id: row['id'],
|
|
mealId: row['meal_id'],
|
|
ingredientId: row['ingredient_id'],
|
|
weightUnitId: row['weight_unit_id'],
|
|
amount: row['amount'],
|
|
planId: row['plan_id'],
|
|
datetime: DateTime.parse(row['datetime']),
|
|
comment: row['comment'],
|
|
);
|
|
}
|
|
|
|
// Boilerplate
|
|
factory Log.fromJson(Map<String, dynamic> json) => _$LogFromJson(json);
|
|
|
|
Map<String, dynamic> toJson() => _$LogToJson(this);
|
|
|
|
/// Calculations
|
|
NutritionalValues get nutritionalValues {
|
|
// This is already done on the server. It might be better to read it from there.
|
|
|
|
final weight = weightUnitObj == null
|
|
? amount
|
|
: amount * weightUnitObj!.amount * weightUnitObj!.grams;
|
|
|
|
return ingredient.nutritionalValues / (100 / weight);
|
|
}
|
|
|
|
static Future<List<Log>> readByMealId(String mealId) async {
|
|
final results = await db.getAll('SELECT * FROM $tableLogItems WHERE meal_id = ?', [mealId]);
|
|
return results.map((r) => Log.fromRow(r)).toList();
|
|
}
|
|
|
|
static Future<List<Log>> readByPlanId(String planId) async {
|
|
final results = await db.getAll('SELECT * FROM $tableLogItems WHERE plan_id = ?', [planId]);
|
|
return results.map((r) => Log.fromRow(r)).toList();
|
|
}
|
|
|
|
/*
|
|
Future<void> delete() async {
|
|
await db.execute('DELETE FROM $logItemsTable WHERE id = ?', [id]);
|
|
}
|
|
*/
|
|
|
|
Future<void> log() async {
|
|
print('DIETER Log.log called id=$id, planId=$planId');
|
|
await db.execute(
|
|
'INSERT INTO $tableLogItems (id, meal_id, ingredient_id, weight_unit_id, amount, plan_id, datetime, comment) VALUES (?, ?, ?, ?, ?, ?, ?, ?)',
|
|
[
|
|
// generate an id using uuid
|
|
uuid.v4(),
|
|
mealId,
|
|
ingredientId,
|
|
weightUnitId,
|
|
amount,
|
|
planId,
|
|
datetime.toIso8601String(),
|
|
comment,
|
|
],
|
|
);
|
|
}
|
|
}
|