Skip to content

Krivega/stack-promises

Repository files navigation

stack-promises

npm npm bundle size

A stack of tasks that are executed one by one, but the result is taken from the last. Identical functions on the stack (check by reference) are executed only once.

Install

npm

npm install stack-promises

yarn

yarn add stack-promises

Usage

import creteStackPromises from 'stack-promises';

const stackPromises = creteStackPromises();

stackPromises.add(() => Promise.resolve(1));
stackPromises.add(() => Promise.resolve(2));

stackPromises().then(data => {
  console.log(data); /// 2
});

Execute after add

import creteStackPromises from 'stack-promises';

const stackPromises = creteStackPromises();

stackPromises
  .add(() => Promise.resolve(1))() // execute
  .then(data => {
    console.log(data); // 1
  });
stackPromises
  .add(() => Promise.resolve(2))() // execute
  .then(data => {
    console.log(data); // 2
  });

stackPromises().then(data => {
  console.log(data); // 2
});

Add after execute

import creteStackPromises, { isPromiseIsNotActualError } from 'stack-promises';
import delayPromise from 'promise-delay';

const stackPromises = creteStackPromises();

let checkQue = 0;
const request1 = () =>
  delayPromise(3000, 1).finally(() => {
    checkQue += 1;
  });
const resultAfter1 = stackPromises.add(request1)();

const request2 = () =>
  delayPromise(1000, 2).finally(() => {
    checkQue *= 2;
  });
const resultAfter2 = stackPromises.add(request2)();

Promise.allSettled([resultAfter1, resultAfter2]).then(([{ reason }, { value }]) => {
  isPromiseIsNotActualError(reason); // true
  value; // 2
  checkQue; // 2
  // request1 called 1 times
  // request2 called 1 times
});

Chaining

stackPromises.add(() => Promise.resolve(1)).add(() => Promise.resolve(2));

Run tests

npm test

Maintainer

Krivega Dmitriy

Contributing

Contributions, issues and feature requests are welcome!
Feel free to check issues page. You can also take a look at the contributing guide.

📝 License

Copyright © 2020 Krivega Dmitriy.
This project is MIT licensed.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages