Skip to content

vadimuz/redux-helper

Folders and files

NameName
Last commit message
Last commit date

Latest commit

author
Vadim Kudriavtcev
Jan 19, 2019
c8140dd · Jan 19, 2019

History

9 Commits
Jan 15, 2019
Jan 15, 2019
Jan 15, 2019
Jan 15, 2019
Jan 19, 2019

Repository files navigation

Redux Helper Logo

Effortless operations with Reducers.

Motivation - make operations with redux store as simple as possible and keep data immutable.

If you currently doing update like this.

export default function example(state = initialState, action) {

      switch (action.type) {

            case UPDATE: 
              return { 
                  ...state, 
                  list: state.sections.map(item => {
                        if (item._id !== action.payload._id) {
                              return item
                        }
                        return {
                              ...item,
                              ...action.payload
                        }
                  })
            }

            default:
                  return state;

      }

}

You can do this shorter:

export default function example(state = initialState, action) {

      switch (action.type) {

            case UPDATE: 
              return { 
                  ...state, 
                  list: ReduxArrayHelper.update(state.list, action.payload)
            }

            default:
                  return state;

      }

}

And many other short operations of CRUD. More examples below.

Redux Array Helper

Installation

Copy ReduxHelper.js to your project. For example to the folder: 'src/utils/'

Importing

import { ReduxArrayHelper } from '../utils/ReduxHelper'

Methods

Method First Arguments Second Arguments Third Arguments Description
append list payload (obj) - Insert to the end of the list
prepend list payload (obj) - Insert to the end of the list
insert list payload (obj) index Insert to position of the list
update list payload (obj) (optional) comparator Update item of list by id in the payload
updateByIndex list payload (obj) index (int) Update item of list by payload
delete list payload (obj) (optional) comparator Delete item from the list by id in the payload
deleteById list payload (id) (optional) comparator Delete item from the list using payload
deleteByIndex list index (int) - Delete item from the list using payload
find list payload (obj) (optional) comparator Return the item from the list by id in the payload
findById list payload (id) (optional) comparator Return the item from the list by payload
findIndexById list payload (id) (optional) comparator Return index of item by payload

if you are using MongoDB, pass the third argument COMPORATOR as string key '_id'.

ReduxArrayHelper.update(state.list, action.payload, '_id')

Payload from action.

{
      id: 1,
      title: 'Redux the best!',
      size: 300,
}

Reducer

import {
  CREATE_BOOK,
  UPDATE_BOOK,
  DELETE_BOOK,
} from '../var/Examples'

import { ReduxArrayHelper } from '../utils/ReduxHelper'

const initialState = {
      list: [
        { id: 1, title: 'Redux awesome!'}
      ],
}

export default function examples(state = initialState, action) {

      switch (action.type) {

            case CREATE_BOOK: 
                  return { ...state, list: ReduxArrayHelper.append(state.list, action.payload) }

            case UPDATE_BOOK: 
                  return { ...state, list: ReduxArrayHelper.update(state.list, action.payload) }

            case DELETE_BOOK: 
                  return { ...state, list: ReduxArrayHelper.delete(state.list, action.payload) }

            default:
                  return state;

      }

}

About

Redux Helper - effortless operations

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published