Skip to content

Library to inject and eject reducers asynchronous to allow your redux store to grow / reduce dynamically

License

Notifications You must be signed in to change notification settings

seanjyjy/React-Inject-Reducer

Repository files navigation

React Inject Reducer

GitHub license PRs Welcome npm

Library to inject and eject reducers asynchronous to allow your redux store to grow / reduce dynamically.


Install

If you are using yarn

$ yarn add react-inject-reducer

If you are using npm

$ npm install react-inject-reducer

Example Usage

Creating Store

initializeStore uses createStore from redux. It has the same argument syntax as createStore.
Note: It is important use initializeStore rather than createStore if we want initial reducer which was used to create the store to remain in the store if injectReducer or ejectReducer is being used.

import { initializeStore } from 'react-inject-reducer';
import { composeWithDevTools } from 'redux-devtools-extension';

import initialReducer from './initialReducer';

const StoreDemo = initializeStore({ initialReducer }, composeWithDevTools());

Using Context Method

import { InjectReducerProvider, useInjectReducer } from 'react-inject-reducer';

const Component = () => {
  const { injectReducer, ejectReducer } = useInjectReducer();

  React.useEffect(() => {
    injectReducer({ reducer1 });

    return () => {
      ejectReducer({ reducer1 });
    };
  }, []);
};

const InjectedComponent = () => {
  return (
    <InjectReducerProvider>
      <Component />
    </InjectReducerProvider>
  );
};

export default InjectedComponent;

Using HOC way

import { withInjectReducer } from 'react-inject-reducer';

const Component = props => {
  const { injectReducer, ejectReducer } = props;

  React.useEffect(() => {
    injectReducer({ reducer1 });

    return () => {
      ejectReducer({ reducer1 });
    };
  }, []);
};

const InjectedComponent = withInjectReducer(Component);
export default InjectedComponent;

Demo

  1. Notice that going between different routes, we can inject and eject the reducers dynamically
  2. The initialReducer which was created at the start will remain if it is not being ejected
Screen.Recording.2021-12-17.at.12.18.22.AM.mov

Development

yarn run build

About

Library to inject and eject reducers asynchronous to allow your redux store to grow / reduce dynamically

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published