plane/web/lib/wrappers/store-wrapper.tsx
sriram veeraghanta 3d09a69d58
fix: eslint issues and reconfiguring (#3891)
* fix: eslint fixes

---------

Co-authored-by: gurusainath <gurusainath007@gmail.com>
2024-03-06 18:39:14 +05:30

65 lines
2.0 KiB
TypeScript

import { ReactNode, useEffect, useState, FC } from "react";
import { observer } from "mobx-react-lite";
import { useRouter } from "next/router";
import { useTheme } from "next-themes";
import useSWR from "swr";
// helpers
import { applyTheme, unsetCustomCssVariables } from "helpers/theme.helper";
// hooks
import { useApplication, useUser } from "hooks/store";
interface IStoreWrapper {
children: ReactNode;
}
const StoreWrapper: FC<IStoreWrapper> = observer((props) => {
const { children } = props;
// states
const [dom, setDom] = useState<unknown>();
// router
const router = useRouter();
// store hooks
const {
config: { fetchAppConfig },
theme: { sidebarCollapsed, toggleSidebar },
router: { setQuery },
} = useApplication();
const { currentUser } = useUser();
// fetching application Config
useSWR("APP_CONFIG", () => fetchAppConfig(), { revalidateIfStale: false, revalidateOnFocus: false });
// theme
const { setTheme } = useTheme();
/**
* Sidebar collapsed fetching from local storage
*/
useEffect(() => {
const localValue = localStorage && localStorage.getItem("app_sidebar_collapsed");
const localBoolValue = localValue ? (localValue === "true" ? true : false) : false;
if (localValue && sidebarCollapsed === undefined) toggleSidebar(localBoolValue);
}, [sidebarCollapsed, currentUser, setTheme, toggleSidebar]);
/**
* Setting up the theme of the user by fetching it from local storage
*/
useEffect(() => {
if (!currentUser) return;
if (window) setDom(window.document?.querySelector<HTMLElement>("[data-theme='custom']"));
setTheme(currentUser?.theme?.theme || "system");
if (currentUser?.theme?.theme === "custom" && dom) applyTheme(currentUser?.theme?.palette, false);
else unsetCustomCssVariables();
}, [currentUser, setTheme, dom]);
useEffect(() => {
if (!router.query) return;
setQuery(router.query);
}, [router.query, setQuery]);
return <>{children}</>;
});
export default StoreWrapper;