import 'package:flutter/material.dart'; import 'package:hooks_riverpod/hooks_riverpod.dart'; import 'package:immich_mobile/extensions/build_context_extensions.dart'; import 'package:immich_mobile/models/backup/backup_state.model.dart'; import 'package:immich_mobile/providers/backup/backup.provider.dart'; import 'package:immich_mobile/providers/backup/manual_upload.provider.dart'; class BackupUploadProgressBar extends ConsumerWidget { const BackupUploadProgressBar({super.key}); @override Widget build(BuildContext context, WidgetRef ref) { final isManualUpload = ref.watch( backupProvider.select((value) => value.backupProgress == BackUpProgressEnum.manualInProgress), ); final isIcloudAsset = isManualUpload ? ref.watch(manualUploadProvider.select((value) => value.currentUploadAsset.isIcloudAsset)) : ref.watch(backupProvider.select((value) => value.currentUploadAsset.isIcloudAsset)); final uploadProgress = isManualUpload ? ref.watch(manualUploadProvider.select((value) => value.progressInPercentage)) : ref.watch(backupProvider.select((value) => value.progressInPercentage)); return Padding( padding: const EdgeInsets.only(top: 8.0), child: Row( children: [ if (isIcloudAsset) SizedBox(width: 110, child: Text("Immich Upload", style: context.textTheme.labelSmall)), Expanded( child: LinearProgressIndicator( minHeight: 10.0, value: uploadProgress / 100.0, borderRadius: const BorderRadius.all(Radius.circular(10.0)), ), ), Text( " ${uploadProgress.toStringAsFixed(0)}%", style: const TextStyle(fontSize: 12, fontFamily: "OverpassMono"), ), ], ), ); } }