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.
39 lines (32 loc) • 1.36 kB
JavaScript
exports.__esModule = true;
exports["default"] = exports.signPolyfill = void 0;
var _ramda = require("ramda");
var _isFunction = _interopRequireDefault(require("./isFunction"));
var _Math = _interopRequireDefault(require("./internal/polyfills/Math.sign"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
var signPolyfill = (0, _ramda.curryN)(1, _Math["default"]);
/**
* Returns the sign of a number, indicating whether the number is positive, negative or zero.
*
* @func sign
* @memberOf RA
* @since {@link https://char0n.github.io/ramda-adjunct/2.15.0|v2.15.0}
* @category Math
* @sig Number | String -> Number
* @param {number} number A number
* @return {number} A number representing the sign of the given argument. If the argument is a positive number, negative number, positive zero or negative zero, the function will return 1, -1, 0 or -0 respectively. Otherwise, NaN is returned
* @example
*
* RA.sign(3); // 1
* RA.sign(-3); // -1
* RA.sign('-3'); // -1
* RA.sign(0); // 0
* RA.sign(-0); // -0
* RA.sign(NaN); // NaN
* RA.sign('foo'); // NaN
*/
exports.signPolyfill = signPolyfill;
var sign = (0, _isFunction["default"])(Math.sign) ? (0, _ramda.curryN)(1, (0, _ramda.bind)(Math.sign, Math)) : signPolyfill;
var _default = sign;
exports["default"] = _default;
;