2024-03-12 15:56:08 +01:00
|
|
|
import 'package:easy_localization/easy_localization.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_hooks/flutter_hooks.dart';
|
|
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
2024-11-21 16:35:58 +01:00
|
|
|
import 'package:immich_mobile/extensions/build_context_extensions.dart';
|
2024-12-11 17:30:56 +01:00
|
|
|
import 'package:immich_mobile/providers/theme.provider.dart';
|
2024-05-02 22:59:14 +02:00
|
|
|
import 'package:immich_mobile/services/app_settings.service.dart';
|
2024-08-06 16:20:27 +02:00
|
|
|
import 'package:immich_mobile/widgets/settings/preference_settings/primary_color_setting.dart';
|
2024-05-07 06:04:21 +02:00
|
|
|
import 'package:immich_mobile/widgets/settings/settings_sub_title.dart';
|
|
|
|
import 'package:immich_mobile/widgets/settings/settings_switch_list_tile.dart';
|
2024-05-10 18:40:41 +02:00
|
|
|
import 'package:immich_mobile/utils/hooks/app_settings_update_hook.dart';
|
2024-03-12 15:56:08 +01:00
|
|
|
|
|
|
|
class ThemeSetting extends HookConsumerWidget {
|
|
|
|
const ThemeSetting({
|
|
|
|
super.key,
|
|
|
|
});
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context, WidgetRef ref) {
|
|
|
|
final currentThemeString = useAppSettingsState(AppSettingsEnum.themeMode);
|
2024-08-06 16:20:27 +02:00
|
|
|
final currentTheme = useValueNotifier(ref.read(immichThemeModeProvider));
|
2024-03-12 15:56:08 +01:00
|
|
|
final isDarkTheme = useValueNotifier(currentTheme.value == ThemeMode.dark);
|
|
|
|
final isSystemTheme =
|
|
|
|
useValueNotifier(currentTheme.value == ThemeMode.system);
|
|
|
|
|
2024-08-06 16:20:27 +02:00
|
|
|
final applyThemeToBackgroundSetting =
|
|
|
|
useAppSettingsState(AppSettingsEnum.colorfulInterface);
|
|
|
|
final applyThemeToBackgroundProvider =
|
|
|
|
useValueNotifier(ref.read(colorfulInterfaceSettingProvider));
|
|
|
|
|
2024-03-12 15:56:08 +01:00
|
|
|
useValueChanged(
|
|
|
|
currentThemeString.value,
|
|
|
|
(_, __) => currentTheme.value = switch (currentThemeString.value) {
|
|
|
|
"light" => ThemeMode.light,
|
|
|
|
"dark" => ThemeMode.dark,
|
|
|
|
_ => ThemeMode.system,
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2024-08-06 16:20:27 +02:00
|
|
|
useValueChanged(
|
|
|
|
applyThemeToBackgroundSetting.value,
|
|
|
|
(_, __) => applyThemeToBackgroundProvider.value =
|
|
|
|
applyThemeToBackgroundSetting.value,
|
|
|
|
);
|
|
|
|
|
2024-03-12 15:56:08 +01:00
|
|
|
void onThemeChange(bool isDark) {
|
|
|
|
if (isDark) {
|
2024-08-06 16:20:27 +02:00
|
|
|
ref.watch(immichThemeModeProvider.notifier).state = ThemeMode.dark;
|
2024-03-12 15:56:08 +01:00
|
|
|
currentThemeString.value = "dark";
|
|
|
|
} else {
|
2024-08-06 16:20:27 +02:00
|
|
|
ref.watch(immichThemeModeProvider.notifier).state = ThemeMode.light;
|
2024-03-12 15:56:08 +01:00
|
|
|
currentThemeString.value = "light";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void onSystemThemeChange(bool isSystem) {
|
|
|
|
if (isSystem) {
|
|
|
|
currentThemeString.value = "system";
|
|
|
|
isSystemTheme.value = true;
|
2024-08-06 16:20:27 +02:00
|
|
|
ref.watch(immichThemeModeProvider.notifier).state = ThemeMode.system;
|
2024-03-12 15:56:08 +01:00
|
|
|
} else {
|
2024-11-21 16:35:58 +01:00
|
|
|
final currentSystemBrightness = context.platformBrightness;
|
2024-03-12 15:56:08 +01:00
|
|
|
isSystemTheme.value = false;
|
|
|
|
isDarkTheme.value = currentSystemBrightness == Brightness.dark;
|
|
|
|
if (currentSystemBrightness == Brightness.light) {
|
|
|
|
currentThemeString.value = "light";
|
2024-08-06 16:20:27 +02:00
|
|
|
ref.watch(immichThemeModeProvider.notifier).state = ThemeMode.light;
|
2024-03-12 15:56:08 +01:00
|
|
|
} else if (currentSystemBrightness == Brightness.dark) {
|
|
|
|
currentThemeString.value = "dark";
|
2024-08-06 16:20:27 +02:00
|
|
|
ref.watch(immichThemeModeProvider.notifier).state = ThemeMode.dark;
|
2024-03-12 15:56:08 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-08-06 16:20:27 +02:00
|
|
|
void onSurfaceColorSettingChange(bool useColorfulInterface) {
|
|
|
|
applyThemeToBackgroundSetting.value = useColorfulInterface;
|
|
|
|
ref.watch(colorfulInterfaceSettingProvider.notifier).state =
|
|
|
|
useColorfulInterface;
|
|
|
|
}
|
|
|
|
|
2024-03-12 15:56:08 +01:00
|
|
|
return Column(
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
children: [
|
|
|
|
SettingsSubTitle(title: "theme_setting_theme_title".tr()),
|
|
|
|
SettingsSwitchListTile(
|
|
|
|
valueNotifier: isSystemTheme,
|
|
|
|
title: 'theme_setting_system_theme_switch'.tr(),
|
|
|
|
onChanged: onSystemThemeChange,
|
|
|
|
),
|
|
|
|
if (currentTheme.value != ThemeMode.system)
|
|
|
|
SettingsSwitchListTile(
|
|
|
|
valueNotifier: isDarkTheme,
|
|
|
|
title: 'theme_setting_dark_mode_switch'.tr(),
|
|
|
|
onChanged: onThemeChange,
|
|
|
|
),
|
2024-08-06 16:20:27 +02:00
|
|
|
const PrimaryColorSetting(),
|
|
|
|
SettingsSwitchListTile(
|
|
|
|
valueNotifier: applyThemeToBackgroundProvider,
|
|
|
|
title: "theme_setting_colorful_interface_title".tr(),
|
|
|
|
subtitle: 'theme_setting_colorful_interface_subtitle'.tr(),
|
|
|
|
onChanged: onSurfaceColorSettingChange,
|
|
|
|
),
|
2024-03-12 15:56:08 +01:00
|
|
|
],
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|