'use strict';
const { EachLimit } = require('./eachLimit');
const { setLimit } = require('./internal/collection');
class FindLimit extends EachLimit {
constructor(collection, limit, iterator) {
super(collection, limit, iterator, set);
}
}
module.exports = { findLimit, FindLimit };
function set(collection) {
setLimit.call(this, collection);
this._callResolve = this._keys === undefined ? callResolveArray : callResolveObject;
return this;
}
function callResolveArray(value, index) {
if (value) {
this._callRest = 0;
this._promise._resolve(this._coll[index]);
} else if (--this._rest === 0) {
this._promise._resolve();
} else if (this._callRest-- > 0) {
this._iterate();
}
}
function callResolveObject(value, index) {
if (value) {
this._callRest = 0;
this._promise._resolve(this._coll[this._keys[index]]);
} else if (--this._rest === 0) {
this._promise._resolve();
} else if (this._callRest-- > 0) {
this._iterate();
}
}
/**
* `Aigle.findLimit` is almost the as [`Aigle.find`](https://suguru03.github.io/aigle/docs/Aigle.html#find) and
* [`Aigle.findSeries`](https://suguru03.github.io/aigle/docs/Aigle.html#findSeries), but it will work with concurrency.
* @param {Array|Object} collection
* @param {integer} [limit=8]
* @param {Function} iterator
* @return {Aigle} Returns an Aigle instance
* @example
* const order = [];
* const collection = [1, 5, 3, 4, 2];
* const iterator = (num, index) => {
* return Aigle.delay(num * 10)
* .then(() => {
* order.push(num);
* return num % 2 === 0;
* });
* };
* Aigle.findLimit(collection, 2, iterator)
* .then(value => {
* console.log(value); // 2
* console.log(order); // [1, 3, 5, 2];
* });
*
* @example
* const order = [];
* const collection = { a: 1, b: 5, c: 3, d: 4, e: 2 };
* const iterator = (num, key) => {
* return Aigle.delay(num * 10)
* .then(() => {
* order.push(num);
* return num % 2 === 0;
* });
* };
* Aigle.findLimit(collection, 2, iterator)
* .then(value => {
* console.log(value); // 2
* console.log(order); // [1, 3, 5, 2];
* });
*
* @example
* const order = [];
* const collection = [1, 5, 3, 4, 2];
* const iterator = num => {
* return Aigle.delay(num * 10)
* .then(() => {
* order.push(num);
* return num % 2 === 0;
* });
* };
* Aigle.findLimit(collection, iterator)
* .then(value => {
* console.log(value); // 2
* console.log(order); // [1, 2];
* });
*/
function findLimit(collection, limit, iterator) {
return new FindLimit(collection, limit, iterator)._execute();
}