redux-select-entities
data:image/s3,"s3://crabby-images/61f4a/61f4adc643584ce71282651c7cb3aad432b9cd61" alt="npm"
Light abstraction over normalizr and reselect to handle normalized entities, using higher-order-reducers.
Getting Started
Install redux-select-entities
via npm:
$ npm install --save redux-select-entities
First, you'll want to create a reducer for one of your entities.
import { entityReducer } from 'redux-select-entities';
const todoReducer = (state, action) => {
};
const enhancedTodoReducer = entityReducer(todoReducer, options);
You can then, instead of using redux
's combineReducers
at the root of your reducers, use combineReducersWithEntities
. It takes two parameters, first your entities reducers, and then your usual reducers.
import { createStore } from 'redux';
import { combineReducersWithEntities } from 'redux-select-entities';
const appReducer = combineReducersWithEntities(
{
todo: enhancedTodoReducer,
},
{
auth: authReducer,
layout: layoutReducer,
},
);
const store = createStore(
reducer,
);
You now have a state which has the following shape:
{
entities: {
todo: {}
},
auth: authState,
layout: layoutState,
}
Usage
The most important part of the API is done by the entityReducer
higher-order reducer. It takes a reducer and an optional option parameter (without any options, the higher-order reducer won't do anything for you beside initializing the state).
const todoReducer = (state, action) => {
switch action.type: {
case DELETE_TODO: {
const {todoId} = action.payload;
const newState = Object.assign({}, state);
delete newState[todoId];
return newState;
}
}
};
const enhancedTodoReducer = entitiesReducer(
todoReducer,
{
actionTypes: ['GET_TODO'],
},
);
const newState = enhancedTodoReducer(
state,
{
type: 'GET_TODO',
payload: {
entities: {
1: {
id: 1,
content: 'be amazing',
},
},
},
},
)
('todo');
The enhanced reducer automatically normalized the todos for you, by returning a map containing the todos:
console.log(newState);
{
1: { id: 1, content: 'be amazing' }
}
| Name | Type | Description |
|:---|:---|:---:|:---|
|actionTypes
|Array<string >
|The list of the actions where the reducer should search the normalized entities|
|revive
|function||
|merger
|function||