UNPKG

devextreme-angular

Version:

Angular UI and visualization components based on DevExtreme widgets

246 lines 32.3 kB
/*! * devextreme-angular * Version: 25.2.3 * Build date: Fri Dec 12 2025 * * Copyright (c) 2012 - 2025 Developer Express Inc. ALL RIGHTS RESERVED * * This software may be modified and distributed under the terms * of the MIT license. See the LICENSE file in the root of the project for details. * * https://github.com/DevExpress/devextreme-angular */ import { Component, EventEmitter, } from '@angular/core'; import render from 'devextreme/core/renderer'; import { triggerHandler } from 'devextreme/events'; import domAdapter from 'devextreme/core/dom_adapter'; import { getElement } from './utils'; import { warnIfLegacyNestedComponent } from './deprecated-config-warning'; import { DX_TEMPLATE_WRAPPER_CLASS } from './template'; import * as i0 from "@angular/core"; const VISIBILITY_CHANGE_SELECTOR = 'dx-visibility-change-handler'; export class BaseNestedOption { _host; _hostOptionPath; _collectionContainerImpl; _initialOptions = {}; constructor() { this._collectionContainerImpl = new CollectionNestedOptionContainerImpl(this._setOption.bind(this), this._filterItems.bind(this)); } _optionChangedHandler(e) { const fullOptionPath = this._fullOptionPath(); if (e.fullName.indexOf(fullOptionPath) === 0) { const optionName = e.fullName.slice(fullOptionPath.length); const emitter = this[`${optionName}Change`]; if (emitter) { emitter.next(e.value); } } } _createEventEmitters(events) { events.forEach((event) => { this[event.emit] = new EventEmitter(); }); } _getOption(name) { if (this.isLinked) { return this.instance.option(this._fullOptionPath() + name); } return this._initialOptions[name]; } _setOption(name, value) { if (this.isLinked) { const fullPath = this._fullOptionPath() + name; this.instance.option(fullPath, value); } else { this._initialOptions[name] = value; } } _addRemovedOption(name) { if (this.instance && this.removedNestedComponents) { this.removedNestedComponents.push(name); } } _deleteRemovedOptions(name) { if (this.instance && this.removedNestedComponents) { this.removedNestedComponents = this.removedNestedComponents.filter((x) => !x.startsWith(name)); } } _addRecreatedComponent() { if (this.instance && this.recreatedNestedComponents) { this.recreatedNestedComponents.push({ getOptionPath: () => this._getOptionPath() }); } } _getOptionPath() { return this._hostOptionPath() + this._optionPath; } setHost(host, optionPath) { this._host = host; this._hostOptionPath = optionPath; this.optionChangedHandlers.subscribe(this._optionChangedHandler.bind(this)); } setChildren(propertyName, items) { this.resetOptions(propertyName); return this._collectionContainerImpl.setChildren(propertyName, items); } _filterItems(items) { return items.filter((item) => item !== this); } get instance() { return this._host?.instance; } get resetOptions() { return this._host && this._host.resetOptions; } get isRecreated() { return this._host && this._host.isRecreated; } get removedNestedComponents() { return this._host && this._host.removedNestedComponents; } set removedNestedComponents(value) { this._host.removedNestedComponents = value; } get recreatedNestedComponents() { return this._host && this._host.recreatedNestedComponents; } set recreatedNestedComponents(value) { this._host.recreatedNestedComponents = value; } get isLinked() { return !!this.instance && this._host.isLinked; } get optionChangedHandlers() { return this._host && this._host.optionChangedHandlers; } /** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BaseNestedOption, deps: [], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: BaseNestedOption, selector: "ng-component", ngImport: i0, template: '', isInline: true }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BaseNestedOption, decorators: [{ type: Component, args: [{ template: '', }] }], ctorParameters: () => [] }); export class CollectionNestedOptionContainerImpl { _setOption; _filterItems; _activatedQueries = {}; constructor(_setOption, _filterItems) { this._setOption = _setOption; this._filterItems = _filterItems; } setChildren(propertyName, items) { if (this._filterItems) { items = this._filterItems(items); } if (items.length) { this._activatedQueries[propertyName] = true; } if (this._activatedQueries[propertyName]) { const widgetItems = items.map((item, index) => { item._index = index; return item._value; }); this._setOption(propertyName, widgetItems); } } } export class NestedOption extends BaseNestedOption { setHost(host, optionPath) { super.setHost(host, optionPath); this._host[this._optionPath] = this._initialOptions; } _fullOptionPath() { return `${this._getOptionPath()}.`; } /** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NestedOption, deps: null, target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: NestedOption, selector: "ng-component", usesInheritance: true, ngImport: i0, template: '', isInline: true }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: NestedOption, decorators: [{ type: Component, args: [{ template: '', }] }] }); export class CollectionNestedOption extends BaseNestedOption { _index; _fullOptionPath() { return `${this._getOptionPath()}[${this._index}].`; } get _value() { return this._initialOptions; } get isLinked() { return this._index !== undefined && !!this.instance && this._host.isLinked; } /** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CollectionNestedOption, deps: null, target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CollectionNestedOption, selector: "ng-component", usesInheritance: true, ngImport: i0, template: '', isInline: true }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CollectionNestedOption, decorators: [{ type: Component, args: [{ template: '', }] }] }); const triggerShownEvent = function (element) { const changeHandlers = []; if (!render(element).hasClass(VISIBILITY_CHANGE_SELECTOR)) { changeHandlers.push(element); } changeHandlers.push.apply(changeHandlers, element.querySelectorAll(`.${VISIBILITY_CHANGE_SELECTOR}`)); for (let i = 0; i < changeHandlers.length; i++) { triggerHandler(changeHandlers[i], 'dxshown'); } }; export function extractTemplate(option, element, renderer, document) { if (!option.template === undefined || !element.nativeElement.hasChildNodes()) { return; } const childNodes = [].slice.call(element.nativeElement.childNodes); const userContent = childNodes.filter((n) => { if (n.tagName) { const tagNamePrefix = n.tagName.toLowerCase().substr(0, 3); return !(tagNamePrefix === 'dxi' || tagNamePrefix === 'dxo'); } return n.nodeName !== '#comment' && n.textContent.replace(/\s/g, '').length; }); if (!userContent.length) { return; } option.template = { render: (renderData) => { const result = element.nativeElement; domAdapter.setClass(result, DX_TEMPLATE_WRAPPER_CLASS, true); if (renderData.container) { const container = getElement(renderData.container); const resultInContainer = container.contains(element.nativeElement); renderer.appendChild(container, element.nativeElement); if (!resultInContainer) { const resultInBody = document.body.contains(container); if (resultInBody) { triggerShownEvent(result); } } } return result; }, }; } export class NestedOptionHost { _host; _optionPath; getHost() { return this._host; } setHost(host, optionPath) { this._host = host; this._optionPath = optionPath || (() => ''); } setNestedOption(nestedOption) { nestedOption.setHost(this._host, this._optionPath); warnIfLegacyNestedComponent(nestedOption, this._host); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nested-option.js","sourceRoot":"","sources":["../../../../dist/core/nested-option.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\n * devextreme-angular\n * Version: 25.2.3\n * Build date: Fri Dec 12 2025\n *\n * Copyright (c) 2012 - 2025 Developer Express Inc. ALL RIGHTS RESERVED\n *\n * This software may be modified and distributed under the terms\n * of the MIT license. See the LICENSE file in the root of the project for details.\n *\n * https://github.com/DevExpress/devextreme-angular\n */\n\nimport {\r\n  Component, QueryList, ElementRef, Renderer2, EventEmitter,\r\n} from '@angular/core';\r\n\r\nimport render from 'devextreme/core/renderer';\r\nimport { triggerHandler } from 'devextreme/events';\r\nimport domAdapter from 'devextreme/core/dom_adapter';\r\nimport { getElement } from './utils';\r\nimport { warnIfLegacyNestedComponent } from './deprecated-config-warning';\r\nimport { DX_TEMPLATE_WRAPPER_CLASS } from './template';\r\n\r\nconst VISIBILITY_CHANGE_SELECTOR = 'dx-visibility-change-handler';\r\n\r\nexport interface INestedOptionContainer {\r\n  instance: any;\r\n  isLinked: boolean;\r\n  removedNestedComponents: string[];\r\n  optionChangedHandlers: EventEmitter<any>;\r\n  recreatedNestedComponents: any[];\r\n  resetOptions: (collectionName?: string) => void;\r\n  isRecreated: (name: string) => boolean;\r\n}\r\n\r\nexport type IOptionPathGetter = () => string;\r\n\r\n@Component({\r\n  template: '',\r\n})\r\nexport abstract class BaseNestedOption implements INestedOptionContainer, ICollectionNestedOptionContainer {\r\n  protected _host: INestedOptionContainer;\r\n\r\n  protected _hostOptionPath: IOptionPathGetter;\r\n\r\n  private readonly _collectionContainerImpl: ICollectionNestedOptionContainer;\r\n\r\n  protected _initialOptions = {};\r\n\r\n  protected abstract get _optionPath(): string;\r\n  protected abstract _fullOptionPath(): string;\r\n\r\n  constructor() {\r\n    this._collectionContainerImpl = new CollectionNestedOptionContainerImpl(this._setOption.bind(this), this._filterItems.bind(this));\r\n  }\r\n\r\n  protected _optionChangedHandler(e: any) {\r\n    const fullOptionPath = this._fullOptionPath();\r\n\r\n    if (e.fullName.indexOf(fullOptionPath) === 0) {\r\n      const optionName = e.fullName.slice(fullOptionPath.length);\r\n      const emitter = this[`${optionName}Change`];\r\n\r\n      if (emitter) {\r\n        emitter.next(e.value);\r\n      }\r\n    }\r\n  }\r\n\r\n  protected _createEventEmitters(events) {\r\n    events.forEach((event) => {\r\n      this[event.emit] = new EventEmitter();\r\n    });\r\n  }\r\n\r\n  protected _getOption(name: string): any {\r\n    if (this.isLinked) {\r\n      return this.instance.option(this._fullOptionPath() + name);\r\n    }\r\n    return this._initialOptions[name];\r\n  }\r\n\r\n  protected _setOption(name: string, value: any) {\r\n    if (this.isLinked) {\r\n      const fullPath = this._fullOptionPath() + name;\r\n      this.instance.option(fullPath, value);\r\n    } else {\r\n      this._initialOptions[name] = value;\r\n    }\r\n  }\r\n\r\n  protected _addRemovedOption(name: string) {\r\n    if (this.instance && this.removedNestedComponents) {\r\n      this.removedNestedComponents.push(name);\r\n    }\r\n  }\r\n\r\n  protected _deleteRemovedOptions(name: string) {\r\n    if (this.instance && this.removedNestedComponents) {\r\n      this.removedNestedComponents = this.removedNestedComponents.filter((x) => !x.startsWith(name));\r\n    }\r\n  }\r\n\r\n  protected _addRecreatedComponent() {\r\n    if (this.instance && this.recreatedNestedComponents) {\r\n      this.recreatedNestedComponents.push({ getOptionPath: () => this._getOptionPath() });\r\n    }\r\n  }\r\n\r\n  protected _getOptionPath() {\r\n    return this._hostOptionPath() + this._optionPath;\r\n  }\r\n\r\n  setHost(host: INestedOptionContainer, optionPath: IOptionPathGetter) {\r\n    this._host = host;\r\n    this._hostOptionPath = optionPath;\r\n    this.optionChangedHandlers.subscribe(this._optionChangedHandler.bind(this));\r\n  }\r\n\r\n  setChildren<T extends ICollectionNestedOption>(propertyName: string, items: QueryList<T>) {\r\n    this.resetOptions(propertyName);\r\n    return this._collectionContainerImpl.setChildren(propertyName, items);\r\n  }\r\n\r\n  _filterItems(items: QueryList<BaseNestedOption>) {\r\n    return items.filter((item) => item !== this);\r\n  }\r\n\r\n  get instance() {\r\n    return this._host?.instance;\r\n  }\r\n\r\n  get resetOptions() {\r\n    return this._host && this._host.resetOptions;\r\n  }\r\n\r\n  get isRecreated() {\r\n    return this._host && this._host.isRecreated;\r\n  }\r\n\r\n  get removedNestedComponents() {\r\n    return this._host && this._host.removedNestedComponents;\r\n  }\r\n\r\n  set removedNestedComponents(value) {\r\n    this._host.removedNestedComponents = value;\r\n  }\r\n\r\n  get recreatedNestedComponents() {\r\n    return this._host && this._host.recreatedNestedComponents;\r\n  }\r\n\r\n  set recreatedNestedComponents(value) {\r\n    this._host.recreatedNestedComponents = value;\r\n  }\r\n\r\n  get isLinked() {\r\n    return !!this.instance && this._host.isLinked;\r\n  }\r\n\r\n  get optionChangedHandlers() {\r\n    return this._host && this._host.optionChangedHandlers;\r\n  }\r\n}\r\n\r\nexport interface ICollectionNestedOptionContainer {\r\n  setChildren: <T extends ICollectionNestedOption>(propertyName: string, items: QueryList<T>) => any;\r\n}\r\n\r\nexport class CollectionNestedOptionContainerImpl implements ICollectionNestedOptionContainer {\r\n  private _activatedQueries = {};\r\n\r\n  constructor(private readonly _setOption: Function, private readonly _filterItems?: Function) { }\r\n\r\n  setChildren<T extends ICollectionNestedOption>(propertyName: string, items: QueryList<T>) {\r\n    if (this._filterItems) {\r\n      items = this._filterItems(items);\r\n    }\r\n    if (items.length) {\r\n      this._activatedQueries[propertyName] = true;\r\n    }\r\n    if (this._activatedQueries[propertyName]) {\r\n      const widgetItems = items.map((item, index) => {\r\n        item._index = index;\r\n        return item._value;\r\n      });\r\n      this._setOption(propertyName, widgetItems);\r\n    }\r\n  }\r\n}\r\n\r\n@Component({\r\n  template: '',\r\n})\r\nexport abstract class NestedOption extends BaseNestedOption {\r\n  setHost(host: INestedOptionContainer, optionPath: IOptionPathGetter) {\r\n    super.setHost(host, optionPath);\r\n\r\n    this._host[this._optionPath] = this._initialOptions;\r\n  }\r\n\r\n  protected _fullOptionPath() {\r\n    return `${this._getOptionPath()}.`;\r\n  }\r\n}\r\n\r\nexport interface ICollectionNestedOption {\r\n  _index: number;\r\n  _value: object;\r\n}\r\n\r\n@Component({\r\n  template: '',\r\n})\r\nexport abstract class CollectionNestedOption extends BaseNestedOption implements ICollectionNestedOption {\r\n  _index: number;\r\n\r\n  protected _fullOptionPath() {\r\n    return `${this._getOptionPath()}[${this._index}].`;\r\n  }\r\n\r\n  get _value() {\r\n    return this._initialOptions;\r\n  }\r\n\r\n  get isLinked() {\r\n    return this._index !== undefined && !!this.instance && this._host.isLinked;\r\n  }\r\n}\r\n\r\nexport interface IOptionWithTemplate extends BaseNestedOption {\r\n  template: any;\r\n}\r\n\r\nconst triggerShownEvent = function (element) {\r\n  const changeHandlers = [];\r\n\r\n  if (!render(element).hasClass(VISIBILITY_CHANGE_SELECTOR)) {\r\n    changeHandlers.push(element);\r\n  }\r\n\r\n  changeHandlers.push.apply(changeHandlers, element.querySelectorAll(`.${VISIBILITY_CHANGE_SELECTOR}`));\r\n\r\n  for (let i = 0; i < changeHandlers.length; i++) {\r\n    triggerHandler(changeHandlers[i], 'dxshown');\r\n  }\r\n};\r\n\r\nexport function extractTemplate(option: IOptionWithTemplate, element: ElementRef, renderer: Renderer2, document: any) {\r\n  if (!option.template === undefined || !element.nativeElement.hasChildNodes()) {\r\n    return;\r\n  }\r\n\r\n  const childNodes = [].slice.call(element.nativeElement.childNodes);\r\n  const userContent = childNodes.filter((n) => {\r\n    if (n.tagName) {\r\n      const tagNamePrefix = n.tagName.toLowerCase().substr(0, 3);\r\n      return !(tagNamePrefix === 'dxi' || tagNamePrefix === 'dxo');\r\n    }\r\n    return n.nodeName !== '#comment' && n.textContent.replace(/\\s/g, '').length;\r\n  });\r\n  if (!userContent.length) {\r\n    return;\r\n  }\r\n\r\n  option.template = {\r\n    render: (renderData) => {\r\n      const result = element.nativeElement;\r\n\r\n      domAdapter.setClass(result, DX_TEMPLATE_WRAPPER_CLASS, true);\r\n\r\n      if (renderData.container) {\r\n        const container = getElement(renderData.container);\r\n        const resultInContainer = container.contains(element.nativeElement);\r\n\r\n        renderer.appendChild(container, element.nativeElement);\r\n\r\n        if (!resultInContainer) {\r\n          const resultInBody = document.body.contains(container);\r\n\r\n          if (resultInBody) {\r\n            triggerShownEvent(result);\r\n          }\r\n        }\r\n      }\r\n\r\n      return result;\r\n    },\r\n  };\r\n}\r\n\r\nexport class NestedOptionHost {\r\n  private _host: INestedOptionContainer;\r\n\r\n  private _optionPath: IOptionPathGetter;\r\n\r\n  getHost(): INestedOptionContainer {\r\n    return this._host;\r\n  }\r\n\r\n  setHost(host: INestedOptionContainer, optionPath?: IOptionPathGetter) {\r\n    this._host = host;\r\n    this._optionPath = optionPath || (() => '');\r\n  }\r\n\r\n  setNestedOption(nestedOption: BaseNestedOption) {\r\n    nestedOption.setHost(this._host, this._optionPath);\r\n    warnIfLegacyNestedComponent(nestedOption, this._host);\r\n  }\r\n}\r\n"]}