import { createContext, useContext } from "react"; // mobx store import { RootStore } from "store/root.store"; let rootStore: RootStore = new RootStore(); export const MobxStoreContext = createContext(rootStore); const initializeStore = () => { const _rootStore: RootStore = rootStore ?? new RootStore(); if (typeof window === "undefined") return _rootStore; if (!rootStore) rootStore = _rootStore; return _rootStore; }; export const MobxStoreProvider = ({ children }: any) => { const store: RootStore = initializeStore(); return {children}; }; // hook export const useMobxStore = () => { const context = useContext(MobxStoreContext); if (context === undefined) throw new Error("useMobxStore must be used within MobxStoreProvider"); return context; };