mirror of
https://github.com/immich-app/immich.git
synced 2025-01-10 13:56:47 +01:00
131 lines
3.6 KiB
Dart
131 lines
3.6 KiB
Dart
import 'package:flutter/foundation.dart';
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
import 'package:immich_mobile/modules/home/services/asset.service.dart';
|
|
import 'package:immich_mobile/modules/home/services/asset_cache.service.dart';
|
|
import 'package:immich_mobile/shared/services/device_info.service.dart';
|
|
import 'package:collection/collection.dart';
|
|
import 'package:intl/intl.dart';
|
|
import 'package:openapi/api.dart';
|
|
import 'package:photo_manager/photo_manager.dart';
|
|
|
|
class AssetNotifier extends StateNotifier<List<AssetResponseDto>> {
|
|
final AssetService _assetService;
|
|
final AssetCacheService _assetCacheService;
|
|
|
|
final DeviceInfoService _deviceInfoService = DeviceInfoService();
|
|
|
|
AssetNotifier(this._assetService, this._assetCacheService) : super([]);
|
|
|
|
_cacheState() {
|
|
_assetCacheService.put(state);
|
|
}
|
|
|
|
getAllAsset() async {
|
|
final stopwatch = Stopwatch();
|
|
|
|
|
|
if (await _assetCacheService.isValid() && state.isEmpty) {
|
|
stopwatch.start();
|
|
state = await _assetCacheService.get();
|
|
debugPrint("Reading assets from cache: ${stopwatch.elapsedMilliseconds}ms");
|
|
stopwatch.reset();
|
|
}
|
|
|
|
stopwatch.start();
|
|
var allAssets = await _assetService.getAllAsset();
|
|
debugPrint("Query assets from API: ${stopwatch.elapsedMilliseconds}ms");
|
|
stopwatch.reset();
|
|
|
|
if (allAssets != null) {
|
|
state = allAssets;
|
|
|
|
stopwatch.start();
|
|
_cacheState();
|
|
debugPrint("Store assets in cache: ${stopwatch.elapsedMilliseconds}ms");
|
|
stopwatch.reset();
|
|
}
|
|
}
|
|
|
|
clearAllAsset() {
|
|
state = [];
|
|
_cacheState();
|
|
}
|
|
|
|
onNewAssetUploaded(AssetResponseDto newAsset) {
|
|
state = [...state, newAsset];
|
|
_cacheState();
|
|
}
|
|
|
|
deleteAssets(Set<AssetResponseDto> deleteAssets) async {
|
|
var deviceInfo = await _deviceInfoService.getDeviceInfo();
|
|
var deviceId = deviceInfo["deviceId"];
|
|
var deleteIdList = <String>[];
|
|
// Delete asset from device
|
|
for (var asset in deleteAssets) {
|
|
// Delete asset on device if present
|
|
if (asset.deviceId == deviceId) {
|
|
var localAsset = await AssetEntity.fromId(asset.deviceAssetId);
|
|
|
|
if (localAsset != null) {
|
|
deleteIdList.add(localAsset.id);
|
|
}
|
|
}
|
|
}
|
|
|
|
try {
|
|
await PhotoManager.editor.deleteWithIds(deleteIdList);
|
|
} catch (e) {
|
|
debugPrint("Delete asset from device failed: $e");
|
|
}
|
|
|
|
// Delete asset on server
|
|
List<DeleteAssetResponseDto>? deleteAssetResult =
|
|
await _assetService.deleteAssets(deleteAssets);
|
|
|
|
if (deleteAssetResult == null) {
|
|
return;
|
|
}
|
|
|
|
for (var asset in deleteAssetResult) {
|
|
if (asset.status == DeleteAssetStatus.SUCCESS) {
|
|
state =
|
|
state.where((immichAsset) => immichAsset.id != asset.id).toList();
|
|
}
|
|
}
|
|
|
|
_cacheState();
|
|
}
|
|
}
|
|
|
|
final assetProvider =
|
|
StateNotifierProvider<AssetNotifier, List<AssetResponseDto>>((ref) {
|
|
return AssetNotifier(
|
|
ref.watch(assetServiceProvider), ref.watch(assetCacheServiceProvider));
|
|
});
|
|
|
|
final assetGroupByDateTimeProvider = StateProvider((ref) {
|
|
var assets = ref.watch(assetProvider);
|
|
|
|
assets.sortByCompare<DateTime>(
|
|
(e) => DateTime.parse(e.createdAt),
|
|
(a, b) => b.compareTo(a),
|
|
);
|
|
return assets.groupListsBy(
|
|
(element) => DateFormat('y-MM-dd')
|
|
.format(DateTime.parse(element.createdAt).toLocal()),
|
|
);
|
|
});
|
|
|
|
final assetGroupByMonthYearProvider = StateProvider((ref) {
|
|
var assets = ref.watch(assetProvider);
|
|
|
|
assets.sortByCompare<DateTime>(
|
|
(e) => DateTime.parse(e.createdAt),
|
|
(a, b) => b.compareTo(a),
|
|
);
|
|
|
|
return assets.groupListsBy(
|
|
(element) => DateFormat('MMMM, y')
|
|
.format(DateTime.parse(element.createdAt).toLocal()),
|
|
);
|
|
});
|