117 lines
3.3 KiB
JavaScript
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");
|
|
}
|
|
}
|
|
}
|