OpenDeck/public/javascripts/index.js

58 lines
1.5 KiB
JavaScript
Raw Normal View History

2021-03-08 11:54:28 +01:00
const socket = io();
2021-03-08 14:16:18 +01:00
const deck = document.getElementById("deck");
2021-03-08 11:54:28 +01:00
2021-03-08 14:16:18 +01:00
socket.on("connected", () => {
2021-03-08 11:54:28 +01:00
console.log("Connected !");
2021-03-08 14:16:18 +01:00
socket.emit("getDeck");
});
2021-03-08 15:22:03 +01:00
socket.on("getDeck", d => {
let data = d.data, name = d.name;
console.log(name);
2021-03-08 14:16:18 +01:00
deck.innerHTML = "";
for (let x = 0; x < data.x; x++) {
const r = document.createElement("div");
r.id = "r" + x;
for (let y = 0; y < data.y; y++) {
const c = document.createElement("div");
c.id = r.id+"c"+y;
r.insertAdjacentElement("beforeend", c);
}
deck.insertAdjacentElement("beforeend", r);
}
for (const [x, cols] of Object.entries(data.rows))
for (const [y, col] of Object.entries(cols))
setSlot(name, col, x, y);
2021-03-08 14:16:18 +01:00
});
socket.on("trigger", data => {
if (data.error)
alert(data.error)
2021-03-08 11:54:28 +01:00
});
socket.on("setSlot", data => {
if (data && !data.error)
setSlot(data.name, data.data, ...data.position)
});
function setSlot(name, data, x, y) {
let e = document.getElementById(`r${x}c${y}`);
2021-03-09 08:23:20 +01:00
if (e && data) {
if (data.image)
e.insertAdjacentHTML("beforeend", `<img src="${data.image}" alt="${data.text}">`);
else if (data.text)
e.insertAdjacentHTML("beforeend", `<p>${data.text}</p>`);
e.addEventListener("click", ev => {
ev.stopPropagation();
socket.emit("trigger", [name, x, y]);
})
2021-03-09 08:23:20 +01:00
} else if (e) {
let d = document.createElement("div");
d.id = e.id;
e.replaceWith(d);
}
}