migrated darkMode feature to js bundle

This commit is contained in:
Aaron Qian 2022-11-11 13:19:44 -08:00 committed by Aaron Qian
parent 67c1f520d8
commit 28fbd7d906
No known key found for this signature in database
GPG key ID: BF1A987C395B5B0E
10 changed files with 92 additions and 5565 deletions

View file

@ -0,0 +1,22 @@
import { enable, disable, auto } from 'darkreader';
import { darkmode } from "@params";
const {
defaultColorScheme,
theme,
fixes,
} = darkmode.darkreader;
export function setSchemeDark() {
enable(theme, fixes);
}
export function setSchemeLight() {
disable();
}
export function setSchemeSystem() {
auto(theme, fixes);
}
export { defaultColorScheme };

View file

@ -0,0 +1,58 @@
const PERSISTENCE_KEY = 'darkmode:color-scheme';
async function getService() {
if(process.env.FEATURE_DARKMODE_DARKREADER) {
return await import('./darkreader');
}
}
window.addEventListener('DOMContentLoaded', async () => {
const $menu = document.getElementById('themeMenu');
const $icon = document.getElementById('navbar-theme-icon-svg');
if ($menu == null || $icon == null) return;
const $btns = $menu.getElementsByTagName('a');
const iconMap = Array.from($btns).reduce((map, $btn) => {
$img = $btn.getElementsByTagName('img')[0];
map[$btn.dataset.scheme] = $img.src;
return map;
}, {});
const {
setSchemeDark,
setSchemeLight,
setSchemeSystem,
defaultColorScheme,
} = await getService();
function loadScheme() {
return localStorage.getItem(PERSISTENCE_KEY) || defaultColorScheme;
}
function saveScheme(scheme) {
localStorage.setItem(PERSISTENCE_KEY, scheme);
}
function setScheme(newScheme) {
$icon.src = iconMap[newScheme];
if (newScheme === 'dark') {
setSchemeDark();
} else if (newScheme === 'system') {
setSchemeSystem();
} else {
setSchemeLight();
}
saveScheme(newScheme);
}
setScheme(loadScheme());
Array.from($menu.getElementsByTagName('a')).forEach(($btn) => {
$btn.addEventListener('click', () => {
const { scheme } = $btn.dataset;
setScheme(scheme);
});
});
});

View file

@ -5,3 +5,7 @@ if (process.env.FEATURE_VIDEOPLAYER) {
if (process.env.FEATURE_TOC) {
import('./toc');
}
if (process.env.FEATURE_DARKMODE) {
import('./darkmode');
}