@mediusinc/mng-commons 0.0.1-rc.3 → 0.0.1-rc.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/assets/i18n/en.json +105 -0
- package/assets/i18n/sl.json +110 -0
- package/assets/templates/tableview-route.component.html +5 -0
- package/esm2020/lib/api/models/builders/query-param.builder.mjs +2 -3
- package/esm2020/lib/components/action/action.component.mjs +1 -1
- package/esm2020/lib/components/action/dialog/action-dialog.component.mjs +13 -4
- package/esm2020/lib/components/form/editor/form-editor.component.mjs +17 -15
- package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +28 -13
- package/esm2020/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +2 -4
- package/esm2020/lib/components/layout/app.breadcrumb.component.mjs +8 -9
- package/esm2020/lib/components/layout/app.menu.component.mjs +10 -24
- package/esm2020/lib/components/layout/app.menuitem.component.mjs +3 -5
- package/esm2020/lib/components/layout/app.topbar.component.mjs +32 -32
- package/esm2020/lib/components/tableview/route/tableview-route.abstract.component.mjs +1 -8
- package/esm2020/lib/components/tableview/tableview.component.mjs +2 -1
- package/esm2020/lib/components/tableview/tableview.component.service.mjs +1 -1
- package/esm2020/lib/config/formly.config.mjs +23 -52
- package/esm2020/lib/mng-commons.module.mjs +6 -31
- package/esm2020/lib/models/config/mng-config.model.mjs +1 -1
- package/esm2020/lib/models/descriptors/action-descriptor.model.mjs +46 -4
- package/esm2020/lib/models/descriptors/editor-descriptor.model.mjs +20 -1
- package/esm2020/lib/models/types/type.decorator.mjs +1 -2
- package/esm2020/lib/services/action.service.mjs +44 -14
- package/esm2020/lib/services/breadcrumb.service.mjs +62 -9
- package/esm2020/lib/services/configuration.service.mjs +1 -1
- package/esm2020/lib/services/menu.service.mjs +18 -7
- package/esm2020/lib/services/settings.service.mjs +46 -5
- package/esm2020/lib/utils/editor-formly.util.mjs +19 -8
- package/esm2020/lib/utils/i18n.util.mjs +29 -13
- package/esm2020/lib/utils/toast.util.mjs +26 -0
- package/esm2020/lib/utils/type.util.mjs +1 -5
- package/fesm2015/mediusinc-mng-commons.mjs +2458 -2274
- package/fesm2015/mediusinc-mng-commons.mjs.map +1 -1
- package/fesm2020/mediusinc-mng-commons.mjs +2603 -2426
- package/fesm2020/mediusinc-mng-commons.mjs.map +1 -1
- package/lib/components/form/editor/form-editor.component.d.ts +3 -1
- package/lib/components/layout/app.breadcrumb.component.d.ts +5 -7
- package/lib/components/layout/app.menu.component.d.ts +4 -3
- package/lib/components/layout/app.topbar.component.d.ts +2 -3
- package/lib/components/tableview/route/tableview-route.abstract.component.d.ts +0 -1
- package/lib/components/tableview/tableview.component.service.d.ts +2 -0
- package/lib/config/formly.config.d.ts +6 -0
- package/lib/mng-commons.module.d.ts +0 -3
- package/lib/models/config/mng-config.model.d.ts +1 -0
- package/lib/models/descriptors/action-descriptor.model.d.ts +21 -0
- package/lib/models/descriptors/editor-descriptor.model.d.ts +7 -0
- package/lib/services/action.service.d.ts +1 -1
- package/lib/services/breadcrumb.service.d.ts +9 -3
- package/lib/services/menu.service.d.ts +9 -4
- package/lib/services/settings.service.d.ts +13 -1
- package/lib/utils/i18n.util.d.ts +5 -4
- package/lib/utils/toast.util.d.ts +12 -0
- package/mediusinc-mng-commons-0.0.1-rc.4.tgz +0 -0
- package/package.json +36 -37
- package/mediusinc-mng-commons-0.0.1-rc.3.tgz +0 -0
package/README.md
CHANGED
|
@@ -9,7 +9,7 @@ Commons knjižnica za izgradnjo uporabniškega vmesnika na ogrodju Angular.
|
|
|
9
9
|
- Zahtevane skupne odvisnosti (peer dependencies)
|
|
10
10
|
- Angular (moduli `@angular/core`, `@angular/common`, `@angular/forms`, `@angular/router`) verzije `^13.1.0`
|
|
11
11
|
- Ngx Formly (modul `@ngx-formly/core`) verzije `^6.0.0-next.6`
|
|
12
|
-
- Ngx Translate (module `@ngx-translate/core`) verzije `^14.0.0`
|
|
12
|
+
- Ngx Translate (module `@ngx-translate/core`) verzije `^14.0.0`
|
|
13
13
|
- PrimeNG (modul `primeng`) verzije `^13.0.0`
|
|
14
14
|
|
|
15
15
|
## Namestitev
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
{
|
|
2
|
+
"app": {
|
|
3
|
+
"name": "Medius Commons"
|
|
4
|
+
},
|
|
5
|
+
"general": {
|
|
6
|
+
"yes": "Yes",
|
|
7
|
+
"no": "No",
|
|
8
|
+
"save": "Save",
|
|
9
|
+
"cancel": "Cancel",
|
|
10
|
+
"close": "Close",
|
|
11
|
+
"add": "Add",
|
|
12
|
+
"addItem": "Add {{item}}",
|
|
13
|
+
"edit": "Edit",
|
|
14
|
+
"delete": "Delete",
|
|
15
|
+
"export": "Export",
|
|
16
|
+
"returnHome": "Go back to home",
|
|
17
|
+
"confirmation": "Confirmation",
|
|
18
|
+
"success": "Success",
|
|
19
|
+
"successMessage": "Operation successful.",
|
|
20
|
+
"error": "Error",
|
|
21
|
+
"errorMessage": "Unknown error."
|
|
22
|
+
},
|
|
23
|
+
"languages": {
|
|
24
|
+
"en": "English",
|
|
25
|
+
"sl": "Slovenski"
|
|
26
|
+
},
|
|
27
|
+
"mngTopbar": {
|
|
28
|
+
"profile": "Profile",
|
|
29
|
+
"settings": "Settings",
|
|
30
|
+
"logout": "Logout"
|
|
31
|
+
},
|
|
32
|
+
"mngTable": {
|
|
33
|
+
"search": "Search...",
|
|
34
|
+
"noItems": "No items",
|
|
35
|
+
"paginationMsg": "Showing {first} to {last} of {totalRecords} entries"
|
|
36
|
+
},
|
|
37
|
+
"mngEditor": {
|
|
38
|
+
"invalidFormToastTitle": "Error in form",
|
|
39
|
+
"invalidFormToastMessage": "Form is not valid, please check and correct inserted values.",
|
|
40
|
+
"validation": {
|
|
41
|
+
"required": "{{field}} is required.",
|
|
42
|
+
"minlength": "{{field}} must be at least {{min}} characters long.",
|
|
43
|
+
"maxlength": "{{field}} must be at most {{max}} characters long.",
|
|
44
|
+
"pattern": "{{field}} must match the pattern {{pattern}}"
|
|
45
|
+
}
|
|
46
|
+
},
|
|
47
|
+
"mngAction": {
|
|
48
|
+
"functions" : {
|
|
49
|
+
"run": {
|
|
50
|
+
"title": "Action"
|
|
51
|
+
},
|
|
52
|
+
"fetch": {
|
|
53
|
+
"title": "Fetch"
|
|
54
|
+
},
|
|
55
|
+
"submit": {
|
|
56
|
+
"title": "Submit"
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
"details": {
|
|
61
|
+
"dialog": {
|
|
62
|
+
"title": "{{modelName}}: {{itemTitle}}"
|
|
63
|
+
}
|
|
64
|
+
},
|
|
65
|
+
"add": {
|
|
66
|
+
"title": "Add",
|
|
67
|
+
"dialog": {
|
|
68
|
+
"title": "Add {{modelName}}"
|
|
69
|
+
},
|
|
70
|
+
"success": {
|
|
71
|
+
"title": "Added",
|
|
72
|
+
"message": "{{itemTitle}} created successfully."
|
|
73
|
+
},
|
|
74
|
+
"error": {
|
|
75
|
+
"title": "Error",
|
|
76
|
+
"message": "Failed to add {{itemTitle}}{{errorMessage}}"
|
|
77
|
+
}
|
|
78
|
+
},
|
|
79
|
+
"edit": {
|
|
80
|
+
"dialog": {
|
|
81
|
+
"title": "Edit {{modelName}}: {{itemTitle}}"
|
|
82
|
+
},
|
|
83
|
+
"success": {
|
|
84
|
+
"title": "Edit {{modelName}}",
|
|
85
|
+
"message": "Changes for {{itemTitle}} saved successfully."
|
|
86
|
+
},
|
|
87
|
+
"error": {
|
|
88
|
+
"title": "Error",
|
|
89
|
+
"message": "Failed to execute {{functionTitle}}{{errorMessage}}"
|
|
90
|
+
}
|
|
91
|
+
},
|
|
92
|
+
"delete": {
|
|
93
|
+
"confirm": {
|
|
94
|
+
"message": "Are you sure you want to delete {{itemTitle}}?"
|
|
95
|
+
},
|
|
96
|
+
"success": {
|
|
97
|
+
"title": "Deleted",
|
|
98
|
+
"message": "{{itemTitle}} deleted successfully."
|
|
99
|
+
},
|
|
100
|
+
"error": {
|
|
101
|
+
"title": "Error",
|
|
102
|
+
"message": "Failed to delete {{itemTitle}}{{errorMessage}}"
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
{
|
|
2
|
+
"app": {
|
|
3
|
+
"name": "Medius Commons"
|
|
4
|
+
},
|
|
5
|
+
"general": {
|
|
6
|
+
"yes": "Da",
|
|
7
|
+
"no": "Ne",
|
|
8
|
+
"save": "Shrani",
|
|
9
|
+
"cancel": "Prekliči",
|
|
10
|
+
"close": "Zapri",
|
|
11
|
+
"add": "Dodaj",
|
|
12
|
+
"addItem": "Dodaj {{item}}",
|
|
13
|
+
"edit": "Uredi",
|
|
14
|
+
"delete": "Izbriši",
|
|
15
|
+
"export": "Izvozi",
|
|
16
|
+
"returnHome": "Pojdi nazaj na začetno stran",
|
|
17
|
+
"confirmation": "Potrditev",
|
|
18
|
+
"success": "Uspešno",
|
|
19
|
+
"successMessage": "Operacija uspešna.",
|
|
20
|
+
"error": "Napaka",
|
|
21
|
+
"errorMessage": "Neznana napaka."
|
|
22
|
+
},
|
|
23
|
+
"languages": {
|
|
24
|
+
"en": "English",
|
|
25
|
+
"sl": "Slovenski"
|
|
26
|
+
},
|
|
27
|
+
"mngTopbar": {
|
|
28
|
+
"profile": "Profil",
|
|
29
|
+
"settings": "Nastavitve",
|
|
30
|
+
"logout": "Odjava"
|
|
31
|
+
},
|
|
32
|
+
"mngTable": {
|
|
33
|
+
"search": "Išči...",
|
|
34
|
+
"noItems": "Ni podatkov",
|
|
35
|
+
"paginationMsg": "Prikazani so zapisi od {first} do {last} od vseh {totalRecords} zapisov"
|
|
36
|
+
},
|
|
37
|
+
"mngEditor": {
|
|
38
|
+
"invalidFormToastTitle": "Napaka v formi",
|
|
39
|
+
"invalidFormToastMessage": "Forma ni veljavna, prosimo preverite vnesene informacije in jih popravite.",
|
|
40
|
+
"validation": {
|
|
41
|
+
"required": "{{field}} je zahtevano.",
|
|
42
|
+
"minlength": "{{field}} mora biti vsaj {{min}} znakov dolgo.",
|
|
43
|
+
"maxlength": "{{field}} mora biti največ {{max}} znakov dolgo.",
|
|
44
|
+
"pattern": "{{field}} mora imeti obliko {{pattern}}."
|
|
45
|
+
}
|
|
46
|
+
},
|
|
47
|
+
"mngAction": {
|
|
48
|
+
"functions" : {
|
|
49
|
+
"run": {
|
|
50
|
+
"title": "Akcija"
|
|
51
|
+
},
|
|
52
|
+
"fetch": {
|
|
53
|
+
"title": "Pridobivanje"
|
|
54
|
+
},
|
|
55
|
+
"submit": {
|
|
56
|
+
"title": "Potrditev"
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
"formValidation": {
|
|
61
|
+
"serviceForm": {
|
|
62
|
+
"allOrNothing": "Polja v {{serviceCost}} morajo biti ali vsa izpolnjena ali vsa prazna."
|
|
63
|
+
}
|
|
64
|
+
},
|
|
65
|
+
"details": {
|
|
66
|
+
"dialog": {
|
|
67
|
+
"title": "{{modelName}}: {{itemTitle}}"
|
|
68
|
+
}
|
|
69
|
+
},
|
|
70
|
+
"add": {
|
|
71
|
+
"title": "Dodaj",
|
|
72
|
+
"dialog": {
|
|
73
|
+
"title": "Dodaj {{modelName}}"
|
|
74
|
+
},
|
|
75
|
+
"success": {
|
|
76
|
+
"title": "Dodano",
|
|
77
|
+
"message": "{{itemTitle}} uspešno dodan."
|
|
78
|
+
},
|
|
79
|
+
"error": {
|
|
80
|
+
"title": "Napaka",
|
|
81
|
+
"message": "Napaka med dodajanjem {{itemTitle}}{{errorMessage}}"
|
|
82
|
+
}
|
|
83
|
+
},
|
|
84
|
+
"edit": {
|
|
85
|
+
"dialog": {
|
|
86
|
+
"title": "Uredi {{modelName}}: {{itemTitle}}"
|
|
87
|
+
},
|
|
88
|
+
"success": {
|
|
89
|
+
"title": "Uredil {{modelName}}",
|
|
90
|
+
"message": "Spremembe {{itemTitle}} so uspešno shranjene."
|
|
91
|
+
},
|
|
92
|
+
"error": {
|
|
93
|
+
"title": "Napaka",
|
|
94
|
+
"message": "Napaka pri dodajanju {{functionTitle}}{{errorMessage}}"
|
|
95
|
+
}
|
|
96
|
+
},
|
|
97
|
+
"delete": {
|
|
98
|
+
"confirm": {
|
|
99
|
+
"message": "Ali ste prepričani, da želite izbrisati {{itemTitle}}?"
|
|
100
|
+
},
|
|
101
|
+
"success": {
|
|
102
|
+
"title": "Izbrisano",
|
|
103
|
+
"message": "{{itemTitle}} je bil uspešno izbrisan."
|
|
104
|
+
},
|
|
105
|
+
"error": {
|
|
106
|
+
"title": "Napaka",
|
|
107
|
+
"message": "Napaka med brisanjem {{itemTitle}}{{errorMessage}}"
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
@@ -18,12 +18,11 @@ export class QueryParamBuilder {
|
|
|
18
18
|
return this;
|
|
19
19
|
}
|
|
20
20
|
withSort(property, asc = true) {
|
|
21
|
-
if (!this.queryParam.sortProperty) {
|
|
21
|
+
if (!this.queryParam.sortProperty || !this.queryParam.sortAsc) {
|
|
22
22
|
this.queryParam.sortProperty = [];
|
|
23
23
|
this.queryParam.sortAsc = [];
|
|
24
24
|
}
|
|
25
25
|
this.queryParam.sortProperty.push(property);
|
|
26
|
-
// @ts-ignore
|
|
27
26
|
this.queryParam.sortAsc.push(asc);
|
|
28
27
|
return this;
|
|
29
28
|
}
|
|
@@ -46,4 +45,4 @@ export class QueryParamBuilder {
|
|
|
46
45
|
return queryParam;
|
|
47
46
|
}
|
|
48
47
|
}
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVlcnktcGFyYW0uYnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21uZy1jb21tb25zL3NyYy9saWIvYXBpL21vZGVscy9idWlsZGVycy9xdWVyeS1wYXJhbS5idWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxlQUFlLEVBQUUsV0FBVyxFQUFFLFVBQVUsRUFBQyxNQUFNLEtBQUssQ0FBQztBQUU3RCxNQUFNLE9BQU8saUJBQWlCO0lBRTFCLFlBQW9CLFVBQXNCO1FBQXRCLGVBQVUsR0FBVixVQUFVLENBQVk7SUFDMUMsQ0FBQztJQUVNLE1BQU0sQ0FBQyxNQUFNLENBQUMsZUFBdUIsRUFBRSxFQUFFLGNBQXNCLENBQUM7UUFDbkUsTUFBTSxVQUFVLEdBQUcsSUFBSSxVQUFVLEVBQUUsQ0FBQztRQUNwQyxVQUFVLENBQUMsWUFBWSxHQUFHLFlBQVksQ0FBQztRQUN2QyxVQUFVLENBQUMsV0FBVyxHQUFHLFdBQVcsQ0FBQztRQUNyQyxPQUFPLElBQUksaUJBQWlCLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUVNLGdCQUFnQixDQUFDLFlBQW9CO1FBQ3hDLElBQUksQ0FBQyxVQUFVLENBQUMsWUFBWSxHQUFHLFlBQVksQ0FBQztRQUM1QyxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0lBRU0sZUFBZSxDQUFDLFdBQW1CO1FBQ3RDLElBQUksQ0FBQyxVQUFVLENBQUMsV0FBVyxHQUFHLFdBQVcsQ0FBQztRQUMxQyxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0lBRU0sUUFBUSxDQUFDLFFBQWdCLEVBQUUsTUFBZSxJQUFJO1FBQ2pELElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFlBQVksSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxFQUFFO1lBQzNELElBQUksQ0FBQyxVQUFVLENBQUMsWUFBWSxHQUFHLEVBQUUsQ0FBQztZQUNsQyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7U0FDaEM7UUFDRCxJQUFJLENBQUMsVUFBVSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDNUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ2xDLE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7SUFFTSxVQUFVLENBQUMsUUFBZ0IsRUFBRSxLQUFVLEVBQUUsVUFBZSxTQUFTLEVBQUUsWUFBNkIsZUFBZSxDQUFDLFFBQVEsRUFBRSxxQkFBOEIsS0FBSztRQUNoSyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxZQUFZLEVBQUU7WUFDL0IsSUFBSSxDQUFDLFVBQVUsQ0FBQyxZQUFZLEdBQUcsRUFBRSxDQUFDO1NBQ3JDO1FBQ0QsTUFBTSxXQUFXLEdBQUcsSUFBSSxXQUFXLEVBQUUsQ0FBQztRQUN0QyxXQUFXLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztRQUNoQyxXQUFXLENBQUMsV0FBVyxHQUFHLEtBQUssQ0FBQztRQUNoQyxXQUFXLENBQUMsYUFBYSxHQUFHLE9BQU8sQ0FBQztRQUNwQyxXQUFXLENBQUMsZUFBZSxHQUFHLFNBQVMsQ0FBQztRQUN4QyxXQUFXLENBQUMsd0JBQXdCLEdBQUcsa0JBQWtCLENBQUM7UUFDMUQsSUFBSSxDQUFDLFVBQVUsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQy9DLE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7SUFFTSxLQUFLO1FBQ1IsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQztRQUNuQyxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksVUFBVSxFQUFFLENBQUM7UUFDbkMsT0FBTyxVQUFVLENBQUM7SUFDdEIsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtGaWx0ZXJNYXRjaFR5cGUsIEZpbHRlclBhcmFtLCBRdWVyeVBhcmFtfSBmcm9tICcuLi8nO1xuXG5leHBvcnQgY2xhc3MgUXVlcnlQYXJhbUJ1aWxkZXIge1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBxdWVyeVBhcmFtOiBRdWVyeVBhcmFtKSB7XG4gICAgfVxuXG4gICAgcHVibGljIHN0YXRpYyBjcmVhdGUoaXRlbXNQZXJQYWdlOiBudW1iZXIgPSA1MCwgaXRlbXNPZmZzZXQ6IG51bWJlciA9IDApOiBRdWVyeVBhcmFtQnVpbGRlciB7XG4gICAgICAgIGNvbnN0IHF1ZXJ5UGFyYW0gPSBuZXcgUXVlcnlQYXJhbSgpO1xuICAgICAgICBxdWVyeVBhcmFtLml0ZW1zUGVyUGFnZSA9IGl0ZW1zUGVyUGFnZTtcbiAgICAgICAgcXVlcnlQYXJhbS5pdGVtc09mZnNldCA9IGl0ZW1zT2Zmc2V0O1xuICAgICAgICByZXR1cm4gbmV3IFF1ZXJ5UGFyYW1CdWlsZGVyKHF1ZXJ5UGFyYW0pO1xuICAgIH1cblxuICAgIHB1YmxpYyB3aXRoSXRlbXNQZXJQYWdlKGl0ZW1zUGVyUGFnZTogbnVtYmVyKTogUXVlcnlQYXJhbUJ1aWxkZXIge1xuICAgICAgICB0aGlzLnF1ZXJ5UGFyYW0uaXRlbXNQZXJQYWdlID0gaXRlbXNQZXJQYWdlO1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICBwdWJsaWMgd2l0aEl0ZW1zT2Zmc2V0KGl0ZW1zT2Zmc2V0OiBudW1iZXIpOiBRdWVyeVBhcmFtQnVpbGRlciB7XG4gICAgICAgIHRoaXMucXVlcnlQYXJhbS5pdGVtc09mZnNldCA9IGl0ZW1zT2Zmc2V0O1xuICAgICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICBwdWJsaWMgd2l0aFNvcnQocHJvcGVydHk6IHN0cmluZywgYXNjOiBib29sZWFuID0gdHJ1ZSk6IFF1ZXJ5UGFyYW1CdWlsZGVyIHtcbiAgICAgICAgaWYgKCF0aGlzLnF1ZXJ5UGFyYW0uc29ydFByb3BlcnR5IHx8ICF0aGlzLnF1ZXJ5UGFyYW0uc29ydEFzYykge1xuICAgICAgICAgICAgdGhpcy5xdWVyeVBhcmFtLnNvcnRQcm9wZXJ0eSA9IFtdO1xuICAgICAgICAgICAgdGhpcy5xdWVyeVBhcmFtLnNvcnRBc2MgPSBbXTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLnF1ZXJ5UGFyYW0uc29ydFByb3BlcnR5LnB1c2gocHJvcGVydHkpO1xuICAgICAgICB0aGlzLnF1ZXJ5UGFyYW0uc29ydEFzYy5wdXNoKGFzYyk7XG4gICAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIHB1YmxpYyB3aXRoRmlsdGVyKHByb3BlcnR5OiBzdHJpbmcsIHZhbHVlOiBhbnksIHZhbHVlVG86IGFueSA9IHVuZGVmaW5lZCwgbWF0Y2hUeXBlOiBGaWx0ZXJNYXRjaFR5cGUgPSBGaWx0ZXJNYXRjaFR5cGUuQ29udGFpbnMsIG1hdGNoQ2FzZVNlbnNpdGl2ZTogYm9vbGVhbiA9IGZhbHNlKTogUXVlcnlQYXJhbUJ1aWxkZXIge1xuICAgICAgICBpZiAoIXRoaXMucXVlcnlQYXJhbS5maWx0ZXJQYXJhbXMpIHtcbiAgICAgICAgICAgIHRoaXMucXVlcnlQYXJhbS5maWx0ZXJQYXJhbXMgPSBbXTtcbiAgICAgICAgfVxuICAgICAgICBjb25zdCBmaWx0ZXJQYXJhbSA9IG5ldyBGaWx0ZXJQYXJhbSgpO1xuICAgICAgICBmaWx0ZXJQYXJhbS5wcm9wZXJ0eSA9IHByb3BlcnR5O1xuICAgICAgICBmaWx0ZXJQYXJhbS5maWx0ZXJWYWx1ZSA9IHZhbHVlO1xuICAgICAgICBmaWx0ZXJQYXJhbS5maWx0ZXJWYWx1ZVRvID0gdmFsdWVUbztcbiAgICAgICAgZmlsdGVyUGFyYW0uZmlsdGVyTWF0Y2hUeXBlID0gbWF0Y2hUeXBlO1xuICAgICAgICBmaWx0ZXJQYXJhbS5maWx0ZXJNYXRjaENhc2VTZW5zaXRpdmUgPSBtYXRjaENhc2VTZW5zaXRpdmU7XG4gICAgICAgIHRoaXMucXVlcnlQYXJhbS5maWx0ZXJQYXJhbXMucHVzaChmaWx0ZXJQYXJhbSk7XG4gICAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIHB1YmxpYyBidWlsZCgpOiBRdWVyeVBhcmFtIHtcbiAgICAgICAgY29uc3QgcXVlcnlQYXJhbSA9IHRoaXMucXVlcnlQYXJhbTtcbiAgICAgICAgdGhpcy5xdWVyeVBhcmFtID0gbmV3IFF1ZXJ5UGFyYW0oKTtcbiAgICAgICAgcmV0dXJuIHF1ZXJ5UGFyYW07XG4gICAgfVxufVxuIl19
|
|
@@ -60,4 +60,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
60
60
|
}], actionData: [{
|
|
61
61
|
type: Input
|
|
62
62
|
}] } });
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action.component.js","sourceRoot":"","sources":["../../../../../../projects/mng-commons/src/lib/components/action/action.component.ts","../../../../../../projects/mng-commons/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';\n\nimport {Observable, of, ReplaySubject} from 'rxjs';\nimport {finalize, first} from 'rxjs/operators';\nimport {ConfirmationService, MessageService} from 'primeng/api';\n\nimport {IdType} from '../../models/types';\nimport {ActionData} from '../../models/action';\nimport {ActionDescriptor} from '../../models/descriptors';\nimport {IConfirmationService} from '../../models/interfaces';\nimport {ActionService} from '../../services';\nimport {I18nUtil} from '../../utils';\nimport {TableviewComponentService} from '../tableview/tableview.component.service';\n\n@Component({\n    selector: 'mng-action',\n    templateUrl: './action.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [MessageService, ConfirmationService]\n})\nexport class ActionComponent<T, S> implements OnInit, IConfirmationService {\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\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\n    constructor(\n        private route: ActivatedRoute,\n        private translate: TranslateService,\n        private actionService: ActionService,\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(this.action, this.itemId, this.item, this.tableviewService?.dataProvider ?? undefined, this.tableviewService, this, this.actionData);\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    }\n\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.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            .subscribe(res => {});\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 *ngIf=\"action.icon && action.title === null; else noIcon\" type=\"button\"\n            pButton pRipple\n            [icon]=\"action.icon\"\n            [loading]=\"($loading | async) ?? false\"\n            [disabled]=\"!($isEnabled | async)\"\n            (click)=\"triggerAction($event)\"\n            class=\"mng-action-button mng-action-button-icon p-button-rounded\"\n            [class.p-button-success]=\"action.level === 5\"\n            [class.p-button-danger]=\"action.level === 7\">\n    </button>\n    <ng-template #noIcon>\n        <button type=\"button\"\n                pButton pRipple\n                [icon]=\"$any(action.icon)\"\n                [label]=\"($label | async) ?? ''\"\n                [loading]=\"($loading | async) ?? false\"\n                [disabled]=\"!($isEnabled | async)\"\n                (click)=\"triggerAction($event)\"\n                class=\"mng-action-button p-button-text\"\n                [class.p-button-success]=\"action.level === 5\"\n                [class.p-button-danger]=\"action.level === 7\">\n        </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,10 +1,11 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
2
|
import { of, ReplaySubject } from 'rxjs';
|
|
3
|
-
import { finalize, first, mergeMap } from 'rxjs/operators';
|
|
3
|
+
import { catchError, finalize, first, mergeMap } from 'rxjs/operators';
|
|
4
4
|
import { ActionError, ActionRunResult } from '../../../models/action';
|
|
5
5
|
import { TemplateDirective } from '../../../directives';
|
|
6
|
-
import { FormEditorComponent } from '
|
|
6
|
+
import { FormEditorComponent } from '../../form';
|
|
7
7
|
import { I18nUtil } from '../../../utils';
|
|
8
|
+
import { ToastUtil } from '../../../utils/toast.util';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "@ngx-translate/core";
|
|
10
11
|
import * as i2 from "primeng/dynamicdialog";
|
|
@@ -89,9 +90,17 @@ export class ActionDialogComponent {
|
|
|
89
90
|
}
|
|
90
91
|
this.loadingSubject.next(true);
|
|
91
92
|
this.actionService.runEditorFetch(this.action, this.itemId, this.dataProvider, this.sourceComponent, this.tableviewService)
|
|
92
|
-
.pipe(first(),
|
|
93
|
+
.pipe(first(), catchError(err => {
|
|
94
|
+
if (this.action.hasRunNotificationError) {
|
|
95
|
+
ToastUtil.actionNotificationError(this.translate, this.action, err, 'fetch', this.tableviewService, this.item);
|
|
96
|
+
}
|
|
97
|
+
throw err;
|
|
98
|
+
}), finalize(() => this.loadingSubject.next(false)))
|
|
93
99
|
.subscribe(res => {
|
|
94
100
|
this.item = res.result;
|
|
101
|
+
if (this.action.hasFetchNotificationSuccess) {
|
|
102
|
+
ToastUtil.actionNotificationSuccess(this.translate, this.action, 'fetch', this.action.fetchNotificationSuccessTitle, this.action.fetchNotificationSuccessMessage, this.tableviewService, this.item);
|
|
103
|
+
}
|
|
95
104
|
this.setDialogHeaderTitle();
|
|
96
105
|
});
|
|
97
106
|
}
|
|
@@ -145,4 +154,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
145
154
|
type: ViewChild,
|
|
146
155
|
args: [FormEditorComponent]
|
|
147
156
|
}] } });
|
|
148
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-dialog.component.js","sourceRoot":"","sources":["../../../../../../../projects/mng-commons/src/lib/components/action/dialog/action-dialog.component.ts","../../../../../../../projects/mng-commons/src/lib/components/action/dialog/action-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Injector, Input, OnDestroy, OnInit, Output, QueryList, ViewChild} from '@angular/core';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {DynamicDialogConfig, DynamicDialogRef} from 'primeng/dynamicdialog';\nimport {Observable, of, ReplaySubject, Subscription} from 'rxjs';\nimport {finalize, first, mergeMap} from 'rxjs/operators';\n\nimport {ActionData, ActionError, ActionRunResult} from '../../../models/action';\nimport {ActionDescriptor, ActionEditorDescriptor} from '../../../models/descriptors';\nimport {IdType} from '../../../models/types';\nimport {IEditorDataProvider} from '../../../models/providers';\nimport {MngEditorItemEvent, MngEditorSubmitEvent} from '../../../models/events';\nimport {ActionService} from '../../../services';\nimport {TemplateDirective} from '../../../directives';\nimport {FormEditorComponent} from '../../../components/form';\nimport {I18nUtil} from '../../../utils';\nimport {TableviewComponentService} from '../../tableview/tableview.component.service';\n\n@Component({\n    selector: 'mng-action-dialog',\n    templateUrl: './action-dialog.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ActionDialogComponent<T, S> implements OnInit, OnDestroy {\n\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\n    // event outputs\n    @Output('onFinished') private createEventEmitter = new EventEmitter<MngEditorItemEvent<T>>();\n    @Output('onVisibleChange') private visibleChangeEventEmitter = new EventEmitter<boolean>();\n\n    // content and view queries\n    @ContentChildren(TemplateDirective) templates!: QueryList<TemplateDirective>;\n\n    @ViewChild('submitButton') private submitButtonElementRef!: ElementRef;\n    @ViewChild(FormEditorComponent) private editorComponent!: FormEditorComponent<T>;\n\n    public cmpId: string = Math.random().toString(36).substring(2);\n\n    private loadingSubject = new ReplaySubject<boolean>(1);\n    private submitLoadingSubject = new ReplaySubject<boolean>(1);\n    public loading$: Observable<boolean> = this.loadingSubject.asObservable();\n    public submitLoading$: Observable<boolean> = this.submitLoadingSubject.asObservable();\n    public isSaveButton = true;\n\n    private tableviewService?: TableviewComponentService<T, S>;\n    private sourceComponent: any = this;\n    private subscriptions: Array<Subscription> = [];\n\n    constructor(\n        private injector: Injector,\n        private translate: TranslateService,\n        public dialogRef: DynamicDialogRef,\n        public dialogConfig: DynamicDialogConfig,\n        private actionService: ActionService\n    ) {}\n\n    public ngOnInit() {\n\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.tableview) {\n                this.tableviewService = this.dialogConfig.data.tableview;\n                if (!this.dataProvider && this.tableviewService?.dataProvider) {\n                    this.dataProvider = this.tableviewService.dataProvider;\n                }\n            }\n            if (this.dialogConfig.data.sourceComponent) {\n                this.sourceComponent = this.dialogConfig.data.sourceComponent;\n            }\n        }\n\n        this.isSaveButton = typeof this.action.submitFunction === 'function';\n        this.setDialogHeaderTitle();\n\n        this.loadItemWithDataProvider();\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    public onSubmit(event: MngEditorSubmitEvent<T>) {\n        if (event.success) {\n            if (typeof this.action.submitFunction !== 'function') {\n                return;\n            }\n            this.submitLoadingSubject.next(true);\n            this.actionService.runEditorSave(this.action, this.itemId, event.formItem, this.dataProvider, this.sourceComponent, this.tableviewService, this.actionData)\n                .pipe(\n                    first(),\n                    finalize(() => this.submitLoadingSubject.next(false))\n                )\n                .subscribe(res => {\n                    this.closeDialog(res);\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.actionService.runEditorFetch(this.action, this.itemId, this.dataProvider, this.sourceComponent, this.tableviewService)\n            .pipe(\n                first(),\n                finalize(() => this.loadingSubject.next(false))\n            )\n            .subscribe(res => {\n                this.item = res.result;\n                this.setDialogHeaderTitle();\n            });\n    }\n\n    private setDialogHeaderTitle() {\n        if (this.action.editorTitle === null) {\n            requestAnimationFrame(() => {\n                this.dialogConfig.header = undefined;\n            });\n            return;\n        }\n        const subscription = I18nUtil.streamActionTranslation(this.translate, this.action as ActionDescriptor<T>, 'dialog.title', undefined, this.item)\n            .pipe(\n                mergeMap(i18nDialogTitle => i18nDialogTitle === null\n                    ? I18nUtil.getActionTranslation(this.translate, this.action as ActionDescriptor<T>, 'title', this.action.editorTitle, this.item)\n                    : of(i18nDialogTitle))\n            )\n            .subscribe(t => {\n                requestAnimationFrame(() => {\n                    this.dialogConfig.header = t ?? undefined;\n                });\n            });\n        this.subscriptions.push(subscription);\n    }\n}\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)\"\n                    [descriptor]=\"action.editorDescriptor\"\n                    [item]=\"item\"\n                    (onSubmit)=\"onSubmit($event)\">\n        </mng-form-editor>\n    </div>\n    <div class=\"flex flex-row justify-content-between\">\n        <div></div>\n        <div>\n            <button type=\"button\" pButton pRipple [label]=\"'general.close' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"closeDialog()\" [disabled]=\"submitLoading$ | async\"></button>\n            <button *ngIf=\"isSaveButton\" #submitButton type=\"button\" pButton 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\">\n            </button>\n        </div>\n    </div>\n</div>\n"]}
|
|
157
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-dialog.component.js","sourceRoot":"","sources":["../../../../../../../projects/mng-commons/src/lib/components/action/dialog/action-dialog.component.ts","../../../../../../../projects/mng-commons/src/lib/components/action/dialog/action-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Injector, Input, OnDestroy, OnInit, Output, QueryList, ViewChild} from '@angular/core';\n\nimport {TranslateService} from '@ngx-translate/core';\nimport {DynamicDialogConfig, DynamicDialogRef} from 'primeng/dynamicdialog';\nimport {Observable, of, ReplaySubject, Subscription} from 'rxjs';\nimport {catchError, finalize, first, mergeMap} from 'rxjs/operators';\n\nimport {ActionData, ActionError, ActionRunResult} from '../../../models/action';\nimport {ActionDescriptor, ActionEditorDescriptor} from '../../../models/descriptors';\nimport {IdType} from '../../../models/types';\nimport {IEditorDataProvider} from '../../../models/providers';\nimport {MngEditorItemEvent, MngEditorSubmitEvent} from '../../../models/events';\nimport {ActionService} from '../../../services';\nimport {TemplateDirective} from '../../../directives';\nimport {FormEditorComponent} from '../../form';\nimport {I18nUtil} from '../../../utils';\nimport {TableviewComponentService} from '../../tableview/tableview.component.service';\nimport {ToastUtil} from '../../../utils/toast.util';\n\n@Component({\n    selector: 'mng-action-dialog',\n    templateUrl: './action-dialog.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ActionDialogComponent<T, S> implements OnInit, OnDestroy {\n\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\n    // event outputs\n    @Output('onFinished') private createEventEmitter = new EventEmitter<MngEditorItemEvent<T>>();\n    @Output('onVisibleChange') private visibleChangeEventEmitter = new EventEmitter<boolean>();\n\n    // content and view queries\n    @ContentChildren(TemplateDirective) templates!: QueryList<TemplateDirective>;\n\n    @ViewChild('submitButton') private submitButtonElementRef!: ElementRef;\n    @ViewChild(FormEditorComponent) private editorComponent!: FormEditorComponent<T>;\n\n    public cmpId: string = Math.random().toString(36).substring(2);\n\n    private loadingSubject = new ReplaySubject<boolean>(1);\n    private submitLoadingSubject = new ReplaySubject<boolean>(1);\n    public loading$: Observable<boolean> = this.loadingSubject.asObservable();\n    public submitLoading$: Observable<boolean> = this.submitLoadingSubject.asObservable();\n    public isSaveButton = true;\n\n    private tableviewService?: TableviewComponentService<T, S>;\n    private sourceComponent: any = this;\n    private subscriptions: Array<Subscription> = [];\n\n    constructor(\n        private injector: Injector,\n        private translate: TranslateService,\n        public dialogRef: DynamicDialogRef,\n        public dialogConfig: DynamicDialogConfig,\n        private actionService: ActionService\n    ) {\n    }\n\n    public ngOnInit() {\n\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.tableview) {\n                this.tableviewService = this.dialogConfig.data.tableview;\n                if (!this.dataProvider && this.tableviewService?.dataProvider) {\n                    this.dataProvider = this.tableviewService.dataProvider;\n                }\n            }\n            if (this.dialogConfig.data.sourceComponent) {\n                this.sourceComponent = this.dialogConfig.data.sourceComponent;\n            }\n        }\n\n        this.isSaveButton = typeof this.action.submitFunction === 'function';\n        this.setDialogHeaderTitle();\n\n        this.loadItemWithDataProvider();\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    public onSubmit(event: MngEditorSubmitEvent<T>) {\n        if (event.success) {\n            if (typeof this.action.submitFunction !== 'function') {\n                return;\n            }\n            this.submitLoadingSubject.next(true);\n            this.actionService.runEditorSave(this.action, this.itemId, event.formItem, this.dataProvider, this.sourceComponent, this.tableviewService, this.actionData)\n                .pipe(\n                    first(),\n                    finalize(() => this.submitLoadingSubject.next(false))\n                )\n                .subscribe(res => {\n                    this.closeDialog(res);\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.actionService.runEditorFetch(this.action, this.itemId, this.dataProvider, this.sourceComponent, this.tableviewService)\n            .pipe(\n                first(),\n                catchError(err => {\n                    if (this.action.hasRunNotificationError) {\n                        ToastUtil.actionNotificationError(this.translate, this.action, err, 'fetch', this.tableviewService, 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(this.translate, this.action, 'fetch', this.action.fetchNotificationSuccessTitle,\n                        this.action.fetchNotificationSuccessMessage,this.tableviewService, this.item);\n                }\n                this.setDialogHeaderTitle();\n            });\n    }\n\n    private setDialogHeaderTitle() {\n        if (this.action.editorTitle === null) {\n            requestAnimationFrame(() => {\n                this.dialogConfig.header = undefined;\n            });\n            return;\n        }\n        const subscription = I18nUtil.streamActionTranslation(this.translate, this.action as ActionDescriptor<T>, 'dialog.title', undefined, this.item)\n            .pipe(\n                mergeMap(i18nDialogTitle => i18nDialogTitle === null\n                    ? I18nUtil.getActionTranslation(this.translate, this.action as ActionDescriptor<T>, 'title', this.action.editorTitle, this.item)\n                    : of(i18nDialogTitle))\n            )\n            .subscribe(t => {\n                requestAnimationFrame(() => {\n                    this.dialogConfig.header = t ?? undefined;\n                });\n            });\n        this.subscriptions.push(subscription);\n    }\n}\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)\"\n                    [descriptor]=\"action.editorDescriptor\"\n                    [item]=\"item\"\n                    (onSubmit)=\"onSubmit($event)\">\n        </mng-form-editor>\n    </div>\n    <div class=\"flex flex-row justify-content-between\">\n        <div></div>\n        <div>\n            <button type=\"button\" pButton pRipple [label]=\"'general.close' | translate\" icon=\"pi pi-times\" class=\"p-button-text\" (click)=\"closeDialog()\" [disabled]=\"submitLoading$ | async\"></button>\n            <button *ngIf=\"isSaveButton\" #submitButton type=\"button\" pButton 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\">\n            </button>\n        </div>\n    </div>\n</div>\n"]}
|
|
@@ -4,14 +4,17 @@ import { Observable, of } from 'rxjs';
|
|
|
4
4
|
import { MngEditorSubmitEvent } from '../../../models/events';
|
|
5
5
|
import { TemplateDirective } from '../../../directives';
|
|
6
6
|
import { EditorFormlyUtil } from '../../../utils';
|
|
7
|
+
import { ToastUtil } from '../../../utils/toast.util';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "@ngx-
|
|
9
|
-
import * as i2 from "
|
|
10
|
-
import * as i3 from "
|
|
11
|
-
import * as i4 from "
|
|
12
|
-
import * as i5 from "
|
|
9
|
+
import * as i1 from "@ngx-translate/core";
|
|
10
|
+
import * as i2 from "@ngx-formly/core";
|
|
11
|
+
import * as i3 from "primeng/messages";
|
|
12
|
+
import * as i4 from "@angular/forms";
|
|
13
|
+
import * as i5 from "primeng/button";
|
|
14
|
+
import * as i6 from "@angular/common";
|
|
13
15
|
export class FormEditorComponent {
|
|
14
|
-
constructor() {
|
|
16
|
+
constructor(translateService) {
|
|
17
|
+
this.translateService = translateService;
|
|
15
18
|
this.submitLoading = false;
|
|
16
19
|
// extra features input
|
|
17
20
|
this.isSubmitButtonVisible = false;
|
|
@@ -55,13 +58,11 @@ export class FormEditorComponent {
|
|
|
55
58
|
onSubmit(event) {
|
|
56
59
|
this.formOptions.formState.submittedOn = Date.now();
|
|
57
60
|
this.formMessages = [];
|
|
58
|
-
const formSubmitItem = this.form.
|
|
61
|
+
const formSubmitItem = this.form.getRawValue();
|
|
59
62
|
if (this.form.valid) {
|
|
60
63
|
this.descriptor.fields.forEach(field => {
|
|
61
64
|
if (field && field.setter) {
|
|
62
|
-
|
|
63
|
-
// @ts-ignore
|
|
64
|
-
field.setter(formSubmitItem, formSubmitItem[field.property]);
|
|
65
|
+
field.setter(formSubmitItem, this.form.value[field.property]);
|
|
65
66
|
}
|
|
66
67
|
});
|
|
67
68
|
this.submitEventEmitter.next(new MngEditorSubmitEvent(formSubmitItem));
|
|
@@ -76,6 +77,7 @@ export class FormEditorComponent {
|
|
|
76
77
|
}
|
|
77
78
|
const event = new MngEditorSubmitEvent(formSubmitItem);
|
|
78
79
|
event.success = false;
|
|
80
|
+
this.formMessages.push(ToastUtil.getFormEditorWarningMessage(this.translateService, 'mngEditor.invalidFormToastTitle', 'mngEditor.invalidFormToastMessage'));
|
|
79
81
|
this.submitEventEmitter.next(event);
|
|
80
82
|
}
|
|
81
83
|
}
|
|
@@ -112,12 +114,12 @@ export class FormEditorComponent {
|
|
|
112
114
|
this.formOptions.formState.disabled = this.isFormDisabled !== null ? this.isFormDisabled === true : this.descriptor.disabled;
|
|
113
115
|
}
|
|
114
116
|
}
|
|
115
|
-
FormEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: FormEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
116
|
-
FormEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: FormEditorComponent, selector: "mng-form-editor", inputs: { descriptor: "descriptor", submitLoading: "submitLoading", item: "item", isSubmitButtonVisible: "isSubmitButtonVisible", isFormDisabled: "isFormDisabled" }, outputs: { submitEventEmitter: "onSubmit" }, queries: [{ propertyName: "templates", predicate: TemplateDirective }], viewQueries: [{ propertyName: "submitButtonElementRef", first: true, predicate: ["submitButton"], descendants: true }], ngImport: i0, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n <button #submitButton pButton type=\"submit\" [class.hidden]=\"!isSubmitButtonVisible\" [disabled]=\"form.disabled\" [loading]=\"(submitLoading$ | async) ?? false\"></button>\n</form>\n<p-messages [value]=\"formMessages\"></p-messages>\n", components: [{ type:
|
|
117
|
+
FormEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: FormEditorComponent, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
118
|
+
FormEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: FormEditorComponent, selector: "mng-form-editor", inputs: { descriptor: "descriptor", submitLoading: "submitLoading", item: "item", isSubmitButtonVisible: "isSubmitButtonVisible", isFormDisabled: "isFormDisabled" }, outputs: { submitEventEmitter: "onSubmit" }, queries: [{ propertyName: "templates", predicate: TemplateDirective }], viewQueries: [{ propertyName: "submitButtonElementRef", first: true, predicate: ["submitButton"], descendants: true }], ngImport: i0, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n <button #submitButton pButton type=\"submit\" [class.hidden]=\"!isSubmitButtonVisible\" [disabled]=\"form.disabled\" [loading]=\"(submitLoading$ | async) ?? false\"></button>\n</form>\n<p-messages [value]=\"formMessages\" [enableService]=\"false\"></p-messages>\n", components: [{ type: i2.FormlyForm, selector: "formly-form", inputs: ["form", "model", "fields", "options"], outputs: ["modelChange"] }, { type: i3.Messages, selector: "p-messages", inputs: ["value", "closable", "style", "styleClass", "enableService", "key", "escape", "severity", "showTransitionOptions", "hideTransitionOptions"], outputs: ["valueChange"] }], directives: [{ type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i5.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }], pipes: { "async": i6.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
117
119
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: FormEditorComponent, decorators: [{
|
|
118
120
|
type: Component,
|
|
119
|
-
args: [{ selector: 'mng-form-editor', changeDetection: ChangeDetectionStrategy.OnPush, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n <button #submitButton pButton type=\"submit\" [class.hidden]=\"!isSubmitButtonVisible\" [disabled]=\"form.disabled\" [loading]=\"(submitLoading$ | async) ?? false\"></button>\n</form>\n<p-messages [value]=\"formMessages\"></p-messages>\n" }]
|
|
120
|
-
}], ctorParameters: function () { return []; }, propDecorators: { descriptor: [{
|
|
121
|
+
args: [{ selector: 'mng-form-editor', changeDetection: ChangeDetectionStrategy.OnPush, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n <button #submitButton pButton type=\"submit\" [class.hidden]=\"!isSubmitButtonVisible\" [disabled]=\"form.disabled\" [loading]=\"(submitLoading$ | async) ?? false\"></button>\n</form>\n<p-messages [value]=\"formMessages\" [enableService]=\"false\"></p-messages>\n" }]
|
|
122
|
+
}], ctorParameters: function () { return [{ type: i1.TranslateService }]; }, propDecorators: { descriptor: [{
|
|
121
123
|
type: Input
|
|
122
124
|
}], submitLoading: [{
|
|
123
125
|
type: Input
|
|
@@ -137,4 +139,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
137
139
|
type: ViewChild,
|
|
138
140
|
args: ['submitButton']
|
|
139
141
|
}] } });
|
|
140
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/mng-commons/src/lib/components/form/editor/form-editor.component.ts","../../../../../../../projects/mng-commons/src/lib/components/form/editor/form-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterContentInit, ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Output, QueryList, ViewChild} from '@angular/core';\nimport {FormGroup} from '@angular/forms';\n\nimport {FormlyFieldConfig, FormlyFormOptions} from '@ngx-formly/core';\nimport {Message} from 'primeng/api';\nimport {Observable, of, Subscription} from 'rxjs';\n\nimport {EditorDescriptor} from '../../../models/descriptors';\nimport {MngEditorSubmitEvent} from '../../../models/events';\nimport {TemplateDirective} from '../../../directives';\nimport {EditorFormlyUtil} from '../../../utils';\n\n@Component({\n    selector: 'mng-form-editor',\n    templateUrl: './form-editor.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FormEditorComponent<T> implements OnInit, AfterContentInit, OnDestroy {\n\n    // metadata and editor mode input\n    @Input() public descriptor!: EditorDescriptor<T>;\n    @Input() public submitLoading: Observable<boolean>|boolean = false;\n\n    // data source inputs;\n    @Input() public item?: T;\n\n    // extra features input\n    @Input() public isSubmitButtonVisible = false;\n    @Input() public isFormDisabled = null;\n\n    // event outputs\n    @Output('onSubmit') private submitEventEmitter = new EventEmitter<MngEditorSubmitEvent<T>>();\n\n    // content and view queries\n    @ContentChildren(TemplateDirective) templates!: QueryList<TemplateDirective>;\n\n    @ViewChild('submitButton')\n    public submitButtonElementRef?: ElementRef;\n\n    public form: FormGroup = new FormGroup({});\n    public formOptions: FormlyFormOptions = {\n        formState: {\n            add: false,\n            edit: false,\n            disabled: false\n        }\n    };\n    public formFields!: FormlyFieldConfig[];\n    public formOrigItem?: T;\n    public formModel: any = {};\n    public formMessages: Message[] = [];\n    public submitLoading$!: Observable<boolean>;\n\n    private subscriptions: Subscription[] = [];\n\n    constructor() { }\n\n    public ngOnInit() {\n\n        this.updateFormModel(this.item);\n        this.submitLoading$ = this.submitLoading instanceof Observable ? this.submitLoading : of(this.submitLoading);\n\n        // init fields for formly\n        this.formFields = EditorFormlyUtil.createFormlyConfigFromDescriptor(this.descriptor);\n        this.updateFormState();\n    }\n\n    public ngAfterContentInit() {\n        this.templates.forEach(template => {\n            switch(template.getType()) {\n                // case 'caption':\n                //     this.captionTemplate = template.template;\n                //     break;\n            }\n        });\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    public submit() {\n        this.submitButtonElementRef?.nativeElement.click();\n    }\n\n    public onSubmit(event: Event) {\n        this.formOptions.formState.submittedOn = Date.now();\n        this.formMessages = [];\n\n        const formSubmitItem = this.form.value as T;\n        if (this.form.valid) {\n            this.descriptor.fields.forEach(field => {\n                if (field && field.setter) {\n                    // TODO: resolve ts ignore\n                    // @ts-ignore\n                    field.setter(formSubmitItem, formSubmitItem[field.property]);\n                }\n            });\n\n            this.submitEventEmitter.next(new MngEditorSubmitEvent(formSubmitItem));\n        } else {\n            // find and mark invalid tabs\n            if (this.formFields[0].type === 'tabs' && this.formFields[0].fieldGroup) {\n                for (const tab of this.formFields[0].fieldGroup) {\n                    const isInvalid = this.isAnyFieldInvalid(tab.fieldGroup);\n                    this.formOptions.formState['tab_' + (tab.id ? tab.id : tab.templateOptions?.label) + '_invalid'] = isInvalid;\n                }\n            }\n            const event = new MngEditorSubmitEvent(formSubmitItem);\n            event.success = false;\n            this.submitEventEmitter.next(event);\n        }\n    }\n\n    private isAnyFieldInvalid(fields: FormlyFieldConfig[] = []): boolean {\n        for (const field of fields) {\n            let fieldInvalid = false;\n            if (Array.isArray(field.fieldGroup)) {\n                fieldInvalid = this.isAnyFieldInvalid(field.fieldGroup);\n            } else if (typeof field.type !== 'undefined') {\n                fieldInvalid = !field.formControl?.valid;\n            }\n            if (fieldInvalid) {\n                return true;\n            }\n        }\n        return false;\n    }\n\n    private updateFormModel(item?: T) {\n        this.formOrigItem = item;\n        // TODO: to check if this is ok, could be problems with dates, if so, try lodash\n        const formModel =  JSON.parse(JSON.stringify(item ?? {}));\n\n        this.descriptor.fields.forEach(field => {\n            if (field.getter && item) {\n                formModel[field.property] = field.getter(item);\n            }\n        });\n        if (typeof this.formOptions.resetModel === 'function') { // could not be initiated yet\n            this.formOptions.resetModel(this.formModel);\n        }\n        this.formModel = formModel;\n    }\n\n    private updateFormState() {\n        this.formOptions.formState.disabled = this.isFormDisabled !== null ? this.isFormDisabled === true : this.descriptor.disabled;\n    }\n}\n","<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n    <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n    <button #submitButton pButton type=\"submit\" [class.hidden]=\"!isSubmitButtonVisible\" [disabled]=\"form.disabled\" [loading]=\"(submitLoading$ | async) ?? false\"></button>\n</form>\n<p-messages [value]=\"formMessages\"></p-messages>\n"]}
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/mng-commons/src/lib/components/form/editor/form-editor.component.ts","../../../../../../../projects/mng-commons/src/lib/components/form/editor/form-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AfterContentInit, ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Output, QueryList, ViewChild} from '@angular/core';\nimport {FormGroup} from '@angular/forms';\n\nimport {FormlyFieldConfig, FormlyFormOptions} from '@ngx-formly/core';\nimport {Message} from 'primeng/api';\nimport {Observable, of, Subscription} from 'rxjs';\nimport {TranslateService} from '@ngx-translate/core';\n\nimport {EditorDescriptor} from '../../../models/descriptors';\nimport {MngEditorSubmitEvent} from '../../../models/events';\nimport {TemplateDirective} from '../../../directives';\nimport {EditorFormlyUtil} from '../../../utils';\nimport {ToastUtil} from '../../../utils/toast.util';\n\n@Component({\n    selector: 'mng-form-editor',\n    templateUrl: './form-editor.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FormEditorComponent<T> implements OnInit, AfterContentInit, OnDestroy {\n\n    // metadata and editor mode input\n    @Input() public descriptor!: EditorDescriptor<T>;\n    @Input() public submitLoading: Observable<boolean>|boolean = false;\n\n    // data source inputs;\n    @Input() public item?: T;\n\n    // extra features input\n    @Input() public isSubmitButtonVisible = false;\n    @Input() public isFormDisabled = null;\n\n    // event outputs\n    @Output('onSubmit') private submitEventEmitter = new EventEmitter<MngEditorSubmitEvent<T>>();\n\n    // content and view queries\n    @ContentChildren(TemplateDirective) templates!: QueryList<TemplateDirective>;\n\n    @ViewChild('submitButton')\n    public submitButtonElementRef?: ElementRef;\n\n    public form: FormGroup = new FormGroup({});\n    public formOptions: FormlyFormOptions = {\n        formState: {\n            add: false,\n            edit: false,\n            disabled: false\n        }\n    };\n    public formFields!: FormlyFieldConfig[];\n    public formOrigItem?: T;\n    public formModel: any = {};\n    public formMessages: Message[] = [];\n    public submitLoading$!: Observable<boolean>;\n\n    private subscriptions: Subscription[] = [];\n\n    constructor(private translateService: TranslateService) { }\n\n    public ngOnInit() {\n\n        this.updateFormModel(this.item);\n        this.submitLoading$ = this.submitLoading instanceof Observable ? this.submitLoading : of(this.submitLoading);\n\n        // init fields for formly\n        this.formFields = EditorFormlyUtil.createFormlyConfigFromDescriptor(this.descriptor);\n        this.updateFormState();\n    }\n\n    public ngAfterContentInit() {\n        this.templates.forEach(template => {\n            switch(template.getType()) {\n                // case 'caption':\n                //     this.captionTemplate = template.template;\n                //     break;\n            }\n        });\n    }\n\n    public ngOnDestroy() {\n        this.subscriptions.forEach(s => s.unsubscribe());\n    }\n\n    public submit() {\n        this.submitButtonElementRef?.nativeElement.click();\n    }\n\n    public onSubmit(event: Event) {\n        this.formOptions.formState.submittedOn = Date.now();\n        this.formMessages = [];\n\n        const formSubmitItem = this.form.getRawValue() as T;\n        if (this.form.valid) {\n            this.descriptor.fields.forEach(field => {\n                if (field && field.setter) {\n                    field.setter(formSubmitItem, this.form.value[field.property]);\n                }\n            });\n\n            this.submitEventEmitter.next(new MngEditorSubmitEvent(formSubmitItem));\n        } else {\n            // find and mark invalid tabs\n            if (this.formFields[0].type === 'tabs' && this.formFields[0].fieldGroup) {\n                for (const tab of this.formFields[0].fieldGroup) {\n                    const isInvalid = this.isAnyFieldInvalid(tab.fieldGroup);\n                    this.formOptions.formState['tab_' + (tab.id ? tab.id : tab.templateOptions?.label) + '_invalid'] = isInvalid;\n                }\n            }\n            const event = new MngEditorSubmitEvent(formSubmitItem);\n            event.success = false;\n            this.formMessages.push(ToastUtil.getFormEditorWarningMessage(this.translateService, 'mngEditor.invalidFormToastTitle', 'mngEditor.invalidFormToastMessage'));\n            this.submitEventEmitter.next(event);\n        }\n    }\n\n    private isAnyFieldInvalid(fields: FormlyFieldConfig[] = []): boolean {\n        for (const field of fields) {\n            let fieldInvalid = false;\n            if (Array.isArray(field.fieldGroup)) {\n                fieldInvalid = this.isAnyFieldInvalid(field.fieldGroup);\n            } else if (typeof field.type !== 'undefined') {\n                fieldInvalid = !field.formControl?.valid;\n            }\n            if (fieldInvalid) {\n                return true;\n            }\n        }\n        return false;\n    }\n\n    private updateFormModel(item?: T) {\n        this.formOrigItem = item;\n        // TODO: to check if this is ok, could be problems with dates, if so, try lodash\n        const formModel =  JSON.parse(JSON.stringify(item ?? {}));\n\n        this.descriptor.fields.forEach(field => {\n            if (field.getter && item) {\n                formModel[field.property] = field.getter(item);\n            }\n        });\n        if (typeof this.formOptions.resetModel === 'function') { // could not be initiated yet\n            this.formOptions.resetModel(this.formModel);\n        }\n        this.formModel = formModel;\n    }\n\n    private updateFormState() {\n        this.formOptions.formState.disabled = this.isFormDisabled !== null ? this.isFormDisabled === true : this.descriptor.disabled;\n    }\n}\n","<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n    <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n    <button #submitButton pButton type=\"submit\" [class.hidden]=\"!isSubmitButtonVisible\" [disabled]=\"form.disabled\" [loading]=\"(submitLoading$ | async) ?? false\"></button>\n</form>\n<p-messages [value]=\"formMessages\" [enableService]=\"false\"></p-messages>\n"]}
|