import 'package:filcnaplo/models/settings.dart'; import 'package:filcnaplo/theme/colors/colors.dart'; import 'package:filcnaplo_mobile_ui/common/panel/panel_button.dart'; import 'package:filcnaplo_mobile_ui/common/splitted_panel/splitted_panel.dart'; import 'package:filcnaplo_mobile_ui/screens/settings/settings_helper.dart'; import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; import 'package:flutter_feather_icons/flutter_feather_icons.dart'; import 'package:provider/provider.dart'; import 'submenu_screen.i18n.dart'; class MenuGeneralSettings extends StatelessWidget { const MenuGeneralSettings({ super.key, this.borderRadius = const BorderRadius.vertical( top: Radius.circular(4.0), bottom: Radius.circular(4.0)), }); final BorderRadius borderRadius; @override Widget build(BuildContext context) { return PanelButton( onPressed: () => Navigator.of(context, rootNavigator: true).push( CupertinoPageRoute(builder: (context) => const GeneralSettingsScreen()), ), title: Text("general".i18n), leading: Icon( FeatherIcons.settings, size: 22.0, color: AppColors.of(context).text.withOpacity(0.95), ), trailing: Icon( FeatherIcons.chevronRight, size: 22.0, color: AppColors.of(context).text.withOpacity(0.95), ), borderRadius: borderRadius, ); } } class GeneralSettingsScreen extends StatefulWidget { const GeneralSettingsScreen({super.key}); @override GeneralSettingsScreenState createState() => GeneralSettingsScreenState(); } class GeneralSettingsScreenState extends State { @override Widget build(BuildContext context) { SettingsProvider settingsProvider = Provider.of(context); return Scaffold( appBar: AppBar( surfaceTintColor: Theme.of(context).scaffoldBackgroundColor, leading: BackButton(color: AppColors.of(context).text), title: Text( "general".i18n, style: TextStyle(color: AppColors.of(context).text), ), ), body: SingleChildScrollView( child: Padding( padding: const EdgeInsets.symmetric(vertical: 16.0, horizontal: 24.0), child: Column( children: [ SplittedPanel( padding: const EdgeInsets.only(top: 8.0), cardPadding: const EdgeInsets.all(4.0), isSeparated: true, children: [ PanelButton( onPressed: () { SettingsHelper.bellDelay(context); setState(() {}); }, title: Text("bell_delay".i18n), leading: Icon( FeatherIcons.sun, size: 22.0, color: AppColors.of(context).text.withOpacity(0.95), ), trailingDivider: true, trailing: Switch( onChanged: (v) => settingsProvider.update(bellDelayEnabled: v), value: settingsProvider.bellDelayEnabled, activeColor: Theme.of(context).colorScheme.secondary, ), borderRadius: const BorderRadius.vertical( top: Radius.circular(12.0), bottom: Radius.circular(12.0), ), ), ], ), ], ), ), ), ); } }