mirror of
				https://github.com/ImranR98/Obtainium.git
				synced 2025-10-26 03:03:45 +01:00 
			
		
		
		
	Added uninstall option
This commit is contained in:
		| @@ -52,6 +52,7 @@ | |||||||
|     <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/> |     <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/> | ||||||
|     <uses-permission android:name="android.permission.WAKE_LOCK"/> |     <uses-permission android:name="android.permission.WAKE_LOCK"/> | ||||||
|     <uses-permission android:name="android.permission.SCHEDULE_EXACT_ALARM"/> |     <uses-permission android:name="android.permission.SCHEDULE_EXACT_ALARM"/> | ||||||
|  |     <uses-permission android:name="android.permission.REQUEST_DELETE_PACKAGES" /> | ||||||
|     <uses-permission |     <uses-permission | ||||||
|         android:name="android.permission.WRITE_EXTERNAL_STORAGE" |         android:name="android.permission.WRITE_EXTERNAL_STORAGE" | ||||||
|         android:maxSdkVersion="29"/> |         android:maxSdkVersion="29"/> | ||||||
|   | |||||||
| @@ -178,7 +178,6 @@ | |||||||
|     "installedVersionX": "Installierte Version: {}", |     "installedVersionX": "Installierte Version: {}", | ||||||
|     "lastUpdateCheckX": "Letzte Aktualisierungsprüfung: {}", |     "lastUpdateCheckX": "Letzte Aktualisierungsprüfung: {}", | ||||||
|     "remove": "Entfernen", |     "remove": "Entfernen", | ||||||
|     "removeAppQuestion": "App entfernen?", |  | ||||||
|     "yesMarkUpdated": "Ja, als aktualisiert markieren", |     "yesMarkUpdated": "Ja, als aktualisiert markieren", | ||||||
|     "fdroid": "F-Droid", |     "fdroid": "F-Droid", | ||||||
|     "appIdOrName": "App ID oder Name", |     "appIdOrName": "App ID oder Name", | ||||||
| @@ -212,6 +211,12 @@ | |||||||
|     "storagePermissionDenied": "Storage permission denied", |     "storagePermissionDenied": "Storage permission denied", | ||||||
|     "selectedCategorizeWarning": "This will replace any existing category settings for the selected Apps.", |     "selectedCategorizeWarning": "This will replace any existing category settings for the selected Apps.", | ||||||
|     "filterAPKsByRegEx": "Filter APKs by Regular Expression", |     "filterAPKsByRegEx": "Filter APKs by Regular Expression", | ||||||
|  |     "removeFromObtainium": "Remove from Obtainium", | ||||||
|  |     "uninstallFromDevice": "Uninstall from Device", | ||||||
|  |     "removeAppQuestion": { | ||||||
|  |         "one": "App entfernen?", | ||||||
|  |         "other": "App entfernen?" | ||||||
|  |     }, | ||||||
|     "tooManyRequestsTryAgainInMinutes": { |     "tooManyRequestsTryAgainInMinutes": { | ||||||
|         "one": "Zu viele Anfragen (Rate begrenzt) - versuchen Sie es in {} Minute erneut", |         "one": "Zu viele Anfragen (Rate begrenzt) - versuchen Sie es in {} Minute erneut", | ||||||
|         "other": "Zu viele Anfragen (Rate begrenzt) - versuchen Sie es in {} Minuten erneut" |         "other": "Zu viele Anfragen (Rate begrenzt) - versuchen Sie es in {} Minuten erneut" | ||||||
|   | |||||||
| @@ -178,7 +178,6 @@ | |||||||
|     "installedVersionX": "Installed Version: {}", |     "installedVersionX": "Installed Version: {}", | ||||||
|     "lastUpdateCheckX": "Last Update Check: {}", |     "lastUpdateCheckX": "Last Update Check: {}", | ||||||
|     "remove": "Remove", |     "remove": "Remove", | ||||||
|     "removeAppQuestion": "Remove App?", |  | ||||||
|     "yesMarkUpdated": "Yes, Mark as Updated", |     "yesMarkUpdated": "Yes, Mark as Updated", | ||||||
|     "fdroid": "F-Droid", |     "fdroid": "F-Droid", | ||||||
|     "appIdOrName": "App ID or Name", |     "appIdOrName": "App ID or Name", | ||||||
| @@ -212,6 +211,12 @@ | |||||||
|     "storagePermissionDenied": "Storage permission denied", |     "storagePermissionDenied": "Storage permission denied", | ||||||
|     "selectedCategorizeWarning": "This will replace any existing category settings for the selected Apps.", |     "selectedCategorizeWarning": "This will replace any existing category settings for the selected Apps.", | ||||||
|     "filterAPKsByRegEx": "Filter APKs by Regular Expression", |     "filterAPKsByRegEx": "Filter APKs by Regular Expression", | ||||||
|  |     "removeFromObtainium": "Remove from Obtainium", | ||||||
|  |     "uninstallFromDevice": "Uninstall from Device", | ||||||
|  |     "removeAppQuestion": { | ||||||
|  |         "one": "Remove App?", | ||||||
|  |         "other": "Remove Apps?" | ||||||
|  |     }, | ||||||
|     "tooManyRequestsTryAgainInMinutes": { |     "tooManyRequestsTryAgainInMinutes": { | ||||||
|         "one": "Too many requests (rate limited) - try again in {} minute", |         "one": "Too many requests (rate limited) - try again in {} minute", | ||||||
|         "other": "Too many requests (rate limited) - try again in {} minutes" |         "other": "Too many requests (rate limited) - try again in {} minutes" | ||||||
|   | |||||||
| @@ -178,7 +178,6 @@ | |||||||
|     "installedVersionX": "Telepített verzió: {}", |     "installedVersionX": "Telepített verzió: {}", | ||||||
|     "lastUpdateCheckX": "Frissítés ellenőrizve: {}", |     "lastUpdateCheckX": "Frissítés ellenőrizve: {}", | ||||||
|     "remove": "Eltávolítás", |     "remove": "Eltávolítás", | ||||||
|     "removeAppQuestion": "Eltávolítja az alkalmazást?", |  | ||||||
|     "yesMarkUpdated": "Igen, megjelölés frissítettként", |     "yesMarkUpdated": "Igen, megjelölés frissítettként", | ||||||
|     "fdroid": "F-Droid", |     "fdroid": "F-Droid", | ||||||
|     "appIdOrName": "App ID vagy név", |     "appIdOrName": "App ID vagy név", | ||||||
| @@ -211,6 +210,12 @@ | |||||||
|     "storagePermissionDenied": "Tárhely engedély megtagadva", |     "storagePermissionDenied": "Tárhely engedély megtagadva", | ||||||
|     "selectedCategorizeWarning": "Ez felváltja a kiválasztott alkalmazások meglévő kategória-beállításait.", |     "selectedCategorizeWarning": "Ez felváltja a kiválasztott alkalmazások meglévő kategória-beállításait.", | ||||||
|     "filterAPKsByRegEx": "Filter APKs by Regular Expression", |     "filterAPKsByRegEx": "Filter APKs by Regular Expression", | ||||||
|  |     "removeFromObtainium": "Remove from Obtainium", | ||||||
|  |     "uninstallFromDevice": "Uninstall from Device", | ||||||
|  |     "removeAppQuestion": { | ||||||
|  |         "one": "Eltávolítja az alkalmazást?", | ||||||
|  |         "other": "Eltávolítja az alkalmazást?" | ||||||
|  |     }, | ||||||
|     "tooManyRequestsTryAgainInMinutes": { |     "tooManyRequestsTryAgainInMinutes": { | ||||||
|         "one": "Túl sok kérés (korlátozott arány) – próbálja újra {} perc múlva", |         "one": "Túl sok kérés (korlátozott arány) – próbálja újra {} perc múlva", | ||||||
|         "other": "Túl sok kérés (korlátozott arány) – próbálja újra {} perc múlva" |         "other": "Túl sok kérés (korlátozott arány) – próbálja újra {} perc múlva" | ||||||
|   | |||||||
| @@ -178,7 +178,6 @@ | |||||||
|     "installedVersionX": "Versione installata: {}", |     "installedVersionX": "Versione installata: {}", | ||||||
|     "lastUpdateCheckX": "Ultimo controllo degli aggiornamenti: {}", |     "lastUpdateCheckX": "Ultimo controllo degli aggiornamenti: {}", | ||||||
|     "remove": "Rimuovi", |     "remove": "Rimuovi", | ||||||
|     "removeAppQuestion": "Rimuovere l'App?", |  | ||||||
|     "yesMarkUpdated": "Sì, contrassegna come aggiornato", |     "yesMarkUpdated": "Sì, contrassegna come aggiornato", | ||||||
|     "fdroid": "F-Droid", |     "fdroid": "F-Droid", | ||||||
|     "appIdOrName": "ID o nome dell'App", |     "appIdOrName": "ID o nome dell'App", | ||||||
| @@ -212,6 +211,12 @@ | |||||||
|     "storagePermissionDenied": "Storage permission denied", |     "storagePermissionDenied": "Storage permission denied", | ||||||
|     "selectedCategorizeWarning": "This will replace any existing category settings for the selected Apps.", |     "selectedCategorizeWarning": "This will replace any existing category settings for the selected Apps.", | ||||||
|     "filterAPKsByRegEx": "Filter APKs by Regular Expression", |     "filterAPKsByRegEx": "Filter APKs by Regular Expression", | ||||||
|  |     "removeFromObtainium": "Remove from Obtainium", | ||||||
|  |     "uninstallFromDevice": "Uninstall from Device", | ||||||
|  |     "removeAppQuestion": { | ||||||
|  |         "one": "Rimuovere l'App?", | ||||||
|  |         "other": "Rimuovere l'App?" | ||||||
|  |     }, | ||||||
|     "tooManyRequestsTryAgainInMinutes": { |     "tooManyRequestsTryAgainInMinutes": { | ||||||
|         "one": "Troppe richieste (traffico limitato) - riprova tra {} minuto", |         "one": "Troppe richieste (traffico limitato) - riprova tra {} minuto", | ||||||
|         "other": "Troppe richieste (traffico limitato) - riprova tra {} minuti" |         "other": "Troppe richieste (traffico limitato) - riprova tra {} minuti" | ||||||
|   | |||||||
| @@ -178,7 +178,6 @@ | |||||||
|     "installedVersionX": "インストールされたバージョン: {}", |     "installedVersionX": "インストールされたバージョン: {}", | ||||||
|     "lastUpdateCheckX": "最終アップデート確認: {}", |     "lastUpdateCheckX": "最終アップデート確認: {}", | ||||||
|     "remove": "削除", |     "remove": "削除", | ||||||
|     "removeAppQuestion": "アプリを削除しますか?", |  | ||||||
|     "yesMarkUpdated": "はい、アップデート済みとしてマークします", |     "yesMarkUpdated": "はい、アップデート済みとしてマークします", | ||||||
|     "fdroid": "F-Droid", |     "fdroid": "F-Droid", | ||||||
|     "appIdOrName": "アプリのIDまたは名前", |     "appIdOrName": "アプリのIDまたは名前", | ||||||
| @@ -212,6 +211,12 @@ | |||||||
|     "storagePermissionDenied": "ストレージ権限が拒否されました", |     "storagePermissionDenied": "ストレージ権限が拒否されました", | ||||||
|     "selectedCategorizeWarning": "これにより、選択したアプリの既存のカテゴリ設定がすべて置き換えられます。", |     "selectedCategorizeWarning": "これにより、選択したアプリの既存のカテゴリ設定がすべて置き換えられます。", | ||||||
|     "filterAPKsByRegEx": "正規表現でAPKを絞り込む", |     "filterAPKsByRegEx": "正規表現でAPKを絞り込む", | ||||||
|  |     "removeFromObtainium": "Remove from Obtainium", | ||||||
|  |     "uninstallFromDevice": "Uninstall from Device", | ||||||
|  |     "removeAppQuestion": { | ||||||
|  |         "one": "アプリを削除しますか?", | ||||||
|  |         "other": "アプリを削除しますか?" | ||||||
|  |     }, | ||||||
|     "tooManyRequestsTryAgainInMinutes": { |     "tooManyRequestsTryAgainInMinutes": { | ||||||
|         "one": "リクエストが多すぎます(レート制限)- {}分後に再試行してください", |         "one": "リクエストが多すぎます(レート制限)- {}分後に再試行してください", | ||||||
|         "other": "リクエストが多すぎます(レート制限)- {}分後に再試行してください" |         "other": "リクエストが多すぎます(レート制限)- {}分後に再試行してください" | ||||||
|   | |||||||
| @@ -178,7 +178,6 @@ | |||||||
|     "installedVersionX": "已安装: {}", |     "installedVersionX": "已安装: {}", | ||||||
|     "lastUpdateCheckX": "最后检查: {}", |     "lastUpdateCheckX": "最后检查: {}", | ||||||
|     "remove": "删除", |     "remove": "删除", | ||||||
|     "removeAppQuestion": "删除应用?", |  | ||||||
|     "yesMarkUpdated": "'是的,标为已更新", |     "yesMarkUpdated": "'是的,标为已更新", | ||||||
|     "fdroid": "F-Droid", |     "fdroid": "F-Droid", | ||||||
|     "appIdOrName": "应用 ID 或名称", |     "appIdOrName": "应用 ID 或名称", | ||||||
| @@ -212,6 +211,12 @@ | |||||||
|     "storagePermissionDenied": "存储权限已被拒绝", |     "storagePermissionDenied": "存储权限已被拒绝", | ||||||
|     "selectedCategorizeWarning": "这将取代所选应用程序的任何现有类别", |     "selectedCategorizeWarning": "这将取代所选应用程序的任何现有类别", | ||||||
|     "filterAPKsByRegEx": "Filter APKs by Regular Expression", |     "filterAPKsByRegEx": "Filter APKs by Regular Expression", | ||||||
|  |     "removeFromObtainium": "Remove from Obtainium", | ||||||
|  |     "uninstallFromDevice": "Uninstall from Device", | ||||||
|  |     "removeAppQuestion": { | ||||||
|  |         "one": "删除应用?", | ||||||
|  |         "other": "删除应用?" | ||||||
|  |     }, | ||||||
|     "tooManyRequestsTryAgainInMinutes": { |     "tooManyRequestsTryAgainInMinutes": { | ||||||
|         "one": "请求过多 (API 限制) - 在 {} 分钟后重试", |         "one": "请求过多 (API 限制) - 在 {} 分钟后重试", | ||||||
|         "other": "请求过多 (API 限制) - 在 {} 分钟后重试" |         "other": "请求过多 (API 限制) - 在 {} 分钟后重试" | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| import 'package:easy_localization/easy_localization.dart'; | import 'package:easy_localization/easy_localization.dart'; | ||||||
| import 'package:flutter/material.dart'; | import 'package:flutter/material.dart'; | ||||||
| import 'package:flutter/services.dart'; | import 'package:flutter/services.dart'; | ||||||
|  | import 'package:obtainium/components/generated_form.dart'; | ||||||
| import 'package:obtainium/components/generated_form_modal.dart'; | import 'package:obtainium/components/generated_form_modal.dart'; | ||||||
| import 'package:obtainium/custom_errors.dart'; | import 'package:obtainium/custom_errors.dart'; | ||||||
| import 'package:obtainium/main.dart'; | import 'package:obtainium/main.dart'; | ||||||
| @@ -361,40 +362,12 @@ class _AppPageState extends State<AppPage> { | |||||||
|                           onPressed: app?.downloadProgress != null |                           onPressed: app?.downloadProgress != null | ||||||
|                               ? null |                               ? null | ||||||
|                               : () { |                               : () { | ||||||
|                                   showDialog( |                                   appsProvider.removeAppsWithModal( | ||||||
|                                       context: context, |                                       context, [app!.app]).then((value) { | ||||||
|                                       builder: (BuildContext ctx) { |                                     if (value == true) { | ||||||
|                                         return AlertDialog( |                                       Navigator.of(context).pop(); | ||||||
|                                           title: Text(tr('removeAppQuestion')), |                                     } | ||||||
|                                           content: Text(tr( |                                   }); | ||||||
|                                               'xWillBeRemovedButRemainInstalled', |  | ||||||
|                                               args: [ |  | ||||||
|                                                 app?.installedInfo?.name ?? |  | ||||||
|                                                     app?.app.name ?? |  | ||||||
|                                                     tr('app') |  | ||||||
|                                               ])), |  | ||||||
|                                           actions: [ |  | ||||||
|                                             TextButton( |  | ||||||
|                                                 onPressed: () { |  | ||||||
|                                                   HapticFeedback |  | ||||||
|                                                       .selectionClick(); |  | ||||||
|                                                   appsProvider.removeApps( |  | ||||||
|                                                       [app!.app.id]).then((_) { |  | ||||||
|                                                     int count = 0; |  | ||||||
|                                                     Navigator.of(context) |  | ||||||
|                                                         .popUntil((_) => |  | ||||||
|                                                             count++ >= 2); |  | ||||||
|                                                   }); |  | ||||||
|                                                 }, |  | ||||||
|                                                 child: Text(tr('remove'))), |  | ||||||
|                                             TextButton( |  | ||||||
|                                                 onPressed: () { |  | ||||||
|                                                   Navigator.of(context).pop(); |  | ||||||
|                                                 }, |  | ||||||
|                                                 child: Text(tr('cancel'))) |  | ||||||
|                                           ], |  | ||||||
|                                         ); |  | ||||||
|                                       }); |  | ||||||
|                                 }, |                                 }, | ||||||
|                           style: TextButton.styleFrom( |                           style: TextButton.styleFrom( | ||||||
|                               foregroundColor: |                               foregroundColor: | ||||||
| @@ -414,3 +387,18 @@ class _AppPageState extends State<AppPage> { | |||||||
|     ); |     ); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | class RemoveAppsModal extends StatefulWidget { | ||||||
|  |   const RemoveAppsModal({super.key, this.apps = const []}); | ||||||
|  |   final List<App> apps; | ||||||
|  |  | ||||||
|  |   @override | ||||||
|  |   State<RemoveAppsModal> createState() => _RemoveAppsModalState(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | class _RemoveAppsModalState extends State<RemoveAppsModal> { | ||||||
|  |   @override | ||||||
|  |   Widget build(BuildContext context) { | ||||||
|  |     return const Placeholder(); | ||||||
|  |   } | ||||||
|  | } | ||||||
|   | |||||||
| @@ -389,28 +389,30 @@ class AppsPageState extends State<AppsPage> { | |||||||
|                                 onPressed: selectedApps.isEmpty |                                 onPressed: selectedApps.isEmpty | ||||||
|                                     ? null |                                     ? null | ||||||
|                                     : () { |                                     : () { | ||||||
|                                         showDialog<Map<String, dynamic>?>( |                                         appsProvider.removeAppsWithModal( | ||||||
|                                             context: context, |                                             context, selectedApps.toList()); | ||||||
|                                             builder: (BuildContext ctx) { |                                         // showDialog<Map<String, dynamic>?>( | ||||||
|                                               return GeneratedFormModal( |                                         //     context: context, | ||||||
|                                                 title: tr( |                                         //     builder: (BuildContext ctx) { | ||||||
|                                                     'removeSelectedAppsQuestion'), |                                         //       return GeneratedFormModal( | ||||||
|                                                 items: const [], |                                         //         title: tr( | ||||||
|                                                 initValid: true, |                                         //             'removeSelectedAppsQuestion'), | ||||||
|                                                 message: tr( |                                         //         items: const [], | ||||||
|                                                     'xWillBeRemovedButRemainInstalled', |                                         //         initValid: true, | ||||||
|                                                     args: [ |                                         //         message: tr( | ||||||
|                                                       plural('apps', |                                         //             'xWillBeRemovedButRemainInstalled', | ||||||
|                                                           selectedApps.length) |                                         //             args: [ | ||||||
|                                                     ]), |                                         //               plural('apps', | ||||||
|                                               ); |                                         //                   selectedApps.length) | ||||||
|                                             }).then((values) { |                                         //             ]), | ||||||
|                                           if (values != null) { |                                         //       ); | ||||||
|                                             appsProvider.removeApps(selectedApps |                                         //     }).then((values) { | ||||||
|                                                 .map((e) => e.id) |                                         //   if (values != null) { | ||||||
|                                                 .toList()); |                                         //     appsProvider.removeApps(selectedApps | ||||||
|                                           } |                                         //         .map((e) => e.id) | ||||||
|                                         }); |                                         //         .toList()); | ||||||
|  |                                         //   } | ||||||
|  |                                         // }); | ||||||
|                                       }, |                                       }, | ||||||
|                                 tooltip: tr('removeSelectedApps'), |                                 tooltip: tr('removeSelectedApps'), | ||||||
|                                 icon: const Icon(Icons.delete_outline_outlined), |                                 icon: const Icon(Icons.delete_outline_outlined), | ||||||
|   | |||||||
| @@ -5,6 +5,7 @@ import 'dart:async'; | |||||||
| import 'dart:convert'; | import 'dart:convert'; | ||||||
| import 'dart:io'; | import 'dart:io'; | ||||||
|  |  | ||||||
|  | import 'package:android_intent_plus/flag.dart'; | ||||||
| import 'package:device_info_plus/device_info_plus.dart'; | import 'package:device_info_plus/device_info_plus.dart'; | ||||||
| import 'package:easy_localization/easy_localization.dart'; | import 'package:easy_localization/easy_localization.dart'; | ||||||
| import 'package:flutter/material.dart'; | import 'package:flutter/material.dart'; | ||||||
| @@ -12,6 +13,8 @@ import 'package:flutter/services.dart'; | |||||||
| import 'package:install_plugin_v2/install_plugin_v2.dart'; | import 'package:install_plugin_v2/install_plugin_v2.dart'; | ||||||
| import 'package:installed_apps/app_info.dart'; | import 'package:installed_apps/app_info.dart'; | ||||||
| import 'package:installed_apps/installed_apps.dart'; | import 'package:installed_apps/installed_apps.dart'; | ||||||
|  | import 'package:obtainium/components/generated_form.dart'; | ||||||
|  | import 'package:obtainium/components/generated_form_modal.dart'; | ||||||
| import 'package:obtainium/custom_errors.dart'; | import 'package:obtainium/custom_errors.dart'; | ||||||
| import 'package:obtainium/providers/logs_provider.dart'; | import 'package:obtainium/providers/logs_provider.dart'; | ||||||
| import 'package:obtainium/providers/notifications_provider.dart'; | import 'package:obtainium/providers/notifications_provider.dart'; | ||||||
| @@ -23,6 +26,7 @@ import 'package:path_provider/path_provider.dart'; | |||||||
| import 'package:flutter_fgbg/flutter_fgbg.dart'; | import 'package:flutter_fgbg/flutter_fgbg.dart'; | ||||||
| import 'package:obtainium/providers/source_provider.dart'; | import 'package:obtainium/providers/source_provider.dart'; | ||||||
| import 'package:http/http.dart'; | import 'package:http/http.dart'; | ||||||
|  | import 'package:android_intent_plus/android_intent.dart'; | ||||||
|  |  | ||||||
| class AppInMemory { | class AppInMemory { | ||||||
|   late App app; |   late App app; | ||||||
| @@ -259,6 +263,15 @@ class AppsProvider with ChangeNotifier { | |||||||
|         attemptToCorrectInstallStatus: false); |         attemptToCorrectInstallStatus: false); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   void uninstallApp(String appId) async { | ||||||
|  |     var intent = AndroidIntent( | ||||||
|  |         action: 'android.intent.action.DELETE', | ||||||
|  |         data: 'package:$appId', | ||||||
|  |         flags: <int>[Flag.FLAG_ACTIVITY_NEW_TASK], | ||||||
|  |         package: 'vnd.android.package-archive'); | ||||||
|  |     await intent.launch(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   Future<String?> confirmApkUrl(App app, BuildContext? context) async { |   Future<String?> confirmApkUrl(App app, BuildContext? context) async { | ||||||
|     // If the App has more than one APK, the user should pick one (if context provided) |     // If the App has more than one APK, the user should pick one (if context provided) | ||||||
|     String? apkUrl = app.apkUrls[app.preferredApkIndex]; |     String? apkUrl = app.apkUrls[app.preferredApkIndex]; | ||||||
| @@ -622,6 +635,49 @@ class AppsProvider with ChangeNotifier { | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   Future<bool> removeAppsWithModal(BuildContext context, List<App> apps) async { | ||||||
|  |     var showUninstallOption = | ||||||
|  |         apps.where((a) => a.installedVersion != null).isNotEmpty; | ||||||
|  |     var values = await showDialog( | ||||||
|  |         context: context, | ||||||
|  |         builder: (BuildContext ctx) { | ||||||
|  |           return GeneratedFormModal( | ||||||
|  |             title: plural('removeAppQuestion', apps.length), | ||||||
|  |             items: !showUninstallOption | ||||||
|  |                 ? [] | ||||||
|  |                 : [ | ||||||
|  |                     [ | ||||||
|  |                       GeneratedFormSwitch('rmAppEntry', | ||||||
|  |                           label: tr('removeFromObtainium'), defaultValue: true) | ||||||
|  |                     ], | ||||||
|  |                     [ | ||||||
|  |                       GeneratedFormSwitch('uninstallApp', | ||||||
|  |                           label: tr('uninstallFromDevice')) | ||||||
|  |                     ] | ||||||
|  |                   ], | ||||||
|  |             initValid: true, | ||||||
|  |           ); | ||||||
|  |         }); | ||||||
|  |     if (values != null) { | ||||||
|  |       bool uninstall = values['uninstallApp'] == true && showUninstallOption; | ||||||
|  |       bool remove = values['rmAppEntry'] == true || !showUninstallOption; | ||||||
|  |       if (uninstall) { | ||||||
|  |         for (var i = 0; i < apps.length; i++) { | ||||||
|  |           if (apps[i].installedVersion != null) { | ||||||
|  |             uninstallApp(apps[i].id); | ||||||
|  |             apps[i].installedVersion = null; | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |         await saveApps(apps, attemptToCorrectInstallStatus: false); | ||||||
|  |       } | ||||||
|  |       if (remove) { | ||||||
|  |         await removeApps(apps.map((e) => e.id).toList()); | ||||||
|  |       } | ||||||
|  |       return uninstall || remove; | ||||||
|  |     } | ||||||
|  |     return false; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   Future<App?> checkUpdate(String appId) async { |   Future<App?> checkUpdate(String appId) async { | ||||||
|     App? currentApp = apps[appId]!.app; |     App? currentApp = apps[appId]!.app; | ||||||
|     SourceProvider sourceProvider = SourceProvider(); |     SourceProvider sourceProvider = SourceProvider(); | ||||||
|   | |||||||
| @@ -9,6 +9,14 @@ packages: | |||||||
|       url: "https://pub.dev" |       url: "https://pub.dev" | ||||||
|     source: hosted |     source: hosted | ||||||
|     version: "2.1.0" |     version: "2.1.0" | ||||||
|  |   android_intent_plus: | ||||||
|  |     dependency: "direct main" | ||||||
|  |     description: | ||||||
|  |       name: android_intent_plus | ||||||
|  |       sha256: ebd110b60723334bdc6eeb373116d6c52e9bed8feb9dcbd9f034531f56636e31 | ||||||
|  |       url: "https://pub.dev" | ||||||
|  |     source: hosted | ||||||
|  |     version: "3.1.5" | ||||||
|   animations: |   animations: | ||||||
|     dependency: "direct main" |     dependency: "direct main" | ||||||
|     description: |     description: | ||||||
|   | |||||||
| @@ -58,6 +58,7 @@ dependencies: | |||||||
|   android_alarm_manager_plus: ^2.1.0 |   android_alarm_manager_plus: ^2.1.0 | ||||||
|   sqflite: ^2.2.0+3 |   sqflite: ^2.2.0+3 | ||||||
|   easy_localization: ^3.0.1 |   easy_localization: ^3.0.1 | ||||||
|  |   android_intent_plus: ^3.1.5 | ||||||
|  |  | ||||||
|  |  | ||||||
| dev_dependencies: | dev_dependencies: | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user