mirror of
https://github.com/immich-app/immich.git
synced 2025-01-04 10:56:47 +01:00
152 lines
4.5 KiB
Dart
152 lines
4.5 KiB
Dart
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<int> count({bool? local}) {
|
|
final baseQuery = db.albums.where();
|
|
final QueryBuilder<Album, Album, QAfterWhereClause> query;
|
|
switch (local) {
|
|
case null:
|
|
query = baseQuery.noOp();
|
|
case true:
|
|
query = baseQuery.localIdIsNotNull();
|
|
case false:
|
|
query = baseQuery.remoteIdIsNotNull();
|
|
}
|
|
return query.count();
|
|
}
|
|
|
|
@override
|
|
Future<Album> create(Album album) => txn(() => db.albums.store(album));
|
|
|
|
@override
|
|
Future<Album?> 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<Album> update(Album album) => txn(() => db.albums.store(album));
|
|
|
|
@override
|
|
Future<void> delete(int albumId) => txn(() => db.albums.delete(albumId));
|
|
|
|
@override
|
|
Future<List<Album>> getAll({
|
|
bool? shared,
|
|
bool? remote,
|
|
int? ownerId,
|
|
AlbumSort? sortBy,
|
|
}) {
|
|
final baseQuery = db.albums.where();
|
|
final QueryBuilder<Album, Album, QAfterWhereClause> afterWhere;
|
|
if (remote == null) {
|
|
afterWhere = baseQuery.noOp();
|
|
} else if (remote) {
|
|
afterWhere = baseQuery.remoteIdIsNotNull();
|
|
} else {
|
|
afterWhere = baseQuery.localIdIsNotNull();
|
|
}
|
|
QueryBuilder<Album, Album, QAfterFilterCondition> filterQuery =
|
|
afterWhere.filter().noOp();
|
|
if (shared != null) {
|
|
filterQuery = filterQuery.sharedEqualTo(true);
|
|
}
|
|
if (ownerId != null) {
|
|
filterQuery = filterQuery.owner((q) => q.isarIdEqualTo(ownerId));
|
|
}
|
|
final QueryBuilder<Album, Album, QAfterSortBy> 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<Album?> get(int id) => db.albums.get(id);
|
|
|
|
@override
|
|
Future<void> removeUsers(Album album, List<User> users) =>
|
|
txn(() => album.sharedUsers.update(unlink: users));
|
|
|
|
@override
|
|
Future<void> addAssets(Album album, List<Asset> assets) =>
|
|
txn(() => album.assets.update(link: assets));
|
|
|
|
@override
|
|
Future<void> removeAssets(Album album, List<Asset> assets) =>
|
|
txn(() => album.assets.update(unlink: assets));
|
|
|
|
@override
|
|
Future<Album> 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<void> addUsers(Album album, List<User> users) =>
|
|
txn(() => album.sharedUsers.update(link: users));
|
|
|
|
@override
|
|
Future<void> deleteAllLocal() =>
|
|
txn(() => db.albums.where().localIdIsNotNull().deleteAll());
|
|
|
|
@override
|
|
Future<List<Album>> 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();
|
|
}
|
|
}
|