mirror of
https://github.com/wger-project/flutter.git
synced 2026-02-18 00:17:48 +01:00
54 lines
1.4 KiB
Dart
54 lines
1.4 KiB
Dart
import 'package:drift/drift.dart';
|
|
import 'package:drift_sqlite_async/drift_sqlite_async.dart';
|
|
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
|
import 'package:powersync/powersync.dart' show uuid;
|
|
import 'package:wger/database/weight/database.dart';
|
|
import 'package:wger/models/body_weight/weight_entry.dart';
|
|
|
|
import 'powersync.dart';
|
|
|
|
part 'database.g.dart';
|
|
|
|
@DriftDatabase(
|
|
tables: [
|
|
WeightEntryTable,
|
|
],
|
|
//include: {'queries.drift'},
|
|
)
|
|
class AppDatabase extends _$AppDatabase {
|
|
AppDatabase(super.e);
|
|
|
|
@override
|
|
int get schemaVersion => 1;
|
|
|
|
@override
|
|
MigrationStrategy get migration {
|
|
return MigrationStrategy(
|
|
onCreate: (m) async {
|
|
// We don't have to call createAll(), PowerSync instantiates the schema
|
|
// for us. We can use the opportunity to create fts5 indexes though.
|
|
},
|
|
onUpgrade: (m, from, to) async {
|
|
if (from == 1) {
|
|
// await createFts5Tables(
|
|
// db: this,
|
|
// tableName: 'todos',
|
|
// columns: ['description', 'list_id'],
|
|
// );
|
|
}
|
|
},
|
|
);
|
|
}
|
|
}
|
|
|
|
final driftPowerSyncDatabase = Provider((ref) {
|
|
return AppDatabase(
|
|
DatabaseConnection.delayed(
|
|
Future(() async {
|
|
final database = await ref.read(powerSyncInstanceProvider.future);
|
|
return SqliteAsyncDriftConnection(database);
|
|
}),
|
|
),
|
|
);
|
|
});
|