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"), ), ], ), ); } }