@eqproject/eqp-dynamic-module 2.2.2 → 2.2.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/esm2020/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.mjs +62 -14
- package/esm2020/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.mjs +8 -8
- package/esm2020/lib/components/private/add-form-field/add-form-field.component.mjs +9 -9
- 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 +5 -5
- package/esm2020/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.mjs +6 -6
- package/esm2020/lib/components/private/field-templates/text-field-template/text-field-template.component.mjs +6 -6
- package/esm2020/lib/components/private/field-templates/textarea-field-template/textarea-field-template.component.mjs +6 -6
- package/esm2020/lib/components/private/form-records/add-form-record/add-form-record.component.mjs +98 -4
- package/esm2020/lib/components/private/form-records/list-form-record/list-form-record.component.mjs +8 -49
- package/esm2020/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.mjs +90 -46
- package/esm2020/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.mjs +54 -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 +119 -71
- package/esm2020/lib/components/private/spinner/spinner.component.mjs +4 -4
- package/esm2020/lib/eqp-dynamic-module.module.mjs +10 -7
- 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 +4 -4
- package/esm2020/lib/services/voice-recognition.service.mjs +4 -4
- package/fesm2015/eqproject-eqp-dynamic-module.mjs +563 -319
- package/fesm2015/eqproject-eqp-dynamic-module.mjs.map +1 -1
- package/fesm2020/eqproject-eqp-dynamic-module.mjs +563 -319
- package/fesm2020/eqproject-eqp-dynamic-module.mjs.map +1 -1
- package/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.d.ts +6 -7
- package/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.d.ts +1 -1
- package/lib/components/private/add-form-field/add-form-field.component.d.ts +1 -1
- package/lib/components/private/add-formula-field/add-formula-field.component.d.ts +2 -2
- package/lib/components/private/dynamic-module-field/dynamic-module-field.component.d.ts +1 -1
- package/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.d.ts +1 -1
- package/lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.d.ts +1 -1
- package/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.d.ts +1 -1
- package/lib/components/private/field-templates/date-field-template/date-field-template.component.d.ts +1 -1
- package/lib/components/private/field-templates/image-field-template/image-field-template.component.d.ts +1 -1
- package/lib/components/private/field-templates/list-value-field-template/list-value-field-template.component.d.ts +1 -1
- package/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.d.ts +1 -1
- package/lib/components/private/field-templates/text-field-template/text-field-template.component.d.ts +1 -1
- package/lib/components/private/field-templates/textarea-field-template/textarea-field-template.component.d.ts +1 -1
- package/lib/components/private/form-records/add-form-record/add-form-record.component.d.ts +10 -1
- package/lib/components/private/form-records/list-form-record/list-form-record.component.d.ts +4 -6
- package/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.d.ts +16 -5
- package/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.d.ts +32 -0
- package/lib/components/private/form-records/repair-form-fields/repair-form-fields.component.d.ts +1 -1
- package/lib/components/private/form-records/view-form-record/view-form-record.component.d.ts +9 -3
- package/lib/components/private/spinner/spinner.component.d.ts +1 -1
- package/lib/eqp-dynamic-module.module.d.ts +11 -10
- 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
|
@@ -2,6 +2,7 @@ import { Component, EventEmitter, Input, Output, ViewChildren } from '@angular/c
|
|
|
2
2
|
import { FieldTypeEnum } from '../../../../models/baseField.model';
|
|
3
3
|
import { FormScalarTypeEnum } from '../../../../models/form.model';
|
|
4
4
|
import { DynRecord, Record } from '../../../../models/record.model';
|
|
5
|
+
import { UtilityHelperService } from '../../../../services/utilityHelper.services';
|
|
5
6
|
import { ParamTypeEnum } from './../../../../models/endPointConfiguration.model';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "../../../../services/utilityHelper.services";
|
|
@@ -30,6 +31,7 @@ export class AddFormRecordComponent {
|
|
|
30
31
|
this.FieldTypeEnum = FieldTypeEnum;
|
|
31
32
|
this.saveRecordEvent = new EventEmitter();
|
|
32
33
|
this.afterSaveRecordEvent = new EventEmitter();
|
|
34
|
+
this.debugMode = true;
|
|
33
35
|
}
|
|
34
36
|
ngOnInit() {
|
|
35
37
|
// add può funzionare anche come modifica e come preview
|
|
@@ -117,6 +119,7 @@ export class AddFormRecordComponent {
|
|
|
117
119
|
dynRec.Version = this.form.Version;
|
|
118
120
|
dynRec.userID = this.userID;
|
|
119
121
|
dynRec.Values = event ?? null;
|
|
122
|
+
dynRec.HTMLreadableValues = this.createHTMLreadableValues(event);
|
|
120
123
|
var dynamicModuleParams = [
|
|
121
124
|
{
|
|
122
125
|
ParamName: "Record",
|
|
@@ -246,10 +249,101 @@ export class AddFormRecordComponent {
|
|
|
246
249
|
this.fieldGroups[groupName] = this.form.Fields.filter((f) => f.FieldGroup == groupName);
|
|
247
250
|
});
|
|
248
251
|
}
|
|
252
|
+
/**
|
|
253
|
+
* Metodo per creare il FormGroup che rappresenta la form.
|
|
254
|
+
*/
|
|
255
|
+
createHTMLreadableValues(record) {
|
|
256
|
+
this.debugLog("record", record);
|
|
257
|
+
this.debugLog("form", this.form);
|
|
258
|
+
let outputValuesArray = this.getResponseValues(record, this.form);
|
|
259
|
+
this.debugLog("outputValuesArray", outputValuesArray);
|
|
260
|
+
let template = this.getResponseTemplate(this.form); // oggetto nel quale viene costruito il template o che prende il valore da un template esterno
|
|
261
|
+
this.debugLog("template", template);
|
|
262
|
+
const regex = /##([\w]+)##/g;
|
|
263
|
+
return this.replaceTemplatePlaceholdersWithValues(template, outputValuesArray, regex); // oggetto che conterrà l'output elaborato
|
|
264
|
+
}
|
|
265
|
+
getResponseValues(record, form) {
|
|
266
|
+
let outputValuesArray = []; // array con i valori delle risposte
|
|
267
|
+
//(<DynRecord>this.record).Values è la lista di oggetti {fieldName: valore}
|
|
268
|
+
this.debugLog("(record).Values", record);
|
|
269
|
+
for (let fieldName in record) {
|
|
270
|
+
try {
|
|
271
|
+
// fieldName è il nome del campo
|
|
272
|
+
// PREPARO VARIABILI VALORI CORRETTI
|
|
273
|
+
let foundObject = form.Fields.find((obj) => obj.Name === fieldName);
|
|
274
|
+
this.debugLog("fieldName", fieldName);
|
|
275
|
+
this.debugLog("foundObject", foundObject);
|
|
276
|
+
// gestire caso fieldtype 8 [elenco generico]
|
|
277
|
+
// fare un eval per popolare i valuePairs se è presente una formula
|
|
278
|
+
// prendere la label corretta
|
|
279
|
+
////////////////////////////////////////////////////////////////////////////////
|
|
280
|
+
if (foundObject.FieldType == FieldTypeEnum["Elenco generico"]) {
|
|
281
|
+
if (foundObject.Formula) {
|
|
282
|
+
// aggiungo a valuepairs i valori calcolati
|
|
283
|
+
// (<ListValueField>foundObject).ValuePairs = {};
|
|
284
|
+
var temp = UtilityHelperService.EvaluateFieldFormula(foundObject.Formula, record, null);
|
|
285
|
+
this.debugLog("temp", temp);
|
|
286
|
+
for (let key2 in temp) {
|
|
287
|
+
if (UtilityHelperService.isNumeric(temp[key2])) {
|
|
288
|
+
foundObject.ValuePairs[Number(key2)] = temp[key2];
|
|
289
|
+
}
|
|
290
|
+
else {
|
|
291
|
+
foundObject.ValuePairs[key2] = temp[key2];
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
this.debugLog("(record).Values[fieldName]", record[fieldName]);
|
|
295
|
+
this.debugLog("(<ListValueField>foundObject).ValuePairs[record[fieldName]]", foundObject.ValuePairs[record[fieldName]]);
|
|
296
|
+
outputValuesArray[fieldName] = foundObject.ValuePairs[record[fieldName]];
|
|
297
|
+
}
|
|
298
|
+
let inverted = {};
|
|
299
|
+
this.debugLog("(<ListValueField>foundObject).ValuePairs", foundObject.ValuePairs);
|
|
300
|
+
for (let key in foundObject.ValuePairs) {
|
|
301
|
+
inverted[foundObject.ValuePairs[key]] = key;
|
|
302
|
+
}
|
|
303
|
+
foundObject.ValuePairs = inverted;
|
|
304
|
+
outputValuesArray[fieldName] = foundObject.ValuePairs[record[fieldName]];
|
|
305
|
+
}
|
|
306
|
+
else {
|
|
307
|
+
this.debugLog("record[fieldName]", record[fieldName]);
|
|
308
|
+
outputValuesArray[fieldName] = record[fieldName];
|
|
309
|
+
}
|
|
310
|
+
////////////////////////////////////////////////////////////////////////////////
|
|
311
|
+
}
|
|
312
|
+
catch (e) {
|
|
313
|
+
console.error(e);
|
|
314
|
+
}
|
|
315
|
+
}
|
|
316
|
+
this.debugLog("outputValuesArray 1", outputValuesArray);
|
|
317
|
+
// cancello i valori indefiniti o nulli
|
|
318
|
+
for (const chiave in outputValuesArray) {
|
|
319
|
+
if (outputValuesArray[chiave] == undefined || outputValuesArray[chiave] == null)
|
|
320
|
+
outputValuesArray[chiave] = '';
|
|
321
|
+
}
|
|
322
|
+
return outputValuesArray;
|
|
323
|
+
}
|
|
324
|
+
getResponseTemplate(form) {
|
|
325
|
+
let template = "";
|
|
326
|
+
// PREPARO O PRENDO LA STRUTTURA DA STAMPARE
|
|
327
|
+
form.Fields.forEach((baseField) => {
|
|
328
|
+
template += '<span style="' + baseField.LabelstyleCSS + '">' + baseField.Description + ':</span> <span style="' + baseField.FieldstyleCSS + '"> ##' + baseField.Name + '##</span> \n <br> ';
|
|
329
|
+
});
|
|
330
|
+
// (attualmente non esiste il concetto di tempate di output)
|
|
331
|
+
return template;
|
|
332
|
+
}
|
|
333
|
+
replaceTemplatePlaceholdersWithValues(template, outputValuesArray, regex) {
|
|
334
|
+
return template.replace(regex, (match, group) => {
|
|
335
|
+
return outputValuesArray[group];
|
|
336
|
+
});
|
|
337
|
+
}
|
|
338
|
+
debugLog(message, item) {
|
|
339
|
+
if (this.debugMode) {
|
|
340
|
+
console.log(message, item);
|
|
341
|
+
}
|
|
342
|
+
}
|
|
249
343
|
}
|
|
250
|
-
AddFormRecordComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
251
|
-
AddFormRecordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
252
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
344
|
+
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 });
|
|
345
|
+
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: "<ng-container *ngIf=\"loader\">\r\n\r\n <div class=\"row eqp-dynamic-module-title add-form-record-header\" *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\" class=\"add-form-record-form\">\r\n\r\n <!-- VISUALIZZAZIONE SEMPLICE -->\r\n <ng-container *ngIf=\"form.FormScalarType == FormScalarTypeEnum.Semplice\" [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: form.Fields }\" class=\"add-form-record-semplice\">\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 class=\"add-form-record-stepper\">\r\n <mat-step *ngFor=\"let group of form.FormFieldsGroups; let i = index; let first = first; let last = last\">\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\r\n <div class=\"mt-2 d-flex justify-content-end add-form-record-buttons\">\r\n <button *ngIf=\"!first\" class=\"mr-2 previous\" mat-raised-button matStepperPrevious>\r\n Precedente\r\n </button>\r\n <button *ngIf=\"!last\" class=\"button-next\" color=\"primary\" mat-raised-button matStepperNext>\r\n Successivo\r\n </button>\r\n <button *ngIf=\"last && showSaveButton\" (click)=\"saveOrExitForm(false)\" class=\"button-next\"\r\n color=\"primary\" mat-raised-button>\r\n Salva\r\n </button>\r\n </div>\r\n\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']\" class=\"add-form-record-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 class=\"add-form-record-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 add-form-record-buttons\"\r\n *ngIf=\"(showBackButton || showSaveButton) && form.FormScalarType != FormScalarTypeEnum['A step']\">\r\n <div class=\"col-sm-12 text-right\">\r\n <button class=\"mr-2\" mat-raised-button type=\"button\" *ngIf=\"showBackButton\" (click)=\"saveOrExitForm(true)\">\r\n Annulla\r\n </button>\r\n <button class=\"mr-2\" mat-raised-button color=\"primary\" type=\"button\" *ngIf=\"showSaveButton\"\r\n (click)=\"saveOrExitForm(false)\" [disabled]=\"formForm.invalid || formForm.disabled\">\r\n Salva\r\n </button>\r\n </div>\r\n </div>\r\n\r\n</ng-container>\r\n\r\n\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\" *ngFor=\"let field of fields\" [hidden]=\"!field.InListView\"\r\n [ngClass]=\"utilityService.getFieldSyleClass(field)\">\r\n <dynamic-module-field-fix #fieldTemplate [field]=\"field\" [form]=\"form\" [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: "directive", type: i3.MatStepperNext, selector: "button[matStepperNext]", inputs: ["type"] }, { kind: "directive", type: i3.MatStepperPrevious, selector: "button[matStepperPrevious]", inputs: ["type"] }, { 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"] }] });
|
|
346
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: AddFormRecordComponent, decorators: [{
|
|
253
347
|
type: Component,
|
|
254
348
|
args: [{ selector: "add-form-record", template: "<ng-container *ngIf=\"loader\">\r\n\r\n <div class=\"row eqp-dynamic-module-title add-form-record-header\" *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\" class=\"add-form-record-form\">\r\n\r\n <!-- VISUALIZZAZIONE SEMPLICE -->\r\n <ng-container *ngIf=\"form.FormScalarType == FormScalarTypeEnum.Semplice\" [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: form.Fields }\" class=\"add-form-record-semplice\">\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 class=\"add-form-record-stepper\">\r\n <mat-step *ngFor=\"let group of form.FormFieldsGroups; let i = index; let first = first; let last = last\">\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\r\n <div class=\"mt-2 d-flex justify-content-end add-form-record-buttons\">\r\n <button *ngIf=\"!first\" class=\"mr-2 previous\" mat-raised-button matStepperPrevious>\r\n Precedente\r\n </button>\r\n <button *ngIf=\"!last\" class=\"button-next\" color=\"primary\" mat-raised-button matStepperNext>\r\n Successivo\r\n </button>\r\n <button *ngIf=\"last && showSaveButton\" (click)=\"saveOrExitForm(false)\" class=\"button-next\"\r\n color=\"primary\" mat-raised-button>\r\n Salva\r\n </button>\r\n </div>\r\n\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']\" class=\"add-form-record-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 class=\"add-form-record-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 add-form-record-buttons\"\r\n *ngIf=\"(showBackButton || showSaveButton) && form.FormScalarType != FormScalarTypeEnum['A step']\">\r\n <div class=\"col-sm-12 text-right\">\r\n <button class=\"mr-2\" mat-raised-button type=\"button\" *ngIf=\"showBackButton\" (click)=\"saveOrExitForm(true)\">\r\n Annulla\r\n </button>\r\n <button class=\"mr-2\" mat-raised-button color=\"primary\" type=\"button\" *ngIf=\"showSaveButton\"\r\n (click)=\"saveOrExitForm(false)\" [disabled]=\"formForm.invalid || formForm.disabled\">\r\n Salva\r\n </button>\r\n </div>\r\n </div>\r\n\r\n</ng-container>\r\n\r\n\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\" *ngFor=\"let field of fields\" [hidden]=\"!field.InListView\"\r\n [ngClass]=\"utilityService.getFieldSyleClass(field)\">\r\n <dynamic-module-field-fix #fieldTemplate [field]=\"field\" [form]=\"form\" [record]=\"record\"\r\n (recordChange)=\"onRecordChange()\">\r\n </dynamic-module-field-fix>\r\n </div>\r\n </div>\r\n</ng-template>" }]
|
|
255
349
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.UtilityHelperService }]; }, propDecorators: { configurations: [{
|
|
@@ -274,4 +368,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
274
368
|
type: ViewChildren,
|
|
275
369
|
args: ["fieldTemplate"]
|
|
276
370
|
}] } });
|
|
277
|
-
//# 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 './../../../../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  loader: boolean = false;\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    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.previewOrNewResponseRecord();\r\n    } else {\r\n      this.editResponseRecord();\r\n    }\r\n\r\n    // l'inizializzazione termina con il recupero del record o con l'inizializzazione del form vuoto\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  previewOrNewResponseRecord(){    \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  }\r\n  editResponseRecord(){\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  /**\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        this.loader = true;\r\n      }\r\n    );\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    this.loader = true;\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","<ng-container *ngIf=\"loader\">\r\n\r\n    <div class=\"row eqp-dynamic-module-title add-form-record-header\" *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\" class=\"add-form-record-form\">\r\n\r\n        <!-- VISUALIZZAZIONE SEMPLICE -->\r\n        <ng-container *ngIf=\"form.FormScalarType == FormScalarTypeEnum.Semplice\" [ngTemplateOutlet]=\"fieldTemplates\"\r\n            [ngTemplateOutletContext]=\"{ fields: form.Fields }\" class=\"add-form-record-semplice\">\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            class=\"add-form-record-stepper\">\r\n            <mat-step *ngFor=\"let group of form.FormFieldsGroups; let i = index; let first = first; let last = last\">\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\r\n                <div class=\"mt-2 d-flex justify-content-end add-form-record-buttons\">\r\n                    <button *ngIf=\"!first\" class=\"mr-2 previous\" mat-raised-button matStepperPrevious>\r\n                        Precedente\r\n                    </button>\r\n                    <button *ngIf=\"!last\" class=\"button-next\" color=\"primary\" mat-raised-button matStepperNext>\r\n                        Successivo\r\n                    </button>\r\n                    <button *ngIf=\"last && showSaveButton\" (click)=\"saveOrExitForm(false)\" class=\"button-next\"\r\n                        color=\"primary\" mat-raised-button>\r\n                        Salva\r\n                    </button>\r\n                </div>\r\n\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']\" class=\"add-form-record-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            class=\"add-form-record-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 add-form-record-buttons\"\r\n        *ngIf=\"(showBackButton || showSaveButton) && form.FormScalarType != FormScalarTypeEnum['A step']\">\r\n        <div class=\"col-sm-12 text-right\">\r\n            <button class=\"mr-2\" mat-raised-button type=\"button\" *ngIf=\"showBackButton\" (click)=\"saveOrExitForm(true)\">\r\n                Annulla\r\n            </button>\r\n            <button class=\"mr-2\" mat-raised-button color=\"primary\" type=\"button\" *ngIf=\"showSaveButton\"\r\n                (click)=\"saveOrExitForm(false)\" [disabled]=\"formForm.invalid || formForm.disabled\">\r\n                Salva\r\n            </button>\r\n        </div>\r\n    </div>\r\n\r\n</ng-container>\r\n\r\n\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\" *ngFor=\"let field of fields\" [hidden]=\"!field.InListView\"\r\n            [ngClass]=\"utilityService.getFieldSyleClass(field)\">\r\n            <dynamic-module-field-fix #fieldTemplate [field]=\"field\" [form]=\"form\" [record]=\"record\"\r\n                (recordChange)=\"onRecordChange()\">\r\n            </dynamic-module-field-fix>\r\n        </div>\r\n    </div>\r\n</ng-template>"]}
|
|
371
|
+
//# 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 './../../../../models/endPointConfiguration.model';\r\nimport { ListValueField } from 'projects/eqp-dynamic-module/src/lib/models/fields/listValueField.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  loader: boolean = false;\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    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.previewOrNewResponseRecord();\r\n    } else {\r\n      this.editResponseRecord();\r\n    }\r\n\r\n    // l'inizializzazione termina con il recupero del record o con l'inizializzazione del form vuoto\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  previewOrNewResponseRecord(){    \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  }\r\n  editResponseRecord(){\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  /**\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      dynRec.HTMLreadableValues = this.createHTMLreadableValues(event);\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        this.loader = true;\r\n      }\r\n    );\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    this.loader = true;\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\r\n\r\n\r\n\r\n\r\n  debugMode = true;\r\n\r\n  /**\r\n   * Metodo per creare il FormGroup che rappresenta la form.\r\n   */\r\n  private createHTMLreadableValues(record:Record) {\r\n    this.debugLog(\"record\", record);\r\n    this.debugLog(\"form\", this.form);\r\n    let outputValuesArray: Array<any> = this.getResponseValues(record, this.form);\r\n    this.debugLog(\"outputValuesArray\", outputValuesArray);\r\n    \r\n    let template: string = this.getResponseTemplate(this.form); // oggetto nel quale viene costruito il template o che prende il valore da un template esterno\r\n    this.debugLog(\"template\", template);\r\n\r\n    const regex = /##([\\w]+)##/g;\r\n    return this.replaceTemplatePlaceholdersWithValues(template, outputValuesArray, regex); // oggetto che conterrà l'output elaborato    \r\n\r\n  }\r\n\r\n  private getResponseValues(record: Record, form: Form ): Array<any> {\r\n    let outputValuesArray: Array<any> = []; // array con i valori delle risposte\r\n    //(<DynRecord>this.record).Values è la lista di oggetti {fieldName: valore}\r\n    this.debugLog(\"(record).Values\", record);\r\n    for (let fieldName in record) {\r\n      try {\r\n        // fieldName è il nome del campo\r\n        // PREPARO VARIABILI VALORI CORRETTI\r\n        let foundObject = form.Fields.find(\r\n          (obj) => obj.Name === fieldName\r\n        );\r\n        this.debugLog(\"fieldName\", fieldName);\r\n        this.debugLog(\"foundObject\", foundObject);\r\n        // gestire caso fieldtype 8 [elenco generico]\r\n        // fare un eval per popolare i valuePairs se è presente una formula\r\n        // prendere la label corretta\r\n        ////////////////////////////////////////////////////////////////////////////////\r\n        if (foundObject.FieldType == FieldTypeEnum[\"Elenco generico\"]) \r\n        {\r\n          if (foundObject.Formula) \r\n          {\r\n            // aggiungo a valuepairs i valori calcolati\r\n            // (<ListValueField>foundObject).ValuePairs = {};\r\n            var temp = UtilityHelperService.EvaluateFieldFormula(\r\n              foundObject.Formula,\r\n              record,\r\n              null\r\n            );\r\n              this.debugLog(\"temp\", temp);\r\n              for (let key2 in temp) {\r\n              if (UtilityHelperService.isNumeric(temp[key2])) \r\n              {\r\n                (<ListValueField>foundObject).ValuePairs[Number(key2)] = temp[key2];\r\n              } else \r\n              {\r\n                (<ListValueField>foundObject).ValuePairs[key2] = temp[key2];\r\n              }\r\n            }\r\n            this.debugLog(\"(record).Values[fieldName]\", record[fieldName]);\r\n            this.debugLog(\"(<ListValueField>foundObject).ValuePairs[record[fieldName]]\", (<ListValueField>foundObject).ValuePairs[record[fieldName]]);\r\n            outputValuesArray[fieldName] = (<ListValueField>foundObject).ValuePairs[record[fieldName]];\r\n          }\r\n          let inverted = {};\r\n              this.debugLog(\"(<ListValueField>foundObject).ValuePairs\", (<ListValueField>foundObject).ValuePairs);\r\n              for (let key in (<ListValueField>foundObject).ValuePairs) \r\n          { \r\n            inverted[(<ListValueField>foundObject).ValuePairs[key]] = key; \r\n          }\r\n          (<ListValueField>foundObject).ValuePairs = inverted;\r\n          outputValuesArray[fieldName] = (<ListValueField>foundObject).ValuePairs[record[fieldName]];\r\n        } else \r\n        {\r\n          this.debugLog(\"record[fieldName]\", record[fieldName]);\r\n          outputValuesArray[fieldName] = record[fieldName];\r\n        }\r\n        ////////////////////////////////////////////////////////////////////////////////\r\n      } catch (e) {\r\n        console.error(e);\r\n      }\r\n    }\r\n    this.debugLog(\"outputValuesArray 1\", outputValuesArray);\r\n    // cancello i valori indefiniti o nulli\r\n    for(const chiave in outputValuesArray){\r\n      if(outputValuesArray[chiave] == undefined || outputValuesArray[chiave] == null)\r\n      outputValuesArray[chiave] = ''\r\n    }\r\n    return outputValuesArray;\r\n  }\r\n\r\n  private getResponseTemplate(form: Form): string {\r\n    let template: string = \"\";\r\n    // PREPARO O PRENDO LA STRUTTURA DA STAMPARE\r\n    form.Fields.forEach((baseField: BaseField) => {\r\n      template += '<span style=\"' + baseField.LabelstyleCSS + '\">' + baseField.Description + ':</span> <span style=\"' + baseField.FieldstyleCSS + '\"> ##' + baseField.Name + '##</span> \\n <br> ';\r\n    });\r\n    // (attualmente non esiste il concetto di tempate di output)\r\n    return template;\r\n  }\r\n\r\n  private replaceTemplatePlaceholdersWithValues(template: string, outputValuesArray: Array<any>, regex): string {\r\n    return template.replace(regex, (match, group) => {\r\n      return <string>outputValuesArray[group];\r\n    });\r\n  }\r\n\r\n  debugLog(message: string, item: any) {\r\n    if (this.debugMode) {\r\n      console.log(message, item);\r\n    }\r\n  }\r\n\r\n\r\n}\r\n","<ng-container *ngIf=\"loader\">\r\n\r\n    <div class=\"row eqp-dynamic-module-title add-form-record-header\" *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\" class=\"add-form-record-form\">\r\n\r\n        <!-- VISUALIZZAZIONE SEMPLICE -->\r\n        <ng-container *ngIf=\"form.FormScalarType == FormScalarTypeEnum.Semplice\" [ngTemplateOutlet]=\"fieldTemplates\"\r\n            [ngTemplateOutletContext]=\"{ fields: form.Fields }\" class=\"add-form-record-semplice\">\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            class=\"add-form-record-stepper\">\r\n            <mat-step *ngFor=\"let group of form.FormFieldsGroups; let i = index; let first = first; let last = last\">\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\r\n                <div class=\"mt-2 d-flex justify-content-end add-form-record-buttons\">\r\n                    <button *ngIf=\"!first\" class=\"mr-2 previous\" mat-raised-button matStepperPrevious>\r\n                        Precedente\r\n                    </button>\r\n                    <button *ngIf=\"!last\" class=\"button-next\" color=\"primary\" mat-raised-button matStepperNext>\r\n                        Successivo\r\n                    </button>\r\n                    <button *ngIf=\"last && showSaveButton\" (click)=\"saveOrExitForm(false)\" class=\"button-next\"\r\n                        color=\"primary\" mat-raised-button>\r\n                        Salva\r\n                    </button>\r\n                </div>\r\n\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']\" class=\"add-form-record-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            class=\"add-form-record-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 add-form-record-buttons\"\r\n        *ngIf=\"(showBackButton || showSaveButton) && form.FormScalarType != FormScalarTypeEnum['A step']\">\r\n        <div class=\"col-sm-12 text-right\">\r\n            <button class=\"mr-2\" mat-raised-button type=\"button\" *ngIf=\"showBackButton\" (click)=\"saveOrExitForm(true)\">\r\n                Annulla\r\n            </button>\r\n            <button class=\"mr-2\" mat-raised-button color=\"primary\" type=\"button\" *ngIf=\"showSaveButton\"\r\n                (click)=\"saveOrExitForm(false)\" [disabled]=\"formForm.invalid || formForm.disabled\">\r\n                Salva\r\n            </button>\r\n        </div>\r\n    </div>\r\n\r\n</ng-container>\r\n\r\n\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\" *ngFor=\"let field of fields\" [hidden]=\"!field.InListView\"\r\n            [ngClass]=\"utilityService.getFieldSyleClass(field)\">\r\n            <dynamic-module-field-fix #fieldTemplate [field]=\"field\" [form]=\"form\" [record]=\"record\"\r\n                (recordChange)=\"onRecordChange()\">\r\n            </dynamic-module-field-fix>\r\n        </div>\r\n    </div>\r\n</ng-template>"]}
|