Change prefs
This commit is contained in:
@@ -33,7 +33,7 @@ Future<void> lazyBootstrap(WidgetsBinding widgetsBinding) async {
|
||||
overrides: [sharedPreferencesProvider.overrideWithValue(sharedPreferences)],
|
||||
);
|
||||
|
||||
final debug = container.read(debugModeProvider) || kDebugMode;
|
||||
final debug = container.read(debugModeNotifierProvider) || kDebugMode;
|
||||
|
||||
final filesEditor = container.read(filesEditorServiceProvider);
|
||||
await filesEditor.init();
|
||||
@@ -42,7 +42,7 @@ Future<void> lazyBootstrap(WidgetsBinding widgetsBinding) async {
|
||||
await container.read(runtimeDetailsServiceProvider).init();
|
||||
_loggy.info("basic setup took [${_stopWatch.elapsedMilliseconds}]ms");
|
||||
|
||||
final silentStart = container.read(silentStartProvider);
|
||||
final silentStart = container.read(silentStartNotifierProvider);
|
||||
if (silentStart) {
|
||||
FlutterNativeSplash.remove();
|
||||
}
|
||||
|
||||
@@ -13,7 +13,7 @@ class AppView extends HookConsumerWidget with PresLogger {
|
||||
@override
|
||||
Widget build(BuildContext context, WidgetRef ref) {
|
||||
final router = ref.watch(routerProvider);
|
||||
final locale = ref.watch(localeNotifierProvider).locale;
|
||||
final locale = ref.watch(localeNotifierProvider).flutterLocale;
|
||||
final theme = ref.watch(themeProvider);
|
||||
|
||||
ref.watch(commonControllersProvider);
|
||||
@@ -21,7 +21,7 @@ class AppView extends HookConsumerWidget with PresLogger {
|
||||
return MaterialApp.router(
|
||||
routerConfig: router,
|
||||
locale: locale,
|
||||
supportedLocales: AppLocale.locales,
|
||||
supportedLocales: AppLocaleUtils.supportedLocales,
|
||||
localizationsDelegates: GlobalMaterialLocalizations.delegates,
|
||||
debugShowCheckedModeBanner: false,
|
||||
themeMode: theme.mode,
|
||||
|
||||
@@ -5,7 +5,7 @@ part 'core_providers.g.dart';
|
||||
|
||||
@Riverpod(keepAlive: true)
|
||||
TranslationsEn translations(TranslationsRef ref) =>
|
||||
ref.watch(localeNotifierProvider).translations();
|
||||
ref.watch(localeNotifierProvider).build();
|
||||
|
||||
@Riverpod(keepAlive: true)
|
||||
AppTheme theme(ThemeRef ref) => AppTheme(
|
||||
|
||||
@@ -1,5 +1,33 @@
|
||||
import 'package:hiddify/data/data_providers.dart';
|
||||
import 'package:hiddify/utils/pref_notifier.dart';
|
||||
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
||||
|
||||
final silentStartProvider = PrefNotifier.provider("silent_start", false);
|
||||
part 'general_prefs.g.dart';
|
||||
|
||||
final debugModeProvider = PrefNotifier.provider("debug_mode", false);
|
||||
@Riverpod(keepAlive: true)
|
||||
class SilentStartNotifier extends _$SilentStartNotifier {
|
||||
late final _pref =
|
||||
Pref(ref.watch(sharedPreferencesProvider), "silent_start", false);
|
||||
|
||||
@override
|
||||
bool build() => _pref.getValue();
|
||||
|
||||
Future<void> update(bool value) {
|
||||
state = value;
|
||||
return _pref.update(value);
|
||||
}
|
||||
}
|
||||
|
||||
@Riverpod(keepAlive: true)
|
||||
class DebugModeNotifier extends _$DebugModeNotifier {
|
||||
late final _pref =
|
||||
Pref(ref.watch(sharedPreferencesProvider), "debug_mode", false);
|
||||
|
||||
@override
|
||||
bool build() => _pref.getValue();
|
||||
|
||||
Future<void> update(bool value) {
|
||||
state = value;
|
||||
return _pref.update(value);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,5 +1,3 @@
|
||||
import 'package:dartx/dartx.dart';
|
||||
import 'package:flutter/widgets.dart';
|
||||
import 'package:hiddify/data/data_providers.dart';
|
||||
import 'package:hiddify/gen/fonts.gen.dart';
|
||||
import 'package:hiddify/gen/translations.g.dart';
|
||||
@@ -24,32 +22,7 @@ class LocaleNotifier extends _$LocaleNotifier {
|
||||
}
|
||||
}
|
||||
|
||||
enum AppLocale {
|
||||
en,
|
||||
fa;
|
||||
|
||||
Locale get locale {
|
||||
return Locale(name);
|
||||
}
|
||||
|
||||
static List<Locale> get locales =>
|
||||
AppLocale.values.map((e) => e.locale).toList();
|
||||
|
||||
static AppLocale fromString(String e) {
|
||||
return AppLocale.values.firstOrNullWhere((element) => element.name == e) ??
|
||||
AppLocale.en;
|
||||
}
|
||||
|
||||
static AppLocale deviceLocale() {
|
||||
return AppLocale.fromString(
|
||||
AppLocaleUtils.findDeviceLocale().languageCode,
|
||||
);
|
||||
}
|
||||
|
||||
TranslationsEn translations() {
|
||||
final appLocale = AppLocaleUtils.parse(name);
|
||||
return appLocale.build();
|
||||
}
|
||||
|
||||
String get preferredFontFamily => this == fa ? FontFamily.shabnam : "";
|
||||
extension AppLocaleX on AppLocale {
|
||||
String get preferredFontFamily =>
|
||||
this == AppLocale.fa ? FontFamily.shabnam : "";
|
||||
}
|
||||
|
||||
@@ -22,7 +22,7 @@ class WindowController extends _$WindowController
|
||||
await windowManager.waitUntilReadyToShow(
|
||||
windowOptions,
|
||||
() async {
|
||||
if (ref.read(silentStartProvider)) {
|
||||
if (ref.read(silentStartNotifierProvider)) {
|
||||
loggy.debug("silent start is enabled, hiding window");
|
||||
await windowManager.hide();
|
||||
}
|
||||
|
||||
@@ -23,7 +23,7 @@ class LogsPage extends HookConsumerWidget with PresLogger {
|
||||
final asyncState = ref.watch(logsNotifierProvider);
|
||||
final notifier = ref.watch(logsNotifierProvider.notifier);
|
||||
|
||||
final debug = ref.watch(debugModeProvider);
|
||||
final debug = ref.watch(debugModeNotifierProvider);
|
||||
final filesEditor = ref.watch(filesEditorServiceProvider);
|
||||
|
||||
final List<PopupMenuEntry> popupButtons = debug || PlatformUtils.isDesktop
|
||||
|
||||
@@ -26,7 +26,7 @@ class ConfigOptionsPage extends HookConsumerWidget {
|
||||
),
|
||||
body: ListView(
|
||||
children: [
|
||||
if (ref.watch(debugModeProvider))
|
||||
if (ref.watch(debugModeNotifierProvider))
|
||||
SwitchListTile(
|
||||
title: Text(t.settings.config.executeConfigAsIs),
|
||||
subtitle: Text(t.settings.config.executeConfigAsIsMsg),
|
||||
|
||||
@@ -12,7 +12,7 @@ class AdvancedSettingTiles extends HookConsumerWidget {
|
||||
Widget build(BuildContext context, WidgetRef ref) {
|
||||
final t = ref.watch(translationsProvider);
|
||||
|
||||
final debug = ref.watch(debugModeProvider);
|
||||
final debug = ref.watch(debugModeNotifierProvider);
|
||||
|
||||
return Column(
|
||||
children: [
|
||||
@@ -47,7 +47,7 @@ class AdvancedSettingTiles extends HookConsumerWidget {
|
||||
},
|
||||
);
|
||||
}
|
||||
await ref.read(debugModeProvider.notifier).update(value);
|
||||
await ref.read(debugModeNotifierProvider.notifier).update(value);
|
||||
},
|
||||
),
|
||||
],
|
||||
|
||||
@@ -87,9 +87,11 @@ class GeneralSettingTiles extends HookConsumerWidget {
|
||||
if (PlatformUtils.isDesktop) ...[
|
||||
SwitchListTile(
|
||||
title: Text(t.settings.general.silentStart),
|
||||
value: ref.watch(silentStartProvider),
|
||||
value: ref.watch(silentStartNotifierProvider),
|
||||
onChanged: (value) async {
|
||||
await ref.read(silentStartProvider.notifier).update(value);
|
||||
await ref
|
||||
.read(silentStartNotifierProvider.notifier)
|
||||
.update(value);
|
||||
},
|
||||
),
|
||||
],
|
||||
|
||||
Reference in New Issue
Block a user