2023-07-01 07:29:43 +00:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_svg/svg.dart';
|
2023-07-03 17:41:12 +00:00
|
|
|
import 'package:go_router/go_router.dart';
|
|
|
|
import 'package:mchess/chess_bloc/promotion_bloc.dart';
|
2023-07-01 07:29:43 +00:00
|
|
|
import 'package:mchess/utils/chess_utils.dart';
|
|
|
|
|
|
|
|
class PromotionDialog extends StatelessWidget {
|
|
|
|
final ChessColor sideColor;
|
|
|
|
const PromotionDialog({required this.sideColor, super.key});
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
2023-07-03 17:41:12 +00:00
|
|
|
double windowWidth = MediaQuery.of(context).size.width;
|
|
|
|
double windowHeight = MediaQuery.of(context).size.height;
|
|
|
|
double iconSize;
|
|
|
|
|
|
|
|
if (windowWidth < windowHeight) {
|
|
|
|
iconSize = 0.15 * windowWidth;
|
|
|
|
} else {
|
|
|
|
iconSize = 0.15 * windowHeight;
|
|
|
|
}
|
|
|
|
|
|
|
|
return Dialog(
|
|
|
|
child: Row(
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
|
|
|
|
children: [
|
|
|
|
IconButton(
|
|
|
|
onPressed: () {
|
|
|
|
pieceChosen(ChessPieceClass.queen);
|
|
|
|
context.pop();
|
|
|
|
},
|
|
|
|
icon: SvgPicture.asset(chessPiecesAssets[ChessPieceAssetKey(
|
|
|
|
pieceClass: ChessPieceClass.queen, color: sideColor)]!),
|
|
|
|
iconSize: 200,
|
|
|
|
),
|
|
|
|
IconButton(
|
|
|
|
onPressed: () {
|
|
|
|
pieceChosen(ChessPieceClass.rook);
|
|
|
|
context.pop();
|
|
|
|
},
|
|
|
|
icon: SvgPicture.asset(chessPiecesAssets[ChessPieceAssetKey(
|
|
|
|
pieceClass: ChessPieceClass.rook, color: sideColor)]!),
|
|
|
|
iconSize: 100,
|
2023-07-01 07:29:43 +00:00
|
|
|
),
|
2023-07-03 17:41:12 +00:00
|
|
|
IconButton(
|
|
|
|
onPressed: () {
|
|
|
|
pieceChosen(ChessPieceClass.knight);
|
|
|
|
context.pop();
|
|
|
|
},
|
|
|
|
icon: SvgPicture.asset(chessPiecesAssets[ChessPieceAssetKey(
|
|
|
|
pieceClass: ChessPieceClass.knight, color: sideColor)]!),
|
|
|
|
iconSize: 10,
|
|
|
|
),
|
|
|
|
IconButton(
|
|
|
|
onPressed: () {
|
|
|
|
pieceChosen(ChessPieceClass.bishop);
|
|
|
|
context.pop();
|
|
|
|
},
|
|
|
|
icon: SvgPicture.asset(chessPiecesAssets[ChessPieceAssetKey(
|
|
|
|
pieceClass: ChessPieceClass.bishop, color: sideColor)]!),
|
|
|
|
iconSize: iconSize,
|
|
|
|
)
|
|
|
|
],
|
|
|
|
),
|
2023-07-01 07:29:43 +00:00
|
|
|
);
|
|
|
|
}
|
2023-07-03 17:41:12 +00:00
|
|
|
|
|
|
|
void pieceChosen(ChessPieceClass pieceClass) {
|
|
|
|
PromotionBloc.getInstance()
|
|
|
|
.add(PieceChosen(pieceClass: pieceClass, color: sideColor));
|
|
|
|
}
|
2023-07-01 07:29:43 +00:00
|
|
|
}
|