/redux-act-fn

Reducing the boilerplate of creating thunk actions based on redux-act

Primary LanguageJavaScriptMIT LicenseMIT

redux-act-fn Build Status

Greenkeeper badge

Reducing the boilerplate of creating thunk actions based on redux-act

Install

$ npm install --save redux-act-fn

Usage

import thunk from 'redux-thunk'
import { createStore, applyMiddleware } from 'redux';
import { createReducer } from 'redux-act';
import { createActionFn } from 'redux-act-fn'

export const login = createActionFn('login', ({idToken}) => {
    localStorage.setItem('idToken', idToken);
    return true
});

export const logout = createActionFn('logout', () => {
    localStorage.removeItem('idToken');
});

const reducer = createReducer({
    [login]: (state, {payload: {arg: {idToken}, output}}) => {
        return {
            ...state,
            isLoggedIn: output
            idToken
        };
    },
    [logout.before]: (state) => {
        return {
            ...state,
            isLoggedIn: false,
            idToken: null
        };
    }
}, {
    isLoggedIn: false,
    idToken: null
});

const store = createStore(reducer, applyMiddleware(thunk));

store.dispatch(login('qwerty'));

API

createActionFn(description, function, [options])

description

Type: string

describe the action, it will be used as a description for generated actions

function

Type: Function

The function to be executed when the action is dispatched

options

options.before
options.before.metaReducer

Type: Function
Default: () => 'BEFORE'

Transform multiple arguments as a unique metadata object. (see redux-act docs)

options.before.payloadReducer

Type: Function
Default: (arg) => arg

options.after
options.after.metaReducer

Type: Function
Default: () => 'BEFORE'

Transform multiple arguments as a unique metadata object. (see redux-act docs)

options.after.payloadReducer

Type: Function
Default: (arg) => arg

Legacy redux

In a nutshell, the following code:

export const login = createActionFn('login', ({idToken}) => {
    localStorage.setItem('idToken', idToken);
    return true
});

is equivalent to:

const loginBefore = (value) => ({
    type: 'LOGIN_BEFORE',
    payload: value
});

const loginAfter = (value) => ({
    type: 'LOGIN_AFTER',
    payload: value
});

export const login = (...args) => (dispatch, getState) => {
    dispatch(loginBefore(...args));
    const output = (({idToken}) => {
        localStorage.setItem('idToken', idToken);
        return true
    })(...args, dispatch, getState);

    const after = {
        args,
        arg: args[0],
        output,
        retuns: output // alias of `output`,
    };

    dispatch(loginAfter(after));
    return output;
};

License

MIT © Thomas Sileghem