@eqproject/eqp-dynamic-module 2.0.11 → 2.0.12
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/esm2020/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.mjs +133 -136
- package/esm2020/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.mjs +9 -10
- package/esm2020/lib/components/private/add-form-field/add-form-field.component.mjs +200 -117
- package/esm2020/lib/components/private/add-formula-field/add-formula-field.component.mjs +7 -7
- package/esm2020/lib/components/private/dynamic-module-field/dynamic-module-field.component.mjs +4 -4
- package/esm2020/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.mjs +4 -4
- package/esm2020/lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.mjs +4 -4
- package/esm2020/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.mjs +4 -4
- package/esm2020/lib/components/private/field-templates/date-field-template/date-field-template.component.mjs +4 -4
- package/esm2020/lib/components/private/field-templates/image-field-template/image-field-template.component.mjs +4 -4
- package/esm2020/lib/components/private/field-templates/list-value-field-template/list-value-field-template.component.mjs +4 -4
- package/esm2020/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.mjs +4 -4
- package/esm2020/lib/components/private/field-templates/text-field-template/text-field-template.component.mjs +4 -4
- package/esm2020/lib/components/private/field-templates/textarea-field-template/textarea-field-template.component.mjs +4 -4
- package/esm2020/lib/components/private/form-records/add-form-record/add-form-record.component.mjs +164 -23
- package/esm2020/lib/components/private/form-records/list-form-record/list-form-record.component.mjs +262 -92
- package/esm2020/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.mjs +424 -0
- package/esm2020/lib/components/private/form-records/repair-form-fields/repair-form-fields.component.mjs +4 -4
- package/esm2020/lib/components/private/form-records/view-form-record/view-form-record.component.mjs +160 -0
- package/esm2020/lib/components/private/spinner/spinner.component.mjs +4 -4
- package/esm2020/lib/eqp-dynamic-module.module.mjs +11 -5
- package/esm2020/lib/models/DynamicModuleViewModeEnum.mjs +6 -4
- package/esm2020/lib/models/endPointConfiguration.model.mjs +60 -1
- package/esm2020/lib/models/record.model.mjs +1 -1
- package/esm2020/lib/modules/material.module.mjs +5 -5
- package/esm2020/lib/services/eqp-dynamic-module-dialog.service.mjs +4 -4
- package/esm2020/lib/services/spinner.service.mjs +4 -4
- package/esm2020/lib/services/utilityHelper.services.mjs +5 -5
- package/esm2020/lib/services/voice-recognition.service.mjs +4 -4
- package/fesm2015/eqproject-eqp-dynamic-module.mjs +1527 -509
- package/fesm2015/eqproject-eqp-dynamic-module.mjs.map +1 -1
- package/fesm2020/eqproject-eqp-dynamic-module.mjs +1522 -506
- package/fesm2020/eqproject-eqp-dynamic-module.mjs.map +1 -1
- package/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.d.ts +24 -8
- package/lib/components/private/add-form-field/add-form-field.component.d.ts +13 -13
- package/lib/components/private/form-records/add-form-record/add-form-record.component.d.ts +18 -3
- package/lib/components/private/form-records/list-form-record/list-form-record.component.d.ts +47 -26
- package/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.d.ts +110 -0
- package/lib/components/private/form-records/view-form-record/view-form-record.component.d.ts +32 -0
- package/lib/eqp-dynamic-module.module.d.ts +18 -16
- package/lib/models/DynamicModuleViewModeEnum.d.ts +5 -3
- package/lib/models/endPointConfiguration.model.d.ts +1 -0
- package/lib/models/record.model.d.ts +2 -0
- package/package.json +1 -1
package/esm2020/lib/components/private/form-records/add-form-record/add-form-record.component.mjs
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output, ViewChildren } from '@angular/core';
|
|
2
2
|
import { FieldTypeEnum } from '../../../../models/baseField.model';
|
|
3
|
-
import {
|
|
4
|
-
import { Record } from '../../../../models/record.model';
|
|
3
|
+
import { FormScalarTypeEnum } from '../../../../models/form.model';
|
|
4
|
+
import { DynRecord, Record } from '../../../../models/record.model';
|
|
5
|
+
import { ParamTypeEnum } from 'projects/eqp-dynamic-module/src/lib/models/endPointConfiguration.model';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
import * as i1 from "../../../../services/utilityHelper.services";
|
|
7
8
|
import * as i2 from "@angular/material/button";
|
|
@@ -16,30 +17,70 @@ export class AddFormRecordComponent {
|
|
|
16
17
|
constructor(cdr, utilityService) {
|
|
17
18
|
this.cdr = cdr;
|
|
18
19
|
this.utilityService = utilityService;
|
|
19
|
-
this.
|
|
20
|
+
this.formID = null; // preview
|
|
21
|
+
this.form = null; // preview config
|
|
22
|
+
this.record = null; // edit
|
|
23
|
+
this.onlyView = false;
|
|
20
24
|
this.showTitle = true;
|
|
21
25
|
this.showSaveButton = true;
|
|
22
26
|
this.showBackButton = true;
|
|
23
|
-
this.userMode = true;
|
|
24
27
|
this.fieldGroups = {};
|
|
25
28
|
this.FormScalarTypeEnum = FormScalarTypeEnum;
|
|
26
29
|
this.FieldTypeEnum = FieldTypeEnum;
|
|
27
30
|
this.saveRecordEvent = new EventEmitter();
|
|
31
|
+
this.afterSaveRecordEvent = new EventEmitter();
|
|
28
32
|
}
|
|
29
33
|
ngOnInit() {
|
|
34
|
+
// add può funzionare anche come modifica e come preview
|
|
35
|
+
// in add abbiamo in input l'ID del Form
|
|
36
|
+
// in modifica abbiamo in input l'ID del Record
|
|
37
|
+
// in preview abbiamo in input il Form(caso configurator) o l'ID del modulo on onlyView impostato a true
|
|
38
|
+
console.log("form: ", this.form);
|
|
39
|
+
console.log("formID: ", this.formID);
|
|
40
|
+
console.log("record: ", this.record);
|
|
30
41
|
this.showTitle = this.configurations.showTitle;
|
|
31
42
|
this.showSaveButton = this.configurations.showSaveButton;
|
|
32
43
|
this.showBackButton = this.configurations.showBackButton;
|
|
33
44
|
if (this.record == null) {
|
|
34
45
|
this.record = new Record();
|
|
46
|
+
if (this.onlyView == true) {
|
|
47
|
+
// modalità preview
|
|
48
|
+
if (this.form != null) {
|
|
49
|
+
// preview per il configurator
|
|
50
|
+
this.fieldsConfig();
|
|
51
|
+
}
|
|
52
|
+
else if (this.formID != null) {
|
|
53
|
+
// preview per admin
|
|
54
|
+
this.getFormByID(); // dentro chiama fieldsConfig
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
// aggiugni nuovo
|
|
59
|
+
this.fieldsConfig();
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
// modiiltà modifica
|
|
64
|
+
if (typeof this.record === "string") {
|
|
65
|
+
// allora è un ID
|
|
66
|
+
this.getRecordByID();
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
// il record viene passato come tale
|
|
70
|
+
// (<Record>this.record).EntID = "3";
|
|
71
|
+
// (<Record>this.record).Version;
|
|
72
|
+
this.getFormByIDandVersion();
|
|
73
|
+
}
|
|
35
74
|
}
|
|
75
|
+
this.cdr.detectChanges();
|
|
76
|
+
}
|
|
77
|
+
fieldsConfig() {
|
|
36
78
|
this.createRecordProperties();
|
|
37
79
|
this.reorderFormFields();
|
|
38
80
|
this.createFormGroup();
|
|
39
81
|
if (this.form.FormScalarType != FormScalarTypeEnum.Semplice) {
|
|
40
82
|
this.createFieldGroups();
|
|
41
83
|
}
|
|
42
|
-
this.cdr.detectChanges();
|
|
43
84
|
}
|
|
44
85
|
/**
|
|
45
86
|
* Metodo invocato al cambio del valore di ogni proprietà dell'oggetto record.
|
|
@@ -47,7 +88,7 @@ export class AddFormRecordComponent {
|
|
|
47
88
|
*/
|
|
48
89
|
onRecordChange() {
|
|
49
90
|
if (this.fieldTemplate && this.fieldTemplate.length > 0) {
|
|
50
|
-
this.fieldTemplate.forEach(f => f.updateField());
|
|
91
|
+
this.fieldTemplate.forEach((f) => f.updateField());
|
|
51
92
|
}
|
|
52
93
|
}
|
|
53
94
|
/**
|
|
@@ -55,26 +96,119 @@ export class AddFormRecordComponent {
|
|
|
55
96
|
*/
|
|
56
97
|
saveOrExitForm(exit) {
|
|
57
98
|
if (exit) {
|
|
58
|
-
this.saveRecordEvent.emit(null);
|
|
99
|
+
// this.saveRecordEvent.emit(null);
|
|
100
|
+
this.onSaveRecord(null);
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
// this.saveRecordEvent.emit(this.record);
|
|
104
|
+
this.onSaveRecord(this.record);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* Metodo per salvare il record aggiunto o modificato.
|
|
109
|
+
* Se è stato configurato un endPoint per il salvataggio viene effettuata una chiamata al server passando l'oggeto da salvare
|
|
110
|
+
* nel body della chiamata, altrimenti scatena l'evento "saveRecord".
|
|
111
|
+
* @param event Oggetto di tipo Record da salvare.
|
|
112
|
+
*/
|
|
113
|
+
onSaveRecord(event) {
|
|
114
|
+
if (event != null &&
|
|
115
|
+
this.endPointConfiguration != null &&
|
|
116
|
+
this.endPointConfiguration.Records.SaveEndPoint) {
|
|
117
|
+
var dynRec = new DynRecord();
|
|
118
|
+
dynRec.ID = event.ID ?? null;
|
|
119
|
+
dynRec.EntID = this.form.ID;
|
|
120
|
+
dynRec.Version = this.form.Version;
|
|
121
|
+
dynRec.userID = this.userID;
|
|
122
|
+
dynRec.Values = event ?? null;
|
|
123
|
+
var dynamicModuleParams = [
|
|
124
|
+
{
|
|
125
|
+
ParamName: "Record",
|
|
126
|
+
ParamValue: dynRec,
|
|
127
|
+
ParamType: ParamTypeEnum["In Body"],
|
|
128
|
+
},
|
|
129
|
+
];
|
|
130
|
+
this.utilityService.RunEndPointCall(this.endPointConfiguration.Records.SaveEndPoint, dynamicModuleParams, (res) => {
|
|
131
|
+
this.afterSaveRecordEvent.emit(event);
|
|
132
|
+
});
|
|
59
133
|
}
|
|
60
134
|
else {
|
|
61
|
-
this.saveRecordEvent.emit(
|
|
135
|
+
this.saveRecordEvent.emit(event);
|
|
62
136
|
}
|
|
63
137
|
}
|
|
138
|
+
getFormByID(id = this.formID) {
|
|
139
|
+
const dynamicModuleParams = new Array();
|
|
140
|
+
dynamicModuleParams.push({
|
|
141
|
+
ParamName: "id",
|
|
142
|
+
ParamValue: id,
|
|
143
|
+
ParamType: ParamTypeEnum["Query param"],
|
|
144
|
+
});
|
|
145
|
+
this.utilityService.RunEndPointCall(this.endPointConfiguration.Forms.GetByIDEndPoint, dynamicModuleParams, (res) => {
|
|
146
|
+
this.form = res;
|
|
147
|
+
this.fieldsConfig();
|
|
148
|
+
}, (err) => { });
|
|
149
|
+
}
|
|
150
|
+
// ci entro solo se è stato passato il parametro "record" come stringa
|
|
151
|
+
getRecordByID() {
|
|
152
|
+
// preparo i dati del record
|
|
153
|
+
var dynamicRecordParams = [
|
|
154
|
+
{
|
|
155
|
+
ParamName: "id",
|
|
156
|
+
ParamValue: this.record,
|
|
157
|
+
ParamType: ParamTypeEnum["Query param"],
|
|
158
|
+
},
|
|
159
|
+
];
|
|
160
|
+
this.utilityService.RunEndPointCall(this.endPointConfiguration.Records.GetByIDEndPoint, dynamicRecordParams, (res) => {
|
|
161
|
+
this.record = new Record();
|
|
162
|
+
this.record = JSON.parse(res.SerializedValues);
|
|
163
|
+
this.record.ID = res.ID;
|
|
164
|
+
this.record.EntID = res.EntID;
|
|
165
|
+
this.record.userID = res.userID;
|
|
166
|
+
this.record.Version = res.Version;
|
|
167
|
+
this.record.Values = JSON.parse(res.SerializedValues);
|
|
168
|
+
// this.viewMode = DynamicModuleViewModeEnum.COMPILE;
|
|
169
|
+
// this.loader = true;
|
|
170
|
+
this.getFormByIDandVersion();
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
getFormByIDandVersion() {
|
|
174
|
+
// preparo la versione corretta del form
|
|
175
|
+
var dynamicModuleParams = [
|
|
176
|
+
{
|
|
177
|
+
ParamName: "EntID",
|
|
178
|
+
ParamValue: this.record.EntID,
|
|
179
|
+
ParamType: ParamTypeEnum["Query param"],
|
|
180
|
+
},
|
|
181
|
+
{
|
|
182
|
+
ParamName: "Version",
|
|
183
|
+
ParamValue: this.record.Version,
|
|
184
|
+
ParamType: ParamTypeEnum["Query param"],
|
|
185
|
+
},
|
|
186
|
+
];
|
|
187
|
+
console.log("this record", this.record);
|
|
188
|
+
this.utilityService.RunEndPointCall(this.endPointConfiguration.Forms.GetByIDAndVersionEndPoint, dynamicModuleParams, (res) => {
|
|
189
|
+
this.form = res;
|
|
190
|
+
this.createRecordProperties();
|
|
191
|
+
this.reorderFormFields();
|
|
192
|
+
this.createFormGroup();
|
|
193
|
+
if (this.form.FormScalarType != FormScalarTypeEnum.Semplice) {
|
|
194
|
+
this.createFieldGroups();
|
|
195
|
+
}
|
|
196
|
+
});
|
|
197
|
+
}
|
|
64
198
|
/**
|
|
65
199
|
* Metodo per creare nell'oggetto Record le proprietà mancanti rispetto ai campi che compongono la form.
|
|
66
200
|
*/
|
|
67
201
|
createRecordProperties() {
|
|
68
202
|
const recordProperties = Object.keys(this.record);
|
|
69
|
-
this.form.Fields.forEach(field => {
|
|
70
|
-
if (!recordProperties.find(p => p === field.Name)) {
|
|
203
|
+
this.form.Fields.forEach((field) => {
|
|
204
|
+
if (!recordProperties.find((p) => p === field.Name)) {
|
|
71
205
|
this.record[field.Name] = null;
|
|
72
206
|
}
|
|
73
207
|
});
|
|
74
208
|
if (this.form.InnerForms && this.form.InnerForms.length > 0) {
|
|
75
|
-
this.form.InnerForms.forEach(form => {
|
|
209
|
+
this.form.InnerForms.forEach((form) => {
|
|
76
210
|
const arrayName = form.Name.split(" ").join("_");
|
|
77
|
-
if (!recordProperties.find(p => p === arrayName)) {
|
|
211
|
+
if (!recordProperties.find((p) => p === arrayName)) {
|
|
78
212
|
this.record[arrayName] = [];
|
|
79
213
|
}
|
|
80
214
|
});
|
|
@@ -85,7 +219,7 @@ export class AddFormRecordComponent {
|
|
|
85
219
|
*/
|
|
86
220
|
reorderFormFields() {
|
|
87
221
|
if (this.form.Fields && this.form.Fields.length > 0) {
|
|
88
|
-
this.form.Fields.sort((a, b) =>
|
|
222
|
+
this.form.Fields.sort((a, b) => a.OrdinalPosition > b.OrdinalPosition ? 1 : b.OrdinalPosition > a.OrdinalPosition ? -1 : 0);
|
|
89
223
|
}
|
|
90
224
|
}
|
|
91
225
|
/**
|
|
@@ -99,21 +233,26 @@ export class AddFormRecordComponent {
|
|
|
99
233
|
* a come è stata configurata dall'utente.
|
|
100
234
|
*/
|
|
101
235
|
createFieldGroups() {
|
|
102
|
-
this.form.FormFieldsGroups
|
|
103
|
-
.
|
|
104
|
-
.
|
|
105
|
-
.
|
|
106
|
-
this.fieldGroups[groupName] = this.form.Fields.filter(f => f.FieldGroup == groupName);
|
|
236
|
+
this.form.FormFieldsGroups.sort((a, b) => a.OrdinalPosition > b.OrdinalPosition ? 1 : b.OrdinalPosition > a.OrdinalPosition ? -1 : 0)
|
|
237
|
+
.map((g) => g.Name)
|
|
238
|
+
.forEach((groupName) => {
|
|
239
|
+
this.fieldGroups[groupName] = this.form.Fields.filter((f) => f.FieldGroup == groupName);
|
|
107
240
|
});
|
|
108
241
|
}
|
|
109
242
|
}
|
|
110
|
-
AddFormRecordComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.
|
|
111
|
-
AddFormRecordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.
|
|
112
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.
|
|
243
|
+
AddFormRecordComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AddFormRecordComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.UtilityHelperService }], target: i0.ɵɵFactoryTarget.Component });
|
|
244
|
+
AddFormRecordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: AddFormRecordComponent, selector: "add-form-record", inputs: { configurations: "configurations", endPointConfiguration: "endPointConfiguration", userID: "userID", formID: "formID", form: "form", record: "record", onlyView: "onlyView" }, outputs: { saveRecordEvent: "saveRecordEvent", afterSaveRecordEvent: "afterSaveRecordEvent" }, viewQueries: [{ propertyName: "fieldTemplate", predicate: ["fieldTemplate"], descendants: true }], ngImport: i0, template: "<div class=\"row eqp-dynamic-module-title\" *ngIf=\"showTitle\">\r\n <div class=\"col-md-12\">\r\n <h4><b>{{form.Name}}</b></h4>\r\n </div>\r\n</div>\r\n\r\n<form [formGroup]=\"formForm\">\r\n\r\n <!-- VISUALIZZAZIONE SEMPLICE -->\r\n <ng-container *ngIf=\"form.FormScalarType == FormScalarTypeEnum.Semplice\" \r\n [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: form.Fields }\">\r\n </ng-container>\r\n\r\n <!-- VISUALIZZAZIONE A STEPPER -->\r\n <mat-horizontal-stepper linear *ngIf=\"form.FormScalarType == FormScalarTypeEnum['A step']\">\r\n <mat-step *ngFor=\"let group of form.FormFieldsGroups\">\r\n <ng-template matStepLabel>\r\n {{group.Name}}\r\n </ng-template>\r\n\r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n </mat-step>\r\n </mat-horizontal-stepper>\r\n\r\n <!-- VISUALIZZAZIONE A TAB -->\r\n <mat-tab-group *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In tab']\">\r\n <mat-tab *ngFor=\"let group of form.FormFieldsGroups\" [label]=\"group.Name\">\r\n <div class=\"mt-3\">\r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n </div>\r\n </mat-tab>\r\n </mat-tab-group>\r\n\r\n <!-- VISUALIZZAZIONE AD ACCORDION -->\r\n <mat-accordion multi *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In accordion']\">\r\n <mat-expansion-panel *ngFor=\"let group of form.FormFieldsGroups\">\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{group.Name}}\r\n </mat-panel-title>\r\n </mat-expansion-panel-header>\r\n\r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n </mat-expansion-panel>\r\n </mat-accordion>\r\n</form>\r\n\r\n<div class=\"row mt-2\" *ngIf=\"showBackButton || showSaveButton\">\r\n <div class=\"col-sm-12 text-right\">\r\n <button class=\"mr-2\" mat-raised-button type=\"button\"\r\n *ngIf=\"showBackButton\"\r\n (click)=\"saveOrExitForm(true)\">\r\n Annulla\r\n </button>\r\n <button class=\"mr-2\" mat-raised-button color=\"primary\" type=\"button\"\r\n *ngIf=\"showSaveButton\"\r\n (click)=\"saveOrExitForm(false)\"\r\n [disabled]=\"formForm.invalid || formForm.disabled\">\r\n Salva\r\n </button>\r\n </div>\r\n</div>\r\n\r\n<!-- TEMPLATE PER LA VISUALIZZAZIONE DEI CAMPI DELLA FORM -->\r\n<ng-template #fieldTemplates let-fields='fields'>\r\n <div class=\"row\">\r\n <div class=\"mt-2\" \r\n *ngFor=\"let field of fields\" \r\n [hidden]=\"!field.InListView\" \r\n [ngClass]=\"utilityService.getFieldSyleClass(field)\">\r\n <dynamic-module-field-fix #fieldTemplate \r\n [field]=\"field\" \r\n [form]=\"form\" \r\n [record]=\"record\"\r\n (recordChange)=\"onRecordChange()\">\r\n </dynamic-module-field-fix>\r\n </div>\r\n </div>\r\n</ng-template>", styles: [""], dependencies: [{ kind: "component", type: i2.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i3.MatStep, selector: "mat-step", inputs: ["color"], exportAs: ["matStep"] }, { kind: "directive", type: i3.MatStepLabel, selector: "[matStepLabel]" }, { kind: "component", type: i3.MatStepper, selector: "mat-stepper, mat-vertical-stepper, mat-horizontal-stepper, [matStepper]", inputs: ["selectedIndex", "disableRipple", "color", "labelPosition", "headerPosition", "animationDuration"], outputs: ["animationDone"], exportAs: ["matStepper", "matVerticalStepper", "matHorizontalStepper"] }, { kind: "component", type: i4.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "disableRipple"], exportAs: ["matTabGroup"] }, { kind: "component", type: i4.MatTab, selector: "mat-tab", inputs: ["disabled", "label", "aria-label", "aria-labelledby", "labelClass", "bodyClass"], exportAs: ["matTab"] }, { kind: "directive", type: i5.MatAccordion, selector: "mat-accordion", inputs: ["multi", "hideToggle", "displayMode", "togglePosition"], exportAs: ["matAccordion"] }, { kind: "component", type: i5.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "component", type: i5.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { kind: "directive", type: i5.MatExpansionPanelTitle, selector: "mat-panel-title" }, { kind: "directive", type: i6.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i6.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i6.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i8.DynamicModuleFieldFixComponent, selector: "dynamic-module-field-fix", inputs: ["field", "form", "record"], outputs: ["recordChange"] }] });
|
|
245
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AddFormRecordComponent, decorators: [{
|
|
113
246
|
type: Component,
|
|
114
|
-
args: [{ selector:
|
|
247
|
+
args: [{ selector: "add-form-record", template: "<div class=\"row eqp-dynamic-module-title\" *ngIf=\"showTitle\">\r\n <div class=\"col-md-12\">\r\n <h4><b>{{form.Name}}</b></h4>\r\n </div>\r\n</div>\r\n\r\n<form [formGroup]=\"formForm\">\r\n\r\n <!-- VISUALIZZAZIONE SEMPLICE -->\r\n <ng-container *ngIf=\"form.FormScalarType == FormScalarTypeEnum.Semplice\" \r\n [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: form.Fields }\">\r\n </ng-container>\r\n\r\n <!-- VISUALIZZAZIONE A STEPPER -->\r\n <mat-horizontal-stepper linear *ngIf=\"form.FormScalarType == FormScalarTypeEnum['A step']\">\r\n <mat-step *ngFor=\"let group of form.FormFieldsGroups\">\r\n <ng-template matStepLabel>\r\n {{group.Name}}\r\n </ng-template>\r\n\r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n </mat-step>\r\n </mat-horizontal-stepper>\r\n\r\n <!-- VISUALIZZAZIONE A TAB -->\r\n <mat-tab-group *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In tab']\">\r\n <mat-tab *ngFor=\"let group of form.FormFieldsGroups\" [label]=\"group.Name\">\r\n <div class=\"mt-3\">\r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n </div>\r\n </mat-tab>\r\n </mat-tab-group>\r\n\r\n <!-- VISUALIZZAZIONE AD ACCORDION -->\r\n <mat-accordion multi *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In accordion']\">\r\n <mat-expansion-panel *ngFor=\"let group of form.FormFieldsGroups\">\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{group.Name}}\r\n </mat-panel-title>\r\n </mat-expansion-panel-header>\r\n\r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n </mat-expansion-panel>\r\n </mat-accordion>\r\n</form>\r\n\r\n<div class=\"row mt-2\" *ngIf=\"showBackButton || showSaveButton\">\r\n <div class=\"col-sm-12 text-right\">\r\n <button class=\"mr-2\" mat-raised-button type=\"button\"\r\n *ngIf=\"showBackButton\"\r\n (click)=\"saveOrExitForm(true)\">\r\n Annulla\r\n </button>\r\n <button class=\"mr-2\" mat-raised-button color=\"primary\" type=\"button\"\r\n *ngIf=\"showSaveButton\"\r\n (click)=\"saveOrExitForm(false)\"\r\n [disabled]=\"formForm.invalid || formForm.disabled\">\r\n Salva\r\n </button>\r\n </div>\r\n</div>\r\n\r\n<!-- TEMPLATE PER LA VISUALIZZAZIONE DEI CAMPI DELLA FORM -->\r\n<ng-template #fieldTemplates let-fields='fields'>\r\n <div class=\"row\">\r\n <div class=\"mt-2\" \r\n *ngFor=\"let field of fields\" \r\n [hidden]=\"!field.InListView\" \r\n [ngClass]=\"utilityService.getFieldSyleClass(field)\">\r\n <dynamic-module-field-fix #fieldTemplate \r\n [field]=\"field\" \r\n [form]=\"form\" \r\n [record]=\"record\"\r\n (recordChange)=\"onRecordChange()\">\r\n </dynamic-module-field-fix>\r\n </div>\r\n </div>\r\n</ng-template>" }]
|
|
115
248
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.UtilityHelperService }]; }, propDecorators: { configurations: [{
|
|
116
249
|
type: Input
|
|
250
|
+
}], endPointConfiguration: [{
|
|
251
|
+
type: Input
|
|
252
|
+
}], userID: [{
|
|
253
|
+
type: Input
|
|
254
|
+
}], formID: [{
|
|
255
|
+
type: Input
|
|
117
256
|
}], form: [{
|
|
118
257
|
type: Input
|
|
119
258
|
}], record: [{
|
|
@@ -122,8 +261,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImpor
|
|
|
122
261
|
type: Input
|
|
123
262
|
}], saveRecordEvent: [{
|
|
124
263
|
type: Output
|
|
264
|
+
}], afterSaveRecordEvent: [{
|
|
265
|
+
type: Output
|
|
125
266
|
}], fieldTemplate: [{
|
|
126
267
|
type: ViewChildren,
|
|
127
268
|
args: ["fieldTemplate"]
|
|
128
269
|
}] } });
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-form-record.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-records/add-form-record/add-form-record.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-records/add-form-record/add-form-record.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, OnInit, Output, QueryList, ViewChildren } from '@angular/core';\r\nimport { UntypedFormGroup } from '@angular/forms';\r\nimport { DynamicModuleCompileConfig } from '../../../../models/dynamicModuleCompileConfig.model';\r\nimport { BaseField, FieldTypeEnum } from '../../../../models/baseField.model';\r\nimport { Form, FormScalarTypeEnum } from '../../../../models/form.model';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { DynamicModuleFieldFixComponent } from '../../dynamic-module-field-fix/dynamic-module-field.component';\r\n// import { DynamicModuleFieldComponent } from '../../dynamic-module-field/dynamic-module-field.component';\r\n\r\n@Component({\r\n  selector: 'add-form-record',\r\n  templateUrl: './add-form-record.component.html',\r\n  styleUrls: ['./add-form-record.component.scss']\r\n})\r\nexport class AddFormRecordComponent implements OnInit {\r\n\r\n  @Input() configurations: DynamicModuleCompileConfig;\r\n\r\n  @Input() form: Form = new Form();\r\n  @Input() record: Record;\r\n  @Input() onlyView: boolean;\r\n  showTitle = true;\r\n  showSaveButton = true;\r\n  showBackButton = true;\r\n  userMode = true;\r\n\r\n  formForm: UntypedFormGroup;\r\n  fieldGroups: { [key: string]: Array<BaseField> } = {};\r\n  FormScalarTypeEnum = FormScalarTypeEnum;\r\n  FieldTypeEnum = FieldTypeEnum;\r\n\r\n  @Output() saveRecordEvent: EventEmitter<Record> = new EventEmitter<Record>();\r\n\r\n  @ViewChildren(\"fieldTemplate\") fieldTemplate: QueryList<DynamicModuleFieldFixComponent>;\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    public utilityService: UtilityHelperService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    this.showTitle = this.configurations.showTitle\r\n    this.showSaveButton = this.configurations.showSaveButton\r\n    this.showBackButton = this.configurations.showBackButton\r\n\r\n    if (this.record == null) {\r\n      this.record = new Record();\r\n    }\r\n    this.createRecordProperties();\r\n    this.reorderFormFields();\r\n    this.createFormGroup();\r\n    if (this.form.FormScalarType != FormScalarTypeEnum.Semplice) {\r\n      this.createFieldGroups();\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato al cambio del valore di ogni proprietà dell'oggetto record.\r\n   * Serve ad aggiornare il valore di tutti i campi che hanno una formula.\r\n   */\r\n  onRecordChange() {\r\n    if (this.fieldTemplate && this.fieldTemplate.length > 0) {\r\n      this.fieldTemplate.forEach(f => f.updateField());\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per salvare i dati inseriti dall'utente una volta conclusa la compilazione della form.\r\n   */\r\n  saveOrExitForm(exit: boolean) {\r\n    if (exit) {\r\n      this.saveRecordEvent.emit(null);\r\n    } else {      \r\n      this.saveRecordEvent.emit(this.record);\r\n\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per creare nell'oggetto Record le proprietà mancanti rispetto ai campi che compongono la form.\r\n   */\r\n  private createRecordProperties() {    \r\n    const recordProperties: Array<string> = Object.keys(this.record);\r\n    this.form.Fields.forEach(field => {\r\n      if (!recordProperties.find(p => p === field.Name)) {\r\n        this.record[field.Name] = null;\r\n      }\r\n    });\r\n    if (this.form.InnerForms && this.form.InnerForms.length > 0) {\r\n      this.form.InnerForms.forEach(form => {\r\n        const arrayName: string = form.Name.split(\" \").join(\"_\");\r\n        if (!recordProperties.find(p => p === arrayName)) {\r\n          this.record[arrayName] = [];\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per riordinare i campi che compongono la form.\r\n   */\r\n  private reorderFormFields() {\r\n    if (this.form.Fields && this.form.Fields.length > 0) {\r\n      this.form.Fields.sort((a, b) => (a.OrdinalPosition > b.OrdinalPosition) ? 1 : ((b.OrdinalPosition > a.OrdinalPosition) ? -1 : 0));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per creare il FormGroup che rappresenta la form.\r\n   */\r\n  private createFormGroup() {\r\n    this.formForm = this.utilityService.CreateFormFormGroup(this.form.Fields, this.record, this.onlyView);\r\n  }\r\n\r\n  /**\r\n   * Metodo per creare i gruppi in cui raggruppare i campi della form in base \r\n   * a come è stata configurata dall'utente.\r\n   */\r\n  private createFieldGroups() {\r\n    this.form.FormFieldsGroups\r\n      .sort((a, b) => (a.OrdinalPosition > b.OrdinalPosition) ? 1 : ((b.OrdinalPosition > a.OrdinalPosition) ? -1 : 0))\r\n      .map(g => g.Name)\r\n      .forEach(groupName => {\r\n        this.fieldGroups[groupName] = this.form.Fields.filter(f => f.FieldGroup == groupName);\r\n      });\r\n  }\r\n}\r\n","<div class=\"row eqp-dynamic-module-title\" *ngIf=\"showTitle\">\r\n    <div class=\"col-md-12\">\r\n        <h4><b>{{form.Name}}</b></h4>\r\n    </div>\r\n</div>\r\n\r\n<form [formGroup]=\"formForm\">\r\n\r\n    <!-- VISUALIZZAZIONE SEMPLICE -->\r\n    <ng-container *ngIf=\"form.FormScalarType == FormScalarTypeEnum.Semplice\" \r\n        [ngTemplateOutlet]=\"fieldTemplates\"\r\n        [ngTemplateOutletContext]=\"{ fields: form.Fields }\">\r\n    </ng-container>\r\n\r\n    <!-- VISUALIZZAZIONE A STEPPER -->\r\n    <mat-horizontal-stepper linear *ngIf=\"form.FormScalarType == FormScalarTypeEnum['A step']\">\r\n        <mat-step *ngFor=\"let group of form.FormFieldsGroups\">\r\n            <ng-template matStepLabel>\r\n                {{group.Name}}\r\n            </ng-template>\r\n\r\n            <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n                [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n            </ng-container>\r\n        </mat-step>\r\n    </mat-horizontal-stepper>\r\n\r\n    <!-- VISUALIZZAZIONE A TAB -->\r\n    <mat-tab-group *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In tab']\">\r\n        <mat-tab *ngFor=\"let group of form.FormFieldsGroups\" [label]=\"group.Name\">\r\n            <div class=\"mt-3\">\r\n                <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n                    [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n                </ng-container>\r\n            </div>\r\n        </mat-tab>\r\n    </mat-tab-group>\r\n\r\n    <!-- VISUALIZZAZIONE AD ACCORDION -->\r\n    <mat-accordion multi *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In accordion']\">\r\n        <mat-expansion-panel *ngFor=\"let group of form.FormFieldsGroups\">\r\n            <mat-expansion-panel-header>\r\n                <mat-panel-title>\r\n                    {{group.Name}}\r\n                </mat-panel-title>\r\n            </mat-expansion-panel-header>\r\n\r\n            <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n                [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n            </ng-container>\r\n        </mat-expansion-panel>\r\n    </mat-accordion>\r\n</form>\r\n\r\n<div class=\"row mt-2\" *ngIf=\"showBackButton || showSaveButton\">\r\n    <div class=\"col-sm-12 text-right\">\r\n        <button class=\"mr-2\" mat-raised-button type=\"button\"\r\n            *ngIf=\"showBackButton\"\r\n            (click)=\"saveOrExitForm(true)\">\r\n            Annulla\r\n        </button>\r\n        <button class=\"mr-2\" mat-raised-button color=\"primary\"  type=\"button\"\r\n            *ngIf=\"showSaveButton\"\r\n            (click)=\"saveOrExitForm(false)\"\r\n            [disabled]=\"formForm.invalid || formForm.disabled\">\r\n            Salva\r\n        </button>\r\n    </div>\r\n</div>\r\n\r\n<!-- TEMPLATE PER LA VISUALIZZAZIONE DEI CAMPI DELLA FORM -->\r\n<ng-template #fieldTemplates let-fields='fields'>\r\n    <div class=\"row\">\r\n        <div class=\"mt-2\" \r\n            *ngFor=\"let field of fields\" \r\n            [hidden]=\"!field.InListView\" \r\n            [ngClass]=\"utilityService.getFieldSyleClass(field)\">\r\n            <dynamic-module-field-fix #fieldTemplate \r\n                [field]=\"field\" \r\n                [form]=\"form\" \r\n                [record]=\"record\"\r\n                (recordChange)=\"onRecordChange()\">\r\n            </dynamic-module-field-fix>\r\n        </div>\r\n    </div>\r\n</ng-template>"]}
|
|
270
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-form-record.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-records/add-form-record/add-form-record.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-records/add-form-record/add-form-record.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, OnInit, Output, QueryList, ViewChildren } from '@angular/core';\r\nimport { UntypedFormGroup } from '@angular/forms';\r\nimport { DynamicModuleCompileConfig } from '../../../../models/dynamicModuleCompileConfig.model';\r\nimport { BaseField, FieldTypeEnum } from '../../../../models/baseField.model';\r\nimport { Form, FormScalarTypeEnum } from '../../../../models/form.model';\r\nimport { DynRecord, Record } from '../../../../models/record.model';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { DynamicModuleFieldFixComponent } from '../../dynamic-module-field-fix/dynamic-module-field.component';\r\nimport { EndPointConfiguration, EndPointDataParams, ParamTypeEnum } from 'projects/eqp-dynamic-module/src/lib/models/endPointConfiguration.model';\r\n// import { DynamicModuleFieldComponent } from '../../dynamic-module-field/dynamic-module-field.component';\r\n\r\n@Component({\r\n  selector: \"add-form-record\",\r\n  templateUrl: \"./add-form-record.component.html\",\r\n  styleUrls: [\"./add-form-record.component.scss\"],\r\n})\r\nexport class AddFormRecordComponent implements OnInit {\r\n  @Input() configurations: DynamicModuleCompileConfig;\r\n  @Input() endPointConfiguration: EndPointConfiguration;\r\n  @Input() userID: string;\r\n\r\n  @Input() formID: string = null; // preview\r\n  @Input() form: Form = null; // preview config\r\n  @Input() record: Record | string = null; // edit\r\n  @Input() onlyView: boolean = false;\r\n\r\n  showTitle = true;\r\n  showSaveButton = true;\r\n  showBackButton = true;\r\n\r\n  formForm: UntypedFormGroup;\r\n  fieldGroups: { [key: string]: Array<BaseField> } = {};\r\n  FormScalarTypeEnum = FormScalarTypeEnum;\r\n  FieldTypeEnum = FieldTypeEnum;\r\n\r\n  @Output() saveRecordEvent: EventEmitter<Record> = new EventEmitter<Record>();\r\n  @Output() afterSaveRecordEvent: EventEmitter<Record> =\r\n    new EventEmitter<Record>();\r\n\r\n  @ViewChildren(\"fieldTemplate\")\r\n  fieldTemplate: QueryList<DynamicModuleFieldFixComponent>;\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    public utilityService: UtilityHelperService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    // add può funzionare anche come modifica e come preview\r\n    // in add abbiamo in input l'ID del Form\r\n    // in modifica abbiamo in input l'ID del Record\r\n    // in preview abbiamo in input il Form(caso configurator) o l'ID del modulo on onlyView impostato a true\r\n\r\n    console.log(\"form: \", this.form );\r\n    console.log(\"formID: \", this.formID );\r\n    console.log(\"record: \", this.record );\r\n    \r\n\r\n    this.showTitle = this.configurations.showTitle;\r\n    this.showSaveButton = this.configurations.showSaveButton;\r\n    this.showBackButton = this.configurations.showBackButton;\r\n\r\n    if(this.record == null){\r\n      this.record = new Record();\r\n      if(this.onlyView == true){\r\n        // modalità preview\r\n        if(this.form != null){\r\n          // preview per il configurator\r\n          this.fieldsConfig();\r\n        } else if(this.formID != null){\r\n          // preview per admin\r\n          this.getFormByID() // dentro chiama fieldsConfig\r\n        }\r\n      } else {\r\n        // aggiugni nuovo\r\n        this.fieldsConfig();\r\n      }\r\n    } else {\r\n      // modiiltà modifica\r\n      if (typeof this.record === \"string\") {\r\n        // allora è un ID\r\n        this.getRecordByID();\r\n      } else {\r\n        // il record viene passato come tale\r\n        // (<Record>this.record).EntID = \"3\";\r\n        // (<Record>this.record).Version;\r\n        this.getFormByIDandVersion();\r\n      }\r\n    }\r\n    \r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  fieldsConfig(){      \r\n    this.createRecordProperties();\r\n    this.reorderFormFields();\r\n    this.createFormGroup();\r\n    if (this.form.FormScalarType != FormScalarTypeEnum.Semplice) {\r\n      this.createFieldGroups();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato al cambio del valore di ogni proprietà dell'oggetto record.\r\n   * Serve ad aggiornare il valore di tutti i campi che hanno una formula.\r\n   */\r\n  onRecordChange() {\r\n    if (this.fieldTemplate && this.fieldTemplate.length > 0) {\r\n      this.fieldTemplate.forEach((f) => f.updateField());\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per salvare i dati inseriti dall'utente una volta conclusa la compilazione della form.\r\n   */\r\n  saveOrExitForm(exit: boolean) {\r\n    if (exit) {\r\n      // this.saveRecordEvent.emit(null);\r\n      this.onSaveRecord(null);\r\n    } else {\r\n      // this.saveRecordEvent.emit(this.record);\r\n      this.onSaveRecord((<Record>this.record));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per salvare il record aggiunto o modificato.\r\n   * Se è stato configurato un endPoint per il salvataggio viene effettuata una chiamata al server passando l'oggeto da salvare\r\n   * nel body della chiamata, altrimenti scatena l'evento \"saveRecord\".\r\n   * @param event Oggetto di tipo Record da salvare.\r\n   */\r\n  onSaveRecord(event: Record) {\r\n    if (\r\n      event != null &&\r\n      this.endPointConfiguration != null &&\r\n      this.endPointConfiguration.Records.SaveEndPoint\r\n    ) {\r\n      var dynRec: DynRecord = new DynRecord();\r\n      dynRec.ID = event.ID ?? null;\r\n      dynRec.EntID = this.form.ID;\r\n      dynRec.Version = this.form.Version;\r\n      dynRec.userID = this.userID;\r\n      dynRec.Values = event ?? null;\r\n      var dynamicModuleParams = [\r\n        {\r\n          ParamName: \"Record\",\r\n          ParamValue: dynRec,\r\n          ParamType: ParamTypeEnum[\"In Body\"],\r\n        },\r\n      ];\r\n      this.utilityService.RunEndPointCall(\r\n        this.endPointConfiguration.Records.SaveEndPoint,\r\n        dynamicModuleParams,\r\n        (res) => {\r\n          this.afterSaveRecordEvent.emit(event);\r\n        }\r\n      );\r\n    } else {\r\n      this.saveRecordEvent.emit(event);\r\n    }\r\n  }\r\n\r\n  getFormByID(id: string = this.formID) {\r\n    const dynamicModuleParams: Array<EndPointDataParams> =\r\n      new Array<EndPointDataParams>();\r\n    dynamicModuleParams.push({\r\n      ParamName: \"id\",\r\n      ParamValue: id,\r\n      ParamType: ParamTypeEnum[\"Query param\"],\r\n    });\r\n    this.utilityService.RunEndPointCall(\r\n      this.endPointConfiguration.Forms.GetByIDEndPoint,\r\n      dynamicModuleParams,\r\n      (res: Form) => {\r\n        this.form = res;\r\n        this.fieldsConfig();\r\n      },\r\n      (err) => {}\r\n    );\r\n  }\r\n\r\n  // ci entro solo se è stato passato il parametro \"record\" come stringa\r\n  getRecordByID() {\r\n    // preparo i dati del record\r\n    var dynamicRecordParams = [\r\n      {\r\n        ParamName: \"id\",\r\n        ParamValue: this.record,\r\n        ParamType: ParamTypeEnum[\"Query param\"],\r\n      },\r\n    ];\r\n    this.utilityService.RunEndPointCall(\r\n      this.endPointConfiguration.Records.GetByIDEndPoint,\r\n      dynamicRecordParams,\r\n      (res: DynRecord) => {\r\n        this.record = new Record();\r\n\r\n        (<Record>this.record) = JSON.parse(res.SerializedValues);\r\n        this.record.ID = res.ID;\r\n        this.record.EntID = res.EntID;\r\n        this.record.userID = res.userID;\r\n        this.record.Version = res.Version;\r\n        this.record.Values = JSON.parse(res.SerializedValues);\r\n        // this.viewMode = DynamicModuleViewModeEnum.COMPILE;\r\n        // this.loader = true;\r\n        this.getFormByIDandVersion();\r\n      }\r\n    );\r\n  }\r\n  getFormByIDandVersion() {\r\n    // preparo la versione corretta del form\r\n    var dynamicModuleParams = [\r\n      {\r\n        ParamName: \"EntID\",\r\n        ParamValue: (<Record>this.record).EntID,\r\n        ParamType: ParamTypeEnum[\"Query param\"],\r\n      },\r\n      {\r\n        ParamName: \"Version\",\r\n        ParamValue: (<Record>this.record).Version,\r\n        ParamType: ParamTypeEnum[\"Query param\"],\r\n      },\r\n    ];\r\n    console.log(\"this record\", <Record>this.record)\r\n    this.utilityService.RunEndPointCall(\r\n      this.endPointConfiguration.Forms.GetByIDAndVersionEndPoint,\r\n      dynamicModuleParams,\r\n      (res: Form) => {\r\n        this.form = res;\r\n\r\n        this.createRecordProperties();\r\n        this.reorderFormFields();\r\n        this.createFormGroup();\r\n        if (this.form.FormScalarType != FormScalarTypeEnum.Semplice) {\r\n          this.createFieldGroups();\r\n        }\r\n      }\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Metodo per creare nell'oggetto Record le proprietà mancanti rispetto ai campi che compongono la form.\r\n   */\r\n  private createRecordProperties() {\r\n    const recordProperties: Array<string> = Object.keys(this.record);\r\n    this.form.Fields.forEach((field) => {\r\n      if (!recordProperties.find((p) => p === field.Name)) {\r\n        this.record[field.Name] = null;\r\n      }\r\n    });\r\n    if (this.form.InnerForms && this.form.InnerForms.length > 0) {\r\n      this.form.InnerForms.forEach((form) => {\r\n        const arrayName: string = form.Name.split(\" \").join(\"_\");\r\n        if (!recordProperties.find((p) => p === arrayName)) {\r\n          this.record[arrayName] = [];\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per riordinare i campi che compongono la form.\r\n   */\r\n  private reorderFormFields() {\r\n    if (this.form.Fields && this.form.Fields.length > 0) {\r\n      this.form.Fields.sort((a, b) =>\r\n        a.OrdinalPosition > b.OrdinalPosition ? 1 : b.OrdinalPosition > a.OrdinalPosition ? -1 : 0 );\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per creare il FormGroup che rappresenta la form.\r\n   */\r\n  private createFormGroup() {\r\n    this.formForm = this.utilityService.CreateFormFormGroup(\r\n      this.form.Fields,\r\n      (<Record>this.record),\r\n      this.onlyView\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Metodo per creare i gruppi in cui raggruppare i campi della form in base\r\n   * a come è stata configurata dall'utente.\r\n   */\r\n  private createFieldGroups() {\r\n    this.form.FormFieldsGroups.sort((a, b) => a.OrdinalPosition > b.OrdinalPosition ? 1 : b.OrdinalPosition > a.OrdinalPosition ? -1 : 0 )\r\n      .map((g) => g.Name)\r\n      .forEach((groupName) => {\r\n        this.fieldGroups[groupName] = this.form.Fields.filter(\r\n          (f) => f.FieldGroup == groupName\r\n        );\r\n      });\r\n  }\r\n}\r\n","<div class=\"row eqp-dynamic-module-title\" *ngIf=\"showTitle\">\r\n    <div class=\"col-md-12\">\r\n        <h4><b>{{form.Name}}</b></h4>\r\n    </div>\r\n</div>\r\n\r\n<form [formGroup]=\"formForm\">\r\n\r\n    <!-- VISUALIZZAZIONE SEMPLICE -->\r\n    <ng-container *ngIf=\"form.FormScalarType == FormScalarTypeEnum.Semplice\" \r\n        [ngTemplateOutlet]=\"fieldTemplates\"\r\n        [ngTemplateOutletContext]=\"{ fields: form.Fields }\">\r\n    </ng-container>\r\n\r\n    <!-- VISUALIZZAZIONE A STEPPER -->\r\n    <mat-horizontal-stepper linear *ngIf=\"form.FormScalarType == FormScalarTypeEnum['A step']\">\r\n        <mat-step *ngFor=\"let group of form.FormFieldsGroups\">\r\n            <ng-template matStepLabel>\r\n                {{group.Name}}\r\n            </ng-template>\r\n\r\n            <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n                [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n            </ng-container>\r\n        </mat-step>\r\n    </mat-horizontal-stepper>\r\n\r\n    <!-- VISUALIZZAZIONE A TAB -->\r\n    <mat-tab-group *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In tab']\">\r\n        <mat-tab *ngFor=\"let group of form.FormFieldsGroups\" [label]=\"group.Name\">\r\n            <div class=\"mt-3\">\r\n                <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n                    [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n                </ng-container>\r\n            </div>\r\n        </mat-tab>\r\n    </mat-tab-group>\r\n\r\n    <!-- VISUALIZZAZIONE AD ACCORDION -->\r\n    <mat-accordion multi *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In accordion']\">\r\n        <mat-expansion-panel *ngFor=\"let group of form.FormFieldsGroups\">\r\n            <mat-expansion-panel-header>\r\n                <mat-panel-title>\r\n                    {{group.Name}}\r\n                </mat-panel-title>\r\n            </mat-expansion-panel-header>\r\n\r\n            <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n                [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n            </ng-container>\r\n        </mat-expansion-panel>\r\n    </mat-accordion>\r\n</form>\r\n\r\n<div class=\"row mt-2\" *ngIf=\"showBackButton || showSaveButton\">\r\n    <div class=\"col-sm-12 text-right\">\r\n        <button class=\"mr-2\" mat-raised-button type=\"button\"\r\n            *ngIf=\"showBackButton\"\r\n            (click)=\"saveOrExitForm(true)\">\r\n            Annulla\r\n        </button>\r\n        <button class=\"mr-2\" mat-raised-button color=\"primary\"  type=\"button\"\r\n            *ngIf=\"showSaveButton\"\r\n            (click)=\"saveOrExitForm(false)\"\r\n            [disabled]=\"formForm.invalid || formForm.disabled\">\r\n            Salva\r\n        </button>\r\n    </div>\r\n</div>\r\n\r\n<!-- TEMPLATE PER LA VISUALIZZAZIONE DEI CAMPI DELLA FORM -->\r\n<ng-template #fieldTemplates let-fields='fields'>\r\n    <div class=\"row\">\r\n        <div class=\"mt-2\" \r\n            *ngFor=\"let field of fields\" \r\n            [hidden]=\"!field.InListView\" \r\n            [ngClass]=\"utilityService.getFieldSyleClass(field)\">\r\n            <dynamic-module-field-fix #fieldTemplate \r\n                [field]=\"field\" \r\n                [form]=\"form\" \r\n                [record]=\"record\"\r\n                (recordChange)=\"onRecordChange()\">\r\n            </dynamic-module-field-fix>\r\n        </div>\r\n    </div>\r\n</ng-template>"]}
|