Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/itsmepetrov/redux-entities
Higher-order reducer for store entities received from normalizr and makes it easy to handle them.
https://github.com/itsmepetrov/redux-entities
normalizr reducer reducers redux redux-entities
Last synced: 2 months ago
JSON representation
Higher-order reducer for store entities received from normalizr and makes it easy to handle them.
- Host: GitHub
- URL: https://github.com/itsmepetrov/redux-entities
- Owner: itsmepetrov
- License: mit
- Created: 2015-10-28T08:18:53.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2017-11-17T14:31:40.000Z (about 7 years ago)
- Last Synced: 2024-01-25T10:01:07.677Z (12 months ago)
- Topics: normalizr, reducer, reducers, redux, redux-entities
- Language: JavaScript
- Homepage:
- Size: 6.84 KB
- Stars: 33
- Watchers: 4
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Redux Entities
[![build status](https://img.shields.io/travis/itsmepetrov/redux-entities/master.svg?style=flat-square)](https://travis-ci.org/itsmepetrov/redux-entities)
[![npm version](https://img.shields.io/npm/v/redux-entities.svg?style=flat-square)](https://www.npmjs.com/package/redux-entities)Higher-order reducer for store entities received from [normalizr](https://github.com/paularmstrong/normalizr) and makes it easy to handle them.
### Installation
```
npm install --save redux-entities
```## Usage
### Use with `entitiesReducer`
```js
import { combineReducers } from 'redux';
import { entitiesReducer } from 'redux-entities';
import { merge, omit } from 'lodash';function contacts(state = {}, action) {
const { type, payload } = action;switch (type) {
case UPDATE_CONTACT:
case REMOVE_CONTACT:
return merge({}, state, { [payload.id]: {
...state[payload.id],
isPending: true
}});case UPDATE_CONTACT_SUCCESS:
return merge({}, state, { [payload.id]: {
...state[payload.id],
isPending: false
}});case REMOVE_CONTACT_SUCCESS:
return omit(state, meta.id);default:
return state;
}
}export default combineReducers({
contacts: entitiesReducer(contacts, 'contacts')
});```
### Use with `combineEntitiesReducers`
```js
import { combineEntitiesReducers } from 'redux-entities';
import { contacts, groups, images, notes } from './entities';export default combineEntitiesReducers({
contacts,
groups,
images,
notes
});```
## Immutable
If you want to use `Immutable` with `Redux` please check out this version of the library: [redux-entities-immutable](https://github.com/beautyfree/redux-entities-immutable)