Anonymous

MediaWiki:Common.js: Difference between revisions

From Melvor Idle
Amend dark mode code
No edit summary
(Amend dark mode code)
(15 intermediate revisions by 2 users not shown)
Line 544: Line 544:
   }
   }
}
}
function toggleDarkMode() {
document.body.classList.toggle('darkMode');
localStorage.setItem('darkMode', localStorage.getItem('darkMode') !== 'true');
}
$(document).ready(function () {
$(document).ready(function () {
if (document.getElementsByClassName("stickyHeader").length > 0) {
if (document.getElementsByClassName('stickyHeader').length > 0) {
setStickyHeaderTop();
setStickyHeaderTop();
$(window).resize(setStickyHeaderTop);
$(window).resize(setStickyHeaderTop);
}
}
});
function setItem(key, value) {
localStorage.setItem(key, JSON.stringify(value));
}


function getItem(key) {
const darkMode = localStorage.getItem('darkMode');
let keydata = localStorage.getItem(key);
if (darkMode === 'true') {
if (keydata == "undefined") return undefined;
document.body.classList.add('darkMode');
return JSON.parse(keydata);
}
function toggleDarkMode() {
const darkMode = getItem("darkMode");
if (darkMode !== true) {
setItem("darkMode", true);
document.body.classList.add("darkMode");
} else {
} else {
setItem("darkMode", false);
document.body.classList.remove('darkMode');
document.body.classList.remove("darkMode");
}
}
}
});
 
// Add dark mode links to "Wiki tools" and personal tools menus
$.when(mw.loader.using(['mediawiki.util']), $.ready).then( function() {
var dmLinkTools = mw.util.addPortletLink('p-tb', '#', 'Dark mode', 't-darkmode', 'Toggle between a dark and light theme', null, '#t-specialpages');
var dmLinkPersonal = mw.util.addPortletLink('p-personal', '#', 'Dark mode', 'pt-darkmode', 'Toggle between a dark and light theme', null, null);
dmLinkPersonal.style.marginTop = '0.5rem';
$(dmLinkTools).on('click', function(e) {
e.preventDefault();
toggleDarkMode();
});
$(dmLinkPersonal).on('click', function(e) {
e.preventDefault();
toggleDarkMode();
});
} );