From 1162310c7c16f57e82f0ef9dae1888352a65a4c2 Mon Sep 17 00:00:00 2001 From: Boris Michiels Date: Wed, 4 Jan 2023 22:10:32 +0100 Subject: [PATCH] fix: cleanup remember patches feature --- lib/services/manager_api.dart | 20 +++++-------------- .../app_selector/app_selector_viewmodel.dart | 2 -- lib/ui/views/patcher/patcher_viewmodel.dart | 3 +-- lib/ui/views/settings/settings_viewmodel.dart | 14 +++++-------- 4 files changed, 11 insertions(+), 28 deletions(-) diff --git a/lib/services/manager_api.dart b/lib/services/manager_api.dart index dbd75098c1..9682bb3421 100644 --- a/lib/services/manager_api.dart +++ b/lib/services/manager_api.dart @@ -424,30 +424,20 @@ class ManagerAPI { } else { patchesMap[app] = patches; } - if (selectedPatchesFile.existsSync()) { - selectedPatchesFile.createSync(recursive: true); - } selectedPatchesFile.writeAsString(jsonEncode(patchesMap)); } Future> getSelectedPatches(String app) async { Map patchesMap = await readSelectedPatchesFile(); - if (patchesMap.isNotEmpty) { - final List patches = - List.from(patchesMap.putIfAbsent(app, () => List.empty())); - return patches; - } - return List.empty(); + return List.from(patchesMap.putIfAbsent(app, () => List.empty())); } Future> readSelectedPatchesFile() async { final File selectedPatchesFile = File(storedPatchesFile); - if (selectedPatchesFile.existsSync()) { - String string = selectedPatchesFile.readAsStringSync(); - if (string.trim().isEmpty) return {}; - return json.decode(string); - } - return {}; + if (!selectedPatchesFile.existsSync()) return {}; + String string = selectedPatchesFile.readAsStringSync(); + if (string.trim().isEmpty) return {}; + return jsonDecode(string); } Future resetLastSelectedPatches() async { diff --git a/lib/ui/views/app_selector/app_selector_viewmodel.dart b/lib/ui/views/app_selector/app_selector_viewmodel.dart index caaa4b31a9..9b5943a575 100644 --- a/lib/ui/views/app_selector/app_selector_viewmodel.dart +++ b/lib/ui/views/app_selector/app_selector_viewmodel.dart @@ -42,7 +42,6 @@ class AppSelectorViewModel extends BaseViewModel { patchDate: DateTime.now(), ); locator().loadLastSelectedPatches(); - locator().notifyListeners(); } Future selectAppFromStorage(BuildContext context) async { @@ -78,7 +77,6 @@ class AppSelectorViewModel extends BaseViewModel { isFromStorage: true, ); locator().loadLastSelectedPatches(); - locator().notifyListeners(); } } } on Exception catch (e, s) { diff --git a/lib/ui/views/patcher/patcher_viewmodel.dart b/lib/ui/views/patcher/patcher_viewmodel.dart index 1c16ed6c79..fa6c42219b 100644 --- a/lib/ui/views/patcher/patcher_viewmodel.dart +++ b/lib/ui/views/patcher/patcher_viewmodel.dart @@ -114,8 +114,7 @@ class PatcherViewModel extends BaseViewModel { await _managerAPI.getSelectedPatches(selectedApp!.originalPackageName); List patches = _patcherAPI.getFilteredPatches(selectedApp!.originalPackageName); - this - .selectedPatches + this.selectedPatches .addAll(patches.where((patch) => selectedPatches.contains(patch.name))); notifyListeners(); } diff --git a/lib/ui/views/settings/settings_viewmodel.dart b/lib/ui/views/settings/settings_viewmodel.dart index 53aac65e76..416068b6c0 100644 --- a/lib/ui/views/settings/settings_viewmodel.dart +++ b/lib/ui/views/settings/settings_viewmodel.dart @@ -80,9 +80,9 @@ class SettingsViewModel extends BaseViewModel { await CRFileSaver.saveFileWithDialog(SaveFileDialogParams( sourceFilePath: tempFilePath, destinationFileName: '')); File(tempFilePath).delete(); - locator().showBottom('settingsView.exportedPatches'); + _toast.showBottom('settingsView.exportedPatches'); } else { - locator().showBottom('settingsView.noExportFileFound'); + _toast.showBottom('settingsView.noExportFileFound'); } } on Exception catch (e, s) { Sentry.captureException(e, stackTrace: s); @@ -97,20 +97,16 @@ class SettingsViewModel extends BaseViewModel { ); if (result != null && result.files.single.path != null) { File inFile = File(result.files.single.path!); - final File storedPatchesFile = File(_managerAPI.storedPatchesFile); - if (!storedPatchesFile.existsSync()) { - storedPatchesFile.createSync(recursive: true); - } - inFile.copySync(storedPatchesFile.path); + inFile.copySync(_managerAPI.storedPatchesFile); inFile.delete(); if (locator().selectedApp != null) { locator().loadLastSelectedPatches(); } - locator().showBottom('settingsView.importedPatches'); + _toast.showBottom('settingsView.importedPatches'); } } on Exception catch (e, s) { await Sentry.captureException(e, stackTrace: s); - locator().showBottom('settingsView.jsonSelectorErrorMessage'); + _toast.showBottom('settingsView.jsonSelectorErrorMessage'); } }