Skip to content
Snippets Groups Projects
Select Git revision
  • cb4b367f95953205cf604281c9f7e375194ce0b4
  • master default protected
  • 94-upgrade-framework-and-dependencies
  • 77-improve-app-metadata
  • 68-add-words
  • 62-fix-get-image-when-word-with-accent
  • 44-implement-game-write-word-from-letters
  • 43-add-script-to-get-images-from-assets
  • 32-add-accents-and-diacritics-in-french-words-2
  • Release_0.10.0_80 protected
  • Release_0.9.2_79 protected
  • Release_0.9.1_78 protected
  • Release_0.9.0_77 protected
  • Release_0.8.0_76 protected
  • Release_0.7.0_75 protected
  • Release_0.6.0_74 protected
  • Release_0.5.2_73 protected
  • Release_0.5.1_72 protected
  • Release_0.5.0_71 protected
  • Release_0.4.1_70 protected
  • Release_0.4.0_69 protected
  • Release_0.3.1_68 protected
  • Release_0.3.0_67 protected
  • Release_0.2.1_66 protected
  • Release_0.2.0_65 protected
  • Release_0.1.40_64 protected
  • Release_0.1.39_63 protected
  • Release_0.1.38_62 protected
  • Release_0.1.37_61 protected
29 results

bottom_nav_cubit.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);
                  }
                },
              ),
            ),
          ],
        );
      }
    }