import { complement, compose, anyPass, curryN } from 'ramda'; /** * Takes a list of predicates and returns a predicate that returns true for a given list of * arguments if none of the provided predicates are satisfied by those arguments. It is the * complement of Ramda's anyPass. * * The function returned is a curried function whose arity matches that of the * highest-arity predicate. * * @func nonePass * @memberOf RA * @since {@link https://char0n.github.io/ramda-adjunct/2.5.0|v2.5.0} * @category Logic * @sig [(*... -> Boolean)] -> (*... -> Boolean) * @param {Array} predicates An array of predicates to check * @return {Function} The combined predicate * @see {@link http://ramdajs.com/docs/#anyPass|R.anyPass} * @example * * const gt10 = R.gt(R.__, 10) * const even = (x) => x % 2 === 0; * const f = RA.nonePass([gt10, even]); * * f(12); //=> false * f(8); //=> false * f(11); //=> false * f(9); //=> true */ const nonePass = curryN(1, compose(complement, anyPass)); export default nonePass;