import 'package:flutter/material.dart'; import 'package:flutter_gen/gen_l10n/l10n.dart'; import '../components/matrix.dart'; import '../components/theme_switcher.dart'; class ThemesSettings extends StatefulWidget { @override ThemesSettingsState createState() => ThemesSettingsState(); } class ThemesSettingsState extends State<ThemesSettings> { Themes _selectedTheme; bool _amoledEnabled; @override Widget build(BuildContext context) { final matrix = Matrix.of(context); final themeEngine = ThemeSwitcherWidget.of(context); _selectedTheme = themeEngine.selectedTheme; _amoledEnabled = themeEngine.amoledEnabled; return Column( children: <Widget>[ RadioListTile<Themes>( title: Text( L10n.of(context).systemTheme, ), value: Themes.system, groupValue: _selectedTheme, activeColor: Theme.of(context).primaryColor, onChanged: (Themes value) { setState(() { _selectedTheme = value; themeEngine.switchTheme(matrix, value, _amoledEnabled); }); }, ), RadioListTile<Themes>( title: Text( L10n.of(context).lightTheme, ), value: Themes.light, groupValue: _selectedTheme, activeColor: Theme.of(context).primaryColor, onChanged: (Themes value) { setState(() { _selectedTheme = value; themeEngine.switchTheme(matrix, value, _amoledEnabled); }); }, ), RadioListTile<Themes>( title: Text( L10n.of(context).darkTheme, ), value: Themes.dark, groupValue: _selectedTheme, activeColor: Theme.of(context).primaryColor, onChanged: (Themes value) { setState(() { _selectedTheme = value; themeEngine.switchTheme(matrix, value, _amoledEnabled); }); }, ), ListTile( title: Text( L10n.of(context).useAmoledTheme, ), trailing: Switch( value: _amoledEnabled, activeColor: Theme.of(context).primaryColor, onChanged: (bool value) { setState(() { _amoledEnabled = value; themeEngine.switchTheme(matrix, _selectedTheme, value); }); }, ), ), ], ); } }