UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

225 lines (222 loc) • 8.54 kB
/** * DevExtreme (cjs/__internal/ui/hierarchical_collection/m_hierarchical_collection_widget.js) * Version: 24.2.6 * Build date: Mon Mar 17 2025 * * Copyright (c) 2012 - 2025 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _devices = _interopRequireDefault(require("../../../core/devices")); var _renderer = _interopRequireDefault(require("../../../core/renderer")); var _bindable_template = require("../../../core/templates/bindable_template"); var _common = require("../../../core/utils/common"); var _data = require("../../../core/utils/data"); var _extend = require("../../../core/utils/extend"); var _icon = require("../../../core/utils/icon"); var _iterator = require("../../../core/utils/iterator"); var _type = require("../../../core/utils/type"); var _uiCollection_widget = _interopRequireDefault(require("../../../ui/collection/ui.collection_widget.async")); var _m_data_adapter = _interopRequireDefault(require("./m_data_adapter")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e } } function _extends() { return _extends = Object.assign ? Object.assign.bind() : function(n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) { ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]) } } return n }, _extends.apply(null, arguments) } const DISABLED_STATE_CLASS = "dx-state-disabled"; const ITEM_URL_CLASS = "dx-item-url"; class HierarchicalCollectionWidget extends _uiCollection_widget.default { _getDefaultOptions() { return _extends({}, super._getDefaultOptions(), { keyExpr: "id", displayExpr: "text", selectedExpr: "selected", disabledExpr: "disabled", itemsExpr: "items", hoverStateEnabled: true, parentIdExpr: "parentId", expandedExpr: "expanded" }) } _defaultOptionsRules() { return super._defaultOptionsRules().concat([{ device: () => "desktop" === _devices.default.real().deviceType && !_devices.default.isSimulator(), options: { focusStateEnabled: true } }]) } _init() { super._init(); this._initAccessors(); this._initDataAdapter(); this._initDynamicTemplates() } _initDataSource() { var _this$_dataSource; super._initDataSource(); null === (_this$_dataSource = this._dataSource) || void 0 === _this$_dataSource || _this$_dataSource.paginate(false) } _initDataAdapter() { const accessors = this._createDataAdapterAccessors(); this._dataAdapter = new _m_data_adapter.default((0, _extend.extend)({ dataAccessors: { getters: accessors.getters, setters: accessors.setters }, items: this.option("items") }, this._getDataAdapterOptions())) } _getDataAdapterOptions() {} _getItemExtraPropNames() {} _initDynamicTemplates() { const fields = ["text", "html", "items", "icon"].concat(this._getItemExtraPropNames()); this._templateManager.addDefaultTemplates({ item: new _bindable_template.BindableTemplate(this._addContent.bind(this), fields, this.option("integrationOptions.watchMethod"), { text: this._displayGetter, items: this._itemsGetter }) }) } _addContent($container, itemData) { $container.html(itemData.html).append(this._getIconContainer(itemData)).append(this._getTextContainer(itemData)) } _getLinkContainer(iconContainer, textContainer, itemData) { const { linkAttr: linkAttr, url: url } = itemData; const linkAttributes = (0, _type.isObject)(linkAttr) ? linkAttr : {}; return (0, _renderer.default)("<a>").addClass("dx-item-url").attr(_extends({}, linkAttributes, { href: url })).append(iconContainer).append(textContainer) } _getIconContainer(itemData) { if (!itemData.icon) { return } const $imageContainer = (0, _icon.getImageContainer)(itemData.icon); if ($imageContainer.is("img")) { var _this$NAME; const componentName = null !== (_this$NAME = this.NAME) && void 0 !== _this$NAME && _this$NAME.startsWith("dxPrivateComponent") ? "" : `${this.NAME} `; $imageContainer.attr("alt", `${componentName}item icon`) } return $imageContainer } _getTextContainer(itemData) { return (0, _renderer.default)("<span>").text(itemData.text) } _initAccessors() { const that = this; (0, _iterator.each)(this._getAccessors(), ((_, accessor) => { that._compileAccessor(accessor) })); this._compileDisplayGetter() } _getAccessors() { return ["key", "selected", "items", "disabled", "parentId", "expanded"] } _getChildNodes(node) { const that = this; const arr = []; (0, _iterator.each)(node.internalFields.childrenKeys, ((_, key) => { const childNode = that._dataAdapter.getNodeByKey(key); arr.push(childNode) })); return arr } _hasChildren(node) { return node && node.internalFields.childrenKeys.length } _compileAccessor(optionName) { const getter = `_${optionName}Getter`; const setter = `_${optionName}Setter`; const optionExpr = this.option(`${optionName}Expr`); if (!optionExpr) { this[getter] = _common.noop; this[setter] = _common.noop; return } if ((0, _type.isFunction)(optionExpr)) { this[setter] = function(obj, value) { obj[optionExpr()] = value }; this[getter] = function(obj) { return obj[optionExpr()] }; return } this[getter] = (0, _data.compileGetter)(optionExpr); this[setter] = (0, _data.compileSetter)(optionExpr) } _createDataAdapterAccessors() { const that = this; const accessors = { getters: {}, setters: {} }; (0, _iterator.each)(this._getAccessors(), ((_, accessor) => { const getterName = `_${accessor}Getter`; const setterName = `_${accessor}Setter`; const newAccessor = "parentId" === accessor ? "parentKey" : accessor; accessors.getters[newAccessor] = that[getterName]; accessors.setters[newAccessor] = that[setterName] })); accessors.getters.display = !this._displayGetter ? itemData => itemData.text : this._displayGetter; return accessors } _initMarkup() { super._initMarkup(); this._addWidgetClass() } _addWidgetClass() { this._focusTarget().addClass(this._widgetClass()) } _widgetClass() {} _renderItemFrame(index, itemData, $itemContainer) { const $itemFrame = super._renderItemFrame.apply(this, arguments); $itemFrame.toggleClass("dx-state-disabled", !!this._disabledGetter(itemData)); return $itemFrame } _optionChanged(args) { switch (args.name) { case "displayExpr": case "keyExpr": this._initAccessors(); this._initDynamicTemplates(); this.repaint(); break; case "itemsExpr": case "selectedExpr": case "disabledExpr": case "expandedExpr": case "parentIdExpr": this._initAccessors(); this._initDataAdapter(); this.repaint(); break; case "items": this._initDataAdapter(); super._optionChanged(args); break; default: super._optionChanged(args) } } } var _default = exports.default = HierarchicalCollectionWidget;