retrieve indexes from html rows/cells rather than vice versa

main
Inga 🏳‍🌈 1 month ago
parent 6de3b5d48a
commit 8b791845e4
  1. 33
      src/frontend/components/board-game.ts

@ -38,53 +38,50 @@ class BoardGameComponent extends HTMLElement {
// Technically we're mixing code and data here, but that's OK // Technically we're mixing code and data here, but that's OK
// because both slotName and templateName originate from getSlotTemplateNames and is not actually arbitrary // because both slotName and templateName originate from getSlotTemplateNames and is not actually arbitrary
for (const [slotName, templateName] of Object.entries(slotTemplateNames)) { for (const [slotName, templateName] of Object.entries(slotTemplateNames)) {
this.querySelectorAll(`.${slotName}`).forEach((slot) => { for (const slot of Array.from(this.querySelectorAll(`.${slotName}`))) {
ensureSlotTemplate(slot, templateName, () => this.querySelector(`template[name="${templateName}"]`)); ensureSlotTemplate(slot, templateName, () => this.querySelector(`template[name="${templateName}"]`));
}); }
} }
const buttonValues = getButtonValues(gameState); const buttonValues = getButtonValues(gameState);
this.querySelectorAll("button").forEach((button) => { for (const button of Array.from(this.querySelectorAll("button"))) {
button.classList.forEach((className) => { for (const className of Array.from(button.classList)) {
if (Object.prototype.hasOwnProperty.call(buttonValues, className)) { if (Object.prototype.hasOwnProperty.call(buttonValues, className)) {
button.value = buttonValues[className as keyof ButtonValues].serialize(); button.value = buttonValues[className as keyof ButtonValues].serialize();
} }
}); }
}); }
const displayStates = getDisplayStates(gameState, currentOutcome); const displayStates = getDisplayStates(gameState, currentOutcome);
for (const [className, shouldEnable] of Object.entries(displayStates)) { for (const [className, shouldEnable] of Object.entries(displayStates)) {
this.classList.toggle(className, shouldEnable); this.classList.toggle(className, shouldEnable);
} }
this.querySelectorAll("tbody.game-board").forEach((tbody) => { for (const tbody of Array.from(this.querySelectorAll("tbody.game-board"))) {
ensureRowsNumber(tbody, gameState.rows); ensureRowsNumber(tbody, gameState.rows);
for (let rowNumber = 0; rowNumber < tbody.rows.length; rowNumber++) { for (const row of Array.from(tbody.rows)) {
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- should not be empty by the definition of rowNumber
const row = tbody.rows[rowNumber]!;
ensureColumnsNumber(row, gameState.columns); ensureColumnsNumber(row, gameState.columns);
for (let columnNumber = 0; columnNumber < row.cells.length; columnNumber++) { for (const cell of Array.from(row.cells)) {
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- should not be empty by the definition of columnNumber
const cell = row.cells[columnNumber]!;
ensureSlotTemplate(cell, "game-cell", () => this.querySelector(`template[name="game-cell"]`)); ensureSlotTemplate(cell, "game-cell", () => this.querySelector(`template[name="game-cell"]`));
const { isDisabled, nextGameState, text, className } = getCellDisplayData({ const { isDisabled, nextGameState, text, className } = getCellDisplayData({
gameState, gameState,
currentOutcome, currentOutcome,
row: rowNumber, row: row.sectionRowIndex,
column: columnNumber, column: cell.cellIndex,
}); });
cell.querySelectorAll("button").forEach((button) => {
for (const button of Array.from(cell.querySelectorAll("button"))) {
button.value = nextGameState.serialize(); button.value = nextGameState.serialize();
button.disabled = isDisabled; button.disabled = isDisabled;
button.innerText = text; button.innerText = text;
button.className = className; button.className = className;
});
} }
} }
}); }
}
} }
connectedCallback() { connectedCallback() {

Loading…
Cancel
Save