2023-04-17 00:17:06 +02:00
|
|
|
document.addEventListener('DOMContentLoaded', () => {
|
2023-05-11 15:16:05 +02:00
|
|
|
let elems = Array.from(document.getElementsByClassName("toggle-button"));
|
|
|
|
for (let elem of elems) {
|
|
|
|
elem.addEventListener('click', () => {
|
|
|
|
registerDomSetting(elem as HTMLElement)
|
|
|
|
})
|
|
|
|
}
|
2023-04-17 00:17:06 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
const setSetting = (key: string, value: string) => {
|
|
|
|
const data = new URLSearchParams();
|
|
|
|
data.append('key', key);
|
|
|
|
data.append('value', value);
|
|
|
|
data.append('_csrf', ((document.getElementsByName('_csrf')[0] as HTMLInputElement).value));
|
2023-06-07 20:50:30 +02:00
|
|
|
return fetch('/admin-panel/set-config', {
|
2023-04-17 00:17:06 +02:00
|
|
|
method: 'PUT',
|
|
|
|
credentials: 'same-origin',
|
|
|
|
body: data,
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2023-05-11 15:16:05 +02:00
|
|
|
const registerDomSetting = (el: HTMLElement) => {
|
|
|
|
// @ts-ignore
|
|
|
|
el.dataset["bool"] = !(el.dataset["bool"] === 'true');
|
|
|
|
setSetting(el.id, el.dataset["bool"] === 'true' ? '1' : '0')
|
|
|
|
.then(() => {
|
|
|
|
el.classList.toggle("bg-primary-600");
|
2023-05-27 13:58:08 +02:00
|
|
|
el.classList.toggle("dark:bg-gray-400");
|
|
|
|
el.classList.toggle("bg-gray-300");
|
2023-05-11 15:16:05 +02:00
|
|
|
(el.childNodes.item(1) as HTMLElement).classList.toggle("translate-x-5");
|
|
|
|
});
|
2023-04-17 00:17:06 +02:00
|
|
|
};
|
|
|
|
|