Change system tray options

This commit is contained in:
problematicconsumer
2023-11-01 22:02:13 +03:30
parent e2f7e24fb4
commit ba5e7d79da
8 changed files with 89 additions and 19 deletions

View File

@@ -12,7 +12,7 @@ import 'package:hiddify/data/repository/app_repository_impl.dart';
import 'package:hiddify/domain/environment.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/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/deep_link_service.dart';
import 'package:hiddify/services/service_providers.dart';

View File

@@ -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';

View File

@@ -1 +0,0 @@
export 'controller/system_tray_controller.dart';

View File

@@ -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();