UNPKG

fundamental-ngx

Version:

SAP Fiori Fundamentals, implemented in Angular

202 lines 21.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { ComponentFactoryResolver, Injectable, ApplicationRef, Injector } from '@angular/core'; import { ModalComponent } from '../modal.component'; import { ModalBackdrop } from '../modal-utils/modal-backdrop'; import { ModalContainer } from '../modal-utils/modal-container'; import { ModalConfig } from '../modal-utils/modal-config'; import { ModalRef } from '../modal-utils/modal-ref'; import { ModalInjector } from '../modal-utils/modal-injector'; /** * Service used to dynamically generate a modal. */ export class ModalService { /** * @hidden * @param {?} componentFactoryResolver * @param {?} appRef * @param {?} injector */ constructor(componentFactoryResolver, appRef, injector) { this.componentFactoryResolver = componentFactoryResolver; this.appRef = appRef; this.injector = injector; this.modals = []; } /** * Status of the modal service. * Returns true if there are open modals, false otherwise. * @return {?} */ hasOpenModals() { return this.modals && this.modals.length > 0; } /** * Dismisses all currently open modals. * @return {?} */ dismissAll() { this.modals.forEach((/** * @param {?} item * @return {?} */ item => { this.destroyModalComponent(item.modalRef); })); } /** * Opens a modal component with a content of type TemplateRef or a component type. * @param {?} contentType Content of the modal component. * @param {?=} modalConfig Configuration of the modal component. * @return {?} */ open(contentType, modalConfig = new ModalConfig()) { // Get default values from model modalConfig = Object.assign(new ModalConfig(), modalConfig); // Setup injectable data /** @type {?} */ const configMap = new WeakMap(); /** @type {?} */ const modalRef = new ModalRef(); modalRef.data = (modalConfig ? modalConfig.data : undefined); configMap.set(ModalRef, modalRef); // Prepare container /** @type {?} */ const containerFactory = this.componentFactoryResolver.resolveComponentFactory(ModalContainer); /** @type {?} */ const containerRef = containerFactory.create(this.injector); this.appRef.attachView(containerRef.hostView); // Prepare modal /** @type {?} */ const componentFactory = this.componentFactoryResolver.resolveComponentFactory(ModalComponent); /** @type {?} */ const componentRef = componentFactory.create(new ModalInjector(this.injector, configMap)); this.appRef.attachView(componentRef.hostView); // Prepare backdrop /** @type {?} */ let backdropRef; if (modalConfig.hasBackdrop) { /** @type {?} */ const backdropFactory = this.componentFactoryResolver.resolveComponentFactory(ModalBackdrop); backdropRef = backdropFactory.create(new ModalInjector(this.injector, configMap)); this.appRef.attachView(backdropRef.hostView); } // Subscribe to close of modalRef /** @type {?} */ const refSub = modalRef.afterClosed.subscribe((/** * @return {?} */ () => { this.destroyModalComponent(componentRef); refSub.unsubscribe(); }), (/** * @return {?} */ () => { this.destroyModalComponent(componentRef); refSub.unsubscribe(); })); // Assign component attributes /** @type {?} */ const configObj = Object.assign({}, modalConfig); Object.keys(configObj).forEach((/** * @param {?} key * @return {?} */ key => { if (key !== 'data') { componentRef.instance[key] = configObj[key]; if (modalConfig.hasBackdrop) { backdropRef.instance[key] = configObj[key]; } } })); componentRef.instance.childComponentType = contentType; // Sizing componentRef.location.nativeElement.style.minWidth = configObj.minWidth; componentRef.location.nativeElement.style.minHeight = configObj.minHeight; componentRef.location.nativeElement.style.maxWidth = configObj.maxWidth; componentRef.location.nativeElement.style.maxHeight = configObj.maxHeight; componentRef.location.nativeElement.style.width = configObj.width; componentRef.location.nativeElement.style.height = configObj.height; // Render container /** @type {?} */ const containerEl = (/** @type {?} */ (((/** @type {?} */ (containerRef.hostView))).rootNodes[0])); document.body.appendChild(containerEl); // Render backdrop if (modalConfig.hasBackdrop) { /** @type {?} */ const domBackdrop = (/** @type {?} */ (((/** @type {?} */ (backdropRef.hostView))).rootNodes[0])); containerRef.location.nativeElement.appendChild(domBackdrop); } // Render modal /** @type {?} */ const domElement = (/** @type {?} */ (((/** @type {?} */ (componentRef.hostView))).rootNodes[0])); containerRef.location.nativeElement.appendChild(domElement); this.modals.push({ modalRef: componentRef, backdropRef: backdropRef, containerRef: containerRef }); return modalRef; } /** * @private * @param {?} modal * @return {?} */ destroyModalComponent(modal) { /** @type {?} */ const arrayRef = this.modals.find((/** * @param {?} item * @return {?} */ (item) => item.modalRef === modal)); /** @type {?} */ const indexOf = this.modals.indexOf(arrayRef); this.appRef.detachView(arrayRef.modalRef.hostView); this.appRef.detachView(arrayRef.containerRef.hostView); arrayRef.containerRef.destroy(); arrayRef.modalRef.destroy(); if (arrayRef.backdropRef) { this.appRef.detachView(arrayRef.backdropRef.hostView); arrayRef.backdropRef.destroy(); } this.modals[indexOf] = null; this.modals = this.modals.filter((/** * @param {?} item * @return {?} */ item => item !== null && item !== undefined)); } } ModalService.decorators = [ { type: Injectable } ]; /** @nocollapse */ ModalService.ctorParameters = () => [ { type: ComponentFactoryResolver }, { type: ApplicationRef }, { type: Injector } ]; if (false) { /** * @type {?} * @private */ ModalService.prototype.modals; /** * @type {?} * @private */ ModalService.prototype.componentFactoryResolver; /** * @type {?} * @private */ ModalService.prototype.appRef; /** * @type {?} * @private */ ModalService.prototype.injector; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.service.js","sourceRoot":"ng://fundamental-ngx/","sources":["lib/modal/modal-service/modal.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ComponentFactoryResolver,\n    Injectable,\n    ApplicationRef,\n    Injector,\n    EmbeddedViewRef,\n    ComponentRef,\n    Type,\n    TemplateRef\n} from '@angular/core';\nimport { ModalComponent } from '../modal.component';\nimport { ModalBackdrop } from '../modal-utils/modal-backdrop';\nimport { ModalContainer } from '../modal-utils/modal-container';\nimport { ModalConfig } from '../modal-utils/modal-config';\nimport { ModalRef } from '../modal-utils/modal-ref';\nimport { ModalInjector } from '../modal-utils/modal-injector';\n\n/**\n * Service used to dynamically generate a modal.\n */\n@Injectable()\nexport class ModalService {\n    private modals: {\n        modalRef: ComponentRef<ModalComponent>,\n        backdropRef?: ComponentRef<ModalBackdrop>,\n        containerRef?: ComponentRef<ModalContainer>\n    }[] = [];\n\n    /** @hidden */\n    constructor(private componentFactoryResolver: ComponentFactoryResolver,\n                private appRef: ApplicationRef,\n                private injector: Injector) {}\n\n    /**\n     * Status of the modal service.\n     * Returns true if there are open modals, false otherwise.\n     */\n    public hasOpenModals(): boolean {\n        return this.modals && this.modals.length > 0;\n    }\n\n    /**\n     * Dismisses all currently open modals.\n     */\n    public dismissAll(): void {\n        this.modals.forEach(item => {\n            this.destroyModalComponent(item.modalRef);\n        });\n    }\n\n    /**\n     * Opens a modal component with a content of type TemplateRef or a component type.\n     * @param contentType Content of the modal component.\n     * @param modalConfig Configuration of the modal component.\n     */\n    public open(contentType: Type<any> | TemplateRef<any>, modalConfig: ModalConfig = new ModalConfig()): ModalRef {\n\n        // Get default values from model\n        modalConfig = Object.assign(new ModalConfig(), modalConfig);\n\n        // Setup injectable data\n        const configMap = new WeakMap();\n        const modalRef = new ModalRef();\n        modalRef.data = (modalConfig ? modalConfig.data : undefined);\n        configMap.set(ModalRef, modalRef);\n\n        // Prepare container\n        const containerFactory = this.componentFactoryResolver.resolveComponentFactory(ModalContainer);\n        const containerRef = containerFactory.create(this.injector);\n        this.appRef.attachView(containerRef.hostView);\n\n        // Prepare modal\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(ModalComponent);\n        const componentRef = componentFactory.create(new ModalInjector(this.injector, configMap));\n        this.appRef.attachView(componentRef.hostView);\n\n        // Prepare backdrop\n        let backdropRef;\n        if (modalConfig.hasBackdrop) {\n            const backdropFactory = this.componentFactoryResolver.resolveComponentFactory(ModalBackdrop);\n            backdropRef = backdropFactory.create(new ModalInjector(this.injector, configMap));\n            this.appRef.attachView(backdropRef.hostView);\n        }\n\n        // Subscribe to close of modalRef\n        const refSub = modalRef.afterClosed.subscribe(() => {\n            this.destroyModalComponent(componentRef);\n            refSub.unsubscribe();\n        }, () => {\n            this.destroyModalComponent(componentRef);\n            refSub.unsubscribe();\n        });\n\n        // Assign component attributes\n        const configObj = Object.assign({}, modalConfig);\n        Object.keys(configObj).forEach(key => {\n            if (key !== 'data') {\n                componentRef.instance[key] = configObj[key];\n\n                if (modalConfig.hasBackdrop) {\n                    backdropRef.instance[key] = configObj[key];\n                }\n            }\n        });\n        componentRef.instance.childComponentType = contentType;\n\n        // Sizing\n        componentRef.location.nativeElement.style.minWidth = configObj.minWidth;\n        componentRef.location.nativeElement.style.minHeight = configObj.minHeight;\n        componentRef.location.nativeElement.style.maxWidth = configObj.maxWidth;\n        componentRef.location.nativeElement.style.maxHeight = configObj.maxHeight;\n        componentRef.location.nativeElement.style.width = configObj.width;\n        componentRef.location.nativeElement.style.height = configObj.height;\n\n        // Render container\n        const containerEl = (containerRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n        document.body.appendChild(containerEl);\n\n        // Render backdrop\n        if (modalConfig.hasBackdrop) {\n            const domBackdrop = (backdropRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n            containerRef.location.nativeElement.appendChild(domBackdrop);\n        }\n\n        // Render modal\n        const domElement = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n        containerRef.location.nativeElement.appendChild(domElement);\n\n        this.modals.push({modalRef: componentRef, backdropRef: backdropRef, containerRef: containerRef});\n        return modalRef;\n    }\n\n    private destroyModalComponent(modal: ComponentRef<ModalComponent>) {\n        const arrayRef = this.modals.find((item) => item.modalRef === modal);\n        const indexOf = this.modals.indexOf(arrayRef);\n        this.appRef.detachView(arrayRef.modalRef.hostView);\n        this.appRef.detachView(arrayRef.containerRef.hostView);\n        arrayRef.containerRef.destroy();\n        arrayRef.modalRef.destroy();\n\n        if (arrayRef.backdropRef) {\n            this.appRef.detachView(arrayRef.backdropRef.hostView);\n            arrayRef.backdropRef.destroy();\n        }\n\n        this.modals[indexOf] = null;\n        this.modals = this.modals.filter(item => item !== null && item !== undefined);\n    }\n\n}\n"]}