mirror of
https://github.com/immich-app/immich.git
synced 2025-09-29 15:31:13 -04:00
* feat(mobile): add album asset sync * add SyncAlbumToAssetDeleteV1 to openapi-spec * update delete queries to use where in statements * clear remote album when clear remote data * fix: bad merge * fix: bad merge * fix: _SyncAckV1 return type --------- Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com> Co-authored-by: wuzihao051119 <wuzihao051119@outlook.com> Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
46 lines
1.3 KiB
Dart
46 lines
1.3 KiB
Dart
import 'package:drift/drift.dart';
|
|
import 'package:immich_mobile/domain/models/album/album.model.dart';
|
|
import 'package:immich_mobile/infrastructure/entities/remote_album.entity.drift.dart';
|
|
import 'package:immich_mobile/infrastructure/repositories/db.repository.dart';
|
|
|
|
enum SortRemoteAlbumsBy { id }
|
|
|
|
class DriftRemoteAlbumRepository extends DriftDatabaseRepository {
|
|
final Drift _db;
|
|
const DriftRemoteAlbumRepository(this._db) : super(_db);
|
|
|
|
Future<List<Album>> getAll({Set<SortRemoteAlbumsBy> sortBy = const {}}) {
|
|
final query = _db.remoteAlbumEntity.select();
|
|
|
|
if (sortBy.isNotEmpty) {
|
|
final orderings = <OrderClauseGenerator<$RemoteAlbumEntityTable>>[];
|
|
for (final sort in sortBy) {
|
|
orderings.add(
|
|
switch (sort) {
|
|
SortRemoteAlbumsBy.id => (row) => OrderingTerm.asc(row.id),
|
|
},
|
|
);
|
|
}
|
|
query.orderBy(orderings);
|
|
}
|
|
|
|
return query.map((row) => row.toDto()).get();
|
|
}
|
|
}
|
|
|
|
extension on RemoteAlbumEntityData {
|
|
Album toDto() {
|
|
return Album(
|
|
id: id,
|
|
name: name,
|
|
ownerId: ownerId,
|
|
createdAt: createdAt,
|
|
updatedAt: updatedAt,
|
|
description: description,
|
|
thumbnailAssetId: thumbnailAssetId,
|
|
isActivityEnabled: isActivityEnabled,
|
|
order: order,
|
|
);
|
|
}
|
|
}
|