mirror of
https://git.selfprivacy.org/kherel/selfprivacy.org.app.git
synced 2025-01-24 01:36:38 +00:00
refactor: Optimistic state update when forgetting a snapshot
This commit is contained in:
parent
1ba8f324fe
commit
e330f71b63
|
@ -366,6 +366,14 @@ class BackupsBloc extends Bloc<BackupsEvent, BackupsState> {
|
||||||
) async {
|
) async {
|
||||||
final currentState = state;
|
final currentState = state;
|
||||||
if (currentState is BackupsInitialized) {
|
if (currentState is BackupsInitialized) {
|
||||||
|
// Optimistically remove the snapshot from the list
|
||||||
|
getIt<ApiConnectionRepository>().apiData.backups.data =
|
||||||
|
getIt<ApiConnectionRepository>()
|
||||||
|
.apiData
|
||||||
|
.backups
|
||||||
|
.data
|
||||||
|
?.where((final Backup backup) => backup.id != event.backupId)
|
||||||
|
.toList();
|
||||||
emit(BackupsBusy.fromState(currentState));
|
emit(BackupsBusy.fromState(currentState));
|
||||||
final GenericResult result =
|
final GenericResult result =
|
||||||
await getIt<ApiConnectionRepository>().api.forgetSnapshot(
|
await getIt<ApiConnectionRepository>().api.forgetSnapshot(
|
||||||
|
@ -377,16 +385,8 @@ class BackupsBloc extends Bloc<BackupsEvent, BackupsState> {
|
||||||
} else if (result.data == false) {
|
} else if (result.data == false) {
|
||||||
getIt<NavigationService>()
|
getIt<NavigationService>()
|
||||||
.showSnackBar('backup.forget_snapshot_error'.tr());
|
.showSnackBar('backup.forget_snapshot_error'.tr());
|
||||||
} else {
|
|
||||||
final backups = getIt<ApiConnectionRepository>().apiData.backups.data;
|
|
||||||
if (backups != null) {
|
|
||||||
getIt<ApiConnectionRepository>().apiData.backups.data = backups
|
|
||||||
.where((final Backup backup) => backup.id != event.backupId)
|
|
||||||
.toList();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
emit(currentState);
|
emit(currentState);
|
||||||
getIt<ApiConnectionRepository>().emitData();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue