UNPKG

devextreme-angular

Version:

Angular UI and visualization components based on DevExtreme widgets

217 lines 30 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 { EventEmitter } from '@angular/core'; import { DX_TEMPLATE_WRAPPER_CLASS } from './template'; import { getElement } from './utils'; import render from 'devextreme/core/renderer'; import * as events from 'devextreme/events'; import * as domAdapter from 'devextreme/core/dom_adapter'; const VISIBILITY_CHANGE_SELECTOR = 'dx-visibility-change-handler'; export class BaseNestedOption { constructor() { this._initialOptions = {}; this._collectionContainerImpl = new CollectionNestedOptionContainerImpl(this._setOption.bind(this), this._filterItems.bind(this)); } _optionChangedHandler(e) { let fullOptionPath = this._fullOptionPath(); if (e.fullName.indexOf(fullOptionPath) === 0) { let optionName = e.fullName.slice(fullOptionPath.length); let 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); } else { 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) => { return item !== this; }); } get instance() { return this._host && 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; } } export class CollectionNestedOptionContainerImpl { constructor(_setOption, _filterItems) { this._setOption = _setOption; this._filterItems = _filterItems; this._activatedQueries = {}; } setChildren(propertyName, items) { if (this._filterItems) { items = this._filterItems(items); } if (items.length) { this._activatedQueries[propertyName] = true; } if (this._activatedQueries[propertyName]) { let 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() + '.'; } } export class CollectionNestedOption extends BaseNestedOption { _fullOptionPath() { return `${this._getOptionPath()}[${this._index}].`; } get _value() { return this._initialOptions; } get isLinked() { return this._index !== undefined && !!this.instance && this._host.isLinked; } } let triggerShownEvent = function (element) { let 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++) { events.triggerHandler(changeHandlers[i], 'dxshown'); } }; const ɵ0 = triggerShownEvent; export function extractTemplate(option, element, renderer, document) { if (!option.template === undefined || !element.nativeElement.hasChildNodes()) { return; } let childNodes = [].slice.call(element.nativeElement.childNodes); let userContent = childNodes.filter((n) => { if (n.tagName) { let tagNamePrefix = n.tagName.toLowerCase().substr(0, 3); return !(tagNamePrefix === 'dxi' || tagNamePrefix === 'dxo'); } else { return n.nodeName !== '#comment' && n.textContent.replace(/\s/g, '').length; } }); if (!userContent.length) { return; } option.template = { render: (renderData) => { let result = element.nativeElement; domAdapter.setClass(result, DX_TEMPLATE_WRAPPER_CLASS, true); if (renderData.container) { let container = getElement(renderData.container); let resultInContainer = container.contains(element.nativeElement); renderer.appendChild(container, element.nativeElement); if (!resultInContainer) { let resultInBody = document.body.contains(container); if (resultInBody) { triggerShownEvent(result); } } } return result; } }; } export class NestedOptionHost { getHost() { return this._host; } setHost(host, optionPath) { this._host = host; this._optionPath = optionPath || (() => ''); } setNestedOption(nestedOption) { nestedOption.setHost(this._host, this._optionPath); } } export { ɵ0 }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nested-option.js","sourceRoot":"ng://devextreme-angular/core/","sources":["nested-option.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 { QueryList, ElementRef, Renderer2, EventEmitter } from '@angular/core';\r\n\r\nimport { DX_TEMPLATE_WRAPPER_CLASS } from './template';\r\nimport { getElement } from './utils';\r\n\r\nimport render from 'devextreme/core/renderer';\r\nimport * as events from 'devextreme/events';\r\nimport * as domAdapter from 'devextreme/core/dom_adapter';\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 interface IOptionPathGetter { (): string; }\r\n\r\nexport abstract class BaseNestedOption implements INestedOptionContainer, ICollectionNestedOptionContainer {\r\n    protected _host: INestedOptionContainer;\r\n    protected _hostOptionPath: IOptionPathGetter;\r\n    private _collectionContainerImpl: ICollectionNestedOptionContainer;\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        let fullOptionPath = this._fullOptionPath();\r\n\r\n        if (e.fullName.indexOf(fullOptionPath) === 0) {\r\n            let optionName = e.fullName.slice(fullOptionPath.length);\r\n            let 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        } else {\r\n            return this._initialOptions[name];\r\n        }\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) => { return item !== this; });\r\n    }\r\n\r\n    get instance() {\r\n        return this._host && 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>);\r\n}\r\n\r\nexport class CollectionNestedOptionContainerImpl implements ICollectionNestedOptionContainer {\r\n    private _activatedQueries = {};\r\n\r\n    constructor(private _setOption: Function, private _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            let 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\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\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\nlet triggerShownEvent = function(element) {\r\n    let 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        events.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    let childNodes = [].slice.call(element.nativeElement.childNodes);\r\n    let userContent = childNodes.filter((n) => {\r\n        if (n.tagName) {\r\n            let tagNamePrefix = n.tagName.toLowerCase().substr(0, 3);\r\n            return !(tagNamePrefix === 'dxi' || tagNamePrefix === 'dxo');\r\n        } else {\r\n            return n.nodeName !== '#comment' && n.textContent.replace(/\\s/g, '').length;\r\n        }\r\n    });\r\n    if (!userContent.length) {\r\n        return;\r\n    }\r\n\r\n    option.template = {\r\n        render: (renderData) => {\r\n            let result = element.nativeElement;\r\n\r\n            domAdapter.setClass(result, DX_TEMPLATE_WRAPPER_CLASS, true);\r\n\r\n            if (renderData.container) {\r\n                let container = getElement(renderData.container);\r\n                let resultInContainer = container.contains(element.nativeElement);\r\n\r\n                renderer.appendChild(container, element.nativeElement);\r\n\r\n                if (!resultInContainer) {\r\n                    let 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    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    }\r\n}\r\n"]}