Add last move highlight
This commit is contained in:
parent
d70bb80c39
commit
a55f0890ce
|
@ -168,6 +168,13 @@ body {
|
|||
left: 12px;
|
||||
}
|
||||
|
||||
.last-move.stone-white-heart::after,
|
||||
.last-move.stone-black-heart::after,
|
||||
.last-move.stone-white-heart::before,
|
||||
.last-move.stone-black-heart::before {
|
||||
border: 2px solid var(--color-info) !important;
|
||||
}
|
||||
|
||||
.stone-black-heart::after,
|
||||
.stone-white-heart::after {
|
||||
left: 0;
|
||||
|
@ -208,10 +215,6 @@ body {
|
|||
padding: 2px;
|
||||
}
|
||||
|
||||
.last-move {
|
||||
box-shadow: 0 0 5px 3px var(--color-warning-light);
|
||||
}
|
||||
|
||||
#game-link-container {
|
||||
position: relative;
|
||||
display: flex;
|
||||
|
|
|
@ -4,6 +4,9 @@ export function renderGameBoardHtml(
|
|||
game: GomokuGame,
|
||||
isPlayerToPlay: boolean,
|
||||
): string {
|
||||
// Check the last move, so that the stone can be highlighted
|
||||
const lastMove = game.history[game.history.length - 1];
|
||||
|
||||
let boardHtml = '<div id="game-board" class="game-board-grid">';
|
||||
for (let row = 0; row < game.board.length; row++) {
|
||||
for (let col = 0; col < game.board[row].length; col++) {
|
||||
|
@ -13,7 +16,8 @@ export function renderGameBoardHtml(
|
|||
if (stone) {
|
||||
const colorClass =
|
||||
stone === 'black' ? 'stone-black-heart' : 'stone-white-heart';
|
||||
stoneHtml = `<div class="${colorClass}"></div>`;
|
||||
const lastMoveClass = col == lastMove.col && row == lastMove.row ? 'last-move' : '';
|
||||
stoneHtml = `<div class="${colorClass} ${lastMoveClass}"></div>`;
|
||||
}
|
||||
|
||||
// Calculate top and left for absolute positioning, offset by half the intersection div size
|
||||
|
|
Loading…
Reference in New Issue