329 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			329 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'package:cabo_counter/data/models/game_manager.dart';
 | |
| import 'package:cabo_counter/data/models/game_session.dart';
 | |
| import 'package:cabo_counter/l10n/app_localizations.dart';
 | |
| import 'package:cabo_counter/utility/custom_theme.dart';
 | |
| import 'package:cabo_counter/utility/globals.dart';
 | |
| import 'package:cabo_counter/views/active_game_view.dart';
 | |
| import 'package:cabo_counter/views/mode_selection_view.dart';
 | |
| import 'package:flutter/cupertino.dart';
 | |
| 
 | |
| class CreateGame extends StatefulWidget {
 | |
|   const CreateGame({super.key});
 | |
| 
 | |
|   @override
 | |
|   // ignore: library_private_types_in_public_api
 | |
|   _CreateGameState createState() => _CreateGameState();
 | |
| }
 | |
| 
 | |
| class _CreateGameState extends State<CreateGame> {
 | |
|   final List<TextEditingController> _playerNameTextControllers = [
 | |
|     TextEditingController()
 | |
|   ];
 | |
|   final TextEditingController _gameTitleTextController =
 | |
|       TextEditingController();
 | |
| 
 | |
|   /// Maximum number of players allowed in the game.
 | |
|   final int maxPlayers = 5;
 | |
| 
 | |
|   /// Variable to store the selected game mode.
 | |
|   bool? selectedMode;
 | |
| 
 | |
|   @override
 | |
|   Widget build(BuildContext context) {
 | |
|     return CupertinoPageScaffold(
 | |
|         navigationBar: CupertinoNavigationBar(
 | |
|           previousPageTitle: AppLocalizations.of(context).overview,
 | |
|           middle: Text(AppLocalizations.of(context).new_game),
 | |
|         ),
 | |
|         child: SafeArea(
 | |
|             child: Center(
 | |
|                 child: Column(
 | |
|           mainAxisAlignment: MainAxisAlignment.start,
 | |
|           crossAxisAlignment: CrossAxisAlignment.start,
 | |
|           children: [
 | |
|             Padding(
 | |
|               padding: const EdgeInsets.fromLTRB(10, 10, 0, 0),
 | |
|               child: Text(
 | |
|                 AppLocalizations.of(context).game,
 | |
|                 style: CustomTheme.rowTitle,
 | |
|               ),
 | |
|             ),
 | |
|             Padding(
 | |
|               padding: const EdgeInsets.fromLTRB(15, 10, 10, 0),
 | |
|               child: CupertinoTextField(
 | |
|                 decoration: const BoxDecoration(),
 | |
|                 maxLength: 16,
 | |
|                 prefix: Text(AppLocalizations.of(context).name),
 | |
|                 textAlign: TextAlign.right,
 | |
|                 placeholder: AppLocalizations.of(context).game_title,
 | |
|                 controller: _gameTitleTextController,
 | |
|               ),
 | |
|             ),
 | |
|             // Spielmodus-Auswahl mit Chevron
 | |
|             Padding(
 | |
|               padding: const EdgeInsets.fromLTRB(15, 10, 10, 0),
 | |
|               child: CupertinoTextField(
 | |
|                 decoration: const BoxDecoration(),
 | |
|                 readOnly: true,
 | |
|                 prefix: Text(AppLocalizations.of(context).mode),
 | |
|                 suffix: Row(
 | |
|                   children: [
 | |
|                     Text(
 | |
|                       selectedMode == null
 | |
|                           ? AppLocalizations.of(context).select_mode
 | |
|                           : (selectedMode!
 | |
|                               ? '${Globals.pointLimit} ${AppLocalizations.of(context).points}'
 | |
|                               : AppLocalizations.of(context).unlimited),
 | |
|                     ),
 | |
|                     const SizedBox(width: 3),
 | |
|                     const CupertinoListTileChevron(),
 | |
|                   ],
 | |
|                 ),
 | |
|                 onTap: () async {
 | |
|                   final selected = await Navigator.push(
 | |
|                     context,
 | |
|                     CupertinoPageRoute(
 | |
|                       builder: (context) => ModeSelectionMenu(
 | |
|                         pointLimit: Globals.pointLimit,
 | |
|                       ),
 | |
|                     ),
 | |
|                   );
 | |
| 
 | |
|                   if (selected != null) {
 | |
|                     setState(() {
 | |
|                       selectedMode = selected;
 | |
|                     });
 | |
|                   }
 | |
|                 },
 | |
|               ),
 | |
|             ),
 | |
|             Padding(
 | |
|               padding: const EdgeInsets.fromLTRB(10, 10, 0, 0),
 | |
|               child: Text(
 | |
|                 AppLocalizations.of(context).players,
 | |
|                 style: CustomTheme.rowTitle,
 | |
|               ),
 | |
|             ),
 | |
|             Expanded(
 | |
|               child: ListView.builder(
 | |
|                 itemCount: _playerNameTextControllers.length +
 | |
|                     1, // +1 für den + Button
 | |
|                 itemBuilder: (context, index) {
 | |
|                   if (index == _playerNameTextControllers.length) {
 | |
|                     // + Button als letztes Element
 | |
|                     return Padding(
 | |
|                       padding: const EdgeInsets.symmetric(vertical: 8.0),
 | |
|                       child: CupertinoButton(
 | |
|                         padding: EdgeInsets.zero,
 | |
|                         child: Row(
 | |
|                           mainAxisAlignment: MainAxisAlignment.center,
 | |
|                           children: [
 | |
|                             const Icon(
 | |
|                               CupertinoIcons.add_circled,
 | |
|                               color: CupertinoColors.activeGreen,
 | |
|                               size: 25,
 | |
|                             ),
 | |
|                             const SizedBox(width: 8),
 | |
|                             Text(
 | |
|                               AppLocalizations.of(context).add_player,
 | |
|                               style: const TextStyle(
 | |
|                                 color: CupertinoColors.activeGreen,
 | |
|                               ),
 | |
|                             ),
 | |
|                           ],
 | |
|                         ),
 | |
|                         onPressed: () {
 | |
|                           if (_playerNameTextControllers.length < maxPlayers) {
 | |
|                             setState(() {
 | |
|                               _playerNameTextControllers
 | |
|                                   .add(TextEditingController());
 | |
|                             });
 | |
|                           } else {
 | |
|                             showCupertinoDialog(
 | |
|                               context: context,
 | |
|                               builder: (context) => CupertinoAlertDialog(
 | |
|                                 title: Text(AppLocalizations.of(context)
 | |
|                                     .max_players_title),
 | |
|                                 content: Text(AppLocalizations.of(context)
 | |
|                                     .max_players_message),
 | |
|                                 actions: [
 | |
|                                   CupertinoDialogAction(
 | |
|                                     child:
 | |
|                                         Text(AppLocalizations.of(context).ok),
 | |
|                                     onPressed: () => Navigator.pop(context),
 | |
|                                   ),
 | |
|                                 ],
 | |
|                               ),
 | |
|                             );
 | |
|                           }
 | |
|                         },
 | |
|                       ),
 | |
|                     );
 | |
|                   } else {
 | |
|                     // Spieler-Einträge
 | |
|                     return Padding(
 | |
|                       padding: const EdgeInsets.symmetric(
 | |
|                           vertical: 8.0, horizontal: 5),
 | |
|                       child: Row(
 | |
|                         children: [
 | |
|                           CupertinoButton(
 | |
|                             padding: EdgeInsets.zero,
 | |
|                             child: const Icon(
 | |
|                               CupertinoIcons.minus_circle_fill,
 | |
|                               color: CupertinoColors.destructiveRed,
 | |
|                               size: 25,
 | |
|                             ),
 | |
|                             onPressed: () {
 | |
|                               setState(() {
 | |
|                                 _playerNameTextControllers[index].dispose();
 | |
|                                 _playerNameTextControllers.removeAt(index);
 | |
|                               });
 | |
|                             },
 | |
|                           ),
 | |
|                           Expanded(
 | |
|                             child: CupertinoTextField(
 | |
|                               controller: _playerNameTextControllers[index],
 | |
|                               placeholder:
 | |
|                                   '${AppLocalizations.of(context).player} ${index + 1}',
 | |
|                               padding: const EdgeInsets.all(12),
 | |
|                               decoration: const BoxDecoration(),
 | |
|                             ),
 | |
|                           ),
 | |
|                         ],
 | |
|                       ),
 | |
|                     );
 | |
|                   }
 | |
|                 },
 | |
|               ),
 | |
|             ),
 | |
|             Center(
 | |
|               child: CupertinoButton(
 | |
|                 padding: EdgeInsets.zero,
 | |
|                 child: Row(
 | |
|                   mainAxisAlignment: MainAxisAlignment.center,
 | |
|                   children: [
 | |
|                     Text(
 | |
|                       AppLocalizations.of(context).create_game,
 | |
|                       style: const TextStyle(
 | |
|                         color: CupertinoColors.activeGreen,
 | |
|                       ),
 | |
|                     ),
 | |
|                   ],
 | |
|                 ),
 | |
|                 onPressed: () async {
 | |
|                   if (_gameTitleTextController.text == '') {
 | |
|                     showCupertinoDialog(
 | |
|                       context: context,
 | |
|                       builder: (context) => CupertinoAlertDialog(
 | |
|                         title: Text(
 | |
|                             AppLocalizations.of(context).no_gameTitle_title),
 | |
|                         content: Text(
 | |
|                             AppLocalizations.of(context).no_gameTitle_message),
 | |
|                         actions: [
 | |
|                           CupertinoDialogAction(
 | |
|                             child: Text(AppLocalizations.of(context).ok),
 | |
|                             onPressed: () => Navigator.pop(context),
 | |
|                           ),
 | |
|                         ],
 | |
|                       ),
 | |
|                     );
 | |
|                     return;
 | |
|                   }
 | |
|                   if (selectedMode == null) {
 | |
|                     showCupertinoDialog(
 | |
|                       context: context,
 | |
|                       builder: (context) => CupertinoAlertDialog(
 | |
|                         title: Text(AppLocalizations.of(context).no_mode_title),
 | |
|                         content:
 | |
|                             Text(AppLocalizations.of(context).no_mode_message),
 | |
|                         actions: [
 | |
|                           CupertinoDialogAction(
 | |
|                             child: Text(AppLocalizations.of(context).ok),
 | |
|                             onPressed: () => Navigator.pop(context),
 | |
|                           ),
 | |
|                         ],
 | |
|                       ),
 | |
|                     );
 | |
|                     return;
 | |
|                   }
 | |
|                   if (_playerNameTextControllers.length < 2) {
 | |
|                     showCupertinoDialog(
 | |
|                       context: context,
 | |
|                       builder: (context) => CupertinoAlertDialog(
 | |
|                         title: Text(
 | |
|                             AppLocalizations.of(context).min_players_title),
 | |
|                         content: Text(
 | |
|                             AppLocalizations.of(context).min_players_message),
 | |
|                         actions: [
 | |
|                           CupertinoDialogAction(
 | |
|                             child: Text(AppLocalizations.of(context).ok),
 | |
|                             onPressed: () => Navigator.pop(context),
 | |
|                           ),
 | |
|                         ],
 | |
|                       ),
 | |
|                     );
 | |
|                     return;
 | |
|                   }
 | |
|                   if (!everyPlayerHasAName()) {
 | |
|                     showCupertinoDialog(
 | |
|                       context: context,
 | |
|                       builder: (context) => CupertinoAlertDialog(
 | |
|                         title: Text(AppLocalizations.of(context).no_name_title),
 | |
|                         content:
 | |
|                             Text(AppLocalizations.of(context).no_name_message),
 | |
|                         actions: [
 | |
|                           CupertinoDialogAction(
 | |
|                             child: Text(AppLocalizations.of(context).ok),
 | |
|                             onPressed: () => Navigator.pop(context),
 | |
|                           ),
 | |
|                         ],
 | |
|                       ),
 | |
|                     );
 | |
|                     return;
 | |
|                   }
 | |
| 
 | |
|                   List<String> players = [];
 | |
|                   for (var controller in _playerNameTextControllers) {
 | |
|                     players.add(controller.text);
 | |
|                   }
 | |
|                   GameSession gameSession = GameSession(
 | |
|                     createdAt: DateTime.now(),
 | |
|                     gameTitle: _gameTitleTextController.text,
 | |
|                     players: players,
 | |
|                     pointLimit: Globals.pointLimit,
 | |
|                     caboPenalty: Globals.caboPenalty,
 | |
|                     isPointsLimitEnabled: selectedMode!,
 | |
|                   );
 | |
|                   final index = await gameManager.addGameSession(gameSession);
 | |
|                   if (context.mounted) {
 | |
|                     Navigator.pushReplacement(
 | |
|                         context,
 | |
|                         CupertinoPageRoute(
 | |
|                             builder: (context) => ActiveGameView(
 | |
|                                 gameSession: gameManager.gameList[index])));
 | |
|                   }
 | |
|                 },
 | |
|               ),
 | |
|             ),
 | |
|           ],
 | |
|         ))));
 | |
|   }
 | |
| 
 | |
|   bool everyPlayerHasAName() {
 | |
|     for (var controller in _playerNameTextControllers) {
 | |
|       if (controller.text == '') {
 | |
|         return false;
 | |
|       }
 | |
|     }
 | |
|     return true;
 | |
|   }
 | |
| 
 | |
|   @override
 | |
|   void dispose() {
 | |
|     for (var controller in _playerNameTextControllers) {
 | |
|       controller.dispose();
 | |
|     }
 | |
|     super.dispose();
 | |
|   }
 | |
| }
 |