/react-promise-wrapper

React HOC to map promises to props

Primary LanguageJavaScript

React promise wrapper.

Build Status

Usage

Install via NPM or Yarn

npm install --save react-promise-wrapper
yarn add react-promise-wrapper

Write a component that will receive several props :

  • loading: a boolean to indicate if promises are done.
  • error: an error thrown if any of the promises fails
  • Your promises names.
// MyComponent.js

const MyComponent = ({ loading, error, promiseData, anotherPromise }) => {
  if (loading) {
    return <span>Loading...</span>;
  }

  if (error) {
    return <span>Oups! Something went wrong</span>;
  }

  return (
    <div>
      <span>{promiseData.id}</span>
      <span>{anotherPromise}</span>
    </div>
  );
};

Then write a wrapper that will inject the promises thanks to the withPromises helper.

withPromises take an object as a first argument. This object's keys are the name of the props that will be injected into the wrapped component and their values are the promises that are to be resolved.

// WithPromiseComponent.js

// import the lib
import withPromises from 'react-promise-wrapper';

// import your component
import MyComponent from './MyComponent';

const WrappedComponent = withPromises({
  // `promiseData` will be injected as prop into MyComponent
  // when all promises will be resolved.
  promiseData: fetch('/data').then(res => res.json()),

  // Same for `anotherPromiseData`
  anotherPromiseData: Promise.resolve('random data'),
})(MyComponent);

You can also pass a function to withPromise, so that you are able to fetch multiple times as the component is updated. The above example would be modified to look like this:

const WrappedComponent = withPromises((props, oldProps, oldPromises) => ({
  user:
    props.id !== oldProps.id
      ? fetch(`/users/${props.id}`).then(res => res.json())
      : oldPromises.user,

  anotherPromiseData: Promise.resolve('random data'),
}))(MyComponent);