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

102 lines
3.5 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';
2023-09-06 12:56:30 +03:30
import 'package:hiddify/core/prefs/prefs.dart';
2023-07-08 23:16:22 +03:30
import 'package:hiddify/features/settings/widgets/theme_mode_switch_button.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';
2023-09-01 15:00:41 +03:30
class GeneralSettingTiles extends HookConsumerWidget {
const GeneralSettingTiles({super.key});
2023-07-08 23:16:22 +03:30
@override
Widget build(BuildContext context, WidgetRef ref) {
final t = ref.watch(translationsProvider);
final locale = ref.watch(localeNotifierProvider);
2023-07-08 23:16:22 +03:30
2023-09-06 12:56:30 +03:30
final theme = ref.watch(themeProvider);
2023-07-08 23:16:22 +03:30
return Column(
children: [
ListTile(
2023-09-01 15:00:41 +03:30
title: Text(t.settings.general.locale),
2023-07-08 23:16:22 +03:30
subtitle: Text(
LocaleNamesLocalizationsDelegate.nativeLocaleNames[locale.name] ??
locale.name,
),
2023-09-01 15:00:41 +03:30
leading: const Icon(Icons.language),
2023-07-08 23:16:22 +03:30
onTap: () async {
2023-09-06 12:56:30 +03:30
final selectedLocale = await showDialog<AppLocale>(
2023-07-08 23:16:22 +03:30
context: context,
builder: (context) {
return SimpleDialog(
2023-09-01 15:00:41 +03:30
title: Text(t.settings.general.locale),
2023-09-06 12:56:30 +03:30
children: AppLocale.values
2023-07-08 23:16:22 +03:30
.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(localeNotifierProvider.notifier)
.update(selectedLocale);
2023-07-08 23:16:22 +03:30
}
},
),
ListTile(
2023-09-01 15:00:41 +03:30
title: Text(t.settings.general.themeMode),
2023-07-08 23:16:22 +03:30
subtitle: Text(
2023-09-06 12:56:30 +03:30
switch (theme.mode) {
2023-07-08 23:16:22 +03:30
ThemeMode.system => t.settings.general.themeModes.system,
ThemeMode.light => t.settings.general.themeModes.light,
ThemeMode.dark => t.settings.general.themeModes.dark,
2023-09-01 15:00:41 +03:30
},
2023-07-08 23:16:22 +03:30
),
trailing: ThemeModeSwitch(
2023-09-06 12:56:30 +03:30
themeMode: theme.mode,
onChanged: ref.read(themeModeNotifierProvider.notifier).update,
2023-07-08 23:16:22 +03:30
),
2023-09-01 15:00:41 +03:30
leading: const Icon(Icons.light_mode),
2023-07-08 23:16:22 +03:30
onTap: () async {
await ref.read(themeModeNotifierProvider.notifier).update(
2023-09-06 12:56:30 +03:30
Theme.of(context).brightness == Brightness.light
? ThemeMode.dark
: ThemeMode.light,
);
2023-07-08 23:16:22 +03:30
},
),
SwitchListTile(
2023-09-01 15:00:41 +03:30
title: Text(t.settings.general.trueBlack),
2023-07-08 23:16:22 +03:30
value: theme.trueBlack,
onChanged: ref.read(trueBlackThemeNotifierProvider.notifier).update,
2023-07-08 23:16:22 +03:30
),
2023-08-24 00:58:58 +03:30
if (PlatformUtils.isDesktop) ...[
2023-07-15 18:00:44 +03:30
SwitchListTile(
2023-09-01 15:00:41 +03:30
title: Text(t.settings.general.silentStart),
2023-09-07 13:43:46 +03:30
value: ref.watch(silentStartNotifierProvider),
2023-08-26 16:18:38 +03:30
onChanged: (value) async {
2023-09-07 13:43:46 +03:30
await ref
.read(silentStartNotifierProvider.notifier)
.update(value);
2023-07-15 18:00:44 +03:30
},
),
2023-08-24 00:58:58 +03:30
],
2023-07-08 23:16:22 +03:30
],
);
}
}