import 'package:dynamic_color/dynamic_color.dart'; import 'package:flutter/material.dart'; import 'package:flutter_gen/gen_l10n/l10n.dart'; import 'package:toolbox/core/extension/context.dart'; import 'package:toolbox/core/extension/locale.dart'; import 'package:toolbox/view/page/full_screen.dart'; import 'core/utils/ui.dart'; import 'data/res/build_data.dart'; import 'data/res/color.dart'; import 'data/store/setting.dart'; import 'locator.dart'; import 'view/page/home.dart'; class MyApp extends StatelessWidget { MyApp({Key? key}) : super(key: key); final _setting = locator(); @override Widget build(BuildContext context) { return DynamicColorBuilder(builder: (light, dark) { setTransparentNavigationBar(context); _setupPrimaryColor(context, light, dark); return ValueListenableBuilder( valueListenable: _setting.themeMode.listenable(), builder: (_, tMode, __) { final isAMOLED = tMode >= 0 && tMode <= ThemeMode.values.length - 1; // Issue #57 // if not [ok] -> [AMOLED] mode, use [ThemeMode.dark] final themeMode = isAMOLED ? ThemeMode.values[tMode] : ThemeMode.dark; final locale = _setting.locale.fetch().toLocale; final darkTheme = ThemeData( useMaterial3: true, brightness: Brightness.dark, colorSchemeSeed: primaryColor, /// After upgrading to flutter 3.13, /// the shadow color of the drawer is white (maybe a bug). /// Only on [iOS]. /// TODO: remember to remove it after the bug is fixed. drawerTheme: const DrawerThemeData( shadowColor: Colors.black12, ), ); return MaterialApp( debugShowCheckedModeBanner: false, locale: locale, localizationsDelegates: S.localizationsDelegates, supportedLocales: S.supportedLocales, title: BuildData.name, themeMode: themeMode, theme: ThemeData( useMaterial3: true, colorSchemeSeed: primaryColor, ), darkTheme: isAMOLED ? darkTheme : _getAmoledTheme(darkTheme), home: _setting.fullScreen.fetch() ? const FullScreenPage() : const HomePage(), ); }, ); }); } void _setupPrimaryColor( BuildContext context, ColorScheme? light, ColorScheme? dark, ) { if (_setting.useSystemPrimaryColor.fetch()) { if (context.isDark && light != null) { primaryColor = light.primary; } else if (!context.isDark && dark != null) { primaryColor = dark.primary; } } else { primaryColor = Color(_setting.primaryColor.fetch()); } } } ThemeData _getAmoledTheme(ThemeData darkTheme) => darkTheme.copyWith( scaffoldBackgroundColor: Colors.black, dialogBackgroundColor: Colors.black, appBarTheme: const AppBarTheme(backgroundColor: Colors.black), dialogTheme: const DialogTheme(backgroundColor: Colors.black), bottomSheetTheme: const BottomSheetThemeData(backgroundColor: Colors.black), listTileTheme: const ListTileThemeData(tileColor: Colors.black12), cardTheme: const CardTheme(color: Colors.black12), navigationBarTheme: const NavigationBarThemeData(backgroundColor: Colors.black), popupMenuTheme: const PopupMenuThemeData(color: Colors.black), );