@libs-ui/services-dialog 0.1.1-1

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.
package/README.md ADDED
@@ -0,0 +1,3 @@
1
+ # services-dialog
2
+
3
+ This library was generated with [Nx](https://nx.dev).
@@ -0,0 +1,12 @@
1
+ import { IDialog } from './interfaces/dialog.interface';
2
+ import * as i0 from "@angular/core";
3
+ export declare class LibsUiDialogService {
4
+ private dialogsRef;
5
+ private dynamicComponentService;
6
+ addDialog(config: IDialog, isAddParentDocument?: boolean): string;
7
+ switchDisableActionsOnDialog(id: string): void;
8
+ removeDialog(id: string): void;
9
+ clearDialogsRef(): void;
10
+ static ɵfac: i0.ɵɵFactoryDeclaration<LibsUiDialogService, never>;
11
+ static ɵprov: i0.ɵɵInjectableDeclaration<LibsUiDialogService>;
12
+ }
@@ -0,0 +1,96 @@
1
+ import { Injectable, inject } from '@angular/core';
2
+ import { LibsUiComponentsModalComponent } from '@libs-ui/components-modal';
3
+ import { LibsUiDynamicComponentService } from '@libs-ui/services-dynamic-component';
4
+ import { uuid } from '@libs-ui/utils';
5
+ import * as i0 from "@angular/core";
6
+ export class LibsUiDialogService {
7
+ dialogsRef = new Map();
8
+ dynamicComponentService = inject(LibsUiDynamicComponentService);
9
+ addDialog(config, isAddParentDocument) {
10
+ const idDialog = uuid();
11
+ const component = this.dynamicComponentService.resolveComponentFactory(LibsUiComponentsModalComponent);
12
+ const instance = component.instance;
13
+ let functionControl;
14
+ instance.outFunctionControl.subscribe((func) => (functionControl = func));
15
+ instance.outEvent.subscribe((eventName) => {
16
+ functionControl.setStateDisable(true);
17
+ switch (eventName) {
18
+ case 'agree':
19
+ config.configAgreeEvent?.callback(functionControl);
20
+ if (!config.configAgreeEvent?.ignoreRemoveDialog) {
21
+ this.removeDialog(idDialog);
22
+ }
23
+ return;
24
+ case 'close':
25
+ config.configCloseEvent?.callback(functionControl);
26
+ if (!config.configCloseEvent?.ignoreRemoveDialog) {
27
+ this.removeDialog(idDialog);
28
+ }
29
+ return;
30
+ case 'cancel':
31
+ config.configCancelEvent?.callback(functionControl);
32
+ if (!config.configCancelEvent?.ignoreRemoveDialog) {
33
+ this.removeDialog(idDialog);
34
+ }
35
+ break;
36
+ case 'back':
37
+ config.configBackEvent?.callback(functionControl);
38
+ if (!config.configBackEvent?.ignoreRemoveDialog) {
39
+ this.removeDialog(idDialog);
40
+ }
41
+ break;
42
+ }
43
+ });
44
+ component.setInput('zIndex', config.zIndex);
45
+ component.setInput('title', config.title);
46
+ component.setInput('titleUseInnerText', config.titleUseInnerText ?? false);
47
+ component.setInput('titleUseXssFilter', config.titleUseXssFilter ?? true);
48
+ component.setInput('width', config.width || '500px');
49
+ component.setInput('height', config.height || 'auto');
50
+ component.setInput('maxWidth', config.maxWidth);
51
+ component.setInput('maxHeight', config.maxHeight);
52
+ component.setInput('headerConfig', config.headerConfig || { hidden: !config.title });
53
+ component.setInput('bodyConfig', config.bodyConfig);
54
+ component.setInput('footerConfig', config.footerConfig);
55
+ component.setInput('classIncludeModalWrapper', config.classIncludeModalWrapper);
56
+ component.setInput('disable', config.disable || false);
57
+ component.setInput('mode', config.mode || 'center');
58
+ component.setInput('ignoreCommunicateMicroEvent', config.ignoreCommunicateMicroEvent);
59
+ if (config.buttonsFooter) {
60
+ component.setInput('buttonsFooter', config.buttonsFooter);
61
+ }
62
+ this.dialogsRef.set(idDialog, { component });
63
+ this.dynamicComponentService.addToBody(component, isAddParentDocument);
64
+ return idDialog;
65
+ }
66
+ switchDisableActionsOnDialog(id) {
67
+ const data = this.dialogsRef.get(id);
68
+ if (!data) {
69
+ return;
70
+ }
71
+ data.component.setInput('disable', !data.component.instance.disable);
72
+ }
73
+ removeDialog(id) {
74
+ const data = this.dialogsRef.get(id);
75
+ if (!data) {
76
+ return;
77
+ }
78
+ this.dynamicComponentService.remove(data.component);
79
+ this.dialogsRef.delete(id);
80
+ }
81
+ clearDialogsRef() {
82
+ const keys = this.dialogsRef.keys();
83
+ for (const key of keys) {
84
+ this.removeDialog(key);
85
+ }
86
+ }
87
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiDialogService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
88
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiDialogService, providedIn: 'root' });
89
+ }
90
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiDialogService, decorators: [{
91
+ type: Injectable,
92
+ args: [{
93
+ providedIn: 'root',
94
+ }]
95
+ }] });
96
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../../../libs-ui/services/dialog/src/dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef, Injectable, inject } from '@angular/core';\nimport { IModalFunctionsControl, LibsUiComponentsModalComponent, TYPE_MODAL_EVENT } from '@libs-ui/components-modal';\nimport { LibsUiDynamicComponentService } from '@libs-ui/services-dynamic-component';\nimport { uuid } from '@libs-ui/utils';\nimport { IDialog } from './interfaces/dialog.interface';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class LibsUiDialogService {\n  private dialogsRef: Map<string, { component: ComponentRef<LibsUiComponentsModalComponent> }> = new Map();\n  private dynamicComponentService = inject(LibsUiDynamicComponentService);\n\n  public addDialog(config: IDialog, isAddParentDocument?: boolean): string {\n    const idDialog = uuid();\n    const component = this.dynamicComponentService.resolveComponentFactory(LibsUiComponentsModalComponent);\n    const instance = component.instance;\n    let functionControl: IModalFunctionsControl;\n    instance.outFunctionControl.subscribe((func: IModalFunctionsControl) => (functionControl = func));\n\n    instance.outEvent.subscribe((eventName: TYPE_MODAL_EVENT) => {\n      functionControl.setStateDisable(true);\n\n      switch (eventName) {\n        case 'agree':\n          config.configAgreeEvent?.callback(functionControl);\n          if (!config.configAgreeEvent?.ignoreRemoveDialog) {\n            this.removeDialog(idDialog);\n          }\n\n          return;\n\n        case 'close':\n          config.configCloseEvent?.callback(functionControl);\n          if (!config.configCloseEvent?.ignoreRemoveDialog) {\n            this.removeDialog(idDialog);\n          }\n\n          return;\n\n        case 'cancel':\n          config.configCancelEvent?.callback(functionControl);\n          if (!config.configCancelEvent?.ignoreRemoveDialog) {\n            this.removeDialog(idDialog);\n          }\n          break;\n\n        case 'back':\n          config.configBackEvent?.callback(functionControl);\n          if (!config.configBackEvent?.ignoreRemoveDialog) {\n            this.removeDialog(idDialog);\n          }\n          break;\n      }\n    });\n\n    component.setInput('zIndex', config.zIndex);\n    component.setInput('title', config.title);\n    component.setInput('titleUseInnerText', config.titleUseInnerText ?? false);\n    component.setInput('titleUseXssFilter', config.titleUseXssFilter ?? true);\n    component.setInput('width', config.width || '500px');\n    component.setInput('height', config.height || 'auto');\n    component.setInput('maxWidth', config.maxWidth);\n    component.setInput('maxHeight', config.maxHeight);\n    component.setInput('headerConfig', config.headerConfig || { hidden: !config.title });\n    component.setInput('bodyConfig', config.bodyConfig);\n    component.setInput('footerConfig', config.footerConfig);\n    component.setInput('classIncludeModalWrapper', config.classIncludeModalWrapper);\n    component.setInput('disable', config.disable || false);\n    component.setInput('mode', config.mode || 'center');\n    component.setInput('ignoreCommunicateMicroEvent', config.ignoreCommunicateMicroEvent);\n    if (config.buttonsFooter) {\n      component.setInput('buttonsFooter', config.buttonsFooter);\n    }\n    this.dialogsRef.set(idDialog, { component });\n    this.dynamicComponentService.addToBody(component, isAddParentDocument);\n\n    return idDialog;\n  }\n\n  public switchDisableActionsOnDialog(id: string) {\n    const data = this.dialogsRef.get(id);\n\n    if (!data) {\n      return;\n    }\n    data.component.setInput('disable', !data.component.instance.disable);\n  }\n\n  public removeDialog(id: string) {\n    const data = this.dialogsRef.get(id);\n\n    if (!data) {\n      return;\n    }\n    this.dynamicComponentService.remove(data.component);\n    this.dialogsRef.delete(id);\n  }\n\n  public clearDialogsRef() {\n    const keys = this.dialogsRef.keys();\n\n    for (const key of keys) {\n      this.removeDialog(key);\n    }\n  }\n}\n"]}
@@ -0,0 +1,3 @@
1
+ export * from './dialog.service';
2
+ export * from './interfaces/dialog.interface';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzLXVpL3NlcnZpY2VzL2RpYWxvZy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLCtCQUErQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kaWFsb2cuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2ludGVyZmFjZXMvZGlhbG9nLmludGVyZmFjZSc7XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMtdWkvc2VydmljZXMvZGlhbG9nL3NyYy9pbnRlcmZhY2VzL2RpYWxvZy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElCdXR0b24gfSBmcm9tICdAbGlicy11aS9jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uJztcbmltcG9ydCB7IElNb2RhbEJvZHlDb25maWcsIElNb2RhbEZvb3RlckNvbmZpZywgSU1vZGFsRnVuY3Rpb25zQ29udHJvbCwgSU1vZGFsSGVhZGVyQ29uZmlnIH0gZnJvbSAnQGxpYnMtdWkvY29tcG9uZW50cy1tb2RhbCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSURpYWxvZyB7XG4gIHpJbmRleD86IG51bWJlcjtcbiAgdGl0bGU/OiBzdHJpbmc7XG4gIHRpdGxlVXNlSW5uZXJUZXh0PzogYm9vbGVhbjtcbiAgdGl0bGVVc2VYc3NGaWx0ZXI/OiBib29sZWFuO1xuICB3aWR0aD86IHN0cmluZztcbiAgaGVpZ2h0Pzogc3RyaW5nO1xuICBtYXhXaWR0aD86IHN0cmluZztcbiAgbWF4SGVpZ2h0Pzogc3RyaW5nO1xuICBjbGFzc0luY2x1ZGVNb2RhbFdyYXBwZXI/OiBzdHJpbmc7XG4gIGhlYWRlckNvbmZpZz86IElNb2RhbEhlYWRlckNvbmZpZztcbiAgYm9keUNvbmZpZz86IElNb2RhbEJvZHlDb25maWc7XG4gIGZvb3RlckNvbmZpZz86IElNb2RhbEZvb3RlckNvbmZpZztcbiAgZGlzYWJsZT86IGJvb2xlYW47XG4gIGJ1dHRvbnNGb290ZXI/OiBBcnJheTxJQnV0dG9uPjtcbiAgY29uZmlnQWdyZWVFdmVudD86IElEaWFsb2dDb25maWdFdmVudDtcbiAgY29uZmlnQ2xvc2VFdmVudD86IElEaWFsb2dDb25maWdFdmVudDtcbiAgY29uZmlnQ2FuY2VsRXZlbnQ/OiBJRGlhbG9nQ29uZmlnRXZlbnQ7XG4gIGNvbmZpZ0JhY2tFdmVudD86IElEaWFsb2dDb25maWdFdmVudDtcbiAgaWdub3JlQ29tbXVuaWNhdGVNaWNyb0V2ZW50PzogYm9vbGVhbjtcbiAgbW9kZT86ICdjZW50ZXInIHwgJ29mZnNldC1yaWdodCc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSURpYWxvZ0NvbmZpZ0V2ZW50IHtcbiAgY2FsbGJhY2s6IChmdW5jdGlvbnNDb250cm9sPzogSU1vZGFsRnVuY3Rpb25zQ29udHJvbCkgPT4gUHJvbWlzZTx2b2lkPjtcbiAgaWdub3JlUmVtb3ZlRGlhbG9nPzogYm9vbGVhbjtcbn1cbiJdfQ==
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlicy11aS1zZXJ2aWNlcy1kaWFsb2cuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzLXVpL3NlcnZpY2VzL2RpYWxvZy9zcmMvbGlicy11aS1zZXJ2aWNlcy1kaWFsb2cudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
@@ -0,0 +1,103 @@
1
+ import * as i0 from '@angular/core';
2
+ import { inject, Injectable } from '@angular/core';
3
+ import { LibsUiComponentsModalComponent } from '@libs-ui/components-modal';
4
+ import { LibsUiDynamicComponentService } from '@libs-ui/services-dynamic-component';
5
+ import { uuid } from '@libs-ui/utils';
6
+
7
+ class LibsUiDialogService {
8
+ dialogsRef = new Map();
9
+ dynamicComponentService = inject(LibsUiDynamicComponentService);
10
+ addDialog(config, isAddParentDocument) {
11
+ const idDialog = uuid();
12
+ const component = this.dynamicComponentService.resolveComponentFactory(LibsUiComponentsModalComponent);
13
+ const instance = component.instance;
14
+ let functionControl;
15
+ instance.outFunctionControl.subscribe((func) => (functionControl = func));
16
+ instance.outEvent.subscribe((eventName) => {
17
+ functionControl.setStateDisable(true);
18
+ switch (eventName) {
19
+ case 'agree':
20
+ config.configAgreeEvent?.callback(functionControl);
21
+ if (!config.configAgreeEvent?.ignoreRemoveDialog) {
22
+ this.removeDialog(idDialog);
23
+ }
24
+ return;
25
+ case 'close':
26
+ config.configCloseEvent?.callback(functionControl);
27
+ if (!config.configCloseEvent?.ignoreRemoveDialog) {
28
+ this.removeDialog(idDialog);
29
+ }
30
+ return;
31
+ case 'cancel':
32
+ config.configCancelEvent?.callback(functionControl);
33
+ if (!config.configCancelEvent?.ignoreRemoveDialog) {
34
+ this.removeDialog(idDialog);
35
+ }
36
+ break;
37
+ case 'back':
38
+ config.configBackEvent?.callback(functionControl);
39
+ if (!config.configBackEvent?.ignoreRemoveDialog) {
40
+ this.removeDialog(idDialog);
41
+ }
42
+ break;
43
+ }
44
+ });
45
+ component.setInput('zIndex', config.zIndex);
46
+ component.setInput('title', config.title);
47
+ component.setInput('titleUseInnerText', config.titleUseInnerText ?? false);
48
+ component.setInput('titleUseXssFilter', config.titleUseXssFilter ?? true);
49
+ component.setInput('width', config.width || '500px');
50
+ component.setInput('height', config.height || 'auto');
51
+ component.setInput('maxWidth', config.maxWidth);
52
+ component.setInput('maxHeight', config.maxHeight);
53
+ component.setInput('headerConfig', config.headerConfig || { hidden: !config.title });
54
+ component.setInput('bodyConfig', config.bodyConfig);
55
+ component.setInput('footerConfig', config.footerConfig);
56
+ component.setInput('classIncludeModalWrapper', config.classIncludeModalWrapper);
57
+ component.setInput('disable', config.disable || false);
58
+ component.setInput('mode', config.mode || 'center');
59
+ component.setInput('ignoreCommunicateMicroEvent', config.ignoreCommunicateMicroEvent);
60
+ if (config.buttonsFooter) {
61
+ component.setInput('buttonsFooter', config.buttonsFooter);
62
+ }
63
+ this.dialogsRef.set(idDialog, { component });
64
+ this.dynamicComponentService.addToBody(component, isAddParentDocument);
65
+ return idDialog;
66
+ }
67
+ switchDisableActionsOnDialog(id) {
68
+ const data = this.dialogsRef.get(id);
69
+ if (!data) {
70
+ return;
71
+ }
72
+ data.component.setInput('disable', !data.component.instance.disable);
73
+ }
74
+ removeDialog(id) {
75
+ const data = this.dialogsRef.get(id);
76
+ if (!data) {
77
+ return;
78
+ }
79
+ this.dynamicComponentService.remove(data.component);
80
+ this.dialogsRef.delete(id);
81
+ }
82
+ clearDialogsRef() {
83
+ const keys = this.dialogsRef.keys();
84
+ for (const key of keys) {
85
+ this.removeDialog(key);
86
+ }
87
+ }
88
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiDialogService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
89
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiDialogService, providedIn: 'root' });
90
+ }
91
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiDialogService, decorators: [{
92
+ type: Injectable,
93
+ args: [{
94
+ providedIn: 'root',
95
+ }]
96
+ }] });
97
+
98
+ /**
99
+ * Generated bundle index. Do not edit.
100
+ */
101
+
102
+ export { LibsUiDialogService };
103
+ //# sourceMappingURL=libs-ui-services-dialog.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"libs-ui-services-dialog.mjs","sources":["../../../../../libs-ui/services/dialog/src/dialog.service.ts","../../../../../libs-ui/services/dialog/src/libs-ui-services-dialog.ts"],"sourcesContent":["import { ComponentRef, Injectable, inject } from '@angular/core';\nimport { IModalFunctionsControl, LibsUiComponentsModalComponent, TYPE_MODAL_EVENT } from '@libs-ui/components-modal';\nimport { LibsUiDynamicComponentService } from '@libs-ui/services-dynamic-component';\nimport { uuid } from '@libs-ui/utils';\nimport { IDialog } from './interfaces/dialog.interface';\n\n@Injectable({\n providedIn: 'root',\n})\nexport class LibsUiDialogService {\n private dialogsRef: Map<string, { component: ComponentRef<LibsUiComponentsModalComponent> }> = new Map();\n private dynamicComponentService = inject(LibsUiDynamicComponentService);\n\n public addDialog(config: IDialog, isAddParentDocument?: boolean): string {\n const idDialog = uuid();\n const component = this.dynamicComponentService.resolveComponentFactory(LibsUiComponentsModalComponent);\n const instance = component.instance;\n let functionControl: IModalFunctionsControl;\n instance.outFunctionControl.subscribe((func: IModalFunctionsControl) => (functionControl = func));\n\n instance.outEvent.subscribe((eventName: TYPE_MODAL_EVENT) => {\n functionControl.setStateDisable(true);\n\n switch (eventName) {\n case 'agree':\n config.configAgreeEvent?.callback(functionControl);\n if (!config.configAgreeEvent?.ignoreRemoveDialog) {\n this.removeDialog(idDialog);\n }\n\n return;\n\n case 'close':\n config.configCloseEvent?.callback(functionControl);\n if (!config.configCloseEvent?.ignoreRemoveDialog) {\n this.removeDialog(idDialog);\n }\n\n return;\n\n case 'cancel':\n config.configCancelEvent?.callback(functionControl);\n if (!config.configCancelEvent?.ignoreRemoveDialog) {\n this.removeDialog(idDialog);\n }\n break;\n\n case 'back':\n config.configBackEvent?.callback(functionControl);\n if (!config.configBackEvent?.ignoreRemoveDialog) {\n this.removeDialog(idDialog);\n }\n break;\n }\n });\n\n component.setInput('zIndex', config.zIndex);\n component.setInput('title', config.title);\n component.setInput('titleUseInnerText', config.titleUseInnerText ?? false);\n component.setInput('titleUseXssFilter', config.titleUseXssFilter ?? true);\n component.setInput('width', config.width || '500px');\n component.setInput('height', config.height || 'auto');\n component.setInput('maxWidth', config.maxWidth);\n component.setInput('maxHeight', config.maxHeight);\n component.setInput('headerConfig', config.headerConfig || { hidden: !config.title });\n component.setInput('bodyConfig', config.bodyConfig);\n component.setInput('footerConfig', config.footerConfig);\n component.setInput('classIncludeModalWrapper', config.classIncludeModalWrapper);\n component.setInput('disable', config.disable || false);\n component.setInput('mode', config.mode || 'center');\n component.setInput('ignoreCommunicateMicroEvent', config.ignoreCommunicateMicroEvent);\n if (config.buttonsFooter) {\n component.setInput('buttonsFooter', config.buttonsFooter);\n }\n this.dialogsRef.set(idDialog, { component });\n this.dynamicComponentService.addToBody(component, isAddParentDocument);\n\n return idDialog;\n }\n\n public switchDisableActionsOnDialog(id: string) {\n const data = this.dialogsRef.get(id);\n\n if (!data) {\n return;\n }\n data.component.setInput('disable', !data.component.instance.disable);\n }\n\n public removeDialog(id: string) {\n const data = this.dialogsRef.get(id);\n\n if (!data) {\n return;\n }\n this.dynamicComponentService.remove(data.component);\n this.dialogsRef.delete(id);\n }\n\n public clearDialogsRef() {\n const keys = this.dialogsRef.keys();\n\n for (const key of keys) {\n this.removeDialog(key);\n }\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
package/index.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ export * from './dialog.service';
2
+ export * from './interfaces/dialog.interface';
@@ -0,0 +1,28 @@
1
+ import { IButton } from '@libs-ui/components-buttons-button';
2
+ import { IModalBodyConfig, IModalFooterConfig, IModalFunctionsControl, IModalHeaderConfig } from '@libs-ui/components-modal';
3
+ export interface IDialog {
4
+ zIndex?: number;
5
+ title?: string;
6
+ titleUseInnerText?: boolean;
7
+ titleUseXssFilter?: boolean;
8
+ width?: string;
9
+ height?: string;
10
+ maxWidth?: string;
11
+ maxHeight?: string;
12
+ classIncludeModalWrapper?: string;
13
+ headerConfig?: IModalHeaderConfig;
14
+ bodyConfig?: IModalBodyConfig;
15
+ footerConfig?: IModalFooterConfig;
16
+ disable?: boolean;
17
+ buttonsFooter?: Array<IButton>;
18
+ configAgreeEvent?: IDialogConfigEvent;
19
+ configCloseEvent?: IDialogConfigEvent;
20
+ configCancelEvent?: IDialogConfigEvent;
21
+ configBackEvent?: IDialogConfigEvent;
22
+ ignoreCommunicateMicroEvent?: boolean;
23
+ mode?: 'center' | 'offset-right';
24
+ }
25
+ export interface IDialogConfigEvent {
26
+ callback: (functionsControl?: IModalFunctionsControl) => Promise<void>;
27
+ ignoreRemoveDialog?: boolean;
28
+ }
package/package.json ADDED
@@ -0,0 +1,28 @@
1
+ {
2
+ "name": "@libs-ui/services-dialog",
3
+ "version": "0.1.1-1",
4
+ "peerDependencies": {
5
+ "@angular/core": ">=18.0.0",
6
+ "@libs-ui/components-modal": "0.1.1-1",
7
+ "@libs-ui/services-dynamic-component": "0.1.1-1",
8
+ "@libs-ui/utils": "0.1.1-1",
9
+ "@libs-ui/components-buttons-button": "0.1.1-1"
10
+ },
11
+ "sideEffects": false,
12
+ "module": "fesm2022/libs-ui-services-dialog.mjs",
13
+ "typings": "index.d.ts",
14
+ "exports": {
15
+ "./package.json": {
16
+ "default": "./package.json"
17
+ },
18
+ ".": {
19
+ "types": "./index.d.ts",
20
+ "esm2022": "./esm2022/libs-ui-services-dialog.mjs",
21
+ "esm": "./esm2022/libs-ui-services-dialog.mjs",
22
+ "default": "./fesm2022/libs-ui-services-dialog.mjs"
23
+ }
24
+ },
25
+ "dependencies": {
26
+ "tslib": "^2.3.0"
27
+ }
28
+ }