1.0.0 • Published 1 year ago

enqueu v1.0.0

Weekly downloads
-
License
MIT
Repository
github
Last release
1 year ago

Enqueu

Promise queue for concurrency control

Installation

$ npm i enqueu

or

<script src="https://unpkg.com/enqueu@1.0.0/dist/index.js"></script>

Example

In this case you will get "hey, my name is yoann, how are you ?, bye" and without Enqueu "my name is yoann, bye, how are you ?, hey".

import Enqueu from "enqueu";

const queu = new Enqueu();

queu
  .add(() => new Promise((r) => setTimeout(r, 3000)))
  .then((_) => console.log("hey"));

queu
  .add(() => new Promise((r) => setTimeout(r, 2000)))
  .then((_) => console.log("how are you ?"));

queu
  .add(() => new Promise((r) => setTimeout(r, 1000)))
  .then((_) => console.log("bye"));

queu
  .add(() => new Promise((r) => setTimeout(r, 500)), { priority: 1 }) //from 1 to Infinity
  .then((_) => console.log("my name is Yoann"));

With event listener

For example in this case if you click 4 times at once on the button you will get "10, 5, 2.5". But without Enqueu you will get "1.25, 1.25, 1.25, 1.25".

const queu = new Enqueu({ maxSize: 3 }); //the maximum size of the queu is 3 (other will be throwed off)

let count = 20;

document.querySelector("button").addEventListener(
  "click",
  queu.createFn(function () {
    count = count / 2;
    return new Promise((r) =>
      setTimeout(function () {
        r(count);
      }, count * 1000)
    );
  })
);

Enqueu

Constructor

  • maxSize Max size of the queu
  • maxConcurrency Max promise as the same time

Attibutes

  • isPaused Return a boolean to see if the queu is paused or not
  • pending Return the number of pending functions
  • queu Return the queu

Methods

  • add(fn: Function, options: Options = {}): Function Add the function to the queu
  • createFn(fn: Function, options: Options = {}): Function Create a function that will add "fn" to the queu on call (useful for addEventListener for example)
  • pause() Pause the queu
  • start() Start the queu after a pause
  • onEmpty(fn: Function) Call the function passed as argument when the queu is empty
  • onQueuElementExecuted(fn: Function) Call the function passed as argument when the a new queu function is started
  • onQueuElementFinishExecution(fn: Function) Call the function passed as argument when the a new queu function which started is finished
  • clear() Clear the queu
  • remove(fn: Function) Remove a function from the queu
  • removeFromIndex(index: number) Remove a specified indexed element in the queu