let socket = io(); let list = document.querySelector('.liste'); let current = {"plate": null, "content": [], "sauce": [], "drink": null, "dessert": null}; let radios = {"plate": null}; function addcmd(id, plate, content, sauce, drink, dessert, state) { $(list).append(`

Commande ${id}

${plate}

${content}

${sauce}

${drink}

${dessert}

`); let e = document.querySelector(`.liste #cmd${id}`); e.addEventListener( "click" ,env => { env.stopPropagation(); e.classList.toggle("show-spec"); }); switch (state) { case "done": done(e); break; case "gave": give(e); break; case "error": error(e); break; } document.querySelector('#resume>h1').innerHTML = `Commande ${id+1}`; } function clear(e) { e.classList.remove('finis'); e.classList.remove('donnee'); e.classList.remove('probleme'); e.classList.remove('show-spec'); list.prepend(e); } function done(e) { e.classList.remove('show-spec'); e.classList.add('finis'); } function give(e) { e.classList.remove('show-spec'); e.classList.add('donnee'); list.appendChild(e); } function error(e) { e.classList.remove('show-spec'); e.classList.add('probleme'); list.appendChild(e); } function donner(id) { socket.emit("give command", {"id": id}); } function annuler(id) { socket.emit("clear command", {"id": id}); } function erreur(id) { socket.emit("error command", {"id": id}); } function addplate() { } socket.on("connect", function (data) { if (data === "ok") { socket.emit("list command"); } }); socket.on("list command", function (data) { let child = list.lastElementChild; while (child) { list.removeChild(child); child = list.lastElementChild; } for (let c of data.list) { addcmd(c.id, c.plate, c.content, c.sauce, c.drink, c.dessert, c.state); } }); socket.on("new command", function (data) { addcmd(data.id, data.plate, data.content, data.sauce, data.drink, data.dessert, data.state); }); socket.on("cleared command", function (data) { clear(document.querySelector(`.liste #cmd${data.id}`)); }); socket.on("finish command", function (data) { done(document.querySelector(`.liste #cmd${data.id}`)); }); socket.on("gave command", function (data) { give(document.querySelector(`.liste #cmd${data.id}`)); }); socket.on("glitched command", function (data) { error(document.querySelector(`.liste #cmd${data.id}`)); }); document.querySelectorAll("input[name=plat]").forEach( function (e) { e.addEventListener("click", () => { if (e.checked) { let curr, name; if (e.id === radios["plate"]) { e.checked = false; radios["plate"] = null; curr = null; name = null; } else { radios["plate"] = e.id; curr = e.id; name = document.querySelector(`label[for=${e.id}]`).innerHTML; } current["plate"] = curr; document.querySelectorAll("#resume p")[0].innerHTML = name; } }) }); document.querySelectorAll("input[name=ingredient]").forEach( function (e) { e.addEventListener("click", () => { if (e.checked) current["content"].push(e.id); else current["content"].splice(current["content"].indexOf(e.id), 1); let content = []; document.querySelectorAll("input[name=ingredient]").forEach( e => { if (e.checked) content.push(document.querySelector(`label[for=${e.id}]`).innerHTML) }); document.querySelectorAll("#resume p")[1].innerHTML = content.join(" - "); document.querySelectorAll("input[name=ingredient]").forEach( e => { if (!e.checked) e.disabled = content.length === 3 }); }) }); document.querySelectorAll("input[name=sauce]").forEach( function (e) { e.addEventListener("click", () => { if (e.checked) current["sauce"].push(e.id); else current["sauce"].splice(current["sauce"].indexOf(e.id), 1); let content = []; document.querySelectorAll("input[name=sauce]").forEach( e => { if (e.checked) content.push(document.querySelector(`label[for=${e.id}]`).innerHTML) }); document.querySelectorAll("#resume p")[2].innerHTML = content.join(" - "); document.querySelectorAll("input[name=sauce]").forEach( e => { if (!e.checked) e.disabled = content.length === 2 }); }) }); document.querySelectorAll("input[name=boisson]").forEach( function (e) { e.addEventListener("click", () => { if (e.checked) { let curr, name; if (e.id === radios["plate"]) { e.checked = false; radios["plate"] = null; curr = null; name = null; } else { radios["plate"] = e.id; curr = e.id; name = document.querySelector(`label[for=${e.id}]`).innerHTML; } current["drink"] = curr; document.querySelectorAll("#resume p")[3].innerHTML = name; } }) }); document.querySelectorAll("input[name=dessert]").forEach( function (e) { e.addEventListener("click", () => { if (e.checked) { let curr, name; if (e.id === radios["plate"]) { e.checked = false; radios["plate"] = null; curr = null; name = null; } else { radios["plate"] = e.id; curr = e.id; name = document.querySelector(`label[for=${e.id}]`).innerHTML; } current["dessert"] = curr; document.querySelectorAll("#resume p")[4].innerHTML = name; } }) }); document.querySelector('.validation').addEventListener('click', ev => { ev.stopPropagation(); current["pc"] = 1; current["sandwitch"] = 1; current["client"] = 1; socket.emit("add command", current); current = {"plate": null, "content": [], "sauce": [], "drink": null, "dessert": null}; document.querySelectorAll("input").forEach( e => { e.checked = false }); document.querySelectorAll("#resume p").forEach( e => { e.innerHTML = "" }); });