Skip to content
Snippets Groups Projects
Select Git revision
  • c95f997dd4a8034c32a7d87e5294401d67385088
  • master default protected
  • 35-upgrade-framework-and-dependencies
  • 24-add-fruits
  • 15-improve-app-metadata
  • Release_0.10.0_31 protected
  • Release_0.9.2_30 protected
  • Release_0.9.1_29 protected
  • Release_0.9.0_28 protected
  • Release_0.8.0_27 protected
  • Release_0.7.0_26 protected
  • Release_0.6.0_25 protected
  • Release_0.5.4_24 protected
  • Release_0.5.3_23 protected
  • Release_0.5.2_22 protected
  • Release_0.5.1_21 protected
  • Release_0.5.0_20 protected
  • Release_0.4.0_19 protected
  • Release_0.3.1_18 protected
  • Release_0.3.0_17 protected
  • Release_0.2.1_16 protected
  • Release_0.2.0_15 protected
  • Release_0.1.1_14 protected
  • Release_0.1.0_13 protected
  • Release_0.0.12_12 protected
25 results

main.dart

Blame
  • submit.dart 1.95 KiB
    import 'package:flutter/material.dart';
    import 'package:flutter_custom_toolbox/flutter_toolbox.dart';
    
    import 'package:tetrisdual/cubit/game_cubit.dart';
    import 'package:tetrisdual/models/game/player.dart';
    
    class SubmitWidget extends StatelessWidget {
      const SubmitWidget({super.key, required this.player});
    
      final Player player;
    
      @override
      Widget build(BuildContext context) {
        const double gainFontSize = 70;
    
        const gainTestStyle = TextStyle(
          fontFamily: 'Blocks',
          fontSize: gainFontSize,
          fontWeight: FontWeight.bold,
        );
        const submitIcon = Icon(
          Icons.done_all,
          color: Colors.orange,
          size: gainFontSize / 2,
        );
    
        const topBorderBlack = BoxDecoration(
          border: Border(
            top: BorderSide(
              color: Colors.black,
              width: 2,
            ),
          ),
        );
    
        return Container(
          decoration: topBorderBlack,
          padding: const EdgeInsets.only(
            top: 10,
          ),
          child: Row(
            mainAxisAlignment: MainAxisAlignment.end,
            crossAxisAlignment: CrossAxisAlignment.center,
            children: [
              Text(
                '+${player.counter.computePoints()}',
                style: gainTestStyle,
                textHeightBehavior: const TextHeightBehavior(
                  applyHeightToFirstAscent: false,
                  applyHeightToLastDescent: false,
                ),
              ),
              const SizedBox(width: 10),
              IconButton(
                padding: EdgeInsets.zero,
                constraints: const BoxConstraints(),
                style: const ButtonStyle(
                  tapTargetSize: MaterialTapTargetSize.shrinkWrap,
                ),
                icon: submitIcon,
                onPressed: () {
                  player.score = player.score + player.counter.computePoints();
                  player.counter.reset();
    
                  BlocProvider.of<GameCubit>(context).toggleCurrentPlayer();
                },
              ),
              const SizedBox(width: 10),
            ],
          ),