import { bind, curryN } from 'ramda';
import isFunction from './isFunction';
import ponyfill from './internal/ponyfills/Number.isSafeInteger';
export const isSafeIntegerPonyfill = curryN(1, ponyfill);
/**
* Checks whether the passed value is a safe `integer`.
*
* @func isSafeInteger
* @memberOf RA
* @since {@link https://char0n.github.io/ramda-adjunct/2.22.0|v2.22.0}
* @category Type
* @sig * -> Boolean
* @param {*} val The value to test
* @return {boolean}
* @example
*
* RA.isSafeInteger(3); //=> true
* RA.isSafeInteger(Math.pow(2, 53)) //=> false
* RA.isSafeInteger(Math.pow(2, 53) - 1); //=> true
* RA.isSafeInteger(NaN); //=> false
* RA.isSafeInteger(Infinity); //=> false
* RA.isSafeInteger('3') //=> false
* RA.isSafeInteger(3.1); //=> false
* RA.isSafeInteger(3.0); //=> true
* RA.isSafeInteger('string'); //=> false
* RA.isSafeInteger(null); //=> false
* RA.isSafeInteger(undefined); //=> false
* RA.isSafeInteger({}); //=> false
* RA.isSafeInteger(() => { }); //=> false
* RA.isSafeInteger(true); //=> false
*/
const isSafeInteger = isFunction(Number.isSafeInteger)
? curryN(1, bind(Number.isSafeInteger, Number))
: isSafeIntegerPonyfill;
export default isSafeInteger;