From b7c23bb84fc6f5fdbb79e54f704095186afab54c Mon Sep 17 00:00:00 2001 From: 4sterisk <4sterisk@ymail.ne.jp> Date: Thu, 21 Nov 2024 04:31:07 +0900 Subject: [PATCH] =?UTF-8?q?enhance:=20=E8=A8=AD=E5=AE=9A=E3=81=AEimport/ex?= =?UTF-8?q?port=E6=99=82=E3=81=AB=E3=82=A4=E3=83=B3=E3=82=B8=E3=82=B1?= =?UTF-8?q?=E3=83=BC=E3=82=BF=E3=83=BC=E8=A1=A8=E7=A4=BA(#687)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- lib/repository/import_export_repository.dart | 86 ++++++++++++-------- 1 file changed, 52 insertions(+), 34 deletions(-) diff --git a/lib/repository/import_export_repository.dart b/lib/repository/import_export_repository.dart index 6ef46dbd2..ef2ffb28a 100644 --- a/lib/repository/import_export_repository.dart +++ b/lib/repository/import_export_repository.dart @@ -12,6 +12,7 @@ import "package:miria/model/exported_setting.dart"; import "package:miria/model/tab_setting.dart"; import "package:miria/providers.dart"; import "package:miria/router/app_router.dart"; +import "package:miria/view/common/modal_indicator.dart"; import "package:miria/view/dialogs/simple_confirm_dialog.dart"; import "package:miria/view/dialogs/simple_message_dialog.dart"; import "package:miria/view/settings_page/import_export_page/folder_select_dialog.dart"; @@ -68,41 +69,50 @@ class ImportExportRepository extends ChangeNotifier { } final importFile = alreadyExists.sortedBy((file) => file.createdAt).last; + try { + IndicatorView.showIndicator(context); - final response = await reader(dioProvider) - .get(importFile.url, options: Options(responseType: ResponseType.json)); + final response = await reader(dioProvider).get(importFile.url, + options: Options(responseType: ResponseType.json)); - final json = jsonDecode(response.data); + final json = jsonDecode(response.data); - final importedSettings = ExportedSetting.fromJson(json); + final importedSettings = ExportedSetting.fromJson(json); - // アカウント設定よみこみ - final accounts = reader(accountsProvider); - for (final accountSetting in importedSettings.accountSettings) { - // この端末でログイン済みのアカウントであれば - if (accounts.any((account) => account.acct == accountSetting.acct)) { - await reader(accountSettingsRepositoryProvider).save(accountSetting); + // アカウント設定よみこみ + final accounts = reader(accountsProvider); + for (final accountSetting in importedSettings.accountSettings) { + // この端末でログイン済みのアカウントであれば + if (accounts.any((account) => account.acct == accountSetting.acct)) { + await reader(accountSettingsRepositoryProvider).save(accountSetting); + } } - } - // 全般設定 - await reader(generalSettingsRepositoryProvider) - .update(importedSettings.generalSettings); + // 全般設定 + await reader(generalSettingsRepositoryProvider) + .update(importedSettings.generalSettings); - // タブ設定 - final tabSettings = []; + // タブ設定 + final tabSettings = []; - for (final tabSetting in importedSettings.tabSettings) { - final account = accounts - .firstWhereOrNull((account) => tabSetting.acct == account.acct); + for (final tabSetting in importedSettings.tabSettings) { + final account = accounts + .firstWhereOrNull((account) => tabSetting.acct == account.acct); - if (account == null) { - continue; - } + if (account == null) { + continue; + } - tabSettings.add(tabSetting); + tabSettings.add(tabSetting); + } + await reader(tabSettingsRepositoryProvider).save(tabSettings); + } catch (e) { + rethrow; + } finally { + if (context.mounted) { + IndicatorView.hideIndicator(context); + } } - await reader(tabSettingsRepositoryProvider).save(tabSettings); if (!context.mounted) return; await SimpleMessageDialog.show(context, S.of(context).importCompleted); @@ -163,16 +173,24 @@ class ImportExportRepository extends ChangeNotifier { }; if (!context.mounted) return; - await reader(misskeyProvider(account)).drive.files.createAsBinary( - DriveFilesCreateRequest( - folderId: folder?.id, - name: "miria.json", - comment: S.of(context).exportedFileComment, - force: true, - ), - Uint8List.fromList(utf8.encode(jsonEncode(data))), - ); - + try { + IndicatorView.showIndicator(context); + await reader(misskeyProvider(account)).drive.files.createAsBinary( + DriveFilesCreateRequest( + folderId: folder?.id, + name: "miria.json", + comment: S.of(context).exportedFileComment, + force: true, + ), + Uint8List.fromList(utf8.encode(jsonEncode(data))), + ); + } catch (e) { + rethrow; + } finally { + if (context.mounted) { + IndicatorView.hideIndicator(context); + } + } if (!context.mounted) return; await SimpleMessageDialog.show(context, S.of(context).exportCompleted); }