47 lines
1.5 KiB
Dart
47 lines
1.5 KiB
Dart
import 'package:drift/drift.dart';
|
|
import 'package:trainhub_flutter/data/database/app_database.dart';
|
|
|
|
part 'analysis_dao.g.dart';
|
|
|
|
@DriftAccessor(tables: [AnalysisSessions, Annotations])
|
|
class AnalysisDao extends DatabaseAccessor<AppDatabase>
|
|
with _$AnalysisDaoMixin {
|
|
AnalysisDao(super.db);
|
|
|
|
Future<List<AnalysisSession>> getAllSessions() =>
|
|
select(analysisSessions).get();
|
|
|
|
Future<AnalysisSession?> getSession(String id) =>
|
|
(select(analysisSessions)..where((t) => t.id.equals(id)))
|
|
.getSingleOrNull();
|
|
|
|
Future<void> insertSession(AnalysisSessionsCompanion entry) =>
|
|
into(analysisSessions).insert(entry);
|
|
|
|
Future<void> deleteSession(String id) =>
|
|
(delete(analysisSessions)..where((t) => t.id.equals(id))).go();
|
|
|
|
Future<List<Annotation>> getAnnotations(String sessionId) =>
|
|
(select(annotations)..where((t) => t.sessionId.equals(sessionId))).get();
|
|
|
|
Future<void> insertAnnotation(AnnotationsCompanion entry) =>
|
|
into(annotations).insert(entry);
|
|
|
|
Future<void> updateAnnotation({
|
|
required String id,
|
|
required String name,
|
|
required String description,
|
|
required String color,
|
|
}) =>
|
|
(update(annotations)..where((t) => t.id.equals(id))).write(
|
|
AnnotationsCompanion(
|
|
name: Value(name),
|
|
description: Value(description),
|
|
color: Value(color),
|
|
),
|
|
);
|
|
|
|
Future<void> deleteAnnotation(String id) =>
|
|
(delete(annotations)..where((t) => t.id.equals(id))).go();
|
|
}
|