mirror of https://gitgud.io/fatchan/jschan.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
61 lines
1.9 KiB
61 lines
1.9 KiB
function changeTheme(e) {
|
|
//is this the initial load, or an event from changing theme dropdown
|
|
var theme = e ? this.value : localStorage.getItem('theme');
|
|
//first visit, set theme to default
|
|
if (!theme) {
|
|
theme = 'default';
|
|
}
|
|
//add theme setting to localstorage
|
|
localStorage.setItem('theme', theme);
|
|
//check for theme style tag
|
|
var tempLink = document.getElementById('customtheme');
|
|
if (theme === 'default') {
|
|
if (tempLink) {
|
|
//remove theme style tag if we switching to default
|
|
tempLink.remove();
|
|
}
|
|
} else {
|
|
//path of the theme css
|
|
var path = '/css/themes/'+theme+'.css';
|
|
//get the raw css from localstorage
|
|
var css = localStorage.getItem(path);
|
|
if (!tempLink) {
|
|
//create the style tag if it doesnt exist
|
|
tempLink = document.createElement('style');
|
|
document.head.appendChild(tempLink);
|
|
}
|
|
if (css) {
|
|
//if we have the css in localstorage, set it (prevents FOUC)
|
|
tempLink.innerHTML = css;
|
|
}
|
|
//then createa new link rel=stylesheet, and load the css
|
|
var themeLink = document.createElement('link');
|
|
themeLink.rel = 'stylesheet';
|
|
themeLink.id = 'customtheme';
|
|
themeLink.onload = function() {
|
|
css = '';
|
|
var rulesName = themeLink.sheet.rules != null ? 'rules' : 'cssRules'; //browser compatibility shit
|
|
for(var i = 0; i < themeLink.sheet[rulesName].length; i++) {
|
|
css += themeLink.sheet[rulesName][i].cssText;
|
|
}
|
|
//update our localstorage with latest version
|
|
localStorage.setItem(path, css);
|
|
tempLink.innerHTML = css;
|
|
//immediately remove it since we dont need it
|
|
tempLink.remove();
|
|
}
|
|
themeLink.href = path;
|
|
document.head.appendChild(themeLink);
|
|
}
|
|
}
|
|
|
|
changeTheme();
|
|
|
|
window.addEventListener('DOMContentLoaded', (event) => {
|
|
|
|
var themePicker = document.getElementById('theme-changer');
|
|
themePicker.value = localStorage.getItem('theme')
|
|
|
|
themePicker.addEventListener('change', changeTheme, false);
|
|
|
|
});
|
|
|