docs/app/providers.tsx

60 lines
1.5 KiB
TypeScript
Raw Permalink Normal View History

2024-07-22 11:49:47 +02:00
"use client";
2025-04-05 03:10:36 +02:00
import { uwuifyDocument } from "@/lib/uwuify";
2024-07-22 11:49:47 +02:00
import { ThemeProvider, useTheme } from "next-themes";
import { type ReactNode, useEffect } from "react";
function ThemeWatcher() {
const { resolvedTheme, setTheme } = useTheme();
useEffect(() => {
const media = window.matchMedia("(prefers-color-scheme: dark)");
function onMediaChange() {
const systemTheme = media.matches ? "dark" : "light";
if (resolvedTheme === systemTheme) {
setTheme("system");
}
}
onMediaChange();
media.addEventListener("change", onMediaChange);
return () => {
media.removeEventListener("change", onMediaChange);
};
}, [resolvedTheme, setTheme]);
return null;
}
2025-04-05 03:10:36 +02:00
function UwuWatcher() {
// Uwuify the whole page when ctrl + u is pressed
useEffect(() => {
function onKeyDown(event: KeyboardEvent) {
if (event.key === "u" && (event.metaKey || event.ctrlKey)) {
event.preventDefault();
uwuifyDocument();
}
}
window.addEventListener("keydown", onKeyDown);
return () => {
window.removeEventListener("keydown", onKeyDown);
};
}, []);
return null;
}
2024-07-22 11:49:47 +02:00
export function Providers({ children }: { children: ReactNode }) {
return (
<ThemeProvider attribute="class" disableTransitionOnChange={true}>
<ThemeWatcher />
2025-04-05 03:10:36 +02:00
<UwuWatcher />
2024-07-22 11:49:47 +02:00
{children}
</ThemeProvider>
);
}