import 'package:flutter/material.dart'; import 'package:flutter_hooks/flutter_hooks.dart'; import 'package:flutter_mobx/flutter_mobx.dart'; import 'package:lemmur/pages/profile_tab.dart'; import 'package:provider/provider.dart'; import 'hooks/stores.dart'; import 'stores/accounts_store.dart'; import 'stores/config_store.dart'; Future main() async { WidgetsFlutterBinding.ensureInitialized(); var configStore = ConfigStore(); await configStore.load(); var accountsStore = AccountsStore(); await accountsStore.load(); runApp( MultiProvider( providers: [ Provider( create: (_) => configStore, dispose: (_, store) => store.dispose(), ), Provider( create: (_) => accountsStore, dispose: (_, store) => store.dispose(), ), ], child: MyApp(), ), ); } class MyApp extends HookWidget { @override Widget build(BuildContext context) { final configStore = useConfigStore(); return Observer( builder: (ctx) { final maybeAmoledColor = configStore.amoledDarkMode ? Colors.black : null; return MaterialApp( title: 'Flutter Demo', themeMode: configStore.theme, darkTheme: ThemeData.dark().copyWith( scaffoldBackgroundColor: maybeAmoledColor, backgroundColor: maybeAmoledColor, canvasColor: maybeAmoledColor, cardColor: maybeAmoledColor, splashColor: maybeAmoledColor, ), theme: ThemeData( visualDensity: VisualDensity.adaptivePlatformDensity, ), home: UserProfileTab(), ); }, ); } } class MyHomePage extends StatefulWidget { MyHomePage({Key key, this.title}) : super(key: key); final String title; @override _MyHomePageState createState() => _MyHomePageState(); } class _MyHomePageState extends State { int _counter = 0; void _incrementCounter() { setState(() { _counter++; }); } @override Widget build(BuildContext context) => Scaffold( appBar: AppBar( title: Text(widget.title), ), body: Center( child: Column( mainAxisAlignment: MainAxisAlignment.center, children: [ Text('You have pushed the button this many times:'), Text( '$_counter', style: Theme.of(context).textTheme.headline4, ), ], ), ), floatingActionButton: FloatingActionButton( onPressed: _incrementCounter, tooltip: 'Increment', child: Icon(Icons.add), ), ); }