cps-ui-kit 17.21.0 → 17.22.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,4 +1,4 @@
|
|
|
1
|
-
import { Injectable, Inject, createComponent, createEnvironmentInjector } from '@angular/core';
|
|
1
|
+
import { Injectable, Inject, createComponent, createEnvironmentInjector, Optional, SkipSelf } from '@angular/core';
|
|
2
2
|
import { DOCUMENT } from '@angular/common';
|
|
3
3
|
import { CpsDialogRef } from './utils/cps-dialog-ref';
|
|
4
4
|
import { CpsDialogConfig } from './utils/cps-dialog-config';
|
|
@@ -10,13 +10,20 @@ import * as i0 from "@angular/core";
|
|
|
10
10
|
* @group Services
|
|
11
11
|
*/
|
|
12
12
|
export class CpsDialogService {
|
|
13
|
+
get openDialogs() {
|
|
14
|
+
return this._parentDialogService
|
|
15
|
+
? this._parentDialogService.openDialogs
|
|
16
|
+
: this._openDialogsAtThisLevel;
|
|
17
|
+
}
|
|
13
18
|
// eslint-disable-next-line no-useless-constructor
|
|
14
|
-
constructor(_appRef, _environmentInjector, _injector, document) {
|
|
19
|
+
constructor(_appRef, _environmentInjector, _injector, document, _parentDialogService) {
|
|
15
20
|
this._appRef = _appRef;
|
|
16
21
|
this._environmentInjector = _environmentInjector;
|
|
17
22
|
this._injector = _injector;
|
|
18
23
|
this.document = document;
|
|
24
|
+
this._parentDialogService = _parentDialogService;
|
|
19
25
|
this.dialogComponentRefMap = new Map();
|
|
26
|
+
this._openDialogsAtThisLevel = [];
|
|
20
27
|
}
|
|
21
28
|
/**
|
|
22
29
|
* Opens a dialog with a dynamically loaded component.
|
|
@@ -61,12 +68,12 @@ export class CpsDialogService {
|
|
|
61
68
|
* @group Method
|
|
62
69
|
*/
|
|
63
70
|
closeAll(force = false) {
|
|
64
|
-
this.
|
|
71
|
+
this._reverseForEach(this.openDialogs, (dialogRef) => {
|
|
65
72
|
if (force) {
|
|
66
|
-
|
|
73
|
+
dialogRef.destroy();
|
|
67
74
|
}
|
|
68
75
|
else {
|
|
69
|
-
|
|
76
|
+
dialogRef.close();
|
|
70
77
|
}
|
|
71
78
|
});
|
|
72
79
|
}
|
|
@@ -94,6 +101,7 @@ export class CpsDialogService {
|
|
|
94
101
|
.rootNodes[0];
|
|
95
102
|
this.document.body.appendChild(domElem);
|
|
96
103
|
this.dialogComponentRefMap.set(dialogRef, componentRef);
|
|
104
|
+
this.openDialogs.push(dialogRef);
|
|
97
105
|
dialogRef._setContainerInstance(componentRef.instance);
|
|
98
106
|
return dialogRef;
|
|
99
107
|
}
|
|
@@ -107,8 +115,21 @@ export class CpsDialogService {
|
|
|
107
115
|
dialogComponentRef.destroy();
|
|
108
116
|
this.dialogComponentRefMap.delete(dialogRef);
|
|
109
117
|
}
|
|
118
|
+
const index = this.openDialogs.indexOf(dialogRef);
|
|
119
|
+
if (index > -1) {
|
|
120
|
+
this.openDialogs.splice(index, 1);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
ngOnDestroy() {
|
|
124
|
+
this._reverseForEach(this._openDialogsAtThisLevel, (dialogRef) => dialogRef.destroy());
|
|
125
|
+
}
|
|
126
|
+
_reverseForEach(items, callback) {
|
|
127
|
+
let i = items.length;
|
|
128
|
+
while (i--) {
|
|
129
|
+
callback(items[i]);
|
|
130
|
+
}
|
|
110
131
|
}
|
|
111
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: i0.Injector }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
132
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: i0.Injector }, { token: DOCUMENT }, { token: CpsDialogService, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
112
133
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, providedIn: 'root' }); }
|
|
113
134
|
}
|
|
114
135
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, decorators: [{
|
|
@@ -117,5 +138,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
117
138
|
}], ctorParameters: () => [{ type: i0.ApplicationRef }, { type: i0.EnvironmentInjector }, { type: i0.Injector }, { type: Document, decorators: [{
|
|
118
139
|
type: Inject,
|
|
119
140
|
args: [DOCUMENT]
|
|
141
|
+
}] }, { type: CpsDialogService, decorators: [{
|
|
142
|
+
type: Optional
|
|
143
|
+
}, {
|
|
144
|
+
type: SkipSelf
|
|
120
145
|
}] }] });
|
|
121
|
-
//# 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  Injector\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    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  /**\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      elementInjector:\n        this._injector !== this._environmentInjector\n          ? this._injector\n          : undefined\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"]}
|
|
146
|
+
//# 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  Injector,\n  Optional,\n  SkipSelf,\n  OnDestroy\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 implements OnDestroy {\n  get openDialogs(): CpsDialogRef<any>[] {\n    return this._parentDialogService\n      ? this._parentDialogService.openDialogs\n      : this._openDialogsAtThisLevel;\n  }\n\n  dialogComponentRefMap: Map<CpsDialogRef, ComponentRef<CpsDialogComponent>> =\n    new Map();\n\n  private _openDialogsAtThisLevel: CpsDialogRef<any>[] = [];\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(\n    private _appRef: ApplicationRef,\n    private _environmentInjector: EnvironmentInjector,\n    private _injector: Injector,\n    @Inject(DOCUMENT) private document: Document,\n    @Optional() @SkipSelf() private _parentDialogService: CpsDialogService\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._reverseForEach(this.openDialogs, (dialogRef) => {\n      if (force) {\n        dialogRef.destroy();\n      } else {\n        dialogRef.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      elementInjector:\n        this._injector !== this._environmentInjector\n          ? this._injector\n          : undefined\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    this.openDialogs.push(dialogRef);\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    const index = this.openDialogs.indexOf(dialogRef);\n\n    if (index > -1) {\n      this.openDialogs.splice(index, 1);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._reverseForEach(this._openDialogsAtThisLevel, (dialogRef) =>\n      dialogRef.destroy()\n    );\n  }\n\n  private _reverseForEach<T>(\n    items: T[] | readonly T[],\n    callback: (current: T) => void\n  ) {\n    let i = items.length;\n\n    while (i--) {\n      callback(items[i]);\n    }\n  }\n}\n"]}
|
package/fesm2022/cps-ui-kit.mjs
CHANGED
|
@@ -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, createComponent, createEnvironmentInjector, Injectable } 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, SkipSelf } 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';
|
|
@@ -13086,13 +13086,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
13086
13086
|
* @group Services
|
|
13087
13087
|
*/
|
|
13088
13088
|
class CpsDialogService {
|
|
13089
|
+
get openDialogs() {
|
|
13090
|
+
return this._parentDialogService
|
|
13091
|
+
? this._parentDialogService.openDialogs
|
|
13092
|
+
: this._openDialogsAtThisLevel;
|
|
13093
|
+
}
|
|
13089
13094
|
// eslint-disable-next-line no-useless-constructor
|
|
13090
|
-
constructor(_appRef, _environmentInjector, _injector, document) {
|
|
13095
|
+
constructor(_appRef, _environmentInjector, _injector, document, _parentDialogService) {
|
|
13091
13096
|
this._appRef = _appRef;
|
|
13092
13097
|
this._environmentInjector = _environmentInjector;
|
|
13093
13098
|
this._injector = _injector;
|
|
13094
13099
|
this.document = document;
|
|
13100
|
+
this._parentDialogService = _parentDialogService;
|
|
13095
13101
|
this.dialogComponentRefMap = new Map();
|
|
13102
|
+
this._openDialogsAtThisLevel = [];
|
|
13096
13103
|
}
|
|
13097
13104
|
/**
|
|
13098
13105
|
* Opens a dialog with a dynamically loaded component.
|
|
@@ -13137,12 +13144,12 @@ class CpsDialogService {
|
|
|
13137
13144
|
* @group Method
|
|
13138
13145
|
*/
|
|
13139
13146
|
closeAll(force = false) {
|
|
13140
|
-
this.
|
|
13147
|
+
this._reverseForEach(this.openDialogs, (dialogRef) => {
|
|
13141
13148
|
if (force) {
|
|
13142
|
-
|
|
13149
|
+
dialogRef.destroy();
|
|
13143
13150
|
}
|
|
13144
13151
|
else {
|
|
13145
|
-
|
|
13152
|
+
dialogRef.close();
|
|
13146
13153
|
}
|
|
13147
13154
|
});
|
|
13148
13155
|
}
|
|
@@ -13170,6 +13177,7 @@ class CpsDialogService {
|
|
|
13170
13177
|
.rootNodes[0];
|
|
13171
13178
|
this.document.body.appendChild(domElem);
|
|
13172
13179
|
this.dialogComponentRefMap.set(dialogRef, componentRef);
|
|
13180
|
+
this.openDialogs.push(dialogRef);
|
|
13173
13181
|
dialogRef._setContainerInstance(componentRef.instance);
|
|
13174
13182
|
return dialogRef;
|
|
13175
13183
|
}
|
|
@@ -13183,8 +13191,21 @@ class CpsDialogService {
|
|
|
13183
13191
|
dialogComponentRef.destroy();
|
|
13184
13192
|
this.dialogComponentRefMap.delete(dialogRef);
|
|
13185
13193
|
}
|
|
13194
|
+
const index = this.openDialogs.indexOf(dialogRef);
|
|
13195
|
+
if (index > -1) {
|
|
13196
|
+
this.openDialogs.splice(index, 1);
|
|
13197
|
+
}
|
|
13198
|
+
}
|
|
13199
|
+
ngOnDestroy() {
|
|
13200
|
+
this._reverseForEach(this._openDialogsAtThisLevel, (dialogRef) => dialogRef.destroy());
|
|
13201
|
+
}
|
|
13202
|
+
_reverseForEach(items, callback) {
|
|
13203
|
+
let i = items.length;
|
|
13204
|
+
while (i--) {
|
|
13205
|
+
callback(items[i]);
|
|
13206
|
+
}
|
|
13186
13207
|
}
|
|
13187
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: i0.Injector }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
13208
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: i0.Injector }, { token: DOCUMENT }, { token: CpsDialogService, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
13188
13209
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, providedIn: 'root' }); }
|
|
13189
13210
|
}
|
|
13190
13211
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, decorators: [{
|
|
@@ -13193,6 +13214,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
13193
13214
|
}], ctorParameters: () => [{ type: i0.ApplicationRef }, { type: i0.EnvironmentInjector }, { type: i0.Injector }, { type: Document, decorators: [{
|
|
13194
13215
|
type: Inject,
|
|
13195
13216
|
args: [DOCUMENT]
|
|
13217
|
+
}] }, { type: CpsDialogService, decorators: [{
|
|
13218
|
+
type: Optional
|
|
13219
|
+
}, {
|
|
13220
|
+
type: SkipSelf
|
|
13196
13221
|
}] }] });
|
|
13197
13222
|
|
|
13198
13223
|
/* eslint-disable no-unused-vars */
|