aboutsummaryrefslogtreecommitdiff
path: root/questions/public/script.js
diff options
context:
space:
mode:
authorLarsVomMars2021-01-26 11:57:48 +0100
committerLarsVomMars2021-01-26 11:57:48 +0100
commit40035bd9cea21c4173f6727ba54d94f4fde44a9c (patch)
tree88a24abf9be3c223db117cb1402cf38161e01fdc /questions/public/script.js
parent9fac4d9823f3350c22b156450cba6cc456ed960f (diff)
Questions update
Diffstat (limited to 'questions/public/script.js')
-rw-r--r--questions/public/script.js46
1 files changed, 27 insertions, 19 deletions
diff --git a/questions/public/script.js b/questions/public/script.js
index aaeac00..2a04a02 100644
--- a/questions/public/script.js
+++ b/questions/public/script.js
@@ -7,7 +7,6 @@ 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));
@@ -23,10 +22,21 @@ fetch(`api/question/${qid}`)
if (!response.empty()) {
question_label.innerText = response["question"];
question_input.setAttribute("value", response["id"]);
+ const div = document.getElementsByClassName("answer-buttons")[0];
+ const prop = 100 / response.options.length;
+ for (const option of response.options) {
+ const btn = document.createElement("btn");
+ btn.classList.add("pure-button", "pure-button-primary", "answer-btn");
+ btn.dataset.value = `${option.id}`;
+ btn.textContent = option.answer_option;
+ btn.style.width = `${prop}%`;
+ div.append(btn);
+ }
+ addListeners();
if (response.answer !== undefined) {
method = "PUT";
+ document.querySelector(`.answer-btn[data-value="${response.answer}"]`).style.opacity = "0.5";
}
- document.querySelector(`.answer-btn[data-value="${response.answer}"]`).style.opacity = "0.5";
} else getNext(); // Resets
});
@@ -63,21 +73,19 @@ NodeList.prototype.on = function (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,
+function addListeners() {
+ const buttons = document.querySelectorAll(".answer-btn");
+ buttons.on("click", async (e) => {
+ const body = JSON.stringify({
+ question: question_input.value,
+ answer: e.target.dataset.value,
+ });
+ const resp = await fetch("api/answer", {
+ method,
+ headers: { "Content-Type": "application/json" },
+ body,
+ });
+ const res = await resp.json();
+ if (res.success) getNext(qid + 1);
});
- const res = await resp.json();
- if (res.success) {
- method = "PUT";
- getNext(qid + 1);
- // 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
- }
-});
+} \ No newline at end of file