@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.
@@ -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
- var _this = this;
74
- EqpDynamicModuleDialogService.Confirm('Duplicare il record selezionato?', function () {
75
- var copiedRecord = JSON.parse(JSON.stringify(record));
76
- if (!isNaN(parseInt(copiedRecord.ID))) {
77
- copiedRecord.ID = (parseInt(copiedRecord.ID) + 1).toString();
78
- }
79
- else {
80
- copiedRecord.ID = "xxxxxxxxx".replace("x", function (c) { return (Math.random() + 16 | 0).toString(16); });
81
- }
82
- _this.values.push(copiedRecord);
83
- _this.reloadTables();
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
- var _this = this;
93
- EqpDynamicModuleDialogService.Confirm('Eliminare il record selezionato?', function () {
94
- _this.values.splice(_this.values.indexOf(record), 1);
95
- _this.reloadTables();
96
- }, false, 'Richiesta conferma');
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":";AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAE1F,OAAO,EAAE,iBAAiB,EAAmC,gBAAgB,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAExH,OAAO,EAAa,aAAa,EAAE,MAAM,oCAAoC,CAAC;AAG9E,OAAO,EAAa,gBAAgB,EAAE,MAAM,2CAA2C,CAAC;AAIxF,OAAO,EAAE,oBAAoB,EAAE,MAAM,6CAA6C,CAAC;AACnF,OAAO,EAAE,6BAA6B,EAAE,MAAM,wDAAwD,CAAC;AAOvG;IAUE;QAJA,YAAO,GAAG,IAAI,KAAK,EAAgB,CAAC;QAE1B,wBAAmB,GAAwD,IAAI,YAAY,EAAyC,CAAC;IAE/H,CAAC;IAEjB,0CAAQ,GAAR;QACE,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED;;OAEG;IACK,kDAAgB,GAAxB;QAAA,iBAeC;QAdC,IAAI,CAAC,OAAO,GAAG;YACb;gBACE,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE;gBAC1B,IAAI,EAAE,UAAU,CAAC,UAAU,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;gBACpF,OAAO,EAAE;oBACP,EAAE,IAAI,EAAE,YAAY,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,UAAC,OAAO,EAAE,KAAK,EAAE,GAAG,IAAK,OAAA,KAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,EAApC,CAAoC,EAAE;oBACvG,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,UAAC,OAAO,EAAE,KAAK,EAAE,GAAG,IAAK,OAAA,KAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,KAAK,CAAC,EAArC,CAAqC,EAAE;oBACtG,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE,UAAC,OAAO,EAAE,KAAK,EAAE,GAAG,IAAK,OAAA,KAAI,CAAC,eAAe,CAAC,OAAO,CAAC,EAA7B,CAA6B,EAAE;oBAClG,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,UAAC,OAAO,EAAE,KAAK,EAAE,GAAG,IAAK,OAAA,KAAI,CAAC,YAAY,CAAC,OAAO,CAAC,EAA1B,CAA0B,EAAE;iBAC7F;aACF;SACF,CAAC;QACF,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC/B,IAAI,CAAC,2BAA2B,EAAE,CAAC;IACrC,CAAC;IAGD;;;OAGG;IACK,yDAAuB,GAA/B;QAAA,iBAiBC;QAhBC,IAAI,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE;YACrE,IAAI,CAAC,IAAI,CAAC,eAAe;iBACtB,IAAI,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,CAAC,CAAC,eAAe,GAAG,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,eAAe,GAAG,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAhG,CAAgG,CAAC;iBAChH,OAAO,CAAC,UAAA,MAAM;gBACb,KAAI,CAAC,OAAO,CAAC,IAAI,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,GAAG,KAAK,QAAQ,EAAlB,CAAkB,CAAC;qBACvC,OAAO;qBACP,IAAI,CAAC;oBACJ,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,EAAE,EAAE,UAAC,OAAO,EAAE,KAAK,EAAE,GAAG;wBAC5D,IAAM,GAAG,GAAG,OAAO,CAAC;wBACpB,IAAM,GAAG,GAAG,oBAAoB,CAAC,OAAO,CAAC;wBACzC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;wBACpB,6BAA6B;oBAC/B,CAAC;iBACF,CAAC,CAAA;YACN,CAAC,CAAC,CAAA;SACL;IACH,CAAC;IAED;;;;;OAKG;IACK,kDAAgB,GAAxB,UAAyB,MAAc,EAAE,QAAiB;QACxD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAE,MAAM,QAAA,EAAE,QAAQ,UAAA,EAAE,CAAC,CAAC;IACtD,CAAC;IAED;;;OAGG;IACK,iDAAe,GAAvB,UAAwB,MAAc;QAAtC,iBAYC;QAXC,6BAA6B,CAAC,OAAO,CAAC,kCAAkC,EAAE;YACxE,IAAI,YAAY,GAAW,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;YAC9D,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,EAAE;gBACrC,YAAY,CAAC,EAAE,GAAG,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;aAC9D;iBAAM;gBACL,YAAY,CAAC,EAAE,GAAG,WAAW,CAAC,OAAO,CAAC,GAAG,EAAE,UAAC,CAAC,IAAO,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aACtG;YACD,KAAI,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAC/B,KAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,EAAE,KAAK,EAAE,oBAAoB,CAAC,CAAC;QAChC,MAAM;IACR,CAAC;IAED;;;OAGG;IACK,8CAAY,GAApB,UAAqB,MAAc;QAAnC,iBAMC;QALC,6BAA6B,CAAC,OAAO,CAAC,kCAAkC,EAAE;YACxE,KAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAI,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;YACnD,KAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,EAAE,KAAK,EAAE,oBAAoB,CAAC,CAAC;QAChC,OAAO;IACT,CAAC;IAED;;;;;;OAMG;IACK,6DAA2B,GAAnC;QAAA,iBAWC;QAVC,IAAI,gBAAkC,CAAC;QACvC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,UAAU,EAAZ,CAAY,CAAC,EAAE;YAC5C,gBAAgB,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,UAAU,EAAZ,CAAY,CAAC,CAAC;SAC/D;aAAM;YACL,gBAAgB,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,eAAe,GAAG,CAAC,EAArB,CAAqB,CAAC,CAAC;SACxE;QACD,gBAAgB,CAAC,IAAI,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,CAAC,CAAC,eAAe,GAAG,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,eAAe,GAAG,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAhG,CAAgG,CAAC;aAC9H,OAAO,CAAC,UAAA,KAAK;YACZ,KAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC;QACnD,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;OAIG;IACK,mDAAiB,GAAzB,UAA0B,KAAgB;QACxC,IAAI,MAAM,GAAiB,EAAE,GAAG,EAAE,KAAK,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC;QACrE,QAAQ,KAAK,CAAC,SAAS,EAAE;YACvB,KAAK,aAAa,CAAC,UAAU,CAAC;gBAC5B,MAAM,CAAC,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC;gBACjC,MAAM,CAAC,aAAa,GAAG,EAAE,KAAK,EAAE,yCAAyC,EAAE,IAAI,EAAE,2CAA2C,EAAE,CAAC;gBAC/H,MAAM,CAAC,MAAM,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,aAAa,EAAE,iBAAiB,CAAC,MAAM,EAAE,CAAC;gBAC5E,MAAM;YACR,KAAK,aAAa,CAAC,cAAc,CAAC;gBAChC,IAAK,KAAmB,CAAC,UAAU,IAAI,gBAAgB,CAAC,aAAa,CAAC,EAAE;oBACtE,MAAM,CAAC,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC;oBAC9B,IAAK,KAAmB,CAAC,UAAU,IAAI,gBAAgB,CAAC,YAAY,CAAC,EAAE;wBACrE,MAAM,CAAC,MAAM,GAAG,kBAAkB,CAAC;qBACpC;yBAAM,IAAK,KAAmB,CAAC,UAAU,IAAI,gBAAgB,CAAC,WAAW,CAAC,EAAE;wBAC3E,MAAM,CAAC,MAAM,GAAG,YAAY,CAAC;qBAC9B;iBACF;gBACD,MAAM;YACR,KAAK,aAAa,CAAC,gBAAgB,CAAC;gBAClC,IAAK,KAAsB,CAAC,cAAc,EAAE;oBAC1C,MAAM,CAAC,UAAU,GAAG,gBAAgB,CAAC,QAAQ,CAAC;oBAC9C,MAAM,CAAC,gBAAgB,GAAI,KAAsB,CAAC,cAAc,CAAC;iBAClE;qBAAM,IAAI,CAAE,KAAsB,CAAC,SAAS,EAAE;oBAC7C,MAAM,CAAC,UAAU,GAAG,gBAAgB,CAAC,OAAO,CAAC;iBAC9C;gBACD,MAAM;YACR,KAAK,aAAa,CAAC,UAAU,CAAC,CAAC;YAC/B,KAAK,aAAa,CAAC,UAAU,CAAC;gBAC5B,MAAM,CAAC,KAAK,GAAG,UAAC,OAAe;oBAC7B,IAAK,KAAyB,CAAC,aAAa,IAAI,CAAE,KAAoB,CAAC,gBAAgB,IAAK,KAAoB,CAAC,gBAAgB,CAAC,aAAa,CAAC,EAAE;wBAChJ,OAAO,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAA2B,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,QAAQ,EAAV,CAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;qBAC9J;yBAAM;wBACL,OAAO,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAA2B,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;qBAC1I;gBACH,CAAC,CAAC;gBACF,MAAM,CAAC,UAAU,GAAG,KAAK,CAAC;gBAC1B,MAAM,CAAC,YAAY,GAAG,KAAK,CAAC;gBAC5B,MAAM;YACR,KAAK,aAAa,CAAC,iBAAiB,CAAC;gBACnC,MAAM,CAAC,KAAK,GAAG,UAAC,OAAe;oBAC7B,IAAK,KAAwB,CAAC,cAAc,EAAE;wBAC5C,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,EAAE;4BAC3D,OAAO,IAAI,CAAC;yBACb;6BAAM;4BACL,OAAO,MAAM,CAAC,IAAI,CAAE,KAAwB,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,UAAA,CAAC,IAAI,OAAA,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAE,KAAwB,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAArE,CAAqE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;yBACxJ;qBACF;yBAAM;wBACL,OAAO,MAAM,CAAC,IAAI,CAAE,KAAwB,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAA,CAAC,IAAI,OAAC,KAAwB,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,EAA9D,CAA8D,CAAC,CAAC;qBACpI;gBACH,CAAC,CAAC;gBACF,MAAM,CAAC,UAAU,GAAG,KAAK,CAAC;gBAC1B,MAAM,CAAC,YAAY,GAAG,KAAK,CAAC;gBAC5B,MAAM;YACR,KAAK,aAAa,CAAC,QAAQ,CAAC;gBAC1B,OAAO;gBACP,MAAM;SACT;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;OAEG;IACK,8CAAY,GAApB;QACE,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,CAAC;SACrC;IACH,CAAC;IA9LQ;QAAR,KAAK,EAAE;yDAAY;IACX;QAAR,KAAK,EAAE;2DAAuB;IACc;QAA5C,SAAS,CAAC,cAAc,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;iEAAiC;IAInE;QAAT,MAAM,EAAE;wEAAsI;IARpI,uBAAuB;QALnC,SAAS,CAAC;YACT,QAAQ,EAAE,kBAAkB;YAC5B,8jBAA8C;;SAE/C,CAAC;OACW,uBAAuB,CAiMnC;IAAD,8BAAC;CAAA,AAjMD,IAiMC;SAjMY,uBAAuB","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":";AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,YAAY,EAA4B,MAAM,eAAe,CAAC;AAEpH,OAAO,EAAE,iBAAiB,EAAmC,gBAAgB,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAExH,OAAO,EAAa,aAAa,EAAE,MAAM,oCAAoC,CAAC;AAG9E,OAAO,EAAa,gBAAgB,EAAE,MAAM,2CAA2C,CAAC;AAIxF,OAAO,EAAE,oBAAoB,EAAE,MAAM,6CAA6C,CAAC;AAQnF;IAgBE;QAdS,cAAS,GAAG,IAAI,CAAC;QAK1B,YAAO,GAAG,IAAI,KAAK,EAAgB,CAAC;QAE1B,wBAAmB,GAAwD,IAAI,YAAY,EAAyC,CAAC;QAErI,mBAAc,GAAyB,IAAI,YAAY,EAAU,CAAC;QAClE,sBAAiB,GAAyB,IAAI,YAAY,EAAU,CAAC;IAI/D,CAAC;IAEjB,0CAAQ,GAAR;QACE,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,6CAAW,GAAX,UAAY,OAAsB;QAChC,0EAA0E;QAC1E,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAI,SAAS,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,WAAW,IAAI,KAAK,EAAE;YAC5E,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC;YAC7C,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;IACH,CAAC;IAED;;OAEG;IACK,kDAAgB,GAAxB;QAAA,iBAeC;QAdC,IAAI,CAAC,OAAO,GAAG;YACb;gBACE,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE;gBAC1B,IAAI,EAAE,UAAU,CAAC,UAAU,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;gBACpF,OAAO,EAAE;oBACP,EAAE,IAAI,EAAE,YAAY,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,UAAC,OAAO,EAAE,KAAK,EAAE,GAAG,IAAK,OAAA,KAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,EAApC,CAAoC,EAAE;oBACvG,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,UAAC,OAAO,EAAE,KAAK,EAAE,GAAG,IAAK,OAAA,KAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,KAAK,CAAC,EAArC,CAAqC,EAAE;oBACtG,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE,UAAC,OAAO,EAAE,KAAK,EAAE,GAAG,IAAK,OAAA,KAAI,CAAC,eAAe,CAAC,OAAO,CAAC,EAA7B,CAA6B,EAAE;oBAClG,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,UAAC,OAAO,EAAE,KAAK,EAAE,GAAG,IAAK,OAAA,KAAI,CAAC,YAAY,CAAC,OAAO,CAAC,EAA1B,CAA0B,EAAE;iBAC7F;aACF;SACF,CAAC;QACF,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC/B,IAAI,CAAC,2BAA2B,EAAE,CAAC;IACrC,CAAC;IAGD;;;OAGG;IACK,yDAAuB,GAA/B;QAAA,iBAiBC;QAhBC,IAAI,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE;YACrE,IAAI,CAAC,IAAI,CAAC,eAAe;iBACtB,IAAI,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,CAAC,CAAC,eAAe,GAAG,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,eAAe,GAAG,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAhG,CAAgG,CAAC;iBAChH,OAAO,CAAC,UAAA,MAAM;gBACb,KAAI,CAAC,OAAO,CAAC,IAAI,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,GAAG,KAAK,QAAQ,EAAlB,CAAkB,CAAC;qBACvC,OAAO;qBACP,IAAI,CAAC;oBACJ,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,EAAE,EAAE,UAAC,OAAO,EAAE,KAAK,EAAE,GAAG;wBAC5D,IAAM,GAAG,GAAG,OAAO,CAAC;wBACpB,IAAM,GAAG,GAAG,oBAAoB,CAAC,OAAO,CAAC;wBACzC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;wBACpB,6BAA6B;oBAC/B,CAAC;iBACF,CAAC,CAAA;YACN,CAAC,CAAC,CAAA;SACL;IACH,CAAC;IAED;;;;;OAKG;IACK,kDAAgB,GAAxB,UAAyB,MAAc,EAAE,QAAiB;QACxD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAE,MAAM,QAAA,EAAE,QAAQ,UAAA,EAAE,CAAC,CAAC;IACtD,CAAC;IAED;;;OAGG;IACK,iDAAe,GAAvB,UAAwB,MAAc;QACpC,oFAAoF;QACpF,mEAAmE;QACnE,6CAA6C;QAC7C,oEAAoE;QACpE,aAAa;QACb,4GAA4G;QAC5G,MAAM;QACN,oCAAoC;QACpC,yBAAyB;QACzB,mCAAmC;QACnC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACpC,MAAM;IACR,CAAC;IAED;;;OAGG;IACK,8CAAY,GAApB,UAAqB,MAAc;QACjC,oFAAoF;QACpF,wDAAwD;QACxD,yBAAyB;QACzB,mCAAmC;QACnC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACjC,OAAO;IACT,CAAC;IAED;;;;;;OAMG;IACK,6DAA2B,GAAnC;QAAA,iBAWC;QAVC,IAAI,gBAAkC,CAAC;QACvC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,UAAU,EAAZ,CAAY,CAAC,EAAE;YAC5C,gBAAgB,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,UAAU,EAAZ,CAAY,CAAC,CAAC;SAC/D;aAAM;YACL,gBAAgB,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,eAAe,GAAG,CAAC,EAArB,CAAqB,CAAC,CAAC;SACxE;QACD,gBAAgB,CAAC,IAAI,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,CAAC,CAAC,eAAe,GAAG,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,eAAe,GAAG,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAhG,CAAgG,CAAC;aAC9H,OAAO,CAAC,UAAA,KAAK;YACZ,KAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC;QACnD,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;OAIG;IACK,mDAAiB,GAAzB,UAA0B,KAAgB;QACxC,IAAI,MAAM,GAAiB,EAAE,GAAG,EAAE,KAAK,CAAC,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC;QACrE,QAAQ,KAAK,CAAC,SAAS,EAAE;YACvB,KAAK,aAAa,CAAC,UAAU,CAAC;gBAC5B,MAAM,CAAC,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC;gBACjC,MAAM,CAAC,aAAa,GAAG,EAAE,KAAK,EAAE,yCAAyC,EAAE,IAAI,EAAE,2CAA2C,EAAE,CAAC;gBAC/H,MAAM,CAAC,MAAM,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,aAAa,EAAE,iBAAiB,CAAC,MAAM,EAAE,CAAC;gBAC5E,MAAM;YACR,KAAK,aAAa,CAAC,cAAc,CAAC;gBAChC,IAAK,KAAmB,CAAC,UAAU,IAAI,gBAAgB,CAAC,aAAa,CAAC,EAAE;oBACtE,MAAM,CAAC,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC;oBAC9B,IAAK,KAAmB,CAAC,UAAU,IAAI,gBAAgB,CAAC,YAAY,CAAC,EAAE;wBACrE,MAAM,CAAC,MAAM,GAAG,kBAAkB,CAAC;qBACpC;yBAAM,IAAK,KAAmB,CAAC,UAAU,IAAI,gBAAgB,CAAC,WAAW,CAAC,EAAE;wBAC3E,MAAM,CAAC,MAAM,GAAG,YAAY,CAAC;qBAC9B;iBACF;gBACD,MAAM;YACR,KAAK,aAAa,CAAC,gBAAgB,CAAC;gBAClC,IAAK,KAAsB,CAAC,cAAc,EAAE;oBAC1C,MAAM,CAAC,UAAU,GAAG,gBAAgB,CAAC,QAAQ,CAAC;oBAC9C,MAAM,CAAC,gBAAgB,GAAI,KAAsB,CAAC,cAAc,CAAC;iBAClE;qBAAM,IAAI,CAAE,KAAsB,CAAC,SAAS,EAAE;oBAC7C,MAAM,CAAC,UAAU,GAAG,gBAAgB,CAAC,OAAO,CAAC;iBAC9C;gBACD,MAAM;YACR,KAAK,aAAa,CAAC,UAAU,CAAC,CAAC;YAC/B,KAAK,aAAa,CAAC,UAAU,CAAC;gBAC5B,MAAM,CAAC,KAAK,GAAG,UAAC,OAAe;oBAC7B,IAAK,KAAyB,CAAC,aAAa,IAAI,CAAE,KAAoB,CAAC,gBAAgB,IAAK,KAAoB,CAAC,gBAAgB,CAAC,aAAa,CAAC,EAAE;wBAChJ,OAAO,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAA2B,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,QAAQ,EAAV,CAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;qBAC9J;yBAAM;wBACL,OAAO,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAA2B,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;qBAC1I;gBACH,CAAC,CAAC;gBACF,MAAM,CAAC,UAAU,GAAG,KAAK,CAAC;gBAC1B,MAAM,CAAC,YAAY,GAAG,KAAK,CAAC;gBAC5B,MAAM;YACR,KAAK,aAAa,CAAC,iBAAiB,CAAC;gBACnC,MAAM,CAAC,KAAK,GAAG,UAAC,OAAe;oBAC7B,IAAK,KAAwB,CAAC,cAAc,EAAE;wBAC5C,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,EAAE;4BAC3D,OAAO,IAAI,CAAC;yBACb;6BAAM;4BACL,OAAO,MAAM,CAAC,IAAI,CAAE,KAAwB,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,UAAA,CAAC,IAAI,OAAA,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAE,KAAwB,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAArE,CAAqE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;yBACxJ;qBACF;yBAAM;wBACL,OAAO,MAAM,CAAC,IAAI,CAAE,KAAwB,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,UAAA,CAAC,IAAI,OAAC,KAAwB,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,EAA9D,CAA8D,CAAC,CAAC;qBACpI;gBACH,CAAC,CAAC;gBACF,MAAM,CAAC,UAAU,GAAG,KAAK,CAAC;gBAC1B,MAAM,CAAC,YAAY,GAAG,KAAK,CAAC;gBAC5B,MAAM;YACR,KAAK,aAAa,CAAC,QAAQ,CAAC;gBAC1B,OAAO;gBACP,MAAM;SACT;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED;;OAEG;IACK,8CAAY,GAApB;QACE,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,CAAC;SACrC;IACH,CAAC;IA9MQ;QAAR,KAAK,EAAE;8DAAkB;IACjB;QAAR,KAAK,EAAE;yDAAY;IACX;QAAR,KAAK,EAAE;2DAAuB;IACc;QAA5C,SAAS,CAAC,cAAc,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;iEAAiC;IAInE;QAAT,MAAM,EAAE;wEAAsI;IAErI;QAAT,MAAM,EAAE;mEAAmE;IAClE;QAAT,MAAM,EAAE;sEAAsE;IAZpE,uBAAuB;QALnC,SAAS,CAAC;YACT,QAAQ,EAAE,kBAAkB;YAC5B,klBAA8C;;SAE/C,CAAC;OACW,uBAAuB,CAiNnC;IAAD,8BAAC;CAAA,AAjND,IAiNC;SAjNY,uBAAuB","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, EventEmitter, ViewChild, Output, ChangeDetectorRef, ViewChildren } from '@angular/core';
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
- if (event.ID && this.values.find(v => v.ID == event.ID)) {
376
- this.values[this.values.findIndex(v => v.ID == event.ID)] = event;
377
- }
378
- else {
379
- this.values.push(event);
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
- console.log(event);
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
- var copiedRecord = JSON.parse(JSON.stringify(record));
2299
- if (!isNaN(parseInt(copiedRecord.ID))) {
2300
- copiedRecord.ID = (parseInt(copiedRecord.ID) + 1).toString();
2301
- }
2302
- else {
2303
- copiedRecord.ID = "xxxxxxxxx".replace("x", (c) => { return (Math.random() + 16 | 0).toString(16); });
2304
- }
2305
- this.values.push(copiedRecord);
2306
- this.reloadTables();
2307
- }, false, 'Richiesta conferma');
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
- this.values.splice(this.values.indexOf(record), 1);
2317
- this.reloadTables();
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 text-center\">\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\" (recordChange)=\"onRecordChange()\"></dynamic-module-field>\n </div>\n </div>\n</ng-template>",
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);