@mediusinc/mng-commons 0.2.18 → 0.2.19

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.
Files changed (66) hide show
  1. package/assets/i18n/sl.json +15 -15
  2. package/esm2020/lib/components/action/action.component.mjs +32 -18
  3. package/esm2020/lib/components/action/editor/action-editor.component.mjs +182 -0
  4. package/esm2020/lib/components/action/index.mjs +2 -2
  5. package/esm2020/lib/components/action/models/action-execution.model.mjs +3 -3
  6. package/esm2020/lib/components/action/route/action-route.component.mjs +17 -12
  7. package/esm2020/lib/components/form/editor/form-editor.component.mjs +2 -2
  8. package/esm2020/lib/components/form/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.mjs +3 -3
  9. package/esm2020/lib/components/form/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +3 -3
  10. package/esm2020/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.mjs +3 -3
  11. package/esm2020/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +3 -3
  12. package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +7 -3
  13. package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +3 -3
  14. package/esm2020/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.mjs +3 -3
  15. package/esm2020/lib/components/form/formly/wrappers/formly-table-wrapper/formly-table-wrapper.component.mjs +4 -3
  16. package/esm2020/lib/components/form/models/form-editor.event.mjs +1 -1
  17. package/esm2020/lib/components/tableview/table/table.component.mjs +9 -9
  18. package/esm2020/lib/components/tableview/tableview.component.mjs +22 -15
  19. package/esm2020/lib/data-providers/table.data-provider.mjs +1 -1
  20. package/esm2020/lib/descriptors/action.descriptor.mjs +112 -1
  21. package/esm2020/lib/descriptors/editor.descriptor.mjs +53 -11
  22. package/esm2020/lib/mng-commons.module.mjs +14 -10
  23. package/esm2020/lib/models/index.mjs +2 -1
  24. package/esm2020/lib/models/view-container.model.mjs +2 -0
  25. package/esm2020/lib/services/action-executor.service.mjs +291 -0
  26. package/esm2020/lib/services/index.mjs +2 -2
  27. package/esm2020/lib/services/mng-view-container-component.service.mjs +35 -0
  28. package/esm2020/lib/services/tokens/default-setting.token.mjs +3 -0
  29. package/esm2020/lib/services/tokens/index.mjs +2 -1
  30. package/esm2020/lib/utils/toast.util.mjs +15 -7
  31. package/esm2020/public-api.mjs +1 -2
  32. package/fesm2015/mediusinc-mng-commons.mjs +944 -677
  33. package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
  34. package/fesm2020/mediusinc-mng-commons.mjs +914 -657
  35. package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
  36. package/lib/components/action/action.component.d.ts +12 -7
  37. package/lib/components/action/{dialog/action-dialog.component.d.ts → editor/action-editor.component.d.ts} +18 -12
  38. package/lib/components/action/index.d.ts +1 -1
  39. package/lib/components/action/models/action-execution.model.d.ts +3 -3
  40. package/lib/components/action/route/action-route.component.d.ts +6 -6
  41. package/lib/components/tableview/table/table.component.d.ts +3 -3
  42. package/lib/components/tableview/tableview.component.d.ts +10 -7
  43. package/lib/descriptors/action.descriptor.d.ts +41 -5
  44. package/lib/descriptors/editor.descriptor.d.ts +23 -4
  45. package/lib/mng-commons.module.d.ts +2 -2
  46. package/lib/models/index.d.ts +1 -0
  47. package/lib/models/view-container.model.d.ts +6 -0
  48. package/lib/services/{action.service.d.ts → action-executor.service.d.ts} +19 -18
  49. package/lib/services/index.d.ts +1 -1
  50. package/lib/services/mng-view-container-component.service.d.ts +22 -0
  51. package/lib/services/tokens/default-setting.token.d.ts +2 -0
  52. package/lib/services/tokens/index.d.ts +1 -0
  53. package/lib/utils/toast.util.d.ts +5 -4
  54. package/package.json +1 -1
  55. package/public-api.d.ts +0 -1
  56. package/scss/mng-overrides/_layout_forms.scss +2 -0
  57. package/scss/mng-overrides/_mixins.scss +7 -0
  58. package/scss/mng-overrides/_theme_button.scss +58 -0
  59. package/scss/mng-overrides/_theme_styles.scss +1 -0
  60. package/scss/mng-overrides/_variables.scss +2 -0
  61. package/esm2020/lib/components/action/dialog/action-dialog.component.mjs +0 -151
  62. package/esm2020/lib/components/tableview/services/index.mjs +0 -2
  63. package/esm2020/lib/components/tableview/services/tableview.component.service.mjs +0 -21
  64. package/esm2020/lib/services/action.service.mjs +0 -273
  65. package/lib/components/tableview/services/index.d.ts +0 -1
  66. package/lib/components/tableview/services/tableview.component.service.d.ts +0 -14
@@ -10,7 +10,7 @@
10
10
  "cancel": "Prekliči",
11
11
  "close": "Zapri",
12
12
  "add": "Dodaj",
13
- "addItem": "Dodaj {{item}}",
13
+ "addItem": "{{item}} - dodaj",
14
14
  "edit": "Uredi",
15
15
  "delete": "Izbriši",
16
16
  "export": "Izvozi",
@@ -45,11 +45,11 @@
45
45
  "invalidFormToastTitle": "Napaka v formi",
46
46
  "invalidFormToastMessage": "Forma ni veljavna, prosimo preverite vnesene informacije in jih popravite.",
47
47
  "validation": {
48
- "required": "{{field}} je zahtevano.",
49
- "minlength": "{{field}} mora biti vsaj {{min}} znakov dolgo.",
50
- "maxlength": "{{field}} mora biti največ {{max}} znakov dolgo.",
51
- "pattern": "{{field}} mora imeti obliko {{pattern}}.",
52
- "email": "{{field}} ni veljaven e-naslov."
48
+ "required": "{{field}} - vnos je obvezen.",
49
+ "minlength": "{{field}} - vons mora biti dolg vsaj {{min}} znakov.",
50
+ "maxlength": "{{field}} - vnos je lahko dolg največ {{max}} znakov.",
51
+ "pattern": "{{field}} - vnos mora imeti obliko {{pattern}}.",
52
+ "email": "{{field}} - vnos ni veljaven e-naslov."
53
53
  }
54
54
  },
55
55
  "mngAutocomplete": {
@@ -70,7 +70,7 @@
70
70
  },
71
71
  "details": {
72
72
  "dialog": {
73
- "title": "{{modelName}}: {{itemTitle}}"
73
+ "title": "{{modelName}} - podrobnosti: {{itemTitle}}"
74
74
  }
75
75
  },
76
76
  "add": {
@@ -84,33 +84,33 @@
84
84
  },
85
85
  "error": {
86
86
  "title": "Napaka",
87
- "message": "Napaka med dodajanjem {{itemTitle}}{{errorMessage}}"
87
+ "message": "Napaka pri shranjevanju '{{itemTitle}}'{{errorMessage}}"
88
88
  }
89
89
  },
90
90
  "edit": {
91
91
  "dialog": {
92
- "title": "Uredi {{modelName}}: {{itemTitle}}"
92
+ "title": "{{modelName}} - urejanje: {{itemTitle}}"
93
93
  },
94
94
  "success": {
95
- "title": "Uredil {{modelName}}",
96
- "message": "Spremembe {{itemTitle}} so uspešno shranjene."
95
+ "title": "Shranjeno",
96
+ "message": "Spremembe v '{{itemTitle}}' so uspešno shranjene."
97
97
  },
98
98
  "error": {
99
99
  "title": "Napaka",
100
- "message": "Napaka pri dodajanju {{functionTitle}}{{errorMessage}}"
100
+ "message": "Napaka pri shranjevanju '{{itemTitle}}'{{errorMessage}}"
101
101
  }
102
102
  },
103
103
  "delete": {
104
104
  "confirm": {
105
- "message": "Ali ste prepričani, da želite izbrisati {{itemTitle}}?"
105
+ "message": "Ali ste prepričani, da želite izbrisati '{{itemTitle}}'?"
106
106
  },
107
107
  "success": {
108
108
  "title": "Izbrisano",
109
- "message": "{{itemTitle}} je bil uspešno izbrisan."
109
+ "message": "'{{itemTitle}}' je bil uspešno izbrisan."
110
110
  },
111
111
  "error": {
112
112
  "title": "Napaka",
113
- "message": "Napaka med brisanjem {{itemTitle}}{{errorMessage}}"
113
+ "message": "Napaka pri brisanju '{{itemTitle}}'{{errorMessage}}"
114
114
  }
115
115
  },
116
116
  "mngPrime": {
@@ -1,33 +1,34 @@
1
- import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
- import { ConfirmationService, MessageService } from 'primeng/api';
1
+ import { ChangeDetectionStrategy, Component, Input, Optional } from '@angular/core';
2
+ import { ConfirmationService } from 'primeng/api';
3
3
  import { ReplaySubject, of } from 'rxjs';
4
- import { finalize, first } from 'rxjs/operators';
4
+ import { first } from 'rxjs/operators';
5
5
  import { I18nUtil } from '../../utils';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "@angular/router";
8
8
  import * as i2 from "@ngx-translate/core";
9
9
  import * as i3 from "../../services";
10
10
  import * as i4 from "primeng/api";
11
- import * as i5 from "../tableview/services";
11
+ import * as i5 from "../../services/mng-view-container-component.service";
12
12
  import * as i6 from "primeng/confirmdialog";
13
13
  import * as i7 from "@angular/common";
14
14
  import * as i8 from "primeng/button";
15
15
  import * as i9 from "primeng/ripple";
16
16
  import * as i10 from "primeng/tooltip";
17
17
  export class MngActionComponent {
18
- constructor(route, translate, actionService, confirmationService, tableviewService) {
18
+ constructor(route, translate, actionExecutor, confirmationService, viewContainerService) {
19
19
  this.route = route;
20
20
  this.translate = translate;
21
- this.actionService = actionService;
21
+ this.actionExecutor = actionExecutor;
22
22
  this.confirmationService = confirmationService;
23
- this.tableviewService = tableviewService;
23
+ this.viewContainerService = viewContainerService;
24
24
  this.loadingSubject = new ReplaySubject(1);
25
25
  this.$loading = this.loadingSubject.asObservable();
26
26
  this.cmpId = Math.random().toString(36).substring(2);
27
27
  this.loadingSubject.next(false);
28
28
  }
29
29
  ngOnInit() {
30
- const context = this.actionService.getActionExecContext(this.action, this.itemId, this.item, this.tableviewService?.dataProvider ?? undefined, this.tableviewService, this, this.actionData);
30
+ this.viewContainer = this.viewContainerInit ?? this.viewContainerService ?? undefined;
31
+ const context = this.actionExecutor.prepareActionExecContext(this.action, this.itemId, this.item, this.dataProvider, this.viewContainer ?? undefined, this, this.actionData);
31
32
  this.$isVisible = typeof this.action.isVisibleFunction === 'function' ? this.action.isVisibleFunction(context) : of(true);
32
33
  this.$isEnabled = typeof this.action.isEnabledFunction === 'function' ? this.action.isEnabledFunction(context) : of(true);
33
34
  this.$label = I18nUtil.streamActionTranslation(this.translate, this.action, 'title', this.action?.title ?? undefined, this.item);
@@ -38,11 +39,17 @@ export class MngActionComponent {
38
39
  this.loadingSubject.next(true);
39
40
  const actionData = this.actionData ? this.actionData : {};
40
41
  actionData['cmpId'] = this.cmpId;
41
- this.actionService
42
- .triggerAction(this.action, this.itemId, this.item, actionData, this.route, this.tableviewService, this)
43
- .pipe(first(), finalize(() => this.loadingSubject.next(false)))
44
- // eslint-disable-next-line @typescript-eslint/no-empty-function
45
- .subscribe(() => { });
42
+ this.actionExecutor
43
+ .triggerAction(this.action, this.itemId, this.item, actionData, this.route, this.viewContainer, this)
44
+ .pipe(first())
45
+ .subscribe({
46
+ next: () => {
47
+ this.loadingSubject.next(false);
48
+ },
49
+ error: err => {
50
+ console.error(`Error occurred while executing action ${this.action.actionName}.`, err);
51
+ }
52
+ });
46
53
  }
47
54
  getConfirmationService() {
48
55
  return this.confirmationService;
@@ -51,12 +58,14 @@ export class MngActionComponent {
51
58
  return `${action.actionName}_${this.cmpId}`;
52
59
  }
53
60
  }
54
- MngActionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngActionComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.TranslateService }, { token: i3.MngActionService }, { token: i4.ConfirmationService }, { token: i5.TableviewComponentService }], target: i0.ɵɵFactoryTarget.Component });
55
- MngActionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngActionComponent, selector: "mng-action", inputs: { action: "action", item: "item", itemId: "itemId", actionData: "actionData" }, providers: [MessageService, ConfirmationService], ngImport: i0, template: "<ng-container *ngIf=\"$isVisible | async\">\n <button\n *ngIf=\"action.icon && action.title === null; else noIcon\"\n type=\"button\"\n pButton\n pRipple\n [icon]=\"action.icon\"\n [loading]=\"($loading | async) ?? false\"\n [disabled]=\"($isEnabled | async) === false\"\n [pTooltip]=\"$any($tooltip | async)\"\n (click)=\"triggerAction($event)\"\n class=\"mng-action-button mng-action-button-icon p-button-rounded\"\n [class.p-button-primary]=\"action.level === 1\"\n [class.p-button-success]=\"action.level === 5\"\n [class.p-button-danger]=\"action.level === 7\"></button>\n <ng-template #noIcon>\n <button\n type=\"button\"\n pButton\n pRipple\n [icon]=\"$any(action.icon)\"\n [label]=\"($label | async) ?? ''\"\n [loading]=\"($loading | async) ?? false\"\n [disabled]=\"($isEnabled | async) === false\"\n [pTooltip]=\"$any($tooltip | async)\"\n (click)=\"triggerAction($event)\"\n class=\"mng-action-button p-button-text\"\n [class.p-button-primary]=\"action.level === 1\"\n [class.p-button-success]=\"action.level === 5\"\n [class.p-button-danger]=\"action.level === 7\"></button>\n </ng-template>\n <p-confirmDialog *ngIf=\"action.hasRunConfirmation\" [key]=\"action.actionName + '_' + cmpId\" [baseZIndex]=\"50\" appendTo=\"body\"></p-confirmDialog>\n</ng-container>\n", components: [{ type: i6.ConfirmDialog, selector: "p-confirmDialog", inputs: ["header", "icon", "message", "style", "styleClass", "maskStyleClass", "acceptIcon", "acceptLabel", "acceptAriaLabel", "acceptVisible", "rejectIcon", "rejectLabel", "rejectAriaLabel", "rejectVisible", "acceptButtonStyleClass", "rejectButtonStyleClass", "closeOnEscape", "dismissableMask", "blockScroll", "rtl", "closable", "appendTo", "key", "autoZIndex", "baseZIndex", "transitionOptions", "focusTrap", "defaultFocus", "breakpoints", "visible", "position"], outputs: ["onHide"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i9.Ripple, selector: "[pRipple]" }, { type: i10.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "pTooltip", "tooltipDisabled", "tooltipOptions"] }], pipes: { "async": i7.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
61
+ MngActionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngActionComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.TranslateService }, { token: i3.MngActionExecutorService }, { token: i4.ConfirmationService }, { token: i5.MngViewContainerComponentService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
62
+ MngActionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngActionComponent, selector: "mng-action", inputs: { action: "action", item: "item", itemId: "itemId", actionData: "actionData", dataProvider: "dataProvider", viewContainerInit: ["viewContainer", "viewContainerInit"] }, providers: [ConfirmationService], ngImport: i0, template: "<ng-container *ngIf=\"$isVisible | async\">\n <button\n *ngIf=\"action.icon && action.title === null; else noIcon\"\n type=\"button\"\n pButton\n pRipple\n [icon]=\"action.icon\"\n [loading]=\"($loading | async) ?? false\"\n [disabled]=\"($isEnabled | async) === false\"\n [pTooltip]=\"$any($tooltip | async)\"\n (click)=\"triggerAction($event)\"\n class=\"mng-action-button mng-action-button-icon p-button-rounded\"\n [class.mng-button-xs]=\"action.isSizeExtraSmall\"\n [class.mng-button-sm]=\"action.isSizeSmall\"\n [class.mng-button-lg]=\"action.isSizeLarge\"\n [class.mng-button-xl]=\"action.isSizeExtraLarge\"\n [class.p-button-primary]=\"action.level === 1\"\n [class.p-button-success]=\"action.level === 5\"\n [class.p-button-danger]=\"action.level === 7\"></button>\n <ng-template #noIcon>\n <button\n type=\"button\"\n pButton\n pRipple\n [icon]=\"$any(action.icon)\"\n [label]=\"($label | async) ?? ''\"\n [loading]=\"($loading | async) ?? false\"\n [disabled]=\"($isEnabled | async) === false\"\n [pTooltip]=\"$any($tooltip | async)\"\n (click)=\"triggerAction($event)\"\n class=\"mng-action-button p-button-text\"\n [class.p-button-sm]=\"action.isSizeSmall\"\n [class.p-button-lg]=\"action.isSizeLarge\"\n [class.p-button-primary]=\"action.level === 1\"\n [class.p-button-success]=\"action.level === 5\"\n [class.p-button-danger]=\"action.level === 7\"></button>\n </ng-template>\n <p-confirmDialog *ngIf=\"action.hasRunConfirmation\" [key]=\"action.actionName + '_' + cmpId\" [baseZIndex]=\"50\" appendTo=\"body\"></p-confirmDialog>\n</ng-container>\n", components: [{ type: i6.ConfirmDialog, selector: "p-confirmDialog", inputs: ["header", "icon", "message", "style", "styleClass", "maskStyleClass", "acceptIcon", "acceptLabel", "acceptAriaLabel", "acceptVisible", "rejectIcon", "rejectLabel", "rejectAriaLabel", "rejectVisible", "acceptButtonStyleClass", "rejectButtonStyleClass", "closeOnEscape", "dismissableMask", "blockScroll", "rtl", "closable", "appendTo", "key", "autoZIndex", "baseZIndex", "transitionOptions", "focusTrap", "defaultFocus", "breakpoints", "visible", "position"], outputs: ["onHide"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i9.Ripple, selector: "[pRipple]" }, { type: i10.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "pTooltip", "tooltipDisabled", "tooltipOptions"] }], pipes: { "async": i7.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
56
63
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngActionComponent, decorators: [{
57
64
  type: Component,
58
- args: [{ selector: 'mng-action', changeDetection: ChangeDetectionStrategy.OnPush, providers: [MessageService, ConfirmationService], template: "<ng-container *ngIf=\"$isVisible | async\">\n <button\n *ngIf=\"action.icon && action.title === null; else noIcon\"\n type=\"button\"\n pButton\n pRipple\n [icon]=\"action.icon\"\n [loading]=\"($loading | async) ?? false\"\n [disabled]=\"($isEnabled | async) === false\"\n [pTooltip]=\"$any($tooltip | async)\"\n (click)=\"triggerAction($event)\"\n class=\"mng-action-button mng-action-button-icon p-button-rounded\"\n [class.p-button-primary]=\"action.level === 1\"\n [class.p-button-success]=\"action.level === 5\"\n [class.p-button-danger]=\"action.level === 7\"></button>\n <ng-template #noIcon>\n <button\n type=\"button\"\n pButton\n pRipple\n [icon]=\"$any(action.icon)\"\n [label]=\"($label | async) ?? ''\"\n [loading]=\"($loading | async) ?? false\"\n [disabled]=\"($isEnabled | async) === false\"\n [pTooltip]=\"$any($tooltip | async)\"\n (click)=\"triggerAction($event)\"\n class=\"mng-action-button p-button-text\"\n [class.p-button-primary]=\"action.level === 1\"\n [class.p-button-success]=\"action.level === 5\"\n [class.p-button-danger]=\"action.level === 7\"></button>\n </ng-template>\n <p-confirmDialog *ngIf=\"action.hasRunConfirmation\" [key]=\"action.actionName + '_' + cmpId\" [baseZIndex]=\"50\" appendTo=\"body\"></p-confirmDialog>\n</ng-container>\n" }]
59
- }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.TranslateService }, { type: i3.MngActionService }, { type: i4.ConfirmationService }, { type: i5.TableviewComponentService }]; }, propDecorators: { action: [{
65
+ args: [{ selector: 'mng-action', changeDetection: ChangeDetectionStrategy.OnPush, providers: [ConfirmationService], template: "<ng-container *ngIf=\"$isVisible | async\">\n <button\n *ngIf=\"action.icon && action.title === null; else noIcon\"\n type=\"button\"\n pButton\n pRipple\n [icon]=\"action.icon\"\n [loading]=\"($loading | async) ?? false\"\n [disabled]=\"($isEnabled | async) === false\"\n [pTooltip]=\"$any($tooltip | async)\"\n (click)=\"triggerAction($event)\"\n class=\"mng-action-button mng-action-button-icon p-button-rounded\"\n [class.mng-button-xs]=\"action.isSizeExtraSmall\"\n [class.mng-button-sm]=\"action.isSizeSmall\"\n [class.mng-button-lg]=\"action.isSizeLarge\"\n [class.mng-button-xl]=\"action.isSizeExtraLarge\"\n [class.p-button-primary]=\"action.level === 1\"\n [class.p-button-success]=\"action.level === 5\"\n [class.p-button-danger]=\"action.level === 7\"></button>\n <ng-template #noIcon>\n <button\n type=\"button\"\n pButton\n pRipple\n [icon]=\"$any(action.icon)\"\n [label]=\"($label | async) ?? ''\"\n [loading]=\"($loading | async) ?? false\"\n [disabled]=\"($isEnabled | async) === false\"\n [pTooltip]=\"$any($tooltip | async)\"\n (click)=\"triggerAction($event)\"\n class=\"mng-action-button p-button-text\"\n [class.p-button-sm]=\"action.isSizeSmall\"\n [class.p-button-lg]=\"action.isSizeLarge\"\n [class.p-button-primary]=\"action.level === 1\"\n [class.p-button-success]=\"action.level === 5\"\n [class.p-button-danger]=\"action.level === 7\"></button>\n </ng-template>\n <p-confirmDialog *ngIf=\"action.hasRunConfirmation\" [key]=\"action.actionName + '_' + cmpId\" [baseZIndex]=\"50\" appendTo=\"body\"></p-confirmDialog>\n</ng-container>\n" }]
66
+ }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.TranslateService }, { type: i3.MngActionExecutorService }, { type: i4.ConfirmationService }, { type: i5.MngViewContainerComponentService, decorators: [{
67
+ type: Optional
68
+ }] }]; }, propDecorators: { action: [{
60
69
  type: Input
61
70
  }], item: [{
62
71
  type: Input
@@ -64,5 +73,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
64
73
  type: Input
65
74
  }], actionData: [{
66
75
  type: Input
76
+ }], dataProvider: [{
77
+ type: Input
78
+ }], viewContainerInit: [{
79
+ type: Input,
80
+ args: ['viewContainer']
67
81
  }] } });
68
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/action/action.component.ts","../../../../../src/lib/components/action/action.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, Input, OnInit} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {ConfirmationService, MessageService} from 'primeng/api';\nimport {Observable, ReplaySubject, of} from 'rxjs';\nimport {finalize, first} from 'rxjs/operators';\n\nimport {ActionDescriptor} from '../../descriptors';\nimport {MngActionService} from '../../services';\nimport {IdType} from '../../types';\nimport {I18nUtil} from '../../utils';\nimport {TableviewComponentService} from '../tableview/services';\nimport {ActionData, IActionConfirmationService} from './models';\n\n@Component({\n    selector: 'mng-action',\n    templateUrl: './action.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [MessageService, ConfirmationService]\n})\nexport class MngActionComponent<T, S> implements OnInit, IActionConfirmationService {\n    // metadata and editor mode input\n    @Input() public action!: ActionDescriptor<T>;\n    @Input() public item?: T;\n    @Input() public itemId?: IdType;\n    @Input() public actionData?: ActionData;\n\n    private loadingSubject = new ReplaySubject<boolean>(1);\n    public $loading: Observable<boolean> = this.loadingSubject.asObservable();\n\n    public cmpId: string = Math.random().toString(36).substring(2);\n    public $isVisible!: Observable<boolean>;\n    public $isEnabled!: Observable<boolean>;\n    public $label!: Observable<string | null>;\n    public $tooltip!: Observable<string | null>;\n\n    constructor(\n        private route: ActivatedRoute,\n        private translate: TranslateService,\n        private actionService: MngActionService,\n        private confirmationService: ConfirmationService,\n        private tableviewService: TableviewComponentService<T, S>\n    ) {\n        this.loadingSubject.next(false);\n    }\n\n    public ngOnInit() {\n        const context = this.actionService.getActionExecContext(\n            this.action,\n            this.itemId,\n            this.item,\n            this.tableviewService?.dataProvider ?? undefined,\n            this.tableviewService,\n            this,\n            this.actionData\n        );\n        this.$isVisible = typeof this.action.isVisibleFunction === 'function' ? this.action.isVisibleFunction(context) : of(true);\n        this.$isEnabled = typeof this.action.isEnabledFunction === 'function' ? this.action.isEnabledFunction(context) : of(true);\n        this.$label = I18nUtil.streamActionTranslation(this.translate, this.action, 'title', this.action?.title ?? undefined, this.item);\n        this.$tooltip = I18nUtil.streamActionTranslation(this.translate, this.action, 'tooltip', this.action?.tooltip ?? undefined, this.item);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    public triggerAction(event: Event) {\n        this.loadingSubject.next(true);\n        const actionData = this.actionData ? this.actionData : {};\n        actionData['cmpId'] = this.cmpId;\n        this.actionService\n            .triggerAction(this.action, this.itemId, this.item, actionData, this.route, this.tableviewService, this)\n            .pipe(\n                first(),\n                finalize(() => this.loadingSubject.next(false))\n            )\n            // eslint-disable-next-line @typescript-eslint/no-empty-function\n            .subscribe(() => {});\n    }\n\n    public getConfirmationService() {\n        return this.confirmationService;\n    }\n\n    public getConfirmationServiceInstanceKey(action: ActionDescriptor<any>) {\n        return `${action.actionName}_${this.cmpId}`;\n    }\n}\n","<ng-container *ngIf=\"$isVisible | async\">\n    <button\n        *ngIf=\"action.icon && action.title === null; else noIcon\"\n        type=\"button\"\n        pButton\n        pRipple\n        [icon]=\"action.icon\"\n        [loading]=\"($loading | async) ?? false\"\n        [disabled]=\"($isEnabled | async) === false\"\n        [pTooltip]=\"$any($tooltip | async)\"\n        (click)=\"triggerAction($event)\"\n        class=\"mng-action-button mng-action-button-icon p-button-rounded\"\n        [class.p-button-primary]=\"action.level === 1\"\n        [class.p-button-success]=\"action.level === 5\"\n        [class.p-button-danger]=\"action.level === 7\"></button>\n    <ng-template #noIcon>\n        <button\n            type=\"button\"\n            pButton\n            pRipple\n            [icon]=\"$any(action.icon)\"\n            [label]=\"($label | async) ?? ''\"\n            [loading]=\"($loading | async) ?? false\"\n            [disabled]=\"($isEnabled | async) === false\"\n            [pTooltip]=\"$any($tooltip | async)\"\n            (click)=\"triggerAction($event)\"\n            class=\"mng-action-button p-button-text\"\n            [class.p-button-primary]=\"action.level === 1\"\n            [class.p-button-success]=\"action.level === 5\"\n            [class.p-button-danger]=\"action.level === 7\"></button>\n    </ng-template>\n    <p-confirmDialog *ngIf=\"action.hasRunConfirmation\" [key]=\"action.actionName + '_' + cmpId\" [baseZIndex]=\"50\" appendTo=\"body\"></p-confirmDialog>\n</ng-container>\n"]}
82
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/action/action.component.ts","../../../../../src/lib/components/action/action.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, Input, OnInit, Optional} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {ConfirmationService} from 'primeng/api';\nimport {Observable, ReplaySubject, of} from 'rxjs';\nimport {first} from 'rxjs/operators';\n\nimport {DataProvider} from '../../data-providers';\nimport {ActionDescriptor} from '../../descriptors';\nimport {IViewContainer} from '../../models';\nimport {MngActionExecutorService} from '../../services';\nimport {MngViewContainerComponentService} from '../../services/mng-view-container-component.service';\nimport {IdType} from '../../types';\nimport {I18nUtil} from '../../utils';\nimport {ActionData, IActionConfirmationService} from './models';\n\n@Component({\n    selector: 'mng-action',\n    templateUrl: './action.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [ConfirmationService]\n})\nexport class MngActionComponent<T, S> implements OnInit, IActionConfirmationService {\n    // metadata and editor mode input\n    @Input() public action!: ActionDescriptor<T>;\n    @Input() public item?: T;\n    @Input() public itemId?: IdType;\n    @Input() public actionData?: ActionData;\n    @Input() public dataProvider?: DataProvider<T, S>;\n    // eslint-disable-next-line @angular-eslint/no-input-rename\n    @Input('viewContainer') public viewContainerInit?: IViewContainer<T, S>;\n\n    private loadingSubject = new ReplaySubject<boolean>(1);\n    public $loading: Observable<boolean> = this.loadingSubject.asObservable();\n\n    public cmpId: string = Math.random().toString(36).substring(2);\n    public $isVisible!: Observable<boolean>;\n    public $isEnabled!: Observable<boolean>;\n    public $label!: Observable<string | null>;\n    public $tooltip!: Observable<string | null>;\n\n    private viewContainer?: IViewContainer<T, S>;\n\n    constructor(\n        private route: ActivatedRoute,\n        private translate: TranslateService,\n        private actionExecutor: MngActionExecutorService,\n        private confirmationService: ConfirmationService,\n        @Optional() private viewContainerService: MngViewContainerComponentService<T, S> | null\n    ) {\n        this.loadingSubject.next(false);\n    }\n\n    public ngOnInit() {\n        this.viewContainer = this.viewContainerInit ?? this.viewContainerService ?? undefined;\n        const context = this.actionExecutor.prepareActionExecContext(\n            this.action,\n            this.itemId,\n            this.item,\n            this.dataProvider,\n            this.viewContainer ?? undefined,\n            this,\n            this.actionData\n        );\n        this.$isVisible = typeof this.action.isVisibleFunction === 'function' ? this.action.isVisibleFunction(context) : of(true);\n        this.$isEnabled = typeof this.action.isEnabledFunction === 'function' ? this.action.isEnabledFunction(context) : of(true);\n        this.$label = I18nUtil.streamActionTranslation(this.translate, this.action, 'title', this.action?.title ?? undefined, this.item);\n        this.$tooltip = I18nUtil.streamActionTranslation(this.translate, this.action, 'tooltip', this.action?.tooltip ?? undefined, this.item);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    public triggerAction(event: Event) {\n        this.loadingSubject.next(true);\n\n        const actionData = this.actionData ? this.actionData : {};\n        actionData['cmpId'] = this.cmpId;\n\n        this.actionExecutor\n            .triggerAction(this.action, this.itemId, this.item, actionData, this.route, this.viewContainer, this)\n            .pipe(first())\n            .subscribe({\n                next: () => {\n                    this.loadingSubject.next(false);\n                },\n                error: err => {\n                    console.error(`Error occurred while executing action ${this.action.actionName}.`, err);\n                }\n            });\n    }\n\n    public getConfirmationService() {\n        return this.confirmationService;\n    }\n\n    public getConfirmationServiceInstanceKey(action: ActionDescriptor<any>) {\n        return `${action.actionName}_${this.cmpId}`;\n    }\n}\n","<ng-container *ngIf=\"$isVisible | async\">\n    <button\n        *ngIf=\"action.icon && action.title === null; else noIcon\"\n        type=\"button\"\n        pButton\n        pRipple\n        [icon]=\"action.icon\"\n        [loading]=\"($loading | async) ?? false\"\n        [disabled]=\"($isEnabled | async) === false\"\n        [pTooltip]=\"$any($tooltip | async)\"\n        (click)=\"triggerAction($event)\"\n        class=\"mng-action-button mng-action-button-icon p-button-rounded\"\n        [class.mng-button-xs]=\"action.isSizeExtraSmall\"\n        [class.mng-button-sm]=\"action.isSizeSmall\"\n        [class.mng-button-lg]=\"action.isSizeLarge\"\n        [class.mng-button-xl]=\"action.isSizeExtraLarge\"\n        [class.p-button-primary]=\"action.level === 1\"\n        [class.p-button-success]=\"action.level === 5\"\n        [class.p-button-danger]=\"action.level === 7\"></button>\n    <ng-template #noIcon>\n        <button\n            type=\"button\"\n            pButton\n            pRipple\n            [icon]=\"$any(action.icon)\"\n            [label]=\"($label | async) ?? ''\"\n            [loading]=\"($loading | async) ?? false\"\n            [disabled]=\"($isEnabled | async) === false\"\n            [pTooltip]=\"$any($tooltip | async)\"\n            (click)=\"triggerAction($event)\"\n            class=\"mng-action-button p-button-text\"\n            [class.p-button-sm]=\"action.isSizeSmall\"\n            [class.p-button-lg]=\"action.isSizeLarge\"\n            [class.p-button-primary]=\"action.level === 1\"\n            [class.p-button-success]=\"action.level === 5\"\n            [class.p-button-danger]=\"action.level === 7\"></button>\n    </ng-template>\n    <p-confirmDialog *ngIf=\"action.hasRunConfirmation\" [key]=\"action.actionName + '_' + cmpId\" [baseZIndex]=\"50\" appendTo=\"body\"></p-confirmDialog>\n</ng-container>\n"]}
@@ -0,0 +1,182 @@
1
+ import { ChangeDetectionStrategy, Component, ContentChildren, Input, Optional, ViewChild } from '@angular/core';
2
+ import { ReplaySubject, of } from 'rxjs';
3
+ import { catchError, finalize, first, mergeMap } from 'rxjs/operators';
4
+ import { MngTemplateDirective } from '../../../directives';
5
+ import { I18nUtil, ToastUtil } from '../../../utils';
6
+ import { MngFormEditorComponent } from '../../form';
7
+ import { ActionError, ActionRunResult } from '../models';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@ngx-translate/core";
10
+ import * as i2 from "../../../services";
11
+ import * as i3 from "primeng/dynamicdialog";
12
+ import * as i4 from "../../../services/mng-view-container-component.service";
13
+ import * as i5 from "primeng/progressspinner";
14
+ import * as i6 from "../../form/editor/form-editor.component";
15
+ import * as i7 from "@angular/common";
16
+ import * as i8 from "primeng/button";
17
+ import * as i9 from "primeng/ripple";
18
+ export class MngActionEditorComponent {
19
+ constructor(injector, translate, actionExecutor, mngCommonsService, dialogRef, dialogConfig, viewContainerService) {
20
+ this.injector = injector;
21
+ this.translate = translate;
22
+ this.actionExecutor = actionExecutor;
23
+ this.mngCommonsService = mngCommonsService;
24
+ this.dialogRef = dialogRef;
25
+ this.dialogConfig = dialogConfig;
26
+ this.viewContainerService = viewContainerService;
27
+ this.cmpId = Math.random().toString(36).substring(2);
28
+ this.isDialog = true;
29
+ this.isSaveButton = true;
30
+ this.loadingSubject = new ReplaySubject(1);
31
+ this.loading$ = this.loadingSubject.asObservable();
32
+ this.submitLoadingSubject = new ReplaySubject(1);
33
+ this.submitLoading$ = this.submitLoadingSubject.asObservable();
34
+ this.sourceComponent = this;
35
+ this.subscriptions = [];
36
+ }
37
+ ngOnInit() {
38
+ if (this.dialogConfig?.data) {
39
+ if (this.dialogConfig.data.action) {
40
+ this.action = this.dialogConfig.data.action;
41
+ }
42
+ if (this.dialogConfig.data.item) {
43
+ this.item = this.dialogConfig.data.item;
44
+ }
45
+ if (this.dialogConfig.data.itemId) {
46
+ this.itemId = this.dialogConfig.data.itemId;
47
+ }
48
+ if (this.dialogConfig.data.actionData) {
49
+ this.actionData = this.dialogConfig.data.actionData;
50
+ }
51
+ if (this.dialogConfig.data.viewContainer) {
52
+ this.viewContainer = this.dialogConfig.data.viewContainer;
53
+ if (!this.dataProvider && this.viewContainer) {
54
+ const dataProvider = this.viewContainer.getDataProvider();
55
+ if (dataProvider && typeof dataProvider['fetch'] === 'function') {
56
+ this.dataProvider = dataProvider;
57
+ }
58
+ }
59
+ }
60
+ if (this.dialogConfig.data.sourceComponent) {
61
+ this.sourceComponent = this.dialogConfig.data.sourceComponent;
62
+ }
63
+ }
64
+ else {
65
+ this.isDialog = false;
66
+ this.viewContainer = this.viewContainerInit ?? this.viewContainerService ?? undefined;
67
+ }
68
+ this.isSaveButton = typeof this.action.submitFunction === 'function';
69
+ this.setTitle();
70
+ this.loadItemWithDataProvider();
71
+ }
72
+ ngOnDestroy() {
73
+ this.subscriptions.forEach(s => s.unsubscribe());
74
+ }
75
+ onSubmit(event) {
76
+ if (event.success) {
77
+ if (typeof this.action.submitFunction !== 'function') {
78
+ return;
79
+ }
80
+ this.submitLoadingSubject.next(true);
81
+ this.actionExecutor
82
+ .runEditorSave(this.action, this.itemId, event.formItem, this.dataProvider, this.sourceComponent, this.viewContainer, this.actionData)
83
+ .pipe(first())
84
+ .subscribe({
85
+ next: res => {
86
+ this.submitLoadingSubject.next(false);
87
+ this.closeDialog(res);
88
+ },
89
+ error: () => {
90
+ this.submitLoadingSubject.next(false);
91
+ }
92
+ });
93
+ }
94
+ }
95
+ closeDialog(result) {
96
+ this.dialogRef?.close(result ? result : new ActionRunResult(undefined, undefined, new ActionError(null, true)));
97
+ }
98
+ saveItem() {
99
+ this.editorComponent.submit();
100
+ }
101
+ loadItemWithDataProvider() {
102
+ if (typeof this.action.fetchFunction !== 'function') {
103
+ return;
104
+ }
105
+ this.loadingSubject.next(true);
106
+ this.actionExecutor
107
+ .runEditorFetch(this.action, this.itemId, this.dataProvider, this.sourceComponent, this.viewContainer)
108
+ .pipe(first(), catchError(err => {
109
+ if (this.action.hasRunNotificationError) {
110
+ ToastUtil.actionNotificationError(this.translate, this.action, err, 'fetch', this.viewContainer, this.item);
111
+ }
112
+ throw err;
113
+ }), finalize(() => this.loadingSubject.next(false)))
114
+ .subscribe(res => {
115
+ this.item = res.result;
116
+ if (this.action.hasFetchNotificationSuccess) {
117
+ ToastUtil.actionNotificationSuccess(this.translate, this.action, 'fetch', this.action.fetchNotificationSuccessTitle, this.action.fetchNotificationSuccessMessage, this.viewContainer, this.item);
118
+ }
119
+ this.setTitle();
120
+ });
121
+ }
122
+ setTitle() {
123
+ if (this.action.editorTitle === null) {
124
+ this.title = undefined;
125
+ if (this.dialogConfig) {
126
+ requestAnimationFrame(() => {
127
+ this.dialogConfig.header = undefined;
128
+ });
129
+ return;
130
+ }
131
+ }
132
+ const subscription = I18nUtil.streamActionTranslation(this.translate, this.action, 'dialog.title', undefined, this.item)
133
+ .pipe(mergeMap(i18nDialogTitle => i18nDialogTitle === null
134
+ ? I18nUtil.getActionTranslation(this.translate, this.action, 'title', this.action.editorTitle, this.item)
135
+ : of(i18nDialogTitle)))
136
+ .subscribe(t => {
137
+ this.title = t ?? undefined;
138
+ if (this.dialogConfig) {
139
+ requestAnimationFrame(() => {
140
+ this.dialogConfig.header = t ?? undefined;
141
+ this.mngCommonsService.setPageTitle(t ?? undefined);
142
+ });
143
+ }
144
+ });
145
+ this.subscriptions.push(subscription);
146
+ }
147
+ }
148
+ MngActionEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngActionEditorComponent, deps: [{ token: i0.Injector }, { token: i1.TranslateService }, { token: i2.MngActionExecutorService }, { token: i2.MngCommonsService }, { token: i3.DynamicDialogRef, optional: true }, { token: i3.DynamicDialogConfig, optional: true }, { token: i4.MngViewContainerComponentService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
149
+ MngActionEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: MngActionEditorComponent, selector: "mng-action-editor", inputs: { action: "action", itemId: "itemId", item: "item", actionData: "actionData", dataProvider: "dataProvider", viewContainerInit: ["viewContainer", "viewContainerInit"] }, queries: [{ propertyName: "templates", predicate: MngTemplateDirective }], viewQueries: [{ propertyName: "submitButtonElementRef", first: true, predicate: ["submitButton"], descendants: true }, { propertyName: "editorComponent", first: true, predicate: MngFormEditorComponent, descendants: true }], ngImport: i0, template: "<h1 *ngIf=\"!isDialog && title\">{{ title }}</h1>\n<div class=\"h-full flex flex-column\">\n <div class=\"flex-grow-1\">\n <div class=\"text-center\" *ngIf=\"loading$ | async\">\n <p-progressSpinner [style]=\"{width: '3rem', height: '3rem'}\" strokeWidth=\"3\"></p-progressSpinner>\n </div>\n <mng-form-editor *ngIf=\"action.editorDescriptor && (loading$ | async) === false\" [descriptor]=\"action.editorDescriptor\" [item]=\"item\" (formSubmit)=\"onSubmit($event)\">\n </mng-form-editor>\n </div>\n <div class=\"flex flex-row justify-content-between\">\n <div></div>\n <div>\n <button\n type=\"button\"\n pButton\n pRipple\n [label]=\"'general.close' | translate\"\n icon=\"pi pi-times\"\n class=\"p-button-text\"\n (click)=\"closeDialog()\"\n [disabled]=\"submitLoading$ | async\"></button>\n <button\n *ngIf=\"isSaveButton\"\n #submitButton\n type=\"button\"\n pButton\n pRipple\n [label]=\"'general.save' | translate\"\n icon=\"pi pi-check\"\n class=\"p-button-text\"\n (click)=\"saveItem()\"\n [loading]=\"(submitLoading$ | async) ?? false\"\n [disabled]=\"(submitLoading$ | async) ?? false\"></button>\n </div>\n </div>\n</div>\n", components: [{ type: i5.ProgressSpinner, selector: "p-progressSpinner", inputs: ["style", "styleClass", "strokeWidth", "fill", "animationDuration"] }, { type: i6.MngFormEditorComponent, selector: "mng-form-editor", inputs: ["descriptor", "submitLoading", "item", "isSubmitButtonVisible", "isFormDisabled"], outputs: ["formSubmit"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i9.Ripple, selector: "[pRipple]" }], pipes: { "async": i7.AsyncPipe, "translate": i1.TranslatePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
150
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngActionEditorComponent, decorators: [{
151
+ type: Component,
152
+ args: [{ selector: 'mng-action-editor', changeDetection: ChangeDetectionStrategy.OnPush, template: "<h1 *ngIf=\"!isDialog && title\">{{ title }}</h1>\n<div class=\"h-full flex flex-column\">\n <div class=\"flex-grow-1\">\n <div class=\"text-center\" *ngIf=\"loading$ | async\">\n <p-progressSpinner [style]=\"{width: '3rem', height: '3rem'}\" strokeWidth=\"3\"></p-progressSpinner>\n </div>\n <mng-form-editor *ngIf=\"action.editorDescriptor && (loading$ | async) === false\" [descriptor]=\"action.editorDescriptor\" [item]=\"item\" (formSubmit)=\"onSubmit($event)\">\n </mng-form-editor>\n </div>\n <div class=\"flex flex-row justify-content-between\">\n <div></div>\n <div>\n <button\n type=\"button\"\n pButton\n pRipple\n [label]=\"'general.close' | translate\"\n icon=\"pi pi-times\"\n class=\"p-button-text\"\n (click)=\"closeDialog()\"\n [disabled]=\"submitLoading$ | async\"></button>\n <button\n *ngIf=\"isSaveButton\"\n #submitButton\n type=\"button\"\n pButton\n pRipple\n [label]=\"'general.save' | translate\"\n icon=\"pi pi-check\"\n class=\"p-button-text\"\n (click)=\"saveItem()\"\n [loading]=\"(submitLoading$ | async) ?? false\"\n [disabled]=\"(submitLoading$ | async) ?? false\"></button>\n </div>\n </div>\n</div>\n" }]
153
+ }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.TranslateService }, { type: i2.MngActionExecutorService }, { type: i2.MngCommonsService }, { type: i3.DynamicDialogRef, decorators: [{
154
+ type: Optional
155
+ }] }, { type: i3.DynamicDialogConfig, decorators: [{
156
+ type: Optional
157
+ }] }, { type: i4.MngViewContainerComponentService, decorators: [{
158
+ type: Optional
159
+ }] }]; }, propDecorators: { action: [{
160
+ type: Input
161
+ }], itemId: [{
162
+ type: Input
163
+ }], item: [{
164
+ type: Input
165
+ }], actionData: [{
166
+ type: Input
167
+ }], dataProvider: [{
168
+ type: Input
169
+ }], viewContainerInit: [{
170
+ type: Input,
171
+ args: ['viewContainer']
172
+ }], templates: [{
173
+ type: ContentChildren,
174
+ args: [MngTemplateDirective]
175
+ }], submitButtonElementRef: [{
176
+ type: ViewChild,
177
+ args: ['submitButton']
178
+ }], editorComponent: [{
179
+ type: ViewChild,
180
+ args: [MngFormEditorComponent]
181
+ }] } });
182
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-editor.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/action/editor/action-editor.component.ts","../../../../../../src/lib/components/action/editor/action-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, ContentChildren, ElementRef, Injector, Input, OnDestroy, OnInit, Optional, QueryList, ViewChild} from '@angular/core';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {DynamicDialogConfig, DynamicDialogRef} from 'primeng/dynamicdialog';\nimport {Observable, ReplaySubject, Subscription, of} from 'rxjs';\nimport {catchError, finalize, first, mergeMap} from 'rxjs/operators';\n\nimport {IEditorDataProvider} from '../../../data-providers';\nimport {ActionDescriptor, ActionEditorDescriptor} from '../../../descriptors';\nimport {MngTemplateDirective} from '../../../directives';\nimport {IViewContainer} from '../../../models';\nimport {MngActionExecutorService, MngCommonsService} from '../../../services';\nimport {MngViewContainerComponentService} from '../../../services/mng-view-container-component.service';\nimport {IdType} from '../../../types';\nimport {I18nUtil, ToastUtil} from '../../../utils';\nimport {MngFormEditorComponent} from '../../form';\nimport {MngFormEditorSubmitEvent} from '../../form/models';\nimport {ActionData, ActionError, ActionRunResult} from '../models';\n\n@Component({\n    selector: 'mng-action-editor',\n    templateUrl: './action-editor.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngActionEditorComponent<T, S> implements OnInit, OnDestroy {\n    // metadata and editor mode input\n    @Input() public action!: ActionEditorDescriptor<T>;\n\n    // data source inputs\n    @Input() public itemId?: IdType;\n    @Input() public item?: T;\n    @Input() public actionData?: ActionData;\n    @Input() public dataProvider?: IEditorDataProvider<T, S>;\n    // eslint-disable-next-line @angular-eslint/no-input-rename\n    @Input('viewContainer') public viewContainerInit?: IViewContainer<T, S>;\n\n    // content and view queries\n    @ContentChildren(MngTemplateDirective) templates!: QueryList<MngTemplateDirective>;\n    @ViewChild('submitButton') private submitButtonElementRef!: ElementRef;\n    @ViewChild(MngFormEditorComponent) private editorComponent!: MngFormEditorComponent<T>;\n\n    public cmpId: string = Math.random().toString(36).substring(2);\n    public title?: string;\n    public isDialog = true;\n    public isSaveButton = true;\n\n    private loadingSubject = new ReplaySubject<boolean>(1);\n    public loading$: Observable<boolean> = this.loadingSubject.asObservable();\n    private submitLoadingSubject = new ReplaySubject<boolean>(1);\n    public submitLoading$: Observable<boolean> = this.submitLoadingSubject.asObservable();\n    private viewContainer?: IViewContainer<T, S>;\n    private sourceComponent: any = this;\n    private subscriptions: Array<Subscription> = [];\n\n    constructor(\n        private injector: Injector,\n        private translate: TranslateService,\n        private actionExecutor: MngActionExecutorService,\n        private mngCommonsService: MngCommonsService,\n        @Optional() private dialogRef: DynamicDialogRef | null,\n        @Optional() private dialogConfig: DynamicDialogConfig | null,\n        @Optional() private viewContainerService: MngViewContainerComponentService<T, S> | null\n    ) {}\n\n    public ngOnInit() {\n        if (this.dialogConfig?.data) {\n            if (this.dialogConfig.data.action) {\n                this.action = this.dialogConfig.data.action;\n            }\n            if (this.dialogConfig.data.item) {\n                this.item = this.dialogConfig.data.item;\n            }\n            if (this.dialogConfig.data.itemId) {\n                this.itemId = this.dialogConfig.data.itemId;\n            }\n            if (this.dialogConfig.data.actionData) {\n                this.actionData = this.dialogConfig.data.actionData;\n            }\n            if (this.dialogConfig.data.viewContainer) {\n                this.viewContainer = this.dialogConfig.data.viewContainer;\n                if (!this.dataProvider && this.viewContainer) {\n                    const dataProvider = this.viewContainer.getDataProvider();\n                    if (dataProvider && typeof dataProvider['fetch' as keyof object] === 'function') {\n                        this.dataProvider = dataProvider as IEditorDataProvider<T, S>;\n                    }\n                }\n            }\n            if (this.dialogConfig.data.sourceComponent) {\n                this.sourceComponent = this.dialogConfig.data.sourceComponent;\n            }\n        } else {\n            this.isDialog = false;\n            this.viewContainer = this.viewContainerInit ?? this.viewContainerService ?? undefined;\n        }\n\n        this.isSaveButton = typeof this.action.submitFunction === 'function';\n        this.setTitle();\n\n        this.loadItemWithDataProvider();\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    public onSubmit(event: MngFormEditorSubmitEvent<T>) {\n        if (event.success) {\n            if (typeof this.action.submitFunction !== 'function') {\n                return;\n            }\n            this.submitLoadingSubject.next(true);\n            this.actionExecutor\n                .runEditorSave(this.action, this.itemId, event.formItem, this.dataProvider, this.sourceComponent, this.viewContainer, this.actionData)\n                .pipe(first())\n                .subscribe({\n                    next: res => {\n                        this.submitLoadingSubject.next(false);\n                        this.closeDialog(res);\n                    },\n                    error: () => {\n                        this.submitLoadingSubject.next(false);\n                    }\n                });\n        }\n    }\n\n    public closeDialog(result?: ActionRunResult<T, any, any>) {\n        this.dialogRef?.close(result ? result : new ActionRunResult(undefined, undefined, new ActionError(null, true)));\n    }\n\n    public saveItem() {\n        this.editorComponent.submit();\n    }\n\n    private loadItemWithDataProvider() {\n        if (typeof this.action.fetchFunction !== 'function') {\n            return;\n        }\n        this.loadingSubject.next(true);\n        this.actionExecutor\n            .runEditorFetch(this.action, this.itemId, this.dataProvider, this.sourceComponent, this.viewContainer)\n            .pipe(\n                first(),\n                catchError(err => {\n                    if (this.action.hasRunNotificationError) {\n                        ToastUtil.actionNotificationError(this.translate, this.action, err, 'fetch', this.viewContainer, this.item);\n                    }\n                    throw err;\n                }),\n                finalize(() => this.loadingSubject.next(false))\n            )\n            .subscribe(res => {\n                this.item = res.result;\n                if (this.action.hasFetchNotificationSuccess) {\n                    ToastUtil.actionNotificationSuccess(\n                        this.translate,\n                        this.action,\n                        'fetch',\n                        this.action.fetchNotificationSuccessTitle,\n                        this.action.fetchNotificationSuccessMessage,\n                        this.viewContainer,\n                        this.item\n                    );\n                }\n                this.setTitle();\n            });\n    }\n\n    private setTitle() {\n        if (this.action.editorTitle === null) {\n            this.title = undefined;\n            if (this.dialogConfig) {\n                requestAnimationFrame(() => {\n                    this.dialogConfig!.header = undefined;\n                });\n                return;\n            }\n        }\n        const subscription = I18nUtil.streamActionTranslation(this.translate, this.action as ActionDescriptor<T>, 'dialog.title', undefined, this.item)\n            .pipe(\n                mergeMap(i18nDialogTitle =>\n                    i18nDialogTitle === null\n                        ? I18nUtil.getActionTranslation(this.translate, this.action as ActionDescriptor<T>, 'title', this.action.editorTitle, this.item)\n                        : of(i18nDialogTitle)\n                )\n            )\n            .subscribe(t => {\n                this.title = t ?? undefined;\n                if (this.dialogConfig) {\n                    requestAnimationFrame(() => {\n                        this.dialogConfig!.header = t ?? undefined;\n                        this.mngCommonsService.setPageTitle(t ?? undefined);\n                    });\n                }\n            });\n        this.subscriptions.push(subscription);\n    }\n}\n","<h1 *ngIf=\"!isDialog && title\">{{ title }}</h1>\n<div class=\"h-full flex flex-column\">\n    <div class=\"flex-grow-1\">\n        <div class=\"text-center\" *ngIf=\"loading$ | async\">\n            <p-progressSpinner [style]=\"{width: '3rem', height: '3rem'}\" strokeWidth=\"3\"></p-progressSpinner>\n        </div>\n        <mng-form-editor *ngIf=\"action.editorDescriptor && (loading$ | async) === false\" [descriptor]=\"action.editorDescriptor\" [item]=\"item\" (formSubmit)=\"onSubmit($event)\">\n        </mng-form-editor>\n    </div>\n    <div class=\"flex flex-row justify-content-between\">\n        <div></div>\n        <div>\n            <button\n                type=\"button\"\n                pButton\n                pRipple\n                [label]=\"'general.close' | translate\"\n                icon=\"pi pi-times\"\n                class=\"p-button-text\"\n                (click)=\"closeDialog()\"\n                [disabled]=\"submitLoading$ | async\"></button>\n            <button\n                *ngIf=\"isSaveButton\"\n                #submitButton\n                type=\"button\"\n                pButton\n                pRipple\n                [label]=\"'general.save' | translate\"\n                icon=\"pi pi-check\"\n                class=\"p-button-text\"\n                (click)=\"saveItem()\"\n                [loading]=\"(submitLoading$ | async) ?? false\"\n                [disabled]=\"(submitLoading$ | async) ?? false\"></button>\n        </div>\n    </div>\n</div>\n"]}
@@ -1,4 +1,4 @@
1
1
  export * from './action.component';
2
2
  export * from './route/action-route.component';
3
- export * from './dialog/action-dialog.component';
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvYWN0aW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLGtDQUFrQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hY3Rpb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcm91dGUvYWN0aW9uLXJvdXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2RpYWxvZy9hY3Rpb24tZGlhbG9nLmNvbXBvbmVudCc7XG4iXX0=
3
+ export * from './editor/action-editor.component';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvYWN0aW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLGtDQUFrQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hY3Rpb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcm91dGUvYWN0aW9uLXJvdXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2VkaXRvci9hY3Rpb24tZWRpdG9yLmNvbXBvbmVudCc7XG4iXX0=
@@ -1,10 +1,10 @@
1
1
  export class ActionExecContext {
2
- constructor(dataProvider, serviceInstance, data, sourceComponent = null, tableview = null) {
2
+ constructor(dataProvider, serviceInstance, data, sourceComponent = null, viewContainer = null) {
3
3
  this.dataProvider = dataProvider;
4
4
  this.serviceInstance = serviceInstance;
5
5
  this.data = data;
6
6
  this.sourceComponent = sourceComponent;
7
- this.tableview = tableview;
7
+ this.viewContainer = viewContainer;
8
8
  }
9
9
  }
10
10
  export class ActionError {
@@ -55,4 +55,4 @@ export class ActionTriggerResult {
55
55
  return this.activationResult ? this.activationResult.dialogRef : null;
56
56
  }
57
57
  }
58
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLWV4ZWN1dGlvbi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9hY3Rpb24vbW9kZWxzL2FjdGlvbi1leGVjdXRpb24ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT0EsTUFBTSxPQUFPLGlCQUFpQjtJQUMxQixZQUNvQixZQUFpQixFQUNqQixlQUFtQixFQUNuQixJQUlmLEVBQ2Usa0JBQXVCLElBQUksRUFDM0IsWUFBb0QsSUFBSTtRQVJ4RCxpQkFBWSxHQUFaLFlBQVksQ0FBSztRQUNqQixvQkFBZSxHQUFmLGVBQWUsQ0FBSTtRQUNuQixTQUFJLEdBQUosSUFBSSxDQUluQjtRQUNlLG9CQUFlLEdBQWYsZUFBZSxDQUFZO1FBQzNCLGNBQVMsR0FBVCxTQUFTLENBQStDO0lBQ3pFLENBQUM7Q0FDUDtBQUVELE1BQU0sT0FBTyxXQUFXO0lBQ3BCLFlBQ29CLEtBQVUsRUFBRSxnQkFBZ0I7SUFDNUIsWUFBcUIsS0FBSyxDQUFDLFVBQVU7O1FBRHJDLFVBQUssR0FBTCxLQUFLLENBQUs7UUFDVixjQUFTLEdBQVQsU0FBUyxDQUFpQjtJQUMzQyxDQUFDO0NBQ1A7QUFFRCxNQUFNLE9BQU8sZUFBZTtJQUN4QixZQUE0QixPQUFxQyxFQUFrQixNQUFVLEVBQWtCLEtBQW1CO1FBQXRHLFlBQU8sR0FBUCxPQUFPLENBQThCO1FBQWtCLFdBQU0sR0FBTixNQUFNLENBQUk7UUFBa0IsVUFBSyxHQUFMLEtBQUssQ0FBYztJQUFHLENBQUM7Q0FDekk7QUFFRCxNQUFNLE9BQU8sc0JBQXNCO0lBQy9CLFlBQTRCLFNBQXFDLEVBQWtCLFNBQTRCO1FBQW5GLGNBQVMsR0FBVCxTQUFTLENBQTRCO1FBQWtCLGNBQVMsR0FBVCxTQUFTLENBQW1CO0lBQUcsQ0FBQztJQUVuSCxJQUFXLFVBQVU7UUFDakIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBQzFELENBQUM7SUFFRCxJQUFXLE1BQU07UUFDYixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDekQsQ0FBQztJQUVELElBQVcsS0FBSztRQUNaLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUN4RCxDQUFDO0NBQ0o7QUFFRCxNQUFNLE9BQU8sbUJBQW1CO0lBQzVCLFlBQTRCLGdCQUFtRCxFQUFrQixnQkFBc0M7UUFBM0cscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFtQztRQUFrQixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQXNCO0lBQUcsQ0FBQztJQUUzSSxJQUFXLFVBQVU7UUFDakIsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUMxRSxDQUFDO0lBRUQsSUFBVyxNQUFNO1FBQ2IsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUN2RSxDQUFDO0lBRUQsSUFBVyxLQUFLO1FBQ1osT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUN0RSxDQUFDO0lBRUQsSUFBVyxTQUFTO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDMUUsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEeW5hbWljRGlhbG9nUmVmfSBmcm9tICdwcmltZW5nL2R5bmFtaWNkaWFsb2cnO1xuaW1wb3J0IHtPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHtJRGF0YVByb3ZpZGVyfSBmcm9tICcuLi8uLi8uLi9kYXRhLXByb3ZpZGVycyc7XG5pbXBvcnQge0lkVHlwZX0gZnJvbSAnLi4vLi4vLi4vdHlwZXMnO1xuaW1wb3J0IHtUYWJsZXZpZXdDb21wb25lbnRTZXJ2aWNlfSBmcm9tICcuLi8uLi90YWJsZXZpZXcvc2VydmljZXMnO1xuXG5leHBvcnQgY2xhc3MgQWN0aW9uRXhlY0NvbnRleHQ8VCwgUywgRFAgZXh0ZW5kcyBJRGF0YVByb3ZpZGVyPFQsIFM+PiB7XG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHB1YmxpYyByZWFkb25seSBkYXRhUHJvdmlkZXI/OiBEUCxcbiAgICAgICAgcHVibGljIHJlYWRvbmx5IHNlcnZpY2VJbnN0YW5jZT86IFMsXG4gICAgICAgIHB1YmxpYyByZWFkb25seSBkYXRhPzoge1xuICAgICAgICAgICAgaXRlbT86IFQ7XG4gICAgICAgICAgICBpdGVtSWQ/OiBJZFR5cGU7XG4gICAgICAgICAgICBhY3Rpb25EYXRhPzogQWN0aW9uRGF0YTtcbiAgICAgICAgfSxcbiAgICAgICAgcHVibGljIHJlYWRvbmx5IHNvdXJjZUNvbXBvbmVudDogYW55ID0gbnVsbCxcbiAgICAgICAgcHVibGljIHJlYWRvbmx5IHRhYmxldmlldzogVGFibGV2aWV3Q29tcG9uZW50U2VydmljZTxULCBTPiB8IG51bGwgPSBudWxsXG4gICAgKSB7fVxufVxuXG5leHBvcnQgY2xhc3MgQWN0aW9uRXJyb3Ige1xuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwdWJsaWMgcmVhZG9ubHkgZXJyb3I6IGFueSwgLy8gZXJyb3IgZGV0YWlsc1xuICAgICAgICBwdWJsaWMgcmVhZG9ubHkgZGlzbWlzc2VkOiBib29sZWFuID0gZmFsc2UgLy8gYnkgdXNlclxuICAgICkge31cbn1cblxuZXhwb3J0IGNsYXNzIEFjdGlvblJ1blJlc3VsdDxULCBTLCBEUCBleHRlbmRzIElEYXRhUHJvdmlkZXI8VCwgUz4+IHtcbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgcmVhZG9ubHkgY29udGV4dD86IEFjdGlvbkV4ZWNDb250ZXh0PFQsIFMsIERQPiwgcHVibGljIHJlYWRvbmx5IHJlc3VsdD86IFQsIHB1YmxpYyByZWFkb25seSBlcnJvcj86IEFjdGlvbkVycm9yKSB7fVxufVxuXG5leHBvcnQgY2xhc3MgQWN0aW9uQWN0aXZhdGlvblJlc3VsdDxULCBTLCBEUCBleHRlbmRzIElEYXRhUHJvdmlkZXI8VCwgUz4+IHtcbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgcmVhZG9ubHkgcnVuUmVzdWx0PzogQWN0aW9uUnVuUmVzdWx0PFQsIFMsIERQPiwgcHVibGljIHJlYWRvbmx5IGRpYWxvZ1JlZj86IER5bmFtaWNEaWFsb2dSZWYpIHt9XG5cbiAgICBwdWJsaWMgZ2V0IHJ1bkNvbnRleHQoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLnJ1blJlc3VsdCA/IHRoaXMucnVuUmVzdWx0LmNvbnRleHQgOiBudWxsO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgcmVzdWx0KCkge1xuICAgICAgICByZXR1cm4gdGhpcy5ydW5SZXN1bHQgPyB0aGlzLnJ1blJlc3VsdC5yZXN1bHQgOiBudWxsO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgZXJyb3IoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLnJ1blJlc3VsdCA/IHRoaXMucnVuUmVzdWx0LmVycm9yIDogbnVsbDtcbiAgICB9XG59XG5cbmV4cG9ydCBjbGFzcyBBY3Rpb25UcmlnZ2VyUmVzdWx0PFQsIFMsIERQIGV4dGVuZHMgSURhdGFQcm92aWRlcjxULCBTPj4ge1xuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyByZWFkb25seSBhY3RpdmF0aW9uUmVzdWx0PzogQWN0aW9uQWN0aXZhdGlvblJlc3VsdDxULCBTLCBEUD4sIHB1YmxpYyByZWFkb25seSByb3V0ZXJOYXZpZ2F0aW9uPzogT2JzZXJ2YWJsZTxib29sZWFuPikge31cblxuICAgIHB1YmxpYyBnZXQgcnVuQ29udGV4dCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuYWN0aXZhdGlvblJlc3VsdCA/IHRoaXMuYWN0aXZhdGlvblJlc3VsdC5ydW5SZXN1bHQgOiBudWxsO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgcmVzdWx0KCkge1xuICAgICAgICByZXR1cm4gdGhpcy5hY3RpdmF0aW9uUmVzdWx0ID8gdGhpcy5hY3RpdmF0aW9uUmVzdWx0LnJlc3VsdCA6IG51bGw7XG4gICAgfVxuXG4gICAgcHVibGljIGdldCBlcnJvcigpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuYWN0aXZhdGlvblJlc3VsdCA/IHRoaXMuYWN0aXZhdGlvblJlc3VsdC5lcnJvciA6IG51bGw7XG4gICAgfVxuXG4gICAgcHVibGljIGdldCBkaWFsb2dSZWYoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmFjdGl2YXRpb25SZXN1bHQgPyB0aGlzLmFjdGl2YXRpb25SZXN1bHQuZGlhbG9nUmVmIDogbnVsbDtcbiAgICB9XG59XG5cbmV4cG9ydCB0eXBlIEFjdGlvbkRhdGEgPSB7XG4gICAgW2tleTogc3RyaW5nXTogYW55O1xufTtcbiJdfQ==
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLWV4ZWN1dGlvbi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9hY3Rpb24vbW9kZWxzL2FjdGlvbi1leGVjdXRpb24ubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT0EsTUFBTSxPQUFPLGlCQUFpQjtJQUMxQixZQUNvQixZQUFpQixFQUNqQixlQUFtQixFQUNuQixJQUlmLEVBQ2Usa0JBQXVCLElBQUksRUFDM0IsZ0JBQTZDLElBQUk7UUFSakQsaUJBQVksR0FBWixZQUFZLENBQUs7UUFDakIsb0JBQWUsR0FBZixlQUFlLENBQUk7UUFDbkIsU0FBSSxHQUFKLElBQUksQ0FJbkI7UUFDZSxvQkFBZSxHQUFmLGVBQWUsQ0FBWTtRQUMzQixrQkFBYSxHQUFiLGFBQWEsQ0FBb0M7SUFDbEUsQ0FBQztDQUNQO0FBRUQsTUFBTSxPQUFPLFdBQVc7SUFDcEIsWUFDb0IsS0FBVSxFQUFFLGdCQUFnQjtJQUM1QixZQUFxQixLQUFLLENBQUMsVUFBVTs7UUFEckMsVUFBSyxHQUFMLEtBQUssQ0FBSztRQUNWLGNBQVMsR0FBVCxTQUFTLENBQWlCO0lBQzNDLENBQUM7Q0FDUDtBQUVELE1BQU0sT0FBTyxlQUFlO0lBQ3hCLFlBQTRCLE9BQXFDLEVBQWtCLE1BQVUsRUFBa0IsS0FBbUI7UUFBdEcsWUFBTyxHQUFQLE9BQU8sQ0FBOEI7UUFBa0IsV0FBTSxHQUFOLE1BQU0sQ0FBSTtRQUFrQixVQUFLLEdBQUwsS0FBSyxDQUFjO0lBQUcsQ0FBQztDQUN6STtBQUVELE1BQU0sT0FBTyxzQkFBc0I7SUFDL0IsWUFBNEIsU0FBcUMsRUFBa0IsU0FBNEI7UUFBbkYsY0FBUyxHQUFULFNBQVMsQ0FBNEI7UUFBa0IsY0FBUyxHQUFULFNBQVMsQ0FBbUI7SUFBRyxDQUFDO0lBRW5ILElBQVcsVUFBVTtRQUNqQixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDMUQsQ0FBQztJQUVELElBQVcsTUFBTTtRQUNiLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUN6RCxDQUFDO0lBRUQsSUFBVyxLQUFLO1FBQ1osT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBQ3hELENBQUM7Q0FDSjtBQUVELE1BQU0sT0FBTyxtQkFBbUI7SUFDNUIsWUFBNEIsZ0JBQW1ELEVBQWtCLGdCQUFzQztRQUEzRyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQW1DO1FBQWtCLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBc0I7SUFBRyxDQUFDO0lBRTNJLElBQVcsVUFBVTtRQUNqQixPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBQzFFLENBQUM7SUFFRCxJQUFXLE1BQU07UUFDYixPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBQ3ZFLENBQUM7SUFFRCxJQUFXLEtBQUs7UUFDWixPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBQ3RFLENBQUM7SUFFRCxJQUFXLFNBQVM7UUFDaEIsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUMxRSxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0R5bmFtaWNEaWFsb2dSZWZ9IGZyb20gJ3ByaW1lbmcvZHluYW1pY2RpYWxvZyc7XG5pbXBvcnQge09ic2VydmFibGV9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQge0lEYXRhUHJvdmlkZXJ9IGZyb20gJy4uLy4uLy4uL2RhdGEtcHJvdmlkZXJzJztcbmltcG9ydCB7SVZpZXdDb250YWluZXJ9IGZyb20gJy4uLy4uLy4uL21vZGVscyc7XG5pbXBvcnQge0lkVHlwZX0gZnJvbSAnLi4vLi4vLi4vdHlwZXMnO1xuXG5leHBvcnQgY2xhc3MgQWN0aW9uRXhlY0NvbnRleHQ8VCwgUywgRFAgZXh0ZW5kcyBJRGF0YVByb3ZpZGVyPFQsIFM+PiB7XG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHB1YmxpYyByZWFkb25seSBkYXRhUHJvdmlkZXI/OiBEUCxcbiAgICAgICAgcHVibGljIHJlYWRvbmx5IHNlcnZpY2VJbnN0YW5jZT86IFMsXG4gICAgICAgIHB1YmxpYyByZWFkb25seSBkYXRhPzoge1xuICAgICAgICAgICAgaXRlbT86IFQ7XG4gICAgICAgICAgICBpdGVtSWQ/OiBJZFR5cGU7XG4gICAgICAgICAgICBhY3Rpb25EYXRhPzogQWN0aW9uRGF0YTtcbiAgICAgICAgfSxcbiAgICAgICAgcHVibGljIHJlYWRvbmx5IHNvdXJjZUNvbXBvbmVudDogYW55ID0gbnVsbCxcbiAgICAgICAgcHVibGljIHJlYWRvbmx5IHZpZXdDb250YWluZXI6IElWaWV3Q29udGFpbmVyPFQsIFM+IHwgbnVsbCA9IG51bGxcbiAgICApIHt9XG59XG5cbmV4cG9ydCBjbGFzcyBBY3Rpb25FcnJvciB7XG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHB1YmxpYyByZWFkb25seSBlcnJvcjogYW55LCAvLyBlcnJvciBkZXRhaWxzXG4gICAgICAgIHB1YmxpYyByZWFkb25seSBkaXNtaXNzZWQ6IGJvb2xlYW4gPSBmYWxzZSAvLyBieSB1c2VyXG4gICAgKSB7fVxufVxuXG5leHBvcnQgY2xhc3MgQWN0aW9uUnVuUmVzdWx0PFQsIFMsIERQIGV4dGVuZHMgSURhdGFQcm92aWRlcjxULCBTPj4ge1xuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyByZWFkb25seSBjb250ZXh0PzogQWN0aW9uRXhlY0NvbnRleHQ8VCwgUywgRFA+LCBwdWJsaWMgcmVhZG9ubHkgcmVzdWx0PzogVCwgcHVibGljIHJlYWRvbmx5IGVycm9yPzogQWN0aW9uRXJyb3IpIHt9XG59XG5cbmV4cG9ydCBjbGFzcyBBY3Rpb25BY3RpdmF0aW9uUmVzdWx0PFQsIFMsIERQIGV4dGVuZHMgSURhdGFQcm92aWRlcjxULCBTPj4ge1xuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyByZWFkb25seSBydW5SZXN1bHQ/OiBBY3Rpb25SdW5SZXN1bHQ8VCwgUywgRFA+LCBwdWJsaWMgcmVhZG9ubHkgZGlhbG9nUmVmPzogRHluYW1pY0RpYWxvZ1JlZikge31cblxuICAgIHB1YmxpYyBnZXQgcnVuQ29udGV4dCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMucnVuUmVzdWx0ID8gdGhpcy5ydW5SZXN1bHQuY29udGV4dCA6IG51bGw7XG4gICAgfVxuXG4gICAgcHVibGljIGdldCByZXN1bHQoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLnJ1blJlc3VsdCA/IHRoaXMucnVuUmVzdWx0LnJlc3VsdCA6IG51bGw7XG4gICAgfVxuXG4gICAgcHVibGljIGdldCBlcnJvcigpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMucnVuUmVzdWx0ID8gdGhpcy5ydW5SZXN1bHQuZXJyb3IgOiBudWxsO1xuICAgIH1cbn1cblxuZXhwb3J0IGNsYXNzIEFjdGlvblRyaWdnZXJSZXN1bHQ8VCwgUywgRFAgZXh0ZW5kcyBJRGF0YVByb3ZpZGVyPFQsIFM+PiB7XG4gICAgY29uc3RydWN0b3IocHVibGljIHJlYWRvbmx5IGFjdGl2YXRpb25SZXN1bHQ/OiBBY3Rpb25BY3RpdmF0aW9uUmVzdWx0PFQsIFMsIERQPiwgcHVibGljIHJlYWRvbmx5IHJvdXRlck5hdmlnYXRpb24/OiBPYnNlcnZhYmxlPGJvb2xlYW4+KSB7fVxuXG4gICAgcHVibGljIGdldCBydW5Db250ZXh0KCkge1xuICAgICAgICByZXR1cm4gdGhpcy5hY3RpdmF0aW9uUmVzdWx0ID8gdGhpcy5hY3RpdmF0aW9uUmVzdWx0LnJ1blJlc3VsdCA6IG51bGw7XG4gICAgfVxuXG4gICAgcHVibGljIGdldCByZXN1bHQoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmFjdGl2YXRpb25SZXN1bHQgPyB0aGlzLmFjdGl2YXRpb25SZXN1bHQucmVzdWx0IDogbnVsbDtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0IGVycm9yKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5hY3RpdmF0aW9uUmVzdWx0ID8gdGhpcy5hY3RpdmF0aW9uUmVzdWx0LmVycm9yIDogbnVsbDtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0IGRpYWxvZ1JlZigpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuYWN0aXZhdGlvblJlc3VsdCA/IHRoaXMuYWN0aXZhdGlvblJlc3VsdC5kaWFsb2dSZWYgOiBudWxsO1xuICAgIH1cbn1cblxuZXhwb3J0IHR5cGUgQWN0aW9uRGF0YSA9IHtcbiAgICBba2V5OiBzdHJpbmddOiBhbnk7XG59O1xuIl19