UNPKG

fundamental-ngx

Version:

SAP Fiori Fundamentals, implemented in Angular

210 lines 20.9 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'; var ModalService = /** @class */ (function () { function ModalService(componentFactoryResolver, appRef, injector) { this.componentFactoryResolver = componentFactoryResolver; this.appRef = appRef; this.injector = injector; this.modals = []; } /** * @return {?} */ ModalService.prototype.hasOpenModals = /** * @return {?} */ function () { return this.modals && this.modals.length > 0; }; /** * @return {?} */ ModalService.prototype.dismissAll = /** * @return {?} */ function () { var _this = this; this.modals.forEach((/** * @param {?} item * @return {?} */ function (item) { _this.destroyModalComponent(item.modalRef); })); }; /** * @param {?} contentType * @param {?=} modalConfig * @return {?} */ ModalService.prototype.open = /** * @param {?} contentType * @param {?=} modalConfig * @return {?} */ function (contentType, modalConfig) { var _this = this; if (modalConfig === void 0) { modalConfig = new ModalConfig(); } // Get default values from model modalConfig = Object.assign(new ModalConfig(), modalConfig); // Setup injectable data /** @type {?} */ var configMap = new WeakMap(); /** @type {?} */ var modalRef = new ModalRef(); modalRef.data = (modalConfig ? modalConfig.data : undefined); configMap.set(ModalRef, modalRef); // Prepare container /** @type {?} */ var containerFactory = this.componentFactoryResolver.resolveComponentFactory(ModalContainer); /** @type {?} */ var containerRef = containerFactory.create(this.injector); this.appRef.attachView(containerRef.hostView); // Prepare modal /** @type {?} */ var componentFactory = this.componentFactoryResolver.resolveComponentFactory(ModalComponent); /** @type {?} */ var componentRef = componentFactory.create(new ModalInjector(this.injector, configMap)); this.appRef.attachView(componentRef.hostView); // Prepare backdrop /** @type {?} */ var backdropRef; if (modalConfig.hasBackdrop) { /** @type {?} */ var backdropFactory = this.componentFactoryResolver.resolveComponentFactory(ModalBackdrop); backdropRef = backdropFactory.create(new ModalInjector(this.injector, configMap)); this.appRef.attachView(backdropRef.hostView); } // Subscribe to close of modalRef /** @type {?} */ var refSub = modalRef.afterClosed.subscribe((/** * @return {?} */ function () { _this.destroyModalComponent(componentRef); refSub.unsubscribe(); }), (/** * @return {?} */ function () { _this.destroyModalComponent(componentRef); refSub.unsubscribe(); })); // Assign component attributes /** @type {?} */ var configObj = Object.assign({}, modalConfig); Object.keys(configObj).forEach((/** * @param {?} key * @return {?} */ function (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 {?} */ var containerEl = (/** @type {?} */ (((/** @type {?} */ (containerRef.hostView))).rootNodes[0])); document.body.appendChild(containerEl); // Render backdrop if (modalConfig.hasBackdrop) { /** @type {?} */ var domBackdrop = (/** @type {?} */ (((/** @type {?} */ (backdropRef.hostView))).rootNodes[0])); containerRef.location.nativeElement.appendChild(domBackdrop); } // Render modal /** @type {?} */ var 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 {?} */ ModalService.prototype.destroyModalComponent = /** * @private * @param {?} modal * @return {?} */ function (modal) { /** @type {?} */ var arrayRef = this.modals.find((/** * @param {?} item * @return {?} */ function (item) { return item.modalRef === modal; })); /** @type {?} */ var 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 {?} */ function (item) { return item !== null && item !== undefined; })); }; ModalService.decorators = [ { type: Injectable } ]; /** @nocollapse */ ModalService.ctorParameters = function () { return [ { type: ComponentFactoryResolver }, { type: ApplicationRef }, { type: Injector } ]; }; return ModalService; }()); export { ModalService }; 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@Injectable()\nexport class ModalService {\n    private modals: {\n        modalRef: ComponentRef<ModalComponent>,\n        backdropRef?: ComponentRef<ModalBackdrop>,\n        containerRef?: ComponentRef<ModalContainer>\n    }[] = [];\n\n    constructor(private componentFactoryResolver: ComponentFactoryResolver,\n                private appRef: ApplicationRef,\n                private injector: Injector) {}\n\n    public hasOpenModals(): boolean {\n        return this.modals && this.modals.length > 0;\n    }\n\n    public dismissAll(): void {\n        this.modals.forEach(item => {\n            this.destroyModalComponent(item.modalRef);\n        });\n    }\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"]}