mirror of
https://github.com/minetest/contentdb.git
synced 2025-01-25 15:31:37 +01:00
d4b1344f6a
Fixes #474
102 lines
2.6 KiB
JavaScript
102 lines
2.6 KiB
JavaScript
// @author rubenwardy
|
|
// @license magnet:?xt=urn:btih:1f739d935676111cfff4b4693e3816e664797050&dn=gpl-3.0.txt GPL-v3-or-Later
|
|
|
|
"use strict";
|
|
|
|
function getVoteCount(button) {
|
|
const badge = button.querySelector(".badge");
|
|
return badge ? parseInt(badge.textContent) : 0;
|
|
}
|
|
|
|
function setVoteCount(button, count) {
|
|
let badge = button.querySelector(".badge");
|
|
if (count == 0) {
|
|
if (badge) {
|
|
badge.remove();
|
|
}
|
|
return;
|
|
}
|
|
if (!badge) {
|
|
badge = document.createElement("span")
|
|
badge.classList.add("badge");
|
|
badge.classList.add("bg-light");
|
|
badge.classList.add("text-dark");
|
|
badge.classList.add("ms-1");
|
|
button.appendChild(badge);
|
|
}
|
|
|
|
badge.textContent = count.toString();
|
|
}
|
|
|
|
|
|
async function submitForm(form, is_helpful) {
|
|
const data = new URLSearchParams();
|
|
for (const pair of new FormData(form)) {
|
|
data.append(pair[0], pair[1]);
|
|
}
|
|
data.set("is_positive", is_helpful ? "yes" : "no");
|
|
|
|
const res = await fetch(form.getAttribute("action"), {
|
|
method: "post",
|
|
body: data,
|
|
headers: {
|
|
"Content-Type": "application/x-www-form-urlencoded",
|
|
"Accept": "application/json",
|
|
},
|
|
});
|
|
|
|
if (!res.ok) {
|
|
const json = await res.json();
|
|
alert(json.error ?? "Unknown server error");
|
|
}
|
|
}
|
|
|
|
|
|
function setButtonSelected(ele, isSelected) {
|
|
if (isSelected) {
|
|
ele.classList.add("btn-primary");
|
|
ele.classList.remove("btn-secondary");
|
|
} else {
|
|
ele.classList.add("btn-secondary");
|
|
ele.classList.remove("btn-primary");
|
|
}
|
|
}
|
|
|
|
|
|
window.addEventListener("load", () => {
|
|
document.querySelectorAll(".review-helpful-vote").forEach((helpful_form) => {
|
|
const yes = helpful_form.querySelector("button[name='is_positive'][value='yes']");
|
|
const no = helpful_form.querySelector("button[name='is_positive'][value='no']");
|
|
|
|
function setVote(is_helpful) {
|
|
const selected = is_helpful ? yes : no;
|
|
const not_selected = is_helpful ? no : yes;
|
|
|
|
if (not_selected.classList.contains("btn-primary")) {
|
|
setVoteCount(not_selected, Math.max(getVoteCount(not_selected) - 1, 0));
|
|
setButtonSelected(not_selected, false);
|
|
}
|
|
|
|
if (selected.classList.contains("btn-secondary")) {
|
|
setVoteCount(selected, getVoteCount(selected) + 1);
|
|
setButtonSelected(selected, true);
|
|
} else if (selected.classList.contains("btn-primary")) {
|
|
setVoteCount(selected, Math.max(getVoteCount(selected) - 1, 0));
|
|
setButtonSelected(selected, false);
|
|
}
|
|
|
|
submitForm(helpful_form, is_helpful).catch(console.error);
|
|
}
|
|
|
|
yes.addEventListener("click", (e) => {
|
|
setVote(true);
|
|
e.preventDefault();
|
|
});
|
|
|
|
no.addEventListener("click", (e) => {
|
|
setVote(false)
|
|
e.preventDefault();
|
|
});
|
|
});
|
|
});
|