import { ReactReduxContext } from '../components/Context'; import { useReduxContext as useDefaultReduxContext, createReduxContextHook } from './useReduxContext'; /** * Hook factory, which creates a `useStore` hook bound to a given context. * * @param {React.Context} [context=ReactReduxContext] Context passed to your ``. * @returns {Function} A `useStore` hook bound to the specified context. */ export function createStoreHook(context = ReactReduxContext) { const useReduxContext = // @ts-ignore context === ReactReduxContext ? useDefaultReduxContext : // @ts-ignore createReduxContextHook(context); return function useStore() { const { store } = useReduxContext(); // @ts-ignore return store; }; } /** * A hook to access the redux store. * * @returns {any} the redux store * * @example * * import React from 'react' * import { useStore } from 'react-redux' * * export const ExampleComponent = () => { * const store = useStore() * return
{store.getState()}
* } */ export const useStore = /*#__PURE__*/createStoreHook();