Remove unnecessary prefs
This commit is contained in:
@@ -51,8 +51,7 @@ Future<void> lazyBootstrap(WidgetsBinding widgetsBinding) async {
|
|||||||
await container.read(runtimeDetailsServiceProvider).init();
|
await container.read(runtimeDetailsServiceProvider).init();
|
||||||
_loggy.info("basic setup took [${_stopWatch.elapsedMilliseconds}]ms");
|
_loggy.info("basic setup took [${_stopWatch.elapsedMilliseconds}]ms");
|
||||||
|
|
||||||
final silentStart =
|
final silentStart = container.read(silentStartProvider);
|
||||||
container.read(prefsControllerProvider).general.silentStart;
|
|
||||||
if (silentStart) {
|
if (silentStart) {
|
||||||
FlutterNativeSplash.remove();
|
FlutterNativeSplash.remove();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,17 +1,3 @@
|
|||||||
import 'package:freezed_annotation/freezed_annotation.dart';
|
import 'package:hiddify/utils/pref_notifier.dart';
|
||||||
|
|
||||||
part 'general_prefs.freezed.dart';
|
final silentStartProvider = PrefNotifier.provider("silent_start", false);
|
||||||
part 'general_prefs.g.dart';
|
|
||||||
|
|
||||||
@freezed
|
|
||||||
class GeneralPrefs with _$GeneralPrefs {
|
|
||||||
const GeneralPrefs._();
|
|
||||||
|
|
||||||
const factory GeneralPrefs({
|
|
||||||
// desktop only
|
|
||||||
@Default(false) bool silentStart,
|
|
||||||
}) = _GeneralPrefs;
|
|
||||||
|
|
||||||
factory GeneralPrefs.fromJson(Map<String, dynamic> json) =>
|
|
||||||
_$GeneralPrefsFromJson(json);
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -1,2 +1,2 @@
|
|||||||
export 'prefs_controller.dart';
|
export 'general_prefs.dart';
|
||||||
export 'prefs_state.dart';
|
export 'misc_prefs.dart';
|
||||||
|
|||||||
@@ -1,75 +0,0 @@
|
|||||||
import 'dart:convert';
|
|
||||||
|
|
||||||
import 'package:hiddify/core/prefs/general_prefs.dart';
|
|
||||||
import 'package:hiddify/core/prefs/prefs_state.dart';
|
|
||||||
import 'package:hiddify/data/data_providers.dart';
|
|
||||||
import 'package:hiddify/domain/clash/clash.dart';
|
|
||||||
import 'package:hiddify/domain/connectivity/connectivity.dart';
|
|
||||||
import 'package:hiddify/utils/utils.dart';
|
|
||||||
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
|
||||||
import 'package:shared_preferences/shared_preferences.dart';
|
|
||||||
|
|
||||||
part 'prefs_controller.g.dart';
|
|
||||||
|
|
||||||
@Riverpod(keepAlive: true)
|
|
||||||
class PrefsController extends _$PrefsController with AppLogger {
|
|
||||||
@override
|
|
||||||
PrefsState build() {
|
|
||||||
return PrefsState(
|
|
||||||
general: _getGeneralPrefs(),
|
|
||||||
clash: _getClashPrefs(),
|
|
||||||
network: _getNetworkPrefs(),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
SharedPreferences get _prefs => ref.read(sharedPreferencesProvider);
|
|
||||||
|
|
||||||
static const _generalKey = "general_prefs";
|
|
||||||
static const _overridesKey = "clash_overrides";
|
|
||||||
static const _networkKey = "network_prefs";
|
|
||||||
|
|
||||||
GeneralPrefs _getGeneralPrefs() {
|
|
||||||
final persisted = _prefs.getString(_generalKey);
|
|
||||||
if (persisted == null) return const GeneralPrefs();
|
|
||||||
return GeneralPrefs.fromJson(jsonDecode(persisted) as Map<String, dynamic>);
|
|
||||||
}
|
|
||||||
|
|
||||||
ClashConfig _getClashPrefs() {
|
|
||||||
final persisted = _prefs.getString(_overridesKey);
|
|
||||||
if (persisted == null) return const ClashConfig();
|
|
||||||
return ClashConfig.fromJson(jsonDecode(persisted) as Map<String, dynamic>);
|
|
||||||
}
|
|
||||||
|
|
||||||
NetworkPrefs _getNetworkPrefs() {
|
|
||||||
final persisted = _prefs.getString(_networkKey);
|
|
||||||
if (persisted == null) return const NetworkPrefs();
|
|
||||||
return NetworkPrefs.fromJson(jsonDecode(persisted) as Map<String, dynamic>);
|
|
||||||
}
|
|
||||||
|
|
||||||
Future<void> patchGeneralPrefs({bool? silentStart}) async {
|
|
||||||
final newPrefs = state.general.copyWith(
|
|
||||||
silentStart: silentStart ?? state.general.silentStart,
|
|
||||||
);
|
|
||||||
await _prefs.setString(_generalKey, jsonEncode(newPrefs.toJson()));
|
|
||||||
state = state.copyWith(general: newPrefs);
|
|
||||||
}
|
|
||||||
|
|
||||||
Future<void> patchClashOverrides(ClashConfigPatch overrides) async {
|
|
||||||
final newPrefs = state.clash.patch(overrides);
|
|
||||||
await _prefs.setString(_overridesKey, jsonEncode(newPrefs.toJson()));
|
|
||||||
state = state.copyWith(clash: newPrefs);
|
|
||||||
}
|
|
||||||
|
|
||||||
Future<void> patchNetworkPrefs({
|
|
||||||
bool? systemProxy,
|
|
||||||
bool? bypassPrivateNetworks,
|
|
||||||
}) async {
|
|
||||||
final newPrefs = state.network.copyWith(
|
|
||||||
systemProxy: systemProxy ?? state.network.systemProxy,
|
|
||||||
bypassPrivateNetworks:
|
|
||||||
bypassPrivateNetworks ?? state.network.bypassPrivateNetworks,
|
|
||||||
);
|
|
||||||
await _prefs.setString(_networkKey, jsonEncode(newPrefs.toJson()));
|
|
||||||
state = state.copyWith(network: newPrefs);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,17 +0,0 @@
|
|||||||
import 'package:freezed_annotation/freezed_annotation.dart';
|
|
||||||
import 'package:hiddify/core/prefs/general_prefs.dart';
|
|
||||||
import 'package:hiddify/domain/clash/clash.dart';
|
|
||||||
import 'package:hiddify/domain/connectivity/connectivity.dart';
|
|
||||||
|
|
||||||
part 'prefs_state.freezed.dart';
|
|
||||||
|
|
||||||
@freezed
|
|
||||||
class PrefsState with _$PrefsState {
|
|
||||||
const PrefsState._();
|
|
||||||
|
|
||||||
const factory PrefsState({
|
|
||||||
@Default(GeneralPrefs()) GeneralPrefs general,
|
|
||||||
@Default(ClashConfig()) ClashConfig clash,
|
|
||||||
@Default(NetworkPrefs()) NetworkPrefs network,
|
|
||||||
}) = _PrefsState;
|
|
||||||
}
|
|
||||||
@@ -1,5 +1,4 @@
|
|||||||
export 'connection_facade.dart';
|
export 'connection_facade.dart';
|
||||||
export 'connection_failure.dart';
|
export 'connection_failure.dart';
|
||||||
export 'connection_status.dart';
|
export 'connection_status.dart';
|
||||||
export 'network_prefs.dart';
|
|
||||||
export 'traffic.dart';
|
export 'traffic.dart';
|
||||||
|
|||||||
@@ -1,17 +0,0 @@
|
|||||||
import 'package:freezed_annotation/freezed_annotation.dart';
|
|
||||||
|
|
||||||
part 'network_prefs.freezed.dart';
|
|
||||||
part 'network_prefs.g.dart';
|
|
||||||
|
|
||||||
@freezed
|
|
||||||
class NetworkPrefs with _$NetworkPrefs {
|
|
||||||
const NetworkPrefs._();
|
|
||||||
|
|
||||||
const factory NetworkPrefs({
|
|
||||||
@Default(true) bool systemProxy,
|
|
||||||
@Default(true) bool bypassPrivateNetworks,
|
|
||||||
}) = _NetworkPrefs;
|
|
||||||
|
|
||||||
factory NetworkPrefs.fromJson(Map<String, dynamic> json) =>
|
|
||||||
_$NetworkPrefsFromJson(json);
|
|
||||||
}
|
|
||||||
@@ -1,26 +0,0 @@
|
|||||||
import 'package:hiddify/core/prefs/prefs.dart';
|
|
||||||
import 'package:hiddify/data/data_providers.dart';
|
|
||||||
import 'package:hiddify/domain/clash/clash.dart';
|
|
||||||
import 'package:hiddify/features/common/connectivity/connectivity_controller.dart';
|
|
||||||
import 'package:hiddify/utils/utils.dart';
|
|
||||||
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
|
||||||
|
|
||||||
part 'clash_mode.g.dart';
|
|
||||||
|
|
||||||
@Riverpod(keepAlive: true)
|
|
||||||
class ClashMode extends _$ClashMode with AppLogger {
|
|
||||||
@override
|
|
||||||
Future<TunnelMode?> build() async {
|
|
||||||
final clash = ref.watch(coreFacadeProvider);
|
|
||||||
if (!await ref.watch(serviceRunningProvider.future)) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
ref.watch(prefsControllerProvider.select((value) => value.clash.mode));
|
|
||||||
return clash.getConfigs().map((r) => r.mode).getOrElse(
|
|
||||||
(l) {
|
|
||||||
loggy.warning("fetching clash mode: $l");
|
|
||||||
throw l;
|
|
||||||
},
|
|
||||||
).run();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -22,7 +22,7 @@ class WindowController extends _$WindowController
|
|||||||
await windowManager.waitUntilReadyToShow(
|
await windowManager.waitUntilReadyToShow(
|
||||||
windowOptions,
|
windowOptions,
|
||||||
() async {
|
() async {
|
||||||
if (ref.read(prefsControllerProvider).general.silentStart) {
|
if (ref.read(silentStartProvider)) {
|
||||||
loggy.debug("silent start is enabled, hiding window");
|
loggy.debug("silent start is enabled, hiding window");
|
||||||
await windowManager.hide();
|
await windowManager.hide();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,7 +16,6 @@ class GroupWithProxies with _$GroupWithProxies {
|
|||||||
|
|
||||||
static Future<List<GroupWithProxies>> fromProxies(
|
static Future<List<GroupWithProxies>> fromProxies(
|
||||||
List<ClashProxy> proxies,
|
List<ClashProxy> proxies,
|
||||||
TunnelMode? mode,
|
|
||||||
) async {
|
) async {
|
||||||
final stopWatch = Stopwatch()..start();
|
final stopWatch = Stopwatch()..start();
|
||||||
final res = await CombineWorker().execute(
|
final res = await CombineWorker().execute(
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ import 'package:fpdart/fpdart.dart';
|
|||||||
import 'package:hiddify/data/data_providers.dart';
|
import 'package:hiddify/data/data_providers.dart';
|
||||||
import 'package:hiddify/domain/clash/clash.dart';
|
import 'package:hiddify/domain/clash/clash.dart';
|
||||||
import 'package:hiddify/domain/core_service_failure.dart';
|
import 'package:hiddify/domain/core_service_failure.dart';
|
||||||
import 'package:hiddify/features/common/clash/clash_mode.dart';
|
|
||||||
import 'package:hiddify/features/common/connectivity/connectivity_controller.dart';
|
import 'package:hiddify/features/common/connectivity/connectivity_controller.dart';
|
||||||
import 'package:hiddify/features/proxies/model/model.dart';
|
import 'package:hiddify/features/proxies/model/model.dart';
|
||||||
import 'package:hiddify/utils/utils.dart';
|
import 'package:hiddify/utils/utils.dart';
|
||||||
@@ -20,11 +19,10 @@ class ProxiesNotifier extends _$ProxiesNotifier with AppLogger {
|
|||||||
if (!await ref.watch(serviceRunningProvider.future)) {
|
if (!await ref.watch(serviceRunningProvider.future)) {
|
||||||
throw const CoreServiceNotRunning();
|
throw const CoreServiceNotRunning();
|
||||||
}
|
}
|
||||||
final mode = await ref.watch(clashModeProvider.future);
|
|
||||||
return _clash.getProxies().flatMap(
|
return _clash.getProxies().flatMap(
|
||||||
(proxies) {
|
(proxies) {
|
||||||
return TaskEither(
|
return TaskEither(
|
||||||
() async => right(await GroupWithProxies.fromProxies(proxies, mode)),
|
() async => right(await GroupWithProxies.fromProxies(proxies)),
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
).getOrElse((l) {
|
).getOrElse((l) {
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import 'package:flutter_localized_locales/flutter_localized_locales.dart';
|
|||||||
import 'package:go_router/go_router.dart';
|
import 'package:go_router/go_router.dart';
|
||||||
import 'package:hiddify/core/core_providers.dart';
|
import 'package:hiddify/core/core_providers.dart';
|
||||||
import 'package:hiddify/core/locale/locale.dart';
|
import 'package:hiddify/core/locale/locale.dart';
|
||||||
import 'package:hiddify/core/prefs/prefs.dart';
|
import 'package:hiddify/core/prefs/general_prefs.dart';
|
||||||
import 'package:hiddify/core/theme/theme.dart';
|
import 'package:hiddify/core/theme/theme.dart';
|
||||||
import 'package:hiddify/features/settings/widgets/theme_mode_switch_button.dart';
|
import 'package:hiddify/features/settings/widgets/theme_mode_switch_button.dart';
|
||||||
import 'package:hiddify/services/service_providers.dart';
|
import 'package:hiddify/services/service_providers.dart';
|
||||||
@@ -18,9 +18,6 @@ class AppearanceSettingTiles extends HookConsumerWidget {
|
|||||||
Widget build(BuildContext context, WidgetRef ref) {
|
Widget build(BuildContext context, WidgetRef ref) {
|
||||||
final t = ref.watch(translationsProvider);
|
final t = ref.watch(translationsProvider);
|
||||||
|
|
||||||
final general =
|
|
||||||
ref.watch(prefsControllerProvider.select((value) => value.general));
|
|
||||||
|
|
||||||
final locale = ref.watch(localeControllerProvider);
|
final locale = ref.watch(localeControllerProvider);
|
||||||
|
|
||||||
final theme = ref.watch(themeControllerProvider);
|
final theme = ref.watch(themeControllerProvider);
|
||||||
@@ -98,11 +95,9 @@ class AppearanceSettingTiles extends HookConsumerWidget {
|
|||||||
if (PlatformUtils.isDesktop) ...[
|
if (PlatformUtils.isDesktop) ...[
|
||||||
SwitchListTile(
|
SwitchListTile(
|
||||||
title: Text(t.settings.general.silentStart.titleCase),
|
title: Text(t.settings.general.silentStart.titleCase),
|
||||||
value: general.silentStart,
|
value: ref.watch(silentStartProvider),
|
||||||
onChanged: (value) {
|
onChanged: (value) async {
|
||||||
ref
|
await ref.read(silentStartProvider.notifier).update(value);
|
||||||
.read(prefsControllerProvider.notifier)
|
|
||||||
.patchGeneralPrefs(silentStart: value);
|
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
ListTile(
|
ListTile(
|
||||||
|
|||||||
@@ -1,9 +1,5 @@
|
|||||||
import 'package:fpdart/fpdart.dart';
|
|
||||||
import 'package:hiddify/core/core_providers.dart';
|
import 'package:hiddify/core/core_providers.dart';
|
||||||
import 'package:hiddify/core/prefs/prefs.dart';
|
|
||||||
import 'package:hiddify/domain/clash/clash.dart';
|
|
||||||
import 'package:hiddify/domain/connectivity/connectivity.dart';
|
import 'package:hiddify/domain/connectivity/connectivity.dart';
|
||||||
import 'package:hiddify/features/common/clash/clash_mode.dart';
|
|
||||||
import 'package:hiddify/features/common/connectivity/connectivity_controller.dart';
|
import 'package:hiddify/features/common/connectivity/connectivity_controller.dart';
|
||||||
import 'package:hiddify/features/common/window/window_controller.dart';
|
import 'package:hiddify/features/common/window/window_controller.dart';
|
||||||
import 'package:hiddify/gen/assets.gen.dart';
|
import 'package:hiddify/gen/assets.gen.dart';
|
||||||
@@ -26,19 +22,14 @@ class SystemTrayController extends _$SystemTrayController
|
|||||||
}
|
}
|
||||||
|
|
||||||
final connection = await ref.watch(connectivityControllerProvider.future);
|
final connection = await ref.watch(connectivityControllerProvider.future);
|
||||||
final mode =
|
|
||||||
ref.watch(clashModeProvider.select((value) => value.valueOrNull));
|
|
||||||
|
|
||||||
loggy.debug('updating system tray');
|
loggy.debug('updating system tray');
|
||||||
await _updateTray(connection, mode);
|
await _updateTray(connection);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool _initialized = false;
|
bool _initialized = false;
|
||||||
|
|
||||||
Future<void> _updateTray(
|
Future<void> _updateTray(ConnectionStatus connection) async {
|
||||||
ConnectionStatus connection,
|
|
||||||
TunnelMode? mode,
|
|
||||||
) async {
|
|
||||||
final t = ref.watch(translationsProvider);
|
final t = ref.watch(translationsProvider);
|
||||||
final trayMenu = Menu(
|
final trayMenu = Menu(
|
||||||
items: [
|
items: [
|
||||||
@@ -46,16 +37,6 @@ class SystemTrayController extends _$SystemTrayController
|
|||||||
label: t.tray.dashboard,
|
label: t.tray.dashboard,
|
||||||
onClick: handleClickShowApp,
|
onClick: handleClickShowApp,
|
||||||
),
|
),
|
||||||
if (mode != null) ...[
|
|
||||||
MenuItem.separator(),
|
|
||||||
...TunnelMode.values.map(
|
|
||||||
(e) => MenuItem.checkbox(
|
|
||||||
label: e.name,
|
|
||||||
checked: e == mode,
|
|
||||||
onClick: (mi) => handleClickModeItem(e, mi),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
MenuItem.separator(),
|
MenuItem.separator(),
|
||||||
MenuItem.checkbox(
|
MenuItem.checkbox(
|
||||||
label: t.tray.systemProxy,
|
label: t.tray.systemProxy,
|
||||||
@@ -89,15 +70,6 @@ class SystemTrayController extends _$SystemTrayController
|
|||||||
await ref.read(windowControllerProvider.notifier).show();
|
await ref.read(windowControllerProvider.notifier).show();
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<void> handleClickModeItem(
|
|
||||||
TunnelMode mode,
|
|
||||||
MenuItem menuItem,
|
|
||||||
) async {
|
|
||||||
return ref
|
|
||||||
.read(prefsControllerProvider.notifier)
|
|
||||||
.patchClashOverrides(ClashConfigPatch(mode: some(mode)));
|
|
||||||
}
|
|
||||||
|
|
||||||
Future<void> handleClickSetAsSystemProxy(MenuItem menuItem) async {
|
Future<void> handleClickSetAsSystemProxy(MenuItem menuItem) async {
|
||||||
return ref.read(connectivityControllerProvider.notifier).toggleConnection();
|
return ref.read(connectivityControllerProvider.notifier).toggleConnection();
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user