Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

cancelbl

Package Overview
Dependencies
Maintainers
1
Versions
2
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

cancelbl

Yet another make-cancelable Promise wrapper

  • 1.0.1
  • latest
  • Source
  • npm
  • Socket score

Version published
Maintainers
1
Created
Source

cancelbl

Yet another cancelable Promise wrapper, inspired by this article from React blog.

Installation

# npm
npm install cancelbl

# yarn
yarn add cancelbl

Or you can copy-paste it from here if ES6 sounds good to you.

Overview

For React components, that use fetch to update the state, unmounting can lead to the following issue:

setState(…): Can only update a mounted or mounting component. This usually means you called setState() on an unmounted component. This is a no-op

The correct way to fix this issue, according to the article, is to cancel any callbacks in componentWillUnmount, prior to unmounting. Suggested makeCancelable wraps target promise and returns cancel() function, which can be called in componentWillUnmount.

The advantage of this implementation is that it wraps and handles the promise in a single statement. Check out Example section below to see how simple it is.

For complete specification, see cancelbl.test.js.

Usage: React component

A typical example of two subsequent fetches without taking care of the method setState:

constructor()
{
  super();
  this.state = {
    item: {},
    relatedItems: {}
  };
}

componentDidMount() {
  fetchResource(this.props.url)
    .then(item => {
      this.setState({item})
      fetchRelatedResources(item)
        .then(relatedItems => {
          this.setState({item});
        })
        .catch(error => { /* handle */ })
    })
    .catch(error => { /* handle */ });
}

Let's import cancelbl:

import cancelbl from 'cancelbl';

And update the component:

constructor()
{
  super();
  this.state = {
    item: {},
    relatedItems: {}
  };
  // set initial cancel object:
  this.cancel = cancelbl.default;
}

componentDidMount() {
  // wrap promises with .make and .with:
  this.cancel = cancelbl.make(
    fetchResource(this.props.url),
    item => {
      this.setState({item});
      this.cancel.with(
        fetchRelatedResources(item),
        relatedItems => this.setState({relatedItems}),
        error => { /* handle */ }
      );
    },
    error => { /* handle */ }
  );
}

componentWillUnmount() {
  // the magic happens here:
  this.cancel.do();
}

Here we go.

Running the tests

# with npm
npm test

# with yarn
yarn test

Other implementations

Please check out react-unplug

Contributing

Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.

Versioning

SemVer is used for versioning. For the versions available, see the tags on this repository.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Credits

  • @istarkov for original makeCancelable implementation here;

Keywords

FAQs

Package last updated on 07 Aug 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc