@eqproject/eqp-dynamic-module 0.0.2 → 0.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/eqproject-eqp-dynamic-module.umd.js +72 -29
- package/bundles/eqproject-eqp-dynamic-module.umd.js.map +1 -1
- package/bundles/eqproject-eqp-dynamic-module.umd.min.js +1 -1
- package/bundles/eqproject-eqp-dynamic-module.umd.min.js.map +1 -1
- package/eqproject-eqp-dynamic-module.metadata.json +1 -1
- package/esm2015/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.js +33 -12
- package/esm2015/lib/components/private/form-records/add-form-record/add-form-record.component.js +6 -2
- package/esm2015/lib/components/private/form-records/list-form-record/list-form-record.component.js +37 -18
- package/esm5/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.js +33 -12
- package/esm5/lib/components/private/form-records/add-form-record/add-form-record.component.js +6 -2
- package/esm5/lib/components/private/form-records/list-form-record/list-form-record.component.js +37 -20
- package/fesm2015/eqproject-eqp-dynamic-module.js +73 -28
- package/fesm2015/eqproject-eqp-dynamic-module.js.map +1 -1
- package/fesm5/eqproject-eqp-dynamic-module.js +73 -30
- package/fesm5/eqproject-eqp-dynamic-module.js.map +1 -1
- package/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.d.ts +7 -1
- package/lib/components/private/form-records/add-form-record/add-form-record.component.d.ts +1 -0
- package/lib/components/private/form-records/list-form-record/list-form-record.component.d.ts +6 -2
- package/package.json +1 -1
package/esm5/lib/components/private/form-records/list-form-record/list-form-record.component.js
CHANGED
|
@@ -4,15 +4,24 @@ import { CellAlignmentEnum, NumberColumnPipe, TypeColumn } from '@eqproject/eqp-
|
|
|
4
4
|
import { FieldTypeEnum } from '../../../../models/baseField.model';
|
|
5
5
|
import { DateTimeTypeEnum } from '../../../../models/fields/dateField.model';
|
|
6
6
|
import { UtilityHelperService } from '../../../../services/utilityHelper.services';
|
|
7
|
-
import { EqpDynamicModuleDialogService } from '../../../../services/eqp-dynamic-module-dialog.service';
|
|
8
7
|
var ListFormRecordComponent = /** @class */ (function () {
|
|
9
8
|
function ListFormRecordComponent() {
|
|
9
|
+
this.showTitle = true;
|
|
10
10
|
this.columns = new Array();
|
|
11
11
|
this.onAddViewEditRecord = new EventEmitter();
|
|
12
|
+
this.onDeleteRecord = new EventEmitter();
|
|
13
|
+
this.onDuplicateRecord = new EventEmitter();
|
|
12
14
|
}
|
|
13
15
|
ListFormRecordComponent.prototype.ngOnInit = function () {
|
|
14
16
|
this.configureColumns();
|
|
15
17
|
};
|
|
18
|
+
ListFormRecordComponent.prototype.ngOnChanges = function (changes) {
|
|
19
|
+
// Se viene modificato il valore di "ngModelInput" allora aggiorna l'input
|
|
20
|
+
if (changes['values'] != undefined && changes['values'].firstChange == false) {
|
|
21
|
+
this.values = changes['values'].currentValue;
|
|
22
|
+
this.reloadTables();
|
|
23
|
+
}
|
|
24
|
+
};
|
|
16
25
|
/**
|
|
17
26
|
* Metodo per configurare le colonne della eqp-table.
|
|
18
27
|
*/
|
|
@@ -70,18 +79,17 @@ var ListFormRecordComponent = /** @class */ (function () {
|
|
|
70
79
|
* @param record Record da duplicare.
|
|
71
80
|
*/
|
|
72
81
|
ListFormRecordComponent.prototype.duplicateRecord = function (record) {
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
}, false, 'Richiesta conferma');
|
|
82
|
+
// EqpDynamicModuleDialogService.Confirm('Duplicare il record selezionato?', () => {
|
|
83
|
+
// var copiedRecord: Record = JSON.parse(JSON.stringify(record));
|
|
84
|
+
// if (!isNaN(parseInt(copiedRecord.ID))) {
|
|
85
|
+
// copiedRecord.ID = (parseInt(copiedRecord.ID) + 1).toString();
|
|
86
|
+
// } else {
|
|
87
|
+
// copiedRecord.ID = "xxxxxxxxx".replace("x", (c) => { return (Math.random() + 16 | 0).toString(16); });
|
|
88
|
+
// }
|
|
89
|
+
// this.values.push(copiedRecord);
|
|
90
|
+
// this.reloadTables();
|
|
91
|
+
// }, false, 'Richiesta conferma');
|
|
92
|
+
this.onDuplicateRecord.emit(record);
|
|
85
93
|
//TODO
|
|
86
94
|
};
|
|
87
95
|
/**
|
|
@@ -89,11 +97,11 @@ var ListFormRecordComponent = /** @class */ (function () {
|
|
|
89
97
|
* @param record Record da eliminare selezionato sulla eqp-table.
|
|
90
98
|
*/
|
|
91
99
|
ListFormRecordComponent.prototype.deleteRecord = function (record) {
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
100
|
+
// EqpDynamicModuleDialogService.Confirm('Eliminare il record selezionato?', () => {
|
|
101
|
+
// this.values.splice(this.values.indexOf(record), 1);
|
|
102
|
+
// this.reloadTables();
|
|
103
|
+
// }, false, 'Richiesta conferma');
|
|
104
|
+
this.onDeleteRecord.emit(record);
|
|
97
105
|
// TODO
|
|
98
106
|
};
|
|
99
107
|
/**
|
|
@@ -194,6 +202,9 @@ var ListFormRecordComponent = /** @class */ (function () {
|
|
|
194
202
|
this.tableRecords.reloadDatatable();
|
|
195
203
|
}
|
|
196
204
|
};
|
|
205
|
+
__decorate([
|
|
206
|
+
Input()
|
|
207
|
+
], ListFormRecordComponent.prototype, "showTitle", void 0);
|
|
197
208
|
__decorate([
|
|
198
209
|
Input()
|
|
199
210
|
], ListFormRecordComponent.prototype, "form", void 0);
|
|
@@ -206,14 +217,20 @@ var ListFormRecordComponent = /** @class */ (function () {
|
|
|
206
217
|
__decorate([
|
|
207
218
|
Output()
|
|
208
219
|
], ListFormRecordComponent.prototype, "onAddViewEditRecord", void 0);
|
|
220
|
+
__decorate([
|
|
221
|
+
Output()
|
|
222
|
+
], ListFormRecordComponent.prototype, "onDeleteRecord", void 0);
|
|
223
|
+
__decorate([
|
|
224
|
+
Output()
|
|
225
|
+
], ListFormRecordComponent.prototype, "onDuplicateRecord", void 0);
|
|
209
226
|
ListFormRecordComponent = __decorate([
|
|
210
227
|
Component({
|
|
211
228
|
selector: 'list-form-record',
|
|
212
|
-
template: "<div class=\"row eqp-dynamic-module-title\">\r\n <div class=\"col-md-6\">\r\n <h4><b>Elenco {{form.Name}}</b></h4>\r\n </div>\r\n <div class=\"col-md-6 text-right\">\r\n <button class=\"btn btn-primary\" mat-raised-button color=\"primary\" type=\"button\" (click)=\"onAddViewEditRecord.emit(null)\">\r\n <mat-icon>add</mat-icon>\r\n <span style=\"margin-left: 10px;\">Aggiungi</span>\r\n </button>\r\n </div>\r\n</div>\r\n\r\n\r\n<eqp-table #tableRecords [data]=\"values\" [columns]=\"columns\"></eqp-table>",
|
|
229
|
+
template: "<div class=\"row eqp-dynamic-module-title\">\r\n <div class=\"col-md-6\">\r\n <h4 *ngIf=\"showTitle\"><b>Elenco {{form.Name}}</b></h4>\r\n </div>\r\n <div class=\"col-md-6 text-right\">\r\n <button class=\"btn btn-primary\" mat-raised-button color=\"primary\" type=\"button\" (click)=\"onAddViewEditRecord.emit(null)\">\r\n <mat-icon>add</mat-icon>\r\n <span style=\"margin-left: 10px;\">Aggiungi</span>\r\n </button>\r\n </div>\r\n</div>\r\n\r\n\r\n<eqp-table #tableRecords [data]=\"values\" [columns]=\"columns\"></eqp-table>",
|
|
213
230
|
styles: ["::ng-deep .error-color{color:var(--danger)}::ng-deep .success-color{color:var(--success)}"]
|
|
214
231
|
})
|
|
215
232
|
], ListFormRecordComponent);
|
|
216
233
|
return ListFormRecordComponent;
|
|
217
234
|
}());
|
|
218
235
|
export { ListFormRecordComponent };
|
|
219
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-form-record.component.js","sourceRoot":"ng://@eqproject/eqp-dynamic-module/","sources":["lib/components/private/form-records/list-form-record/list-form-record.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewChild, Output, EventEmitter } from '@angular/core';\r\nimport { IAttachmentDTO } from '@eqproject/eqp-attachments';\r\nimport { CellAlignmentEnum, ConfigColumn, EqpTableComponent, NumberColumnPipe, TypeColumn } from '@eqproject/eqp-table';\r\nimport { Form } from '../../../../models/form.model';\r\nimport { BaseField, FieldTypeEnum } from '../../../../models/baseField.model';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { AttachmentField } from '../../../../models/fields/attachmentField.model';\r\nimport { DateField, DateTimeTypeEnum } from '../../../../models/fields/dateField.model';\r\nimport { ImageField } from '../../../../models/fields/imageField.model';\r\nimport { ListValueField } from '../../../../models/fields/listValueField.model';\r\nimport { NumericField } from '../../../../models/fields/numericField.model';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { EqpDynamicModuleDialogService } from '../../../../services/eqp-dynamic-module-dialog.service';\r\n\r\n@Component({\r\n  selector: 'list-form-record',\r\n  templateUrl: 'list-form-record.component.html',\r\n  styleUrls: ['./list-form-record.component.scss']\r\n})\r\nexport class ListFormRecordComponent implements OnInit {\r\n\r\n  @Input() form: Form;\r\n  @Input() values: Array<Record>;\r\n  @ViewChild('tableRecords', { static: true }) tableRecords: EqpTableComponent;\r\n\r\n  columns = new Array<ConfigColumn>();\r\n\r\n  @Output() onAddViewEditRecord: EventEmitter<{ record: Record, onlyView: boolean }> = new EventEmitter<{ record: Record, onlyView: boolean }>();\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.configureColumns();\r\n  }\r\n\r\n  /**\r\n   * Metodo per configurare le colonne della eqp-table.\r\n   */\r\n  private configureColumns() {\r\n    this.columns = [\r\n      {\r\n        key: \"action\", display: \"\",\r\n        type: TypeColumn.MenuAction, buttonMenuIcon: \"more_vert\", styles: { flex: \"0 0 6%\" },\r\n        actions: [\r\n          { name: \"Visualizza\", icon: \"info\", fn: (element, index, col) => this.viewOrEditRecord(element, true) },\r\n          { name: \"Modifica\", icon: \"edit\", fn: (element, index, col) => this.viewOrEditRecord(element, false) },\r\n          { name: \"Duplica\", icon: \"file_copy\", fn: (element, index, col) => this.duplicateRecord(element) },\r\n          { name: \"Elimina\", icon: \"delete\", fn: (element, index, col) => this.deleteRecord(element) },\r\n        ],\r\n      },\r\n    ];\r\n    this.createAdditionalActions();\r\n    this.createColumnsFromFormFields();\r\n  }\r\n\r\n\r\n  /**\r\n   * Metodo per aggiungere nella colonna \"action\" della eqp-table le azioni sui record \r\n   * definite dall'utente all'interno della Form.\r\n   */\r\n  private createAdditionalActions() {\r\n    if (this.form.ActionsOnRecord && this.form.ActionsOnRecord.length > 0) {\r\n      this.form.ActionsOnRecord\r\n        .sort((a, b) => (a.OrdinalPosition > b.OrdinalPosition) ? 1 : ((b.OrdinalPosition > a.OrdinalPosition) ? -1 : 0))\r\n        .forEach(action => {\r\n          this.columns.find(c => c.key === 'action')\r\n            .actions\r\n            .push({\r\n              name: action.Name, icon: action.Icon, fn: (element, index, col) => {\r\n                const rec = element;\r\n                const ctx = UtilityHelperService.context;\r\n                eval(action.Action);\r\n                // TODO: salvare le modifiche\r\n              }\r\n            })\r\n        })\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo che scatena l'evento di Output per mostrare o modificare il record\r\n   * selezionato sulla eqp-table.\r\n   * @param record Record da visualizzare o modificare selezionato sulla eqp-table.\r\n   * @param onlyView Se TRUE viene mostrato il componente add-form-record in sola lettura.\r\n   */\r\n  private viewOrEditRecord(record: Record, onlyView: boolean) {\r\n    this.onAddViewEditRecord.emit({ record, onlyView });\r\n  }\r\n\r\n  /**\r\n   * Metodo per duplicare un record della form.\r\n   * @param record Record da duplicare.\r\n   */\r\n  private duplicateRecord(record: Record) {\r\n    EqpDynamicModuleDialogService.Confirm('Duplicare il record selezionato?', () => {\r\n      var copiedRecord: Record = JSON.parse(JSON.stringify(record));\r\n      if (!isNaN(parseInt(copiedRecord.ID))) {\r\n        copiedRecord.ID = (parseInt(copiedRecord.ID) + 1).toString();\r\n      } else {\r\n        copiedRecord.ID = \"xxxxxxxxx\".replace(\"x\", (c) => { return (Math.random() + 16 | 0).toString(16); });\r\n      }\r\n      this.values.push(copiedRecord);\r\n      this.reloadTables();\r\n    }, false, 'Richiesta conferma');\r\n    //TODO\r\n  }\r\n\r\n  /**\r\n   * Metodo per eliminare un record dalla lista.\r\n   * @param record Record da eliminare selezionato sulla eqp-table.\r\n   */\r\n  private deleteRecord(record: Record) {\r\n    EqpDynamicModuleDialogService.Confirm('Eliminare il record selezionato?', () => {\r\n      this.values.splice(this.values.indexOf(record), 1);\r\n      this.reloadTables();\r\n    }, false, 'Richiesta conferma');\r\n    // TODO\r\n  }\r\n\r\n  /**\r\n   * Metodo per creare la configurazione delle colonne per la eqp-table.\r\n   * Individua i BaseField da mostrare e li usa per creare le ConfigColumn.\r\n   * Le colonne vengono create per i BaseField con il flag InListView a TRUE\r\n   * oppure, nel caso non siano stati specificati i campi da visualizzare, \r\n   * seleziona i primi 6.\r\n   */\r\n  private createColumnsFromFormFields() {\r\n    var fieldsForColumns: Array<BaseField>;\r\n    if (this.form.Fields.find(f => f.InListView)) {\r\n      fieldsForColumns = this.form.Fields.filter(f => f.InListView);\r\n    } else {\r\n      fieldsForColumns = this.form.Fields.filter(f => f.OrdinalPosition < 6);\r\n    }\r\n    fieldsForColumns.sort((a, b) => (a.OrdinalPosition > b.OrdinalPosition) ? 1 : ((b.OrdinalPosition > a.OrdinalPosition) ? -1 : 0))\r\n      .forEach(field => {\r\n        this.columns.push(this.createFieldColumn(field));\r\n      });\r\n  }\r\n\r\n  /**\r\n   * Metodo per creare l'oggetto ConfigureColumn che rappresenta il BaseField passato in input.\r\n   * @param field BaseField per cui creare la colonna nella eqp-table\r\n   * @returns Restituisce una ConfigColumn per la eqp-table\r\n   */\r\n  private createFieldColumn(field: BaseField): ConfigColumn {\r\n    var column: ConfigColumn = { key: field.Name, display: field.Label };\r\n    switch (field.FieldType) {\r\n      case FieldTypeEnum['Booleano']:\r\n        column.type = TypeColumn.Boolean;\r\n        column.booleanValues = { false: '<i class=\"fa fa-times error-color\"></i>', true: '<i class=\"fa fa-check success-color\"></i>' };\r\n        column.styles = { flex: \"0 0 7%\", cellAlignment: CellAlignmentEnum.CENTER };\r\n        break;\r\n      case FieldTypeEnum['Data e/o ora']:\r\n        if ((field as DateField).IsOnlyDate != DateTimeTypeEnum['Solo orario']) {\r\n          column.type = TypeColumn.Date;\r\n          if ((field as DateField).IsOnlyDate == DateTimeTypeEnum['Data e ora']) {\r\n            column.format = \"dd/MM/yyyy HH:mm\";\r\n          } else if ((field as DateField).IsOnlyDate == DateTimeTypeEnum['Solo data']) {\r\n            column.format = \"dd/MM/yyyy\";\r\n          }\r\n        }\r\n        break;\r\n      case FieldTypeEnum['Campo numerico']:\r\n        if ((field as NumericField).CurrencySymbol) {\r\n          column.numberPipe = NumberColumnPipe.CURRENCY;\r\n          column.currencyPipeCode = (field as NumericField).CurrencySymbol;\r\n        } else if (!(field as NumericField).IsInteger) {\r\n          column.numberPipe = NumberColumnPipe.DECIMAL;\r\n        }\r\n        break;\r\n      case FieldTypeEnum['Allegato']:\r\n      case FieldTypeEnum['Immagine']:\r\n        column.value = (element: Record) => {\r\n          if ((field as AttachmentField).IsMultiAttach || ((field as ImageField).AttachDefinition && (field as ImageField).AttachDefinition.IsMultiAttach)) {\r\n            return element[field.Name] != null && element[field.Name].length > 0 ? (element[field.Name] as Array<IAttachmentDTO>).map(a => a.FileName).join(\", \") : null;\r\n          } else {\r\n            return element[field.Name] != null && element[field.Name].length > 0 ? (element[field.Name] as Array<IAttachmentDTO>)[0].FileName : null;\r\n          }\r\n        };\r\n        column.isSortable = false;\r\n        column.isSearchable = false;\r\n        break;\r\n      case FieldTypeEnum['Elenco generico']:\r\n        column.value = (element: Record) => {\r\n          if ((field as ListValueField).IsMultiChoiche) {\r\n            if (!element[field.Name] || element[field.Name].length == 0) {\r\n              return null;\r\n            } else {\r\n              return Object.keys((field as ListValueField).ValuePairs).filter(k => element[field.Name].includes((field as ListValueField).ValuePairs[k])).join(\", \");\r\n            }\r\n          } else {\r\n            return Object.keys((field as ListValueField).ValuePairs).find(k => (field as ListValueField).ValuePairs[k] == element[field.Name]);\r\n          }\r\n        };\r\n        column.isSortable = false;\r\n        column.isSearchable = false;\r\n        break;\r\n      case FieldTypeEnum['Lookup']:\r\n        // TODO\r\n        break;\r\n    }\r\n    return column;\r\n  }\r\n\r\n  /**\r\n   * Metodo per ricaricare i dati della eqp-table.\r\n   */\r\n  private reloadTables() {\r\n    if (this.tableRecords) {\r\n      this.tableRecords.reloadDatatable();\r\n    }\r\n  }\r\n}\r\n"]}
|
|
236
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-form-record.component.js","sourceRoot":"ng://@eqproject/eqp-dynamic-module/","sources":["lib/components/private/form-records/list-form-record/list-form-record.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewChild, Output, EventEmitter, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { IAttachmentDTO } from '@eqproject/eqp-attachments';\r\nimport { CellAlignmentEnum, ConfigColumn, EqpTableComponent, NumberColumnPipe, TypeColumn } from '@eqproject/eqp-table';\r\nimport { Form } from '../../../../models/form.model';\r\nimport { BaseField, FieldTypeEnum } from '../../../../models/baseField.model';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { AttachmentField } from '../../../../models/fields/attachmentField.model';\r\nimport { DateField, DateTimeTypeEnum } from '../../../../models/fields/dateField.model';\r\nimport { ImageField } from '../../../../models/fields/imageField.model';\r\nimport { ListValueField } from '../../../../models/fields/listValueField.model';\r\nimport { NumericField } from '../../../../models/fields/numericField.model';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { EqpDynamicModuleDialogService } from '../../../../services/eqp-dynamic-module-dialog.service';\r\n\r\n@Component({\r\n  selector: 'list-form-record',\r\n  templateUrl: 'list-form-record.component.html',\r\n  styleUrls: ['./list-form-record.component.scss']\r\n})\r\nexport class ListFormRecordComponent implements OnInit, OnChanges {\r\n\r\n  @Input() showTitle = true;\r\n  @Input() form: Form;\r\n  @Input() values: Array<Record>;\r\n  @ViewChild('tableRecords', { static: true }) tableRecords: EqpTableComponent;\r\n\r\n  columns = new Array<ConfigColumn>();\r\n\r\n  @Output() onAddViewEditRecord: EventEmitter<{ record: Record, onlyView: boolean }> = new EventEmitter<{ record: Record, onlyView: boolean }>();\r\n  \r\n  @Output() onDeleteRecord: EventEmitter<Record> = new EventEmitter<Record>();\r\n  @Output() onDuplicateRecord: EventEmitter<Record> = new EventEmitter<Record>();\r\n\r\n\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.configureColumns();\r\n  }\r\n  \r\n  ngOnChanges(changes: SimpleChanges) {\r\n    // Se viene modificato il valore di \"ngModelInput\" allora aggiorna l'input\r\n    if (changes['values'] != undefined && changes['values'].firstChange == false) {\r\n      this.values = changes['values'].currentValue;\r\n      this.reloadTables();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per configurare le colonne della eqp-table.\r\n   */\r\n  private configureColumns() {\r\n    this.columns = [\r\n      {\r\n        key: \"action\", display: \"\",\r\n        type: TypeColumn.MenuAction, buttonMenuIcon: \"more_vert\", styles: { flex: \"0 0 6%\" },\r\n        actions: [\r\n          { name: \"Visualizza\", icon: \"info\", fn: (element, index, col) => this.viewOrEditRecord(element, true) },\r\n          { name: \"Modifica\", icon: \"edit\", fn: (element, index, col) => this.viewOrEditRecord(element, false) },\r\n          { name: \"Duplica\", icon: \"file_copy\", fn: (element, index, col) => this.duplicateRecord(element) },\r\n          { name: \"Elimina\", icon: \"delete\", fn: (element, index, col) => this.deleteRecord(element) },\r\n        ],\r\n      },\r\n    ];\r\n    this.createAdditionalActions();\r\n    this.createColumnsFromFormFields();\r\n  }\r\n\r\n\r\n  /**\r\n   * Metodo per aggiungere nella colonna \"action\" della eqp-table le azioni sui record \r\n   * definite dall'utente all'interno della Form.\r\n   */\r\n  private createAdditionalActions() {\r\n    if (this.form.ActionsOnRecord && this.form.ActionsOnRecord.length > 0) {\r\n      this.form.ActionsOnRecord\r\n        .sort((a, b) => (a.OrdinalPosition > b.OrdinalPosition) ? 1 : ((b.OrdinalPosition > a.OrdinalPosition) ? -1 : 0))\r\n        .forEach(action => {\r\n          this.columns.find(c => c.key === 'action')\r\n            .actions\r\n            .push({\r\n              name: action.Name, icon: action.Icon, fn: (element, index, col) => {\r\n                const rec = element;\r\n                const ctx = UtilityHelperService.context;\r\n                eval(action.Action);\r\n                // TODO: salvare le modifiche\r\n              }\r\n            })\r\n        })\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo che scatena l'evento di Output per mostrare o modificare il record\r\n   * selezionato sulla eqp-table.\r\n   * @param record Record da visualizzare o modificare selezionato sulla eqp-table.\r\n   * @param onlyView Se TRUE viene mostrato il componente add-form-record in sola lettura.\r\n   */\r\n  private viewOrEditRecord(record: Record, onlyView: boolean) {\r\n    this.onAddViewEditRecord.emit({ record, onlyView });\r\n  }\r\n\r\n  /**\r\n   * Metodo per duplicare un record della form.\r\n   * @param record Record da duplicare.\r\n   */\r\n  private duplicateRecord(record: Record) {\r\n    // EqpDynamicModuleDialogService.Confirm('Duplicare il record selezionato?', () => {\r\n    //   var copiedRecord: Record = JSON.parse(JSON.stringify(record));\r\n    //   if (!isNaN(parseInt(copiedRecord.ID))) {\r\n    //     copiedRecord.ID = (parseInt(copiedRecord.ID) + 1).toString();\r\n    //   } else {\r\n    //     copiedRecord.ID = \"xxxxxxxxx\".replace(\"x\", (c) => { return (Math.random() + 16 | 0).toString(16); });\r\n    //   }\r\n    //   this.values.push(copiedRecord);\r\n    //   this.reloadTables();\r\n    // }, false, 'Richiesta conferma');\r\n    this.onDuplicateRecord.emit(record);\r\n    //TODO\r\n  }\r\n\r\n  /**\r\n   * Metodo per eliminare un record dalla lista.\r\n   * @param record Record da eliminare selezionato sulla eqp-table.\r\n   */\r\n  private deleteRecord(record: Record) {\r\n    // EqpDynamicModuleDialogService.Confirm('Eliminare il record selezionato?', () => {\r\n    //   this.values.splice(this.values.indexOf(record), 1);\r\n    //   this.reloadTables();\r\n    // }, false, 'Richiesta conferma');\r\n    this.onDeleteRecord.emit(record);  \r\n    // TODO\r\n  }\r\n\r\n  /**\r\n   * Metodo per creare la configurazione delle colonne per la eqp-table.\r\n   * Individua i BaseField da mostrare e li usa per creare le ConfigColumn.\r\n   * Le colonne vengono create per i BaseField con il flag InListView a TRUE\r\n   * oppure, nel caso non siano stati specificati i campi da visualizzare, \r\n   * seleziona i primi 6.\r\n   */\r\n  private createColumnsFromFormFields() {\r\n    var fieldsForColumns: Array<BaseField>;\r\n    if (this.form.Fields.find(f => f.InListView)) {\r\n      fieldsForColumns = this.form.Fields.filter(f => f.InListView);\r\n    } else {\r\n      fieldsForColumns = this.form.Fields.filter(f => f.OrdinalPosition < 6);\r\n    }\r\n    fieldsForColumns.sort((a, b) => (a.OrdinalPosition > b.OrdinalPosition) ? 1 : ((b.OrdinalPosition > a.OrdinalPosition) ? -1 : 0))\r\n      .forEach(field => {\r\n        this.columns.push(this.createFieldColumn(field));\r\n      });\r\n  }\r\n\r\n  /**\r\n   * Metodo per creare l'oggetto ConfigureColumn che rappresenta il BaseField passato in input.\r\n   * @param field BaseField per cui creare la colonna nella eqp-table\r\n   * @returns Restituisce una ConfigColumn per la eqp-table\r\n   */\r\n  private createFieldColumn(field: BaseField): ConfigColumn {\r\n    var column: ConfigColumn = { key: field.Name, display: field.Label };\r\n    switch (field.FieldType) {\r\n      case FieldTypeEnum['Booleano']:\r\n        column.type = TypeColumn.Boolean;\r\n        column.booleanValues = { false: '<i class=\"fa fa-times error-color\"></i>', true: '<i class=\"fa fa-check success-color\"></i>' };\r\n        column.styles = { flex: \"0 0 7%\", cellAlignment: CellAlignmentEnum.CENTER };\r\n        break;\r\n      case FieldTypeEnum['Data e/o ora']:\r\n        if ((field as DateField).IsOnlyDate != DateTimeTypeEnum['Solo orario']) {\r\n          column.type = TypeColumn.Date;\r\n          if ((field as DateField).IsOnlyDate == DateTimeTypeEnum['Data e ora']) {\r\n            column.format = \"dd/MM/yyyy HH:mm\";\r\n          } else if ((field as DateField).IsOnlyDate == DateTimeTypeEnum['Solo data']) {\r\n            column.format = \"dd/MM/yyyy\";\r\n          }\r\n        }\r\n        break;\r\n      case FieldTypeEnum['Campo numerico']:\r\n        if ((field as NumericField).CurrencySymbol) {\r\n          column.numberPipe = NumberColumnPipe.CURRENCY;\r\n          column.currencyPipeCode = (field as NumericField).CurrencySymbol;\r\n        } else if (!(field as NumericField).IsInteger) {\r\n          column.numberPipe = NumberColumnPipe.DECIMAL;\r\n        }\r\n        break;\r\n      case FieldTypeEnum['Allegato']:\r\n      case FieldTypeEnum['Immagine']:\r\n        column.value = (element: Record) => {\r\n          if ((field as AttachmentField).IsMultiAttach || ((field as ImageField).AttachDefinition && (field as ImageField).AttachDefinition.IsMultiAttach)) {\r\n            return element[field.Name] != null && element[field.Name].length > 0 ? (element[field.Name] as Array<IAttachmentDTO>).map(a => a.FileName).join(\", \") : null;\r\n          } else {\r\n            return element[field.Name] != null && element[field.Name].length > 0 ? (element[field.Name] as Array<IAttachmentDTO>)[0].FileName : null;\r\n          }\r\n        };\r\n        column.isSortable = false;\r\n        column.isSearchable = false;\r\n        break;\r\n      case FieldTypeEnum['Elenco generico']:\r\n        column.value = (element: Record) => {\r\n          if ((field as ListValueField).IsMultiChoiche) {\r\n            if (!element[field.Name] || element[field.Name].length == 0) {\r\n              return null;\r\n            } else {\r\n              return Object.keys((field as ListValueField).ValuePairs).filter(k => element[field.Name].includes((field as ListValueField).ValuePairs[k])).join(\", \");\r\n            }\r\n          } else {\r\n            return Object.keys((field as ListValueField).ValuePairs).find(k => (field as ListValueField).ValuePairs[k] == element[field.Name]);\r\n          }\r\n        };\r\n        column.isSortable = false;\r\n        column.isSearchable = false;\r\n        break;\r\n      case FieldTypeEnum['Lookup']:\r\n        // TODO\r\n        break;\r\n    }\r\n    return column;\r\n  }\r\n\r\n  /**\r\n   * Metodo per ricaricare i dati della eqp-table.\r\n   */\r\n  private reloadTables() {\r\n    if (this.tableRecords) {\r\n      this.tableRecords.reloadDatatable();\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { __decorate } from 'tslib';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { ɵɵdefineInjectable, ɵɵinject, Injectable, Input, Component, NgModule,
|
|
3
|
+
import { ɵɵdefineInjectable, ɵɵinject, Injectable, EventEmitter, Input, Output, Component, NgModule, ViewChild, ChangeDetectorRef, ViewChildren } from '@angular/core';
|
|
4
4
|
import { Validators, FormControl, FormBuilder, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
5
5
|
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
6
6
|
import { MatButtonModule } from '@angular/material/button';
|
|
@@ -352,7 +352,11 @@ let EqpDynamicModuleComponent = class EqpDynamicModuleComponent {
|
|
|
352
352
|
this.context = new Context();
|
|
353
353
|
this.form = new Form();
|
|
354
354
|
this.showButtons = true;
|
|
355
|
+
this.showTitle = true;
|
|
355
356
|
this.viewMode = FormTypeEnum.LIST;
|
|
357
|
+
this.saveRecord = new EventEmitter();
|
|
358
|
+
this.deleteRecord = new EventEmitter();
|
|
359
|
+
this.duplicateRecord = new EventEmitter();
|
|
356
360
|
this.FormTypeEnum = FormTypeEnum;
|
|
357
361
|
}
|
|
358
362
|
ngOnInit() {
|
|
@@ -371,16 +375,21 @@ let EqpDynamicModuleComponent = class EqpDynamicModuleComponent {
|
|
|
371
375
|
}
|
|
372
376
|
onSaveForm(event) {
|
|
373
377
|
//TODO: Salvare il record!
|
|
374
|
-
if (event != null) {
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
378
|
+
// if (event != null) {
|
|
379
|
+
// if (event.ID && this.values.find(v => v.ID == event.ID)) {
|
|
380
|
+
// this.values[this.values.findIndex(v => v.ID == event.ID)] = event;
|
|
381
|
+
// } else {
|
|
382
|
+
// this.values.push(event);
|
|
383
|
+
// }
|
|
384
|
+
// }
|
|
385
|
+
this.saveRecord.emit(event);
|
|
382
386
|
this.viewMode = FormTypeEnum.LIST;
|
|
383
|
-
|
|
387
|
+
}
|
|
388
|
+
onDuplicateRecord(record) {
|
|
389
|
+
this.duplicateRecord.emit(record);
|
|
390
|
+
}
|
|
391
|
+
onDeleteRecord(record) {
|
|
392
|
+
this.deleteRecord.emit(record);
|
|
384
393
|
}
|
|
385
394
|
};
|
|
386
395
|
__decorate([
|
|
@@ -395,13 +404,25 @@ __decorate([
|
|
|
395
404
|
__decorate([
|
|
396
405
|
Input()
|
|
397
406
|
], EqpDynamicModuleComponent.prototype, "showButtons", void 0);
|
|
407
|
+
__decorate([
|
|
408
|
+
Input()
|
|
409
|
+
], EqpDynamicModuleComponent.prototype, "showTitle", void 0);
|
|
398
410
|
__decorate([
|
|
399
411
|
Input()
|
|
400
412
|
], EqpDynamicModuleComponent.prototype, "viewMode", void 0);
|
|
413
|
+
__decorate([
|
|
414
|
+
Output()
|
|
415
|
+
], EqpDynamicModuleComponent.prototype, "saveRecord", void 0);
|
|
416
|
+
__decorate([
|
|
417
|
+
Output()
|
|
418
|
+
], EqpDynamicModuleComponent.prototype, "deleteRecord", void 0);
|
|
419
|
+
__decorate([
|
|
420
|
+
Output()
|
|
421
|
+
], EqpDynamicModuleComponent.prototype, "duplicateRecord", void 0);
|
|
401
422
|
EqpDynamicModuleComponent = __decorate([
|
|
402
423
|
Component({
|
|
403
424
|
selector: 'eqp-dynamic-module',
|
|
404
|
-
template: "<add-form-record *ngIf=\"viewMode == FormTypeEnum.SCALAR\" [form]=\"form\" [record]=\"selectedRecord\"\r\n [showButtons]=\"showButtons\" [onlyView]=\"onlyView\" (saveRecordEvent)=\"onSaveForm($event)\">\r\n</add-form-record>\r\n\r\n<list-form-record *ngIf=\"viewMode == FormTypeEnum.LIST\" [form]=\"form\" [values]=\"values\"\r\n (onAddViewEditRecord)=\"onAddViewEditRecord($event)\">\r\n</list-form-record>",
|
|
425
|
+
template: "<add-form-record *ngIf=\"viewMode == FormTypeEnum.SCALAR\" [form]=\"form\" [record]=\"selectedRecord\"\r\n [showButtons]=\"showButtons\" [onlyView]=\"onlyView\" (saveRecordEvent)=\"onSaveForm($event)\" [showTitle]=\"showTitle\">\r\n</add-form-record>\r\n\r\n<list-form-record *ngIf=\"viewMode == FormTypeEnum.LIST\" [form]=\"form\" [values]=\"values\"\r\n (onAddViewEditRecord)=\"onAddViewEditRecord($event)\" [showTitle]=\"showTitle\"\r\n (onDeleteRecord)=\"onDeleteRecord($event)\" (onDuplicateRecord)=\"onDuplicateRecord($event)\">\r\n</list-form-record>",
|
|
405
426
|
styles: ["::ng-deep mat-form-field{width:100%}"]
|
|
406
427
|
})
|
|
407
428
|
], EqpDynamicModuleComponent);
|
|
@@ -2233,12 +2254,22 @@ ImageFieldTemplateComponent = __decorate([
|
|
|
2233
2254
|
|
|
2234
2255
|
let ListFormRecordComponent = class ListFormRecordComponent {
|
|
2235
2256
|
constructor() {
|
|
2257
|
+
this.showTitle = true;
|
|
2236
2258
|
this.columns = new Array();
|
|
2237
2259
|
this.onAddViewEditRecord = new EventEmitter();
|
|
2260
|
+
this.onDeleteRecord = new EventEmitter();
|
|
2261
|
+
this.onDuplicateRecord = new EventEmitter();
|
|
2238
2262
|
}
|
|
2239
2263
|
ngOnInit() {
|
|
2240
2264
|
this.configureColumns();
|
|
2241
2265
|
}
|
|
2266
|
+
ngOnChanges(changes) {
|
|
2267
|
+
// Se viene modificato il valore di "ngModelInput" allora aggiorna l'input
|
|
2268
|
+
if (changes['values'] != undefined && changes['values'].firstChange == false) {
|
|
2269
|
+
this.values = changes['values'].currentValue;
|
|
2270
|
+
this.reloadTables();
|
|
2271
|
+
}
|
|
2272
|
+
}
|
|
2242
2273
|
/**
|
|
2243
2274
|
* Metodo per configurare le colonne della eqp-table.
|
|
2244
2275
|
*/
|
|
@@ -2294,17 +2325,17 @@ let ListFormRecordComponent = class ListFormRecordComponent {
|
|
|
2294
2325
|
* @param record Record da duplicare.
|
|
2295
2326
|
*/
|
|
2296
2327
|
duplicateRecord(record) {
|
|
2297
|
-
EqpDynamicModuleDialogService.Confirm('Duplicare il record selezionato?', () => {
|
|
2298
|
-
|
|
2299
|
-
|
|
2300
|
-
|
|
2301
|
-
|
|
2302
|
-
|
|
2303
|
-
|
|
2304
|
-
|
|
2305
|
-
|
|
2306
|
-
|
|
2307
|
-
|
|
2328
|
+
// EqpDynamicModuleDialogService.Confirm('Duplicare il record selezionato?', () => {
|
|
2329
|
+
// var copiedRecord: Record = JSON.parse(JSON.stringify(record));
|
|
2330
|
+
// if (!isNaN(parseInt(copiedRecord.ID))) {
|
|
2331
|
+
// copiedRecord.ID = (parseInt(copiedRecord.ID) + 1).toString();
|
|
2332
|
+
// } else {
|
|
2333
|
+
// copiedRecord.ID = "xxxxxxxxx".replace("x", (c) => { return (Math.random() + 16 | 0).toString(16); });
|
|
2334
|
+
// }
|
|
2335
|
+
// this.values.push(copiedRecord);
|
|
2336
|
+
// this.reloadTables();
|
|
2337
|
+
// }, false, 'Richiesta conferma');
|
|
2338
|
+
this.onDuplicateRecord.emit(record);
|
|
2308
2339
|
//TODO
|
|
2309
2340
|
}
|
|
2310
2341
|
/**
|
|
@@ -2312,10 +2343,11 @@ let ListFormRecordComponent = class ListFormRecordComponent {
|
|
|
2312
2343
|
* @param record Record da eliminare selezionato sulla eqp-table.
|
|
2313
2344
|
*/
|
|
2314
2345
|
deleteRecord(record) {
|
|
2315
|
-
EqpDynamicModuleDialogService.Confirm('Eliminare il record selezionato?', () => {
|
|
2316
|
-
|
|
2317
|
-
|
|
2318
|
-
}, false, 'Richiesta conferma');
|
|
2346
|
+
// EqpDynamicModuleDialogService.Confirm('Eliminare il record selezionato?', () => {
|
|
2347
|
+
// this.values.splice(this.values.indexOf(record), 1);
|
|
2348
|
+
// this.reloadTables();
|
|
2349
|
+
// }, false, 'Richiesta conferma');
|
|
2350
|
+
this.onDeleteRecord.emit(record);
|
|
2319
2351
|
// TODO
|
|
2320
2352
|
}
|
|
2321
2353
|
/**
|
|
@@ -2416,6 +2448,9 @@ let ListFormRecordComponent = class ListFormRecordComponent {
|
|
|
2416
2448
|
}
|
|
2417
2449
|
}
|
|
2418
2450
|
};
|
|
2451
|
+
__decorate([
|
|
2452
|
+
Input()
|
|
2453
|
+
], ListFormRecordComponent.prototype, "showTitle", void 0);
|
|
2419
2454
|
__decorate([
|
|
2420
2455
|
Input()
|
|
2421
2456
|
], ListFormRecordComponent.prototype, "form", void 0);
|
|
@@ -2428,10 +2463,16 @@ __decorate([
|
|
|
2428
2463
|
__decorate([
|
|
2429
2464
|
Output()
|
|
2430
2465
|
], ListFormRecordComponent.prototype, "onAddViewEditRecord", void 0);
|
|
2466
|
+
__decorate([
|
|
2467
|
+
Output()
|
|
2468
|
+
], ListFormRecordComponent.prototype, "onDeleteRecord", void 0);
|
|
2469
|
+
__decorate([
|
|
2470
|
+
Output()
|
|
2471
|
+
], ListFormRecordComponent.prototype, "onDuplicateRecord", void 0);
|
|
2431
2472
|
ListFormRecordComponent = __decorate([
|
|
2432
2473
|
Component({
|
|
2433
2474
|
selector: 'list-form-record',
|
|
2434
|
-
template: "<div class=\"row eqp-dynamic-module-title\">\r\n <div class=\"col-md-6\">\r\n <h4><b>Elenco {{form.Name}}</b></h4>\r\n </div>\r\n <div class=\"col-md-6 text-right\">\r\n <button class=\"btn btn-primary\" mat-raised-button color=\"primary\" type=\"button\" (click)=\"onAddViewEditRecord.emit(null)\">\r\n <mat-icon>add</mat-icon>\r\n <span style=\"margin-left: 10px;\">Aggiungi</span>\r\n </button>\r\n </div>\r\n</div>\r\n\r\n\r\n<eqp-table #tableRecords [data]=\"values\" [columns]=\"columns\"></eqp-table>",
|
|
2475
|
+
template: "<div class=\"row eqp-dynamic-module-title\">\r\n <div class=\"col-md-6\">\r\n <h4 *ngIf=\"showTitle\"><b>Elenco {{form.Name}}</b></h4>\r\n </div>\r\n <div class=\"col-md-6 text-right\">\r\n <button class=\"btn btn-primary\" mat-raised-button color=\"primary\" type=\"button\" (click)=\"onAddViewEditRecord.emit(null)\">\r\n <mat-icon>add</mat-icon>\r\n <span style=\"margin-left: 10px;\">Aggiungi</span>\r\n </button>\r\n </div>\r\n</div>\r\n\r\n\r\n<eqp-table #tableRecords [data]=\"values\" [columns]=\"columns\"></eqp-table>",
|
|
2435
2476
|
styles: ["::ng-deep .error-color{color:var(--danger)}::ng-deep .success-color{color:var(--success)}"]
|
|
2436
2477
|
})
|
|
2437
2478
|
], ListFormRecordComponent);
|
|
@@ -2443,6 +2484,7 @@ let AddFormRecordComponent = class AddFormRecordComponent {
|
|
|
2443
2484
|
constructor(cdr, utilityService) {
|
|
2444
2485
|
this.cdr = cdr;
|
|
2445
2486
|
this.utilityService = utilityService;
|
|
2487
|
+
this.showTitle = true;
|
|
2446
2488
|
this.showButtons = true;
|
|
2447
2489
|
this.form = new Form();
|
|
2448
2490
|
this.fieldGroups = {};
|
|
@@ -2532,6 +2574,9 @@ AddFormRecordComponent.ctorParameters = () => [
|
|
|
2532
2574
|
{ type: ChangeDetectorRef },
|
|
2533
2575
|
{ type: UtilityHelperService }
|
|
2534
2576
|
];
|
|
2577
|
+
__decorate([
|
|
2578
|
+
Input()
|
|
2579
|
+
], AddFormRecordComponent.prototype, "showTitle", void 0);
|
|
2535
2580
|
__decorate([
|
|
2536
2581
|
Input()
|
|
2537
2582
|
], AddFormRecordComponent.prototype, "showButtons", void 0);
|
|
@@ -2553,7 +2598,7 @@ __decorate([
|
|
|
2553
2598
|
AddFormRecordComponent = __decorate([
|
|
2554
2599
|
Component({
|
|
2555
2600
|
selector: 'add-form-record',
|
|
2556
|
-
template: "<div class=\"row eqp-dynamic-module-title\">\n <div class=\"col-md-12
|
|
2601
|
+
template: "<div class=\"row eqp-dynamic-module-title\" *ngIf=\"showTitle\">\n <div class=\"col-md-12\">\n <h4><b>{{form.Name}}</b></h4>\n </div>\n</div>\n\n<form [formGroup]=\"formForm\">\n\n <!-- VISUALIZZAZIONE SEMPLICE -->\n <ng-container *ngIf=\"form.FormScalarType == FormScalarTypeEnum.Semplice\" [ngTemplateOutlet]=\"fieldTemplates\"\n [ngTemplateOutletContext]=\"{ fields: form.Fields }\">\n </ng-container>\n\n <!-- VISUALIZZAZIONE A STEPPER -->\n <mat-horizontal-stepper linear *ngIf=\"form.FormScalarType == FormScalarTypeEnum['A step']\">\n <mat-step *ngFor=\"let group of form.FormFieldsGroups\">\n <ng-template matStepLabel>\n {{group.Name}}\n </ng-template>\n\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\n </ng-container>\n </mat-step>\n </mat-horizontal-stepper>\n\n <!-- VISUALIZZAZIONE A TAB -->\n <mat-tab-group *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In tab']\">\n <mat-tab *ngFor=\"let group of form.FormFieldsGroups\" [label]=\"group.Name\">\n <div class=\"mt-3\">\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\n </ng-container>\n </div>\n </mat-tab>\n </mat-tab-group>\n\n <!-- VISUALIZZAZIONE AD ACCORDION -->\n <mat-accordion multi *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In accordion']\">\n <mat-expansion-panel *ngFor=\"let group of form.FormFieldsGroups\">\n <mat-expansion-panel-header>\n <mat-panel-title>\n {{group.Name}}\n </mat-panel-title>\n </mat-expansion-panel-header>\n\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\n </ng-container>\n </mat-expansion-panel>\n </mat-accordion>\n</form>\n\n<div class=\"row mt-2\" *ngIf=\"showButtons\">\n <div class=\"col-sm-12 text-right\">\n <button class=\"mr-2\" mat-raised-button (click)=\"saveOrExitForm(true)\" type=\"button\">\n Annulla\n </button>\n <button class=\"mr-2\" mat-raised-button color=\"primary\" (click)=\"saveOrExitForm(false)\"\n [disabled]=\"formForm.invalid || formForm.disabled\" type=\"button\">\n Salva\n </button>\n </div>\n</div>\n\n<!-- TEMPLATE PER LA VISUALIZZAZIONE DEI CAMPI DELLA FORM -->\n<ng-template #fieldTemplates let-fields='fields'>\n <div class=\"row\">\n <div class=\"mt-2\" *ngFor=\"let field of fields\" [ngClass]=\"utilityService.getFieldSyleClass(field)\">\n <dynamic-module-field #fieldTemplate [field]=\"field\" [form]=\"form\" [record]=\"record\"\n (recordChange)=\"onRecordChange()\"></dynamic-module-field>\n </div>\n </div>\n</ng-template>",
|
|
2557
2602
|
styles: [""]
|
|
2558
2603
|
})
|
|
2559
2604
|
], AddFormRecordComponent);
|