Skip to content
/ qulee Public

JavaScript library implementation of a Queue - with extra power

License

Notifications You must be signed in to change notification settings

kfirm/qulee

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

qulee

JavaScript library implementation of a queue with extra power

Usage

Using qulee is very simple. Just add the script tag with the relevant reference for qulee.js or qulee.min.js file.
Or if on Node just require the module as shown in the examples

I first found it useful to implement a situation where I wanted http calls (promises) to get executed in a synchronized fashion.

Installation

Using CDN:

<script src="https://unpkg.com/qulee/dist/qulee.min.js"></script>

Using NPM:

npm install qulee --save

Api

qulee.enqueue(item) - add an item to the queue.
qulee.dequeue() - extract an item from the queue.
qulee.clear() - clears the queue
qulee.size() - return queue size
qulee.current() - return the current/last dequeued object
qulee.archive() - archives the current/last dequeued object
qulee.lock() - locks the queue from enqueuing new objects
qulee.unlock() - un-locks the queue from enqueuing new objects
qulee.last() - returns the last object in the queue
qulee.createNamedQueue(name) - creates a new queue by name - for example you can create a new queue named 'myQueue' and call it by qulee['myQueue'];
qulee.setAllowDuplicate(isAllowed) - set if to allowed to queue the same object more than once. default is false qulee.executeOnQueue(callback,doDequeue) - execute the call back on each of the object in the queue (callback(obj)). If doDequeue is set to true, each object will be removed from queue (default is false)

Events

qulee.onQueue(callback) - Add a call back to be executed on queue event
qulee.onDequeue(callback) - Add a call back to be executed on dequeue event
qulee.onDuplicate(callback) - Add a call back to be executed on queueing a duplicated event
qulee.onLock(callback) - Add a call back to be executed when trying to queue an object when the queue is locked

Examples

Simple example:

var qulee = require('qulee');

qulee.enqueue('Hello ');
qulee.enqueue('World ');
qulee.enqueue('!');

while (qulee.dequeue()){
    console.log(qulee.current());
}
// will output:
// Hello
// World
// !

Execute callback on each item in queue:

var qulee = require('qulee');

qulee.enqueue({ value: 1 });
qulee.enqueue({ value: 2 });
qulee.enqueue({ value: 3 });

qulee.executeOnQueue(function(item){
    item.value *= 2; // multiply each value by 2
});

while (qulee.dequeue()){
    console.log(qulee.current().value);
}

// output: 2 4 6


About

JavaScript library implementation of a Queue - with extra power

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published