blob: 51c39f793b7ae87825dbe8a17e5f6fd5f7ae23fc (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
import React, { createContext, useContext } from 'react';
import type { RootStore } from '../stores/RootStore';
const StoreContext = createContext<RootStore | null>(null);
export function useStore(): RootStore {
const store = useContext(StoreContext);
if (store === null) {
throw new Error('useStore can only be called inside of StoreProvider');
}
return store;
}
export function StoreProvider({ children, store }: {
children: JSX.Element | JSX.Element[],
store: RootStore,
}): JSX.Element {
return (
<StoreContext.Provider value={store}>
{children}
</StoreContext.Provider>
);
}
|