Files
umbrix/lib/features/settings/widgets/general_setting_tiles.dart

116 lines
4.1 KiB
Dart
Raw Normal View History

2023-07-08 23:16:22 +03:30
import 'package:flutter/material.dart';
import 'package:flutter_localized_locales/flutter_localized_locales.dart';
import 'package:go_router/go_router.dart';
import 'package:hiddify/core/core_providers.dart';
import 'package:hiddify/core/locale/locale.dart';
2023-08-26 16:18:38 +03:30
import 'package:hiddify/core/prefs/general_prefs.dart';
2023-07-08 23:16:22 +03:30
import 'package:hiddify/core/theme/theme.dart';
import 'package:hiddify/features/settings/widgets/theme_mode_switch_button.dart';
2023-08-24 00:58:58 +03:30
import 'package:hiddify/services/service_providers.dart';
2023-08-25 17:58:04 +03:30
import 'package:hiddify/utils/utils.dart';
2023-07-08 23:16:22 +03:30
import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:recase/recase.dart';
class AppearanceSettingTiles extends HookConsumerWidget {
const AppearanceSettingTiles({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
final t = ref.watch(translationsProvider);
final locale = ref.watch(localeControllerProvider);
final theme = ref.watch(themeControllerProvider);
final themeController = ref.watch(themeControllerProvider.notifier);
return Column(
children: [
ListTile(
title: Text(t.settings.general.locale.titleCase),
subtitle: Text(
LocaleNamesLocalizationsDelegate.nativeLocaleNames[locale.name] ??
locale.name,
),
onTap: () async {
final selectedLocale = await showDialog<LocalePref>(
context: context,
builder: (context) {
return SimpleDialog(
title: Text(t.settings.general.locale.titleCase),
children: LocalePref.values
.map(
(e) => RadioListTile(
title: Text(
LocaleNamesLocalizationsDelegate
.nativeLocaleNames[e.name] ??
e.name,
),
value: e,
groupValue: locale,
onChanged: (e) => context.pop(e),
),
)
.toList(),
);
},
);
if (selectedLocale != null) {
await ref
.read(localeControllerProvider.notifier)
.change(selectedLocale);
}
},
),
ListTile(
title: Text(t.settings.general.themeMode.titleCase),
subtitle: Text(
switch (theme.themeMode) {
ThemeMode.system => t.settings.general.themeModes.system,
ThemeMode.light => t.settings.general.themeModes.light,
ThemeMode.dark => t.settings.general.themeModes.dark,
}
.sentenceCase,
),
trailing: ThemeModeSwitch(
themeMode: theme.themeMode,
onChanged: (value) {
themeController.change(themeMode: value);
},
),
onTap: () async {
await themeController.change(
themeMode: Theme.of(context).brightness == Brightness.light
? ThemeMode.dark
: ThemeMode.light,
);
},
),
SwitchListTile(
title: Text(t.settings.general.trueBlack.titleCase),
value: theme.trueBlack,
onChanged: (value) {
themeController.change(trueBlack: value);
},
),
2023-08-24 00:58:58 +03:30
if (PlatformUtils.isDesktop) ...[
2023-07-15 18:00:44 +03:30
SwitchListTile(
title: Text(t.settings.general.silentStart.titleCase),
2023-08-26 16:18:38 +03:30
value: ref.watch(silentStartProvider),
onChanged: (value) async {
await ref.read(silentStartProvider.notifier).update(value);
2023-07-15 18:00:44 +03:30
},
),
2023-08-24 00:58:58 +03:30
ListTile(
title: Text(t.settings.general.openWorkingDir.titleCase),
trailing: const Icon(Icons.arrow_outward_outlined),
onTap: () async {
final path = ref.read(filesEditorServiceProvider).workingDir.uri;
2023-08-25 17:58:04 +03:30
await UriUtils.tryLaunch(path);
2023-08-24 00:58:58 +03:30
},
),
],
2023-07-08 23:16:22 +03:30
],
);
}
}