import 'package:hooks_riverpod/hooks_riverpod.dart'; import 'package:immich_mobile/entities/album.entity.dart'; import 'package:immich_mobile/entities/asset.entity.dart'; import 'package:immich_mobile/entities/store.entity.dart'; import 'package:immich_mobile/entities/user.entity.dart'; import 'package:immich_mobile/interfaces/album.interface.dart'; import 'package:immich_mobile/models/albums/album_search.model.dart'; import 'package:immich_mobile/providers/db.provider.dart'; import 'package:immich_mobile/repositories/database.repository.dart'; import 'package:isar/isar.dart'; final albumRepositoryProvider = Provider((ref) => AlbumRepository(ref.watch(dbProvider))); class AlbumRepository extends DatabaseRepository implements IAlbumRepository { AlbumRepository(super.db); @override Future count({bool? local}) { final baseQuery = db.albums.where(); final QueryBuilder query; switch (local) { case null: query = baseQuery.noOp(); case true: query = baseQuery.localIdIsNotNull(); case false: query = baseQuery.remoteIdIsNotNull(); } return query.count(); } @override Future create(Album album) => txn(() => db.albums.store(album)); @override Future getByName(String name, {bool? shared, bool? remote}) { var query = db.albums.filter().nameEqualTo(name); if (shared != null) { query = query.sharedEqualTo(shared); } if (remote == true) { query = query.localIdIsNull(); } else if (remote == false) { query = query.remoteIdIsNull(); } return query.findFirst(); } @override Future update(Album album) => txn(() => db.albums.store(album)); @override Future delete(int albumId) => txn(() => db.albums.delete(albumId)); @override Future> getAll({ bool? shared, bool? remote, int? ownerId, AlbumSort? sortBy, }) { final baseQuery = db.albums.where(); final QueryBuilder afterWhere; if (remote == null) { afterWhere = baseQuery.noOp(); } else if (remote) { afterWhere = baseQuery.remoteIdIsNotNull(); } else { afterWhere = baseQuery.localIdIsNotNull(); } QueryBuilder filterQuery = afterWhere.filter().noOp(); if (shared != null) { filterQuery = filterQuery.sharedEqualTo(true); } if (ownerId != null) { filterQuery = filterQuery.owner((q) => q.isarIdEqualTo(ownerId)); } final QueryBuilder query; switch (sortBy) { case null: query = filterQuery.noOp(); case AlbumSort.remoteId: query = filterQuery.sortByRemoteId(); case AlbumSort.localId: query = filterQuery.sortByLocalId(); } return query.findAll(); } @override Future get(int id) => db.albums.get(id); @override Future removeUsers(Album album, List users) => txn(() => album.sharedUsers.update(unlink: users)); @override Future addAssets(Album album, List assets) => txn(() => album.assets.update(link: assets)); @override Future removeAssets(Album album, List assets) => txn(() => album.assets.update(unlink: assets)); @override Future recalculateMetadata(Album album) async { album.startDate = await album.assets.filter().fileCreatedAtProperty().min(); album.endDate = await album.assets.filter().fileCreatedAtProperty().max(); album.lastModifiedAssetTimestamp = await album.assets.filter().updatedAtProperty().max(); return album; } @override Future addUsers(Album album, List users) => txn(() => album.sharedUsers.update(link: users)); @override Future deleteAllLocal() => txn(() => db.albums.where().localIdIsNotNull().deleteAll()); @override Future> search( String searchTerm, QuickFilterMode filterMode, ) async { var query = db.albums .filter() .nameContains(searchTerm, caseSensitive: false) .remoteIdIsNotNull(); switch (filterMode) { case QuickFilterMode.sharedWithMe: query = query.owner( (q) => q.not().isarIdEqualTo(Store.get(StoreKey.currentUser).isarId), ); break; case QuickFilterMode.myAlbums: query = query.owner( (q) => q.isarIdEqualTo(Store.get(StoreKey.currentUser).isarId), ); break; case QuickFilterMode.all: default: break; } return await query.findAll(); } }