react-hooks-global-state
data:image/s3,"s3://crabby-images/31391/31391e36e670717810ee34faa292ec5bc9f016fc" alt="npm version"
Simple global state for React by Hooks API
Background
React Hooks API looks promising.
This is an experimental library to use React Hooks API for global state.
Install
npm install react-hooks-global-state
Usage
setState style
import React from 'react';
import { createGlobalState } from 'react-hooks-global-state';
const initialState = { counter: 0 };
const { stateItemHooks } = createGlobalState(initialState);
const useCounter = stateItemHooks.counter;
const Counter = () => {
const [value, update] = useCounter();
return (
<div>
<span>Counter: {value}</span>
<button onClick={() => update(v => v + 1)}>+1</button>
<button onClick={() => update(v => v - 1)}>-1</button>
</div>
);
};
const App = () => (
<div>
<Counter />
<Counter />
</div>
);
reducer style
import React from 'react';
import { createStore } from 'react-hooks-global-state';
const reducer = (state, action) => {
switch (action.type) {
case: 'increment': return { ...state, counter: state.counter + 1 };
case: 'decrement': return { ...state, counter: state.counter - 1 };
default: return state;
}
};
const initialState = { counter: 0 };
const { dispatch, stateItemHooks } = createStore(reducer, initialState);
const useCounter = stateItemHooks.counter;
const Counter = () => {
const [value] = useCounter();
return (
<div>
<span>Counter: {value}</span>
<button onClick={() => dispatch({ type: 'increment' })}>+1</button>
<button onClick={() => dispatch({ type: 'decrement' })}>-1</button>
</div>
);
};
const App = () => (
<div>
<Counter />
<Counter />
</div>
);
Example
The examples folder contains a working example.
You can run it with
PORT=8080 npm run examples:minimal
and open http://localhost:8080 in your web browser.
Blogs