"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = isValid; var _index = _interopRequireDefault(require("../isDate/index.js")); var _index2 = _interopRequireDefault(require("../toDate/index.js")); var _index3 = _interopRequireDefault(require("../_lib/requiredArgs/index.js")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } /** * @name isValid * @category Common Helpers * @summary Is the given date valid? * * @description * Returns false if argument is Invalid Date and true otherwise. * Argument is converted to Date using `toDate`. See [toDate]{@link https://date-fns.org/docs/toDate} * Invalid Date is a Date, whose time value is NaN. * * Time value of Date: http://es5.github.io/#x15.9.1.1 * * @param {*} date - the date to check * @returns {Boolean} the date is valid * @throws {TypeError} 1 argument required * * @example * // For the valid date: * const result = isValid(new Date(2014, 1, 31)) * //=> true * * @example * // For the value, convertable into a date: * const result = isValid(1393804800000) * //=> true * * @example * // For the invalid date: * const result = isValid(new Date('')) * //=> false */ function isValid(dirtyDate) { (0, _index3.default)(1, arguments); if (!(0, _index.default)(dirtyDate) && typeof dirtyDate !== 'number') { return false; } var date = (0, _index2.default)(dirtyDate); return !isNaN(Number(date)); } module.exports = exports.default;