@eqproject/eqp-dynamic-module 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (125) hide show
  1. package/README.md +24 -0
  2. package/bundles/eqproject-eqp-dynamic-module.umd.js +3117 -0
  3. package/bundles/eqproject-eqp-dynamic-module.umd.js.map +1 -0
  4. package/bundles/eqproject-eqp-dynamic-module.umd.min.js +17 -0
  5. package/bundles/eqproject-eqp-dynamic-module.umd.min.js.map +1 -0
  6. package/eqproject-eqp-dynamic-module.d.ts +5 -0
  7. package/eqproject-eqp-dynamic-module.metadata.json +1 -0
  8. package/esm2015/eqproject-eqp-dynamic-module.js +6 -0
  9. package/esm2015/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.js +65 -0
  10. package/esm2015/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.js +534 -0
  11. package/esm2015/lib/components/private/add-form-field/add-form-field.component.js +486 -0
  12. package/esm2015/lib/components/private/dynamic-module-field/dynamic-module-field.component.js +127 -0
  13. package/esm2015/lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.js +181 -0
  14. package/esm2015/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.js +56 -0
  15. package/esm2015/lib/components/private/field-templates/date-field-template/date-field-template.component.js +71 -0
  16. package/esm2015/lib/components/private/field-templates/image-field-template/image-field-template.component.js +54 -0
  17. package/esm2015/lib/components/private/field-templates/list-value-field-template/list-value-field-template.component.js +118 -0
  18. package/esm2015/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.js +63 -0
  19. package/esm2015/lib/components/private/field-templates/text-field-template/text-field-template.component.js +51 -0
  20. package/esm2015/lib/components/private/field-templates/textarea-field-template/textarea-field-template.component.js +51 -0
  21. package/esm2015/lib/components/private/form-records/add-form-record/add-form-record.component.js +126 -0
  22. package/esm2015/lib/components/private/form-records/list-form-record/list-form-record.component.js +210 -0
  23. package/esm2015/lib/eqp-dynamic-module.module.js +67 -0
  24. package/esm2015/lib/interfaces/iBaseFieldComponent.interface.js +1 -0
  25. package/esm2015/lib/interfaces/iRootObject.interface.js +1 -0
  26. package/esm2015/lib/models/baseField.model.js +36 -0
  27. package/esm2015/lib/models/baseObj.model.js +9 -0
  28. package/esm2015/lib/models/context.model.js +8 -0
  29. package/esm2015/lib/models/entity.model.js +7 -0
  30. package/esm2015/lib/models/fields/attachmentField.model.js +22 -0
  31. package/esm2015/lib/models/fields/booleanField.model.js +12 -0
  32. package/esm2015/lib/models/fields/dateField.model.js +11 -0
  33. package/esm2015/lib/models/fields/imageField.model.js +4 -0
  34. package/esm2015/lib/models/fields/listValueField.model.js +12 -0
  35. package/esm2015/lib/models/fields/lookupField.model.js +5 -0
  36. package/esm2015/lib/models/fields/numericField.model.js +5 -0
  37. package/esm2015/lib/models/fields/testareaField.model.js +4 -0
  38. package/esm2015/lib/models/fields/textField.model.js +5 -0
  39. package/esm2015/lib/models/form.model.js +24 -0
  40. package/esm2015/lib/models/record.model.js +3 -0
  41. package/esm2015/lib/modules/material.module.js +108 -0
  42. package/esm2015/lib/services/custom-form-validators.service.js +19 -0
  43. package/esm2015/lib/services/eqp-dynamic-module-dialog.service.js +104 -0
  44. package/esm2015/lib/services/utilityHelper.services.js +220 -0
  45. package/esm2015/public-api.js +37 -0
  46. package/esm5/eqproject-eqp-dynamic-module.js +6 -0
  47. package/esm5/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.js +66 -0
  48. package/esm5/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.js +546 -0
  49. package/esm5/lib/components/private/add-form-field/add-form-field.component.js +497 -0
  50. package/esm5/lib/components/private/dynamic-module-field/dynamic-module-field.component.js +128 -0
  51. package/esm5/lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.js +184 -0
  52. package/esm5/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.js +57 -0
  53. package/esm5/lib/components/private/field-templates/date-field-template/date-field-template.component.js +72 -0
  54. package/esm5/lib/components/private/field-templates/image-field-template/image-field-template.component.js +55 -0
  55. package/esm5/lib/components/private/field-templates/list-value-field-template/list-value-field-template.component.js +121 -0
  56. package/esm5/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.js +64 -0
  57. package/esm5/lib/components/private/field-templates/text-field-template/text-field-template.component.js +52 -0
  58. package/esm5/lib/components/private/field-templates/textarea-field-template/textarea-field-template.component.js +52 -0
  59. package/esm5/lib/components/private/form-records/add-form-record/add-form-record.component.js +129 -0
  60. package/esm5/lib/components/private/form-records/list-form-record/list-form-record.component.js +216 -0
  61. package/esm5/lib/eqp-dynamic-module.module.js +70 -0
  62. package/esm5/lib/interfaces/iBaseFieldComponent.interface.js +1 -0
  63. package/esm5/lib/interfaces/iRootObject.interface.js +1 -0
  64. package/esm5/lib/models/baseField.model.js +43 -0
  65. package/esm5/lib/models/baseObj.model.js +13 -0
  66. package/esm5/lib/models/context.model.js +14 -0
  67. package/esm5/lib/models/entity.model.js +14 -0
  68. package/esm5/lib/models/fields/attachmentField.model.js +29 -0
  69. package/esm5/lib/models/fields/booleanField.model.js +19 -0
  70. package/esm5/lib/models/fields/dateField.model.js +18 -0
  71. package/esm5/lib/models/fields/imageField.model.js +11 -0
  72. package/esm5/lib/models/fields/listValueField.model.js +19 -0
  73. package/esm5/lib/models/fields/lookupField.model.js +12 -0
  74. package/esm5/lib/models/fields/numericField.model.js +12 -0
  75. package/esm5/lib/models/fields/testareaField.model.js +11 -0
  76. package/esm5/lib/models/fields/textField.model.js +12 -0
  77. package/esm5/lib/models/form.model.js +39 -0
  78. package/esm5/lib/models/record.model.js +7 -0
  79. package/esm5/lib/modules/material.module.js +111 -0
  80. package/esm5/lib/services/custom-form-validators.service.js +23 -0
  81. package/esm5/lib/services/eqp-dynamic-module-dialog.service.js +113 -0
  82. package/esm5/lib/services/utilityHelper.services.js +225 -0
  83. package/esm5/public-api.js +37 -0
  84. package/fesm2015/eqproject-eqp-dynamic-module.js +2757 -0
  85. package/fesm2015/eqproject-eqp-dynamic-module.js.map +1 -0
  86. package/fesm5/eqproject-eqp-dynamic-module.js +2902 -0
  87. package/fesm5/eqproject-eqp-dynamic-module.js.map +1 -0
  88. package/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.d.ts +21 -0
  89. package/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.d.ts +186 -0
  90. package/lib/components/private/add-form-field/add-form-field.component.d.ts +160 -0
  91. package/lib/components/private/dynamic-module-field/dynamic-module-field.component.d.ts +55 -0
  92. package/lib/components/private/field-templates/attachment-field-template/attachment-field-template.component.d.ts +84 -0
  93. package/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.d.ts +21 -0
  94. package/lib/components/private/field-templates/date-field-template/date-field-template.component.d.ts +27 -0
  95. package/lib/components/private/field-templates/image-field-template/image-field-template.component.d.ts +16 -0
  96. package/lib/components/private/field-templates/list-value-field-template/list-value-field-template.component.d.ts +59 -0
  97. package/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.d.ts +26 -0
  98. package/lib/components/private/field-templates/text-field-template/text-field-template.component.d.ts +20 -0
  99. package/lib/components/private/field-templates/textarea-field-template/textarea-field-template.component.d.ts +20 -0
  100. package/lib/components/private/form-records/add-form-record/add-form-record.component.d.ts +50 -0
  101. package/lib/components/private/form-records/list-form-record/list-form-record.component.d.ts +59 -0
  102. package/lib/eqp-dynamic-module.module.d.ts +2 -0
  103. package/lib/interfaces/iBaseFieldComponent.interface.d.ts +8 -0
  104. package/lib/interfaces/iRootObject.interface.d.ts +10 -0
  105. package/lib/models/baseField.model.d.ts +56 -0
  106. package/lib/models/baseObj.model.d.ts +9 -0
  107. package/lib/models/context.model.d.ts +9 -0
  108. package/lib/models/entity.model.d.ts +10 -0
  109. package/lib/models/fields/attachmentField.model.d.ts +17 -0
  110. package/lib/models/fields/booleanField.model.d.ts +11 -0
  111. package/lib/models/fields/dateField.model.d.ts +12 -0
  112. package/lib/models/fields/imageField.model.d.ts +10 -0
  113. package/lib/models/fields/listValueField.model.d.ts +21 -0
  114. package/lib/models/fields/lookupField.model.d.ts +10 -0
  115. package/lib/models/fields/numericField.model.d.ts +9 -0
  116. package/lib/models/fields/testareaField.model.d.ts +7 -0
  117. package/lib/models/fields/textField.model.d.ts +7 -0
  118. package/lib/models/form.model.d.ts +45 -0
  119. package/lib/models/record.model.d.ts +5 -0
  120. package/lib/modules/material.module.d.ts +2 -0
  121. package/lib/services/custom-form-validators.service.d.ts +5 -0
  122. package/lib/services/eqp-dynamic-module-dialog.service.d.ts +28 -0
  123. package/lib/services/utilityHelper.services.d.ts +48 -0
  124. package/package.json +39 -0
  125. package/public-api.d.ts +35 -0
@@ -0,0 +1,546 @@
1
+ import { __decorate } from "tslib";
2
+ import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
3
+ import { FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms';
4
+ import { MatDialog, MatDialogRef } from '@angular/material/dialog';
5
+ import { CellAlignmentEnum, TypeColumn } from '@eqproject/eqp-table';
6
+ import { BaseField, FieldTypeEnum } from '../../../models/baseField.model';
7
+ import { Context } from '../../../models/context.model';
8
+ import { ActionOnRecord, Form, FormScalarTypeEnum, FormTypeEnum } from '../../../models/form.model';
9
+ import { ArrayValidators } from '../../../services/custom-form-validators.service';
10
+ import { EqpDynamicModuleDialogService } from '../../../services/eqp-dynamic-module-dialog.service';
11
+ import { UtilityHelperService } from '../../../services/utilityHelper.services';
12
+ var EqpDynamicModuleConfiguratorComponent = /** @class */ (function () {
13
+ function EqpDynamicModuleConfiguratorComponent(formBuilder, dialog) {
14
+ this.formBuilder = formBuilder;
15
+ this.dialog = dialog;
16
+ this.context = new Context();
17
+ this.form = new Form();
18
+ this.innerFormManagment = false;
19
+ this.formCompleted = false;
20
+ //#region Enumeratori usati nell'html
21
+ this.FormTypeEnum = FormTypeEnum;
22
+ this.FormScalarTypeEnum = FormScalarTypeEnum;
23
+ //#endregion
24
+ this.saveFormEvent = new EventEmitter();
25
+ }
26
+ EqpDynamicModuleConfiguratorComponent.prototype.ngOnInit = function () {
27
+ if (this.context) {
28
+ UtilityHelperService.SetContext(this.context);
29
+ }
30
+ this.configureColumns();
31
+ this.createFormForm();
32
+ };
33
+ /**
34
+ * Metodo invocato al cambio del tipo di visualizzazione della form.
35
+ * Se l'utente sceglie una visualizzazione raggruppata il metodo aggiunge al FormGroup un nuovo
36
+ * controllo per l'array dei nomi delle sezioni da creare.
37
+ */
38
+ EqpDynamicModuleConfiguratorComponent.prototype.onChangeFormScalarType = function () {
39
+ if (this.form.FormScalarType != FormScalarTypeEnum.Semplice) {
40
+ if (!this.formFormGroup.contains("FormFieldsGroups")) {
41
+ this.formFormGroup.removeControl("FormFieldsGroups");
42
+ this.formFormGroup.addControl("FormFieldsGroups", new FormControl(this.form.FormFieldsGroups, [Validators.required, ArrayValidators.minLenght(1)]));
43
+ }
44
+ }
45
+ else {
46
+ this.form.FormFieldsGroups = null;
47
+ if (this.formFormGroup.contains("FormFieldsGroups"))
48
+ this.formFormGroup.removeControl("FormFieldsGroups");
49
+ }
50
+ this.formFormGroup.updateValueAndValidity();
51
+ this.configureColumns();
52
+ };
53
+ /**
54
+ * Evento invocato al keyup nell'input per inserire i nomi delle sezioni per la visualizzazione
55
+ * raggruppata della form. Quanto l'utente preme il tasto invio viene aggiunto il nuovo nome alle
56
+ * sezioni dispobili se non ne esiste una con lo stesso nome.
57
+ * @param event Evento che rappresenta il keyup sulla tastiera.
58
+ */
59
+ EqpDynamicModuleConfiguratorComponent.prototype.onFormFieldGroupNameKeyUp = function (event) {
60
+ var _this = this;
61
+ if (event.code === 'Enter' || event.code === 'NumpadEnter') {
62
+ if (!this.form.FormFieldsGroups) {
63
+ this.form.FormFieldsGroups = new Array();
64
+ }
65
+ if (!this.form.FormFieldsGroups.find(function (n) { return n.Name == _this.formFieldGroupName; })) {
66
+ this.form.FormFieldsGroups.push({ Name: this.formFieldGroupName });
67
+ }
68
+ // Imposto il nuovo valore del FormControl per aggiornare lo stato della form.
69
+ this.formFormGroup.controls["FormFieldsGroups"].setValue(this.form.FormFieldsGroups);
70
+ this.formFieldGroupName = null;
71
+ this.setFormFieldGroupOrdinalPosition();
72
+ }
73
+ };
74
+ /**
75
+ * Metodo per rimuovere la sezione selezionata da quelle disponibili per la form.
76
+ * @param groupName Nome della sezione da eliminare.
77
+ */
78
+ EqpDynamicModuleConfiguratorComponent.prototype.onDeleteFormFieldGroupName = function (groupName) {
79
+ this.form.FormFieldsGroups.splice(this.form.FormFieldsGroups.findIndex(function (g) { return g.Name === groupName; }), 1);
80
+ // Imposto il nuovo valore del FormControl per aggiornare lo stato della form.
81
+ this.formFormGroup.controls["FormFieldsGroups"].setValue(this.form.FormFieldsGroups);
82
+ // Se esistono Field legati alla sezione che si vuole eliminare allora rompo il legame.
83
+ if (this.form.Fields.find(function (f) { return f.FieldGroup == groupName; })) {
84
+ this.form.Fields.filter(function (f) { return f.FieldGroup == groupName; }).forEach(function (f) { return f.FieldGroup = null; });
85
+ }
86
+ this.setFormFieldGroupOrdinalPosition();
87
+ };
88
+ /**
89
+ * Metodo chiamato quando si vuole aggiungere un nuovo campo o si vuole modificare uno esistente.
90
+ * Memorizza l'eventuale Field scelto one crea uno nuovo prima di aprire il dialog per modificarlo/aggiungerlo.
91
+ * @param field Oggetto BaseField da modificare. Se null ne viene creata una nuova istanza per l'aggiunta.
92
+ */
93
+ EqpDynamicModuleConfiguratorComponent.prototype.openFieldDialog = function (field) {
94
+ if (field === void 0) { field = null; }
95
+ if (field) {
96
+ this.indexSelectedField = this.form.Fields.indexOf(field);
97
+ this.selectedField = JSON.parse(JSON.stringify(field));
98
+ }
99
+ else {
100
+ this.selectedField = new BaseField();
101
+ this.indexSelectedField = null;
102
+ }
103
+ this.dialogFieldRef = this.dialog.open(this.dialogField, {
104
+ disableClose: true,
105
+ hasBackdrop: true,
106
+ width: '75%'
107
+ });
108
+ };
109
+ /**
110
+ * Metodo che salva il campo appena creato o modificato.
111
+ * Prima del salvataggio controlla se esiste un altro campo con la stessa label, in questo
112
+ * case genere un errore (i campi devono avere nomi, e quindi label, univoche - i nomi vengono
113
+ * ricavati unendo le parole che formano la label tramite "_").
114
+ * @param field Campo da salvare
115
+ */
116
+ EqpDynamicModuleConfiguratorComponent.prototype.onSaveField = function (field) {
117
+ var _this = this;
118
+ if (field) {
119
+ if (this.form.Fields
120
+ && this.form.Fields.find(function (f, i) { return f.Label === field.Label
121
+ && (_this.indexSelectedField == null ? true : _this.indexSelectedField !== i); })) {
122
+ EqpDynamicModuleDialogService.Warning('Impossibile inserire due campi con la stessa label.');
123
+ throw new Error('Impossibile inserire due campi con la stessa label.');
124
+ }
125
+ if (this.indexSelectedField != null && this.indexSelectedField >= 0) {
126
+ this.form.Fields[this.indexSelectedField] = field;
127
+ }
128
+ else {
129
+ if (!this.form.Fields) {
130
+ this.form.Fields = new Array();
131
+ }
132
+ this.form.Fields.push(field);
133
+ }
134
+ }
135
+ this.closeFieldDialog();
136
+ this.setFieldOrdinalPosition();
137
+ this.reloadFieldsTable();
138
+ };
139
+ /**
140
+ * Metodo che controlla se lo step per l'aggiunta dei campi nella form è concluso.
141
+ * @returns Se TRUE lo step viene considerato completato ed è possbile passare al successivo.
142
+ */
143
+ EqpDynamicModuleConfiguratorComponent.prototype.isFieldStepCompleted = function () {
144
+ if (!this.form.Fields) {
145
+ return false;
146
+ }
147
+ if (this.form.FormScalarType != FormScalarTypeEnum.Semplice && this.form.Fields.find(function (f) { return !f.FieldGroup; })) {
148
+ return false;
149
+ }
150
+ return this.form.Fields.length > 0;
151
+ };
152
+ /**
153
+ * Metodo per aprire il dialog di creazione/modifica delle form di dettaglio.
154
+ * Se il parametro passato è null sono in aggiunta altrimenti sono in modifica.
155
+ * @param innenrForm Form di dettaglio da modificare (se null allora vado in add).
156
+ */
157
+ EqpDynamicModuleConfiguratorComponent.prototype.openInnerFormDialog = function (innenrForm) {
158
+ if (innenrForm === void 0) { innenrForm = null; }
159
+ if (innenrForm) {
160
+ this.indexSelectedInnerForm = this.form.InnerForms.indexOf(innenrForm);
161
+ this.selectedInnerForm = JSON.parse(JSON.stringify(innenrForm));
162
+ this.selectedInnerForm.OldName = innenrForm.Name;
163
+ this.indexSelectedField = this.form.Fields.findIndex(function (f) { return f.Label === innenrForm.Name; });
164
+ }
165
+ else {
166
+ this.selectedInnerForm = new Form();
167
+ this.indexSelectedInnerForm = null;
168
+ this.indexSelectedField = null;
169
+ }
170
+ this.dialogInnerFormRef = this.dialog.open(this.dialogInnerForm, {
171
+ disableClose: true,
172
+ hasBackdrop: true,
173
+ width: '85%'
174
+ });
175
+ };
176
+ /**
177
+ * Metodo scatenato al salvataggio di una form di dettaglio.
178
+ * @param event Form creata/modificata dall'utente. Se è null allora l'utente ha abbandonato la configurazione.
179
+ */
180
+ EqpDynamicModuleConfiguratorComponent.prototype.onSaveOrExitInnerForm = function (event) {
181
+ var _this = this;
182
+ if (event != null) {
183
+ if (this.form.Name === event.Name ||
184
+ (this.form.InnerForms
185
+ && this.form.InnerForms.find(function (a, i) { return a.Name === event.Name
186
+ && (_this.indexSelectedInnerForm == null ? true : _this.indexSelectedInnerForm !== i); })) ||
187
+ (this.form.Fields
188
+ && this.indexSelectedInnerForm == null
189
+ && this.form.Fields.find(function (f, i) { return f.Label === event.Name
190
+ && (_this.indexSelectedField == null ? true : _this.indexSelectedField !== i); }))) {
191
+ EqpDynamicModuleDialogService.Warning('Impossibile inserire due form di dettaglio con lo stesso nome.');
192
+ throw new Error('Impossibile inserire due form di dettaglio con lo stesso nome.');
193
+ }
194
+ var innerFormField = new BaseField();
195
+ innerFormField.Name = event.Name.split(" ").join("_");
196
+ innerFormField.Label = event.Name;
197
+ innerFormField.FieldType = FieldTypeEnum['Form di dettaglio'];
198
+ innerFormField.FieldGroup = this.indexSelectedField != null ? this.form.Fields[this.indexSelectedField].FieldGroup : null;
199
+ if (this.indexSelectedInnerForm != null && this.indexSelectedInnerForm >= 0) {
200
+ this.form.InnerForms[this.indexSelectedInnerForm] = event;
201
+ this.form.Fields[this.indexSelectedField] = innerFormField;
202
+ }
203
+ else {
204
+ if (!this.form.InnerForms) {
205
+ this.form.InnerForms = new Array();
206
+ }
207
+ this.form.InnerForms.push(event);
208
+ this.form.Fields.push(innerFormField);
209
+ }
210
+ this.reloadFieldsTable();
211
+ }
212
+ this.dialogInnerFormRef.close();
213
+ };
214
+ /**
215
+ * Metodo per aprire il dialog di creazione/modifica delle action.
216
+ * Se il parametro passato è null sono in aggiunta altrimenti sono in modifica.
217
+ * @param action ActionOnRecord da modificare (se null allora vado in add).
218
+ */
219
+ EqpDynamicModuleConfiguratorComponent.prototype.openActionOnRecordDialog = function (action) {
220
+ if (action === void 0) { action = null; }
221
+ if (action) {
222
+ this.indexSelectedAction = this.form.ActionsOnRecord.indexOf(action);
223
+ this.selectedAction = JSON.parse(JSON.stringify(action));
224
+ }
225
+ else {
226
+ this.selectedAction = new ActionOnRecord();
227
+ this.indexSelectedAction = null;
228
+ }
229
+ this.createActionOnRecordForm();
230
+ this.dialogActionOnRecordRef = this.dialog.open(this.dialogActionOnRecord, {
231
+ disableClose: true,
232
+ hasBackdrop: true,
233
+ width: '75%'
234
+ });
235
+ };
236
+ /**
237
+ * Metodo per impostare i valori da suggerire nell'autocomplete del campo Formula.
238
+ * Viene scatenato al focus (in questo caso viene passato il parametro a null per differenziarlo
239
+ * dall'evento di click sulla tastiera) e al keyup sull'input (il parametro è diverso da null).
240
+ * @param keyboardEvent Evento scatenato al keyup sulla tastiera. Se null allora il metodo è stato invocato dal focus sull'input.
241
+ * @summary Aggiorna l'elenco dei suggerimenti per l'autocomplete se l'utente esegue il focus sull'input
242
+ * oppure al keyup sulla tastiera di un tasto diverso dalle frecce.
243
+ */
244
+ EqpDynamicModuleConfiguratorComponent.prototype.setActionAutocompleteOptions = function (keyboardEvent) {
245
+ // Creo l'array per l'autocomplete solo se sto facendo il focus sull'input o se sto premendo un tasto
246
+ // sulla tastiera diverso dalle frecce (in quest'ultimo caso, se non viene eseguito il filtro sull'evento,
247
+ // non si può selezionare un suggerimento dell'autocomplete perchè al click verrebbe ricaricato l'array e
248
+ // si prederebbe la selezione appena fatta).
249
+ if (!keyboardEvent || !keyboardEvent.code.includes("Arrow")) {
250
+ this.actionAutocompleteOptions = UtilityHelperService.GetAutocompleteOptions(this.form.Fields, this.selectedAction.Action);
251
+ }
252
+ };
253
+ /**
254
+ * Metodo per salvare l'azione creata/modificate.
255
+ */
256
+ EqpDynamicModuleConfiguratorComponent.prototype.saveActionOnRecord = function () {
257
+ var _this = this;
258
+ if (this.form.ActionsOnRecord
259
+ && this.form.ActionsOnRecord.find(function (a, i) { return a.Name === _this.selectedAction.Name
260
+ && (_this.indexSelectedAction == null ? true : _this.indexSelectedAction !== i); })) {
261
+ EqpDynamicModuleDialogService.Warning('Impossibile inserire due action con lo stesso nome.');
262
+ throw new Error('Impossibile inserire due action con lo stesso nome.');
263
+ }
264
+ if (this.indexSelectedAction != null && this.indexSelectedAction >= 0) {
265
+ this.form.ActionsOnRecord[this.indexSelectedAction] = this.selectedAction;
266
+ }
267
+ else {
268
+ if (!this.form.ActionsOnRecord) {
269
+ this.form.ActionsOnRecord = new Array();
270
+ }
271
+ this.form.ActionsOnRecord.push(this.selectedAction);
272
+ }
273
+ this.closeDialogActionOnRecord();
274
+ this.setActionOrdinalPosition();
275
+ this.reloadActionsOnRecordTable();
276
+ };
277
+ /**
278
+ * Metodo per chiudere il dialog di gestione delle action.
279
+ */
280
+ EqpDynamicModuleConfiguratorComponent.prototype.closeDialogActionOnRecord = function () {
281
+ this.dialogActionOnRecordRef.close();
282
+ };
283
+ /**
284
+ * Metodo per segnare come conclusa la creazione della form e per crearne una copia
285
+ * da visalizzare come anteprima.
286
+ * @param completed Se TRUE segna la form come conclusa e ne crea una copia da visualizzare
287
+ */
288
+ EqpDynamicModuleConfiguratorComponent.prototype.setFormStatus = function (completed) {
289
+ if (completed) {
290
+ this.formCompleted = true;
291
+ this.previewForm = JSON.parse(JSON.stringify(this.form));
292
+ // Per visualizzare correttamente l'oanteprima della form appena creata
293
+ // bisogna valorizzare la proprietà Name dei campi della form e delle InnerForms.
294
+ this.previewForm.Fields.forEach(function (field) { field.Name = field.Label.split(' ').join('_'); });
295
+ if (this.previewForm.InnerForms && this.previewForm.InnerForms.length > 0) {
296
+ this.previewForm.InnerForms.forEach(function (form) {
297
+ form.Fields.forEach(function (field) { field.Name = field.Label.split(' ').join('_'); });
298
+ });
299
+ }
300
+ }
301
+ else {
302
+ this.formCompleted = false;
303
+ this.previewForm = null;
304
+ }
305
+ };
306
+ /**
307
+ * Metodo che scatena l'evento di output per salvare la form creata alla fine del wizard
308
+ */
309
+ EqpDynamicModuleConfiguratorComponent.prototype.saveForm = function () {
310
+ this.saveFormEvent.emit(this.form);
311
+ };
312
+ /**
313
+ * Configura le colonne per le tabelle necessarie alla creazione della form:
314
+ * - per la visualizzazione dei campi inseriti
315
+ * - per le form di dettaglio create
316
+ * - per le azioni configurate sui record della form
317
+ */
318
+ EqpDynamicModuleConfiguratorComponent.prototype.configureColumns = function () {
319
+ var _this = this;
320
+ this.fieldsColumns = [
321
+ {
322
+ key: 'action', display: '', type: TypeColumn.MenuAction, buttonMenuIcon: 'more_vert', styles: { flex: '0 0 6%' },
323
+ actions: [
324
+ { name: 'Modifica', icon: 'edit', fn: function (element, index, col) { return _this.editField(element); } },
325
+ { name: 'Elimina', icon: 'delete', fn: function (element, index, col) { return _this.deleteElement(element, "Fields"); } },
326
+ {
327
+ name: 'Sposta su', icon: 'arrow_upward',
328
+ fn: function (element, index, col) { return _this.moveElement(element, true, "Fields"); },
329
+ disabled: function (element) { return _this.form.Fields.indexOf(element) === 0; }
330
+ },
331
+ {
332
+ name: 'Sposta giù', icon: 'arrow_downward',
333
+ fn: function (element, index, col) { return _this.moveElement(element, false, "Fields"); },
334
+ disabled: function (element) { return _this.form.Fields.indexOf(element) >= (_this.form.Fields.length - 1); }
335
+ },
336
+ ]
337
+ },
338
+ { key: 'FieldType', display: 'Tipologia', type: TypeColumn.Enum, enumModel: FieldTypeEnum },
339
+ { key: 'Label', display: 'Label' },
340
+ { key: 'Description', display: 'Descrizione' },
341
+ {
342
+ key: 'Required', display: 'Obbligatorio',
343
+ value: function (element) { return !!element.Required; },
344
+ type: TypeColumn.Boolean,
345
+ booleanValues: {
346
+ true: '<i class="fa fa-check success-color"></i>',
347
+ false: '<i class="fa fa-close error-color"></i>'
348
+ },
349
+ styles: { flex: '0 0 7%', cellAlignment: CellAlignmentEnum.CENTER }
350
+ },
351
+ ];
352
+ if (this.form.FormScalarType && this.form.FormScalarType != FormScalarTypeEnum.Semplice) {
353
+ this.fieldsColumns.splice(this.fieldsColumns.findIndex(function (c) { return c.key == 'Description'; }), 0, { key: 'FieldGroup', display: 'Sezione', type: TypeColumn.ExternalTemplate, externalTemplate: this.fieldSectionColumnTemplate });
354
+ }
355
+ this.actionsOnRecordColumns = [
356
+ {
357
+ key: 'action', display: '', type: TypeColumn.MenuAction, buttonMenuIcon: 'more_vert', styles: { flex: '0 0 6%' },
358
+ actions: [
359
+ { name: 'Modifica', icon: 'edit', fn: function (element, index, col) { return _this.openActionOnRecordDialog(element); } },
360
+ { name: 'Elimina', icon: 'delete', fn: function (element, index, col) { return _this.deleteElement(element, "ActionsOnRecord"); } },
361
+ {
362
+ name: 'Sposta su', icon: 'arrow_upward',
363
+ fn: function (element, index, col) { return _this.moveElement(element, true, "ActionsOnRecord"); },
364
+ disabled: function (element) { return _this.form.ActionsOnRecord.indexOf(element) === 0; }
365
+ },
366
+ {
367
+ name: 'Sposta giù', icon: 'arrow_downward',
368
+ fn: function (element, index, col) { return _this.moveElement(element, false, "ActionsOnRecord"); },
369
+ disabled: function (element) { return _this.form.ActionsOnRecord.indexOf(element) >= (_this.form.ActionsOnRecord.length - 1); }
370
+ },
371
+ ]
372
+ },
373
+ { key: 'Icon', display: 'Icona', styles: { flex: ' 0 0 15%' } },
374
+ { key: 'Name', display: 'Nome', styles: { flex: ' 0 0 20%' } },
375
+ { key: 'Action', display: 'Azione' },
376
+ ];
377
+ };
378
+ /**
379
+ * Crea il FormGroup per l'oggetto Form
380
+ */
381
+ EqpDynamicModuleConfiguratorComponent.prototype.createFormForm = function () {
382
+ this.formFormGroup = this.formBuilder.group({
383
+ Name: [this.form.Name, Validators.required],
384
+ FormScalarType: [this.form.FormScalarType, Validators.required],
385
+ });
386
+ this.onChangeFormScalarType();
387
+ };
388
+ /**
389
+ * Crea il FormGroup epr l'aggiunta o la modifica di una action sui record della Form.
390
+ */
391
+ EqpDynamicModuleConfiguratorComponent.prototype.createActionOnRecordForm = function () {
392
+ this.actionOnRecordFormGroup = this.formBuilder.group({
393
+ Name: [this.selectedAction.Name, Validators.required],
394
+ Icon: [this.selectedAction.Icon, Validators.required],
395
+ Action: [this.selectedAction.Action, Validators.required],
396
+ });
397
+ };
398
+ /**
399
+ * Chiude il dialog per aggiungere/modificare un Field senza salvare
400
+ */
401
+ EqpDynamicModuleConfiguratorComponent.prototype.closeFieldDialog = function () {
402
+ this.dialogFieldRef.close();
403
+ };
404
+ /**
405
+ * Metodo per gestire l'apertura del dialog per la modifica di un Field.
406
+ * Se il field è di tipo "Form di dettaglio" apre il dialog per la modifica di una
407
+ * InnerForm altrimenti apre quello per la modifica di un Field.
408
+ * @param field Campo da modificare
409
+ */
410
+ EqpDynamicModuleConfiguratorComponent.prototype.editField = function (field) {
411
+ if (field.FieldType != FieldTypeEnum['Form di dettaglio']) {
412
+ this.openFieldDialog(field);
413
+ }
414
+ else {
415
+ this.openInnerFormDialog(this.form.InnerForms.find(function (f) { return f.Name == field.Label; }));
416
+ }
417
+ };
418
+ /**
419
+ * Metodo per rimuovere un Field all'interno di una Form.
420
+ * Richiede conferma all'utente prima di rimuoverlo.
421
+ * @param field BaseField da rimuovere
422
+ */
423
+ EqpDynamicModuleConfiguratorComponent.prototype.deleteElement = function (element, propertyName) {
424
+ var _this = this;
425
+ EqpDynamicModuleDialogService.Confirm('Eliminare l\'elemento selezionato?', function () {
426
+ _this.form[propertyName].splice(_this.form[propertyName].indexOf(element), 1);
427
+ if (propertyName === "Fields") {
428
+ _this.setFieldOrdinalPosition();
429
+ _this.reloadFieldsTable();
430
+ }
431
+ else if (propertyName === "ActionsOnRecord") {
432
+ _this.setActionOrdinalPosition();
433
+ _this.reloadActionsOnRecordTable();
434
+ }
435
+ }, false, 'Richiesta conferma');
436
+ };
437
+ /**
438
+ * Metodo per spostare un campo all'interno della form.
439
+ * @param field Oggetto di tipo BaseField da spostare.
440
+ * @param moveUp Se TRUE allora sposta verso l'alto il campo (abbassa l'indice) altrimenti il contrario.
441
+ */
442
+ EqpDynamicModuleConfiguratorComponent.prototype.moveElement = function (element, moveUp, propertyName) {
443
+ var startingIndex = this.form[propertyName].indexOf(element);
444
+ var endingIndex = startingIndex + (moveUp ? -1 : 1);
445
+ this.form[propertyName].splice(startingIndex, 1);
446
+ this.form[propertyName].splice(endingIndex, 0, element);
447
+ if (propertyName === "Fields") {
448
+ this.setFieldOrdinalPosition();
449
+ this.reloadFieldsTable();
450
+ }
451
+ else if (propertyName === "ActionsOnRecord") {
452
+ this.setActionOrdinalPosition();
453
+ this.reloadActionsOnRecordTable();
454
+ }
455
+ };
456
+ /**
457
+ * Imposta l'ordinamento delle sezioni che compongono la form.
458
+ */
459
+ EqpDynamicModuleConfiguratorComponent.prototype.setFormFieldGroupOrdinalPosition = function () {
460
+ this.form.FormFieldsGroups.forEach(function (g, i) { return g.OrdinalPosition = i; });
461
+ };
462
+ /**
463
+ * Imposta l'ordinamento dei campi all'interno della form in base all'ordine che l'utente
464
+ * ha definito nella tabella in cui sono mostrati
465
+ */
466
+ EqpDynamicModuleConfiguratorComponent.prototype.setFieldOrdinalPosition = function () {
467
+ var _this = this;
468
+ if (this.form.Fields) {
469
+ this.form.Fields.forEach(function (field) {
470
+ field.OrdinalPosition = _this.form.Fields.indexOf(field);
471
+ });
472
+ }
473
+ };
474
+ /**
475
+ * Metodo per ricaricare i dati della tabella dei campi aggiunti in una form
476
+ */
477
+ EqpDynamicModuleConfiguratorComponent.prototype.reloadFieldsTable = function () {
478
+ if (this.fieldsTable) {
479
+ this.fieldsTable.reloadDatatable();
480
+ }
481
+ };
482
+ /**
483
+ * Imposta l'ordinamento dei campi all'interno della form in base all'ordine che l'utente
484
+ * ha definito nella tabella in cui sono mostrati
485
+ */
486
+ EqpDynamicModuleConfiguratorComponent.prototype.setActionOrdinalPosition = function () {
487
+ var _this = this;
488
+ if (this.form.ActionsOnRecord) {
489
+ this.form.ActionsOnRecord.forEach(function (action) {
490
+ action.OrdinalPosition = _this.form.ActionsOnRecord.indexOf(action);
491
+ });
492
+ }
493
+ };
494
+ /**
495
+ * Metodo per ricaricare i dati della tabella delle azioni aggiuntive sui record della Form.
496
+ */
497
+ EqpDynamicModuleConfiguratorComponent.prototype.reloadActionsOnRecordTable = function () {
498
+ if (this.actionsOnRecordTable) {
499
+ this.actionsOnRecordTable.reloadDatatable();
500
+ }
501
+ };
502
+ EqpDynamicModuleConfiguratorComponent.ctorParameters = function () { return [
503
+ { type: FormBuilder },
504
+ { type: MatDialog }
505
+ ]; };
506
+ __decorate([
507
+ Input()
508
+ ], EqpDynamicModuleConfiguratorComponent.prototype, "context", void 0);
509
+ __decorate([
510
+ Input()
511
+ ], EqpDynamicModuleConfiguratorComponent.prototype, "form", void 0);
512
+ __decorate([
513
+ Input()
514
+ ], EqpDynamicModuleConfiguratorComponent.prototype, "innerFormManagment", void 0);
515
+ __decorate([
516
+ ViewChild('fieldsTable', { static: false })
517
+ ], EqpDynamicModuleConfiguratorComponent.prototype, "fieldsTable", void 0);
518
+ __decorate([
519
+ ViewChild('dialogField', { static: true })
520
+ ], EqpDynamicModuleConfiguratorComponent.prototype, "dialogField", void 0);
521
+ __decorate([
522
+ ViewChild('fieldSectionColumnTemplate', { static: true })
523
+ ], EqpDynamicModuleConfiguratorComponent.prototype, "fieldSectionColumnTemplate", void 0);
524
+ __decorate([
525
+ ViewChild('dialogInnerForm', { static: true })
526
+ ], EqpDynamicModuleConfiguratorComponent.prototype, "dialogInnerForm", void 0);
527
+ __decorate([
528
+ ViewChild('actionsOnRecordTable', { static: false })
529
+ ], EqpDynamicModuleConfiguratorComponent.prototype, "actionsOnRecordTable", void 0);
530
+ __decorate([
531
+ ViewChild('dialogActionOnRecord', { static: true })
532
+ ], EqpDynamicModuleConfiguratorComponent.prototype, "dialogActionOnRecord", void 0);
533
+ __decorate([
534
+ Output()
535
+ ], EqpDynamicModuleConfiguratorComponent.prototype, "saveFormEvent", void 0);
536
+ EqpDynamicModuleConfiguratorComponent = __decorate([
537
+ Component({
538
+ selector: 'eqp-dynamic-module-configurator',
539
+ template: "<mat-horizontal-stepper linear #stepper>\r\n <!-- DATI GENERALI DELLA FORM -->\r\n <mat-step [stepControl]=\"formFormGroup\">\r\n <form [formGroup]=\"formFormGroup\" (keydown.enter)=\"false\">\r\n <ng-template matStepLabel>\r\n <div class=\"stepper-header-overlay\" (click)=\"setFormStatus(false)\"></div>\r\n Dati generali della form\r\n </ng-template>\r\n\r\n <div class=\"row\">\r\n <div class=\"col-md-4\">\r\n <mat-form-field>\r\n <mat-label>Nome</mat-label>\r\n <input matInput formControlName=\"Name\" [(ngModel)]=\"form.Name\" required>\r\n </mat-form-field>\r\n </div>\r\n\r\n <div class=\"col-md-4\">\r\n <eqp-select [enumData]=\"FormScalarTypeEnum\" [(ngModelInput)]=\"form.FormScalarType\"\r\n [isRequired]=\"true\" [showCancelButton]=\"false\" placeholder=\"Tipo di visualizzazione\"\r\n [formGroupInput]=\"formFormGroup\" [formControlNameInput]=\"'FormScalarType'\"\r\n (ngModelInputChange)=\"onChangeFormScalarType()\">\r\n </eqp-select>\r\n </div>\r\n </div>\r\n <div class=\"row\" *ngIf=\"form.FormScalarType && form.FormScalarType != FormScalarTypeEnum.Semplice\">\r\n <div class=\"col-md-4 d-flex align-items-center\">\r\n <mat-form-field>\r\n <mat-label> Nome sezione (invio per confermare) </mat-label>\r\n <input matInput [(ngModel)]=\"formFieldGroupName\" [ngModelOptions]=\"{standalone: true}\"\r\n (keyup)=\"onFormFieldGroupNameKeyUp($event)\">\r\n </mat-form-field>\r\n </div>\r\n <div class=\"col-md-4 d-flex align-items-center\">\r\n <span class=\"mr-3\">Sezioni inserite:</span>\r\n <ul class=\"section-list\">\r\n <li *ngFor=\"let groupName of form.FormFieldsGroups, let i=index\">\r\n <mat-icon class=\"mr-1\" (click)=\"onDeleteFormFieldGroupName(groupName.Name)\">close\r\n </mat-icon>\r\n <span> {{i+1}}) {{groupName.Name}}</span>\r\n </li>\r\n </ul>\r\n </div>\r\n </div>\r\n\r\n <div class=\"mt-2 d-flex justify-content-end\">\r\n <button mat-raised-button color=\"primary\" matStepperNext\r\n [disabled]=\"formFormGroup.invalid\">Successivo</button>\r\n </div>\r\n </form>\r\n </mat-step>\r\n\r\n <!-- AGGIUNTA DEI CAMPI DELLA FORM -->\r\n <mat-step [completed]=\"isFieldStepCompleted()\">\r\n <ng-template matStepLabel>\r\n <div class=\"stepper-header-overlay\" (click)=\"setFormStatus(false)\"></div>\r\n Campi da inserire\r\n </ng-template>\r\n\r\n <div class=\"row justify-content-end\">\r\n <button class=\"btn btn-primary\" mat-raised-button color=\"primary\" type=\"button\" (click)=\"openFieldDialog()\">\r\n <mat-icon>add</mat-icon>\r\n <span style=\"margin-left: 10px;\">Aggiungi campo</span>\r\n </button>\r\n\r\n <button class=\"btn btn-primary ml-2\" mat-raised-button color=\"primary\" type=\"button\"\r\n (click)=\"openInnerFormDialog()\" *ngIf=\"!innerFormManagment\">\r\n <mat-icon>add</mat-icon>\r\n <span style=\"margin-left: 10px;\">Aggiungi form di dettaglio</span>\r\n </button>\r\n </div>\r\n\r\n <eqp-table #fieldsTable [createMatCard]=\"false\" [columns]=\"fieldsColumns\" [data]=\"form.Fields\"\r\n [emptyTableMessage]=\"'Nessun campo inserito'\" [searchText]=\"'Cerca'\">\r\n </eqp-table>\r\n\r\n <div class=\"mt-2 d-flex justify-content-end\">\r\n <button class=\"mr-2\" mat-raised-button matStepperPrevious>Precedente</button>\r\n <button mat-raised-button color=\"primary\" matStepperNext [disabled]=\"!isFieldStepCompleted()\"\r\n (click)=\"setFormStatus(false)\">Successivo</button>\r\n </div>\r\n </mat-step>\r\n\r\n <!-- AGGIUNTA DELLE OPERAZIONI SUI RECORD -->\r\n <mat-step>\r\n <ng-template matStepLabel>\r\n <div class=\"stepper-header-overlay\" (click)=\"setFormStatus(false)\"></div>\r\n Azioni aggiuntive sui record\r\n </ng-template>\r\n\r\n <div class=\"row justify-content-end\">\r\n <button class=\"btn btn-primary\" mat-raised-button color=\"primary\" type=\"button\"\r\n (click)=\"openActionOnRecordDialog()\">\r\n <mat-icon>add</mat-icon>\r\n <span style=\"margin-left: 10px;\">Aggiungi azione</span>\r\n </button>\r\n </div>\r\n <eqp-table #actionsOnRecordTable [createMatCard]=\"false\" [columns]=\"actionsOnRecordColumns\"\r\n [data]=\"form.ActionsOnRecord\" [emptyTableMessage]=\"'Nessuna action inserita'\" [searchText]=\"'Cerca'\">\r\n </eqp-table>\r\n\r\n <div class=\"mt-2 d-flex justify-content-end\">\r\n <button class=\"mr-2\" mat-raised-button matStepperPrevious>Precedente</button>\r\n <button mat-raised-button color=\"primary\" matStepperNext (click)=\"setFormStatus(true)\">\r\n Successivo\r\n </button>\r\n </div>\r\n </mat-step>\r\n\r\n <!-- VISUALIZZAZIONE FORM CREATA -->\r\n <mat-step>\r\n <ng-template matStepLabel>\r\n <div class=\"stepper-header-overlay\"\r\n (click)=\"setFormStatus(formFormGroup.valid && form.Fields && form.Fields.length > 0)\"></div>\r\n Riepilogo\r\n </ng-template>\r\n\r\n <eqp-dynamic-module [form]=\"previewForm\" *ngIf=\"previewForm && formCompleted\" [showButtons]=\"false\"\r\n [viewMode]=\"FormTypeEnum.SCALAR\"></eqp-dynamic-module>\r\n\r\n <div class=\"mt-2 d-flex justify-content-end\">\r\n <button class=\"mr-2\" mat-raised-button matStepperPrevious (click)=\"setFormStatus(false)\">Precedente</button>\r\n <button mat-raised-button color=\"primary\" (click)=\"saveForm()\">Salva form</button>\r\n </div>\r\n </mat-step>\r\n</mat-horizontal-stepper>\r\n\r\n<div class=\"row\" *ngIf=\"innerFormManagment\">\r\n <div class=\"col-md-12 text-right\">\r\n <button mat-raised-button (click)=\"saveFormEvent.emit(null)\">Esci</button>\r\n </div>\r\n</div>\r\n\r\n<!-- DIALOG AGGIUNTA/MODIFICA CAMPO -->\r\n<ng-template #dialogField>\r\n <eqp-dynamic-module-add-form-field [field]=\"selectedField\" [indexField]=\"indexSelectedField\"\r\n (saveFieldEvent)=\"onSaveField($event)\" [availableFields]=\"form.Fields\"\r\n [formFieldsGroups]=\"form.FormScalarType != FormScalarTypeEnum.Semplice ? form.FormFieldsGroups : null\">\r\n </eqp-dynamic-module-add-form-field>\r\n</ng-template>\r\n\r\n<!-- TEMPLATE PER VISUALIZZARE LA COLONNA DELLA SEZIONE NELLA TABELLA DEI FIELDS -->\r\n<ng-template #fieldSectionColumnTemplate let-row=\"row\">\r\n <eqp-select [arrayData]=\"form.FormFieldsGroups\" [(ngModelInput)]=\"row.FieldGroup\" [arrayKeyProperty]=\"'Name'\"\r\n [arrayValueProperty]=\"'Name'\" placeholder=\"Sezione\" [isRequired]=\"true\" [includeFullObject]=\"false\">\r\n </eqp-select>\r\n</ng-template>\r\n\r\n<!-- DIALOG PER AGGIUNGERE/MODIFICARE UNA ACTION SUI RECORD DELLA FORM -->\r\n<ng-template #dialogActionOnRecord>\r\n <div class=\"container-fluid\" style=\"max-height: 70vh !important; overflow-x: hidden; overflow-y: auto;\">\r\n <form [formGroup]=\"actionOnRecordFormGroup\">\r\n <div class=\"row\">\r\n <div class=\"header-title-standard\">{{indexSelectedAction != null && indexSelectedAction >= 0 ?\r\n \"Modifica\"\r\n : \"Aggiungi\"}} azione sul record</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-sm-12 col-md-4 mt-2\">\r\n <mat-form-field>\r\n <mat-label> Nome </mat-label>\r\n <input formControlName=\"Name\" required matInput [(ngModel)]=\"selectedAction.Name\">\r\n </mat-form-field>\r\n </div>\r\n\r\n <div class=\"col-sm-12 col-md-4 mt-2\">\r\n <mat-form-field>\r\n <mat-label> Icona </mat-label>\r\n <input formControlName=\"Icon\" required matInput [(ngModel)]=\"selectedAction.Icon\">\r\n </mat-form-field>\r\n </div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-sm-12 col-md-12 mt-2\">\r\n <mat-form-field>\r\n <textarea matInput [placeholder]=\"'Azione (Javascript)'\" [rows]=\"3\" formControlName=\"Action\"\r\n required [(ngModel)]=\"selectedAction.Action\" [matAutocomplete]=\"actionAutocomplete\"\r\n (keyup)=\"setActionAutocompleteOptions($event)\"\r\n (focus)=\"setActionAutocompleteOptions(null)\"></textarea>\r\n <mat-autocomplete #actionAutocomplete=\"matAutocomplete\">\r\n <mat-option *ngFor=\"let option of actionAutocompleteOptions\" [value]=\"option.value\">\r\n {{option.label}}\r\n </mat-option>\r\n </mat-autocomplete>\r\n </mat-form-field>\r\n </div>\r\n </div>\r\n\r\n\r\n <div class=\"row mt-2 mb-1\">\r\n <div class=\"col-sm-12 text-right\">\r\n <button class=\"mr-2\" mat-raised-button color=\"primary\" (click)=\"saveActionOnRecord()\"\r\n [disabled]=\"actionOnRecordFormGroup.invalid\" type=\"button\">\r\n Salva\r\n </button>\r\n <button class=\"btn mat-raised-button\" (click)=\"closeDialogActionOnRecord()\" type=\"button\">\r\n Esci\r\n </button>\r\n </div>\r\n </div>\r\n </form>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #dialogInnerForm>\r\n <eqp-dynamic-module-configurator [form]=\"selectedInnerForm\" [innerFormManagment]=\"true\"\r\n (saveFormEvent)=\"onSaveOrExitInnerForm($event)\"></eqp-dynamic-module-configurator>\r\n</ng-template>",
540
+ styles: ["::ng-deep mat-form-field{width:100%}.stepper-header-overlay{position:absolute;top:0;left:0;width:100%;height:100%}.section-list{list-style:none;padding:0}.section-list mat-icon{vertical-align:middle;font-size:15px;height:15px;width:15px;color:var(--danger);margin-right:10px;cursor:pointer}.danger-color{color:var(--danger)}"]
541
+ })
542
+ ], EqpDynamicModuleConfiguratorComponent);
543
+ return EqpDynamicModuleConfiguratorComponent;
544
+ }());
545
+ export { EqpDynamicModuleConfiguratorComponent };
546
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eqp-dynamic-module-configurator.component.js","sourceRoot":"ng://@eqproject/eqp-dynamic-module/","sources":["lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, TemplateRef, ViewChild } from '@angular/core';\r\nimport { FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms';\r\nimport { MatDialog, MatDialogRef } from '@angular/material/dialog';\r\nimport { CellAlignmentEnum, ConfigColumn, EqpTableComponent, TypeColumn } from '@eqproject/eqp-table';\r\nimport { BaseField, FieldTypeEnum } from '../../../models/baseField.model';\r\nimport { Context } from '../../../models/context.model';\r\nimport { ActionOnRecord, Form, FormFieldGroup, FormScalarTypeEnum, FormTypeEnum } from '../../../models/form.model';\r\nimport { ArrayValidators } from '../../../services/custom-form-validators.service';\r\nimport { EqpDynamicModuleDialogService } from '../../../services/eqp-dynamic-module-dialog.service';\r\nimport { UtilityHelperService } from '../../../services/utilityHelper.services';\r\n\r\n@Component({\r\n  selector: 'eqp-dynamic-module-configurator',\r\n  templateUrl: './eqp-dynamic-module-configurator.component.html',\r\n  styleUrls: ['./eqp-dynamic-module-configurator.component.scss']\r\n})\r\nexport class EqpDynamicModuleConfiguratorComponent implements OnInit {\r\n\r\n  @Input() context: Context = new Context();\r\n  @Input() form: Form = new Form();\r\n  @Input() innerFormManagment: boolean = false;\r\n\r\n  formFormGroup: FormGroup;\r\n  formCompleted = false;\r\n  previewForm: Form;\r\n  formFieldGroupName: string;\r\n\r\n  actionAutocompleteOptions: Array<{ label: string, value: string }>;\r\n\r\n  //#region Enumeratori usati nell'html\r\n  FormTypeEnum = FormTypeEnum;\r\n  FormScalarTypeEnum = FormScalarTypeEnum;\r\n  //#endregion\r\n\r\n  //#region Proprietà per creazione/modifica campo\r\n  fieldsColumns: Array<ConfigColumn>;\r\n  @ViewChild('fieldsTable', { static: false }) fieldsTable: EqpTableComponent;\r\n  selectedField: BaseField | any;\r\n  indexSelectedField: number;\r\n  actionOnRecordFormGroup: FormGroup;\r\n  dialogFieldRef: MatDialogRef<TemplateRef<any>>;\r\n  @ViewChild('dialogField', { static: true }) dialogField: TemplateRef<any>;\r\n  @ViewChild('fieldSectionColumnTemplate', { static: true }) fieldSectionColumnTemplate: TemplateRef<any>;\r\n  //#endregion\r\n\r\n  //#region Proprietà per creare/modificare una Form di dettaglio\r\n  selectedInnerForm: Form;\r\n  indexSelectedInnerForm: number;\r\n  dialogInnerFormRef: MatDialogRef<TemplateRef<any>>;\r\n  @ViewChild('dialogInnerForm', { static: true }) dialogInnerForm: TemplateRef<any>;\r\n  //#endregion\r\n\r\n  //#region Proprietà per creare/modificare una action sui record di una Form\r\n  actionsOnRecordColumns: Array<ConfigColumn>;\r\n  @ViewChild('actionsOnRecordTable', { static: false }) actionsOnRecordTable: EqpTableComponent;\r\n  selectedAction: ActionOnRecord;\r\n  indexSelectedAction: number;\r\n  dialogActionOnRecordRef: MatDialogRef<TemplateRef<any>>;\r\n  @ViewChild('dialogActionOnRecord', { static: true }) dialogActionOnRecord: TemplateRef<any>;\r\n  //#endregion\r\n\r\n\r\n  @Output() saveFormEvent: EventEmitter<Form> = new EventEmitter<Form>();\r\n\r\n  constructor(\r\n    private formBuilder: FormBuilder,\r\n    private dialog: MatDialog\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    if (this.context) {\r\n      UtilityHelperService.SetContext(this.context);\r\n    }\r\n    this.configureColumns();\r\n    this.createFormForm();\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato al cambio del tipo di visualizzazione della form.\r\n   * Se l'utente sceglie una visualizzazione raggruppata il metodo aggiunge al FormGroup un nuovo\r\n   * controllo per l'array dei nomi delle sezioni da creare.\r\n   */\r\n  onChangeFormScalarType() {\r\n    if (this.form.FormScalarType != FormScalarTypeEnum.Semplice) {\r\n      if (!this.formFormGroup.contains(\"FormFieldsGroups\")) {\r\n        this.formFormGroup.removeControl(\"FormFieldsGroups\");\r\n        this.formFormGroup.addControl(\"FormFieldsGroups\", new FormControl(this.form.FormFieldsGroups, [Validators.required, ArrayValidators.minLenght(1)]));\r\n      }\r\n    } else {\r\n      this.form.FormFieldsGroups = null;\r\n      if (this.formFormGroup.contains(\"FormFieldsGroups\"))\r\n        this.formFormGroup.removeControl(\"FormFieldsGroups\");\r\n    }\r\n    this.formFormGroup.updateValueAndValidity();\r\n    this.configureColumns();\r\n  }\r\n\r\n  /**\r\n   * Evento invocato al keyup nell'input per inserire i nomi delle sezioni per la visualizzazione \r\n   * raggruppata della form. Quanto l'utente preme il tasto invio viene aggiunto il nuovo nome alle\r\n   * sezioni dispobili se non ne esiste una con lo stesso nome.\r\n   * @param event Evento che rappresenta il keyup sulla tastiera.\r\n   */\r\n  onFormFieldGroupNameKeyUp(event) {\r\n    if (event.code === 'Enter' || event.code === 'NumpadEnter') {\r\n      if (!this.form.FormFieldsGroups) {\r\n        this.form.FormFieldsGroups = new Array<FormFieldGroup>();\r\n      }\r\n      if (!this.form.FormFieldsGroups.find(n => n.Name == this.formFieldGroupName)) {\r\n        this.form.FormFieldsGroups.push({ Name: this.formFieldGroupName });\r\n      }\r\n      // Imposto il nuovo valore del FormControl per aggiornare lo stato della form.\r\n      this.formFormGroup.controls[\"FormFieldsGroups\"].setValue(this.form.FormFieldsGroups);\r\n      this.formFieldGroupName = null;\r\n      this.setFormFieldGroupOrdinalPosition();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per rimuovere la sezione selezionata da quelle disponibili per la form.\r\n   * @param groupName Nome della sezione da eliminare.\r\n   */\r\n  onDeleteFormFieldGroupName(groupName: string) {\r\n    this.form.FormFieldsGroups.splice(this.form.FormFieldsGroups.findIndex(g => g.Name === groupName), 1);\r\n    // Imposto il nuovo valore del FormControl per aggiornare lo stato della form.\r\n    this.formFormGroup.controls[\"FormFieldsGroups\"].setValue(this.form.FormFieldsGroups);\r\n    // Se esistono Field legati alla sezione che si vuole eliminare allora rompo il legame.\r\n    if (this.form.Fields.find(f => f.FieldGroup == groupName)) {\r\n      this.form.Fields.filter(f => f.FieldGroup == groupName).forEach(f => f.FieldGroup = null);\r\n    }\r\n    this.setFormFieldGroupOrdinalPosition();\r\n  }\r\n\r\n  /**\r\n   * Metodo chiamato quando si vuole aggiungere un nuovo campo o si vuole modificare uno esistente.\r\n   * Memorizza l'eventuale Field scelto one crea uno nuovo prima di aprire il dialog per modificarlo/aggiungerlo.\r\n   * @param field Oggetto BaseField da modificare. Se null ne viene creata una nuova istanza per l'aggiunta.\r\n   */\r\n  openFieldDialog(field: BaseField = null) {\r\n    if (field) {\r\n      this.indexSelectedField = this.form.Fields.indexOf(field);\r\n      this.selectedField = JSON.parse(JSON.stringify(field));\r\n    } else {\r\n      this.selectedField = new BaseField();\r\n      this.indexSelectedField = null;\r\n    }\r\n    this.dialogFieldRef = this.dialog.open(this.dialogField, {\r\n      disableClose: true,\r\n      hasBackdrop: true,\r\n      width: '75%'\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Metodo che salva il campo appena creato o modificato.\r\n   * Prima del salvataggio controlla se esiste un altro campo con la stessa label, in questo\r\n   * case genere un errore (i campi devono avere nomi, e quindi label, univoche - i nomi vengono\r\n   * ricavati unendo le parole che formano la label tramite \"_\").\r\n   * @param field Campo da salvare\r\n   */\r\n  onSaveField(field: BaseField) {\r\n    if (field) {\r\n      if (\r\n        this.form.Fields\r\n        && this.form.Fields.find(\r\n          (f, i) => f.Label === field.Label\r\n            && (this.indexSelectedField == null ? true : this.indexSelectedField !== i)\r\n        )\r\n      ) {\r\n        EqpDynamicModuleDialogService.Warning('Impossibile inserire due campi con la stessa label.');\r\n        throw new Error('Impossibile inserire due campi con la stessa label.');\r\n      }\r\n\r\n      if (this.indexSelectedField != null && this.indexSelectedField >= 0) {\r\n        this.form.Fields[this.indexSelectedField] = field;\r\n      } else {\r\n        if (!this.form.Fields) {\r\n          this.form.Fields = new Array<BaseField>();\r\n        }\r\n        this.form.Fields.push(field);\r\n      }\r\n    }\r\n    this.closeFieldDialog();\r\n    this.setFieldOrdinalPosition();\r\n    this.reloadFieldsTable();\r\n  }\r\n\r\n  /**\r\n   * Metodo che controlla se lo step per l'aggiunta dei campi nella form è concluso.\r\n   * @returns Se TRUE lo step viene considerato completato ed è possbile passare al successivo.\r\n   */\r\n  isFieldStepCompleted(): boolean {\r\n    if (!this.form.Fields) {\r\n      return false;\r\n    }\r\n    if (this.form.FormScalarType != FormScalarTypeEnum.Semplice && this.form.Fields.find(f => !f.FieldGroup)) {\r\n      return false;\r\n    }\r\n    return this.form.Fields.length > 0;\r\n  }\r\n\r\n  /**\r\n   * Metodo per aprire il dialog di creazione/modifica delle form di dettaglio.\r\n   * Se il parametro passato è null sono in aggiunta altrimenti sono in modifica.\r\n   * @param innenrForm Form di dettaglio da modificare (se null allora vado in add).\r\n   */\r\n  openInnerFormDialog(innenrForm: Form = null) {\r\n    if (innenrForm) {\r\n      this.indexSelectedInnerForm = this.form.InnerForms.indexOf(innenrForm);\r\n      this.selectedInnerForm = JSON.parse(JSON.stringify(innenrForm));\r\n      this.selectedInnerForm.OldName = innenrForm.Name;\r\n      this.indexSelectedField = this.form.Fields.findIndex(f => f.Label === innenrForm.Name);\r\n    } else {\r\n      this.selectedInnerForm = new Form();\r\n      this.indexSelectedInnerForm = null;\r\n      this.indexSelectedField = null;\r\n    }\r\n    this.dialogInnerFormRef = this.dialog.open(this.dialogInnerForm, {\r\n      disableClose: true,\r\n      hasBackdrop: true,\r\n      width: '85%'\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Metodo scatenato al salvataggio di una form di dettaglio. \r\n   * @param event Form creata/modificata dall'utente. Se è null allora l'utente ha abbandonato la configurazione.\r\n   */\r\n  onSaveOrExitInnerForm(event: Form) {\r\n    if (event != null) {\r\n      if (this.form.Name === event.Name ||\r\n        (\r\n          this.form.InnerForms\r\n          && this.form.InnerForms.find(\r\n            (a, i) => a.Name === event.Name\r\n              && (this.indexSelectedInnerForm == null ? true : this.indexSelectedInnerForm !== i)\r\n          )\r\n        ) ||\r\n        (\r\n          this.form.Fields\r\n          && this.indexSelectedInnerForm == null\r\n          && this.form.Fields.find(\r\n            (f, i) => f.Label === event.Name\r\n              && (this.indexSelectedField == null ? true : this.indexSelectedField !== i)\r\n          )\r\n        )\r\n      ) {\r\n        EqpDynamicModuleDialogService.Warning('Impossibile inserire due form di dettaglio con lo stesso nome.');\r\n        throw new Error('Impossibile inserire due form di dettaglio con lo stesso nome.');\r\n      }\r\n\r\n      let innerFormField: BaseField = new BaseField();\r\n      innerFormField.Name = event.Name.split(\" \").join(\"_\");\r\n      innerFormField.Label = event.Name;\r\n      innerFormField.FieldType = FieldTypeEnum['Form di dettaglio'];\r\n      innerFormField.FieldGroup = this.indexSelectedField != null ? this.form.Fields[this.indexSelectedField].FieldGroup : null;\r\n\r\n      if (this.indexSelectedInnerForm != null && this.indexSelectedInnerForm >= 0) {\r\n        this.form.InnerForms[this.indexSelectedInnerForm] = event;\r\n        this.form.Fields[this.indexSelectedField] = innerFormField;\r\n      } else {\r\n        if (!this.form.InnerForms) {\r\n          this.form.InnerForms = new Array<Form>();\r\n        }\r\n        this.form.InnerForms.push(event);\r\n        this.form.Fields.push(innerFormField);\r\n      }\r\n      this.reloadFieldsTable();\r\n    }\r\n    this.dialogInnerFormRef.close();\r\n  }\r\n\r\n  /**\r\n   * Metodo per aprire il dialog di creazione/modifica delle action.\r\n   * Se il parametro passato è null sono in aggiunta altrimenti sono in modifica.\r\n   * @param action ActionOnRecord da modificare (se null allora vado in add).\r\n   */\r\n  openActionOnRecordDialog(action: ActionOnRecord = null) {\r\n    if (action) {\r\n      this.indexSelectedAction = this.form.ActionsOnRecord.indexOf(action);\r\n      this.selectedAction = JSON.parse(JSON.stringify(action));\r\n    } else {\r\n      this.selectedAction = new ActionOnRecord();\r\n      this.indexSelectedAction = null;\r\n    }\r\n    this.createActionOnRecordForm();\r\n    this.dialogActionOnRecordRef = this.dialog.open(this.dialogActionOnRecord, {\r\n      disableClose: true,\r\n      hasBackdrop: true,\r\n      width: '75%'\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Metodo per impostare i valori da suggerire nell'autocomplete del campo Formula.\r\n   * Viene scatenato al focus (in questo caso viene passato il parametro a null per differenziarlo\r\n   * dall'evento di click sulla tastiera) e al keyup sull'input (il parametro è diverso da null).\r\n   * @param keyboardEvent Evento scatenato al keyup sulla tastiera. Se null allora il metodo è stato invocato dal focus sull'input.\r\n   * @summary Aggiorna l'elenco dei suggerimenti per l'autocomplete se l'utente esegue il focus sull'input\r\n   * oppure al keyup sulla tastiera di un tasto diverso dalle frecce.\r\n   */\r\n  setActionAutocompleteOptions(keyboardEvent: KeyboardEvent) {\r\n    // Creo l'array per l'autocomplete solo se sto facendo il focus sull'input o se sto premendo un tasto\r\n    // sulla tastiera diverso dalle frecce (in quest'ultimo caso, se non viene eseguito il filtro sull'evento,\r\n    // non si può selezionare un suggerimento dell'autocomplete perchè al click verrebbe ricaricato l'array e\r\n    // si prederebbe la selezione appena fatta).\r\n    if (!keyboardEvent || !keyboardEvent.code.includes(\"Arrow\")) {\r\n      this.actionAutocompleteOptions = UtilityHelperService.GetAutocompleteOptions(this.form.Fields, this.selectedAction.Action);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per salvare l'azione creata/modificate.\r\n   */\r\n  saveActionOnRecord() {\r\n    if (\r\n      this.form.ActionsOnRecord\r\n      && this.form.ActionsOnRecord.find(\r\n        (a, i) => a.Name === this.selectedAction.Name\r\n          && (this.indexSelectedAction == null ? true : this.indexSelectedAction !== i)\r\n      )\r\n    ) {\r\n      EqpDynamicModuleDialogService.Warning('Impossibile inserire due action con lo stesso nome.');\r\n      throw new Error('Impossibile inserire due action con lo stesso nome.');\r\n    }\r\n\r\n    if (this.indexSelectedAction != null && this.indexSelectedAction >= 0) {\r\n      this.form.ActionsOnRecord[this.indexSelectedAction] = this.selectedAction;\r\n    } else {\r\n      if (!this.form.ActionsOnRecord) {\r\n        this.form.ActionsOnRecord = new Array<ActionOnRecord>();\r\n      }\r\n      this.form.ActionsOnRecord.push(this.selectedAction);\r\n    }\r\n    this.closeDialogActionOnRecord();\r\n    this.setActionOrdinalPosition();\r\n    this.reloadActionsOnRecordTable();\r\n  }\r\n\r\n  /**\r\n   * Metodo per chiudere il dialog di gestione delle action.\r\n   */\r\n  closeDialogActionOnRecord() {\r\n    this.dialogActionOnRecordRef.close();\r\n  }\r\n\r\n  /**\r\n   * Metodo per segnare come conclusa la creazione della form e per crearne una copia\r\n   * da visalizzare come anteprima.\r\n   * @param completed Se TRUE segna la form come conclusa e ne crea una copia da visualizzare\r\n   */\r\n  setFormStatus(completed: boolean) {\r\n    if (completed) {\r\n      this.formCompleted = true;\r\n      this.previewForm = JSON.parse(JSON.stringify(this.form));\r\n\r\n      // Per visualizzare correttamente l'oanteprima della form appena creata\r\n      // bisogna valorizzare la proprietà Name dei campi della form e delle InnerForms.\r\n      this.previewForm.Fields.forEach(field => { field.Name = field.Label.split(' ').join('_'); });\r\n      if (this.previewForm.InnerForms && this.previewForm.InnerForms.length > 0) {\r\n        this.previewForm.InnerForms.forEach(form => {\r\n          form.Fields.forEach(field => { field.Name = field.Label.split(' ').join('_'); });\r\n        });\r\n      }\r\n    } else {\r\n      this.formCompleted = false;\r\n      this.previewForm = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo che scatena l'evento di output per salvare la form creata alla fine del wizard\r\n   */\r\n  saveForm() {\r\n    this.saveFormEvent.emit(this.form);\r\n  }\r\n\r\n  /**\r\n   * Configura le colonne per le tabelle necessarie alla creazione della form:\r\n   *  - per la visualizzazione dei campi inseriti\r\n   *  - per le form di dettaglio create\r\n   *  - per le azioni configurate sui record della form\r\n   */\r\n  private configureColumns() {\r\n    this.fieldsColumns = [\r\n      {\r\n        key: 'action', display: '', type: TypeColumn.MenuAction, buttonMenuIcon: 'more_vert', styles: { flex: '0 0 6%' },\r\n        actions: [\r\n          { name: 'Modifica', icon: 'edit', fn: (element, index, col) => this.editField(element) },\r\n          { name: 'Elimina', icon: 'delete', fn: (element, index, col) => this.deleteElement(element, \"Fields\") },\r\n          {\r\n            name: 'Sposta su', icon: 'arrow_upward',\r\n            fn: (element, index, col) => this.moveElement(element, true, \"Fields\"),\r\n            disabled: (element) => this.form.Fields.indexOf(element) === 0\r\n          },\r\n          {\r\n            name: 'Sposta giù', icon: 'arrow_downward',\r\n            fn: (element, index, col) => this.moveElement(element, false, \"Fields\"),\r\n            disabled: (element) => this.form.Fields.indexOf(element) >= (this.form.Fields.length - 1)\r\n          },\r\n        ]\r\n      },\r\n      { key: 'FieldType', display: 'Tipologia', type: TypeColumn.Enum, enumModel: FieldTypeEnum },\r\n      { key: 'Label', display: 'Label' },\r\n      { key: 'Description', display: 'Descrizione' },\r\n      {\r\n        key: 'Required', display: 'Obbligatorio',\r\n        value: (element) => !!element.Required,\r\n        type: TypeColumn.Boolean,\r\n        booleanValues: {\r\n          true: '<i class=\"fa fa-check success-color\"></i>',\r\n          false: '<i class=\"fa fa-close error-color\"></i>'\r\n        },\r\n        styles: { flex: '0 0 7%', cellAlignment: CellAlignmentEnum.CENTER }\r\n      },\r\n    ];\r\n\r\n    if (this.form.FormScalarType && this.form.FormScalarType != FormScalarTypeEnum.Semplice) {\r\n      this.fieldsColumns.splice(\r\n        this.fieldsColumns.findIndex(c => c.key == 'Description'), 0,\r\n        { key: 'FieldGroup', display: 'Sezione', type: TypeColumn.ExternalTemplate, externalTemplate: this.fieldSectionColumnTemplate }\r\n      );\r\n    }\r\n\r\n    this.actionsOnRecordColumns = [\r\n      {\r\n        key: 'action', display: '', type: TypeColumn.MenuAction, buttonMenuIcon: 'more_vert', styles: { flex: '0 0 6%' },\r\n        actions: [\r\n          { name: 'Modifica', icon: 'edit', fn: (element, index, col) => this.openActionOnRecordDialog(element) },\r\n          { name: 'Elimina', icon: 'delete', fn: (element, index, col) => this.deleteElement(element, \"ActionsOnRecord\") },\r\n          {\r\n            name: 'Sposta su', icon: 'arrow_upward',\r\n            fn: (element, index, col) => this.moveElement(element, true, \"ActionsOnRecord\"),\r\n            disabled: (element) => this.form.ActionsOnRecord.indexOf(element) === 0\r\n          },\r\n          {\r\n            name: 'Sposta giù', icon: 'arrow_downward',\r\n            fn: (element, index, col) => this.moveElement(element, false, \"ActionsOnRecord\"),\r\n            disabled: (element) => this.form.ActionsOnRecord.indexOf(element) >= (this.form.ActionsOnRecord.length - 1)\r\n          },\r\n        ]\r\n      },\r\n      { key: 'Icon', display: 'Icona', styles: { flex: ' 0 0 15%' } },\r\n      { key: 'Name', display: 'Nome', styles: { flex: ' 0 0 20%' } },\r\n      { key: 'Action', display: 'Azione' },\r\n    ];\r\n  }\r\n\r\n  /**\r\n   * Crea il FormGroup per l'oggetto Form\r\n   */\r\n  private createFormForm() {\r\n    this.formFormGroup = this.formBuilder.group({\r\n      Name: [this.form.Name, Validators.required],\r\n      FormScalarType: [this.form.FormScalarType, Validators.required],\r\n    });\r\n    this.onChangeFormScalarType();\r\n  }\r\n\r\n  /**\r\n   * Crea il FormGroup epr l'aggiunta o la modifica di una action sui record della Form.\r\n   */\r\n  private createActionOnRecordForm() {\r\n    this.actionOnRecordFormGroup = this.formBuilder.group({\r\n      Name: [this.selectedAction.Name, Validators.required],\r\n      Icon: [this.selectedAction.Icon, Validators.required],\r\n      Action: [this.selectedAction.Action, Validators.required],\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Chiude il dialog per aggiungere/modificare un Field senza salvare\r\n   */\r\n  private closeFieldDialog() {\r\n    this.dialogFieldRef.close();\r\n  }\r\n\r\n  /**\r\n   * Metodo per gestire l'apertura del dialog per la modifica di un Field.\r\n   * Se il field è di tipo \"Form di dettaglio\" apre il dialog per la modifica di una \r\n   * InnerForm altrimenti apre quello per la modifica di un Field.\r\n   * @param field Campo da modificare\r\n   */\r\n  private editField(field: BaseField) {\r\n    if (field.FieldType != FieldTypeEnum['Form di dettaglio']) {\r\n      this.openFieldDialog(field);\r\n    } else {\r\n      this.openInnerFormDialog(this.form.InnerForms.find(f => f.Name == field.Label));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per rimuovere un Field all'interno di una Form.\r\n   * Richiede conferma all'utente prima di rimuoverlo.\r\n   * @param field BaseField da rimuovere\r\n   */\r\n  private deleteElement(element: BaseField | ActionOnRecord | Form, propertyName: string) {\r\n    EqpDynamicModuleDialogService.Confirm('Eliminare l\\'elemento selezionato?', () => {\r\n      this.form[propertyName].splice(this.form[propertyName].indexOf(element), 1);\r\n      if (propertyName === \"Fields\") {\r\n        this.setFieldOrdinalPosition();\r\n        this.reloadFieldsTable();\r\n      } else if (propertyName === \"ActionsOnRecord\") {\r\n        this.setActionOrdinalPosition();\r\n        this.reloadActionsOnRecordTable();\r\n      }\r\n    }, false, 'Richiesta conferma');\r\n  }\r\n\r\n  /**\r\n   * Metodo per spostare un campo all'interno della form.\r\n   * @param field Oggetto di tipo BaseField da spostare.\r\n   * @param moveUp Se TRUE allora sposta verso l'alto il campo (abbassa l'indice) altrimenti il contrario.\r\n   */\r\n  private moveElement(element: BaseField | ActionOnRecord, moveUp: boolean, propertyName: string) {\r\n    const startingIndex = this.form[propertyName].indexOf(element);\r\n    const endingIndex = startingIndex + (moveUp ? -1 : 1);\r\n\r\n    this.form[propertyName].splice(startingIndex, 1);\r\n    this.form[propertyName].splice(endingIndex, 0, element);\r\n\r\n    if (propertyName === \"Fields\") {\r\n      this.setFieldOrdinalPosition();\r\n      this.reloadFieldsTable();\r\n    } else if (propertyName === \"ActionsOnRecord\") {\r\n      this.setActionOrdinalPosition();\r\n      this.reloadActionsOnRecordTable();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Imposta l'ordinamento delle sezioni che compongono la form.\r\n   */\r\n  private setFormFieldGroupOrdinalPosition() {\r\n    this.form.FormFieldsGroups.forEach((g, i) => g.OrdinalPosition = i);\r\n  }\r\n\r\n  /**\r\n   * Imposta l'ordinamento dei campi all'interno della form in base all'ordine che l'utente\r\n   * ha definito nella tabella in cui sono mostrati\r\n   */\r\n  private setFieldOrdinalPosition() {\r\n    if (this.form.Fields) {\r\n      this.form.Fields.forEach(field => {\r\n        field.OrdinalPosition = this.form.Fields.indexOf(field);\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per ricaricare i dati della tabella dei campi aggiunti in una form\r\n   */\r\n  private reloadFieldsTable() {\r\n    if (this.fieldsTable) {\r\n      this.fieldsTable.reloadDatatable();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Imposta l'ordinamento dei campi all'interno della form in base all'ordine che l'utente\r\n   * ha definito nella tabella in cui sono mostrati\r\n   */\r\n  private setActionOrdinalPosition() {\r\n    if (this.form.ActionsOnRecord) {\r\n      this.form.ActionsOnRecord.forEach(action => {\r\n        action.OrdinalPosition = this.form.ActionsOnRecord.indexOf(action);\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per ricaricare i dati della tabella delle azioni aggiuntive sui record della Form.\r\n   */\r\n  private reloadActionsOnRecordTable() {\r\n    if (this.actionsOnRecordTable) {\r\n      this.actionsOnRecordTable.reloadDatatable();\r\n    }\r\n  }\r\n}\r\n"]}