46 lines
1.8 KiB
JavaScript
46 lines
1.8 KiB
JavaScript
const Cookie = {
|
|
get: name => {
|
|
const c = document.cookie.match(`(?:(?:^|.*; *)${name} *= *([^;]*).*$)|^.*$`)[1];
|
|
if(c) return decodeURIComponent(c);
|
|
},
|
|
set: (name, value, opts = {}) => {
|
|
if(opts.days) {
|
|
opts['max-age'] = opts.days * 60 * 60 * 24;
|
|
delete opts.days;
|
|
}
|
|
opts = Object.entries(opts).reduce((accumulatedStr, [k, v]) => `${accumulatedStr}; ${k}=${v}`, '');
|
|
document.cookie = name + '=' + encodeURIComponent(value) + opts
|
|
}
|
|
};
|
|
|
|
(() => {
|
|
const acttheme = Cookie.get('theme') ?? "f0ck";
|
|
const themecontainer = document.querySelector("li#themes > ul.dropdown-menu");
|
|
const themes = [...themecontainer.querySelectorAll("li > a")].map(t => t.innerText.toLowerCase());
|
|
if(acttheme !== document.documentElement.getAttribute("theme") && themes.includes(acttheme))
|
|
document.documentElement.setAttribute("theme", acttheme);
|
|
[...themecontainer.querySelectorAll("li > a")].forEach(t => t.addEventListener("click", e => {
|
|
e.preventDefault();
|
|
const _theme = e.target.innerText.toLowerCase();
|
|
document.documentElement.setAttribute("theme", _theme);
|
|
document.querySelector("#themes > a").setAttribute("content", _theme);
|
|
Cookie.set("theme", _theme, { path: "/", days: 360 });
|
|
return false;
|
|
}));
|
|
|
|
document.addEventListener("keydown", e => {
|
|
const acttheme = Cookie.get('theme') ?? "f0ck";
|
|
const themes = [...themecontainer.querySelectorAll("li > a")].map(t => t.innerText.toLowerCase());
|
|
const k = e.key;
|
|
if(k === "t") {
|
|
e.preventDefault();
|
|
let i = themes.indexOf(acttheme);
|
|
if(++i >= themes.length)
|
|
i = 0;
|
|
document.documentElement.setAttribute("theme", themes[i]);
|
|
document.querySelector("#themes > a").setAttribute("content", themes[i]);
|
|
Cookie.set("theme", themes[i], { path: "/", days: 360 });
|
|
}
|
|
});
|
|
})();
|