Skip to content
Snippets Groups Projects
Select Git revision
  • c02f0f42e04de4812d32a2ade3abbddd3c41a4cc
  • master default protected
  • 61-upgrade-framework-and-dependencies
  • 42-add-allowed-categories-in-settings-page
  • 44-improve-app-metadata
  • 23-add-tip-response-on-clic-on-button
  • Release_1.11.0_55 protected
  • Release_1.10.2_54 protected
  • Release_1.10.1_53 protected
  • Release_1.10.0_52 protected
  • Release_1.9.0_51 protected
  • Release_1.8.0_50 protected
  • Release_1.7.0_49 protected
  • Release_1.6.2_48 protected
  • Release_1.6.1_47 protected
  • Release_1.6.0_46 protected
  • Release_1.5.1_45 protected
  • Release_1.5.0_44 protected
  • Release_1.4.1_43 protected
  • Release_1.4.0_42 protected
  • Release_1.3.1_41 protected
  • Release_1.3.0_40 protected
  • Release_1.2.33_39 protected
  • Release_1.2.32_38 protected
  • Release_1.2.31_37 protected
  • Release_1.2.30_36 protected
26 results

parameter_image.dart

Blame
  • global_app_bar.dart 2.84 KiB
    import 'package:flutter/material.dart';
    import 'package:flutter_bloc/flutter_bloc.dart';
    
    import 'package:petitbac/config/menu.dart';
    import 'package:petitbac/cubit/game_cubit.dart';
    import 'package:petitbac/cubit/nav_cubit.dart';
    import 'package:petitbac/models/game/game.dart';
    import 'package:petitbac/ui/helpers/app_titles.dart';
    import 'package:petitbac/ui/helpers/styled_button.dart';
    
    class GlobalAppBar extends StatelessWidget implements PreferredSizeWidget {
      const GlobalAppBar({super.key});
    
      @override
      Widget build(BuildContext context) {
        return BlocBuilder<GameCubit, GameState>(
          builder: (BuildContext context, GameState gameState) {
            return BlocBuilder<NavCubit, int>(
              builder: (BuildContext context, int pageIndex) {
                final Game currentGame = gameState.currentGame;
    
                final List<Widget> menuActions = [];
    
                if (currentGame.isRunning && !currentGame.isFinished) {
                  menuActions.add(StyledButton(
                    color: Colors.red,
                    onPressed: () {},
                    onLongPress: () {
                      BlocProvider.of<GameCubit>(context).quitGame();
                    },
                    child: const Image(
                      image: AssetImage('assets/ui/button_back.png'),
                      fit: BoxFit.fill,
                    ),
                  ));
                } else {
                  if (pageIndex == Menu.indexGame) {
                    // go to Settings page
                    menuActions.add(ElevatedButton(
                      onPressed: () {
                        context.read<NavCubit>().goToSettingsPage();
                      },
                      style: ElevatedButton.styleFrom(
                        shape: const CircleBorder(),
                      ),
                      child: Menu.menuItemSettings.icon,
                    ));
    
                    // go to About page
                    menuActions.add(ElevatedButton(
                      onPressed: () {
                        context.read<NavCubit>().goToAboutPage();
                      },
                      style: ElevatedButton.styleFrom(
                        shape: const CircleBorder(),
                      ),
                      child: Menu.menuItemAbout.icon,
                    ));
                  } else {
                    // back to Home page
                    menuActions.add(ElevatedButton(
                      onPressed: () {
                        context.read<NavCubit>().goToGamePage();
                      },
                      style: ElevatedButton.styleFrom(
                        shape: const CircleBorder(),
                      ),
                      child: Menu.menuItemGame.icon,
                    ));
                  }