aboutsummaryrefslogtreecommitdiffstats
path: root/packages/renderer/src/components/StoreProvider.tsx
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>
  );
}