@libs-ui/services-dialog 0.2.10-6.2
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 +3 -0
- package/dialog.service.d.ts +12 -0
- package/esm2022/dialog.service.mjs +94 -0
- package/esm2022/index.mjs +3 -0
- package/esm2022/interfaces/dialog.interface.mjs +2 -0
- package/esm2022/libs-ui-services-dialog.mjs +5 -0
- package/fesm2022/libs-ui-services-dialog.mjs +101 -0
- package/fesm2022/libs-ui-services-dialog.mjs.map +1 -0
- package/index.d.ts +2 -0
- package/interfaces/dialog.interface.d.ts +26 -0
- package/package.json +25 -0
package/README.md
ADDED
|
@@ -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,94 @@
|
|
|
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('width', config.width || '500px');
|
|
47
|
+
component.setInput('height', config.height || 'auto');
|
|
48
|
+
component.setInput('maxWidth', config.maxWidth);
|
|
49
|
+
component.setInput('maxHeight', config.maxHeight);
|
|
50
|
+
component.setInput('headerConfig', config.headerConfig || { hidden: !config.title });
|
|
51
|
+
component.setInput('bodyConfig', config.bodyConfig);
|
|
52
|
+
component.setInput('footerConfig', config.footerConfig);
|
|
53
|
+
component.setInput('classIncludeModalWrapper', config.classIncludeModalWrapper);
|
|
54
|
+
component.setInput('disable', config.disable || false);
|
|
55
|
+
component.setInput('mode', config.mode || 'center');
|
|
56
|
+
component.setInput('ignoreCommunicateMicroEvent', config.ignoreCommunicateMicroEvent);
|
|
57
|
+
if (config.buttonsFooter) {
|
|
58
|
+
component.setInput('buttonsFooter', config.buttonsFooter);
|
|
59
|
+
}
|
|
60
|
+
this.dialogsRef.set(idDialog, { component });
|
|
61
|
+
this.dynamicComponentService.addToBody(component, isAddParentDocument);
|
|
62
|
+
return idDialog;
|
|
63
|
+
}
|
|
64
|
+
switchDisableActionsOnDialog(id) {
|
|
65
|
+
const data = this.dialogsRef.get(id);
|
|
66
|
+
if (!data) {
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
data.component.setInput('disable', !data.component.instance.disable);
|
|
70
|
+
}
|
|
71
|
+
removeDialog(id) {
|
|
72
|
+
const data = this.dialogsRef.get(id);
|
|
73
|
+
if (!data) {
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
this.dynamicComponentService.remove(data.component);
|
|
77
|
+
this.dialogsRef.delete(id);
|
|
78
|
+
}
|
|
79
|
+
clearDialogsRef() {
|
|
80
|
+
const keys = this.dialogsRef.keys();
|
|
81
|
+
for (const key of keys) {
|
|
82
|
+
this.removeDialog(key);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiDialogService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
86
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiDialogService, providedIn: 'root' });
|
|
87
|
+
}
|
|
88
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiDialogService, decorators: [{
|
|
89
|
+
type: Injectable,
|
|
90
|
+
args: [{
|
|
91
|
+
providedIn: 'root'
|
|
92
|
+
}]
|
|
93
|
+
}] });
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../../../libs-ui/services/dialog/src/dialog.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACjE,OAAO,EAA0B,8BAA8B,EAAoB,MAAM,2BAA2B,CAAC;AACrH,OAAO,EAAE,6BAA6B,EAAE,MAAM,qCAAqC,CAAC;AACpF,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;;AAMtC,MAAM,OAAO,mBAAmB;IACtB,UAAU,GAA6E,IAAI,GAAG,EAAE,CAAC;IACjG,uBAAuB,GAAG,MAAM,CAAC,6BAA6B,CAAC,CAAC;IAEjE,SAAS,CAAC,MAAe,EAAE,mBAA6B;QAC7D,MAAM,QAAQ,GAAG,IAAI,EAAE,CAAC;QACxB,MAAM,SAAS,GAAG,IAAI,CAAC,uBAAuB,CAAC,uBAAuB,CAAC,8BAA8B,CAAC,CAAC;QACvG,MAAM,QAAQ,GAAG,SAAS,CAAC,QAAQ,CAAC;QACpC,IAAI,eAAuC,CAAC;QAC5C,QAAQ,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,IAA4B,EAAE,EAAE,CAAC,eAAe,GAAG,IAAI,CAAC,CAAC;QAEhG,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,SAA2B,EAAE,EAAE;YAC1D,eAAe,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;YAEtC,QAAQ,SAAS,EAAE,CAAC;gBAClB,KAAK,OAAO;oBACV,MAAM,CAAC,gBAAgB,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;oBACnD,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,kBAAkB,EAAE,CAAC;wBACjD,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;oBAC9B,CAAC;oBAED,OAAO;gBAET,KAAK,OAAO;oBACV,MAAM,CAAC,gBAAgB,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;oBACnD,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,kBAAkB,EAAE,CAAC;wBACjD,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;oBAC9B,CAAC;oBAED,OAAO;gBAET,KAAK,QAAQ;oBACX,MAAM,CAAC,iBAAiB,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;oBACpD,IAAI,CAAC,MAAM,CAAC,iBAAiB,EAAE,kBAAkB,EAAE,CAAC;wBAClD,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;oBAC9B,CAAC;oBACD,MAAM;gBAER,KAAK,MAAM;oBACT,MAAM,CAAC,eAAe,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;oBAClD,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,kBAAkB,EAAE,CAAC;wBAChD,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;oBAC9B,CAAC;oBACD,MAAM;YACV,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;QAC5C,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;QAC1C,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC,KAAK,IAAI,OAAO,CAAC,CAAC;QACrD,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,CAAC;QACtD,SAAS,CAAC,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC;QAChD,SAAS,CAAC,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC;QAClD,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,MAAM,CAAC,YAAY,IAAI,EAAE,MAAM,EAAE,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC;QACrF,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC;QACpD,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,MAAM,CAAC,YAAY,CAAC,CAAC;QACxD,SAAS,CAAC,QAAQ,CAAC,0BAA0B,EAAE,MAAM,CAAC,wBAAwB,CAAC,CAAC;QAChF,SAAS,CAAC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC,OAAO,IAAI,KAAK,CAAC,CAAC;QACvD,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,IAAI,QAAQ,CAAC,CAAC;QACpD,SAAS,CAAC,QAAQ,CAAC,6BAA6B,EAAE,MAAM,CAAC,2BAA2B,CAAC,CAAC;QACtF,IAAI,MAAM,CAAC,aAAa,EAAE,CAAC;YACzB,SAAS,CAAC,QAAQ,CAAC,eAAe,EAAE,MAAM,CAAC,aAAa,CAAC,CAAA;QAC3D,CAAC;QACD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC;QAC7C,IAAI,CAAC,uBAAuB,CAAC,SAAS,CAAC,SAAS,EAAE,mBAAmB,CAAC,CAAC;QAEvE,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEM,4BAA4B,CAAC,EAAU;QAC5C,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAErC,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,OAAO;QACT,CAAC;QACD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IACvE,CAAC;IAEM,YAAY,CAAC,EAAU;QAC5B,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAErC,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,OAAO;QACT,CAAC;QACD,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACpD,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAC7B,CAAC;IAEM,eAAe;QACpB,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QAEpC,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;QACzB,CAAC;IACH,CAAC;wGA9FU,mBAAmB;4GAAnB,mBAAmB,cAFlB,MAAM;;4FAEP,mBAAmB;kBAH/B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","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('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}"]}
|
|
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMtdWkvc2VydmljZXMvZGlhbG9nL3NyYy9pbnRlcmZhY2VzL2RpYWxvZy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIlxuaW1wb3J0IHsgSUJ1dHRvbiB9IGZyb20gXCJAbGlicy11aS9jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uXCI7XG5pbXBvcnQgeyBJTW9kYWxCb2R5Q29uZmlnLCBJTW9kYWxGb290ZXJDb25maWcsIElNb2RhbEZ1bmN0aW9uc0NvbnRyb2wsIElNb2RhbEhlYWRlckNvbmZpZyB9IGZyb20gXCJAbGlicy11aS9jb21wb25lbnRzLW1vZGFsXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSURpYWxvZyB7XG4gIHpJbmRleD86IG51bWJlcjtcbiAgdGl0bGU/OiBzdHJpbmc7XG4gIHdpZHRoPzogc3RyaW5nO1xuICBoZWlnaHQ/OiBzdHJpbmc7XG4gIG1heFdpZHRoPzogc3RyaW5nO1xuICBtYXhIZWlnaHQ/OiBzdHJpbmc7XG4gIGNsYXNzSW5jbHVkZU1vZGFsV3JhcHBlcj86IHN0cmluZztcbiAgaGVhZGVyQ29uZmlnPzogSU1vZGFsSGVhZGVyQ29uZmlnO1xuICBib2R5Q29uZmlnPzogSU1vZGFsQm9keUNvbmZpZztcbiAgZm9vdGVyQ29uZmlnPzogSU1vZGFsRm9vdGVyQ29uZmlnO1xuICBkaXNhYmxlPzogYm9vbGVhbjtcbiAgYnV0dG9uc0Zvb3Rlcj86IEFycmF5PElCdXR0b24+O1xuICBjb25maWdBZ3JlZUV2ZW50PzogSURpYWxvZ0NvbmZpZ0V2ZW50O1xuICBjb25maWdDbG9zZUV2ZW50PzogSURpYWxvZ0NvbmZpZ0V2ZW50O1xuICBjb25maWdDYW5jZWxFdmVudD86IElEaWFsb2dDb25maWdFdmVudDtcbiAgY29uZmlnQmFja0V2ZW50PzogSURpYWxvZ0NvbmZpZ0V2ZW50O1xuICBpZ25vcmVDb21tdW5pY2F0ZU1pY3JvRXZlbnQ/OiBib29sZWFuO1xuICBtb2RlPzogJ2NlbnRlcicgfCAnb2Zmc2V0LXJpZ2h0Jztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJRGlhbG9nQ29uZmlnRXZlbnQge1xuICBjYWxsYmFjazogKGZ1bmN0aW9uc0NvbnRyb2w/OiBJTW9kYWxGdW5jdGlvbnNDb250cm9sKSA9PiBQcm9taXNlPHZvaWQ+O1xuICBpZ25vcmVSZW1vdmVEaWFsb2c6IGJvb2xlYW47XG59Il19
|
|
@@ -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,101 @@
|
|
|
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('width', config.width || '500px');
|
|
48
|
+
component.setInput('height', config.height || 'auto');
|
|
49
|
+
component.setInput('maxWidth', config.maxWidth);
|
|
50
|
+
component.setInput('maxHeight', config.maxHeight);
|
|
51
|
+
component.setInput('headerConfig', config.headerConfig || { hidden: !config.title });
|
|
52
|
+
component.setInput('bodyConfig', config.bodyConfig);
|
|
53
|
+
component.setInput('footerConfig', config.footerConfig);
|
|
54
|
+
component.setInput('classIncludeModalWrapper', config.classIncludeModalWrapper);
|
|
55
|
+
component.setInput('disable', config.disable || false);
|
|
56
|
+
component.setInput('mode', config.mode || 'center');
|
|
57
|
+
component.setInput('ignoreCommunicateMicroEvent', config.ignoreCommunicateMicroEvent);
|
|
58
|
+
if (config.buttonsFooter) {
|
|
59
|
+
component.setInput('buttonsFooter', config.buttonsFooter);
|
|
60
|
+
}
|
|
61
|
+
this.dialogsRef.set(idDialog, { component });
|
|
62
|
+
this.dynamicComponentService.addToBody(component, isAddParentDocument);
|
|
63
|
+
return idDialog;
|
|
64
|
+
}
|
|
65
|
+
switchDisableActionsOnDialog(id) {
|
|
66
|
+
const data = this.dialogsRef.get(id);
|
|
67
|
+
if (!data) {
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
data.component.setInput('disable', !data.component.instance.disable);
|
|
71
|
+
}
|
|
72
|
+
removeDialog(id) {
|
|
73
|
+
const data = this.dialogsRef.get(id);
|
|
74
|
+
if (!data) {
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
this.dynamicComponentService.remove(data.component);
|
|
78
|
+
this.dialogsRef.delete(id);
|
|
79
|
+
}
|
|
80
|
+
clearDialogsRef() {
|
|
81
|
+
const keys = this.dialogsRef.keys();
|
|
82
|
+
for (const key of keys) {
|
|
83
|
+
this.removeDialog(key);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiDialogService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
87
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiDialogService, providedIn: 'root' });
|
|
88
|
+
}
|
|
89
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiDialogService, decorators: [{
|
|
90
|
+
type: Injectable,
|
|
91
|
+
args: [{
|
|
92
|
+
providedIn: 'root'
|
|
93
|
+
}]
|
|
94
|
+
}] });
|
|
95
|
+
|
|
96
|
+
/**
|
|
97
|
+
* Generated bundle index. Do not edit.
|
|
98
|
+
*/
|
|
99
|
+
|
|
100
|
+
export { LibsUiDialogService };
|
|
101
|
+
//# 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('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 * 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,26 @@
|
|
|
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
|
+
width?: string;
|
|
7
|
+
height?: string;
|
|
8
|
+
maxWidth?: string;
|
|
9
|
+
maxHeight?: string;
|
|
10
|
+
classIncludeModalWrapper?: string;
|
|
11
|
+
headerConfig?: IModalHeaderConfig;
|
|
12
|
+
bodyConfig?: IModalBodyConfig;
|
|
13
|
+
footerConfig?: IModalFooterConfig;
|
|
14
|
+
disable?: boolean;
|
|
15
|
+
buttonsFooter?: Array<IButton>;
|
|
16
|
+
configAgreeEvent?: IDialogConfigEvent;
|
|
17
|
+
configCloseEvent?: IDialogConfigEvent;
|
|
18
|
+
configCancelEvent?: IDialogConfigEvent;
|
|
19
|
+
configBackEvent?: IDialogConfigEvent;
|
|
20
|
+
ignoreCommunicateMicroEvent?: boolean;
|
|
21
|
+
mode?: 'center' | 'offset-right';
|
|
22
|
+
}
|
|
23
|
+
export interface IDialogConfigEvent {
|
|
24
|
+
callback: (functionsControl?: IModalFunctionsControl) => Promise<void>;
|
|
25
|
+
ignoreRemoveDialog: boolean;
|
|
26
|
+
}
|
package/package.json
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@libs-ui/services-dialog",
|
|
3
|
+
"version": "0.2.106.2",
|
|
4
|
+
"peerDependencies": {
|
|
5
|
+
"@angular/common": "^18.2.0",
|
|
6
|
+
"@angular/core": "^18.2.0"
|
|
7
|
+
},
|
|
8
|
+
"sideEffects": false,
|
|
9
|
+
"module": "fesm2022/libs-ui-services-dialog.mjs",
|
|
10
|
+
"typings": "index.d.ts",
|
|
11
|
+
"exports": {
|
|
12
|
+
"./package.json": {
|
|
13
|
+
"default": "./package.json"
|
|
14
|
+
},
|
|
15
|
+
".": {
|
|
16
|
+
"types": "./index.d.ts",
|
|
17
|
+
"esm2022": "./esm2022/libs-ui-services-dialog.mjs",
|
|
18
|
+
"esm": "./esm2022/libs-ui-services-dialog.mjs",
|
|
19
|
+
"default": "./fesm2022/libs-ui-services-dialog.mjs"
|
|
20
|
+
}
|
|
21
|
+
},
|
|
22
|
+
"dependencies": {
|
|
23
|
+
"tslib": "^2.3.0"
|
|
24
|
+
}
|
|
25
|
+
}
|