Change system tray options
This commit is contained in:
@@ -3,7 +3,7 @@ import 'package:hiddify/features/common/app_update_notifier.dart';
|
||||
import 'package:hiddify/features/common/connectivity/connectivity_controller.dart';
|
||||
import 'package:hiddify/features/common/window/window_controller.dart';
|
||||
import 'package:hiddify/features/profiles/notifier/notifier.dart';
|
||||
import 'package:hiddify/features/system_tray/controller/system_tray_controller.dart';
|
||||
import 'package:hiddify/features/system_tray/system_tray_controller.dart';
|
||||
import 'package:hiddify/services/service_providers.dart';
|
||||
import 'package:hiddify/utils/platform_utils.dart';
|
||||
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
||||
|
||||
@@ -1 +0,0 @@
|
||||
export 'controller/system_tray_controller.dart';
|
||||
@@ -1,8 +1,10 @@
|
||||
import 'dart:io';
|
||||
|
||||
import 'package:hiddify/core/core_providers.dart';
|
||||
import 'package:hiddify/data/repository/config_options_store.dart';
|
||||
import 'package:hiddify/domain/connectivity/connectivity.dart';
|
||||
import 'package:hiddify/domain/constants.dart';
|
||||
import 'package:hiddify/domain/singbox/singbox.dart';
|
||||
import 'package:hiddify/features/common/connectivity/connectivity_controller.dart';
|
||||
import 'package:hiddify/features/common/window/window_controller.dart';
|
||||
import 'package:hiddify/gen/assets.gen.dart';
|
||||
@@ -29,20 +31,12 @@ class SystemTrayController extends _$SystemTrayController
|
||||
}
|
||||
|
||||
final connection = await ref.watch(connectivityControllerProvider.future);
|
||||
final mode = ref.watch(coreModeStoreProvider);
|
||||
|
||||
final t = ref.watch(translationsProvider);
|
||||
|
||||
loggy.debug('updating system tray');
|
||||
await _updateTray(connection);
|
||||
}
|
||||
|
||||
bool _initialized = false;
|
||||
|
||||
String get _trayIconPath {
|
||||
if (Platform.isWindows) return Assets.images.trayIconIco;
|
||||
return Assets.images.trayIconPng.path;
|
||||
}
|
||||
|
||||
Future<void> _updateTray(ConnectionStatus connection) async {
|
||||
final t = ref.watch(translationsProvider);
|
||||
final trayMenu = Menu(
|
||||
items: [
|
||||
MenuItem(
|
||||
@@ -51,11 +45,37 @@ class SystemTrayController extends _$SystemTrayController
|
||||
),
|
||||
MenuItem.separator(),
|
||||
MenuItem.checkbox(
|
||||
label: t.tray.systemProxy,
|
||||
label: switch (connection) {
|
||||
Disconnected() => t.tray.status.connect,
|
||||
Connecting() => t.tray.status.connecting,
|
||||
Connected() => t.tray.status.disconnect,
|
||||
Disconnecting() => t.tray.status.disconnecting,
|
||||
},
|
||||
checked: connection.isConnected,
|
||||
disabled: connection.isSwitching,
|
||||
onClick: handleClickSetAsSystemProxy,
|
||||
),
|
||||
MenuItem.submenu(
|
||||
label: t.settings.config.mode,
|
||||
submenu: Menu(
|
||||
items: [
|
||||
...CoreMode.values.map(
|
||||
(e) => MenuItem.checkbox(
|
||||
checked: e == mode,
|
||||
key: e.name,
|
||||
label: e.present(t),
|
||||
onClick: (menuItem) async {
|
||||
final newMode = CoreMode.values.byName(menuItem.key!);
|
||||
loggy.debug("switching core mode: [$newMode]");
|
||||
await ref
|
||||
.read(coreModeStoreProvider.notifier)
|
||||
.update(newMode);
|
||||
},
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
MenuItem.separator(),
|
||||
MenuItem(
|
||||
label: t.tray.quit,
|
||||
@@ -66,6 +86,13 @@ class SystemTrayController extends _$SystemTrayController
|
||||
await trayManager.setContextMenu(trayMenu);
|
||||
}
|
||||
|
||||
bool _initialized = false;
|
||||
|
||||
String get _trayIconPath {
|
||||
if (Platform.isWindows) return Assets.images.trayIconIco;
|
||||
return Assets.images.trayIconPng.path;
|
||||
}
|
||||
|
||||
@override
|
||||
Future<void> onTrayIconMouseDown() async {
|
||||
await ref.read(windowControllerProvider.notifier).show();
|
||||
Reference in New Issue
Block a user