102 lines
14 KiB
JavaScript
102 lines
14 KiB
JavaScript
import { Injectable, Inject, createComponent } from '@angular/core';
|
|
import { DomHandler } from 'primeng/dom';
|
|
import { DynamicDialogComponent } from './dynamicdialog';
|
|
import { DynamicDialogInjector } from './dynamicdialog-injector';
|
|
import { DynamicDialogConfig } from './dynamicdialog-config';
|
|
import { DynamicDialogRef } from './dynamicdialog-ref';
|
|
import { DOCUMENT } from '@angular/common';
|
|
import * as i0 from "@angular/core";
|
|
/**
|
|
* Dynamic Dialog component methods.
|
|
* @group Service
|
|
*/
|
|
export class DialogService {
|
|
appRef;
|
|
injector;
|
|
document;
|
|
dialogComponentRefMap = new Map();
|
|
constructor(appRef, injector, document) {
|
|
this.appRef = appRef;
|
|
this.injector = injector;
|
|
this.document = document;
|
|
}
|
|
/**
|
|
* Displays the dialog using the dynamic dialog object options.
|
|
* @param {*} componentType - Dynamic component for content template.
|
|
* @param {DynamicDialogConfig} config - DynamicDialog object.
|
|
* @returns {DynamicDialogRef} DynamicDialog instance.
|
|
* @group Method
|
|
*/
|
|
open(componentType, config) {
|
|
if (!this.duplicationPermission(componentType, config)) {
|
|
return null;
|
|
}
|
|
const dialogRef = this.appendDialogComponentToBody(config, componentType);
|
|
this.dialogComponentRefMap.get(dialogRef).instance.childComponentType = componentType;
|
|
return dialogRef;
|
|
}
|
|
/**
|
|
* Returns the dynamic dialog component instance.
|
|
* @param {ref} DynamicDialogRef - DynamicDialog instance.
|
|
* @group Method
|
|
*/
|
|
getInstance(ref) {
|
|
return this.dialogComponentRefMap.get(ref).instance;
|
|
}
|
|
appendDialogComponentToBody(config, componentType) {
|
|
const map = new WeakMap();
|
|
map.set(DynamicDialogConfig, config);
|
|
const dialogRef = new DynamicDialogRef();
|
|
map.set(DynamicDialogRef, dialogRef);
|
|
const sub = dialogRef.onClose.subscribe(() => {
|
|
this.dialogComponentRefMap.get(dialogRef).instance.close();
|
|
});
|
|
const destroySub = dialogRef.onDestroy.subscribe(() => {
|
|
this.removeDialogComponentFromBody(dialogRef);
|
|
destroySub.unsubscribe();
|
|
sub.unsubscribe();
|
|
});
|
|
const componentRef = createComponent(DynamicDialogComponent, { environmentInjector: this.appRef.injector, elementInjector: new DynamicDialogInjector(this.injector, map) });
|
|
this.appRef.attachView(componentRef.hostView);
|
|
const domElem = componentRef.hostView.rootNodes[0];
|
|
if (!config.appendTo || config.appendTo === 'body') {
|
|
this.document.body.appendChild(domElem);
|
|
}
|
|
else {
|
|
DomHandler.appendChild(domElem, config.appendTo);
|
|
}
|
|
this.dialogComponentRefMap.set(dialogRef, componentRef);
|
|
return dialogRef;
|
|
}
|
|
removeDialogComponentFromBody(dialogRef) {
|
|
if (!dialogRef || !this.dialogComponentRefMap.has(dialogRef)) {
|
|
return;
|
|
}
|
|
const dialogComponentRef = this.dialogComponentRefMap.get(dialogRef);
|
|
this.appRef.detachView(dialogComponentRef.hostView);
|
|
dialogComponentRef.destroy();
|
|
this.dialogComponentRefMap.delete(dialogRef);
|
|
}
|
|
duplicationPermission(componentType, config) {
|
|
if (config.duplicate) {
|
|
return true;
|
|
}
|
|
let permission = true;
|
|
for (const [key, value] of this.dialogComponentRefMap) {
|
|
if (value.instance.childComponentType === componentType) {
|
|
permission = false;
|
|
break;
|
|
}
|
|
}
|
|
return permission;
|
|
}
|
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: DialogService, deps: [{ token: i0.ApplicationRef }, { token: i0.Injector }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: DialogService });
|
|
}
|
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: DialogService, decorators: [{
|
|
type: Injectable
|
|
}], ctorParameters: () => [{ type: i0.ApplicationRef }, { type: i0.Injector }, { type: Document, decorators: [{
|
|
type: Inject,
|
|
args: [DOCUMENT]
|
|
}] }] });
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialogservice.js","sourceRoot":"","sources":["../../../src/app/components/dynamicdialog/dialogservice.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, ApplicationRef, Injector, Type, EmbeddedViewRef, ComponentRef, Inject, createComponent } from '@angular/core';\nimport { DomHandler } from 'primeng/dom';\nimport { DynamicDialogComponent } from './dynamicdialog';\nimport { DynamicDialogInjector } from './dynamicdialog-injector';\nimport { DynamicDialogConfig } from './dynamicdialog-config';\nimport { DynamicDialogRef } from './dynamicdialog-ref';\nimport { DOCUMENT } from '@angular/common';\nimport { ObjectUtils } from 'primeng/utils';\n/**\n * Dynamic Dialog component methods.\n * @group Service\n */\n@Injectable()\nexport class DialogService {\n    dialogComponentRefMap: Map<DynamicDialogRef<any>, ComponentRef<DynamicDialogComponent>> = new Map();\n\n    constructor(private appRef: ApplicationRef, private injector: Injector, @Inject(DOCUMENT) private document: Document) {}\n    /**\n     * Displays the dialog using the dynamic dialog object options.\n     * @param {*} componentType - Dynamic component for content template.\n     * @param {DynamicDialogConfig} config - DynamicDialog object.\n     * @returns {DynamicDialogRef} DynamicDialog instance.\n     * @group Method\n     */\n    public open<T>(componentType: Type<T>, config: DynamicDialogConfig): DynamicDialogRef<T> {\n        if (!this.duplicationPermission(componentType, config)) {\n            return null;\n        }\n\n        const dialogRef = this.appendDialogComponentToBody<T>(config, componentType);\n\n        this.dialogComponentRefMap.get(dialogRef).instance.childComponentType = componentType;\n\n        return dialogRef;\n    }\n    /**\n     * Returns the dynamic dialog component instance.\n     * @param {ref} DynamicDialogRef - DynamicDialog instance.\n     * @group Method\n     */\n    public getInstance(ref: DynamicDialogRef<any>) {\n        return this.dialogComponentRefMap.get(ref).instance;\n    }\n\n    private appendDialogComponentToBody<T>(config: DynamicDialogConfig, componentType: Type<T>): DynamicDialogRef<T> {\n        const map = new WeakMap();\n        map.set(DynamicDialogConfig, config);\n\n        const dialogRef = new DynamicDialogRef<T>();\n        map.set(DynamicDialogRef, dialogRef);\n\n        const sub = dialogRef.onClose.subscribe(() => {\n            this.dialogComponentRefMap.get(dialogRef).instance.close();\n        });\n\n        const destroySub = dialogRef.onDestroy.subscribe(() => {\n            this.removeDialogComponentFromBody(dialogRef);\n            destroySub.unsubscribe();\n            sub.unsubscribe();\n        });\n\n        const componentRef = createComponent(DynamicDialogComponent, { environmentInjector: this.appRef.injector, elementInjector: new DynamicDialogInjector(this.injector, map) });\n\n        this.appRef.attachView(componentRef.hostView);\n\n        const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n        if (!config.appendTo || config.appendTo === 'body') {\n            this.document.body.appendChild(domElem);\n        } else {\n            DomHandler.appendChild(domElem, config.appendTo);\n        }\n\n        this.dialogComponentRefMap.set(dialogRef, componentRef);\n\n        return dialogRef;\n    }\n\n    private removeDialogComponentFromBody(dialogRef: DynamicDialogRef<any>) {\n        if (!dialogRef || !this.dialogComponentRefMap.has(dialogRef)) {\n            return;\n        }\n\n        const dialogComponentRef = this.dialogComponentRefMap.get(dialogRef);\n        this.appRef.detachView(dialogComponentRef.hostView);\n        dialogComponentRef.destroy();\n        this.dialogComponentRefMap.delete(dialogRef);\n    }\n\n    private duplicationPermission(componentType: Type<any>, config: DynamicDialogConfig): boolean {\n        if (config.duplicate) {\n            return true;\n        }\n        let permission = true;\n        for (const [key, value] of this.dialogComponentRefMap) {\n            if (value.instance.childComponentType === componentType) {\n                permission = false;\n                break;\n            }\n        }\n        return permission;\n    }\n}\n"]}
|