Merge pull request #130 from flixcoo/enhance/128-activegameview-enhancements
ActiveGameView enhancements
This commit is contained in:
		| @@ -97,7 +97,7 @@ | |||||||
|   }, |   }, | ||||||
|  |  | ||||||
|   "end_of_game_title": "End of Game", |   "end_of_game_title": "End of Game", | ||||||
|   "end_of_game_message": "{names} won the game with {points} points. Congratulations!", |   "end_of_game_message": "{playerCount, plural, =1{{names} won the game with {points} points. Congratulations!} other{{names} won the game with {points} points. Congratulations to everyone!}}", | ||||||
|   "@end_of_game_message": { |   "@end_of_game_message": { | ||||||
|     "placeholders": { |     "placeholders": { | ||||||
|       "playerCount": { |       "playerCount": { | ||||||
|   | |||||||
| @@ -210,7 +210,14 @@ class AppLocalizationsEn extends AppLocalizations { | |||||||
|  |  | ||||||
|   @override |   @override | ||||||
|   String end_of_game_message(int playerCount, String names, int points) { |   String end_of_game_message(int playerCount, String names, int points) { | ||||||
|     return '$names won the game with $points points. Congratulations!'; |     String _temp0 = intl.Intl.pluralLogic( | ||||||
|  |       playerCount, | ||||||
|  |       locale: localeName, | ||||||
|  |       other: | ||||||
|  |           '$names won the game with $points points. Congratulations to everyone!', | ||||||
|  |       one: '$names won the game with $points points. Congratulations!', | ||||||
|  |     ); | ||||||
|  |     return '$_temp0'; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   @override |   @override | ||||||
|   | |||||||
| @@ -49,7 +49,10 @@ class _ActiveGameViewState extends State<ActiveGameView> { | |||||||
|                   gameSession.playerScores, sortedPlayerIndices); |                   gameSession.playerScores, sortedPlayerIndices); | ||||||
|               return CupertinoPageScaffold( |               return CupertinoPageScaffold( | ||||||
|                   navigationBar: CupertinoNavigationBar( |                   navigationBar: CupertinoNavigationBar( | ||||||
|                     middle: Text(gameSession.gameTitle), |                     middle: Text( | ||||||
|  |                       gameSession.gameTitle, | ||||||
|  |                       overflow: TextOverflow.ellipsis, | ||||||
|  |                     ), | ||||||
|                   ), |                   ), | ||||||
|                   child: SafeArea( |                   child: SafeArea( | ||||||
|                     child: SingleChildScrollView( |                     child: SingleChildScrollView( | ||||||
|   | |||||||
| @@ -38,11 +38,16 @@ class CreateGameView extends StatefulWidget { | |||||||
| } | } | ||||||
|  |  | ||||||
| class _CreateGameViewState extends State<CreateGameView> { | class _CreateGameViewState extends State<CreateGameView> { | ||||||
|  |   final TextEditingController _gameTitleTextController = | ||||||
|  |       TextEditingController(); | ||||||
|  |  | ||||||
|  |   /// List of text controllers for player names. | ||||||
|   final List<TextEditingController> _playerNameTextControllers = [ |   final List<TextEditingController> _playerNameTextControllers = [ | ||||||
|     TextEditingController() |     TextEditingController() | ||||||
|   ]; |   ]; | ||||||
|   final TextEditingController _gameTitleTextController = |  | ||||||
|       TextEditingController(); |   /// List of focus nodes for player name text fields. | ||||||
|  |   final List<FocusNode> _playerNameFocusNodes = [FocusNode()]; | ||||||
|  |  | ||||||
|   /// Maximum number of players allowed in the game. |   /// Maximum number of players allowed in the game. | ||||||
|   final int maxPlayers = 5; |   final int maxPlayers = 5; | ||||||
| @@ -94,11 +99,19 @@ class _CreateGameViewState extends State<CreateGameView> { | |||||||
|                 padding: const EdgeInsets.fromLTRB(15, 10, 10, 0), |                 padding: const EdgeInsets.fromLTRB(15, 10, 10, 0), | ||||||
|                 child: CupertinoTextField( |                 child: CupertinoTextField( | ||||||
|                   decoration: const BoxDecoration(), |                   decoration: const BoxDecoration(), | ||||||
|                   maxLength: 16, |                   maxLength: 20, | ||||||
|                   prefix: Text(AppLocalizations.of(context).name), |                   prefix: Text(AppLocalizations.of(context).name), | ||||||
|                   textAlign: TextAlign.right, |                   textAlign: TextAlign.right, | ||||||
|                   placeholder: AppLocalizations.of(context).game_title, |                   placeholder: AppLocalizations.of(context).game_title, | ||||||
|                   controller: _gameTitleTextController, |                   controller: _gameTitleTextController, | ||||||
|  |                   onSubmitted: (_) { | ||||||
|  |                     _playerNameFocusNodes.isNotEmpty | ||||||
|  |                         ? _playerNameFocusNodes[0].requestFocus() | ||||||
|  |                         : FocusScope.of(context).unfocus(); | ||||||
|  |                   }, | ||||||
|  |                   textInputAction: _playerNameFocusNodes.isNotEmpty | ||||||
|  |                       ? TextInputAction.next | ||||||
|  |                       : TextInputAction.done, | ||||||
|                 ), |                 ), | ||||||
|               ), |               ), | ||||||
|               Padding( |               Padding( | ||||||
| @@ -177,11 +190,24 @@ class _CreateGameViewState extends State<CreateGameView> { | |||||||
|                           Expanded( |                           Expanded( | ||||||
|                             child: CupertinoTextField( |                             child: CupertinoTextField( | ||||||
|                               controller: _playerNameTextControllers[index], |                               controller: _playerNameTextControllers[index], | ||||||
|  |                               focusNode: _playerNameFocusNodes[index], | ||||||
|                               maxLength: 12, |                               maxLength: 12, | ||||||
|                               placeholder: |                               placeholder: | ||||||
|                                   '${AppLocalizations.of(context).player} ${index + 1}', |                                   '${AppLocalizations.of(context).player} ${index + 1}', | ||||||
|                               padding: const EdgeInsets.all(12), |                               padding: const EdgeInsets.all(12), | ||||||
|                               decoration: const BoxDecoration(), |                               decoration: const BoxDecoration(), | ||||||
|  |                               textInputAction: | ||||||
|  |                                   index + 1 < _playerNameTextControllers.length | ||||||
|  |                                       ? TextInputAction.next | ||||||
|  |                                       : TextInputAction.done, | ||||||
|  |                               onSubmitted: (_) { | ||||||
|  |                                 if (index + 1 < _playerNameFocusNodes.length) { | ||||||
|  |                                   _playerNameFocusNodes[index + 1] | ||||||
|  |                                       .requestFocus(); | ||||||
|  |                                 } else { | ||||||
|  |                                   FocusScope.of(context).unfocus(); | ||||||
|  |                                 } | ||||||
|  |                               }, | ||||||
|                             ), |                             ), | ||||||
|                           ), |                           ), | ||||||
|                           AnimatedOpacity( |                           AnimatedOpacity( | ||||||
| @@ -207,38 +233,56 @@ class _CreateGameViewState extends State<CreateGameView> { | |||||||
|                   }), |                   }), | ||||||
|               Padding( |               Padding( | ||||||
|                 padding: const EdgeInsets.fromLTRB(8, 0, 8, 50), |                 padding: const EdgeInsets.fromLTRB(8, 0, 8, 50), | ||||||
|                 child: Center( |                 child: Stack( | ||||||
|                   child: SizedBox( |                   children: [ | ||||||
|                     width: double.infinity, |                     Row( | ||||||
|                     child: CupertinoButton( |                       mainAxisAlignment: MainAxisAlignment.start, | ||||||
|                       padding: const EdgeInsets.symmetric(horizontal: 16), |                       children: [ | ||||||
|                       child: Row( |                         CupertinoButton( | ||||||
|                         mainAxisAlignment: MainAxisAlignment.center, |                           padding: EdgeInsets.zero, | ||||||
|                         children: [ |                           onPressed: null, | ||||||
|                           Text( |                           child: Icon( | ||||||
|                             AppLocalizations.of(context).add_player, |                             CupertinoIcons.plus_circle_fill, | ||||||
|                             style: TextStyle(color: CustomTheme.primaryColor), |  | ||||||
|                           ), |  | ||||||
|                           const SizedBox(width: 8), |  | ||||||
|                           Icon( |  | ||||||
|                             CupertinoIcons.add_circled_solid, |  | ||||||
|                             color: CustomTheme.primaryColor, |                             color: CustomTheme.primaryColor, | ||||||
|                             size: 25, |                             size: 25, | ||||||
|                           ), |                           ), | ||||||
|                         ], |                         ), | ||||||
|                       ), |                       ], | ||||||
|                       onPressed: () { |  | ||||||
|                         if (_playerNameTextControllers.length < maxPlayers) { |  | ||||||
|                           setState(() { |  | ||||||
|                             _playerNameTextControllers |  | ||||||
|                                 .add(TextEditingController()); |  | ||||||
|                           }); |  | ||||||
|                         } else { |  | ||||||
|                           _showFeedbackDialog(CreateStatus.maxPlayers); |  | ||||||
|                         } |  | ||||||
|                       }, |  | ||||||
|                     ), |                     ), | ||||||
|                   ), |                     Center( | ||||||
|  |                       child: CupertinoButton( | ||||||
|  |                         padding: const EdgeInsets.symmetric(horizontal: 0), | ||||||
|  |                         child: Row( | ||||||
|  |                           mainAxisAlignment: MainAxisAlignment.start, | ||||||
|  |                           children: [ | ||||||
|  |                             Expanded( | ||||||
|  |                               child: Center( | ||||||
|  |                                 child: Text( | ||||||
|  |                                   AppLocalizations.of(context).add_player, | ||||||
|  |                                   style: TextStyle( | ||||||
|  |                                       color: CustomTheme.primaryColor), | ||||||
|  |                                 ), | ||||||
|  |                               ), | ||||||
|  |                             ), | ||||||
|  |                           ], | ||||||
|  |                         ), | ||||||
|  |                         onPressed: () { | ||||||
|  |                           if (_playerNameTextControllers.length < maxPlayers) { | ||||||
|  |                             setState(() { | ||||||
|  |                               _playerNameTextControllers | ||||||
|  |                                   .add(TextEditingController()); | ||||||
|  |                               _playerNameFocusNodes.add(FocusNode()); | ||||||
|  |                             }); | ||||||
|  |                             WidgetsBinding.instance.addPostFrameCallback((_) { | ||||||
|  |                               _playerNameFocusNodes.last.requestFocus(); | ||||||
|  |                             }); | ||||||
|  |                           } else { | ||||||
|  |                             _showFeedbackDialog(CreateStatus.maxPlayers); | ||||||
|  |                           } | ||||||
|  |                         }, | ||||||
|  |                       ), | ||||||
|  |                     ), | ||||||
|  |                   ], | ||||||
|                 ), |                 ), | ||||||
|               ), |               ), | ||||||
|               Padding( |               Padding( | ||||||
| @@ -415,6 +459,9 @@ class _CreateGameViewState extends State<CreateGameView> { | |||||||
|     for (var controller in _playerNameTextControllers) { |     for (var controller in _playerNameTextControllers) { | ||||||
|       controller.dispose(); |       controller.dispose(); | ||||||
|     } |     } | ||||||
|  |     for (var focusnode in _playerNameFocusNodes) { | ||||||
|  |       focusnode.dispose(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     super.dispose(); |     super.dispose(); | ||||||
|   } |   } | ||||||
|   | |||||||
| @@ -144,6 +144,9 @@ class _MainMenuViewState extends State<MainMenuView> { | |||||||
|                                         )), |                                         )), | ||||||
|                                     trailing: Row( |                                     trailing: Row( | ||||||
|                                       children: [ |                                       children: [ | ||||||
|  |                                         const SizedBox( | ||||||
|  |                                           width: 5, | ||||||
|  |                                         ), | ||||||
|                                         Text('${session.roundNumber}'), |                                         Text('${session.roundNumber}'), | ||||||
|                                         const SizedBox(width: 3), |                                         const SizedBox(width: 3), | ||||||
|                                         const Icon(CupertinoIcons |                                         const Icon(CupertinoIcons | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ name: cabo_counter | |||||||
| description: "Mobile app for the card game Cabo" | description: "Mobile app for the card game Cabo" | ||||||
| publish_to: 'none' | publish_to: 'none' | ||||||
|  |  | ||||||
| version: 0.5.2+581 | version: 0.5.3+589 | ||||||
|  |  | ||||||
| environment: | environment: | ||||||
|   sdk: ^3.5.4 |   sdk: ^3.5.4 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 GitHub
						GitHub