devextreme-angular
Version:
Angular UI and visualization components based on DevExtreme widgets
288 lines • 37.5 kB
JavaScript
/*!
* devextreme-angular
* Version: 24.2.6
* Build date: Mon Mar 17 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 { TransferState, makeStateKey, Component, ElementRef, NgZone, PLATFORM_ID, Inject, EventEmitter, } from '@angular/core';
import { isPlatformServer } from '@angular/common';
import domAdapter from 'devextreme/core/dom_adapter';
import { triggerHandler } from 'devextreme/events';
import config from 'devextreme/core/config';
import { DxTemplateHost } from './template-host';
import { EmitterHelper, NgEventsStrategy } from './events-strategy';
import { WatcherHelper } from './watcher-helper';
import { CollectionNestedOptionContainerImpl, } from './nested-option';
import * as i0 from "@angular/core";
import * as i1 from "./template-host";
import * as i2 from "./watcher-helper";
config({
buyNowLink: 'https://go.devexpress.com/Licensing_Installer_Watermark_DevExtremeAngular.aspx',
licensingDocLink: 'https://go.devexpress.com/Licensing_Documentation_DevExtremeAngular.aspx',
});
let serverStateKey;
export const getServerStateKey = () => {
if (!serverStateKey) {
serverStateKey = makeStateKey('DX_isPlatformServer');
}
return serverStateKey;
};
export class DxComponent {
element;
ngZone;
watcherHelper;
transferState;
platformId;
_initialOptions = {};
_optionsToUpdate = {};
_collectionContainerImpl;
eventHelper;
optionChangedHandlers = new EventEmitter();
templates;
instance;
isLinked = true;
changedOptions = {};
removedNestedComponents = [];
recreatedNestedComponents;
widgetUpdateLocked = false;
templateUpdateRequired = false;
_updateTemplates() {
if (this.templates.length && this.templateUpdateRequired) {
const updatedTemplates = {};
this.templates.forEach((template) => {
updatedTemplates[template.name] = template;
});
this.instance.option('integrationOptions.templates', updatedTemplates);
this.templates = Object.values(updatedTemplates);
this.templateUpdateRequired = false;
}
}
_initEvents() {
this.instance.on('optionChanged', (e) => {
this.changedOptions[e.name] = e.value;
const value = e.name === e.fullName ? e.value : e.component.option(e.name);
this.eventHelper.fireNgEvent(`${e.name}Change`, [value]);
this.optionChangedHandlers.emit(e);
});
}
_initOptions() {
this._initialOptions.integrationOptions.watchMethod = this.watcherHelper.getWatchMethod();
}
_initPlatform() {
if (this.transferState.hasKey(getServerStateKey())) {
this._initialOptions.integrationOptions.renderedOnServer = this.transferState.get(getServerStateKey(), null);
}
else if (isPlatformServer(this.platformId)) {
this.transferState.set(getServerStateKey(), true);
}
}
_createEventEmitters(events) {
const zone = this.ngZone;
this.eventHelper.createEmitters(events);
this._initialOptions.eventsStrategy = (instance) => {
const strategy = new NgEventsStrategy(instance, zone);
events.filter((event) => event.subscribe).forEach((event) => {
strategy.addEmitter(event.subscribe, this[event.emit]);
});
return strategy;
};
this._initialOptions.nestedComponentOptions = function (component) {
return {
eventsStrategy: (instance) => new NgEventsStrategy(instance, zone),
nestedComponentOptions: component.option('nestedComponentOptions'),
};
};
}
_shouldOptionChange(name, value) {
if (this.changedOptions.hasOwnProperty(name)) {
const prevValue = this.changedOptions[name];
delete this.changedOptions[name];
return value !== prevValue;
}
return true;
}
clearChangedOptions() {
this.changedOptions = {};
}
_getOption(name) {
return this.instance
? this.instance.option(name)
: this._initialOptions[name];
}
lockWidgetUpdate() {
if (!this.widgetUpdateLocked && this.instance) {
this.instance.beginUpdate();
this.widgetUpdateLocked = true;
}
}
unlockWidgetUpdate() {
if (this.widgetUpdateLocked) {
this.widgetUpdateLocked = false;
this.instance.endUpdate();
}
}
_setOption(name, value) {
this.lockWidgetUpdate();
if (!this._shouldOptionChange(name, value)) {
return;
}
if (this.instance) {
this.instance.option(name, value);
}
else {
this._initialOptions[name] = value;
}
}
_createWidget(element) {
this._initialOptions.integrationOptions = {};
this._initPlatform();
this._initOptions();
this._initialOptions.onInitializing = function () {
this.beginUpdate();
};
this.instance = this._createInstance(element, this._initialOptions);
this._initEvents();
this._initialOptions = {};
}
_destroyWidget() {
this.removedNestedComponents = [];
if (this.instance) {
const element = this.instance.element();
triggerHandler(element, 'dxremove', { _angularIntegration: true });
this.instance.dispose();
domAdapter.removeElement(element);
}
}
_setChildren(propertyName, value, className) {
if (this.checkContentChildren(propertyName, value, className)) {
this.setContentChildren(propertyName, value, className);
this.setChildren(propertyName, value);
}
}
constructor(element, ngZone, templateHost, watcherHelper, transferState, platformId) {
this.element = element;
this.ngZone = ngZone;
this.watcherHelper = watcherHelper;
this.transferState = transferState;
this.platformId = platformId;
this.templates = [];
templateHost.setHost(this);
this._collectionContainerImpl = new CollectionNestedOptionContainerImpl(this._setOption.bind(this));
this.eventHelper = new EmitterHelper(ngZone, this);
}
ngOnChanges(changes) {
for (const key in changes) {
const change = changes[key];
if (change.currentValue !== this[key]) {
this._optionsToUpdate[key] = changes[key].currentValue;
}
}
}
ngOnInit() {
this._createWidget(this.element.nativeElement);
}
ngDoCheck() {
this.applyOptions();
}
ngAfterContentChecked() {
this.applyOptions();
this.resetOptions();
this.unlockWidgetUpdate();
}
ngAfterViewInit() {
this._updateTemplates();
this.instance.endUpdate();
this.recreatedNestedComponents = [];
}
ngAfterViewChecked() {
this._updateTemplates();
}
applyOptions() {
if (Object.keys(this._optionsToUpdate).length) {
if (this.instance) {
this.instance.option(this._optionsToUpdate);
}
this._optionsToUpdate = {};
}
}
resetOptions(collectionName) {
if (this.instance) {
this.removedNestedComponents.filter((option) => (option
&& !this.isRecreated(option)
&& collectionName ? option.startsWith(collectionName) : true))
.forEach((option) => {
this.instance.resetOption(option);
});
this.removedNestedComponents = [];
this.recreatedNestedComponents = [];
}
}
isRecreated(name) {
return this.recreatedNestedComponents
&& this.recreatedNestedComponents.some((nestedComponent) => nestedComponent.getOptionPath() === name);
}
setTemplate(template) {
this.templates.push(template);
this.templateUpdateRequired = true;
}
contentChildren = {};
checkContentChildren(propertyName, items, className) {
if (this.contentChildren[propertyName] && this.contentChildren[propertyName] !== className) {
if (items.length > 0) {
if (console && console.warn) {
console.warn(`In ${this.constructor.name},
the nested ${className} and ${this.contentChildren[propertyName]} components are incompatible.
Ensure that all nested components in the content area match.`);
}
}
return false;
}
return true;
}
setContentChildren(propertyName, items, className) {
if (items.length > 0) {
this.contentChildren[propertyName] = className;
}
}
setChildren(propertyName, items) {
this.resetOptions(propertyName);
return this._collectionContainerImpl.setChildren(propertyName, items);
}
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DxComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i1.DxTemplateHost }, { token: i2.WatcherHelper }, { token: i0.TransferState }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DxComponent, selector: "ng-component", usesOnChanges: true, ngImport: i0, template: '', isInline: true });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DxComponent, decorators: [{
type: Component,
args: [{
template: '',
}]
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i1.DxTemplateHost }, { type: i2.WatcherHelper }, { type: i0.TransferState }, { type: undefined, decorators: [{
type: Inject,
args: [PLATFORM_ID]
}] }] });
export class DxComponentExtension extends DxComponent {
createInstance(element) {
this._createWidget(element);
}
ngOnInit() {
}
ngAfterViewInit() {
this._createWidget(this.element.nativeElement);
this.instance.endUpdate();
}
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DxComponentExtension, deps: null, target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DxComponentExtension, selector: "ng-component", usesInheritance: true, ngImport: i0, template: '', isInline: true });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DxComponentExtension, decorators: [{
type: Component,
args: [{
template: '',
}]
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../dist/core/component.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\n * devextreme-angular\n * Version: 24.2.6\n * Build date: Mon Mar 17 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  TransferState,\r\n  makeStateKey,\r\n  Component,\r\n  ElementRef,\r\n  NgZone,\r\n  QueryList,\r\n  SimpleChanges,\r\n  PLATFORM_ID,\r\n  Inject,\r\n  EventEmitter,\r\n\r\n  OnChanges,\r\n  OnInit,\r\n  DoCheck,\r\n  AfterContentChecked,\r\n  AfterViewInit,\r\n  AfterViewChecked,\r\n} from '@angular/core';\r\n\r\nimport { isPlatformServer } from '@angular/common';\r\n\r\nimport domAdapter from 'devextreme/core/dom_adapter';\r\nimport { triggerHandler } from 'devextreme/events';\r\nimport config from 'devextreme/core/config';\r\n\r\nimport { DxTemplateDirective } from './template';\r\nimport { IDxTemplateHost, DxTemplateHost } from './template-host';\r\nimport { EmitterHelper, NgEventsStrategy } from './events-strategy';\r\nimport { WatcherHelper } from './watcher-helper';\r\n\r\nimport {\r\n  INestedOptionContainer,\r\n  ICollectionNestedOption,\r\n  ICollectionNestedOptionContainer,\r\n  CollectionNestedOptionContainerImpl,\r\n} from './nested-option';\r\n\r\nconfig({\r\n  buyNowLink: 'https://go.devexpress.com/Licensing_Installer_Watermark_DevExtremeAngular.aspx',\r\n  licensingDocLink: 'https://go.devexpress.com/Licensing_Documentation_DevExtremeAngular.aspx',\r\n});\r\n\r\nlet serverStateKey;\r\nexport const getServerStateKey = () => {\r\n  if (!serverStateKey) {\r\n    serverStateKey = makeStateKey<any>('DX_isPlatformServer');\r\n  }\r\n\r\n  return serverStateKey;\r\n};\r\n\r\n@Component({\r\n  template: '',\r\n})\r\nexport abstract class DxComponent implements OnChanges, OnInit, DoCheck, AfterContentChecked, AfterViewInit, AfterViewChecked,\r\n    INestedOptionContainer, ICollectionNestedOptionContainer, IDxTemplateHost {\r\n  private _initialOptions: any = {};\r\n\r\n  protected _optionsToUpdate: any = {};\r\n\r\n  private readonly _collectionContainerImpl: ICollectionNestedOptionContainer;\r\n\r\n  eventHelper: EmitterHelper;\r\n\r\n  optionChangedHandlers: EventEmitter<any> = new EventEmitter();\r\n\r\n  templates: DxTemplateDirective[];\r\n\r\n  instance: any;\r\n\r\n  isLinked = true;\r\n\r\n  changedOptions = {};\r\n\r\n  removedNestedComponents: string[] = [];\r\n\r\n  recreatedNestedComponents: any[];\r\n\r\n  widgetUpdateLocked = false;\r\n\r\n  templateUpdateRequired = false;\r\n\r\n  private _updateTemplates() {\r\n    if (this.templates.length && this.templateUpdateRequired) {\r\n      const updatedTemplates = {};\r\n      this.templates.forEach((template) => {\r\n        updatedTemplates[template.name] = template;\r\n      });\r\n      this.instance.option('integrationOptions.templates', updatedTemplates);\r\n      this.templates = Object.values(updatedTemplates);\r\n      this.templateUpdateRequired = false;\r\n    }\r\n  }\r\n\r\n  private _initEvents() {\r\n    this.instance.on('optionChanged', (e) => {\r\n      this.changedOptions[e.name] = e.value;\r\n\r\n      const value = e.name === e.fullName ? e.value : e.component.option(e.name);\r\n      this.eventHelper.fireNgEvent(`${e.name}Change`, [value]);\r\n      this.optionChangedHandlers.emit(e);\r\n    });\r\n  }\r\n\r\n  private _initOptions() {\r\n    this._initialOptions.integrationOptions.watchMethod = this.watcherHelper.getWatchMethod();\r\n  }\r\n\r\n  private _initPlatform() {\r\n    if (this.transferState.hasKey(getServerStateKey())) {\r\n      this._initialOptions.integrationOptions.renderedOnServer = this.transferState.get(getServerStateKey(), null);\r\n    } else if (isPlatformServer(this.platformId)) {\r\n      this.transferState.set(getServerStateKey(), true);\r\n    }\r\n  }\r\n\r\n  protected _createEventEmitters(events) {\r\n    const zone = this.ngZone;\r\n    this.eventHelper.createEmitters(events);\r\n\r\n    this._initialOptions.eventsStrategy = (instance) => {\r\n      const strategy = new NgEventsStrategy(instance, zone);\r\n\r\n      events.filter((event) => event.subscribe).forEach((event) => {\r\n        strategy.addEmitter(event.subscribe, this[event.emit]);\r\n      });\r\n\r\n      return strategy;\r\n    };\r\n\r\n    this._initialOptions.nestedComponentOptions = function (component) {\r\n      return {\r\n        eventsStrategy: (instance) => new NgEventsStrategy(instance, zone),\r\n        nestedComponentOptions: component.option('nestedComponentOptions'),\r\n      };\r\n    };\r\n  }\r\n\r\n  _shouldOptionChange(name: string, value: any) {\r\n    if (this.changedOptions.hasOwnProperty(name)) {\r\n      const prevValue = this.changedOptions[name];\r\n      delete this.changedOptions[name];\r\n\r\n      return value !== prevValue;\r\n    }\r\n    return true;\r\n  }\r\n\r\n  clearChangedOptions() {\r\n    this.changedOptions = {};\r\n  }\r\n\r\n  protected _getOption(name: string) {\r\n    return this.instance\r\n      ? this.instance.option(name)\r\n      : this._initialOptions[name];\r\n  }\r\n\r\n  lockWidgetUpdate() {\r\n    if (!this.widgetUpdateLocked && this.instance) {\r\n      this.instance.beginUpdate();\r\n      this.widgetUpdateLocked = true;\r\n    }\r\n  }\r\n\r\n  unlockWidgetUpdate() {\r\n    if (this.widgetUpdateLocked) {\r\n      this.widgetUpdateLocked = false;\r\n      this.instance.endUpdate();\r\n    }\r\n  }\r\n\r\n  protected _setOption(name: string, value: any) {\r\n    this.lockWidgetUpdate();\r\n\r\n    if (!this._shouldOptionChange(name, value)) {\r\n      return;\r\n    }\r\n\r\n    if (this.instance) {\r\n      this.instance.option(name, value);\r\n    } else {\r\n      this._initialOptions[name] = value;\r\n    }\r\n  }\r\n\r\n  protected abstract _createInstance(element, options);\r\n\r\n  protected _createWidget(element: any) {\r\n    this._initialOptions.integrationOptions = {};\r\n    this._initPlatform();\r\n    this._initOptions();\r\n\r\n    this._initialOptions.onInitializing = function () {\r\n      this.beginUpdate();\r\n    };\r\n    this.instance = this._createInstance(element, this._initialOptions);\r\n    this._initEvents();\r\n    this._initialOptions = {};\r\n  }\r\n\r\n  protected _destroyWidget() {\r\n    this.removedNestedComponents = [];\r\n    if (this.instance) {\r\n      const element = this.instance.element();\r\n      triggerHandler(element, 'dxremove', { _angularIntegration: true });\r\n      this.instance.dispose();\r\n      domAdapter.removeElement(element);\r\n    }\r\n  }\r\n\r\n  protected _setChildren(propertyName, value, className) {\r\n    if (this.checkContentChildren(propertyName, value, className)) {\r\n      this.setContentChildren(propertyName, value, className);\r\n      this.setChildren(propertyName, value);\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    protected element: ElementRef,\r\n    private readonly ngZone: NgZone,\r\n    templateHost: DxTemplateHost,\r\n    private readonly watcherHelper: WatcherHelper,\r\n    private readonly transferState: TransferState,\r\n    @Inject(PLATFORM_ID) private readonly platformId: any,\r\n  ) {\r\n    this.templates = [];\r\n    templateHost.setHost(this);\r\n    this._collectionContainerImpl = new CollectionNestedOptionContainerImpl(this._setOption.bind(this));\r\n    this.eventHelper = new EmitterHelper(ngZone, this);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    for (const key in changes) {\r\n      const change = changes[key];\r\n      if (change.currentValue !== this[key]) {\r\n        this._optionsToUpdate[key] = changes[key].currentValue;\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this._createWidget(this.element.nativeElement);\r\n  }\r\n\r\n  ngDoCheck() {\r\n    this.applyOptions();\r\n  }\r\n\r\n  ngAfterContentChecked() {\r\n    this.applyOptions();\r\n    this.resetOptions();\r\n    this.unlockWidgetUpdate();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this._updateTemplates();\r\n    this.instance.endUpdate();\r\n    this.recreatedNestedComponents = [];\r\n  }\r\n\r\n  ngAfterViewChecked(): void {\r\n    this._updateTemplates();\r\n  }\r\n\r\n  applyOptions() {\r\n    if (Object.keys(this._optionsToUpdate).length) {\r\n      if (this.instance) {\r\n        this.instance.option(this._optionsToUpdate);\r\n      }\r\n      this._optionsToUpdate = {};\r\n    }\r\n  }\r\n\r\n  resetOptions(collectionName?: string) {\r\n    if (this.instance) {\r\n      this.removedNestedComponents.filter((option) => (option\r\n                && !this.isRecreated(option)\r\n                && collectionName ? option.startsWith(collectionName) : true))\r\n        .forEach((option) => {\r\n          this.instance.resetOption(option);\r\n        });\r\n\r\n      this.removedNestedComponents = [];\r\n      this.recreatedNestedComponents = [];\r\n    }\r\n  }\r\n\r\n  isRecreated(name: string): boolean {\r\n    return this.recreatedNestedComponents\r\n            && this.recreatedNestedComponents.some((nestedComponent) => nestedComponent.getOptionPath() === name);\r\n  }\r\n\r\n  setTemplate(template: DxTemplateDirective) {\r\n    this.templates.push(template);\r\n    this.templateUpdateRequired = true;\r\n  }\r\n\r\n  contentChildren = {};\r\n\r\n  checkContentChildren<T>(propertyName: string, items: QueryList<T>, className: string) {\r\n    if (this.contentChildren[propertyName] && this.contentChildren[propertyName] !== className) {\r\n      if (items.length > 0) {\r\n        if (console && console.warn) {\r\n          console.warn(`In ${this.constructor.name}, \r\n          the nested ${className} and ${this.contentChildren[propertyName]} components are incompatible. \r\n          Ensure that all nested components in the content area match.`);\r\n        }\r\n      }\r\n      return false;\r\n    }\r\n    return true;\r\n  }\r\n\r\n  setContentChildren<T>(propertyName: string, items: QueryList<T>, className: string) {\r\n    if (items.length > 0) {\r\n      this.contentChildren[propertyName] = className;\r\n    }\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\r\n@Component({\r\n  template: '',\r\n})\r\nexport abstract class DxComponentExtension extends DxComponent implements OnInit, AfterViewInit {\r\n  createInstance(element: any) {\r\n    this._createWidget(element);\r\n  }\r\n\r\n  ngOnInit() {\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this._createWidget(this.element.nativeElement);\r\n    this.instance.endUpdate();\r\n  }\r\n}\r\n"]}