cps-ui-kit 17.12.0 → 17.13.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,4 @@
1
- import { Injectable, Inject } from '@angular/core';
2
- import { DynamicDialogInjector } from 'primeng/dynamicdialog';
1
+ import { Injectable, Inject, createComponent, createEnvironmentInjector } from '@angular/core';
3
2
  import { DOCUMENT } from '@angular/common';
4
3
  import { CpsDialogRef } from './utils/cps-dialog-ref';
5
4
  import { CpsDialogConfig } from './utils/cps-dialog-config';
@@ -12,9 +11,9 @@ import * as i0 from "@angular/core";
12
11
  */
13
12
  export class CpsDialogService {
14
13
  // eslint-disable-next-line no-useless-constructor
15
- constructor(viewContainerRef, injector, document) {
16
- this.viewContainerRef = viewContainerRef;
17
- this.injector = injector;
14
+ constructor(_appRef, _environmentInjector, document) {
15
+ this._appRef = _appRef;
16
+ this._environmentInjector = _environmentInjector;
18
17
  this.document = document;
19
18
  this.dialogComponentRefMap = new Map();
20
19
  }
@@ -55,11 +54,23 @@ export class CpsDialogService {
55
54
  instance.childComponentType = CpsConfirmationComponent;
56
55
  return dialogRef;
57
56
  }
57
+ /**
58
+ * Closes all dialogs.
59
+ * @param {boolean} [force=false] - If true closes all dialogs even if they have disableClose set to true.
60
+ * @group Method
61
+ */
62
+ closeAll(force = false) {
63
+ this.dialogComponentRefMap.forEach((_, key) => {
64
+ if (force) {
65
+ key.destroy();
66
+ }
67
+ else {
68
+ key.close();
69
+ }
70
+ });
71
+ }
58
72
  appendDialogComponentToBody(config) {
59
- const map = new WeakMap();
60
- map.set(CpsDialogConfig, config);
61
73
  const dialogRef = new CpsDialogRef();
62
- map.set(CpsDialogRef, dialogRef);
63
74
  const sub = dialogRef.onClose.subscribe(() => {
64
75
  this.dialogComponentRefMap.get(dialogRef)?.instance.close();
65
76
  });
@@ -68,7 +79,13 @@ export class CpsDialogService {
68
79
  destroySub.unsubscribe();
69
80
  sub.unsubscribe();
70
81
  });
71
- const componentRef = this.viewContainerRef.createComponent(CpsDialogComponent, { injector: new DynamicDialogInjector(this.injector, map) });
82
+ const componentRef = createComponent(CpsDialogComponent, {
83
+ environmentInjector: createEnvironmentInjector([
84
+ { provide: CpsDialogConfig, useValue: config },
85
+ { provide: CpsDialogRef, useValue: dialogRef }
86
+ ], this._environmentInjector)
87
+ });
88
+ this._appRef.attachView(componentRef.hostView);
72
89
  const domElem = componentRef.hostView
73
90
  .rootNodes[0];
74
91
  this.document.body.appendChild(domElem);
@@ -82,18 +99,19 @@ export class CpsDialogService {
82
99
  }
83
100
  const dialogComponentRef = this.dialogComponentRefMap.get(dialogRef);
84
101
  if (dialogComponentRef) {
85
- this.viewContainerRef.detach(this.viewContainerRef.indexOf(dialogComponentRef.hostView));
102
+ this._appRef.detachView(dialogComponentRef.hostView);
86
103
  dialogComponentRef.destroy();
87
104
  this.dialogComponentRefMap.delete(dialogRef);
88
105
  }
89
106
  }
90
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.ViewContainerRef }, { token: i0.Injector }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
91
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService }); }
107
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
108
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, providedIn: 'root' }); }
92
109
  }
93
110
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, decorators: [{
94
- type: Injectable
95
- }], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.Injector }, { type: Document, decorators: [{
111
+ type: Injectable,
112
+ args: [{ providedIn: 'root' }]
113
+ }], ctorParameters: () => [{ type: i0.ApplicationRef }, { type: i0.EnvironmentInjector }, { type: Document, decorators: [{
96
114
  type: Inject,
97
115
  args: [DOCUMENT]
98
116
  }] }] });
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-dialog.service.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/services/cps-dialog/cps-dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Injectable,\n  Injector,\n  Type,\n  EmbeddedViewRef,\n  ComponentRef,\n  Inject,\n  ViewContainerRef\n} from '@angular/core';\nimport { DynamicDialogInjector } from 'primeng/dynamicdialog';\nimport { DOCUMENT } from '@angular/common';\nimport { CpsDialogRef } from './utils/cps-dialog-ref';\nimport { CpsDialogConfig } from './utils/cps-dialog-config';\nimport { CpsDialogComponent } from './internal/components/cps-dialog/cps-dialog.component';\nimport { CpsConfirmationComponent } from './internal/components/cps-confirmation/cps-confirmation.component';\n\n/**\n * Service for showing CpsDialog.\n * @group Services\n */\n@Injectable()\nexport class CpsDialogService {\n  dialogComponentRefMap: Map<CpsDialogRef, ComponentRef<CpsDialogComponent>> =\n    new Map();\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(\n    private viewContainerRef: ViewContainerRef,\n    private injector: Injector,\n    @Inject(DOCUMENT) private document: Document\n  ) {}\n\n  /**\n   * Opens a dialog with a dynamically loaded component.\n   * @param {*} componentType - Dynamic component for content template.\n   * @param {CpsDialogConfig} config - CpsDialogConfig object.\n   * @returns {CpsDialogRef} CpsDialogRef instance.\n   * @group Method\n   */\n  public open(componentType: Type<any>, config: CpsDialogConfig): CpsDialogRef {\n    const dialogRef = this.appendDialogComponentToBody(config);\n\n    const instance = this.dialogComponentRefMap.get(dialogRef)?.instance;\n    if (instance) instance.childComponentType = componentType;\n\n    return dialogRef;\n  }\n\n  /**\n   * Opens a confirmation dialog.\n   * @param {CpsDialogConfig} config - CpsDialogConfig object.\n   * @returns {CpsDialogRef} CpsDialogRef instance.\n   * @group Method\n   */\n  public openConfirmationDialog(config: CpsDialogConfig): CpsDialogRef {\n    if (!config.headerTitle) config.headerTitle = 'Confirm the action';\n    if (!config.headerIcon) config.headerIcon = 'warning';\n    if (!config.headerIconColor) config.headerIconColor = 'calm';\n    if (!config.minWidth) config.minWidth = '400px';\n    if (!config.maxWidth) config.maxWidth = '600px';\n    const dialogRef = this.appendDialogComponentToBody(config);\n\n    const instance = this.dialogComponentRefMap.get(dialogRef)?.instance;\n    if (instance) instance.childComponentType = CpsConfirmationComponent;\n\n    return dialogRef;\n  }\n\n  private appendDialogComponentToBody(config: CpsDialogConfig) {\n    const map = new WeakMap();\n    map.set(CpsDialogConfig, config);\n\n    const dialogRef = new CpsDialogRef();\n    map.set(CpsDialogRef, 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 = this.viewContainerRef.createComponent(\n      CpsDialogComponent,\n      { injector: new DynamicDialogInjector(this.injector, map) }\n    );\n\n    const domElem = (componentRef.hostView as EmbeddedViewRef<any>)\n      .rootNodes[0] as HTMLElement;\n    this.document.body.appendChild(domElem);\n\n    this.dialogComponentRefMap.set(dialogRef, componentRef);\n    dialogRef._setContainerInstance(componentRef.instance);\n\n    return dialogRef;\n  }\n\n  private removeDialogComponentFromBody(dialogRef: CpsDialogRef) {\n    if (!dialogRef || !this.dialogComponentRefMap.has(dialogRef)) {\n      return;\n    }\n\n    const dialogComponentRef = this.dialogComponentRefMap.get(dialogRef);\n    if (dialogComponentRef) {\n      this.viewContainerRef.detach(\n        this.viewContainerRef.indexOf(dialogComponentRef.hostView)\n      );\n      dialogComponentRef.destroy();\n      this.dialogComponentRefMap.delete(dialogRef);\n    }\n  }\n}\n"]}
117
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-dialog.service.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/services/cps-dialog/cps-dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Injectable,\n  Type,\n  EmbeddedViewRef,\n  ComponentRef,\n  Inject,\n  ApplicationRef,\n  createComponent,\n  EnvironmentInjector,\n  createEnvironmentInjector\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { CpsDialogRef } from './utils/cps-dialog-ref';\nimport { CpsDialogConfig } from './utils/cps-dialog-config';\nimport { CpsDialogComponent } from './internal/components/cps-dialog/cps-dialog.component';\nimport { CpsConfirmationComponent } from './internal/components/cps-confirmation/cps-confirmation.component';\n\n/**\n * Service for showing CpsDialog.\n * @group Services\n */\n@Injectable({ providedIn: 'root' })\nexport class CpsDialogService {\n  dialogComponentRefMap: Map<CpsDialogRef, ComponentRef<CpsDialogComponent>> =\n    new Map();\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(\n    private _appRef: ApplicationRef,\n    private _environmentInjector: EnvironmentInjector,\n    @Inject(DOCUMENT) private document: Document\n  ) {}\n\n  /**\n   * Opens a dialog with a dynamically loaded component.\n   * @param {*} componentType - Dynamic component for content template.\n   * @param {CpsDialogConfig} config - CpsDialogConfig object.\n   * @returns {CpsDialogRef} CpsDialogRef instance.\n   * @group Method\n   */\n  public open(componentType: Type<any>, config: CpsDialogConfig): CpsDialogRef {\n    const dialogRef = this.appendDialogComponentToBody(config);\n\n    const instance = this.dialogComponentRefMap.get(dialogRef)?.instance;\n    if (instance) instance.childComponentType = componentType;\n\n    return dialogRef;\n  }\n\n  /**\n   * Opens a confirmation dialog.\n   * @param {CpsDialogConfig} config - CpsDialogConfig object.\n   * @returns {CpsDialogRef} CpsDialogRef instance.\n   * @group Method\n   */\n  public openConfirmationDialog(config: CpsDialogConfig): CpsDialogRef {\n    if (!config.headerTitle) config.headerTitle = 'Confirm the action';\n    if (!config.headerIcon) config.headerIcon = 'warning';\n    if (!config.headerIconColor) config.headerIconColor = 'calm';\n    if (!config.minWidth) config.minWidth = '400px';\n    if (!config.maxWidth) config.maxWidth = '600px';\n    const dialogRef = this.appendDialogComponentToBody(config);\n\n    const instance = this.dialogComponentRefMap.get(dialogRef)?.instance;\n    if (instance) instance.childComponentType = CpsConfirmationComponent;\n\n    return dialogRef;\n  }\n\n  /**\n   * Closes all dialogs.\n   * @param {boolean} [force=false] - If true closes all dialogs even if they have disableClose set to true.\n   * @group Method\n   */\n  public closeAll(force = false): void {\n    this.dialogComponentRefMap.forEach((_, key) => {\n      if (force) {\n        key.destroy();\n      } else {\n        key.close();\n      }\n    });\n  }\n\n  private appendDialogComponentToBody(config: CpsDialogConfig) {\n    const dialogRef = new CpsDialogRef();\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(CpsDialogComponent, {\n      environmentInjector: createEnvironmentInjector(\n        [\n          { provide: CpsDialogConfig, useValue: config },\n          { provide: CpsDialogRef, useValue: dialogRef }\n        ],\n        this._environmentInjector\n      )\n    });\n\n    this._appRef.attachView(componentRef.hostView);\n\n    const domElem = (componentRef.hostView as EmbeddedViewRef<any>)\n      .rootNodes[0] as HTMLElement;\n    this.document.body.appendChild(domElem);\n\n    this.dialogComponentRefMap.set(dialogRef, componentRef);\n    dialogRef._setContainerInstance(componentRef.instance);\n\n    return dialogRef;\n  }\n\n  private removeDialogComponentFromBody(dialogRef: CpsDialogRef) {\n    if (!dialogRef || !this.dialogComponentRefMap.has(dialogRef)) {\n      return;\n    }\n\n    const dialogComponentRef = this.dialogComponentRefMap.get(dialogRef);\n    if (dialogComponentRef) {\n      this._appRef.detachView(dialogComponentRef.hostView);\n      dialogComponentRef.destroy();\n      this.dialogComponentRefMap.delete(dialogRef);\n    }\n  }\n}\n"]}
@@ -10,7 +10,7 @@ export class CpsConfirmationComponent {
10
10
  this._dialogRef = _dialogRef;
11
11
  this._config = _config;
12
12
  this.subtitle = '';
13
- this.subtitle = this._config.data.subtitle;
13
+ this.subtitle = this._config.data?.subtitle;
14
14
  }
15
15
  close(confirm) {
16
16
  this._dialogRef?.close(confirm);
@@ -22,4 +22,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
22
22
  type: Component,
23
23
  args: [{ standalone: true, imports: [CpsButtonComponent, CpsIconComponent], selector: 'cps-confirmation', template: "<div class=\"cps-confirmation\">\n <span class=\"cps-confirmation-subtitle\">{{ subtitle }}</span>\n <div class=\"cps-confirmation-buttons\">\n <cps-button\n type=\"outlined\"\n label=\"No\"\n (clicked)=\"close(false)\"\n color=\"prepared\">\n </cps-button>\n <cps-button\n data-cy=\"btn-yes\"\n label=\"Yes\"\n (clicked)=\"close(true)\"\n color=\"prepared\">\n </cps-button>\n </div>\n</div>\n", styles: [":host .cps-confirmation{display:flex;flex-direction:column;align-items:center;padding:8px}:host .cps-confirmation-subtitle{font-size:16px;font-weight:400;font-family:Source Sans Pro,sans-serif;color:var(--cps-color-text-dark)}:host .cps-confirmation-buttons{width:100%;display:flex;justify-content:space-around;padding-top:28px}\n"] }]
24
24
  }], ctorParameters: () => [{ type: i1.CpsDialogRef }, { type: i2.CpsDialogConfig }] });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLWNvbmZpcm1hdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvc2VydmljZXMvY3BzLWRpYWxvZy9pbnRlcm5hbC9jb21wb25lbnRzL2Nwcy1jb25maXJtYXRpb24vY3BzLWNvbmZpcm1hdGlvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvc2VydmljZXMvY3BzLWRpYWxvZy9pbnRlcm5hbC9jb21wb25lbnRzL2Nwcy1jb25maXJtYXRpb24vY3BzLWNvbmZpcm1hdGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDJEQUEyRCxDQUFDO0FBQy9GLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVEQUF1RCxDQUFDOzs7O0FBV3pGLE1BQU0sT0FBTyx3QkFBd0I7SUFHbkMsa0RBQWtEO0lBQ2xELFlBQ1UsVUFBd0IsRUFDeEIsT0FBd0I7UUFEeEIsZUFBVSxHQUFWLFVBQVUsQ0FBYztRQUN4QixZQUFPLEdBQVAsT0FBTyxDQUFpQjtRQUxsQyxhQUFRLEdBQUcsRUFBRSxDQUFDO1FBT1osSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDN0MsQ0FBQztJQUVELEtBQUssQ0FBQyxPQUFnQjtRQUNwQixJQUFJLENBQUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNsQyxDQUFDOzhHQWJVLHdCQUF3QjtrR0FBeEIsd0JBQXdCLDRFQ2JyQyxtY0FpQkEsb1lEVFksa0JBQWtCOzsyRkFLakIsd0JBQXdCO2tCQVBwQyxTQUFTO2lDQUNJLElBQUksV0FDUCxDQUFDLGtCQUFrQixFQUFFLGdCQUFnQixDQUFDLFlBQ3JDLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ3BzQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vY29tcG9uZW50cy9jcHMtYnV0dG9uL2Nwcy1idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7IENwc0ljb25Db21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi9jb21wb25lbnRzL2Nwcy1pY29uL2Nwcy1pY29uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDcHNEaWFsb2dSZWYgfSBmcm9tICcuLi8uLi8uLi91dGlscy9jcHMtZGlhbG9nLXJlZic7XG5pbXBvcnQgeyBDcHNEaWFsb2dDb25maWcgfSBmcm9tICcuLi8uLi8uLi91dGlscy9jcHMtZGlhbG9nLWNvbmZpZyc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ3BzQnV0dG9uQ29tcG9uZW50LCBDcHNJY29uQ29tcG9uZW50XSxcbiAgc2VsZWN0b3I6ICdjcHMtY29uZmlybWF0aW9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Nwcy1jb25maXJtYXRpb24uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jcHMtY29uZmlybWF0aW9uLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgQ3BzQ29uZmlybWF0aW9uQ29tcG9uZW50IHtcbiAgc3VidGl0bGUgPSAnJztcblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tdXNlbGVzcy1jb25zdHJ1Y3RvclxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIF9kaWFsb2dSZWY6IENwc0RpYWxvZ1JlZixcbiAgICBwcml2YXRlIF9jb25maWc6IENwc0RpYWxvZ0NvbmZpZ1xuICApIHtcbiAgICB0aGlzLnN1YnRpdGxlID0gdGhpcy5fY29uZmlnLmRhdGEuc3VidGl0bGU7XG4gIH1cblxuICBjbG9zZShjb25maXJtOiBib29sZWFuKSB7XG4gICAgdGhpcy5fZGlhbG9nUmVmPy5jbG9zZShjb25maXJtKTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImNwcy1jb25maXJtYXRpb25cIj5cbiAgPHNwYW4gY2xhc3M9XCJjcHMtY29uZmlybWF0aW9uLXN1YnRpdGxlXCI+e3sgc3VidGl0bGUgfX08L3NwYW4+XG4gIDxkaXYgY2xhc3M9XCJjcHMtY29uZmlybWF0aW9uLWJ1dHRvbnNcIj5cbiAgICA8Y3BzLWJ1dHRvblxuICAgICAgdHlwZT1cIm91dGxpbmVkXCJcbiAgICAgIGxhYmVsPVwiTm9cIlxuICAgICAgKGNsaWNrZWQpPVwiY2xvc2UoZmFsc2UpXCJcbiAgICAgIGNvbG9yPVwicHJlcGFyZWRcIj5cbiAgICA8L2Nwcy1idXR0b24+XG4gICAgPGNwcy1idXR0b25cbiAgICAgIGRhdGEtY3k9XCJidG4teWVzXCJcbiAgICAgIGxhYmVsPVwiWWVzXCJcbiAgICAgIChjbGlja2VkKT1cImNsb3NlKHRydWUpXCJcbiAgICAgIGNvbG9yPVwicHJlcGFyZWRcIj5cbiAgICA8L2Nwcy1idXR0b24+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLWNvbmZpcm1hdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvc2VydmljZXMvY3BzLWRpYWxvZy9pbnRlcm5hbC9jb21wb25lbnRzL2Nwcy1jb25maXJtYXRpb24vY3BzLWNvbmZpcm1hdGlvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvc2VydmljZXMvY3BzLWRpYWxvZy9pbnRlcm5hbC9jb21wb25lbnRzL2Nwcy1jb25maXJtYXRpb24vY3BzLWNvbmZpcm1hdGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDJEQUEyRCxDQUFDO0FBQy9GLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVEQUF1RCxDQUFDOzs7O0FBV3pGLE1BQU0sT0FBTyx3QkFBd0I7SUFHbkMsa0RBQWtEO0lBQ2xELFlBQ1UsVUFBd0IsRUFDeEIsT0FBd0I7UUFEeEIsZUFBVSxHQUFWLFVBQVUsQ0FBYztRQUN4QixZQUFPLEdBQVAsT0FBTyxDQUFpQjtRQUxsQyxhQUFRLEdBQUcsRUFBRSxDQUFDO1FBT1osSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxRQUFRLENBQUM7SUFDOUMsQ0FBQztJQUVELEtBQUssQ0FBQyxPQUFnQjtRQUNwQixJQUFJLENBQUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNsQyxDQUFDOzhHQWJVLHdCQUF3QjtrR0FBeEIsd0JBQXdCLDRFQ2JyQyxtY0FpQkEsb1lEVFksa0JBQWtCOzsyRkFLakIsd0JBQXdCO2tCQVBwQyxTQUFTO2lDQUNJLElBQUksV0FDUCxDQUFDLGtCQUFrQixFQUFFLGdCQUFnQixDQUFDLFlBQ3JDLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ3BzQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vY29tcG9uZW50cy9jcHMtYnV0dG9uL2Nwcy1idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7IENwc0ljb25Db21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi9jb21wb25lbnRzL2Nwcy1pY29uL2Nwcy1pY29uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDcHNEaWFsb2dSZWYgfSBmcm9tICcuLi8uLi8uLi91dGlscy9jcHMtZGlhbG9nLXJlZic7XG5pbXBvcnQgeyBDcHNEaWFsb2dDb25maWcgfSBmcm9tICcuLi8uLi8uLi91dGlscy9jcHMtZGlhbG9nLWNvbmZpZyc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ3BzQnV0dG9uQ29tcG9uZW50LCBDcHNJY29uQ29tcG9uZW50XSxcbiAgc2VsZWN0b3I6ICdjcHMtY29uZmlybWF0aW9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Nwcy1jb25maXJtYXRpb24uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jcHMtY29uZmlybWF0aW9uLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgQ3BzQ29uZmlybWF0aW9uQ29tcG9uZW50IHtcbiAgc3VidGl0bGUgPSAnJztcblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tdXNlbGVzcy1jb25zdHJ1Y3RvclxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIF9kaWFsb2dSZWY6IENwc0RpYWxvZ1JlZixcbiAgICBwcml2YXRlIF9jb25maWc6IENwc0RpYWxvZ0NvbmZpZ1xuICApIHtcbiAgICB0aGlzLnN1YnRpdGxlID0gdGhpcy5fY29uZmlnLmRhdGE/LnN1YnRpdGxlO1xuICB9XG5cbiAgY2xvc2UoY29uZmlybTogYm9vbGVhbikge1xuICAgIHRoaXMuX2RpYWxvZ1JlZj8uY2xvc2UoY29uZmlybSk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJjcHMtY29uZmlybWF0aW9uXCI+XG4gIDxzcGFuIGNsYXNzPVwiY3BzLWNvbmZpcm1hdGlvbi1zdWJ0aXRsZVwiPnt7IHN1YnRpdGxlIH19PC9zcGFuPlxuICA8ZGl2IGNsYXNzPVwiY3BzLWNvbmZpcm1hdGlvbi1idXR0b25zXCI+XG4gICAgPGNwcy1idXR0b25cbiAgICAgIHR5cGU9XCJvdXRsaW5lZFwiXG4gICAgICBsYWJlbD1cIk5vXCJcbiAgICAgIChjbGlja2VkKT1cImNsb3NlKGZhbHNlKVwiXG4gICAgICBjb2xvcj1cInByZXBhcmVkXCI+XG4gICAgPC9jcHMtYnV0dG9uPlxuICAgIDxjcHMtYnV0dG9uXG4gICAgICBkYXRhLWN5PVwiYnRuLXllc1wiXG4gICAgICBsYWJlbD1cIlllc1wiXG4gICAgICAoY2xpY2tlZCk9XCJjbG9zZSh0cnVlKVwiXG4gICAgICBjb2xvcj1cInByZXBhcmVkXCI+XG4gICAgPC9jcHMtYnV0dG9uPlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
@@ -1,7 +1,7 @@
1
1
  import * as i2 from '@angular/common';
2
2
  import { CommonModule, isPlatformBrowser, DOCUMENT } from '@angular/common';
3
3
  import * as i0 from '@angular/core';
4
- import { Component, Input, Directive, HostListener, EventEmitter, Self, Optional, Output, ViewChild, Pipe, PLATFORM_ID, ChangeDetectionStrategy, ViewEncapsulation, Inject, HostBinding, InjectionToken, Host, ContentChild, ViewChildren, RendererStyleFlags2, TemplateRef, ContentChildren, Injectable, createComponent } from '@angular/core';
4
+ import { Component, Input, Directive, HostListener, EventEmitter, Self, Optional, Output, ViewChild, Pipe, PLATFORM_ID, ChangeDetectionStrategy, ViewEncapsulation, Inject, HostBinding, InjectionToken, Host, ContentChild, ViewChildren, RendererStyleFlags2, TemplateRef, ContentChildren, createComponent, createEnvironmentInjector, Injectable } from '@angular/core';
5
5
  import * as i1 from '@angular/forms';
6
6
  import { FormsModule, Validators, ReactiveFormsModule } from '@angular/forms';
7
7
  import { isEqual, cloneDeep } from 'lodash-es';
@@ -30,7 +30,6 @@ import { AngleDoubleRightIcon } from 'primeng/icons/angledoubleright';
30
30
  import { fromEvent, Subscription, debounceTime, distinctUntilChanged, take, catchError, of, Subject } from 'rxjs';
31
31
  import * as i1$4 from 'primeng/paginator';
32
32
  import { PaginatorModule } from 'primeng/paginator';
33
- import { DynamicDialogInjector } from 'primeng/dynamicdialog';
34
33
 
35
34
  const convertSize = (size) => {
36
35
  const res = String(size).trim();
@@ -13036,7 +13035,7 @@ class CpsConfirmationComponent {
13036
13035
  this._dialogRef = _dialogRef;
13037
13036
  this._config = _config;
13038
13037
  this.subtitle = '';
13039
- this.subtitle = this._config.data.subtitle;
13038
+ this.subtitle = this._config.data?.subtitle;
13040
13039
  }
13041
13040
  close(confirm) {
13042
13041
  this._dialogRef?.close(confirm);
@@ -13055,9 +13054,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
13055
13054
  */
13056
13055
  class CpsDialogService {
13057
13056
  // eslint-disable-next-line no-useless-constructor
13058
- constructor(viewContainerRef, injector, document) {
13059
- this.viewContainerRef = viewContainerRef;
13060
- this.injector = injector;
13057
+ constructor(_appRef, _environmentInjector, document) {
13058
+ this._appRef = _appRef;
13059
+ this._environmentInjector = _environmentInjector;
13061
13060
  this.document = document;
13062
13061
  this.dialogComponentRefMap = new Map();
13063
13062
  }
@@ -13098,11 +13097,23 @@ class CpsDialogService {
13098
13097
  instance.childComponentType = CpsConfirmationComponent;
13099
13098
  return dialogRef;
13100
13099
  }
13100
+ /**
13101
+ * Closes all dialogs.
13102
+ * @param {boolean} [force=false] - If true closes all dialogs even if they have disableClose set to true.
13103
+ * @group Method
13104
+ */
13105
+ closeAll(force = false) {
13106
+ this.dialogComponentRefMap.forEach((_, key) => {
13107
+ if (force) {
13108
+ key.destroy();
13109
+ }
13110
+ else {
13111
+ key.close();
13112
+ }
13113
+ });
13114
+ }
13101
13115
  appendDialogComponentToBody(config) {
13102
- const map = new WeakMap();
13103
- map.set(CpsDialogConfig, config);
13104
13116
  const dialogRef = new CpsDialogRef();
13105
- map.set(CpsDialogRef, dialogRef);
13106
13117
  const sub = dialogRef.onClose.subscribe(() => {
13107
13118
  this.dialogComponentRefMap.get(dialogRef)?.instance.close();
13108
13119
  });
@@ -13111,7 +13122,13 @@ class CpsDialogService {
13111
13122
  destroySub.unsubscribe();
13112
13123
  sub.unsubscribe();
13113
13124
  });
13114
- const componentRef = this.viewContainerRef.createComponent(CpsDialogComponent, { injector: new DynamicDialogInjector(this.injector, map) });
13125
+ const componentRef = createComponent(CpsDialogComponent, {
13126
+ environmentInjector: createEnvironmentInjector([
13127
+ { provide: CpsDialogConfig, useValue: config },
13128
+ { provide: CpsDialogRef, useValue: dialogRef }
13129
+ ], this._environmentInjector)
13130
+ });
13131
+ this._appRef.attachView(componentRef.hostView);
13115
13132
  const domElem = componentRef.hostView
13116
13133
  .rootNodes[0];
13117
13134
  this.document.body.appendChild(domElem);
@@ -13125,17 +13142,18 @@ class CpsDialogService {
13125
13142
  }
13126
13143
  const dialogComponentRef = this.dialogComponentRefMap.get(dialogRef);
13127
13144
  if (dialogComponentRef) {
13128
- this.viewContainerRef.detach(this.viewContainerRef.indexOf(dialogComponentRef.hostView));
13145
+ this._appRef.detachView(dialogComponentRef.hostView);
13129
13146
  dialogComponentRef.destroy();
13130
13147
  this.dialogComponentRefMap.delete(dialogRef);
13131
13148
  }
13132
13149
  }
13133
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.ViewContainerRef }, { token: i0.Injector }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
13134
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService }); }
13150
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
13151
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, providedIn: 'root' }); }
13135
13152
  }
13136
13153
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, decorators: [{
13137
- type: Injectable
13138
- }], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.Injector }, { type: Document, decorators: [{
13154
+ type: Injectable,
13155
+ args: [{ providedIn: 'root' }]
13156
+ }], ctorParameters: () => [{ type: i0.ApplicationRef }, { type: i0.EnvironmentInjector }, { type: Document, decorators: [{
13139
13157
  type: Inject,
13140
13158
  args: [DOCUMENT]
13141
13159
  }] }] });