adding appearance toggle (light/dark mode)
This commit is contained in:
@@ -63,6 +63,35 @@ export default function RootLayout({
|
||||
}: Readonly<{ children: React.ReactNode }>) {
|
||||
return (
|
||||
<html lang="en-GB" suppressHydrationWarning>
|
||||
<head>
|
||||
<script
|
||||
dangerouslySetInnerHTML={{
|
||||
__html: `
|
||||
(function () {
|
||||
var key = "novarix-theme";
|
||||
var root = document.documentElement;
|
||||
var theme = "light";
|
||||
|
||||
try {
|
||||
var saved = window.localStorage.getItem(key);
|
||||
if (saved === "light" || saved === "dark") {
|
||||
theme = saved;
|
||||
} else if (window.matchMedia("(prefers-color-scheme: dark)").matches) {
|
||||
theme = "dark";
|
||||
}
|
||||
} catch (error) {
|
||||
if (window.matchMedia("(prefers-color-scheme: dark)").matches) {
|
||||
theme = "dark";
|
||||
}
|
||||
}
|
||||
|
||||
root.dataset.theme = theme;
|
||||
root.style.colorScheme = theme;
|
||||
})();
|
||||
`,
|
||||
}}
|
||||
/>
|
||||
</head>
|
||||
<body>
|
||||
{children}
|
||||
<CookieBanner />
|
||||
|
||||
Reference in New Issue
Block a user