UNPKG

handsontable

Version:

Handsontable is a JavaScript Spreadsheet Component available for React, Angular and Vue.

78 lines (67 loc) 2.39 kB
import "core-js/modules/es.regexp.exec.js"; import "core-js/modules/es.string.search.js"; import moment from 'moment'; import { getEditorInstance } from "../../editors/registry.mjs"; import { EDITOR_TYPE as DATE_EDITOR_TYPE } from "../../editors/dateEditor/index.mjs"; import { getNormalizedDate } from "../../helpers/date.mjs"; export var VALIDATOR_TYPE = 'date'; /** * The Date cell validator. * * @private * @param {*} value Value of edited cell. * @param {Function} callback Callback called with validation result. */ export function dateValidator(value, callback) { var dateEditor = getEditorInstance(DATE_EDITOR_TYPE, this.instance); var valueToValidate = value; var valid = true; if (valueToValidate === null || valueToValidate === void 0) { valueToValidate = ''; } var isValidFormat = moment(valueToValidate, this.dateFormat || dateEditor.defaultDateFormat, true).isValid(); var isValidDate = moment(new Date(valueToValidate)).isValid() || isValidFormat; if (this.allowEmpty && valueToValidate === '') { isValidDate = true; isValidFormat = true; } if (!isValidDate) { valid = false; } if (!isValidDate && isValidFormat) { valid = true; } if (isValidDate && !isValidFormat) { if (this.correctFormat === true) { // if format correction is enabled var correctedValue = correctFormat(valueToValidate, this.dateFormat); var row = this.instance.toVisualRow(this.row); var column = this.instance.toVisualColumn(this.col); this.instance.setDataAtCell(row, column, correctedValue, 'dateValidator'); valid = true; } else { valid = false; } } callback(valid); } dateValidator.VALIDATOR_TYPE = VALIDATOR_TYPE; /** * Format the given string using moment.js' format feature. * * @param {string} value The value to format. * @param {string} dateFormat The date pattern to format to. * @returns {string} */ export function correctFormat(value, dateFormat) { var dateFromDate = moment(getNormalizedDate(value)); var dateFromMoment = moment(value, dateFormat); var isAlphanumeric = value.search(/[A-z]/g) > -1; var date; if (dateFromDate.isValid() && dateFromDate.format('x') === dateFromMoment.format('x') || !dateFromMoment.isValid() || isAlphanumeric) { date = dateFromDate; } else { date = dateFromMoment; } return date.format(dateFormat); }