devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
488 lines (469 loc) • 18.4 kB
JavaScript
/**
* DevExtreme (renovation/component_wrapper/component.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.default = void 0;
var _inferno = require("inferno");
var _infernoCreateElement = require("inferno-create-element");
var _infernoHydrate = require("inferno-hydrate");
var _renderer = _interopRequireDefault(require("../../core/renderer"));
var _dom_adapter = _interopRequireDefault(require("../../core/dom_adapter"));
var _dom_component = _interopRequireDefault(require("../../core/dom_component"));
var _extend = require("../../core/utils/extend");
var _element = require("../../core/element");
var _type = require("../../core/utils/type");
var _vdom = require("@devextreme/vdom");
var _template_wrapper = require("./template_wrapper");
var _utils = require("./utils");
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 _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 _defineProperty(obj, key, value) {
if (key in obj) {
Object.defineProperty(obj, key, {
value: value,
enumerable: true,
configurable: true,
writable: true
})
} else {
obj[key] = value
}
return obj
}
function _extends() {
_extends = Object.assign || function(target) {
for (var i = 1; i < arguments.length; i++) {
var source = arguments[i];
for (var key in source) {
if (Object.prototype.hasOwnProperty.call(source, key)) {
target[key] = source[key]
}
}
}
return target
};
return _extends.apply(this, arguments)
}
function _slicedToArray(arr, i) {
return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest()
}
function _nonIterableRest() {
throw new TypeError("Invalid attempt to destructure 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 _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
}
function _iterableToArrayLimit(arr, i) {
var _i = null == arr ? null : "undefined" !== typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"];
if (null == _i) {
return
}
var _arr = [];
var _n = true;
var _d = false;
var _s, _e;
try {
for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {
_arr.push(_s.value);
if (i && _arr.length === i) {
break
}
}
} catch (err) {
_d = true;
_e = err
} finally {
try {
if (!_n && null != _i.return) {
_i.return()
}
} finally {
if (_d) {
throw _e
}
}
}
return _arr
}
function _arrayWithHoles(arr) {
if (Array.isArray(arr)) {
return arr
}
}
function _defineProperties(target, props) {
for (var i = 0; i < props.length; i++) {
var descriptor = props[i];
descriptor.enumerable = descriptor.enumerable || false;
descriptor.configurable = true;
if ("value" in descriptor) {
descriptor.writable = true
}
Object.defineProperty(target, descriptor.key, descriptor)
}
}
function _createClass(Constructor, protoProps, staticProps) {
if (protoProps) {
_defineProperties(Constructor.prototype, protoProps)
}
if (staticProps) {
_defineProperties(Constructor, staticProps)
}
return Constructor
}
function _inheritsLoose(subClass, superClass) {
subClass.prototype = Object.create(superClass.prototype);
subClass.prototype.constructor = subClass;
_setPrototypeOf(subClass, superClass)
}
function _setPrototypeOf(o, p) {
_setPrototypeOf = Object.setPrototypeOf || function(o, p) {
o.__proto__ = p;
return o
};
return _setPrototypeOf(o, p)
}
var setDefaultOptionValue = function(options, defaultValueGetter) {
return function(name) {
if (options.hasOwnProperty(name) && void 0 === options[name]) {
options[name] = defaultValueGetter(name)
}
}
};
var ComponentWrapper = function(_DOMComponent) {
_inheritsLoose(ComponentWrapper, _DOMComponent);
function ComponentWrapper() {
var _this;
_this = _DOMComponent.apply(this, arguments) || this;
_this._disposeMethodCalled = false;
return _this
}
var _proto = ComponentWrapper.prototype;
_proto._getDefaultOptions = function() {
var _this2 = this;
return (0, _extend.extend)(true, _DOMComponent.prototype._getDefaultOptions.call(this), this._viewComponent.defaultProps, this._propsInfo.twoWay.reduce((function(options, _ref) {
var _extends2;
var _ref2 = _slicedToArray(_ref, 3),
name = _ref2[0],
defaultValue = _ref2[1],
eventName = _ref2[2];
return _extends({}, options, (_extends2 = {}, _defineProperty(_extends2, name, defaultValue), _defineProperty(_extends2, eventName, (function(value) {
return _this2.option(name, value)
})), _extends2))
}), {}), this._propsInfo.templates.reduce((function(options, name) {
return _extends({}, options, _defineProperty({}, name, null))
}), {}))
};
_proto._initMarkup = function() {
var props = this.getProps();
this._renderWrapper(props)
};
_proto._renderWrapper = function(props) {
var containerNode = this.$element()[0];
var parentNode = containerNode.parentNode;
if (!this._isNodeReplaced) {
var nextNode = null === containerNode || void 0 === containerNode ? void 0 : containerNode.nextSibling;
var rootNode = _dom_adapter.default.createElement("div");
rootNode.appendChild(containerNode);
var mountNode = this._documentFragment.appendChild(rootNode);
_vdom.InfernoEffectHost.lock();
(0, _infernoHydrate.hydrate)((0, _infernoCreateElement.createElement)(this._viewComponent, props), mountNode);
containerNode.$V = mountNode.$V;
if (parentNode) {
parentNode.insertBefore(containerNode, nextNode)
}
_vdom.InfernoEffectHost.callEffects();
this._isNodeReplaced = true
} else {
(0, _inferno.render)((0, _infernoCreateElement.createElement)(this._viewComponent, props), containerNode)
}
};
_proto._render = function() {};
_proto.dispose = function() {
this._disposeMethodCalled = true;
_DOMComponent.prototype.dispose.call(this)
};
_proto._dispose = function() {
var containerNode = this.$element()[0];
var parentNode = containerNode.parentNode;
parentNode.$V = containerNode.$V;
containerNode.$V = null;
(0, _inferno.render)(this._disposeMethodCalled ? (0, _infernoCreateElement.createElement)(containerNode.tagName, this.elementAttr) : null, parentNode);
delete parentNode.$V;
_DOMComponent.prototype._dispose.call(this)
};
_proto._patchOptionValues = function(options) {
var _this3 = this;
var _this$_propsInfo = this._propsInfo,
allowNull = _this$_propsInfo.allowNull,
elements = _this$_propsInfo.elements,
props = _this$_propsInfo.props,
twoWay = _this$_propsInfo.twoWay;
var defaultProps = this._viewComponent.defaultProps;
var widgetProps = props.reduce((function(acc, propName) {
if (options.hasOwnProperty(propName)) {
acc[propName] = options[propName]
}
return acc
}), {
ref: options.ref,
children: options.children
});
allowNull.forEach(setDefaultOptionValue(widgetProps, (function() {
return null
})));
Object.keys(defaultProps).forEach(setDefaultOptionValue(widgetProps, (function(name) {
return defaultProps[name]
})));
twoWay.forEach((function(_ref3) {
var _ref4 = _slicedToArray(_ref3, 2),
name = _ref4[0],
defaultValue = _ref4[1];
return setDefaultOptionValue(widgetProps, (function() {
return defaultValue
}))(name)
}));
elements.forEach((function(name) {
if (name in widgetProps) {
var value = widgetProps[name];
if ((0, _type.isRenderer)(value)) {
widgetProps[name] = _this3._patchElementParam(value)
}
}
}));
return widgetProps
};
_proto.getProps = function() {
var _this4 = this;
var _this$option = this.option(),
elementAttr = _this$option.elementAttr;
var options = this._patchOptionValues(_extends({}, this._props, {
ref: this._viewRef,
children: this._extractDefaultSlot()
}));
this._propsInfo.templates.forEach((function(template) {
options[template] = _this4._componentTemplates[template]
}));
return _extends({}, options, this.elementAttr, elementAttr, {
className: [].concat(_toConsumableArray((this.elementAttr.class || "").split(" ")), _toConsumableArray((elementAttr.class || "").split(" "))).filter((function(c, i, a) {
return c && a.indexOf(c) === i
})).join(" ").trim(),
class: ""
}, this._actionsMap)
};
_proto._getActionConfigs = function() {
return {}
};
_proto._init = function() {
var _this5 = this;
_DOMComponent.prototype._init.call(this);
this._props = _extends({}, this.option());
this._documentFragment = _dom_adapter.default.createDocumentFragment();
this._actionsMap = {};
this._componentTemplates = {};
this._propsInfo.templates.forEach((function(template) {
_this5._componentTemplates[template] = _this5._createTemplateComponent(_this5._props[template])
}));
Object.keys(this._getActionConfigs()).forEach((function(name) {
return _this5._addAction(name)
}));
this._viewRef = (0, _inferno.createRef)();
this._supportedKeys = function() {
return {}
}
};
_proto._addAction = function(event, action) {
if (!action) {
var actionByOption = this._createActionByOption(event, this._getActionConfigs()[event]);
action = function(actArgs) {
Object.keys(actArgs).forEach((function(name) {
if ((0, _type.isDefined)(actArgs[name]) && _dom_adapter.default.isNode(actArgs[name])) {
actArgs[name] = (0, _element.getPublicElement)((0, _renderer.default)(actArgs[name]))
}
}));
return actionByOption(actArgs)
}
}
this._actionsMap[event] = action
};
_proto._optionChanged = function(option) {
var fullName = option.fullName,
name = option.name,
value = option.value;
(0, _utils.updatePropsImmutable)(this._props, this.option(), name, fullName);
if (this._propsInfo.templates.indexOf(name) > -1) {
this._componentTemplates[name] = this._createTemplateComponent(value)
}
if (name && this._getActionConfigs()[name]) {
this._addAction(name)
}
_DOMComponent.prototype._optionChanged.call(this, option);
this._invalidate()
};
_proto._extractDefaultSlot = function() {
if (this.option("_hasAnonymousTemplateContent")) {
return (0, _infernoCreateElement.createElement)(_template_wrapper.TemplateWrapper, {
template: this._getTemplate(this._templateManager.anonymousTemplateName),
transclude: true
})
}
return null
};
_proto._createTemplateComponent = function(templateOption) {
if (!templateOption) {
return
}
var template = this._getTemplate(templateOption);
return function(model) {
return (0, _infernoCreateElement.createElement)(_template_wrapper.TemplateWrapper, {
template: template,
model: model
})
}
};
_proto._wrapKeyDownHandler = function(handler) {
var _this6 = this;
return function(options) {
var keyName = options.keyName,
originalEvent = options.originalEvent,
which = options.which;
var keys = _this6._supportedKeys();
var func = keys[keyName] || keys[which];
if (void 0 !== func) {
var _handler = func.bind(_this6);
var result = _handler(originalEvent, options);
if (!result) {
originalEvent.cancel = true;
return originalEvent
}
}
return null === handler || void 0 === handler ? void 0 : handler(originalEvent, options)
}
};
_proto._toPublicElement = function(element) {
return (0, _element.getPublicElement)((0, _renderer.default)(element))
};
_proto._patchElementParam = function(value) {
var _result, _result2;
var result;
try {
result = (0, _renderer.default)(value)
} catch (error) {
return value
}
result = null === (_result = result) || void 0 === _result ? void 0 : _result.get(0);
return null !== (_result2 = result) && void 0 !== _result2 && _result2.nodeType ? result : value
};
_proto.repaint = function() {
this._isNodeReplaced = false;
this._refresh()
};
_proto.registerKeyHandler = function(key, handler) {
var currentKeys = this._supportedKeys();
this._supportedKeys = function() {
return _extends({}, currentKeys, _defineProperty({}, key, handler))
}
};
_proto.setAria = function(name, value) {
throw new Error('"setAria" method is deprecated, use "aria" property instead')
};
_createClass(ComponentWrapper, [{
key: "_propsInfo",
get: function() {
return {
allowNull: [],
twoWay: [],
elements: [],
templates: [],
props: []
}
}
}, {
key: "viewRef",
get: function() {
var _this$_viewRef;
return null === (_this$_viewRef = this._viewRef) || void 0 === _this$_viewRef ? void 0 : _this$_viewRef.current
}
}, {
key: "elementAttr",
get: function() {
var _this$_storedClasses;
if (!this._elementAttr) {
var attributes = this.$element()[0].attributes;
this._elementAttr = _extends({}, Object.keys(attributes).reduce((function(a, key) {
if (attributes[key].specified) {
a[attributes[key].name] = attributes[key].value
}
return a
}), {}))
}
var elemStyle = this.$element()[0].style;
var style = {};
for (var i = 0; i < elemStyle.length; i++) {
style[elemStyle[i]] = elemStyle.getPropertyValue(elemStyle[i])
}
this._elementAttr.style = style;
var cssClass = this.$element()[0].getAttribute("class") || "";
this._storedClasses = null !== (_this$_storedClasses = this._storedClasses) && void 0 !== _this$_storedClasses ? _this$_storedClasses : cssClass.split(" ").filter((function(name) {
return 0 === name.indexOf("dx-")
})).join(" ");
this._elementAttr.class = cssClass.split(" ").filter((function(name) {
return 0 !== name.indexOf("dx-")
})).concat(this._storedClasses).join(" ").trim();
return this._elementAttr
}
}]);
return ComponentWrapper
}(_dom_component.default);
exports.default = ComponentWrapper;
ComponentWrapper.IS_RENOVATED_WIDGET = false;
ComponentWrapper.IS_RENOVATED_WIDGET = true;
module.exports = exports.default;
module.exports.default = exports.default;