ramda-adjunct
Version:
Ramda Adjunct is the most popular and most comprehensive set of utilities for use with Ramda, providing a variety of useful, well tested functions with excellent documentation.
42 lines (40 loc) • 1.47 kB
JavaScript
import { curry, propOr, partial, nth } from 'ramda';
import isNonNegative from './isNonNegative.js';
import isInteger from './isInteger.js';
/**
* Creates a promise which resolves/rejects after the specified milliseconds.
*
* @func delayP
* @memberOf RA
* @category Function
* @sig Number -> Promise Undefined
* @sig {timeout: Number, value: a} -> Promise a
* @param {number|Object} milliseconds number of milliseconds or options object
* @return {Promise} A Promise that is resolved/rejected with the given value (if provided) after the specified delay
* @example
*
* RA.delayP(200); //=> Promise(undefined)
* RA.delayP({ timeout: 1000, value: 'hello world' }); //=> Promise('hello world')
* RA.delayP.reject(100); //=> Promise(undefined)
* RA.delayP.reject({ timeout: 100, value: new Error('error') }); //=> Promise(Error('error'))
*/
var makeDelay = curry(function (settleFnPicker, opts) {
var timeout;
var value;
if (isInteger(opts) && isNonNegative(opts)) {
timeout = opts;
} else {
timeout = propOr(0, 'timeout', opts);
value = propOr(value, 'value', opts);
}
return new Promise(function () {
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
var settleFn = settleFnPicker(args);
setTimeout(partial(settleFn, [value]), timeout);
});
});
var delayP = makeDelay(nth(0));
delayP.reject = makeDelay(nth(1));
export default delayP;