"use client"; // react import { useEffect } from "react"; // next theme import { useTheme } from "next-themes"; // mobx react lite import { observer } from "mobx-react-lite"; // mobx import { useMobxStore } from "lib/mobx/store-provider"; import { RootStore } from "store/root"; export const NavbarTheme = observer(() => { const store: RootStore = useMobxStore(); const { setTheme, theme } = useTheme(); const handleTheme = () => { store?.theme?.setTheme(store?.theme?.theme === "light" ? "dark" : "light"); setTheme(theme === "light" ? "dark" : "light"); document?.documentElement.setAttribute("data-theme", theme ?? store?.theme?.theme); }; useEffect(() => { document?.documentElement.setAttribute("data-theme", theme ?? store?.theme?.theme); }, [theme, store]); // TODO: check these styles return (
{theme === "light" ? ( dark_mode ) : ( light_mode )}
); });