devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
971 lines (963 loc) • 69.7 kB
JavaScript
/**
* DevExtreme (cjs/ui/grid_core/ui.grid_core.validating.js)
* Version: 21.1.4
* Build date: Mon Jun 21 2021
*
* Copyright (c) 2012 - 2021 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
"use strict";
exports.validatingModule = void 0;
var _renderer = _interopRequireDefault(require("../../core/renderer"));
var _events_engine = _interopRequireDefault(require("../../events/core/events_engine"));
var _uiGrid_core = _interopRequireDefault(require("./ui.grid_core.modules"));
var _uiGrid_core2 = _interopRequireDefault(require("./ui.grid_core.utils"));
var _array_utils = require("../../data/array_utils");
var _common = require("../../core/utils/common");
var _iterator = require("../../core/utils/iterator");
var _type = require("../../core/utils/type");
var _extend = require("../../core/utils/extend");
var _selectors = require("../widget/selectors");
var _message = _interopRequireDefault(require("../../localization/message"));
var _button = _interopRequireDefault(require("../button"));
var _pointer = _interopRequireDefault(require("../../events/pointer"));
var _validation_engine = _interopRequireDefault(require("../validation_engine"));
var _validator = _interopRequireDefault(require("../validator"));
var _ui = _interopRequireDefault(require("../overlay/ui.overlay"));
var _ui2 = _interopRequireDefault(require("../widget/ui.errors"));
var _deferred = require("../../core/utils/deferred");
var _load_indicator = _interopRequireDefault(require("../load_indicator"));
var _string = require("../../core/utils/string");
var _browser = _interopRequireDefault(require("../../core/utils/browser"));
function _interopRequireDefault(obj) {
return obj && obj.__esModule ? obj : {
default: obj
}
}
function _toConsumableArray(arr) {
return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread()
}
function _nonIterableSpread() {
throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")
}
function _unsupportedIterableToArray(o, minLen) {
if (!o) {
return
}
if ("string" === typeof o) {
return _arrayLikeToArray(o, minLen)
}
var n = Object.prototype.toString.call(o).slice(8, -1);
if ("Object" === n && o.constructor) {
n = o.constructor.name
}
if ("Map" === n || "Set" === n) {
return Array.from(o)
}
if ("Arguments" === n || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) {
return _arrayLikeToArray(o, minLen)
}
}
function _iterableToArray(iter) {
if ("undefined" !== typeof Symbol && null != iter[Symbol.iterator] || null != iter["@@iterator"]) {
return Array.from(iter)
}
}
function _arrayWithoutHoles(arr) {
if (Array.isArray(arr)) {
return _arrayLikeToArray(arr)
}
}
function _arrayLikeToArray(arr, len) {
if (null == len || len > arr.length) {
len = arr.length
}
for (var i = 0, arr2 = new Array(len); i < len; i++) {
arr2[i] = arr[i]
}
return arr2
}
var INVALIDATE_CLASS = "invalid";
var REVERT_TOOLTIP_CLASS = "revert-tooltip";
var ROWS_VIEW_CLASS = "rowsview";
var INVALID_MESSAGE_CLASS = "dx-invalid-message";
var WIDGET_INVALID_MESSAGE_CLASS = "invalid-message";
var INVALID_MESSAGE_ALWAYS_CLASS = "dx-invalid-message-always";
var REVERT_BUTTON_CLASS = "dx-revert-button";
var VALIDATOR_CLASS = "validator";
var PENDING_INDICATOR_CLASS = "dx-pending-indicator";
var VALIDATION_PENDING_CLASS = "dx-validation-pending";
var CONTENT_CLASS = "content";
var INSERT_INDEX = "__DX_INSERT_INDEX__";
var PADDING_BETWEEN_TOOLTIPS = 2;
var EDIT_MODE_ROW = "row";
var EDIT_MODE_FORM = "form";
var EDIT_MODE_BATCH = "batch";
var EDIT_MODE_CELL = "cell";
var EDIT_MODE_POPUP = "popup";
var GROUP_CELL_CLASS = "dx-group-cell";
var FORM_BASED_MODES = [EDIT_MODE_POPUP, EDIT_MODE_FORM];
var COMMAND_TRANSPARENT = "transparent";
var VALIDATION_STATUS = {
valid: "valid",
invalid: "invalid",
pending: "pending"
};
var EDIT_DATA_INSERT_TYPE = "insert";
var EDIT_DATA_REMOVE_TYPE = "remove";
var VALIDATION_CANCELLED = "cancel";
var NEW_SCROLLING_MODE = "scrolling.newMode";
var validationResultIsValid = function(result) {
return (0, _type.isDefined)(result) && result !== VALIDATION_CANCELLED
};
var cellValueShouldBeValidated = function(value, rowOptions) {
return void 0 !== value || void 0 === value && rowOptions && !rowOptions.isNewRow
};
var ValidatingController = _uiGrid_core.default.Controller.inherit({
init: function() {
this._editingController = this.getController("editing");
this.createAction("onRowValidating");
if (!this._validationState) {
this._validationState = []
}
},
_rowIsValidated: function(change) {
var validationData = this._getValidationData(null === change || void 0 === change ? void 0 : change.key);
return !!validationData && !!validationData.validated
},
_getValidationData: function(key, create) {
var validationData = this._validationState.filter((function(data) {
return (0, _common.equalByValue)(data.key, key)
}))[0];
if (!validationData && create) {
validationData = {
key: key,
isValid: true
};
this._validationState.push(validationData)
}
return validationData
},
_getBrokenRules: function(validationData, validationResults) {
var brokenRules;
if (validationResults) {
brokenRules = validationResults.brokenRules || validationResults.brokenRule && [validationResults.brokenRule]
} else {
brokenRules = validationData.brokenRules || []
}
return brokenRules
},
_rowValidating: function(validationData, validationResults) {
var deferred = new _deferred.Deferred;
var change = this._editingController.getChangeByKey(null === validationData || void 0 === validationData ? void 0 : validationData.key);
var brokenRules = this._getBrokenRules(validationData, validationResults);
var isValid = validationResults ? validationResults.isValid : validationData.isValid;
var parameters = {
brokenRules: brokenRules,
isValid: isValid,
key: change.key,
newData: change.data,
oldData: this._editingController._getOldData(change.key),
promise: null,
errorText: this.getHiddenValidatorsErrorText(brokenRules)
};
this.executeAction("onRowValidating", parameters);
(0, _deferred.when)((0, _deferred.fromPromise)(parameters.promise)).always((function() {
validationData.isValid = parameters.isValid;
validationData.errorText = parameters.errorText;
deferred.resolve(parameters)
}));
return deferred.promise()
},
getHiddenValidatorsErrorText: function(brokenRules) {
var brokenRulesMessages = [];
(0, _iterator.each)(brokenRules, (function(_, brokenRule) {
var column = brokenRule.column;
var isGroupExpandColumn = column && void 0 !== column.groupIndex && !column.showWhenGrouped;
var isVisibleColumn = column && column.visible;
if (!brokenRule.validator.$element().parent().length && (!isVisibleColumn || isGroupExpandColumn)) {
brokenRulesMessages.push(brokenRule.message)
}
}));
return brokenRulesMessages.join(", ")
},
validate: function(isFull) {
var _this = this;
var isValid = true;
var editingController = this._editingController;
var deferred = new _deferred.Deferred;
var completeList = [];
var editMode = editingController.getEditMode();
isFull = isFull || editMode === EDIT_MODE_ROW;
if (this._isValidationInProgress) {
return deferred.resolve(false).promise()
}
this._isValidationInProgress = true;
if (isFull) {
editingController.addDeferred(deferred);
var changes = editingController.getChanges();
(0, _iterator.each)(changes, (function(index, _ref) {
var type = _ref.type,
key = _ref.key;
if ("remove" !== type) {
var validationData = _this._getValidationData(key, true);
var validationResult = _this.validateGroup(validationData);
completeList.push(validationResult);
validationResult.done((function(validationResult) {
validationData.validated = true;
isValid = isValid && validationResult.isValid
}))
}
}))
} else if (this._currentCellValidator) {
var validationResult = this.validateGroup(this._currentCellValidator._findGroup());
completeList.push(validationResult);
validationResult.done((function(validationResult) {
isValid = validationResult.isValid
}))
}
_deferred.when.apply(void 0, completeList).done((function() {
_this._isValidationInProgress = false;
deferred.resolve(isValid)
}));
return deferred.promise()
},
validateGroup: function(validationData) {
var _validationResult, _this2 = this;
var result = new _deferred.Deferred;
var validateGroup = validationData && _validation_engine.default.getGroupConfig(validationData);
var validationResult;
if (null !== validateGroup && void 0 !== validateGroup && validateGroup.validators.length) {
this.resetRowValidationResults(validationData);
validationResult = _validation_engine.default.validateGroup(validationData)
}(0, _deferred.when)((null === (_validationResult = validationResult) || void 0 === _validationResult ? void 0 : _validationResult.complete) || validationResult).done((function(validationResult) {
(0, _deferred.when)(_this2._rowValidating(validationData, validationResult)).done(result.resolve)
}));
return result.promise()
},
isRowDataModified: function(change) {
return !(0, _type.isEmptyObject)(change.data)
},
updateValidationState: function(change) {
var editMode = this._editingController.getEditMode();
var key = change.key;
var validationData = this._getValidationData(key, true);
if (-1 === FORM_BASED_MODES.indexOf(editMode)) {
if (change.type === EDIT_DATA_INSERT_TYPE && !this.isRowDataModified(change)) {
validationData.isValid = true;
return
}
this.setDisableApplyValidationResults(true);
var groupConfig = _validation_engine.default.getGroupConfig(validationData);
if (groupConfig) {
var validationResult = _validation_engine.default.validateGroup(validationData);
(0, _deferred.when)(validationResult.complete || validationResult).done((function(validationResult) {
validationData.isValid = validationResult.isValid;
validationData.brokenRules = validationResult.brokenRules
}))
} else if (!validationData.brokenRules || !validationData.brokenRules.length) {
validationData.isValid = true
}
this.setDisableApplyValidationResults(false)
} else {
validationData.isValid = true
}
},
setValidator: function(validator) {
this._currentCellValidator = validator
},
renderCellPendingIndicator: function($container) {
var $indicator = $container.find("." + PENDING_INDICATOR_CLASS);
if (!$indicator.length) {
var $indicatorContainer = $container;
$indicator = (0, _renderer.default)("<div>").appendTo($indicatorContainer).addClass(PENDING_INDICATOR_CLASS);
this._createComponent($indicator, _load_indicator.default);
$container.addClass(VALIDATION_PENDING_CLASS)
}
},
disposeCellPendingIndicator: function($container) {
var $indicator = $container.find("." + PENDING_INDICATOR_CLASS);
if ($indicator.length) {
var indicator = _load_indicator.default.getInstance($indicator);
if (indicator) {
indicator.dispose();
indicator.$element().remove()
}
$container.removeClass(VALIDATION_PENDING_CLASS)
}
},
validationStatusChanged: function(result) {
var validator = result.validator;
var validationGroup = validator.option("validationGroup");
var column = validator.option("dataGetter")().column;
this.updateCellValidationResult({
rowKey: validationGroup.key,
columnIndex: column.index,
validationResult: result
})
},
validatorInitialized: function(arg) {
arg.component.on("validating", this.validationStatusChanged.bind(this));
arg.component.on("validated", this.validationStatusChanged.bind(this))
},
validatorDisposing: function(arg) {
var validator = arg.component;
var validationGroup = validator.option("validationGroup");
var column = validator.option("dataGetter")().column;
var result = this.getCellValidationResult({
rowKey: null === validationGroup || void 0 === validationGroup ? void 0 : validationGroup.key,
columnIndex: column.index
});
if (validationResultIsValid(result) && result.status === VALIDATION_STATUS.pending) {
this.cancelCellValidationResult({
change: validationGroup,
columnIndex: column.index
})
}
},
applyValidationResult: function($container, result) {
var validator = result.validator;
var validationGroup = validator.option("validationGroup");
var column = validator.option("dataGetter")().column;
result.brokenRules && result.brokenRules.forEach((function(rule) {
rule.columnIndex = column.index;
rule.column = column
}));
if ($container) {
var validationResult = this.getCellValidationResult({
rowKey: validationGroup.key,
columnIndex: column.index
});
var requestIsDisabled = validationResultIsValid(validationResult) && validationResult.disabledPendingId === result.id;
if (this._disableApplyValidationResults || requestIsDisabled) {
return
}
if (result.status === VALIDATION_STATUS.invalid) {
var $focus = $container.find(":focus");
if (!(0, _selectors.focused)($focus)) {
_events_engine.default.trigger($focus, "focus");
_events_engine.default.trigger($focus, _pointer.default.down)
}
}
var editor = !column.editCellTemplate && this.getController("editorFactory").getEditorInstance($container);
if (result.status === VALIDATION_STATUS.pending) {
if (editor) {
editor.option("validationStatus", VALIDATION_STATUS.pending)
} else {
this.renderCellPendingIndicator($container)
}
} else if (editor) {
editor.option("validationStatus", VALIDATION_STATUS.valid)
} else {
this.disposeCellPendingIndicator($container)
}
$container.toggleClass(this.addWidgetPrefix(INVALIDATE_CLASS), result.status === VALIDATION_STATUS.invalid)
}
},
createValidator: function(parameters, $container) {
var _this3 = this;
var editingController = this._editingController;
var column = parameters.column;
var showEditorAlways = column.showEditorAlways;
if ((0, _type.isDefined)(column.command) || !column.validationRules || !Array.isArray(column.validationRules) || !column.validationRules.length) {
return
}
var editIndex = editingController.getIndexByKey(parameters.key, editingController.getChanges());
var needCreateValidator = editIndex > -1;
if (!needCreateValidator) {
if (!showEditorAlways) {
var columnsController = this.getController("columns");
var visibleColumns = (null === columnsController || void 0 === columnsController ? void 0 : columnsController.getVisibleColumns()) || [];
showEditorAlways = visibleColumns.some((function(column) {
return column.showEditorAlways
}))
}
var isEditRow = (0, _common.equalByValue)(this.option("editing.editRowKey"), parameters.key);
var isCellOrBatchEditingAllowed = editingController.isCellOrBatchEditMode() && editingController.allowUpdating({
row: parameters.row
});
needCreateValidator = isEditRow || isCellOrBatchEditingAllowed && showEditorAlways;
if (isCellOrBatchEditingAllowed && showEditorAlways) {
editingController._addInternalData({
key: parameters.key,
oldData: parameters.data
})
}
}
if (needCreateValidator) {
if ($container && !$container.length) {
_ui2.default.log("E1050");
return
}
var validationData = this._getValidationData(parameters.key, true);
var getValue = function() {
var change = editingController.getChangeByKey(null === validationData || void 0 === validationData ? void 0 : validationData.key);
var value = column.calculateCellValue((null === change || void 0 === change ? void 0 : change.data) || {});
return void 0 !== value ? value : parameters.value
};
var useDefaultValidator = $container && $container.hasClass("dx-widget");
$container && $container.addClass(this.addWidgetPrefix(VALIDATOR_CLASS));
var validator = new _validator.default($container || (0, _renderer.default)("<div>"), {
name: column.caption,
validationRules: (0, _extend.extend)(true, [], column.validationRules),
validationGroup: validationData,
adapter: useDefaultValidator ? null : {
getValue: getValue,
applyValidationResults: function(result) {
_this3.applyValidationResult($container, result)
}
},
dataGetter: function() {
var key = null === validationData || void 0 === validationData ? void 0 : validationData.key;
var change = editingController.getChangeByKey(key);
var oldData = editingController._getOldData(key);
return {
data: (0, _array_utils.createObjectWithChanges)(oldData, null === change || void 0 === change ? void 0 : change.data),
column: column
}
},
onInitialized: this.validatorInitialized.bind(this),
onDisposing: this.validatorDisposing.bind(this)
});
if (useDefaultValidator) {
var adapter = validator.option("adapter");
if (adapter) {
adapter.getValue = getValue;
adapter.validationRequestsCallbacks = []
}
}
return validator
}
},
setDisableApplyValidationResults: function(flag) {
this._disableApplyValidationResults = flag
},
getDisableApplyValidationResults: function() {
return this._disableApplyValidationResults
},
isCurrentValidatorProcessing: function(_ref2) {
var rowKey = _ref2.rowKey,
columnIndex = _ref2.columnIndex;
return this._currentCellValidator && (0, _common.equalByValue)(this._currentCellValidator.option("validationGroup").key, rowKey) && this._currentCellValidator.option("dataGetter")().column.index === columnIndex
},
validateCell: function(validator) {
var cellParams = {
rowKey: validator.option("validationGroup").key,
columnIndex: validator.option("dataGetter")().column.index
};
var validationResult = this.getCellValidationResult(cellParams);
var stateRestored = validationResultIsValid(validationResult);
if (!stateRestored) {
validationResult = validator.validate()
}
var deferred = new _deferred.Deferred;
var adapter = validator.option("adapter");
if (stateRestored && validationResult.status === VALIDATION_STATUS.pending) {
this.updateCellValidationResult(cellParams);
adapter.applyValidationResults(validationResult)
}(0, _deferred.when)(validationResult.complete || validationResult).done((function(validationResult) {
stateRestored && adapter.applyValidationResults(validationResult);
deferred.resolve(validationResult)
}));
return deferred.promise()
},
updateCellValidationResult: function(_ref3) {
var rowKey = _ref3.rowKey,
columnIndex = _ref3.columnIndex,
validationResult = _ref3.validationResult;
var validationData = this._getValidationData(rowKey);
if (!validationData) {
return
}
if (!validationData.validationResults) {
validationData.validationResults = {}
}
var result;
if (validationResult) {
result = (0, _extend.extend)({}, validationResult);
validationData.validationResults[columnIndex] = result;
if (validationResult.status === VALIDATION_STATUS.pending) {
if (this._editingController.getEditMode() === EDIT_MODE_CELL) {
result.deferred = new _deferred.Deferred;
result.complete.always((function() {
result.deferred.resolve()
}));
this._editingController.addDeferred(result.deferred)
}
if (this._disableApplyValidationResults) {
result.disabledPendingId = validationResult.id;
return
}
}
} else {
result = validationData.validationResults[columnIndex]
}
if (result && result.disabledPendingId) {
delete result.disabledPendingId
}
},
getCellValidationResult: function(_ref4) {
var _validationData$valid;
var rowKey = _ref4.rowKey,
columnIndex = _ref4.columnIndex;
var validationData = this._getValidationData(rowKey, true);
return null === validationData || void 0 === validationData ? void 0 : null === (_validationData$valid = validationData.validationResults) || void 0 === _validationData$valid ? void 0 : _validationData$valid[columnIndex]
},
removeCellValidationResult: function(_ref5) {
var change = _ref5.change,
columnIndex = _ref5.columnIndex;
var validationData = this._getValidationData(null === change || void 0 === change ? void 0 : change.key);
if (validationData && validationData.validationResults) {
this.cancelCellValidationResult({
change: change,
columnIndex: columnIndex
});
delete validationData.validationResults[columnIndex]
}
},
cancelCellValidationResult: function(_ref6) {
var change = _ref6.change,
columnIndex = _ref6.columnIndex;
var validationData = this._getValidationData(change.key);
if (change && validationData.validationResults) {
var result = validationData.validationResults[columnIndex];
if (result) {
result.deferred && result.deferred.reject(VALIDATION_CANCELLED);
validationData.validationResults[columnIndex] = VALIDATION_CANCELLED
}
}
},
resetRowValidationResults: function(validationData) {
if (validationData) {
validationData.validationResults && delete validationData.validationResults;
delete validationData.validated
}
},
isInvalidCell: function(_ref7) {
var rowKey = _ref7.rowKey,
columnIndex = _ref7.columnIndex;
var result = this.getCellValidationResult({
rowKey: rowKey,
columnIndex: columnIndex
});
return validationResultIsValid(result) && result.status === VALIDATION_STATUS.invalid
},
getCellValidator: function(_ref8) {
var rowKey = _ref8.rowKey,
columnIndex = _ref8.columnIndex;
var validationData = this._getValidationData(rowKey);
var groupConfig = validationData && _validation_engine.default.getGroupConfig(validationData);
var validators = groupConfig && groupConfig.validators;
return validators && validators.filter((function(v) {
var column = v.option("dataGetter")().column;
return column ? column.index === columnIndex : false
}))[0]
},
setCellValidationStatus: function(cellOptions) {
var validationResult = this.getCellValidationResult({
rowKey: cellOptions.key,
columnIndex: cellOptions.column.index
});
if ((0, _type.isDefined)(validationResult)) {
cellOptions.validationStatus = validationResult !== VALIDATION_CANCELLED ? validationResult.status : VALIDATION_CANCELLED
} else {
delete cellOptions.validationStatus
}
}
});
var validatingModule = {
defaultOptions: function() {
return {
editing: {
texts: {
validationCancelChanges: _message.default.format("dxDataGrid-validationCancelChanges")
}
}
}
},
controllers: {
validating: ValidatingController
},
extenders: {
controllers: {
editing: {
_addChange: function(options, row) {
var index = this.callBase(options, row);
var validatingController = this.getController("validating");
if (index >= 0 && options.type !== EDIT_DATA_REMOVE_TYPE) {
var change = this.getChanges()[index];
change && validatingController.updateValidationState(change)
}
return index
},
_handleChangesChange: function(args) {
this.callBase.apply(this, arguments);
var validatingController = this.getController("validating");
args.value.forEach((function(change) {
if (void 0 === validatingController._getValidationData(change.key)) {
validatingController.updateValidationState(change)
}
}))
},
_updateRowAndPageIndices: function() {
var _this4 = this;
var that = this;
var startInsertIndex = that.getView("rowsView").getTopVisibleItemIndex();
var rowIndex = startInsertIndex;
(0, _iterator.each)(that.getChanges(), (function(_, _ref9) {
var key = _ref9.key,
type = _ref9.type;
var validationData = _this4.getController("validating")._getValidationData(key);
if (validationData && !validationData.isValid && validationData.pageIndex !== that._pageIndex) {
validationData.pageIndex = that._pageIndex;
if (type === EDIT_DATA_INSERT_TYPE) {
validationData.rowIndex = startInsertIndex
} else {
validationData.rowIndex = rowIndex
}
rowIndex++
}
}))
},
_getValidationGroupsInForm: function(detailOptions) {
var validatingController = this.getController("validating");
var validationData = validatingController._getValidationData(detailOptions.key, true);
return {
validationGroup: validationData
}
},
_validateEditFormAfterUpdate: function(row, isCustomSetCellValue) {
if (isCustomSetCellValue && this._editForm && !row.isNewRow) {
this._editForm.validate()
}
this.callBase.apply(this, arguments)
},
_needInsertItem: function(change) {
var result = this.callBase.apply(this, arguments);
var key = change.key,
pageIndex = change.pageIndex;
var validationData = this.getController("validating")._getValidationData(key);
var scrollingMode = this.option("scrolling.mode");
var virtualMode = "virtual" === scrollingMode;
var appendMode = "infinite" === scrollingMode;
if (result && !(null !== validationData && void 0 !== validationData && validationData.isValid) && !virtualMode && !(appendMode && this.option(NEW_SCROLLING_MODE))) {
result = pageIndex === this._pageIndex
}
return result
},
_prepareEditCell: function(params) {
var isNotCanceled = this.callBase.apply(this, arguments);
var validatingController = this.getController("validating");
if (isNotCanceled && params.column.showEditorAlways) {
validatingController.updateValidationState({
key: params.key
})
}
return isNotCanceled
},
processItems: function(items, changeType) {
var that = this;
var changes = that.getChanges();
var dataController = that.getController("data");
var validatingController = this.getController("validating");
items = that.callBase(items, changeType);
var itemsCount = items.length;
var addInValidItem = function(change, validationData) {
var data = {
key: change.key
};
var index = function(change, items) {
var index = -1;
var isInsert = change.type === EDIT_DATA_INSERT_TYPE;
var key = change.key;
(0, _iterator.each)(items, (function(i, item) {
if ((0, _common.equalByValue)(key, isInsert ? item : dataController.keyOf(item))) {
index = i;
return false
}
}));
return index
}(change, items);
if (index >= 0) {
return
}
validationData.rowIndex = validationData.rowIndex > itemsCount ? validationData.rowIndex % itemsCount : validationData.rowIndex;
var rowIndex = validationData.rowIndex;
data[INSERT_INDEX] = 1;
items.splice(rowIndex, 0, data)
};
if (that.getEditMode() === EDIT_MODE_BATCH && "prepend" !== changeType && "append" !== changeType) {
changes.forEach((function(change) {
var key = change.key;
var validationData = validatingController._getValidationData(key);
if (validationData && change.type && validationData.pageIndex === that._pageIndex && (null === change || void 0 === change ? void 0 : change.pageIndex) !== that._pageIndex) {
addInValidItem(change, validationData)
}
}))
}
return items
},
processDataItem: function(item) {
var isInserted = item.data[INSERT_INDEX];
var key = isInserted ? item.data.key : item.key;
var editMode = this.getEditMode();
if (editMode === EDIT_MODE_BATCH && isInserted && key) {
var changes = this.getChanges();
var editIndex = _uiGrid_core2.default.getIndexByKey(key, changes);
if (editIndex >= 0) {
var change = changes[editIndex];
if (change.type !== EDIT_DATA_INSERT_TYPE) {
var oldData = this._getOldData(change.key);
item.data = (0, _extend.extend)(true, {}, oldData, change.data);
item.key = key
}
}
}
this.callBase.apply(this, arguments)
},
_createInvisibleColumnValidators: function(changes) {
var _this5 = this;
var that = this;
var validatingController = this.getController("validating");
var columnsController = this.getController("columns");
var columns = columnsController.getColumns();
var invisibleColumns = columnsController.getInvisibleColumns().filter((function(column) {
return !column.isBand
}));
var groupColumns = columnsController.getGroupColumns().filter((function(column) {
return !column.showWhenGrouped && -1 === invisibleColumns.indexOf(column)
}));
var invisibleColumnValidators = [];
invisibleColumns.push.apply(invisibleColumns, _toConsumableArray(groupColumns));
if (-1 === FORM_BASED_MODES.indexOf(this.getEditMode())) {
(0, _iterator.each)(columns, (function(_, column) {
changes.forEach((function(change) {
var data;
if (function(column, rowKey) {
return _this5._dataController.getRowIndexByKey(rowKey) >= 0 && invisibleColumns.indexOf(column) < 0
}(column, change.key)) {
return
}
if (change.type === EDIT_DATA_INSERT_TYPE) {
data = change.data
} else if ("update" === change.type) {
var oldData = that._getOldData(change.key);
data = (0, _array_utils.createObjectWithChanges)(oldData, change.data)
}
if (data) {
var validator = validatingController.createValidator({
column: column,
key: change.key,
value: column.calculateCellValue(data)
});
if (validator) {
invisibleColumnValidators.push(validator)
}
}
}))
}))
}
return function() {
invisibleColumnValidators.forEach((function(validator) {
validator.dispose()
}))
}
},
_beforeSaveEditData: function(change, editIndex) {
var _this6 = this;
var result = this.callBase.apply(this, arguments);
var validatingController = this.getController("validating");
var validationData = validatingController._getValidationData(null === change || void 0 === change ? void 0 : change.key);
if (change) {
var isValid = "remove" === change.type || validationData.isValid;
result = result || !isValid
} else {
var disposeValidators = this._createInvisibleColumnValidators(this.getChanges());
result = new _deferred.Deferred;
this.executeOperation(result, (function() {
validatingController.validate(true).done((function(isFullValid) {
disposeValidators();
_this6._updateRowAndPageIndices();
switch (_this6.getEditMode()) {
case EDIT_MODE_CELL:
if (!isFullValid) {
_this6._focusEditingCell()
}
break;
case EDIT_MODE_BATCH:
if (!isFullValid) {
_this6._resetEditRowKey();
_this6._resetEditColumnName();
_this6.getController("data").updateItems()
}
}
result.resolve(!isFullValid)
}))
}))
}
return result.promise ? result.promise() : result
},
_beforeEditCell: function(rowIndex, columnIndex, item) {
var result = this.callBase(rowIndex, columnIndex, item);
if (this.getEditMode() === EDIT_MODE_CELL) {
var $cell = this._rowsView._getCellElement(rowIndex, columnIndex);
var validator = $cell && $cell.data("dxValidator");
var rowOptions = $cell && $cell.closest(".dx-row").data("options");
var value = validator && validator.option("adapter").getValue();
if (validator && cellValueShouldBeValidated(value, rowOptions)) {
var validatingController = this.getController("validating");
var deferred = new _deferred.Deferred;
(0, _deferred.when)(validatingController.validateCell(validator), result).done((function(validationResult, result) {
deferred.resolve(validationResult.status === VALIDATION_STATUS.valid && result)
}));
return deferred.promise()
} else if (!validator) {
return result
}
}
},
_afterSaveEditData: function(cancel) {
var _this7 = this;
var $firstErrorRow;
(0, _iterator.each)(this.getChanges(), (function(_, change) {
var $errorRow = _this7._showErrorRow(change);
$firstErrorRow = $firstErrorRow || $errorRow
}));
if ($firstErrorRow) {
var scrollable = this._rowsView.getScrollable();
if (scrollable) {
scrollable.update();
scrollable.scrollToElement($firstErrorRow)
}
}
if (cancel && this.getEditMode() === EDIT_MODE_CELL && this._needUpdateRow()) {
var editRowIndex = this.getEditRowIndex();
this._dataController.updateItems({
changeType: "update",
rowIndices: [editRowIndex]
});
this._focusEditingCell()
} else if (!cancel) {
this.getController("validating")._validationState = []
}
},
_handleDataChanged: function(args) {
var validationState = this.getController("validating")._validationState;
if ("standard" === this.option("scrolling.mode")) {
this.resetRowAndPageIndices()
}
if ("prepend" === args.changeType) {
(0, _iterator.each)(validationState, (function(_, validationData) {
validationData.rowIndex += args.items.length
}))
}
this.callBase(args)
},
resetRowAndPageIndices: function() {
var _this8 = this;
var validationState = this.getController("validating")._validationState;
(0, _iterator.each)(validationState, (function(_, validationData) {
if (validationData.pageIndex !== _this8._pageIndex) {
delete validationData.pageIndex;
delete validationData.rowIndex
}
}))
},
_beforeCancelEditData: function() {
var validatingController = this.getController("validating");
validatingController._validationState = [];
this.callBase()
},
_showErrorRow: function(change) {
var $popupContent;
var errorHandling = this.getController("errorHandling");
var items = this.getController("data").items();
var rowIndex = this.getIndexByKey(change.key, items);
var validationData = this.getController("validating")._getValidationData(change.key);
if (!(null !== validationData && void 0 !== validationData && validationData.isValid) && null !== validationData && void 0 !== validationData && validationData.errorText && rowIndex >= 0) {
$popupContent = this.getPopupContent();
return errorHandling && errorHandling.renderErrorRow(null === validationData || void 0 === validationData ? void 0 : validationData.errorText, rowIndex, $popupContent)
}
},
updateFieldValue: function(e) {
var _this9 = this;
var validatingController = this.getController("validating");
var deferred = new _deferred.Deferred;
validatingController.removeCellValidationResult({
change: this.getChangeByKey(e.key),
columnIndex: e.column.index
});
this.callBase.apply(this, arguments).done((function() {
var currentValidator = validatingController.getCellValidator({
rowKey: e.key,
columnIndex: e.column.index
});
(0, _deferred.when)(currentValidator && validatingController.validateCell(currentValidator)).done((function(validationResult) {
_this9.getController("editorFactory").refocus();
deferred.resolve(validationResult)
}))
}));
return deferred.promise()
},
highlightDataCell: function($cell, parameters) {
this.callBase.apply(this, arguments);
var validatingController = this.getController("validating");
validatingController.setCellValidationStatus(parameters);
var isEditableCell = !!parameters.setValue;
var cellModified = this.isCellModified(parameters);
var isValidated = (0, _type.isDefined)(parameters.validationStatus);
var needValidation = cellModified && parameters.column.setCellValue || isEditableCell && !cellModified && !(parameters.row.isNewRow || !isValidated);
if (needValidation) {
var validator = $cell.data("dxValidator");
if (validator) {
(0, _deferred.when)(this.getController("validating").validateCell(validator)).done((function() {
validatingController.setCellValidationStatus(parameters)
}))
}
}
},
getChangeByKey: function(key) {
var changes = this.getChanges();
return changes[_uiGrid_core2.default.getIndexByKey(key, changes)]
},
isCellModified: function(parameters) {
var cellModified = this.callBase(parameters);
var change = this.getChangeByKey(parameters.key);
var isCellInvalid = !!parameters.row && this.getController("validating").isInvalidCell({
rowKey: parameters.key,
columnIndex: parameters.column.index
});
return cellModified || this.getController("validating")._rowIsValidated(change) && isCellInvalid
}
},
editorFactory: {
_showRevertButton: function($container) {
var _this10 = this;
if (!$container || !$container.length) {
return
}
var $tooltipElement = $container.find("." + this.addWidgetPrefix(REVERT_TOOLTIP_CLASS));
var $overlayContainer = $container.closest(".".concat(this.addWidgetPrefix(CONTENT_CLASS)));
$tooltipElement && $tooltipElement.remove();
$tooltipElement = (0, _renderer.default)("<div>").addClass(this.addWidgetPrefix(REVERT_TOOLTIP_CLASS)).appendTo($container);
var tooltipOptions = {
animation: null,
visible: true,
width: "auto",
height: "auto",
target: $container,
shading: false,
container: $overlayContainer,
propagateOutsideClick: true,
closeOnOutsideClick: false,
closeOnTargetScroll: false,
contentTemplate: function() {
var $buttonElement = (0, _renderer.default)("<div>").addClass(REVERT_BUTTON_CLASS);
var buttonOptions = {
icon: "revert",
hint: _this10.option("editing.texts.validationCancelChanges"),
onClick: function() {
_this10._editingController.cancelEditData()
}
};
return new _button.default($buttonElement, buttonOptions).$element()