@mediusinc/mng-commons 0.4.0 → 0.4.3

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 (30) hide show
  1. package/assets/i18n/en.json +25 -20
  2. package/assets/i18n/sl.json +23 -18
  3. package/esm2020/lib/components/action/action.component.mjs +4 -4
  4. package/esm2020/lib/components/action/editor/action-editor.component.mjs +6 -10
  5. package/esm2020/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +3 -3
  6. package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +1 -1
  7. package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +1 -1
  8. package/esm2020/lib/components/tableview/table/table.component.mjs +7 -3
  9. package/esm2020/lib/components/tableview/tableview.component.mjs +4 -4
  10. package/esm2020/lib/descriptors/action.descriptor.mjs +29 -10
  11. package/esm2020/lib/descriptors/editor.descriptor.mjs +4 -4
  12. package/esm2020/lib/descriptors/field.descriptor.mjs +3 -3
  13. package/esm2020/lib/pipes/i18n-property.pipe.mjs +3 -3
  14. package/esm2020/lib/pipes/link-formatter.pipe.mjs +1 -1
  15. package/esm2020/lib/services/action-executor.service.mjs +13 -14
  16. package/esm2020/lib/services/view-container.component.service.mjs +2 -2
  17. package/esm2020/lib/utils/i18n.util.mjs +213 -144
  18. package/esm2020/lib/utils/notification.util.mjs +16 -17
  19. package/fesm2015/mediusinc-mng-commons.mjs +367 -280
  20. package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
  21. package/fesm2020/mediusinc-mng-commons.mjs +361 -278
  22. package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
  23. package/lib/components/tableview/table/table.component.d.ts +4 -1
  24. package/lib/descriptors/action.descriptor.d.ts +13 -6
  25. package/lib/pipes/link-formatter.pipe.d.ts +1 -1
  26. package/lib/services/action-executor.service.d.ts +4 -2
  27. package/lib/services/view-container.component.service.d.ts +1 -1
  28. package/lib/utils/i18n.util.d.ts +52 -21
  29. package/lib/utils/notification.util.d.ts +4 -4
  30. package/package.json +1 -1
@@ -19,7 +19,7 @@
19
19
  "success": "Success",
20
20
  "successMessage": "Operation successful.",
21
21
  "error": "Error",
22
- "errorMessage": "Unknown error {{errorMessage}}",
22
+ "errorMessage": "Error occurred {{errorMessage}}",
23
23
  "general": "General",
24
24
  "searchItem": "{{item}} - search",
25
25
  "search": "Search",
@@ -56,28 +56,21 @@
56
56
  "mngAutocomplete": {
57
57
  "noMatches": "No mathces"
58
58
  },
59
- "mngAction": {
60
- "functions": {
61
- "run": {
62
- "title": "Action"
63
- },
64
- "fetch": {
65
- "title": "Fetch"
66
- },
67
- "submit": {
68
- "title": "Submit"
69
- }
70
- }
71
- },
72
59
  "details": {
60
+ "title": "Details",
73
61
  "editor": {
74
- "title": "{{modelName}}: {{itemTitle}}"
62
+ "title": "{{itemTitle}}"
63
+ },
64
+ "error": {
65
+ "fetch": {
66
+ "message": "Item fetch failed: {{errorMessage}}"
67
+ }
75
68
  }
76
69
  },
77
70
  "add": {
78
71
  "title": "Add",
79
72
  "editor": {
80
- "title": "Add: {{modelName}}"
73
+ "title": "Add: {{typeName}}"
81
74
  },
82
75
  "success": {
83
76
  "title": "Added",
@@ -85,23 +78,35 @@
85
78
  },
86
79
  "error": {
87
80
  "title": "Error",
88
- "message": "Failed to execute action ''{{functionTitle}} for item '{{itemTitle}}'{{errorMessage}}"
81
+ "fetch": {
82
+ "message": "Item fetch failed: {{errorMessage}}"
83
+ },
84
+ "submit": {
85
+ "message": "Item submit failed: {{errorMessage}}"
86
+ }
89
87
  }
90
88
  },
91
89
  "edit": {
90
+ "title": "Edit",
92
91
  "editor": {
93
92
  "title": "Edit: {{itemTitle}}"
94
93
  },
95
94
  "success": {
96
95
  "title": "Saved",
97
- "message": "Changes for item '{{itemTitle}}' saved successfully."
96
+ "message": "Item '{{itemTitle}}' changes saved successfully."
98
97
  },
99
98
  "error": {
100
99
  "title": "Error",
101
- "message": "Failed to execute action ''{{functionTitle}} for item '{{itemTitle}}'{{errorMessage}}"
100
+ "fetch": {
101
+ "message": "Item fetch failed: {{errorMessage}}"
102
+ },
103
+ "submit": {
104
+ "message": "Item '{{itemTitle}}' submit failed: {{errorMessage}}"
105
+ }
102
106
  }
103
107
  },
104
108
  "delete": {
109
+ "title": "Delete",
105
110
  "confirm": {
106
111
  "message": "Are you sure you want to delete item '{{itemTitle}}'?"
107
112
  },
@@ -111,7 +116,7 @@
111
116
  },
112
117
  "error": {
113
118
  "title": "Error",
114
- "message": "Failed to delete item '{{itemTitle}}'{{errorMessage}}"
119
+ "message": "Item '{{itemTitle}}' delete failed: {{errorMessage}}"
115
120
  }
116
121
  },
117
122
  "mngPrime": {
@@ -19,7 +19,7 @@
19
19
  "success": "Uspešno",
20
20
  "successMessage": "Operacija uspešna.",
21
21
  "error": "Napaka",
22
- "errorMessage": "Neznana napaka {{errorMessage}}",
22
+ "errorMessage": "Prišlo je do napake: {{errorMessage}}",
23
23
  "general": "Splošno",
24
24
  "searchItem": "{{item}} - išči",
25
25
  "search": "Išči",
@@ -56,28 +56,21 @@
56
56
  "mngAutocomplete": {
57
57
  "noMatches": "Ni zadetkov"
58
58
  },
59
- "mngAction": {
60
- "functions": {
61
- "run": {
62
- "title": "Akcija"
63
- },
64
- "fetch": {
65
- "title": "Pridobivanje"
66
- },
67
- "submit": {
68
- "title": "Shrani"
69
- }
70
- }
71
- },
72
59
  "details": {
60
+ "title": "Podrobnosti",
73
61
  "editor": {
74
62
  "title": "{{itemTitle}}"
63
+ },
64
+ "error": {
65
+ "fetch": {
66
+ "message": "Pridobivanje vnosa ni uspelo: {{errorMessage}}"
67
+ }
75
68
  }
76
69
  },
77
70
  "add": {
78
71
  "title": "Dodaj",
79
72
  "editor": {
80
- "title": "Dodaj: {{modelName}}"
73
+ "title": "Dodaj: {{typeName}}"
81
74
  },
82
75
  "success": {
83
76
  "title": "Dodano",
@@ -85,10 +78,16 @@
85
78
  },
86
79
  "error": {
87
80
  "title": "Napaka",
88
- "message": "Napaka pri izvedbi akcije '{{functionTitle}}' za vnos '{{itemTitle}}'{{errorMessage}}"
81
+ "fetch": {
82
+ "message": "Pridobivanje vnosa ni uspelo: {{errorMessage}}"
83
+ },
84
+ "submit": {
85
+ "message": "Napaka pri shranjevanju vnosa: {{errorMessage}}"
86
+ }
89
87
  }
90
88
  },
91
89
  "edit": {
90
+ "title": "Uredi",
92
91
  "editor": {
93
92
  "title": "Uredi: {{itemTitle}}"
94
93
  },
@@ -98,10 +97,16 @@
98
97
  },
99
98
  "error": {
100
99
  "title": "Napaka",
101
- "message": "Napaka pri izvedbi akcije '{{functionTitle}}' za vnos '{{itemTitle}}'{{errorMessage}}"
100
+ "fetch": {
101
+ "message": "Pridobivanje vnosa ni uspelo: {{errorMessage}}"
102
+ },
103
+ "submit": {
104
+ "message": "Shranjevanje vnosa '{{itemTitle}}' ni uspelo: {{errorMessage}}"
105
+ }
102
106
  }
103
107
  },
104
108
  "delete": {
109
+ "title": "Izbriši",
105
110
  "confirm": {
106
111
  "message": "Ali ste prepričani, da želite izbrisati vnos '{{itemTitle}}'?"
107
112
  },
@@ -111,7 +116,7 @@
111
116
  },
112
117
  "error": {
113
118
  "title": "Napaka",
114
- "message": "Napaka pri brisanju vnosa '{{itemTitle}}'{{errorMessage}}"
119
+ "message": "Napaka pri brisanju vnosa '{{itemTitle}}': {{errorMessage}}"
115
120
  }
116
121
  },
117
122
  "mngPrime": {
@@ -3,7 +3,7 @@ import { ConfirmationService } from 'primeng/api';
3
3
  import { ReplaySubject, of } from 'rxjs';
4
4
  import { first } from 'rxjs/operators';
5
5
  import { ActionLevelEnum, ActionLinkDescriptor } from '../../descriptors';
6
- import { I18nUtil } from '../../utils';
6
+ import { I18nUtils } from '../../utils';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "@angular/router";
9
9
  import * as i2 from "@ngx-translate/core";
@@ -46,8 +46,8 @@ export class MngActionComponent {
46
46
  const context = this.actionExecutor.prepareActionExecContext(this.action, this.itemId, this.item, this.dataProvider, this.viewContainer ?? undefined, this, this.actionData);
47
47
  this.$isVisible = typeof this.action.isVisibleFunction === 'function' ? this.action.isVisibleFunction(context) : of(true);
48
48
  this.$isEnabled = typeof this.action.isEnabledFunction === 'function' ? this.action.isEnabledFunction(context) : of(true);
49
- this.$label = this.hasNoTitle ? of(null) : I18nUtil.streamActionTranslation(this.translate, this.action, 'title', this.action?.title ?? undefined, this.item);
50
- this.$tooltip = I18nUtil.streamActionTranslation(this.translate, this.action, 'tooltip', this.action?.tooltip ?? undefined, this.item);
49
+ this.$label = this.hasNoTitle ? of(null) : I18nUtils.Action.getAsync(this.translate, this.action, 'title', this.action?.title ?? undefined, this.item);
50
+ this.$tooltip = I18nUtils.Action.getAsync(this.translate, this.action, 'tooltip', this.action?.tooltip ?? undefined, this.item);
51
51
  if (this.action instanceof ActionLinkDescriptor) {
52
52
  this.actionLink = this.action;
53
53
  }
@@ -114,4 +114,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
114
114
  type: Output,
115
115
  args: ['trigger']
116
116
  }] } });
117
- //# 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":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAU,QAAQ,EAAE,MAAM,EAAC,MAAM,eAAe,CAAC;AAI7H,OAAO,EAAC,mBAAmB,EAAC,MAAM,aAAa,CAAC;AAChD,OAAO,EAAa,aAAa,EAAE,EAAE,EAAC,MAAM,MAAM,CAAC;AACnD,OAAO,EAAC,KAAK,EAAC,MAAM,gBAAgB,CAAC;AAGrC,OAAO,EAAmB,eAAe,EAAE,oBAAoB,EAAC,MAAM,mBAAmB,CAAC;AAI1F,OAAO,EAAC,QAAQ,EAAC,MAAM,aAAa,CAAC;;;;;;;;;;;;AAUrC,MAAM,OAAO,kBAAkB;IAsC3B,YACY,KAAqB,EACrB,SAA2B,EAC3B,cAAwC,EACxC,mBAAwC,EAC5B,oBAAmE;QAJ/E,UAAK,GAAL,KAAK,CAAgB;QACrB,cAAS,GAAT,SAAS,CAAkB;QAC3B,mBAAc,GAAd,cAAc,CAA0B;QACxC,wBAAmB,GAAnB,mBAAmB,CAAqB;QAC5B,yBAAoB,GAApB,oBAAoB,CAA+C;QA1C3E,iBAAY,GAAG,eAAe,CAAC,OAAO,CAAC;QACvC,iBAAY,GAAG,eAAe,CAAC,OAAO,CAAC;QACvC,mBAAc,GAAG,eAAe,CAAC,SAAS,CAAC;QAC3C,cAAS,GAAG,eAAe,CAAC,IAAI,CAAC;QACjC,cAAS,GAAG,eAAe,CAAC,IAAI,CAAC;QACjC,iBAAY,GAAG,eAAe,CAAC,OAAO,CAAC;QACvC,iBAAY,GAAG,eAAe,CAAC,OAAO,CAAC;QACvC,gBAAW,GAAG,eAAe,CAAC,MAAM,CAAC;QAE/B,cAAS,GAAG,mBAAmB,CAAC;QAQ5B,kBAAa,GAAwB,EAAE,CAAC,KAAK,CAAC,CAAC;QAChD,iBAAY,GAAwB,EAAE,CAAC,KAAK,CAAC,CAAC;QAG7C,wBAAmB,GAAG,IAAI,YAAY,EAAkD,CAAC;QAE3G,mBAAc,GAAG,IAAI,aAAa,CAAU,CAAC,CAAC,CAAC;QAChD,aAAQ,GAAwB,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;QAEnE,UAAK,GAAW,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QASxD,eAAU,GAAG,KAAK,CAAC;QAStB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAEM,QAAQ;QACX,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,oBAAoB,IAAI,SAAS,CAAC;QAEtF,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,KAAK,IAAI,CAAC;QAC7C,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,wBAAwB,CACxD,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,aAAa,IAAI,SAAS,EAC/B,IAAI,EACJ,IAAI,CAAC,UAAU,CAClB,CAAC;QACF,IAAI,CAAC,UAAU,GAAG,OAAO,IAAI,CAAC,MAAM,CAAC,iBAAiB,KAAK,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QAC1H,IAAI,CAAC,UAAU,GAAG,OAAO,IAAI,CAAC,MAAM,CAAC,iBAAiB,KAAK,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QAC1H,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,uBAAuB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9J,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,uBAAuB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,EAAE,SAAS,EAAE,IAAI,CAAC,MAAM,EAAE,OAAO,IAAI,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;QAEvI,IAAI,IAAI,CAAC,MAAM,YAAY,oBAAoB,EAAE;YAC7C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC;SACjC;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE;YACvB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;SAC1C;IACL,CAAC;IAED,6DAA6D;IACtD,aAAa,CAAC,KAAY;QAC7B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE/B,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC;QAC1D,UAAU,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;QAEjC,IAAI,CAAC,cAAc;aACd,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC;aACpG,IAAI,CAAC,KAAK,EAAE,CAAC;aACb,SAAS,CAAC;YACP,IAAI,EAAE,GAAG,CAAC,EAAE;gBACR,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBACnC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACpC,CAAC;YACD,KAAK,EAAE,GAAG,CAAC,EAAE;gBACT,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAChC,OAAO,CAAC,IAAI,CAAC,yCAAyC,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,EAAE,GAAG,CAAC,CAAC;YAC1F,CAAC;SACJ,CAAC,CAAC;IACX,CAAC;IAEM,sBAAsB;QACzB,OAAO,IAAI,CAAC,mBAAmB,CAAC;IACpC,CAAC;IAEM,iCAAiC,CAAC,MAA6B;QAClE,OAAO,GAAG,MAAM,CAAC,UAAU,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;IAChD,CAAC;;+GAvGQ,kBAAkB;mGAAlB,kBAAkB,iZAFhB,CAAC,mBAAmB,CAAC,0BCrBpC,ivKA+FA;2FDxEa,kBAAkB;kBAP9B,SAAS;+BACI,YAAY,mBAGL,uBAAuB,CAAC,MAAM,aACpC,CAAC,mBAAmB,CAAC;;0BA6C3B,QAAQ;4CAjCS,SAAS;sBAA9B,WAAW;uBAAC,OAAO;gBAGJ,MAAM;sBAArB,KAAK;gBACU,IAAI;sBAAnB,KAAK;gBACU,MAAM;sBAArB,KAAK;gBACU,UAAU;sBAAzB,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACoB,aAAa;sBAAtC,KAAK;uBAAC,UAAU;gBACQ,YAAY;sBAApC,KAAK;uBAAC,SAAS;gBACe,iBAAiB;sBAA/C,KAAK;uBAAC,eAAe;gBAEI,mBAAmB;sBAA5C,MAAM;uBAAC,SAAS","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Input, OnInit, Optional, Output} 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 {IDataProvider} from '../../data-providers';\nimport {ActionDescriptor, ActionLevelEnum, ActionLinkDescriptor} from '../../descriptors';\nimport {IViewContainer} from '../../models';\nimport {MngActionExecutorService, MngViewContainerComponentService} from '../../services';\nimport {IdType} from '../../types';\nimport {I18nUtil} from '../../utils';\nimport {ActionData, ActionTriggerResult, IActionConfirmationService} from './models';\n\n@Component({\n    selector: 'mng-action',\n    templateUrl: './action.component.html',\n    styleUrls: ['./action.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [ConfirmationService]\n})\nexport class MngActionComponent<T, S> implements OnInit, IActionConfirmationService {\n    public readonly levelDefault = ActionLevelEnum.Default;\n    public readonly levelPrimary = ActionLevelEnum.Primary;\n    public readonly levelSecondary = ActionLevelEnum.Secondary;\n    public readonly levelInfo = ActionLevelEnum.Info;\n    public readonly levelHelp = ActionLevelEnum.Help;\n    public readonly levelSuccess = ActionLevelEnum.Success;\n    public readonly levelWarning = ActionLevelEnum.Warning;\n    public readonly levelDanger = ActionLevelEnum.Danger;\n\n    @HostBinding('class') hostClass = 'mng-action-button';\n\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?: IDataProvider<T, S>;\n    @Input('disabled') public inputDisabled: Observable<boolean> = of(false);\n    @Input('loading') public inputLoading: Observable<boolean> = of(false);\n    @Input('viewContainer') public viewContainerInit?: IViewContainer<T, S>;\n\n    @Output('trigger') public triggerEventEmitter = new EventEmitter<ActionTriggerResult<T, S, IDataProvider<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    public actionLink?: ActionLinkDescriptor<T>;\n    public hasNoTitle = false;\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\n        this.hasNoTitle = this.action.title === null;\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 = this.hasNoTitle ? of(null) : 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        if (this.action instanceof ActionLinkDescriptor) {\n            this.actionLink = this.action;\n        }\n\n        if (this.action.className) {\n            this.hostClass = this.action.className;\n        }\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: atr => {\n                    this.triggerEventEmitter.next(atr);\n                    this.loadingSubject.next(false);\n                },\n                error: err => {\n                    this.loadingSubject.next(false);\n                    console.warn(`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    <a\n        *ngIf=\"actionLink && actionLink.url !== ''; else routerLink\"\n        pButton\n        pRipple\n        [icon]=\"$any(action.icon)\"\n        [href]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : actionLink.url\"\n        [target]=\"actionLink.target\"\n        [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n        [class.p-button-rounded]=\"hasNoTitle\"\n        [class.mng-action-button-icon]=\"hasNoTitle\"\n        [class.p-button-text]=\"action.isStyleText\"\n        [class.p-button-link]=\"actionLink.isStyleLink\"\n        [class.p-button-raised]=\"action.isStyleRaised\"\n        [class.p-button-outlined]=\"action.isStyleOutlined\"\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-default]=\"action.level === levelDefault\"\n        [class.p-button-primary]=\"action.level === levelPrimary\"\n        [class.p-button-secondary]=\"action.level === levelSecondary\"\n        [class.p-button-info]=\"action.level === levelInfo\"\n        [class.p-button-help]=\"action.level === levelHelp\"\n        [class.p-button-success]=\"action.level === levelSuccess\"\n        [class.p-button-warning]=\"action.level === levelWarning\"\n        [class.p-button-danger]=\"action.level === levelDanger\"\n        >{{ ($label | async) ?? '' }}</a\n    >\n    <ng-template #routerLink>\n        <a\n            *ngIf=\"actionLink; else button\"\n            pButton\n            pRipple\n            [icon]=\"$any(action.icon)\"\n            [target]=\"actionLink.target\"\n            [replaceUrl]=\"actionLink.replaceUrl\"\n            [routerLink]=\"\n                ($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.pathSegments | linkFormatter: itemId:item:action.model:actionData)\n            \"\n            [queryParams]=\"actionLink.queryParams\"\n            [queryParamsHandling]=\"actionLink.queryParamsHandling\"\n            [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n            [class.p-button-rounded]=\"hasNoTitle\"\n            [class.mng-action-button-icon]=\"hasNoTitle\"\n            [class.p-button-text]=\"action.isStyleText\"\n            [class.p-button-link]=\"actionLink.isStyleLink\"\n            [class.p-button-raised]=\"action.isStyleRaised\"\n            [class.p-button-outlined]=\"action.isStyleOutlined\"\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-default]=\"action.level === levelDefault\"\n            [class.p-button-primary]=\"action.level === levelPrimary\"\n            [class.p-button-secondary]=\"action.level === levelSecondary\"\n            [class.p-button-info]=\"action.level === levelInfo\"\n            [class.p-button-help]=\"action.level === levelHelp\"\n            [class.p-button-success]=\"action.level === levelSuccess\"\n            [class.p-button-warning]=\"action.level === levelWarning\"\n            [class.p-button-danger]=\"action.level === levelDanger\"\n            >{{ ($label | async) ?? '' }}</a\n        >\n    </ng-template>\n    <ng-template #button>\n        <button\n            type=\"button\"\n            pButton\n            pRipple\n            [icon]=\"$any(action.icon)\"\n            [label]=\"($label | async) ?? ''\"\n            [pTooltip]=\"$any($tooltip | async)\"\n            [loading]=\"(($loading | async) ?? false) || ((inputLoading | async) ?? false)\"\n            [disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n            (click)=\"triggerAction($event)\"\n            [class.p-button-rounded]=\"hasNoTitle\"\n            [class.mng-action-button-icon]=\"hasNoTitle\"\n            [class.p-button-text]=\"action.isStyleText\"\n            [class.p-button-raised]=\"action.isStyleRaised\"\n            [class.p-button-outlined]=\"action.isStyleOutlined\"\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-default]=\"action.level === levelDefault\"\n            [class.p-button-primary]=\"action.level === levelPrimary\"\n            [class.p-button-secondary]=\"action.level === levelSecondary\"\n            [class.p-button-info]=\"action.level === levelInfo\"\n            [class.p-button-help]=\"action.level === levelHelp\"\n            [class.p-button-success]=\"action.level === levelSuccess\"\n            [class.p-button-warning]=\"action.level === levelWarning\"\n            [class.p-button-danger]=\"action.level === levelDanger\"></button>\n    </ng-template>\n    <p-confirmDialog *ngIf=\"action.hasRunConfirmation\" [key]=\"action.actionName + '_' + cmpId\" [baseZIndex]=\"50\" appendTo=\"body\"></p-confirmDialog>\n</ng-container>\n"]}
117
+ //# 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, EventEmitter, HostBinding, Input, OnInit, Optional, Output} 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 {IDataProvider} from '../../data-providers';\nimport {ActionDescriptor, ActionLevelEnum, ActionLinkDescriptor} from '../../descriptors';\nimport {IViewContainer} from '../../models';\nimport {MngActionExecutorService, MngViewContainerComponentService} from '../../services';\nimport {IdType} from '../../types';\nimport {I18nUtils} from '../../utils';\nimport {ActionData, ActionTriggerResult, IActionConfirmationService} from './models';\n\n@Component({\n    selector: 'mng-action',\n    templateUrl: './action.component.html',\n    styleUrls: ['./action.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [ConfirmationService]\n})\nexport class MngActionComponent<T, S> implements OnInit, IActionConfirmationService {\n    public readonly levelDefault = ActionLevelEnum.Default;\n    public readonly levelPrimary = ActionLevelEnum.Primary;\n    public readonly levelSecondary = ActionLevelEnum.Secondary;\n    public readonly levelInfo = ActionLevelEnum.Info;\n    public readonly levelHelp = ActionLevelEnum.Help;\n    public readonly levelSuccess = ActionLevelEnum.Success;\n    public readonly levelWarning = ActionLevelEnum.Warning;\n    public readonly levelDanger = ActionLevelEnum.Danger;\n\n    @HostBinding('class') hostClass = 'mng-action-button';\n\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?: IDataProvider<T, S>;\n    @Input('disabled') public inputDisabled: Observable<boolean> = of(false);\n    @Input('loading') public inputLoading: Observable<boolean> = of(false);\n    @Input('viewContainer') public viewContainerInit?: IViewContainer<T, S>;\n\n    @Output('trigger') public triggerEventEmitter = new EventEmitter<ActionTriggerResult<T, S, IDataProvider<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    public actionLink?: ActionLinkDescriptor<T>;\n    public hasNoTitle = false;\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\n        this.hasNoTitle = this.action.title === null;\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 = this.hasNoTitle ? of(null) : I18nUtils.Action.getAsync(this.translate, this.action, 'title', this.action?.title ?? undefined, this.item);\n        this.$tooltip = I18nUtils.Action.getAsync(this.translate, this.action, 'tooltip', this.action?.tooltip ?? undefined, this.item);\n\n        if (this.action instanceof ActionLinkDescriptor) {\n            this.actionLink = this.action;\n        }\n\n        if (this.action.className) {\n            this.hostClass = this.action.className;\n        }\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: atr => {\n                    this.triggerEventEmitter.next(atr);\n                    this.loadingSubject.next(false);\n                },\n                error: err => {\n                    this.loadingSubject.next(false);\n                    console.warn(`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    <a\n        *ngIf=\"actionLink && actionLink.url !== ''; else routerLink\"\n        pButton\n        pRipple\n        [icon]=\"$any(action.icon)\"\n        [href]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : actionLink.url\"\n        [target]=\"actionLink.target\"\n        [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n        [class.p-button-rounded]=\"hasNoTitle\"\n        [class.mng-action-button-icon]=\"hasNoTitle\"\n        [class.p-button-text]=\"action.isStyleText\"\n        [class.p-button-link]=\"actionLink.isStyleLink\"\n        [class.p-button-raised]=\"action.isStyleRaised\"\n        [class.p-button-outlined]=\"action.isStyleOutlined\"\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-default]=\"action.level === levelDefault\"\n        [class.p-button-primary]=\"action.level === levelPrimary\"\n        [class.p-button-secondary]=\"action.level === levelSecondary\"\n        [class.p-button-info]=\"action.level === levelInfo\"\n        [class.p-button-help]=\"action.level === levelHelp\"\n        [class.p-button-success]=\"action.level === levelSuccess\"\n        [class.p-button-warning]=\"action.level === levelWarning\"\n        [class.p-button-danger]=\"action.level === levelDanger\"\n        >{{ ($label | async) ?? '' }}</a\n    >\n    <ng-template #routerLink>\n        <a\n            *ngIf=\"actionLink; else button\"\n            pButton\n            pRipple\n            [icon]=\"$any(action.icon)\"\n            [target]=\"actionLink.target\"\n            [replaceUrl]=\"actionLink.replaceUrl\"\n            [routerLink]=\"\n                ($isEnabled | async) === false || ((inputDisabled | async) ?? false) ? null : (actionLink.pathSegments | linkFormatter: itemId:item:action.model:actionData)\n            \"\n            [queryParams]=\"actionLink.queryParams\"\n            [queryParamsHandling]=\"actionLink.queryParamsHandling\"\n            [class.disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n            [class.p-button-rounded]=\"hasNoTitle\"\n            [class.mng-action-button-icon]=\"hasNoTitle\"\n            [class.p-button-text]=\"action.isStyleText\"\n            [class.p-button-link]=\"actionLink.isStyleLink\"\n            [class.p-button-raised]=\"action.isStyleRaised\"\n            [class.p-button-outlined]=\"action.isStyleOutlined\"\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-default]=\"action.level === levelDefault\"\n            [class.p-button-primary]=\"action.level === levelPrimary\"\n            [class.p-button-secondary]=\"action.level === levelSecondary\"\n            [class.p-button-info]=\"action.level === levelInfo\"\n            [class.p-button-help]=\"action.level === levelHelp\"\n            [class.p-button-success]=\"action.level === levelSuccess\"\n            [class.p-button-warning]=\"action.level === levelWarning\"\n            [class.p-button-danger]=\"action.level === levelDanger\"\n            >{{ ($label | async) ?? '' }}</a\n        >\n    </ng-template>\n    <ng-template #button>\n        <button\n            type=\"button\"\n            pButton\n            pRipple\n            [icon]=\"$any(action.icon)\"\n            [label]=\"($label | async) ?? ''\"\n            [pTooltip]=\"$any($tooltip | async)\"\n            [loading]=\"(($loading | async) ?? false) || ((inputLoading | async) ?? false)\"\n            [disabled]=\"($isEnabled | async) === false || ((inputDisabled | async) ?? false)\"\n            (click)=\"triggerAction($event)\"\n            [class.p-button-rounded]=\"hasNoTitle\"\n            [class.mng-action-button-icon]=\"hasNoTitle\"\n            [class.p-button-text]=\"action.isStyleText\"\n            [class.p-button-raised]=\"action.isStyleRaised\"\n            [class.p-button-outlined]=\"action.isStyleOutlined\"\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-default]=\"action.level === levelDefault\"\n            [class.p-button-primary]=\"action.level === levelPrimary\"\n            [class.p-button-secondary]=\"action.level === levelSecondary\"\n            [class.p-button-info]=\"action.level === levelInfo\"\n            [class.p-button-help]=\"action.level === levelHelp\"\n            [class.p-button-success]=\"action.level === levelSuccess\"\n            [class.p-button-warning]=\"action.level === levelWarning\"\n            [class.p-button-danger]=\"action.level === levelDanger\"></button>\n    </ng-template>\n    <p-confirmDialog *ngIf=\"action.hasRunConfirmation\" [key]=\"action.actionName + '_' + cmpId\" [baseZIndex]=\"50\" appendTo=\"body\"></p-confirmDialog>\n</ng-container>\n"]}
@@ -1,9 +1,9 @@
1
1
  import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Optional, Output, ViewChild } from '@angular/core';
2
2
  import { ReplaySubject, of, throwError } from 'rxjs';
3
- import { catchError, finalize, first, mergeMap } from 'rxjs/operators';
3
+ import { catchError, finalize, first } from 'rxjs/operators';
4
4
  import { ActionEditorSubmitDescriptor, ActionPositionEnum } from '../../../descriptors';
5
5
  import { MngTemplateDirective } from '../../../directives';
6
- import { I18nUtil, NotificationUtil } from '../../../utils';
6
+ import { I18nUtils, NotificationUtil } from '../../../utils';
7
7
  import { MngFormEditorComponent } from '../../form';
8
8
  import { ActionError, ActionRunResult } from '../models';
9
9
  import * as i0 from "@angular/core";
@@ -184,11 +184,7 @@ export class MngActionEditorComponent {
184
184
  }
185
185
  return;
186
186
  }
187
- const subscription = I18nUtil.streamActionTranslation(this.translate, this.action, 'editor.title', this.action.editorTitle, this.item)
188
- .pipe(mergeMap(i18nDialogTitle => i18nDialogTitle === null
189
- ? I18nUtil.getActionTranslation(this.translate, this.action, 'title', undefined, this.item)
190
- : of(i18nDialogTitle)))
191
- .subscribe(t => {
187
+ const subscription = I18nUtils.Action.getEditorTitleAsync(this.translate, this.action, this.item).subscribe(t => {
192
188
  this.title = t ?? undefined;
193
189
  if (this.dialogConfig) {
194
190
  requestAnimationFrame(() => {
@@ -201,10 +197,10 @@ export class MngActionEditorComponent {
201
197
  }
202
198
  }
203
199
  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: i2.MngNavigationService }, { token: i3.DynamicDialogRef, optional: true }, { token: i3.DynamicDialogConfig, optional: true }, { token: i2.MngViewContainerComponentService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
204
- 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"] }, outputs: { actionRunEventEmitter: "actionSubmit" }, 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: "<h2 *ngIf=\"!isDialog && title\">{{ title }}</h2>\n<div class=\"h-full flex flex-column\">\n <div class=\"flex-grow-1\" *ngIf=\"toolbarLeftActions.length > 0 || toolbarRightActions.length > 0\">\n <p-toolbar styleClass=\"mng-action-editor-toolbar\">\n <ng-template pTemplate=\"left\">\n <mng-action *ngFor=\"let action of toolbarLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </ng-template>\n <ng-template pTemplate=\"right\">\n <mng-action *ngFor=\"let action of toolbarRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </ng-template>\n </p-toolbar>\n </div>\n\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\n <div class=\"flex flex-row justify-content-between\">\n <div>\n <mng-action *ngFor=\"let action of footerLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </div>\n <div>\n <mng-action *ngFor=\"let action of footerRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </div>\n </div>\n</div>\n", components: [{ type: i4.Toolbar, selector: "p-toolbar", inputs: ["style", "styleClass"] }, { type: i5.MngActionComponent, selector: "mng-action", inputs: ["action", "item", "itemId", "actionData", "dataProvider", "disabled", "loading", "viewContainer"], outputs: ["trigger"] }, { type: i6.ProgressSpinner, selector: "p-progressSpinner", inputs: ["style", "styleClass", "strokeWidth", "fill", "animationDuration"] }, { type: i7.MngFormEditorComponent, selector: "mng-form-editor", inputs: ["descriptor", "submitLoading", "item", "isSubmitButtonVisible", "isFormDisabled"], outputs: ["formSubmit"] }], directives: [{ type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i8.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
200
+ 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"] }, outputs: { actionRunEventEmitter: "actionSubmit" }, 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: "<h5 *ngIf=\"!isDialog && title\">{{ title }}</h5>\n<div class=\"h-full flex flex-column\">\n <div class=\"flex-grow-1\" *ngIf=\"toolbarLeftActions.length > 0 || toolbarRightActions.length > 0\">\n <p-toolbar styleClass=\"mng-action-editor-toolbar\">\n <ng-template pTemplate=\"left\">\n <mng-action *ngFor=\"let action of toolbarLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </ng-template>\n <ng-template pTemplate=\"right\">\n <mng-action *ngFor=\"let action of toolbarRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </ng-template>\n </p-toolbar>\n </div>\n\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\n <div class=\"flex flex-row justify-content-between\">\n <div>\n <mng-action *ngFor=\"let action of footerLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </div>\n <div>\n <mng-action *ngFor=\"let action of footerRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </div>\n </div>\n</div>\n", components: [{ type: i4.Toolbar, selector: "p-toolbar", inputs: ["style", "styleClass"] }, { type: i5.MngActionComponent, selector: "mng-action", inputs: ["action", "item", "itemId", "actionData", "dataProvider", "disabled", "loading", "viewContainer"], outputs: ["trigger"] }, { type: i6.ProgressSpinner, selector: "p-progressSpinner", inputs: ["style", "styleClass", "strokeWidth", "fill", "animationDuration"] }, { type: i7.MngFormEditorComponent, selector: "mng-form-editor", inputs: ["descriptor", "submitLoading", "item", "isSubmitButtonVisible", "isFormDisabled"], outputs: ["formSubmit"] }], directives: [{ type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i8.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
205
201
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: MngActionEditorComponent, decorators: [{
206
202
  type: Component,
207
- args: [{ selector: 'mng-action-editor', changeDetection: ChangeDetectionStrategy.OnPush, template: "<h2 *ngIf=\"!isDialog && title\">{{ title }}</h2>\n<div class=\"h-full flex flex-column\">\n <div class=\"flex-grow-1\" *ngIf=\"toolbarLeftActions.length > 0 || toolbarRightActions.length > 0\">\n <p-toolbar styleClass=\"mng-action-editor-toolbar\">\n <ng-template pTemplate=\"left\">\n <mng-action *ngFor=\"let action of toolbarLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </ng-template>\n <ng-template pTemplate=\"right\">\n <mng-action *ngFor=\"let action of toolbarRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </ng-template>\n </p-toolbar>\n </div>\n\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\n <div class=\"flex flex-row justify-content-between\">\n <div>\n <mng-action *ngFor=\"let action of footerLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </div>\n <div>\n <mng-action *ngFor=\"let action of footerRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </div>\n </div>\n</div>\n" }]
203
+ args: [{ selector: 'mng-action-editor', changeDetection: ChangeDetectionStrategy.OnPush, template: "<h5 *ngIf=\"!isDialog && title\">{{ title }}</h5>\n<div class=\"h-full flex flex-column\">\n <div class=\"flex-grow-1\" *ngIf=\"toolbarLeftActions.length > 0 || toolbarRightActions.length > 0\">\n <p-toolbar styleClass=\"mng-action-editor-toolbar\">\n <ng-template pTemplate=\"left\">\n <mng-action *ngFor=\"let action of toolbarLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </ng-template>\n <ng-template pTemplate=\"right\">\n <mng-action *ngFor=\"let action of toolbarRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </ng-template>\n </p-toolbar>\n </div>\n\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\n <div class=\"flex flex-row justify-content-between\">\n <div>\n <mng-action *ngFor=\"let action of footerLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </div>\n <div>\n <mng-action *ngFor=\"let action of footerRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n </div>\n </div>\n</div>\n" }]
208
204
  }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.TranslateService }, { type: i2.MngActionExecutorService }, { type: i2.MngCommonsService }, { type: i2.MngNavigationService }, { type: i3.DynamicDialogRef, decorators: [{
209
205
  type: Optional
210
206
  }] }, { type: i3.DynamicDialogConfig, decorators: [{
@@ -237,4 +233,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
237
233
  type: ViewChild,
238
234
  args: [MngFormEditorComponent]
239
235
  }] } });
240
- //# 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 {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    Injector,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    QueryList,\n    ViewChild\n} from '@angular/core';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {DynamicDialogConfig, DynamicDialogRef} from 'primeng/dynamicdialog';\nimport {Observable, ReplaySubject, Subscription, of, throwError} from 'rxjs';\nimport {catchError, finalize, first, mergeMap} from 'rxjs/operators';\n\nimport {IDataProvider, IEditorDataProvider} from '../../../data-providers';\nimport {ActionDescriptor, ActionEditorDescriptor, ActionEditorSubmitDescriptor, ActionPositionEnum} from '../../../descriptors';\nimport {MngTemplateDirective} from '../../../directives';\nimport {IViewContainer} from '../../../models';\nimport {MngActionExecutorService, MngCommonsService, MngNavigationService, MngViewContainerComponentService} from '../../../services';\nimport {IdType} from '../../../types';\nimport {I18nUtil, NotificationUtil} 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    @Input('viewContainer') public viewContainerInit?: IViewContainer<T, S>;\n\n    @Output('actionSubmit') public actionRunEventEmitter = new EventEmitter<ActionRunResult<T, S, IDataProvider<T, S>>>();\n\n    // content and view queries\n    @ContentChildren(MngTemplateDirective) public templates!: QueryList<MngTemplateDirective>;\n    @ViewChild('submitButton') public submitButtonElementRef!: ElementRef;\n    @ViewChild(MngFormEditorComponent) public 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    // actions\n    public toolbarLeftActions: ActionDescriptor<T>[] = [];\n    public toolbarRightActions: ActionDescriptor<T>[] = [];\n    public footerLeftActions: ActionDescriptor<T>[] = [];\n    public footerRightActions: ActionDescriptor<T>[] = [];\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    public 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        private navigationService: MngNavigationService,\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        for (const action of this.action.editorActions) {\n            if (action instanceof ActionEditorSubmitDescriptor) {\n                if (typeof action.icon === 'undefined') {\n                    action.withIcon(action.submitType === ActionEditorSubmitDescriptor.TypeEnum.Submit ? 'pi pi-check' : 'pi pi-times');\n                }\n                if (typeof action.title === 'undefined') {\n                    action.withTitle(action.submitType === ActionEditorSubmitDescriptor.TypeEnum.Submit ? 'general.save' : this.isDialog ? 'general.close' : 'general.cancel');\n                }\n\n                // assign run operations\n                action.withRunNotificationSuccess(undefined, undefined, false);\n                if (action.submitType === ActionEditorSubmitDescriptor.TypeEnum.Submit) {\n                    action.withRunFunction(() => {\n                        this.triggerSubmit();\n                        return of(undefined);\n                    });\n                } else {\n                    action.withRunFunction(() => {\n                        this.cancel();\n                        return of(undefined);\n                    });\n                }\n            }\n            switch (action.position) {\n                case ActionPositionEnum.ToolbarLeft:\n                    this.toolbarLeftActions.push(action);\n                    break;\n                case ActionPositionEnum.ToolbarRight:\n                    this.toolbarRightActions.push(action);\n                    break;\n                case ActionPositionEnum.FooterLeft:\n                    this.footerLeftActions.push(action);\n                    break;\n                case ActionPositionEnum.FooterRight:\n                    this.footerRightActions.push(action);\n                    break;\n            }\n        }\n\n        this.toolbarRightActions = this.toolbarRightActions.reverse();\n        this.footerRightActions = this.footerRightActions.reverse();\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.cancel(res);\n                    },\n                    error: () => {\n                        this.submitLoadingSubject.next(false);\n                    }\n                });\n        }\n    }\n\n    public cancel(result?: ActionRunResult<T, S, IDataProvider<T, S>>) {\n        if (!result) {\n            result = new ActionRunResult<T, S, IDataProvider<T, S>>(undefined, undefined, new ActionError(null, true));\n        }\n        if (this.isDialog) {\n            this.dialogRef?.close(result);\n        }\n        this.actionRunEventEmitter.next(result);\n    }\n\n    public triggerSubmit() {\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.item, this.itemId, this.dataProvider, this.sourceComponent, this.viewContainer)\n            .pipe(\n                first(),\n                catchError(err => {\n                    const actionError = this.actionExecutor.toMngActionError(err);\n                    if (this.action.hasRunNotificationError) {\n                        NotificationUtil.actionNotificationError(this.translate, this.action, actionError, 'fetch', this.viewContainer, this.item);\n                    }\n                    return throwError(() => actionError);\n                }),\n                finalize(() => this.loadingSubject.next(false))\n            )\n            .subscribe(res => {\n                this.item = res.result;\n                if (this.action.hasFetchNotificationSuccess) {\n                    NotificationUtil.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            }\n            return;\n        }\n        const subscription = I18nUtil.streamActionTranslation(this.translate, this.action as ActionDescriptor<T>, 'editor.title', this.action.editorTitle, this.item)\n            .pipe(\n                mergeMap(i18nDialogTitle =>\n                    i18nDialogTitle === null\n                        ? I18nUtil.getActionTranslation(this.translate, this.action as ActionDescriptor<T>, 'title', undefined, 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","<h2 *ngIf=\"!isDialog && title\">{{ title }}</h2>\n<div class=\"h-full flex flex-column\">\n    <div class=\"flex-grow-1\" *ngIf=\"toolbarLeftActions.length > 0 || toolbarRightActions.length > 0\">\n        <p-toolbar styleClass=\"mng-action-editor-toolbar\">\n            <ng-template pTemplate=\"left\">\n                <mng-action *ngFor=\"let action of toolbarLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n            </ng-template>\n            <ng-template pTemplate=\"right\">\n                <mng-action *ngFor=\"let action of toolbarRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n            </ng-template>\n        </p-toolbar>\n    </div>\n\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\n    <div class=\"flex flex-row justify-content-between\">\n        <div>\n            <mng-action *ngFor=\"let action of footerLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n        </div>\n        <div>\n            <mng-action *ngFor=\"let action of footerRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n        </div>\n    </div>\n</div>\n"]}
236
+ //# 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 {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    Injector,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    QueryList,\n    ViewChild\n} from '@angular/core';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {DynamicDialogConfig, DynamicDialogRef} from 'primeng/dynamicdialog';\nimport {Observable, ReplaySubject, Subscription, of, throwError} from 'rxjs';\nimport {catchError, finalize, first} from 'rxjs/operators';\n\nimport {IDataProvider, IEditorDataProvider} from '../../../data-providers';\nimport {ActionDescriptor, ActionEditorDescriptor, ActionEditorSubmitDescriptor, ActionPositionEnum} from '../../../descriptors';\nimport {MngTemplateDirective} from '../../../directives';\nimport {IViewContainer} from '../../../models';\nimport {MngActionExecutorService, MngCommonsService, MngNavigationService, MngViewContainerComponentService} from '../../../services';\nimport {IdType} from '../../../types';\nimport {I18nUtils, NotificationUtil} 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    @Input('viewContainer') public viewContainerInit?: IViewContainer<T, S>;\n\n    @Output('actionSubmit') public actionRunEventEmitter = new EventEmitter<ActionRunResult<T, S, IDataProvider<T, S>>>();\n\n    // content and view queries\n    @ContentChildren(MngTemplateDirective) public templates!: QueryList<MngTemplateDirective>;\n    @ViewChild('submitButton') public submitButtonElementRef!: ElementRef;\n    @ViewChild(MngFormEditorComponent) public 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    // actions\n    public toolbarLeftActions: ActionDescriptor<T>[] = [];\n    public toolbarRightActions: ActionDescriptor<T>[] = [];\n    public footerLeftActions: ActionDescriptor<T>[] = [];\n    public footerRightActions: ActionDescriptor<T>[] = [];\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    public 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        private navigationService: MngNavigationService,\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        for (const action of this.action.editorActions) {\n            if (action instanceof ActionEditorSubmitDescriptor) {\n                if (typeof action.icon === 'undefined') {\n                    action.withIcon(action.submitType === ActionEditorSubmitDescriptor.TypeEnum.Submit ? 'pi pi-check' : 'pi pi-times');\n                }\n                if (typeof action.title === 'undefined') {\n                    action.withTitle(action.submitType === ActionEditorSubmitDescriptor.TypeEnum.Submit ? 'general.save' : this.isDialog ? 'general.close' : 'general.cancel');\n                }\n\n                // assign run operations\n                action.withRunNotificationSuccess(undefined, undefined, false);\n                if (action.submitType === ActionEditorSubmitDescriptor.TypeEnum.Submit) {\n                    action.withRunFunction(() => {\n                        this.triggerSubmit();\n                        return of(undefined);\n                    });\n                } else {\n                    action.withRunFunction(() => {\n                        this.cancel();\n                        return of(undefined);\n                    });\n                }\n            }\n            switch (action.position) {\n                case ActionPositionEnum.ToolbarLeft:\n                    this.toolbarLeftActions.push(action);\n                    break;\n                case ActionPositionEnum.ToolbarRight:\n                    this.toolbarRightActions.push(action);\n                    break;\n                case ActionPositionEnum.FooterLeft:\n                    this.footerLeftActions.push(action);\n                    break;\n                case ActionPositionEnum.FooterRight:\n                    this.footerRightActions.push(action);\n                    break;\n            }\n        }\n\n        this.toolbarRightActions = this.toolbarRightActions.reverse();\n        this.footerRightActions = this.footerRightActions.reverse();\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.cancel(res);\n                    },\n                    error: () => {\n                        this.submitLoadingSubject.next(false);\n                    }\n                });\n        }\n    }\n\n    public cancel(result?: ActionRunResult<T, S, IDataProvider<T, S>>) {\n        if (!result) {\n            result = new ActionRunResult<T, S, IDataProvider<T, S>>(undefined, undefined, new ActionError(null, true));\n        }\n        if (this.isDialog) {\n            this.dialogRef?.close(result);\n        }\n        this.actionRunEventEmitter.next(result);\n    }\n\n    public triggerSubmit() {\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.item, this.itemId, this.dataProvider, this.sourceComponent, this.viewContainer)\n            .pipe(\n                first(),\n                catchError(err => {\n                    const actionError = this.actionExecutor.toMngActionError(err);\n                    if (this.action.hasRunNotificationError) {\n                        NotificationUtil.actionNotificationError(this.translate, this.action, actionError, 'fetch', this.viewContainer, this.item);\n                    }\n                    return throwError(() => actionError);\n                }),\n                finalize(() => this.loadingSubject.next(false))\n            )\n            .subscribe(res => {\n                this.item = res.result;\n                if (this.action.hasFetchNotificationSuccess) {\n                    NotificationUtil.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            }\n            return;\n        }\n        const subscription = I18nUtils.Action.getEditorTitleAsync(this.translate, this.action, this.item).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","<h5 *ngIf=\"!isDialog && title\">{{ title }}</h5>\n<div class=\"h-full flex flex-column\">\n    <div class=\"flex-grow-1\" *ngIf=\"toolbarLeftActions.length > 0 || toolbarRightActions.length > 0\">\n        <p-toolbar styleClass=\"mng-action-editor-toolbar\">\n            <ng-template pTemplate=\"left\">\n                <mng-action *ngFor=\"let action of toolbarLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n            </ng-template>\n            <ng-template pTemplate=\"right\">\n                <mng-action *ngFor=\"let action of toolbarRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n            </ng-template>\n        </p-toolbar>\n    </div>\n\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\n    <div class=\"flex flex-row justify-content-between\">\n        <div>\n            <mng-action *ngFor=\"let action of footerLeftActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n        </div>\n        <div>\n            <mng-action *ngFor=\"let action of footerRightActions\" [action]=\"action\" [disabled]=\"submitLoading$\" [viewContainer]=\"viewContainer\"></mng-action>\n        </div>\n    </div>\n</div>\n"]}