// ignore_for_file: use_build_context_synchronously import 'package:dynamic_themes/dynamic_themes.dart'; import 'package:flutter/material.dart'; import 'package:flutter_i18n/flutter_i18n.dart'; import 'package:revanced_manager/app/app.locator.dart'; import 'package:revanced_manager/app/app.router.dart'; import 'package:revanced_manager/services/manager_api.dart'; import 'package:revanced_manager/ui/widgets/installerView/custom_material_button.dart'; import 'package:revanced_manager/ui/widgets/settingsView/custom_text_field.dart'; import 'package:stacked/stacked.dart'; import 'package:stacked_services/stacked_services.dart'; import 'package:timeago/timeago.dart'; class SettingsViewModel extends BaseViewModel { final NavigationService _navigationService = locator(); final ManagerAPI _managerAPI = locator(); final TextEditingController _orgPatSourceController = TextEditingController(); final TextEditingController _patSourceController = TextEditingController(); final TextEditingController _orgIntSourceController = TextEditingController(); final TextEditingController _intSourceController = TextEditingController(); void setLanguage(String language) { notifyListeners(); } void navigateToContributors() { _navigationService.navigateTo(Routes.contributorsView); } Future updateLanguage(BuildContext context, String? value) async { if (value != null) { await FlutterI18n.refresh(context, Locale(value)); setLocaleMessages(value, EnMessages()); } } bool getDynamicThemeStatus() { return _managerAPI.getUseDynamicTheme(); } void setUseDynamicTheme(BuildContext context, bool value) async { await _managerAPI.setUseDynamicTheme(value); int currentTheme = DynamicTheme.of(context)!.themeId; if (currentTheme.isEven) { DynamicTheme.of(context)!.setTheme(value ? 2 : 0); } else { DynamicTheme.of(context)!.setTheme(value ? 3 : 1); } notifyListeners(); } bool getDarkThemeStatus() { return _managerAPI.getUseDarkTheme(); } void setUseDarkTheme(BuildContext context, bool value) async { await _managerAPI.setUseDarkTheme(value); int currentTheme = DynamicTheme.of(context)!.themeId; if (currentTheme < 2) { DynamicTheme.of(context)!.setTheme(value ? 1 : 0); } else { DynamicTheme.of(context)!.setTheme(value ? 3 : 2); } notifyListeners(); } Future showLanguagesDialog(BuildContext context) { return showDialog( context: context, builder: (context) => SimpleDialog( title: I18nText('settingsView.languageLabel'), backgroundColor: Theme.of(context).colorScheme.surface, children: [ RadioListTile( title: I18nText('settingsView.englishOption'), value: 'en', groupValue: 'en', onChanged: (value) { updateLanguage(context, value); Navigator.of(context).pop(); }, ), ], ), ); } Future showSourcesDialog(BuildContext context) async { String patchesRepo = _managerAPI.getPatchesRepo(); String integrationsRepo = _managerAPI.getIntegrationsRepo(); _orgPatSourceController.text = patchesRepo.split('/')[0]; _patSourceController.text = patchesRepo.split('/')[1]; _orgIntSourceController.text = integrationsRepo.split('/')[0]; _intSourceController.text = integrationsRepo.split('/')[1]; return showDialog( context: context, builder: (context) => AlertDialog( title: I18nText('settingsView.sourcesLabel'), content: SingleChildScrollView( child: Column( children: [ CustomTextField( leadingIcon: Icon( Icons.extension_outlined, color: Theme.of(context).colorScheme.primary, ), inputController: _orgPatSourceController, label: I18nText('settingsView.orgPatchesLabel'), hint: patchesRepo.split('/')[0], onChanged: (value) => notifyListeners(), ), const SizedBox(height: 8), CustomTextField( leadingIcon: const Icon( Icons.extension_outlined, color: Colors.transparent, ), inputController: _patSourceController, label: I18nText('settingsView.sourcesPatchesLabel'), hint: patchesRepo.split('/')[1], onChanged: (value) => notifyListeners(), ), const SizedBox(height: 20), CustomTextField( leadingIcon: Icon( Icons.merge_outlined, color: Theme.of(context).colorScheme.primary, ), inputController: _orgIntSourceController, label: I18nText('settingsView.orgIntegrationsLabel'), hint: integrationsRepo.split('/')[0], onChanged: (value) => notifyListeners(), ), const SizedBox(height: 8), CustomTextField( leadingIcon: const Icon( Icons.merge_outlined, color: Colors.transparent, ), inputController: _intSourceController, label: I18nText('settingsView.sourcesIntegrationsLabel'), hint: integrationsRepo.split('/')[1], onChanged: (value) => notifyListeners(), ), ], ), ), actions: [ CustomMaterialButton( isFilled: false, label: I18nText('cancelButton'), onPressed: () { _orgPatSourceController.clear(); _patSourceController.clear(); _orgIntSourceController.clear(); _intSourceController.clear(); Navigator.of(context).pop(); }, ), CustomMaterialButton( label: I18nText('okButton'), onPressed: () { _managerAPI.setPatchesRepo( '${_orgPatSourceController.text}/${_patSourceController.text}', ); _managerAPI.setIntegrationsRepo( '${_orgIntSourceController.text}/${_intSourceController.text}', ); Navigator.of(context).pop(); }, ) ], backgroundColor: Theme.of(context).colorScheme.secondaryContainer, ), ); } }