Skip to content
Snippets Groups Projects
Select Git revision
  • master default protected
  • 21-improve-app-metadata
  • Release_0.9.0_40 protected
  • Release_0.8.2_39 protected
  • Release_0.8.1_38 protected
  • Release_0.8.0_37 protected
  • Release_0.7.0_36 protected
  • Release_0.6.0_35 protected
  • Release_0.5.0_34 protected
  • Release_0.4.2_33 protected
  • Release_0.4.1_32 protected
  • Release_0.4.0_31 protected
  • Release_0.3.1_30 protected
  • Release_0.3.0_29 protected
  • Release_0.2.1_28 protected
  • Release_0.2.0_27 protected
  • Release_0.1.2_26 protected
  • Release_0.1.1_25 protected
  • Release_0.1.0_24 protected
  • Release_0.0.23_23 protected
  • Release_0.0.22_22 protected
  • Release_0.0.21_21 protected
22 results

global_app_bar.dart

Blame
  • global_app_bar.dart 2.83 KiB
    import 'package:flutter/material.dart';
    import 'package:flutter_bloc/flutter_bloc.dart';
    
    import 'package:twister/config/menu.dart';
    import 'package:twister/cubit/game_cubit.dart';
    import 'package:twister/cubit/nav_cubit.dart';
    import 'package:twister/models/game/game.dart';
    import 'package:twister/ui/helpers/app_titles.dart';
    import 'package:twister/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,
                    ));
                  }