yubioath-flutter/lib/settings_page.dart

69 lines
2.4 KiB
Dart
Raw Normal View History

import 'package:flutter/material.dart';
2022-09-09 11:07:46 +03:00
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:logging/logging.dart';
2022-06-02 16:49:52 +03:00
import 'app/logging.dart';
2022-03-15 20:04:26 +03:00
import 'app/state.dart';
2022-06-02 16:49:52 +03:00
import 'widgets/list_title.dart';
import 'widgets/responsive_dialog.dart';
final _log = Logger('settings');
class SettingsPage extends ConsumerWidget {
2022-05-12 10:56:55 +03:00
const SettingsPage({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
2022-06-02 16:49:52 +03:00
final themeMode = ref.watch(themeModeProvider);
final theme = Theme.of(context);
2022-03-15 20:04:26 +03:00
return ResponsiveDialog(
2022-09-09 11:07:46 +03:00
title: Text(AppLocalizations.of(context)!.general_settings),
child: Theme(
// Make the headers use the primary color to pop a bit.
// Once M3 is implemented this will probably not be needed.
data: theme.copyWith(
textTheme: theme.textTheme.copyWith(
labelLarge: theme.textTheme.labelLarge
?.copyWith(color: theme.colorScheme.primary)),
),
child: Column(
mainAxisSize: MainAxisSize.min,
crossAxisAlignment: CrossAxisAlignment.start,
children: [
2022-09-09 11:24:39 +03:00
ListTitle(AppLocalizations.of(context)!.general_appearance),
RadioListTile<ThemeMode>(
2022-09-09 11:24:39 +03:00
title: Text(AppLocalizations.of(context)!.general_system_default),
value: ThemeMode.system,
groupValue: themeMode,
onChanged: (mode) {
ref.read(themeModeProvider.notifier).setThemeMode(mode!);
_log.debug('Set theme mode to $mode');
},
),
RadioListTile<ThemeMode>(
2022-09-09 11:24:39 +03:00
title: Text(AppLocalizations.of(context)!.general_light_mode),
value: ThemeMode.light,
groupValue: themeMode,
onChanged: (mode) {
ref.read(themeModeProvider.notifier).setThemeMode(mode!);
_log.debug('Set theme mode to $mode');
},
),
RadioListTile<ThemeMode>(
2022-09-09 11:24:39 +03:00
title: Text(AppLocalizations.of(context)!.general_dark_mode),
value: ThemeMode.dark,
groupValue: themeMode,
onChanged: (mode) {
ref.read(themeModeProvider.notifier).setThemeMode(mode!);
_log.debug('Set theme mode to $mode');
},
),
],
),
),
);
}
}