Skip to content
Snippets Groups Projects
Select Git revision
  • 61d60618baf24e57b80e22d3da862036d2e12d17
  • master default protected
  • 58-upgrade-framework-and-dependencies
  • 49-fix-end-game
  • 40-improve-app-metadata
  • 12-improve-layout
  • 4-add-animations
  • Release_0.9.0_46 protected
  • Release_0.8.2_45 protected
  • Release_0.8.1_44 protected
  • Release_0.8.0_43 protected
  • Release_0.7.0_42 protected
  • Release_0.6.0_41 protected
  • Release_0.5.0_40 protected
  • Release_0.4.2_39 protected
  • Release_0.4.1_38 protected
  • Release_0.4.0_37 protected
  • Release_0.3.1_36 protected
  • Release_0.3.0_35 protected
  • Release_0.2.1_34 protected
  • Release_0.2.0_33 protected
  • Release_0.1.2_32 protected
  • Release_0.1.1_31 protected
  • Release_0.1.0_30 protected
  • Release_0.0.29_29 protected
  • Release_0.0.28_28 protected
  • Release_0.0.27_27 protected
27 results

key.dart

Blame
  • key.dart 1.62 KiB
    import 'package:flutter/material.dart';
    import 'package:flutter_custom_toolbox/flutter_toolbox.dart';
    
    import 'package:momomotus/cubit/game_cubit.dart';
    
    class KeyWidget extends StatelessWidget {
      const KeyWidget({
        super.key,
        required this.caption,
      });
    
      final String caption;
    
      @override
      Widget build(BuildContext context) {
        String keyText = caption;
        if (caption == '<') {
          keyText = '⬅️';
        } else if (caption == '!') {
          keyText = '☑️';
        }
    
        const Color keyColor = Colors.black;
    
        if (caption == ' ') {
          return const SizedBox();
        }
    
        return Stack(
          alignment: Alignment.center,
          children: <Widget>[
            const Image(
              image: AssetImage('assets/ui/key.png'),
              fit: BoxFit.fill,
            ),
            Center(
              child: TextButton(
                style: TextButton.styleFrom(
                  padding: const EdgeInsets.all(0),
                ),
                child: Text(
                  keyText,
                  style: const TextStyle(
                    color: keyColor,
                    fontSize: 30.0,
                    fontWeight: FontWeight.w800,
                  ),
                  textAlign: TextAlign.center,
                ),
                onPressed: () {
                  if (caption == '<') {
                    BlocProvider.of<GameCubit>(context).currentGuessRemoveLetter();
                  } else if (caption == '!') {
                    BlocProvider.of<GameCubit>(context).submitWord();
                  } else if (caption != ' ') {
                    BlocProvider.of<GameCubit>(context).currentGuessAddLetter(caption);
                  }
                },
              ),
            ),
          ],
        );
      }
    }