chore: refactor download group (#20099)

This commit is contained in:
Alex 2025-07-22 23:21:58 -05:00 committed by GitHub
parent 1a70896113
commit c7853fbe9d
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 19 additions and 19 deletions

View File

@ -20,6 +20,9 @@ const String kSecuredPinCode = "secured_pin_code";
const String kManualUploadGroup = 'manual_upload_group'; const String kManualUploadGroup = 'manual_upload_group';
const String kBackupGroup = 'backup_group'; const String kBackupGroup = 'backup_group';
const String kBackupLivePhotoGroup = 'backup_live_photo_group'; const String kBackupLivePhotoGroup = 'backup_live_photo_group';
const String kDownloadGroupImage = 'group_image';
const String kDownloadGroupVideo = 'group_video';
const String kDownloadGroupLivePhoto = 'group_livephoto';
// Timeline constants // Timeline constants
const int kTimelineNoneSegmentSize = 120; const int kTimelineNoneSegmentSize = 120;

View File

@ -10,6 +10,7 @@ import 'package:flutter/material.dart';
import 'package:flutter/services.dart'; import 'package:flutter/services.dart';
import 'package:flutter_displaymode/flutter_displaymode.dart'; import 'package:flutter_displaymode/flutter_displaymode.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart'; import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:immich_mobile/constants/constants.dart';
import 'package:immich_mobile/constants/locales.dart'; import 'package:immich_mobile/constants/locales.dart';
import 'package:immich_mobile/extensions/build_context_extensions.dart'; import 'package:immich_mobile/extensions/build_context_extensions.dart';
import 'package:immich_mobile/generated/codegen_loader.g.dart'; import 'package:immich_mobile/generated/codegen_loader.g.dart';
@ -29,7 +30,6 @@ import 'package:immich_mobile/theme/dynamic_theme.dart';
import 'package:immich_mobile/theme/theme_data.dart'; import 'package:immich_mobile/theme/theme_data.dart';
import 'package:immich_mobile/utils/bootstrap.dart'; import 'package:immich_mobile/utils/bootstrap.dart';
import 'package:immich_mobile/utils/cache/widgets_binding.dart'; import 'package:immich_mobile/utils/cache/widgets_binding.dart';
import 'package:immich_mobile/utils/download.dart';
import 'package:immich_mobile/utils/http_ssl_options.dart'; import 'package:immich_mobile/utils/http_ssl_options.dart';
import 'package:immich_mobile/utils/licenses.dart'; import 'package:immich_mobile/utils/licenses.dart';
import 'package:immich_mobile/utils/migration.dart'; import 'package:immich_mobile/utils/migration.dart';
@ -101,7 +101,7 @@ Future<void> initApp() async {
); );
await FileDownloader().trackTasksInGroup( await FileDownloader().trackTasksInGroup(
downloadGroupLivePhoto, kDownloadGroupLivePhoto,
markDownloadedComplete: false, markDownloadedComplete: false,
); );
@ -179,7 +179,7 @@ class ImmichAppState extends ConsumerState<ImmichApp>
void _configureFileDownloaderNotifications() { void _configureFileDownloaderNotifications() {
FileDownloader().configureNotificationForGroup( FileDownloader().configureNotificationForGroup(
downloadGroupImage, kDownloadGroupImage,
running: TaskNotification( running: TaskNotification(
'downloading_media'.tr(), 'downloading_media'.tr(),
'${'file_name'.tr()}: {filename}', '${'file_name'.tr()}: {filename}',
@ -192,7 +192,7 @@ class ImmichAppState extends ConsumerState<ImmichApp>
); );
FileDownloader().configureNotificationForGroup( FileDownloader().configureNotificationForGroup(
downloadGroupVideo, kDownloadGroupVideo,
running: TaskNotification( running: TaskNotification(
'downloading_media'.tr(), 'downloading_media'.tr(),
'${'file_name'.tr()}: {filename}', '${'file_name'.tr()}: {filename}',

View File

@ -4,10 +4,10 @@ import 'dart:io';
import 'package:background_downloader/background_downloader.dart'; import 'package:background_downloader/background_downloader.dart';
import 'package:collection/collection.dart'; import 'package:collection/collection.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart'; import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:immich_mobile/constants/constants.dart';
import 'package:immich_mobile/domain/models/asset/base_asset.model.dart'; import 'package:immich_mobile/domain/models/asset/base_asset.model.dart';
import 'package:immich_mobile/models/download/livephotos_medatada.model.dart'; import 'package:immich_mobile/models/download/livephotos_medatada.model.dart';
import 'package:immich_mobile/services/api.service.dart'; import 'package:immich_mobile/services/api.service.dart';
import 'package:immich_mobile/utils/download.dart';
import 'package:immich_mobile/utils/image_url_builder.dart'; import 'package:immich_mobile/utils/image_url_builder.dart';
final downloadRepositoryProvider = Provider((ref) => DownloadRepository()); final downloadRepositoryProvider = Provider((ref) => DownloadRepository());
@ -33,19 +33,19 @@ class DownloadRepository {
DownloadRepository() { DownloadRepository() {
_downloader.registerCallbacks( _downloader.registerCallbacks(
group: downloadGroupImage, group: kDownloadGroupImage,
taskStatusCallback: (update) => onImageDownloadStatus?.call(update), taskStatusCallback: (update) => onImageDownloadStatus?.call(update),
taskProgressCallback: (update) => onTaskProgress?.call(update), taskProgressCallback: (update) => onTaskProgress?.call(update),
); );
_downloader.registerCallbacks( _downloader.registerCallbacks(
group: downloadGroupVideo, group: kDownloadGroupVideo,
taskStatusCallback: (update) => onVideoDownloadStatus?.call(update), taskStatusCallback: (update) => onVideoDownloadStatus?.call(update),
taskProgressCallback: (update) => onTaskProgress?.call(update), taskProgressCallback: (update) => onTaskProgress?.call(update),
); );
_downloader.registerCallbacks( _downloader.registerCallbacks(
group: downloadGroupLivePhoto, group: kDownloadGroupLivePhoto,
taskStatusCallback: (update) => onLivePhotoDownloadStatus?.call(update), taskStatusCallback: (update) => onLivePhotoDownloadStatus?.call(update),
taskProgressCallback: (update) => onTaskProgress?.call(update), taskProgressCallback: (update) => onTaskProgress?.call(update),
); );
@ -66,7 +66,7 @@ class DownloadRepository {
Future<List<TaskRecord>> getLiveVideoTasks() { Future<List<TaskRecord>> getLiveVideoTasks() {
return _downloader.database.allRecordsWithStatus( return _downloader.database.allRecordsWithStatus(
TaskStatus.complete, TaskStatus.complete,
group: downloadGroupLivePhoto, group: kDownloadGroupLivePhoto,
); );
} }
@ -100,7 +100,7 @@ class DownloadRepository {
headers: headers, headers: headers,
filename: asset.name, filename: asset.name,
updates: Updates.statusAndProgress, updates: Updates.statusAndProgress,
group: isVideo ? downloadGroupVideo : downloadGroupImage, group: isVideo ? kDownloadGroupVideo : kDownloadGroupImage,
); );
continue; continue;
} }
@ -113,7 +113,7 @@ class DownloadRepository {
headers: headers, headers: headers,
filename: asset.name, filename: asset.name,
updates: Updates.statusAndProgress, updates: Updates.statusAndProgress,
group: downloadGroupLivePhoto, group: kDownloadGroupLivePhoto,
metaData: json.encode(_dummyMetadata), metaData: json.encode(_dummyMetadata),
); );
@ -126,7 +126,7 @@ class DownloadRepository {
.toUpperCase() .toUpperCase()
.replaceAll(RegExp(r"\.(JPG|HEIC)$"), '.MOV'), .replaceAll(RegExp(r"\.(JPG|HEIC)$"), '.MOV'),
updates: Updates.statusAndProgress, updates: Updates.statusAndProgress,
group: downloadGroupLivePhoto, group: kDownloadGroupLivePhoto,
metaData: json.encode(_dummyMetadata), metaData: json.encode(_dummyMetadata),
); );
} }

View File

@ -3,6 +3,7 @@ import 'dart:io';
import 'package:background_downloader/background_downloader.dart'; import 'package:background_downloader/background_downloader.dart';
import 'package:flutter/services.dart'; import 'package:flutter/services.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart'; import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:immich_mobile/constants/constants.dart';
import 'package:immich_mobile/domain/models/store.model.dart'; import 'package:immich_mobile/domain/models/store.model.dart';
import 'package:immich_mobile/entities/asset.entity.dart'; import 'package:immich_mobile/entities/asset.entity.dart';
import 'package:immich_mobile/entities/store.entity.dart'; import 'package:immich_mobile/entities/store.entity.dart';
@ -10,7 +11,6 @@ import 'package:immich_mobile/models/download/livephotos_medatada.model.dart';
import 'package:immich_mobile/repositories/download.repository.dart'; import 'package:immich_mobile/repositories/download.repository.dart';
import 'package:immich_mobile/repositories/file_media.repository.dart'; import 'package:immich_mobile/repositories/file_media.repository.dart';
import 'package:immich_mobile/services/api.service.dart'; import 'package:immich_mobile/services/api.service.dart';
import 'package:immich_mobile/utils/download.dart';
import 'package:logging/logging.dart'; import 'package:logging/logging.dart';
final downloadServiceProvider = Provider( final downloadServiceProvider = Provider(
@ -173,7 +173,7 @@ class DownloadService {
_buildDownloadTask( _buildDownloadTask(
asset.remoteId!, asset.remoteId!,
asset.fileName, asset.fileName,
group: downloadGroupLivePhoto, group: kDownloadGroupLivePhoto,
metadata: LivePhotosMetadata( metadata: LivePhotosMetadata(
part: LivePhotosPart.image, part: LivePhotosPart.image,
id: asset.remoteId!, id: asset.remoteId!,
@ -184,7 +184,7 @@ class DownloadService {
asset.fileName asset.fileName
.toUpperCase() .toUpperCase()
.replaceAll(RegExp(r"\.(JPG|HEIC)$"), '.MOV'), .replaceAll(RegExp(r"\.(JPG|HEIC)$"), '.MOV'),
group: downloadGroupLivePhoto, group: kDownloadGroupLivePhoto,
metadata: LivePhotosMetadata( metadata: LivePhotosMetadata(
part: LivePhotosPart.video, part: LivePhotosPart.video,
id: asset.remoteId!, id: asset.remoteId!,
@ -201,7 +201,7 @@ class DownloadService {
_buildDownloadTask( _buildDownloadTask(
asset.remoteId!, asset.remoteId!,
asset.fileName, asset.fileName,
group: asset.isImage ? downloadGroupImage : downloadGroupVideo, group: asset.isImage ? kDownloadGroupImage : kDownloadGroupVideo,
), ),
]; ];
} }

View File

@ -1,3 +0,0 @@
const downloadGroupImage = 'group_image';
const downloadGroupVideo = 'group_video';
const downloadGroupLivePhoto = 'group_livephoto';