ducks-helpers

Utils for redux

Downloads in past

Stats

StarsIssuesVersionUpdatedCreatedSize
ducks-helpers
201.0.86 years ago6 years agoMinified + gzip package size for ducks-helpers in KB

Readme

ducks-helpers
Utils for ducks in redux to create action types and actions creators

Installation

``` npm i --save ducks-helpers ```

constants(namespace, actions)

constants() - generates action types names If ~ sign presents at the beginning of the string then extra sufixes will be generated: ``` //SUFFIXES
'LOADING',
'PENDING',
'SUCCESS',
'ERROR',
'FAILED',
'CANCELED'
``` How to use: ``` import {constants} from 'ducks-helpers' export const TYPE = constants('module-name/namespace',
'~ASYNC_ACTION',
'SYNC_ACTION'
) ``` Result: ``` // with ~ TYPE.ASYNCACTION === 'module-name/namespace/ASYNCACTION' TYPE.ASYNCACTIONSUCCESS === 'module-name/namespace/ASYNCACTIONSUCCESS' ... TYPE.ASYNCACTIONCANCELED === 'module-name/namespace/ASYNCACTIONCANCELED' // without ~ TYPE.SYNCACTION === 'module-name/namespace/SYNCACTION' ``` reducer.js using handleActions() from redux-actions ``` export default handleActions({
TYPE.SYNC_ACTION: (state, action) => state,
TYPE.ASYNC_ACTION: (state, action) => state,
TYPE.ASYNC_ACTION_LOADING: (state, action) => state,
//... other suffixes also is available and can be used
TYPE.ASYNC_ACTION_SUCCESS: (state, action) => state,
TYPE.ASYNC_ACTION_ERROR: (state, action) => state,
}, {}) ```

actions(types)

types is an array of constants. In case of using ~ sign at the beginning of action name it will also create action creators with suffixes syncAction, asyncAction, asyncActionLoading, asyncActionPending, asyncActionCanceled, asyncActionError, asyncActionFailed using redux-actions: ``` import {actions} from 'ducks-helpers' export const ACTION = actions(TYPE) ``` All action creators have been built now. You can use any action creators in your component. ``` // container.js import { ACTION } from '../duck' ... @connect(
...,
{
asyncAction: ACTION.asyncAction
}
) ... componentWillMount(){
this.props.asyncAction()
} ... ```