devextreme-angular
Version:
Angular UI and visualization components based on DevExtreme widgets
240 lines • 32.6 kB
JavaScript
/*!
* 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"]}