Move all click handlers to the App
This commit is contained in:
parent
80b55732e7
commit
30cbc40d38
1 changed files with 45 additions and 39 deletions
|
@ -1,6 +1,9 @@
|
||||||
import { Constants } from "./Constants.js";
|
import { Constants } from "./Constants.js";
|
||||||
|
|
||||||
const saveGameKey = "connect-force-save";
|
const saveGameKey = "connect-force-save";
|
||||||
|
const newGameClass = "new-game";
|
||||||
|
const saveGameClass = "save-game";
|
||||||
|
const loadGameClass = "load-game";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets a component which represents the specified {@link game `game`}.
|
* Gets a component which represents the specified {@link game `game`}.
|
||||||
|
@ -20,6 +23,20 @@ export function App(game)
|
||||||
{
|
{
|
||||||
let target = /** @type {HTMLElement} */ (event.target);
|
let target = /** @type {HTMLElement} */ (event.target);
|
||||||
|
|
||||||
|
if (target.classList.contains(newGameClass))
|
||||||
|
{
|
||||||
|
game.reset();
|
||||||
|
}
|
||||||
|
else if (target.classList.contains(saveGameClass))
|
||||||
|
{
|
||||||
|
localStorage.setItem(saveGameKey, JSON.stringify(game.dump()));
|
||||||
|
}
|
||||||
|
else if (target.classList.contains(loadGameClass))
|
||||||
|
{
|
||||||
|
game.load(JSON.parse(localStorage.getItem(saveGameKey)));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
for (let y = 0; y < game.board.length; y++)
|
for (let y = 0; y < game.board.length; y++)
|
||||||
{
|
{
|
||||||
let rowLength = game.board[y].length;
|
let rowLength = game.board[y].length;
|
||||||
|
@ -39,6 +56,7 @@ export function App(game)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
[
|
[
|
||||||
Board,
|
Board,
|
||||||
|
@ -123,59 +141,47 @@ export function MenuBar(game)
|
||||||
{ className: "menu-bar" },
|
{ className: "menu-bar" },
|
||||||
[
|
[
|
||||||
Button,
|
Button,
|
||||||
|
[
|
||||||
|
"New Game",
|
||||||
{
|
{
|
||||||
text: "New Game",
|
className: newGameClass
|
||||||
attributes: {
|
|
||||||
onclick: () =>
|
|
||||||
{
|
|
||||||
game.reset();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
]
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
Button,
|
Button,
|
||||||
|
[
|
||||||
|
"Save Game",
|
||||||
{
|
{
|
||||||
text: "Save Game",
|
className: saveGameClass
|
||||||
attributes: {
|
|
||||||
onclick: () =>
|
|
||||||
{
|
|
||||||
localStorage.setItem(
|
|
||||||
saveGameKey,
|
|
||||||
JSON.stringify(game.dump()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
]
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
Button,
|
Button,
|
||||||
|
[
|
||||||
|
"Load Game",
|
||||||
{
|
{
|
||||||
text: "Load Game",
|
className: loadGameClass
|
||||||
attributes: {
|
|
||||||
onclick: () =>
|
|
||||||
{
|
|
||||||
game.load(JSON.parse(localStorage.getItem(saveGameKey)));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
]
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Renders a button.
|
* Renders a button.
|
||||||
*
|
*
|
||||||
* @param {{text: string, attributes: (Partial<HTMLElement> & Record<string, any>)}} data
|
* @param {...ElementDescriptor[1][]} content
|
||||||
* The settings of the button.
|
* The settings of the button.
|
||||||
*
|
*
|
||||||
* @returns {NodeDescriptor}
|
* @returns {NodeDescriptor}
|
||||||
* The rendered element.
|
* The rendered element.
|
||||||
*/
|
*/
|
||||||
export function Button(data)
|
export function Button(content)
|
||||||
{
|
{
|
||||||
return [
|
return [
|
||||||
"button",
|
"button",
|
||||||
data.attributes,
|
...content
|
||||||
data.text
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue