Skip to content
Snippets Groups Projects
Select Git revision
  • master default protected
  • 70-improve-app-metadata
  • Release_0.9.0_77 protected
  • Release_0.8.2_76 protected
  • Release_0.8.1_75 protected
  • Release_0.8.0_74 protected
  • Release_0.7.0_73 protected
  • Release_0.6.0_72 protected
  • Release_0.5.0_71 protected
  • Release_0.4.2_70 protected
  • Release_0.4.1_69 protected
  • Release_0.4.0_68 protected
  • Release_0.3.1_67 protected
  • Release_0.3.0_66 protected
  • Release_0.2.1_65 protected
  • Release_0.2.0_64 protected
  • Release_0.1.1_63 protected
  • Release_0.1.0_62 protected
  • Release_0.0.61_61 protected
  • Release_0.0.60_60 protected
  • Release_0.0.59_59 protected
  • Release_0.0.58_58 protected
22 results

main.dart

Blame
  • main.dart 2.95 KiB
    import 'dart:io';
    
    import 'package:flutter/material.dart';
    import 'package:flutter/services.dart';
    import 'package:flutter_custom_toolbox/flutter_toolbox.dart';
    
    import 'package:puzzlegame/config/application_config.dart';
    import 'package:puzzlegame/cubit/activity/activity_cubit.dart';
    import 'package:puzzlegame/ui/skeleton.dart';
    
    void main() async {
      // Initialize packages
      WidgetsFlutterBinding.ensureInitialized();
      await EasyLocalization.ensureInitialized();
      final Directory tmpDir = await getTemporaryDirectory();
      Hive.init(tmpDir.toString());
      HydratedBloc.storage = await HydratedStorage.build(
        storageDirectory: tmpDir,
      );
    
      SystemChrome.setPreferredOrientations([DeviceOrientation.portraitUp])
          .then((value) => runApp(EasyLocalization(
                path: 'assets/translations',
                supportedLocales: const <Locale>[
                  Locale('en'),
                  Locale('fr'),
                ],
                fallbackLocale: const Locale('en'),
                useFallbackTranslations: true,
                child: const MyApp(),
              )));
    }
    
    class MyApp extends StatelessWidget {
      const MyApp({super.key});
    
      @override
      Widget build(BuildContext context) {
        final List<String> assets = getImagesAssets();
        for (String asset in assets) {
          precacheImage(AssetImage(asset), context);
        }
    
        return MultiBlocProvider(
          providers: [
            // default providers
            BlocProvider<NavCubitPage>(
              create: (context) => NavCubitPage(appConfig: ApplicationConfig.config),
            ),
            BlocProvider<NavCubitScreen>(
              create: (context) => NavCubitScreen(),
            ),
            BlocProvider<ApplicationThemeModeCubit>(
              create: (context) => ApplicationThemeModeCubit(),
            ),
            BlocProvider<ActivityCubit>(
              create: (context) => ActivityCubit(),
            ),
            BlocProvider<ActivitySettingsCubit>(
              create: (context) => ActivitySettingsCubit(appConfig: ApplicationConfig.config),
            ),
          ],
          child: BlocBuilder<ApplicationThemeModeCubit, ApplicationThemeModeState>(
            builder: (BuildContext context, ApplicationThemeModeState state) {
              return MaterialApp(
                title: ApplicationConfig.config.appTitle,
                home: const SkeletonScreen(),
    
                // Theme stuff
                theme: lightTheme,