mirror of
https://github.com/wger-project/flutter.git
synced 2026-02-18 00:17:48 +01:00
handleUpdateExerciseFromApi should now be faster and save up on some requests. Ideally we would pre-populate the database with all exercises on first run, or even just ship it pre-filled
86 lines
2.4 KiB
Dart
86 lines
2.4 KiB
Dart
import 'dart:io';
|
|
|
|
import 'package:drift/drift.dart';
|
|
import 'package:drift/native.dart';
|
|
import 'package:path/path.dart' as p;
|
|
import 'package:path_provider/path_provider.dart';
|
|
import 'package:wger/database/exercises/type_converters.dart';
|
|
import 'package:wger/models/exercises/category.dart';
|
|
import 'package:wger/models/exercises/equipment.dart';
|
|
import 'package:wger/models/exercises/language.dart';
|
|
import 'package:wger/models/exercises/muscle.dart';
|
|
|
|
part 'exercise_database.g.dart';
|
|
|
|
@DataClassName('ExerciseTable')
|
|
class Exercises extends Table {
|
|
IntColumn get id => integer()();
|
|
|
|
TextColumn get data => text()();
|
|
|
|
// TextColumn get data => text().map(const ExerciseBaseConverter())();
|
|
|
|
DateTimeColumn get lastUpdate => dateTime()();
|
|
|
|
/// The date when the exercise was last fetched from the API. While we know
|
|
/// when the exercise itself was last updated in `lastUpdate`, we can save
|
|
/// ourselves a lot of requests if we don't check too often
|
|
DateTimeColumn get lastFetched => dateTime()();
|
|
}
|
|
|
|
@DataClassName('MuscleTable')
|
|
class Muscles extends Table {
|
|
IntColumn get id => integer()();
|
|
|
|
TextColumn get data => text().map(const MuscleConverter())();
|
|
}
|
|
|
|
@DataClassName('CategoryTable')
|
|
class Categories extends Table {
|
|
IntColumn get id => integer()();
|
|
|
|
TextColumn get data => text().map(const ExerciseCategoryConverter())();
|
|
}
|
|
|
|
@DataClassName('LanguagesTable')
|
|
class Languages extends Table {
|
|
IntColumn get id => integer()();
|
|
|
|
TextColumn get data => text().map(const LanguageConverter())();
|
|
}
|
|
|
|
@DataClassName('EquipmentTable')
|
|
class Equipments extends Table {
|
|
IntColumn get id => integer()();
|
|
|
|
TextColumn get data => text().map(const EquipmentConverter())();
|
|
}
|
|
|
|
@DriftDatabase(tables: [Exercises, Muscles, Equipments, Categories, Languages])
|
|
class ExerciseDatabase extends _$ExerciseDatabase {
|
|
ExerciseDatabase() : super(_openConnection());
|
|
|
|
// Named constructor for creating in-memory database
|
|
ExerciseDatabase.inMemory(super.e);
|
|
|
|
@override
|
|
// TODO: implement schemaVersion
|
|
int get schemaVersion => 1;
|
|
|
|
Future<void> deleteEverything() {
|
|
return transaction(() async {
|
|
for (final table in allTables) {
|
|
await delete(table).go();
|
|
}
|
|
});
|
|
}
|
|
}
|
|
|
|
LazyDatabase _openConnection() {
|
|
return LazyDatabase(() async {
|
|
final dbFolder = await getApplicationDocumentsDirectory();
|
|
final file = File(p.join(dbFolder.path, 'exercises.sqlite'));
|
|
return NativeDatabase.createInBackground(file);
|
|
});
|
|
}
|