migrated darkMode feature to js bundle
This commit is contained in:
parent
67c1f520d8
commit
28fbd7d906
10 changed files with 92 additions and 5565 deletions
22
assets/scripts/features/darkmode/darkreader.js
Normal file
22
assets/scripts/features/darkmode/darkreader.js
Normal 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 };
|
58
assets/scripts/features/darkmode/index.js
Normal file
58
assets/scripts/features/darkmode/index.js
Normal 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);
|
||||
});
|
||||
});
|
||||
});
|
|
@ -5,3 +5,7 @@ if (process.env.FEATURE_VIDEOPLAYER) {
|
|||
if (process.env.FEATURE_TOC) {
|
||||
import('./toc');
|
||||
}
|
||||
|
||||
if (process.env.FEATURE_DARKMODE) {
|
||||
import('./darkmode');
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue