aboutsummaryrefslogtreecommitdiff
path: root/questions/public/script.js
blob: e5a03d05c02dd776be47f36b4bb402bdf84b32b9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
const query = new URL(window.location.href).searchParams;
const qid = +query.get("qid") || 0;
let method = "POST";

const question_input = document.getElementById("question");
const question_label = document.getElementById("question_label");
const prev = document.getElementById("prev-btn");
const skip = document.getElementById("skip-btn");
const progress = document.getElementById("progress");
const buttons = document.querySelectorAll(".answer-btn");

skip.addEventListener("click", () => getNext(qid + 1));
prev.addEventListener("click", () => getNext(qid - 1));

if (qid === 0) {
    prev.style.display = "none";
    skip.style.width = "100%";
}

fetch(`api/question/${qid}`)
    .then((response) => response.json())
    .then((response) => {
        if (!response.empty()) {
            question_label.innerText = response["question"];
            question_input.setAttribute("value", response["id"]);
            if (response.answer !== undefined) {
                method = "PUT";
            }
            document.querySelector(`.answer-btn[data-value="${response.answer}"]`).style.opacity = "0.5";
        } else getNext(); // Resets
    });

fetch(`api/questions`)
    .then((response) => response.json())
    .then((response) => {
        for (const elem of response) {
            progress.insertAdjacentHTML(
                "beforeend",
                `<div data-current="${+elem.id === qid}" data-answered="${elem.answered}">${elem.id + 1}</div>`,
            );
        }
    })
    .then(() => {
        document.querySelectorAll("div.bar div").forEach((elem) => {
            elem.addEventListener("click", () => {
                getNext(+elem.innerText - 1);
            });
        });
    });

function getNext(q = 0) {
    window.location.assign(`/questions/?qid=${q}`);
}

// I did this myself lel
Object.prototype.empty = function () {
    return Object.keys(this).length === 0;
};

NodeList.prototype.on = function (listener, event) {
    for (const node of this) {
        node.addEventListener(listener, event);
    }
}

buttons.on("click", async (e) => {
    const body = JSON.stringify({
        question: question_input.value,
        answer: e.target.dataset.value === "1",
    });
    const resp = await fetch(`api/answer`, {
        method,
        headers: { "Content-Type": "application/json" },
        body,
    });
    const res = await resp.json();
    if (res.success) {
        method = "PUT";
        getNext(qid);
        // document.querySelector(`.answer-btn[data-value="${e.target.dataset.value}"]`).style.opacity = "0.5";
        // document.querySelector(`.answer-btn[data-value="${+!+e.target.dataset.value}"]`).style.opacity = "1"; // Let's not talk about it
    }
});