handsontable
Version:
Handsontable is a JavaScript Spreadsheet Component available for React, Angular and Vue.
78 lines (67 loc) • 2.39 kB
JavaScript
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);
}