handle decided boards

feature/modern-browsers
Inga 🏳‍🌈 1 month ago
parent a30663b268
commit 83e63f0538
  1. 54
      src/backend/components/boardgame.tsx
  2. 3
      src/backend/main/boardgame-handler.ts
  3. 5
      src/shared/rules.spec.ts

@ -1,48 +1,66 @@
import { sequence } from "../../shared/array-utils.ts";
import { BoardgameStateType, SquareState, formatSquareState } from "../../shared/datatypes.ts";
import {
BoardgameStateType,
CurrentOutcome,
GameRules,
SquareState,
formatSquareState,
} from "../../shared/datatypes.ts";
const getCellHtml = (key: string, state: BoardgameStateType, row: number, column: number) => {
if (!state.board) {
const getCellHtml = ({
key,
gameState,
currentOutcome,
row,
column,
}: {
key: string;
gameState: BoardgameStateType;
currentOutcome: CurrentOutcome;
row: number;
column: number;
}) => {
if (!gameState.board) {
return (
<button type="submit" name={key} value={state.serialize()} disabled>
<button type="submit" name={key} value={gameState.serialize()} disabled>
{" "}
</button>
);
}
const squareState = state.board.get(row, column);
const nextGameState = squareState === SquareState.Unoccupied ? state.withMove(row, column) : state;
const squareState = gameState.board.get(row, column);
const nextGameState =
squareState === SquareState.Unoccupied && currentOutcome === CurrentOutcome.Undecided
? gameState.withMove(row, column)
: gameState;
return (
<button
type="submit"
name={key}
value={nextGameState.serialize()}
disabled={squareState !== SquareState.Unoccupied}
>
<button type="submit" name={key} value={nextGameState.serialize()} disabled={nextGameState === gameState}>
{formatSquareState(squareState)}
</button>
);
};
export const getBoardgameHtml = (key: string, state: BoardgameStateType) => {
export const getBoardgameHtml = (key: string, gameState: BoardgameStateType, rules: GameRules) => {
const currentOutcome = gameState.board ? rules.getBoardOutcome(gameState.board) : CurrentOutcome.Undecided;
return (
<board-game>
<form method="post">
<p>Current player: {state.currentPlayerName}</p>
<p>Current player: {gameState.currentPlayerName}</p>
<table>
<tbody>
{sequence(state.rows).map((row) => (
{sequence(gameState.rows).map((row) => (
<tr>
{sequence(state.columns).map((column) => (
<td>{getCellHtml(key, state, row, column)}</td>
{sequence(gameState.columns).map((column) => (
<td>{getCellHtml({ key, gameState, currentOutcome, row, column })}</td>
))}
</tr>
))}
</tbody>
</table>
<button type="submit" name={key} value={state.withEmptyBoard().serialize()}>
<button type="submit" name={key} value={gameState.withEmptyBoard().serialize()}>
Start game
</button>
</form>

@ -2,6 +2,7 @@ import type { Request, Response } from "express";
import { rewriteQueryParamsWith, safeGetQueryValue } from "../utils.ts";
import { BoardgameState } from "../../shared/boardgame-state.ts";
import { getBoardgameHtml } from "../components/boardgame.tsx";
import { gamesRules } from "../../shared/rules.spec.ts";
// Returns nothing if query parameter is uninitialized and a redirect was made,
// or component if query parameter is initialized.
@ -15,5 +16,5 @@ export const handleBoardgame = (req: Request, res: Response, key: string) => {
return;
}
return getBoardgameHtml(key, state);
return getBoardgameHtml(key, state, gamesRules.tictactoe);
};

@ -0,0 +1,5 @@
import { rules as tictactoeRules } from "./tictactoe-rules.ts";
export const gamesRules = {
tictactoe: tictactoeRules,
};
Loading…
Cancel
Save