context-hook-provider
v1.0.3
Published
A pattern proposal to move away from connect using hooks
Downloads
10
Maintainers
Readme
context-hook-provider
A pattern proposal.
The aim is to stop using connect. Instead, we should useContext
and create hooks that select from the redux store.
Demo here.
Install
As usual:
yarn add context-hook-provider
or
npm install context-hook-provider
Usage
As usual, we create a redux store and pass it to the Provider.
import React from "react";
import ReactDOM from "react-dom";
import { createStore } from "redux";
import { Provider } from "context-hook-provider";
// using createStore directly from redux
const store = createStore(reducer); // the regular redux store
ReactDOM.render(
<Provider store={store}>
<App />
</Provider>,
document.getElementById("root")
);
Where Provider is:
import React, { createContext, useState, useEffect } from "react";
// create a Context
export const State = createContext();
export function Provider({ store, children }) {
const [state, updateState] = useState(store.getState());
const listener = () => updateState(store.getState());
useEffect(() => {
const unsub = store.subscribe(listener);
return () => unsub();
}, []);
return (
<State.Provider value={{ state, dispatch: store.dispatch }}>
{children}
</State.Provider>
);
}
Then we can easily consume the state. Say for example that <App>
, has a child called <Counter>
.
import React, { useContext } from "react";
import { State } from "context-hook-provider";
export function Counter() {
const {
state: { count }
} = useContext(State);
return <div>{count}</div>;
}
Furthermore, you can make a hook on the count
.
import { useContext } from "react";
export function useCount() {
const { state } = useContext(State);
return state.count;
}
And re-do the Counter.
import React from "react";
import useCount from "./";
export function Counter() {
const count = useCount();
return <div>{count}</div>;
}