document.addEventListener("DOMContentLoaded", async () => { "use strict"; const $ = (s,c) => (c||document).querySelector(s); function $$(x,y,z,a){a=(z||document).querySelectorAll(x);if(typeof y=="function")[].forEach.call(a,y);return a} function m(a,b,c){c=document;b=c.createElement(b||"p");b.innerHTML=a.trim();for(a=c.createDocumentFragment();c=b.firstChild;)a.appendChild(c);return a.firstChild} const board = []; const boardEl = document.createElement("table"); $("#board").appendChild(boardEl); for (let i=0;i<6;i++) { let o = ""; for (let j=0;j<6;j++) o += ` `; o = m(o, "tbody"); boardEl.appendChild(o); board.push(o); } function setRow(r, s) { s = s.toUpperCase(); $$("td", (e,i) => e.innerHTML = s.charAt(i)||" ", r); } function setRowState(r, s) { $$("td", (e,i) => { e.classList.add({ "=":"found", "-":"present", " ":"absent" }[s.charAt(i)]); }, r); } function updateKeyboard(keys) { $$("td[data-key]", e => { if (keys.hasOwnProperty(e.dataset.key)) { e.classList.remove("found","present","absent"); e.classList.add(["absent","present","found"][keys[e.dataset.key]]); } }); } let done = false; let currentRow = 0; let currentStr = ""; function processKey(key) { if (done || !/^([a-z]|enter|bspc)$/.test(key)) return; if (key === "enter") { return tryWord(); } else if (key === "bspc") { currentStr = currentStr.slice(0,-1); } else { currentStr += key; currentStr = currentStr.slice(0,6); } setRow(board[currentRow], currentStr); } const guessedLetters = {}; async function tryWord() { if (currentStr.length !== 6) return alert("Guesses must use all six letters!"); const r = await fetch("/guess/"+currentStr).then(r => r.json()); if (r.result === false) return alert("Not in word list!"); for (let i=0;i<6;i++) { const j = currentStr.charAt(i); guessedLetters[j] = Math.max(guessedLetters[j]||0, " -=".indexOf(r.result.charAt(i))); } updateKeyboard(guessedLetters); setRowState(board[currentRow], r.result); if (r.result === "======") { setTimeout(() => alert("Congratulations!")); done = true; return; } currentStr = ""; currentRow++; if (currentRow === 6) { setTimeout(() => alert("Better luck next time!")); done = true; } } document.addEventListener("keydown", e => e.ctrlKey || e.altKey || e.metaKey || processKey(e.key.toLowerCase() .replace("backspace", "bspc"))); $$("td[data-key]", k => k.addEventListener("click", () => processKey(k.dataset.key))); //if ("serviceWorker" in navigator) { // navigator.serviceWorker.register("sw.js") // .then(() => console.log("Service worker registered")); //} });