You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

93 lines
3.0 KiB

2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
  1. import 'package:flutter/material.dart';
  2. import 'package:flutter_riverpod/flutter_riverpod.dart';
  3. import 'package:my_flutter_puzzle/models/puzzle_data.dart';
  4. import 'package:my_flutter_puzzle/providers.dart';
  5. import 'package:my_flutter_puzzle/utils/puzzle_solver.dart';
  6. import 'game_button_widget/puzzle_game_button.dart';
  7. class GameButtonWidget extends StatelessWidget {
  8. const GameButtonWidget({
  9. Key? key,
  10. required PuzzleSolverClient solverClient,
  11. required PuzzleData initialPuzzleData,
  12. this.width = 145,
  13. this.padding = const EdgeInsets.only(top: 13.0, bottom: 12.0),
  14. }) : _solverClient = solverClient,
  15. _initialPuzzleData = initialPuzzleData,
  16. super(key: key);
  17. final PuzzleSolverClient _solverClient;
  18. final PuzzleData _initialPuzzleData;
  19. final double width;
  20. final EdgeInsets padding;
  21. @override
  22. Widget build(BuildContext context) {
  23. return Consumer(
  24. builder: (context, ref, child) {
  25. final state = ref.watch(puzzleNotifierProvider(_solverClient));
  26. return state.when(
  27. () => PuzzleGameButton(
  28. text: 'Start Game',
  29. onTap: () => ref.read(puzzleNotifierProvider(_solverClient).notifier).initializePuzzle(
  30. initialPuzzleData: _initialPuzzleData,
  31. ),
  32. padding: padding,
  33. width: width,
  34. ),
  35. initializing: () => PuzzleGameButton(
  36. text: 'Get ready...',
  37. onTap: null,
  38. padding: padding,
  39. width: width,
  40. ),
  41. scrambling: (_) => PuzzleGameButton(
  42. text: 'Get ready...',
  43. onTap: null,
  44. padding: padding,
  45. width: width,
  46. ),
  47. current: (puzzleData) => PuzzleGameButton(
  48. text: 'Restart',
  49. onTap: () {
  50. ref.read(timerNotifierProvider.notifier).stopTimer();
  51. ref.read(puzzleNotifierProvider(_solverClient).notifier).restartPuzzle();
  52. },
  53. padding: padding,
  54. width: width,
  55. ),
  56. computingSolution: (puzzleData) => PuzzleGameButton(
  57. text: 'Processing...',
  58. onTap: null,
  59. padding: padding,
  60. width: width,
  61. ),
  62. autoSolving: (puzzleData) => PuzzleGameButton(
  63. text: 'Solving...',
  64. onTap: null,
  65. padding: padding,
  66. width: width,
  67. ),
  68. solved: (puzzleData) => PuzzleGameButton(
  69. text: 'Start Game',
  70. onTap: () => ref.read(puzzleNotifierProvider(_solverClient).notifier).initializePuzzle(
  71. initialPuzzleData: puzzleData,
  72. ),
  73. padding: padding,
  74. width: width,
  75. ),
  76. error: (_) => PuzzleGameButton(
  77. text: 'Start Game',
  78. onTap: () => ref.read(puzzleNotifierProvider(_solverClient).notifier).initializePuzzle(
  79. initialPuzzleData: _initialPuzzleData,
  80. ),
  81. padding: padding,
  82. width: width,
  83. ),
  84. );
  85. },
  86. );
  87. }
  88. }