Skip to content
Snippets Groups Projects
Select Git revision
  • f7fe85a2eb8aa4685ab50a73121dfac9a6b3fdf6
  • master default protected
  • 49-upgrade-framework-and-dependencies
  • 32-improve-app-metadata
  • Release_0.9.0_43 protected
  • Release_0.8.2_42 protected
  • Release_0.8.1_41 protected
  • Release_0.8.0_40 protected
  • Release_0.7.0_39 protected
  • Release_0.6.0_38 protected
  • Release_0.5.0_37 protected
  • Release_0.4.2_36 protected
  • Release_0.4.1_35 protected
  • Release_0.4.0_34 protected
  • Release_0.3.1_33 protected
  • Release_0.3.0_32 protected
  • Release_0.2.1_31 protected
  • Release_0.2.0_30 protected
  • Release_0.1.2_29 protected
  • Release_0.1.1_28 protected
  • Release_0.1.0_27 protected
  • Release_0.0.26_26 protected
  • Release_0.0.25_25 protected
  • Release_0.0.24_24 protected
24 results

default_global_settings.dart

Blame
  • letters.dart 3.14 KiB
    import 'package:flutter/material.dart';
    import 'package:provider/provider.dart';
    
    import '../provider/data.dart';
    import '../utils/constants.dart';
    import '../widgets/dialog_gameover.dart';
    
    class LetterButtons extends StatelessWidget {
      const LetterButtons({super.key});
    
      @override
      Widget build(BuildContext context) {
        final Orientation orientation = MediaQuery.of(context).orientation;
        var size = MediaQuery.of(context).size;
        final double paddingTop = MediaQuery.of(context).padding.top;
        final double itemHeight = (size.height - paddingTop) / 2;
        final double itemWidth = size.width / 2;
    
        final Data myProvider = Provider.of<Data>(context);
    
        final List<String> lettersList = letters.split('');
        final List<Widget> keys = [];
    
        for (var key in lettersList) {
          keys.add(
            Padding(
              padding: const EdgeInsets.all(2.0),
              child: TextButton(
                style: TextButton.styleFrom(
                  backgroundColor: Colors.grey,
                  foregroundColor: Colors.white,
                  shadowColor: const Color(accent),
                ),
                onPressed: myProvider.usedLetters.contains(key)
                    ? null
                    : () async {
                        myProvider.updateUsedLetters(key);
                        if (myProvider.secretWord.contains(key)) {
                          for (int index = 0; index < myProvider.secretWord.length; index++) {
                            if (key == myProvider.secretWord[index]) {
                              myProvider.updateHiddenWord(index, key);
                            }
                          }
    
                          if (myProvider.hiddenWord == myProvider.secretWord) {
                            myProvider.addVictory();
                            showDialog(
                              context: context,
                              builder: (context) => const DialogGameOver(victory),
                            );
                          }
                        } else {
                          myProvider.addError();
                          if (myProvider.errors == 8) {
                            await Future.delayed(const Duration(milliseconds: 900)); //????
                            myProvider.addDefeat();
                            showDialog(
                              context: context,
                              builder: (context) => const DialogGameOver(defeat),
                            );
                          }
                        }
                      },
                child: Text(
                  key,
                  textAlign: TextAlign.center,
                ),
              ),
            ),
          );