/resolve-promise-middleware

Redux middleware to return the resolved value of an async action's payload when using `redux-promise-middleware`.

Primary LanguageJavaScript

Resolve Promise Middleware

resolve-promise-middleware combined with redux-promise-middleware allows to use the resolved value of an async payload without accessing the store.

Install

$ npm install resolve-promise-middleware --save

Setup

Apply it before promiseMiddleware

import promiseMiddleware from 'redux-promise-middleware';
import { resolvePromiseMiddleware } from "resolve-promise-middleware";

composeStoreWithMiddleware = applyMiddleware(
    resolvePromiseMiddleware
    promiseMiddleware(),
)(createStore)

Usage

action.js

const asyncAction = () => ({
  type: 'PROMISE',
  payload: new Promise(...)
})

component.js

getDogs().then(dogs => this.dogs = dogs);

service.js

getDogs() {
    return store.dispatch(asyncAction)
        .catch(handleError)