UNPKG

devextreme-angular

Version:

Angular UI and visualization components based on DevExtreme widgets

240 lines • 32.6 kB
/*! * devextreme-angular * Version: 20.2.5 * Build date: Fri Jan 15 2021 * * Copyright (c) 2012 - 2021 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 * as tslib_1 from "tslib"; import { ElementRef, NgZone, PLATFORM_ID, Inject, EventEmitter } from '@angular/core'; import { isPlatformServer } from '@angular/common'; import { TransferState, makeStateKey } from '@angular/platform-browser'; import { DxTemplateHost } from './template-host'; import { EmitterHelper, NgEventsStrategy } from './events-strategy'; import { WatcherHelper } from './watcher-helper'; import * as domAdapter from 'devextreme/core/dom_adapter'; import * as events from 'devextreme/events'; import { CollectionNestedOptionContainerImpl } from './nested-option'; var serverStateKey; export var getServerStateKey = function () { if (!serverStateKey) { serverStateKey = makeStateKey('DX_isPlatformServer'); } return serverStateKey; }; var DxComponent = /** @class */ (function () { function DxComponent(element, ngZone, templateHost, watcherHelper, transferState, platformId) { this.element = element; this.ngZone = ngZone; this.watcherHelper = watcherHelper; this.transferState = transferState; this.platformId = platformId; this._initialOptions = {}; this._optionsToUpdate = {}; this.optionChangedHandlers = new EventEmitter(); this.isLinked = true; this.changedOptions = {}; this.removedNestedComponents = []; this.widgetUpdateLocked = false; this.templates = []; templateHost.setHost(this); this._collectionContainerImpl = new CollectionNestedOptionContainerImpl(this._setOption.bind(this)); this.eventHelper = new EmitterHelper(ngZone, this); } DxComponent.prototype._initTemplates = function () { if (this.templates.length) { var initialTemplates_1 = {}; this.templates.forEach(function (template) { initialTemplates_1[template.name] = template; }); this.instance.option('integrationOptions.templates', initialTemplates_1); } }; DxComponent.prototype._initEvents = function () { var _this = this; this.instance.on('optionChanged', function (e) { _this.changedOptions[e.name] = e.value; var value = e.name === e.fullName ? e.value : e.component.option(e.name); _this.eventHelper.fireNgEvent(e.name + 'Change', [value]); _this.optionChangedHandlers.emit(e); }); }; DxComponent.prototype._initOptions = function () { this._initialOptions.integrationOptions.watchMethod = this.watcherHelper.getWatchMethod(); }; DxComponent.prototype._initPlatform = function () { if (this.transferState.hasKey(getServerStateKey())) { this._initialOptions.integrationOptions.renderedOnServer = this.transferState.get(getServerStateKey(), null); } else if (isPlatformServer(this.platformId)) { this.transferState.set(getServerStateKey(), true); } }; DxComponent.prototype._createEventEmitters = function (events) { var _this = this; var zone = this.ngZone; this.eventHelper.createEmitters(events); this._initialOptions.eventsStrategy = function (instance) { var strategy = new NgEventsStrategy(instance, zone); events.filter(function (event) { return event.subscribe; }).forEach(function (event) { strategy.addEmitter(event.subscribe, _this[event.emit]); }); return strategy; }; this._initialOptions.nestedComponentOptions = function (component) { return { eventsStrategy: function (instance) { return new NgEventsStrategy(instance, zone); }, nestedComponentOptions: component.option('nestedComponentOptions') }; }; }; DxComponent.prototype._shouldOptionChange = function (name, value) { if (this.changedOptions.hasOwnProperty(name)) { var prevValue = this.changedOptions[name]; delete this.changedOptions[name]; return value !== prevValue; } return true; }; DxComponent.prototype.clearChangedOptions = function () { this.changedOptions = {}; }; DxComponent.prototype._getOption = function (name) { return this.instance ? this.instance.option(name) : this._initialOptions[name]; }; DxComponent.prototype.lockWidgetUpdate = function () { if (!this.widgetUpdateLocked && this.instance) { this.instance.beginUpdate(); this.widgetUpdateLocked = true; } }; DxComponent.prototype.unlockWidgetUpdate = function () { if (this.widgetUpdateLocked) { this.widgetUpdateLocked = false; this.instance.endUpdate(); } }; DxComponent.prototype._setOption = function (name, value) { this.lockWidgetUpdate(); if (!this._shouldOptionChange(name, value)) { return; } if (this.instance) { this.instance.option(name, value); } else { this._initialOptions[name] = value; } }; DxComponent.prototype._createWidget = function (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 = {}; }; DxComponent.prototype._destroyWidget = function () { this.removedNestedComponents = []; if (this.instance) { var element = this.instance.element(); events.triggerHandler(element, 'dxremove', { _angularIntegration: true }); this.instance.dispose(); domAdapter.removeElement(element); } }; DxComponent.prototype.ngOnChanges = function (changes) { for (var key in changes) { var change = changes[key]; if (change.currentValue !== this[key]) { this._optionsToUpdate[key] = changes[key].currentValue; } } }; DxComponent.prototype.ngOnInit = function () { this._createWidget(this.element.nativeElement); }; DxComponent.prototype.ngDoCheck = function () { this.applyOptions(); }; DxComponent.prototype.ngAfterContentChecked = function () { this.applyOptions(); this.resetOptions(); this.unlockWidgetUpdate(); }; DxComponent.prototype.ngAfterViewInit = function () { this._initTemplates(); this.instance.endUpdate(); this.recreatedNestedComponents = []; }; DxComponent.prototype.applyOptions = function () { if (Object.keys(this._optionsToUpdate).length) { if (this.instance) { this.instance.option(this._optionsToUpdate); } this._optionsToUpdate = {}; } }; DxComponent.prototype.resetOptions = function (collectionName) { var _this = this; if (this.instance) { this.removedNestedComponents.filter(function (option) { return option && !_this.isRecreated(option) && collectionName ? option.startsWith(collectionName) : true; }) .forEach(function (option) { _this.instance.resetOption(option); }); this.removedNestedComponents = []; this.recreatedNestedComponents = []; } }; DxComponent.prototype.isRecreated = function (name) { return this.recreatedNestedComponents && this.recreatedNestedComponents.some(function (nestedComponent) { return nestedComponent.getOptionPath() === name; }); }; DxComponent.prototype.setTemplate = function (template) { this.templates.push(template); }; DxComponent.prototype.setChildren = function (propertyName, items) { this.resetOptions(propertyName); return this._collectionContainerImpl.setChildren(propertyName, items); }; DxComponent = tslib_1.__decorate([ tslib_1.__param(5, Inject(PLATFORM_ID)), tslib_1.__metadata("design:paramtypes", [ElementRef, NgZone, DxTemplateHost, WatcherHelper, TransferState, Object]) ], DxComponent); return DxComponent; }()); export { DxComponent }; var DxComponentExtension = /** @class */ (function (_super) { tslib_1.__extends(DxComponentExtension, _super); function DxComponentExtension() { return _super !== null && _super.apply(this, arguments) || this; } DxComponentExtension.prototype.createInstance = function (element) { this._createWidget(element); }; DxComponentExtension.prototype.ngOnInit = function () { }; DxComponentExtension.prototype.ngAfterViewInit = function () { this._createWidget(this.element.nativeElement); this.instance.endUpdate(); }; return DxComponentExtension; }(DxComponent)); export { DxComponentExtension }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"ng://devextreme-angular/core/","sources":["component.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\n * devextreme-angular\n * Version: 20.2.5\n * Build date: Fri Jan 15 2021\n *\n * Copyright (c) 2012 - 2021 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    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} from '@angular/core';\r\n\r\nimport { isPlatformServer } from '@angular/common';\r\nimport { TransferState, makeStateKey } from '@angular/platform-browser';\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\nimport * as domAdapter from 'devextreme/core/dom_adapter';\r\nimport * as events from 'devextreme/events';\r\n\r\nimport {\r\n    INestedOptionContainer,\r\n    ICollectionNestedOption,\r\n    ICollectionNestedOptionContainer,\r\n    CollectionNestedOptionContainerImpl\r\n} from './nested-option';\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\nexport abstract class DxComponent implements OnChanges, OnInit, DoCheck, AfterContentChecked, AfterViewInit,\r\n    INestedOptionContainer, ICollectionNestedOptionContainer, IDxTemplateHost {\r\n    private _initialOptions: any = {};\r\n    protected _optionsToUpdate: any = {};\r\n    private _collectionContainerImpl: ICollectionNestedOptionContainer;\r\n    eventHelper: EmitterHelper;\r\n    optionChangedHandlers: EventEmitter<any> = new EventEmitter();\r\n    templates: DxTemplateDirective[];\r\n    instance: any;\r\n    isLinked = true;\r\n    changedOptions = {};\r\n    removedNestedComponents = [];\r\n    recreatedNestedComponents: any[];\r\n    widgetUpdateLocked = false;\r\n\r\n    private _initTemplates() {\r\n        if (this.templates.length) {\r\n            let initialTemplates = {};\r\n            this.templates.forEach(template => {\r\n                initialTemplates[template.name] = template;\r\n            });\r\n            this.instance.option('integrationOptions.templates', initialTemplates);\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            let 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) => { return 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            let element = this.instance.element();\r\n            events.triggerHandler(element, 'dxremove', { _angularIntegration: true });\r\n            this.instance.dispose();\r\n            domAdapter.removeElement(element);\r\n        }\r\n    }\r\n\r\n    constructor(protected element: ElementRef,\r\n        private ngZone: NgZone,\r\n        templateHost: DxTemplateHost,\r\n        private watcherHelper: WatcherHelper,\r\n        private transferState: TransferState,\r\n        @Inject(PLATFORM_ID) private platformId: any) {\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 (let key in changes) {\r\n            let 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._initTemplates();\r\n        this.instance.endUpdate();\r\n        this.recreatedNestedComponents = [];\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    }\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\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"]}