Compare commits
2 commits
b1ace6ceb3
...
191ae2113c
Author | SHA1 | Date | |
---|---|---|---|
191ae2113c | |||
7ba310c7ca |
4 changed files with 32 additions and 3 deletions
|
@ -25,3 +25,5 @@ pipeline:
|
||||||
github_sshkey
|
github_sshkey
|
||||||
target_branch: gh-pages
|
target_branch: gh-pages
|
||||||
pages_directory: ./lib/static
|
pages_directory: ./lib/static
|
||||||
|
when:
|
||||||
|
branch: main
|
||||||
|
|
|
@ -94,7 +94,7 @@ export function App()
|
||||||
`Player ${Constants.PLAYER_NAMES[game.winner]} wins!` :
|
`Player ${Constants.PLAYER_NAMES[game.winner]} wins!` :
|
||||||
`It's player "${Constants.PLAYER_NAMES[game.currentPlayer]}"s turn`
|
`It's player "${Constants.PLAYER_NAMES[game.currentPlayer]}"s turn`
|
||||||
],
|
],
|
||||||
[MenuBar]
|
[MenuBar, { game }]
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -153,10 +153,13 @@ export function Field({ field })
|
||||||
/**
|
/**
|
||||||
* Renders a menu bar.
|
* Renders a menu bar.
|
||||||
*
|
*
|
||||||
|
* @param {{ game: Game }} game
|
||||||
|
* The game to represent.
|
||||||
|
*
|
||||||
* @returns {NodeDescriptor}
|
* @returns {NodeDescriptor}
|
||||||
* The rendered element.
|
* The rendered element.
|
||||||
*/
|
*/
|
||||||
export function MenuBar()
|
export function MenuBar({ game })
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
"div",
|
"div",
|
||||||
|
@ -164,7 +167,18 @@ export function MenuBar()
|
||||||
[Button, { content: ["New Game", { className: newGameClass }] }],
|
[Button, { content: ["New Game", { className: newGameClass }] }],
|
||||||
[Button, { content: ["Save Game", { className: saveGameClass }] }],
|
[Button, { content: ["Save Game", { className: saveGameClass }] }],
|
||||||
[Button, { content: ["Load Game", { className: loadGameClass }] }],
|
[Button, { content: ["Load Game", { className: loadGameClass }] }],
|
||||||
[Button, { content: ["Undo Last Move", { className: undoClass }] }]
|
[
|
||||||
|
Button,
|
||||||
|
{
|
||||||
|
content: [
|
||||||
|
"Undo Last Move",
|
||||||
|
{
|
||||||
|
className: undoClass,
|
||||||
|
...(game.undoStackCount > 0 ? {} : { disabled: true })
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -68,6 +68,14 @@ export class Game
|
||||||
return this.state.turnCount % 2 === 0 ? "r" : "b";
|
return this.state.turnCount % 2 === 0 ? "r" : "b";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the number of entries in the undo stack.
|
||||||
|
*/
|
||||||
|
get undoStackCount()
|
||||||
|
{
|
||||||
|
return this.#previousStates.length;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the id of the player that is winning.
|
* Gets the id of the player that is winning.
|
||||||
*
|
*
|
||||||
|
|
|
@ -19,6 +19,11 @@ button:active {
|
||||||
background-color: rgb(96, 190, 221);
|
background-color: rgb(96, 190, 221);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
button:disabled {
|
||||||
|
background-color: whitesmoke;
|
||||||
|
border-color: lightgray;
|
||||||
|
}
|
||||||
|
|
||||||
div {
|
div {
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue