mirror of
https://github.com/immich-app/immich.git
synced 2025-01-07 20:36:48 +01:00
b05132a01a
* refactor: server info model to use data classes instead of dtos * mobile: add return types and refactor private variables in map / stack --------- Co-authored-by: shalong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
72 lines
1.9 KiB
Dart
72 lines
1.9 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
import 'package:immich_mobile/shared/models/asset.dart';
|
|
import 'package:immich_mobile/shared/providers/api.provider.dart';
|
|
import 'package:immich_mobile/shared/services/api.service.dart';
|
|
import 'package:openapi/api.dart';
|
|
|
|
class AssetStackService {
|
|
AssetStackService(this._api);
|
|
|
|
final ApiService _api;
|
|
|
|
Future<void> updateStack(
|
|
Asset parentAsset, {
|
|
List<Asset>? childrenToAdd,
|
|
List<Asset>? childrenToRemove,
|
|
}) async {
|
|
// Guard [local asset]
|
|
if (parentAsset.remoteId == null) {
|
|
return;
|
|
}
|
|
|
|
try {
|
|
if (childrenToAdd != null) {
|
|
final toAdd = childrenToAdd
|
|
.where((e) => e.isRemote)
|
|
.map((e) => e.remoteId!)
|
|
.toList();
|
|
|
|
await _api.assetApi.updateAssets(
|
|
AssetBulkUpdateDto(ids: toAdd, stackParentId: parentAsset.remoteId),
|
|
);
|
|
}
|
|
|
|
if (childrenToRemove != null) {
|
|
final toRemove = childrenToRemove
|
|
.where((e) => e.isRemote)
|
|
.map((e) => e.remoteId!)
|
|
.toList();
|
|
await _api.assetApi.updateAssets(
|
|
AssetBulkUpdateDto(ids: toRemove, removeParent: true),
|
|
);
|
|
}
|
|
} catch (error) {
|
|
debugPrint("Error while updating stack children: ${error.toString()}");
|
|
}
|
|
}
|
|
|
|
Future<void> updateStackParent(Asset oldParent, Asset newParent) async {
|
|
// Guard [local asset]
|
|
if (oldParent.remoteId == null || newParent.remoteId == null) {
|
|
return;
|
|
}
|
|
|
|
try {
|
|
await _api.assetApi.updateStackParent(
|
|
UpdateStackParentDto(
|
|
oldParentId: oldParent.remoteId!,
|
|
newParentId: newParent.remoteId!,
|
|
),
|
|
);
|
|
} catch (error) {
|
|
debugPrint("Error while updating stack parent: ${error.toString()}");
|
|
}
|
|
}
|
|
}
|
|
|
|
final assetStackServiceProvider = Provider(
|
|
(ref) => AssetStackService(
|
|
ref.watch(apiServiceProvider),
|
|
),
|
|
);
|