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.
37 lines (35 loc) • 1.23 kB
JavaScript
import { isNil, curryN, curry, apply } from 'ramda';
import defaultWhen from './defaultWhen';
import mapIndexed from './mapIndexed';
/**
* Returns a function which is called with the given arguments. If any of the given arguments are null or undefined,
* the corresponding default value for that argument is used instead.
*
* @func fnull
* @memberOf RA
* @category Function
* @sig (a ... -> b) -> [c] -> a ... | c -> b
* @param {Function} function to be executed
* @param {Array} defaults default arguments
* @return {Function} will apply provided arguments or default ones
* @example
*
* const addDefaults = RA.fnull((a, b) => a + b, [4, 5])
*
* addDefaults(1, 2); // => 3
* addDefaults(null, 2); // => 6
* addDefaults(2, null); // => 7
* addDefaults(undefined, undefined); // => 9
*/
var fnull = curry(function (fn, defaults) {
return curryN(fn.length, function () {
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
var argsWithDefaults = mapIndexed(function (val, idx) {
return defaultWhen(isNil, defaults[idx], val);
}, args);
return apply(fn, argsWithDefaults);
});
});
export default fnull;