Skip to content
Snippets Groups Projects
Select Git revision
  • 08ffe708b98f38fedf4a1bac80ba34740be29ffa
  • master default protected
  • 101-upgrade-framework-and-dependencies
  • 84-improve-app-metadata
  • 82-fix-colors
  • 23-add-timer
  • 65-update-icons
  • Release_0.10.0_87 protected
  • Release_0.9.2_86 protected
  • Release_0.9.1_85 protected
  • Release_0.9.0_84 protected
  • Release_0.8.0_83 protected
  • Release_0.7.0_82 protected
  • Release_0.6.0_81 protected
  • Release_0.5.2_80 protected
  • Release_0.5.1_79 protected
  • Release_0.5.0_78 protected
  • Release_0.4.1_77 protected
  • Release_0.4.0_76 protected
  • Release_0.3.1_75 protected
  • Release_0.3.0_74 protected
  • Release_0.2.1_73 protected
  • Release_0.2.0_72 protected
  • Release_0.1.22_71 protected
  • Release_0.1.21_70 protected
  • Release_0.1.20_69 protected
  • Release_0.1.19_68 protected
27 results

game_board.dart

Blame
  • game_board.dart 1.77 KiB
    import 'package:flutter/material.dart';
    import 'package:flutter_bloc/flutter_bloc.dart';
    
    import 'package:sudoku/cubit/game_cubit.dart';
    import 'package:sudoku/models/game/cell_location.dart';
    import 'package:sudoku/models/game/game.dart';
    import 'package:sudoku/ui/widgets/game/cell.dart';
    
    class GameBoardWidget extends StatelessWidget {
      const GameBoardWidget({super.key});
    
      @override
      Widget build(BuildContext context) {
        return BlocBuilder<GameCubit, GameState>(
          builder: (BuildContext context, GameState gameState) {
            final Game currentGame = gameState.currentGame;
    
            final Color borderColor = Theme.of(context).colorScheme.onSurface;
    
            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: Column(
                children: [
                  Table(
                    defaultColumnWidth: const IntrinsicColumnWidth(),
                    children: [
                      for (int row = 0; row < currentGame.boardSize; row++)
                        TableRow(
                          children: [
                            for (int col = 0; col < currentGame.boardSize; col++)
                              Column(
                                children: [
                                  CellWidget(
                                      cell: currentGame.board.get(CellLocation.go(row, col)))
                                ],
                              ),
                          ],
                        ),
                    ],
                  ),
                ],
              ),
            );
          },
        );
      }
    }