Change system tray options
This commit is contained in:
@@ -164,6 +164,12 @@
|
|||||||
"clearSelection": "Clear selection"
|
"clearSelection": "Clear selection"
|
||||||
},
|
},
|
||||||
"config": {
|
"config": {
|
||||||
|
"mode": "Mode",
|
||||||
|
"modes": {
|
||||||
|
"none": "None",
|
||||||
|
"proxy": "Proxy",
|
||||||
|
"tun": "VPN"
|
||||||
|
},
|
||||||
"section": {
|
"section": {
|
||||||
"route": "Route Options",
|
"route": "Route Options",
|
||||||
"dns": "DNS Options",
|
"dns": "DNS Options",
|
||||||
@@ -220,7 +226,12 @@
|
|||||||
"tray": {
|
"tray": {
|
||||||
"dashboard": "Dashboard",
|
"dashboard": "Dashboard",
|
||||||
"quit": "Quit",
|
"quit": "Quit",
|
||||||
"systemProxy": "System Proxy"
|
"status": {
|
||||||
|
"connect": "Connect",
|
||||||
|
"connecting": "Connecting",
|
||||||
|
"disconnect": "Disconnect",
|
||||||
|
"disconnecting": "Disconnecting"
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"failure": {
|
"failure": {
|
||||||
"unexpected": "Unexpected Error",
|
"unexpected": "Unexpected Error",
|
||||||
|
|||||||
@@ -164,6 +164,12 @@
|
|||||||
"clearSelection": "حذف انتخابها"
|
"clearSelection": "حذف انتخابها"
|
||||||
},
|
},
|
||||||
"config": {
|
"config": {
|
||||||
|
"mode": "حالت",
|
||||||
|
"modes": {
|
||||||
|
"none": "هیچ یک",
|
||||||
|
"proxy": "پروکسی",
|
||||||
|
"tun": "VPN"
|
||||||
|
},
|
||||||
"section": {
|
"section": {
|
||||||
"route": "تنظیمات مسیریاب",
|
"route": "تنظیمات مسیریاب",
|
||||||
"dns": "تنظیمات DNS",
|
"dns": "تنظیمات DNS",
|
||||||
@@ -220,7 +226,12 @@
|
|||||||
"tray": {
|
"tray": {
|
||||||
"dashboard": "داشبورد",
|
"dashboard": "داشبورد",
|
||||||
"quit": "خروج",
|
"quit": "خروج",
|
||||||
"systemProxy": "پراکسی سیستم"
|
"status": {
|
||||||
|
"connect": "اتصال",
|
||||||
|
"connecting": "در حال اتصال",
|
||||||
|
"disconnect": "قطع اتصال",
|
||||||
|
"disconnecting": "در حال قطع اتصال"
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"failure": {
|
"failure": {
|
||||||
"unexpected": "خطای غیرمنتظره",
|
"unexpected": "خطای غیرمنتظره",
|
||||||
|
|||||||
@@ -164,6 +164,12 @@
|
|||||||
"clearSelection": "Очистить выбор"
|
"clearSelection": "Очистить выбор"
|
||||||
},
|
},
|
||||||
"config": {
|
"config": {
|
||||||
|
"mode": "Режим",
|
||||||
|
"modes": {
|
||||||
|
"none": "Никто",
|
||||||
|
"proxy": "Прокси",
|
||||||
|
"tun": "VPN"
|
||||||
|
},
|
||||||
"section": {
|
"section": {
|
||||||
"route": "Варианты маршрутизации",
|
"route": "Варианты маршрутизации",
|
||||||
"dns": "Параметры DNS",
|
"dns": "Параметры DNS",
|
||||||
@@ -220,7 +226,12 @@
|
|||||||
"tray": {
|
"tray": {
|
||||||
"dashboard": "Панель",
|
"dashboard": "Панель",
|
||||||
"quit": "Выход",
|
"quit": "Выход",
|
||||||
"systemProxy": "Системный прокси"
|
"status": {
|
||||||
|
"connect": "Соединять",
|
||||||
|
"connecting": "Подключение",
|
||||||
|
"disconnect": "Отключить",
|
||||||
|
"disconnecting": "Отключение"
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"failure": {
|
"failure": {
|
||||||
"unexpected": "Неожиданная ошибка",
|
"unexpected": "Неожиданная ошибка",
|
||||||
|
|||||||
@@ -164,6 +164,12 @@
|
|||||||
"clearSelection": "清空选项"
|
"clearSelection": "清空选项"
|
||||||
},
|
},
|
||||||
"config": {
|
"config": {
|
||||||
|
"mode": "模式",
|
||||||
|
"modes": {
|
||||||
|
"none": "没有任何",
|
||||||
|
"proxy": "代理人",
|
||||||
|
"tun": "VPN"
|
||||||
|
},
|
||||||
"section": {
|
"section": {
|
||||||
"route": "路线选项",
|
"route": "路线选项",
|
||||||
"dns": "DNS 选项",
|
"dns": "DNS 选项",
|
||||||
@@ -220,7 +226,12 @@
|
|||||||
"tray": {
|
"tray": {
|
||||||
"dashboard": "控制面板",
|
"dashboard": "控制面板",
|
||||||
"quit": "退出",
|
"quit": "退出",
|
||||||
"systemProxy": "系统代理"
|
"status": {
|
||||||
|
"connect": "连接",
|
||||||
|
"connecting": "正在连接",
|
||||||
|
"disconnect": "断开",
|
||||||
|
"disconnecting": "断开连接"
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"failure": {
|
"failure": {
|
||||||
"unexpected": "意外错误",
|
"unexpected": "意外错误",
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ import 'package:hiddify/data/repository/app_repository_impl.dart';
|
|||||||
import 'package:hiddify/domain/environment.dart';
|
import 'package:hiddify/domain/environment.dart';
|
||||||
import 'package:hiddify/features/common/active_profile/active_profile_notifier.dart';
|
import 'package:hiddify/features/common/active_profile/active_profile_notifier.dart';
|
||||||
import 'package:hiddify/features/common/window/window_controller.dart';
|
import 'package:hiddify/features/common/window/window_controller.dart';
|
||||||
import 'package:hiddify/features/system_tray/system_tray.dart';
|
import 'package:hiddify/features/system_tray/system_tray_controller.dart';
|
||||||
import 'package:hiddify/services/auto_start_service.dart';
|
import 'package:hiddify/services/auto_start_service.dart';
|
||||||
import 'package:hiddify/services/deep_link_service.dart';
|
import 'package:hiddify/services/deep_link_service.dart';
|
||||||
import 'package:hiddify/services/service_providers.dart';
|
import 'package:hiddify/services/service_providers.dart';
|
||||||
|
|||||||
@@ -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/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/features/profiles/notifier/notifier.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/services/service_providers.dart';
|
||||||
import 'package:hiddify/utils/platform_utils.dart';
|
import 'package:hiddify/utils/platform_utils.dart';
|
||||||
import 'package:riverpod_annotation/riverpod_annotation.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 'dart:io';
|
||||||
|
|
||||||
import 'package:hiddify/core/core_providers.dart';
|
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/connectivity/connectivity.dart';
|
||||||
import 'package:hiddify/domain/constants.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/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';
|
||||||
@@ -29,20 +31,12 @@ class SystemTrayController extends _$SystemTrayController
|
|||||||
}
|
}
|
||||||
|
|
||||||
final connection = await ref.watch(connectivityControllerProvider.future);
|
final connection = await ref.watch(connectivityControllerProvider.future);
|
||||||
|
final mode = ref.watch(coreModeStoreProvider);
|
||||||
|
|
||||||
|
final t = ref.watch(translationsProvider);
|
||||||
|
|
||||||
loggy.debug('updating system tray');
|
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(
|
final trayMenu = Menu(
|
||||||
items: [
|
items: [
|
||||||
MenuItem(
|
MenuItem(
|
||||||
@@ -51,11 +45,37 @@ class SystemTrayController extends _$SystemTrayController
|
|||||||
),
|
),
|
||||||
MenuItem.separator(),
|
MenuItem.separator(),
|
||||||
MenuItem.checkbox(
|
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,
|
checked: connection.isConnected,
|
||||||
disabled: connection.isSwitching,
|
disabled: connection.isSwitching,
|
||||||
onClick: handleClickSetAsSystemProxy,
|
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.separator(),
|
||||||
MenuItem(
|
MenuItem(
|
||||||
label: t.tray.quit,
|
label: t.tray.quit,
|
||||||
@@ -66,6 +86,13 @@ class SystemTrayController extends _$SystemTrayController
|
|||||||
await trayManager.setContextMenu(trayMenu);
|
await trayManager.setContextMenu(trayMenu);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool _initialized = false;
|
||||||
|
|
||||||
|
String get _trayIconPath {
|
||||||
|
if (Platform.isWindows) return Assets.images.trayIconIco;
|
||||||
|
return Assets.images.trayIconPng.path;
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Future<void> onTrayIconMouseDown() async {
|
Future<void> onTrayIconMouseDown() async {
|
||||||
await ref.read(windowControllerProvider.notifier).show();
|
await ref.read(windowControllerProvider.notifier).show();
|
||||||
Reference in New Issue
Block a user