BrickTracker/static/scripts/set.js
2025-01-17 11:03:00 +01:00

117 lines
3.3 KiB
JavaScript

// Clean a status indicator
const clean_status = (status) => {
const to_remove = Array.from(status.classList.values()).filter((name) => name.startsWith('ri-') || name.startsWith('text-') || name.startsWith('bg-'))
if (to_remove.length) {
status.classList.remove(...to_remove);
}
}
// Change the status of a set checkbox
const change_set_checkbox_status = async (el, kind, id, url) => {
const status = document.getElementById(`status-${kind}-${id}`);
try {
// Set the status to unknown
if (status) {
clean_status(status)
status.classList.add("ri-question-line", "text-warning");
}
const response = await fetch(url, {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify({
state: el.checked
})
});
if (!response.ok) {
throw new Error(`Response status: ${response.status}`);
}
const json = await response.json();
if ("error" in json) {
throw new Error(`Error received: ${json.error}`)
}
// Set the status to OK
if (status) {
clean_status(status)
status.classList.add("ri-checkbox-circle-line", "text-success");
}
// Update the card
const card = document.getElementById(`set-${id}`);
if (card) {
// Not going through dataset to avoid converting
card.setAttribute(`data-${kind}`, Number(el.checked));
}
} catch (error) {
console.log(error.message);
// Set the status to not OK
if (status) {
clean_status(status)
status.classList.add("ri-alert-line", "text-danger");
}
}
}
// Change the amount of missing parts
const change_part_missing_amount = async (el, set_id, part_id, url) => {
const status = document.getElementById(`status-part-${set_id}-${part_id}`);
try {
// Set the status to unknown
if (status) {
clean_status(status)
status.classList.add("ri-question-line", "bg-warning-subtle");
}
const response = await fetch(url, {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify({
missing: el.value
})
});
if (!response.ok) {
throw new Error(`Response status: ${response.status}`);
}
const json = await response.json();
if ("error" in json) {
throw new Error(`Error received: ${json.error}`);
}
// Set the status to OK
if (status) {
clean_status(status)
status.classList.add("ri-checkbox-circle-line", "text-success", "bg-success-subtle");
}
// Update the sort data
const sort = document.getElementById(`sort-part-${set_id}-${part_id}`);
if (sort) {
sort.dataset.sort = el.value;
}
} catch (error) {
console.log(error.message);
// Set the status to not OK
if (status) {
clean_status(status)
status.classList.add("ri-alert-line", "text-danger", "bg-danger-subtle");
}
}
}