fundamental-ngx
Version:
SAP Fiori Fundamentals, implemented in Angular
210 lines • 20.9 kB
JavaScript
/**
* @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"]}