You've already forked immich
mirror of
https://github.com/immich-app/immich.git
synced 2025-07-06 06:07:29 +02:00
* add full image provider and refactor thumb providers * photo_view updates * wip: asset-viewer * fix controller dispose on page change * wip: bottom sheet * fix interactions * more bottomsheet changes * generate schema * PR feedback * refactor asset viewer * never rotate and fix background on page change * use photoview as the loading builder * precache after delay * claude: optimizing rebuild of image provider * claude: optimizing image decoding and caching * use proper cache for new full size image providers * chore: load local HEIC fullsize for iOS * make controller callbacks nullable * remove imageprovider cache * do not handle drag gestures when zoomed * use loadOriginal setting for HEIC / larger images * preload assets outside timer * never use same controllers in photo-view gallery * fix: cannot scroll down once swipe with bottom sheet --------- Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com> Co-authored-by: Alex <alex.tran1502@gmail.com>
135 lines
3.7 KiB
Dart
135 lines
3.7 KiB
Dart
import 'package:auto_route/auto_route.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:immich_mobile/constants/enums.dart';
|
|
import 'package:immich_mobile/domain/models/asset/base_asset.model.dart';
|
|
import 'package:immich_mobile/infrastructure/repositories/remote_asset.repository.dart';
|
|
import 'package:immich_mobile/providers/infrastructure/asset.provider.dart';
|
|
import 'package:immich_mobile/repositories/asset_api.repository.dart';
|
|
import 'package:immich_mobile/routing/router.dart';
|
|
import 'package:immich_mobile/widgets/common/location_picker.dart';
|
|
import 'package:maplibre_gl/maplibre_gl.dart';
|
|
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
|
|
|
final actionServiceProvider = Provider<ActionService>(
|
|
(ref) => ActionService(
|
|
ref.watch(assetApiRepositoryProvider),
|
|
ref.watch(remoteAssetRepositoryProvider),
|
|
),
|
|
);
|
|
|
|
class ActionService {
|
|
final AssetApiRepository _assetApiRepository;
|
|
final RemoteAssetRepository _remoteAssetRepository;
|
|
|
|
const ActionService(
|
|
this._assetApiRepository,
|
|
this._remoteAssetRepository,
|
|
);
|
|
|
|
Future<void> shareLink(List<String> remoteIds, BuildContext context) async {
|
|
context.pushRoute(
|
|
SharedLinkEditRoute(
|
|
assetsList: remoteIds,
|
|
),
|
|
);
|
|
}
|
|
|
|
Future<void> favorite(List<String> remoteIds) async {
|
|
await _assetApiRepository.updateFavorite(remoteIds, true);
|
|
await _remoteAssetRepository.updateFavorite(remoteIds, true);
|
|
}
|
|
|
|
Future<void> unFavorite(List<String> remoteIds) async {
|
|
await _assetApiRepository.updateFavorite(remoteIds, false);
|
|
await _remoteAssetRepository.updateFavorite(remoteIds, false);
|
|
}
|
|
|
|
Future<void> archive(List<String> remoteIds) async {
|
|
await _assetApiRepository.updateVisibility(
|
|
remoteIds,
|
|
AssetVisibilityEnum.archive,
|
|
);
|
|
await _remoteAssetRepository.updateVisibility(
|
|
remoteIds,
|
|
AssetVisibility.archive,
|
|
);
|
|
}
|
|
|
|
Future<void> unArchive(List<String> remoteIds) async {
|
|
await _assetApiRepository.updateVisibility(
|
|
remoteIds,
|
|
AssetVisibilityEnum.timeline,
|
|
);
|
|
await _remoteAssetRepository.updateVisibility(
|
|
remoteIds,
|
|
AssetVisibility.timeline,
|
|
);
|
|
}
|
|
|
|
Future<void> moveToLockFolder(List<String> remoteIds) async {
|
|
await _assetApiRepository.updateVisibility(
|
|
remoteIds,
|
|
AssetVisibilityEnum.locked,
|
|
);
|
|
await _remoteAssetRepository.updateVisibility(
|
|
remoteIds,
|
|
AssetVisibility.locked,
|
|
);
|
|
}
|
|
|
|
Future<void> removeFromLockFolder(List<String> remoteIds) async {
|
|
await _assetApiRepository.updateVisibility(
|
|
remoteIds,
|
|
AssetVisibilityEnum.timeline,
|
|
);
|
|
await _remoteAssetRepository.updateVisibility(
|
|
remoteIds,
|
|
AssetVisibility.timeline,
|
|
);
|
|
}
|
|
|
|
Future<void> trash(List<String> remoteIds) async {
|
|
await _assetApiRepository.delete(remoteIds, false);
|
|
await _remoteAssetRepository.trash(remoteIds);
|
|
}
|
|
|
|
Future<void> delete(List<String> remoteIds) async {
|
|
await _assetApiRepository.delete(remoteIds, true);
|
|
await _remoteAssetRepository.delete(remoteIds);
|
|
}
|
|
|
|
Future<bool> editLocation(
|
|
List<String> remoteIds,
|
|
BuildContext context,
|
|
) async {
|
|
LatLng? initialLatLng;
|
|
if (remoteIds.length == 1) {
|
|
final exif = await _remoteAssetRepository.getExif(remoteIds[0]);
|
|
|
|
if (exif?.latitude != null && exif?.longitude != null) {
|
|
initialLatLng = LatLng(exif!.latitude!, exif.longitude!);
|
|
}
|
|
}
|
|
|
|
final location = await showLocationPicker(
|
|
context: context,
|
|
initialLatLng: initialLatLng,
|
|
);
|
|
|
|
if (location == null) {
|
|
return false;
|
|
}
|
|
|
|
await _assetApiRepository.updateLocation(
|
|
remoteIds,
|
|
location,
|
|
);
|
|
await _remoteAssetRepository.updateLocation(
|
|
remoteIds,
|
|
location,
|
|
);
|
|
|
|
return true;
|
|
}
|
|
}
|