Files
umbrix/lib/features/common/general_pref_tiles.dart

180 lines
5.9 KiB
Dart
Raw Normal View History

2024-02-15 15:23:02 +03:30
import 'package:fluentui_system_icons/fluentui_system_icons.dart';
2023-09-17 00:23:31 +03:30
import 'package:flutter/material.dart';
2023-12-22 14:16:24 +03:30
import 'package:hiddify/core/analytics/analytics_controller.dart';
2023-12-01 12:56:24 +03:30
import 'package:hiddify/core/localization/locale_extensions.dart';
import 'package:hiddify/core/localization/locale_preferences.dart';
import 'package:hiddify/core/localization/translations.dart';
import 'package:hiddify/core/model/region.dart';
import 'package:hiddify/core/theme/app_theme_mode.dart';
import 'package:hiddify/core/theme/theme_preferences.dart';
import 'package:hiddify/features/config_option/data/config_option_repository.dart';
2023-09-17 00:23:31 +03:30
import 'package:hooks_riverpod/hooks_riverpod.dart';
class LocalePrefTile extends ConsumerWidget {
2023-09-17 00:23:31 +03:30
const LocalePrefTile({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
final t = ref.watch(translationsProvider);
2023-12-01 12:56:24 +03:30
final locale = ref.watch(localePreferencesProvider);
2023-09-17 00:23:31 +03:30
return ListTile(
title: Text(t.settings.general.locale),
2023-11-25 22:48:22 +03:30
subtitle: Text(locale.localeName),
2024-02-15 15:23:02 +03:30
leading: const Icon(FluentIcons.local_language_24_regular),
2023-09-17 00:23:31 +03:30
onTap: () async {
final selectedLocale = await showDialog<AppLocale>(
context: context,
builder: (context) {
return SimpleDialog(
title: Text(t.settings.general.locale),
children: AppLocale.values
.map(
(e) => RadioListTile(
2023-11-25 22:48:22 +03:30
title: Text(e.localeName),
2023-09-17 00:23:31 +03:30
value: e,
groupValue: locale,
2023-12-28 10:43:57 +03:30
onChanged: Navigator.of(context).maybePop,
2023-09-17 00:23:31 +03:30
),
)
.toList(),
);
},
);
if (selectedLocale != null) {
await ref.read(localePreferencesProvider.notifier).changeLocale(selectedLocale);
2023-09-17 00:23:31 +03:30
}
},
);
}
}
class RegionPrefTile extends ConsumerWidget {
2023-09-17 14:55:46 +03:30
const RegionPrefTile({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
final t = ref.watch(translationsProvider);
final region = ref.watch(ConfigOptions.region);
2023-09-17 14:55:46 +03:30
return ListTile(
title: Text(t.settings.general.region),
subtitle: Text(region.present(t)),
2024-02-15 15:23:02 +03:30
leading: const Icon(FluentIcons.globe_location_24_regular),
2023-09-17 14:55:46 +03:30
onTap: () async {
final selectedRegion = await showDialog<Region>(
context: context,
builder: (context) {
return SimpleDialog(
title: Text(t.settings.general.region),
children: Region.values
.map(
(e) => RadioListTile(
title: Text(e.present(t)),
value: e,
groupValue: region,
2023-12-28 10:43:57 +03:30
onChanged: Navigator.of(context).maybePop,
2023-09-17 14:55:46 +03:30
),
)
.toList(),
);
},
);
if (selectedRegion != null) {
// await ref.read(Preferences.region.notifier).update(selectedRegion);
2024-07-27 23:51:54 +02:00
await ref.watch(ConfigOptions.region.notifier).update(selectedRegion);
2024-07-27 23:51:54 +02:00
await ref.watch(ConfigOptions.directDnsAddress.notifier).reset();
// await ref.read(configOptionNotifierProvider.notifier).build();
// await ref.watch(ConfigOptions.resolveDestination.notifier).update(!ref.watch(ConfigOptions.resolveDestination.notifier).raw());
//for reload config
// final tmp = ref.watch(ConfigOptions.resolveDestination.notifier).raw();
// await ref.watch(ConfigOptions.resolveDestination.notifier).update(!tmp);
// await ref.watch(ConfigOptions.resolveDestination.notifier).update(tmp);
//TODO: fix it
2023-09-17 14:55:46 +03:30
}
},
);
}
}
class EnableAnalyticsPrefTile extends ConsumerWidget {
2023-09-17 00:23:31 +03:30
const EnableAnalyticsPrefTile({
super.key,
this.onChanged,
});
final ValueChanged<bool>? onChanged;
@override
Widget build(BuildContext context, WidgetRef ref) {
final t = ref.watch(translationsProvider);
2023-12-23 11:01:48 +03:30
final enabled = ref.watch(analyticsControllerProvider).requireValue;
2023-09-17 00:23:31 +03:30
return SwitchListTile(
title: Text(t.settings.general.enableAnalytics),
subtitle: Text(
t.settings.general.enableAnalyticsMsg,
style: Theme.of(context).textTheme.bodySmall,
),
2024-02-15 15:23:02 +03:30
secondary: const Icon(FluentIcons.bug_24_regular),
2023-12-23 11:01:48 +03:30
value: enabled,
2023-09-17 00:23:31 +03:30
onChanged: (value) async {
if (onChanged != null) {
return onChanged!(value);
}
2023-12-23 11:01:48 +03:30
if (enabled) {
await ref.read(analyticsControllerProvider.notifier).disableAnalytics();
2023-12-22 14:16:24 +03:30
} else {
await ref.read(analyticsControllerProvider.notifier).enableAnalytics();
2023-12-22 14:16:24 +03:30
}
2023-09-17 00:23:31 +03:30
},
);
}
}
class ThemeModePrefTile extends ConsumerWidget {
const ThemeModePrefTile({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
final t = ref.watch(translationsProvider);
final themeMode = ref.watch(themePreferencesProvider);
return ListTile(
title: Text(t.settings.general.themeMode),
subtitle: Text(themeMode.present(t)),
leading: const Icon(FluentIcons.weather_moon_20_regular),
onTap: () async {
final selectedThemeMode = await showDialog<AppThemeMode>(
context: context,
builder: (context) {
return SimpleDialog(
title: Text(t.settings.general.themeMode),
children: AppThemeMode.values
.map(
(e) => RadioListTile(
title: Text(e.present(t)),
value: e,
groupValue: themeMode,
onChanged: Navigator.of(context).maybePop,
),
)
.toList(),
);
},
);
if (selectedThemeMode != null) {
await ref.read(themePreferencesProvider.notifier).changeThemeMode(selectedThemeMode);
}
},
);
}
}