27 lines
852 B
HTML
27 lines
852 B
HTML
|
<!DOCTYPE html>
|
||
|
<html lang="{{ site.LanguageCode }}">
|
||
|
{{ partial "head.html" . }}
|
||
|
|
||
|
<body class="not-ready" data-menu="{{ isset site.Menus `main` }}">
|
||
|
{{ partial "header.html" . }}
|
||
|
|
||
|
<main class="main">{{ block "main" . }}{{ end }}</main>
|
||
|
|
||
|
{{ partial "footer.html" . }}
|
||
|
</body>
|
||
|
<script>
|
||
|
let bodyClx = document.body.classList;
|
||
|
let sysDark = window.matchMedia('(prefers-color-scheme: dark)');
|
||
|
let darkVal = localStorage.getItem('dark');
|
||
|
|
||
|
let setDark = (isDark) => {
|
||
|
bodyClx[isDark ? 'add' : 'remove']('dark');
|
||
|
localStorage.setItem('dark', isDark ? 'yes' : 'no');
|
||
|
};
|
||
|
|
||
|
setDark(darkVal ? darkVal === 'yes' : sysDark.matches);
|
||
|
requestAnimationFrame(() => bodyClx.remove('not-ready'));
|
||
|
sysDark.addEventListener('change', (event) => setDark(event.matches));
|
||
|
</script>
|
||
|
</html>
|