import 'package:flutter/material.dart'; import 'package:fluffychat/config/app_config.dart'; import 'package:fluffychat/config/setting_keys.dart'; import 'package:fluffychat/widgets/theme_builder.dart'; import '../../widgets/matrix.dart'; import 'settings_style_view.dart'; class SettingsStyle extends StatefulWidget { const SettingsStyle({super.key}); @override SettingsStyleController createState() => SettingsStyleController(); } class SettingsStyleController extends State { void setChatColor(Color? color) async { AppConfig.colorSchemeSeed = color; ThemeController.of(context).setPrimaryColor(color); } ThemeMode get currentTheme => ThemeController.of(context).themeMode; Color? get currentColor => ThemeController.of(context).primaryColor; static final List customColors = [ null, AppConfig.chatColor, Colors.indigo, Colors.green, Colors.orange, Colors.pink, Colors.blueGrey, ]; void switchTheme(ThemeMode? newTheme) { if (newTheme == null) return; switch (newTheme) { case ThemeMode.light: ThemeController.of(context).setThemeMode(ThemeMode.light); break; case ThemeMode.dark: ThemeController.of(context).setThemeMode(ThemeMode.dark); break; case ThemeMode.system: ThemeController.of(context).setThemeMode(ThemeMode.system); break; } setState(() {}); } void changeFontSizeFactor(double d) { setState(() => AppConfig.fontSizeFactor = d); Matrix.of(context).store.setString( SettingKeys.fontSizeFactor, AppConfig.fontSizeFactor.toString(), ); } @override Widget build(BuildContext context) => SettingsStyleView(this); }