Skip to content
Snippets Groups Projects
Select Git revision
  • master default protected
  • 29-add-difficulty-level-parameter
  • 23-improve-app-metadata
  • 3-fix-layout-on-orientation-change
  • Release_1.9.0_41 protected
  • Release_1.8.2_40 protected
  • Release_1.8.1_39 protected
  • Release_1.8.0_38 protected
  • Release_1.7.0_37 protected
  • Release_1.6.0_36 protected
  • Release_1.5.0_35 protected
  • Release_1.4.2_34 protected
  • Release_1.4.1_33 protected
  • Release_1.4.0_32 protected
  • Release_1.3.0_31 protected
  • Release_1.2.1_30 protected
  • Release_1.2.0_29 protected
  • Release_1.1.1_28 protected
  • Release_1.1.0_27 protected
  • Release_1.0.25_26 protected
  • Release_1.0.24_25 protected
  • Release_1.0.23_24 protected
  • Release_1.0.22_23 protected
  • Release_1.0.21_22 protected
24 results

game_bottom.dart

Blame
  • game_bottom.dart 1.55 KiB
    import 'package:flutter/material.dart';
    import 'package:flutter_bloc/flutter_bloc.dart';
    
    import 'package:memory/cubit/game_cubit.dart';
    import 'package:memory/models/game/game.dart';
    
    class GameBottomWidget extends StatelessWidget {
      const GameBottomWidget({super.key});
    
      @override
      Widget build(BuildContext context) {
        return BlocBuilder<GameCubit, GameState>(
          builder: (BuildContext context, GameState gameState) {
            final Game currentGame = gameState.currentGame;
    
            const Color borderColor = Colors.grey;
            final int values = currentGame.board.tiles.length ~/ 2;
    
            List<Widget> items = [];
            for (int value = 1; value <= values; value++) {
              final String assetName =
                  'assets/skins/${currentGame.globalSettings.skin}_${currentGame.pairsFound.contains(value) ? value.toString() : 'unknown'}.png';
              items.add(Padding(
                padding: const EdgeInsets.all(2),
                child: Image(
                  image: AssetImage(assetName),
                ),
              ));
            }
    
            return Container(
              margin: const EdgeInsets.all(2),
              padding: const EdgeInsets.all(2),
              decoration: BoxDecoration(
                color: borderColor,
                borderRadius: BorderRadius.circular(2),
                border: Border.all(
                  color: borderColor,
                  width: 2,
                ),
              ),
              child: Table(
                children: [
                  TableRow(
                    children: items,
                  ),
                ],
              ),
            );
          },
        );
      }
    }