forked from github/plane
31 lines
798 B
TypeScript
31 lines
798 B
TypeScript
|
import { createContext, useContext } from "react";
|
||
|
// mobx store
|
||
|
import { RootStore } from "store/root";
|
||
|
|
||
|
let rootStore: any = null;
|
||
|
|
||
|
export const MobxStoreContext = createContext(null);
|
||
|
|
||
|
const initializeStore = () => {
|
||
|
const _rootStore = rootStore ?? new RootStore();
|
||
|
|
||
|
if (typeof window === "undefined") return _rootStore;
|
||
|
|
||
|
if (!rootStore) rootStore = _rootStore;
|
||
|
|
||
|
return _rootStore;
|
||
|
};
|
||
|
|
||
|
export const MobxStoreProvider = ({ children }: any) => {
|
||
|
const store = initializeStore();
|
||
|
|
||
|
return <MobxStoreContext.Provider value={store}>{children}</MobxStoreContext.Provider>;
|
||
|
};
|
||
|
|
||
|
// hook
|
||
|
export const useMobxStore = () => {
|
||
|
const context = useContext(MobxStoreContext);
|
||
|
if (context === undefined) throw new Error("useMobxStore must be used within MobxStoreProvider");
|
||
|
return context;
|
||
|
};
|