devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
251 lines (240 loc) • 9.05 kB
JavaScript
/**
* DevExtreme (renovation/ui/common/dom_component_wrapper.js)
* Version: 23.2.6
* Build date: Wed May 01 2024
*
* Copyright (c) 2012 - 2024 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
"use strict";
exports.viewFunction = exports.DomComponentWrapperProps = exports.DomComponentWrapper = void 0;
var _inferno = require("inferno");
var _inferno2 = require("@devextreme/runtime/inferno");
var _config_context = require("../../common/config_context");
var _get_updated_options = require("./utils/get_updated_options");
const _excluded = ["valueChange"],
_excluded2 = ["componentProps", "componentType", "templateNames"];
function _objectWithoutPropertiesLoose(source, excluded) {
if (null == source) {
return {}
}
var target = {};
var sourceKeys = Object.keys(source);
var key, i;
for (i = 0; i < sourceKeys.length; i++) {
key = sourceKeys[i];
if (excluded.indexOf(key) >= 0) {
continue
}
target[key] = source[key]
}
return target
}
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, _toPropertyKey(descriptor.key), descriptor)
}
}
function _createClass(Constructor, protoProps, staticProps) {
if (protoProps) {
_defineProperties(Constructor.prototype, protoProps)
}
if (staticProps) {
_defineProperties(Constructor, staticProps)
}
Object.defineProperty(Constructor, "prototype", {
writable: false
});
return Constructor
}
function _toPropertyKey(arg) {
var key = _toPrimitive(arg, "string");
return "symbol" === typeof key ? key : String(key)
}
function _toPrimitive(input, hint) {
if ("object" !== typeof input || null === input) {
return input
}
var prim = input[Symbol.toPrimitive];
if (void 0 !== prim) {
var res = prim.call(input, hint || "default");
if ("object" !== typeof res) {
return res
}
throw new TypeError("@@toPrimitive must return a primitive value.")
}
return ("string" === hint ? String : Number)(input)
}
function _assertThisInitialized(self) {
if (void 0 === self) {
throw new ReferenceError("this hasn't been initialised - super() hasn't been called")
}
return self
}
function _inheritsLoose(subClass, superClass) {
subClass.prototype = Object.create(superClass.prototype);
subClass.prototype.constructor = subClass;
_setPrototypeOf(subClass, superClass)
}
function _setPrototypeOf(o, p) {
_setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function(o, p) {
o.__proto__ = p;
return o
};
return _setPrototypeOf(o, p)
}
function _extends() {
_extends = Object.assign ? Object.assign.bind() : 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)
}
const normalizeProps = props => Object.keys(props).reduce((accumulator, key) => {
if (void 0 !== props[key]) {
accumulator[key] = props[key]
}
return accumulator
}, {});
const viewFunction = _ref => {
let {
props: {
componentProps: {
className: className
}
},
restAttributes: restAttributes,
widgetRef: widgetRef
} = _ref;
return normalizeProps((0, _inferno.createVNode)(1, "div", className, null, 1, _extends({}, restAttributes), null, widgetRef))
};
exports.viewFunction = viewFunction;
const DomComponentWrapperProps = {};
exports.DomComponentWrapperProps = DomComponentWrapperProps;
let DomComponentWrapper = function(_InfernoComponent) {
_inheritsLoose(DomComponentWrapper, _InfernoComponent);
function DomComponentWrapper(props) {
var _this;
_this = _InfernoComponent.call(this, props) || this;
_this.state = {};
_this.widgetRef = (0, _inferno.createRef)();
_this.getInstance = _this.getInstance.bind(_assertThisInitialized(_this));
_this.setupWidget = _this.setupWidget.bind(_assertThisInitialized(_this));
_this.updateWidget = _this.updateWidget.bind(_assertThisInitialized(_this));
return _this
}
var _proto = DomComponentWrapper.prototype;
_proto.createEffects = function() {
return [new _inferno2.InfernoEffect(this.setupWidget, []), new _inferno2.InfernoEffect(this.updateWidget, [this.props.componentProps, this.config, this.props.templateNames])]
};
_proto.updateEffects = function() {
var _this$_effects$;
null === (_this$_effects$ = this._effects[1]) || void 0 === _this$_effects$ ? void 0 : _this$_effects$.update([this.props.componentProps, this.config, this.props.templateNames])
};
_proto.setupWidget = function() {
const componentInstance = new this.props.componentType(this.widgetRef.current, this.properties);
this.instance = componentInstance;
return () => {
componentInstance.dispose();
this.instance = null
}
};
_proto.updateWidget = function() {
const instance = this.getInstance();
if (!instance) {
return
}
const updatedOptions = (0, _get_updated_options.getUpdatedOptions)(this.prevProps || {}, this.properties);
if (updatedOptions.length) {
instance.beginUpdate();
updatedOptions.forEach(_ref2 => {
let {
path: path,
value: value
} = _ref2;
instance.option(path, value)
});
instance.endUpdate()
}
this.prevProps = this.properties
};
_proto.getInstance = function() {
return this.instance
};
_proto.render = function() {
const props = this.props;
return viewFunction({
props: _extends({}, props),
widgetRef: this.widgetRef,
config: this.config,
properties: this.properties,
restAttributes: this.restAttributes
})
};
_createClass(DomComponentWrapper, [{
key: "config",
get: function() {
if (this.context[_config_context.ConfigContext.id]) {
return this.context[_config_context.ConfigContext.id]
}
return _config_context.ConfigContext.defaultValue
}
}, {
key: "properties",
get: function() {
var _this$config;
const normalizedProps = normalizeProps(this.props.componentProps);
const {
valueChange: valueChange
} = normalizedProps, restProps = _objectWithoutPropertiesLoose(normalizedProps, _excluded);
const properties = _extends({
rtlEnabled: !!(null !== (_this$config = this.config) && void 0 !== _this$config && _this$config.rtlEnabled),
isRenovated: true
}, restProps);
if (valueChange) {
properties.onValueChanged = _ref3 => {
let {
value: value
} = _ref3;
return valueChange(value)
}
}
const templates = this.props.templateNames;
templates.forEach(name => {
if ((0, _inferno2.hasTemplate)(name, properties, this)) {
properties[name] = (item, index, container) => {
(0, _inferno2.renderTemplate)(this.props.componentProps[name], {
item: item,
index: index,
container: container
}, this)
}
}
});
return properties
}
}, {
key: "restAttributes",
get: function() {
const _this$props = this.props,
restProps = _objectWithoutPropertiesLoose(_this$props, _excluded2);
return restProps
}
}]);
return DomComponentWrapper
}(_inferno2.InfernoComponent);
exports.DomComponentWrapper = DomComponentWrapper;
DomComponentWrapper.defaultProps = DomComponentWrapperProps;