@eqproject/eqp-dynamic-module 2.8.37 → 2.8.39

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (30) hide show
  1. package/esm2020/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.mjs +23 -3
  2. package/esm2020/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.mjs +148 -3
  3. package/esm2020/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.mjs +1 -1
  4. package/esm2020/lib/components/private/form-records/add-form-record/add-form-record.component.mjs +24 -4
  5. package/esm2020/lib/components/private/form-records/hlist-form-record/hlist-form-record.component.mjs +12 -2
  6. package/esm2020/lib/components/private/form-records/list-form-record/list-form-record.component.mjs +11 -2
  7. package/esm2020/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.mjs +52 -3
  8. package/esm2020/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.mjs +12 -3
  9. package/esm2020/lib/components/private/form-records/view-form-record/view-form-record.component.mjs +11 -3
  10. package/esm2020/lib/components/private/form-statistics/filter-form-statistic/filter-form-statistic.component.mjs +11 -2
  11. package/esm2020/lib/components/private/graphs/graphs.component.mjs +12 -3
  12. package/esm2020/lib/models/form.model.mjs +1 -1
  13. package/esm2020/lib/models/trigger.model.mjs +14 -1
  14. package/fesm2015/eqproject-eqp-dynamic-module.mjs +357 -58
  15. package/fesm2015/eqproject-eqp-dynamic-module.mjs.map +1 -1
  16. package/fesm2020/eqproject-eqp-dynamic-module.mjs +357 -58
  17. package/fesm2020/eqproject-eqp-dynamic-module.mjs.map +1 -1
  18. package/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.d.ts +5 -2
  19. package/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.d.ts +33 -1
  20. package/lib/components/private/form-records/add-form-record/add-form-record.component.d.ts +7 -2
  21. package/lib/components/private/form-records/hlist-form-record/hlist-form-record.component.d.ts +5 -1
  22. package/lib/components/private/form-records/list-form-record/list-form-record.component.d.ts +5 -1
  23. package/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.d.ts +7 -2
  24. package/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.d.ts +5 -2
  25. package/lib/components/private/form-records/view-form-record/view-form-record.component.d.ts +5 -1
  26. package/lib/components/private/form-statistics/filter-form-statistic/filter-form-statistic.component.d.ts +5 -1
  27. package/lib/components/private/graphs/graphs.component.d.ts +6 -2
  28. package/lib/models/form.model.d.ts +3 -1
  29. package/lib/models/trigger.model.d.ts +23 -0
  30. package/package.json +1 -1
@@ -11,10 +11,12 @@ export class SingleRecordComponent {
11
11
  this.pageState = 'visualizzaContenuto';
12
12
  this.showBackButton = true;
13
13
  this.onlyView = true;
14
+ this.actionButtons = new Array();
14
15
  this.saveRecordEvent = new EventEmitter();
15
16
  this.afterSaveRecordEvent = new EventEmitter();
16
17
  this.out = new EventEmitter();
17
18
  this.fireTrigger = new EventEmitter();
19
+ this.fireAction = new EventEmitter();
18
20
  this.loaded = false;
19
21
  }
20
22
  ngOnInit() {
@@ -39,12 +41,15 @@ export class SingleRecordComponent {
39
41
  onFireTrigger(ev) {
40
42
  this.fireTrigger.emit(ev);
41
43
  }
44
+ onFireAction(ev) {
45
+ this.fireAction.emit(ev);
46
+ }
42
47
  }
43
48
  SingleRecordComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SingleRecordComponent, deps: [{ token: i1.UtilityHelperService }], target: i0.ɵɵFactoryTarget.Component });
44
- SingleRecordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: SingleRecordComponent, selector: "lib-single-record", inputs: { endPointConfiguration: "endPointConfiguration", record: "record", pageState: "pageState", userID: "userID", form: "form", showBackButton: "showBackButton", outCompileConfigurations: "outCompileConfigurations", onlyView: "onlyView", QueryEditorComponent: "QueryEditorComponent" }, outputs: { saveRecordEvent: "saveRecordEvent", afterSaveRecordEvent: "afterSaveRecordEvent", out: "out", fireTrigger: "fireTrigger" }, ngImport: i0, template: "<ng-container *ngIf=\"loaded && record && pageState\">\r\n\r\n <!--#region VISUALIZZA CONTENUTO -->\r\n <ng-container *ngIf=\"pageState == 'visualizzaContenuto'\">\r\n <view-form-record \r\n [endPointConfiguration]=\"endPointConfiguration\"\r\n [record]=\"record\" \r\n [showBackButton]=\"false\">\r\n </view-form-record>\r\n </ng-container>\r\n <!--#endregion VISUALIZZA CONTENUTO -->\r\n\r\n <!--#region MODIFICA RISPOSTA -->\r\n <ng-container *ngIf=\"pageState == 'modificaContenuto'\">\r\n <add-form-record\r\n [onlyView]=\"onlyView\"\r\n [form]=\"form\"\r\n [userID]=\"userID\"\r\n [record]=\"record\"\r\n\r\n [QueryEditorComponent]=\"QueryEditorComponent\"\r\n [configurations]=\"outCompileConfigurations\"\r\n [endPointConfiguration]=\"endPointConfiguration\"\r\n\r\n (out)=\"onExternalComponentOut($event)\"\r\n (saveRecordEvent)=\"saveOrExitForm($event)\"\r\n (afterSaveRecordEvent)=\"onAfterSaveRecord($event)\"\r\n (fireTrigger)=\"onFireTrigger($event)\"\r\n >\r\n </add-form-record>\r\n </ng-container>\r\n <!--#endregion MODIFICA RISPOSTA -->\r\n\r\n</ng-container>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.AddFormRecordComponent, selector: "add-form-record", inputs: ["configurations", "endPointConfiguration", "userID", "orgaID", "formID", "form", "record", "onlyView", "isDuplicate", "inConfig", "showAllFields", "showTitle", "QueryEditorComponent"], outputs: ["saveRecordEvent", "afterSaveRecordEvent", "out", "fireTrigger"] }, { kind: "component", type: i4.ViewFormRecordComponent, selector: "view-form-record", inputs: ["endPointConfiguration", "record", "showBackButton"], outputs: ["goBackEvent"] }] });
49
+ SingleRecordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: SingleRecordComponent, selector: "lib-single-record", inputs: { endPointConfiguration: "endPointConfiguration", record: "record", pageState: "pageState", userID: "userID", form: "form", showBackButton: "showBackButton", outCompileConfigurations: "outCompileConfigurations", onlyView: "onlyView", actionButtons: "actionButtons", QueryEditorComponent: "QueryEditorComponent" }, outputs: { saveRecordEvent: "saveRecordEvent", afterSaveRecordEvent: "afterSaveRecordEvent", out: "out", fireTrigger: "fireTrigger", fireAction: "fireAction" }, ngImport: i0, template: "<ng-container *ngIf=\"loaded && record && pageState\">\r\n\r\n <!--#region VISUALIZZA CONTENUTO -->\r\n <ng-container *ngIf=\"pageState == 'visualizzaContenuto'\">\r\n <view-form-record \r\n [endPointConfiguration]=\"endPointConfiguration\"\r\n [record]=\"record\" \r\n [actionButtons]=\"actionButtons\"\r\n [showBackButton]=\"false\"\r\n (fireAction)=\"onFireAction($event)\"\r\n >\r\n </view-form-record>\r\n </ng-container>\r\n <!--#endregion VISUALIZZA CONTENUTO -->\r\n\r\n <!--#region MODIFICA RISPOSTA -->\r\n <ng-container *ngIf=\"pageState == 'modificaContenuto'\">\r\n <add-form-record\r\n [onlyView]=\"onlyView\"\r\n [form]=\"form\"\r\n [userID]=\"userID\"\r\n [record]=\"record\"\r\n [actionButtons]=\"actionButtons\"\r\n\r\n [QueryEditorComponent]=\"QueryEditorComponent\"\r\n [configurations]=\"outCompileConfigurations\"\r\n [endPointConfiguration]=\"endPointConfiguration\"\r\n\r\n (out)=\"onExternalComponentOut($event)\"\r\n (saveRecordEvent)=\"saveOrExitForm($event)\"\r\n (afterSaveRecordEvent)=\"onAfterSaveRecord($event)\"\r\n (fireTrigger)=\"onFireTrigger($event)\"\r\n (fireAction)=\"onFireAction($event)\"\r\n >\r\n </add-form-record>\r\n </ng-container>\r\n <!--#endregion MODIFICA RISPOSTA -->\r\n\r\n</ng-container>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.AddFormRecordComponent, selector: "add-form-record", inputs: ["configurations", "endPointConfiguration", "userID", "orgaID", "formID", "form", "record", "onlyView", "isDuplicate", "inConfig", "showAllFields", "showTitle", "actionButtons", "QueryEditorComponent"], outputs: ["saveRecordEvent", "afterSaveRecordEvent", "out", "fireTrigger", "fireAction"] }, { kind: "component", type: i4.ViewFormRecordComponent, selector: "view-form-record", inputs: ["endPointConfiguration", "record", "showBackButton", "actionButtons"], outputs: ["goBackEvent", "fireAction"] }] });
45
50
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: SingleRecordComponent, decorators: [{
46
51
  type: Component,
47
- args: [{ selector: 'lib-single-record', template: "<ng-container *ngIf=\"loaded && record && pageState\">\r\n\r\n <!--#region VISUALIZZA CONTENUTO -->\r\n <ng-container *ngIf=\"pageState == 'visualizzaContenuto'\">\r\n <view-form-record \r\n [endPointConfiguration]=\"endPointConfiguration\"\r\n [record]=\"record\" \r\n [showBackButton]=\"false\">\r\n </view-form-record>\r\n </ng-container>\r\n <!--#endregion VISUALIZZA CONTENUTO -->\r\n\r\n <!--#region MODIFICA RISPOSTA -->\r\n <ng-container *ngIf=\"pageState == 'modificaContenuto'\">\r\n <add-form-record\r\n [onlyView]=\"onlyView\"\r\n [form]=\"form\"\r\n [userID]=\"userID\"\r\n [record]=\"record\"\r\n\r\n [QueryEditorComponent]=\"QueryEditorComponent\"\r\n [configurations]=\"outCompileConfigurations\"\r\n [endPointConfiguration]=\"endPointConfiguration\"\r\n\r\n (out)=\"onExternalComponentOut($event)\"\r\n (saveRecordEvent)=\"saveOrExitForm($event)\"\r\n (afterSaveRecordEvent)=\"onAfterSaveRecord($event)\"\r\n (fireTrigger)=\"onFireTrigger($event)\"\r\n >\r\n </add-form-record>\r\n </ng-container>\r\n <!--#endregion MODIFICA RISPOSTA -->\r\n\r\n</ng-container>" }]
52
+ args: [{ selector: 'lib-single-record', template: "<ng-container *ngIf=\"loaded && record && pageState\">\r\n\r\n <!--#region VISUALIZZA CONTENUTO -->\r\n <ng-container *ngIf=\"pageState == 'visualizzaContenuto'\">\r\n <view-form-record \r\n [endPointConfiguration]=\"endPointConfiguration\"\r\n [record]=\"record\" \r\n [actionButtons]=\"actionButtons\"\r\n [showBackButton]=\"false\"\r\n (fireAction)=\"onFireAction($event)\"\r\n >\r\n </view-form-record>\r\n </ng-container>\r\n <!--#endregion VISUALIZZA CONTENUTO -->\r\n\r\n <!--#region MODIFICA RISPOSTA -->\r\n <ng-container *ngIf=\"pageState == 'modificaContenuto'\">\r\n <add-form-record\r\n [onlyView]=\"onlyView\"\r\n [form]=\"form\"\r\n [userID]=\"userID\"\r\n [record]=\"record\"\r\n [actionButtons]=\"actionButtons\"\r\n\r\n [QueryEditorComponent]=\"QueryEditorComponent\"\r\n [configurations]=\"outCompileConfigurations\"\r\n [endPointConfiguration]=\"endPointConfiguration\"\r\n\r\n (out)=\"onExternalComponentOut($event)\"\r\n (saveRecordEvent)=\"saveOrExitForm($event)\"\r\n (afterSaveRecordEvent)=\"onAfterSaveRecord($event)\"\r\n (fireTrigger)=\"onFireTrigger($event)\"\r\n (fireAction)=\"onFireAction($event)\"\r\n >\r\n </add-form-record>\r\n </ng-container>\r\n <!--#endregion MODIFICA RISPOSTA -->\r\n\r\n</ng-container>" }]
48
53
  }], ctorParameters: function () { return [{ type: i1.UtilityHelperService }]; }, propDecorators: { endPointConfiguration: [{
49
54
  type: Input
50
55
  }], record: [{
@@ -61,6 +66,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
61
66
  type: Input
62
67
  }], onlyView: [{
63
68
  type: Input
69
+ }], actionButtons: [{
70
+ type: Input
64
71
  }], QueryEditorComponent: [{
65
72
  type: Input
66
73
  }], saveRecordEvent: [{
@@ -71,5 +78,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
71
78
  type: Output
72
79
  }], fireTrigger: [{
73
80
  type: Output
81
+ }], fireAction: [{
82
+ type: Output
74
83
  }] } });
75
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"single-record.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.ts","../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAO/E,OAAO,EAAE,aAAa,EAAE,MAAM,wCAAwC,CAAC;;;;;;AAWvE,MAAM,OAAO,qBAAqB;IAoBhC,YACU,oBAA0C;QAA1C,yBAAoB,GAApB,oBAAoB,CAAsB;QAjB3C,cAAS,GAAc,qBAAqB,CAAC;QAG7C,mBAAc,GAAG,IAAI,CAAC;QAEtB,aAAQ,GAAY,IAAI,CAAC;QAGxB,oBAAe,GAAyB,IAAI,YAAY,EAAU,CAAC;QACnE,yBAAoB,GAC5B,IAAI,YAAY,EAAU,CAAC;QACnB,QAAG,GAA2B,IAAI,YAAY,EAAY,CAAC;QAC3D,gBAAW,GAA8B,IAAI,YAAY,EAAe,CAAC;QAEnF,WAAM,GAAG,KAAK,CAAC;IAIX,CAAC;IAEL,QAAQ;QACN,IAAI,CAAC,wBAAwB,CAAC,cAAc,GAAG,KAAK,CAAC;QAErD,aAAa,CAAC,QAAQ,CAAC,0CAA0C,EAAE,IAAI,CAAC,wBAAwB,CAAC,CAAA;QACjG,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;IACrB,CAAC;IAED;;OAEG;IACH,cAAc,CAAC,MAAc;QAC3B,aAAa,CAAC,QAAQ,CAAC,+BAA+B,EAAE,MAAM,CAAC,CAAA;QAC/D,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IACD,iBAAiB,CAAC,KAAK;QACrB,aAAa,CAAC,QAAQ,CAAC,oCAAoC,EAAE,KAAK,CAAC,CAAA;QACnE,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAED,sBAAsB,CAAC,EAAY;QACjC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACpB,CAAC;IAED,aAAa,CAAC,EAAe;QAC3B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC5B,CAAC;;mHAjDU,qBAAqB;uGAArB,qBAAqB,keClBlC,ixCAiCe;4FDfF,qBAAqB;kBALjC,SAAS;+BACE,mBAAmB;2GAMpB,qBAAqB;sBAA7B,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,wBAAwB;sBAAhC,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBAEI,eAAe;sBAAxB,MAAM;gBACG,oBAAoB;sBAA7B,MAAM;gBAEG,GAAG;sBAAZ,MAAM;gBACG,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { DynamicModuleCompileConfig } from '../../../../../models/dynamicModuleCompileConfig.model';\r\nimport { EndPointConfiguration, EndPointDataParams, ParamTypeEnum } from '../../../../../models/endPointConfiguration.model';\r\nimport { Form } from '../../../../../models/form.model';\r\nimport { DynRecord, Record } from \"../../../../../models/record.model\";\r\nimport { UtilityHelperService } from '../../../../../services/utilityHelper.services';\r\nimport { single } from 'rxjs';\r\nimport { GlobalService } from '../../../../../services/global.service';\r\nimport { DynamicLoaderDirectiveData, eventOut } from '../../../../../directives/dynamic-loader/dynamic-loader.directive';\r\nimport { FireTrigger } from '../../../../../models/trigger.model';\r\n\r\ntype PageState = null | 'visualizzaContenuto' | 'modificaContenuto'\r\n\r\n@Component({\r\n  selector: 'lib-single-record',\r\n  templateUrl: './single-record.component.html',\r\n  styleUrls: ['./single-record.component.scss']\r\n})\r\nexport class SingleRecordComponent implements OnInit {\r\n  \r\n  @Input() endPointConfiguration: EndPointConfiguration;\r\n  @Input() record;\r\n  @Input() pageState: PageState = 'visualizzaContenuto';\r\n  @Input() userID: string;\r\n  @Input() form: Form;\r\n  @Input() showBackButton = true;\r\n  @Input() outCompileConfigurations: DynamicModuleCompileConfig;\r\n  @Input() onlyView: boolean = true;\r\n  @Input() QueryEditorComponent: DynamicLoaderDirectiveData; // L'intero componente query Editor\r\n\r\n  @Output() saveRecordEvent: EventEmitter<Record> = new EventEmitter<Record>();\r\n  @Output() afterSaveRecordEvent: EventEmitter<Record> =\r\n    new EventEmitter<Record>();\r\n  @Output() out: EventEmitter<eventOut> = new EventEmitter<eventOut>();\r\n  @Output() fireTrigger: EventEmitter<FireTrigger> = new EventEmitter<FireTrigger>();\r\n\r\n  loaded = false;\r\n\r\n  constructor(\r\n    private utilityHelperService: UtilityHelperService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    this.outCompileConfigurations.showBackButton = false;\r\n    \r\n    GlobalService.debugLog(\"single-record - outCompileConfigurations\", this.outCompileConfigurations)\r\n    this.loaded = true;    \r\n  }\r\n\r\n  /**\r\n   * Metodo per salvare i dati inseriti dall'utente una volta conclusa la compilazione della form.\r\n   */\r\n  saveOrExitForm(record: Record) {\r\n    GlobalService.debugLog('single-record saveRecordEvent', record)\r\n    this.saveRecordEvent.emit(record);\r\n  }\r\n  onAfterSaveRecord(event) {\r\n    GlobalService.debugLog('single-record afterSaveRecordEvent', event)\r\n    this.afterSaveRecordEvent.emit(event);\r\n  }\r\n  \r\n  onExternalComponentOut(ev: eventOut){\r\n    this.out.emit(ev);\r\n  }\r\n\r\n  onFireTrigger(ev: FireTrigger){\r\n    this.fireTrigger.emit(ev);\r\n  }\r\n\r\n  /**\r\n   * Metodo invocato quando si vuole aggiungere, visualizzare o modificare un record.\r\n   * Se l'evento è null vuol dire che stiamo aggiungendo un nuovo record altrimenti siamo in modifica\r\n   * o visualizzazione. In questi ultimi due casi, se è stato configurato un endpoint per il recupero\r\n   * del record completo allora viene effettuata una chiamata al server, altrimenti viene usato l'oggetto selezionato.\r\n   * @param event Oggetto con due proprietà:\r\n   * \"record\" = oggetto da modificare/visualizzare,\r\n   * \"onlyView\" = booleano (se TRUE siamo in visualizzazione altrimenti in modifica)\r\n   */\r\n  // onAddViewEditRecord2(event: { record: Record; onlyView: boolean }) {\r\n  //   this.loaded = false;\r\n  //   this.record = null;\r\n\r\n  //   this.onlyView = event.onlyView;\r\n\r\n  //   this.outCompileConfigurations.showBackButton = false;\r\n  //   this.outCompileConfigurations.showSaveButton = !event.onlyView;\r\n  //   this.outCompileConfigurations.showTitle = false;\r\n\r\n  //   if (event != null) {\r\n  //     if (\r\n  //       this.endPointConfiguration &&\r\n  //       this.endPointConfiguration.Records &&\r\n  //       this.endPointConfiguration.Records.GetByIDEndPoint\r\n  //     ) {\r\n  //       // preparo la versione corretta del form\r\n  //       var dynamicModuleParams = [\r\n  //         {\r\n  //           ParamName: \"EntID\",\r\n  //           ParamValue: event.record.EntID,\r\n  //           ParamType: ParamTypeEnum[\"Query param\"],\r\n  //         },\r\n  //         {\r\n  //           ParamName: \"Version\",\r\n  //           ParamValue: event.record.Version,\r\n  //           ParamType: ParamTypeEnum[\"Query param\"],\r\n  //         },\r\n  //       ];\r\n  //       this.utilityHelperService.RunEndPointCall(\r\n  //         this.endPointConfiguration.Forms.GetByIDAndVersionEndPoint,\r\n  //         dynamicModuleParams,\r\n  //         (res: Form) => {\r\n  //           this.form = res;\r\n\r\n  //           // preparo i dati del record\r\n  //           var dynamicRecordParams = [\r\n  //             {\r\n  //               ParamName: \"id\",\r\n  //               ParamValue: event.record.ID,\r\n  //               ParamType: ParamTypeEnum[\"Query param\"],\r\n  //             },\r\n  //           ];\r\n  //           this.utilityHelperService.RunEndPointCall(\r\n  //             this.endPointConfiguration.Records.GetByIDEndPoint,\r\n  //             dynamicRecordParams,\r\n  //             (res: DynRecord) => {\r\n  //               this.record = JSON.parse(res.SerializedValues);\r\n  //               this.record.ID = res.ID;\r\n  //               this.record.EntID = res.EntID;\r\n  //               this.record.userID = res.userID;\r\n  //               this.record.Version = res.Version;\r\n  //               this.record.HTMLreadableValues = res.HTMLreadableValues\r\n\r\n  //               this.loaded = true;\r\n  //             }\r\n  //           );\r\n  //         }\r\n  //       );\r\n  //     } else {\r\n  //       this.record = JSON.parse(JSON.stringify(event.record));\r\n  //       this.loaded = true;\r\n  //     }\r\n  //   } else {\r\n  //     const dynamicModuleParams: Array<EndPointDataParams> =\r\n  //       new Array<EndPointDataParams>();\r\n  //     dynamicModuleParams.push({\r\n  //       ParamName: \"id\",\r\n  //       ParamValue: this.form.ID,\r\n  //       ParamType: ParamTypeEnum[\"Query param\"],\r\n  //     });\r\n  //     this.utilityHelperService.RunEndPointCall(\r\n  //       this.endPointConfiguration.Forms.GetByIDEndPoint,\r\n  //       dynamicModuleParams,\r\n  //       (res: Form) => {\r\n  //         this.form = res;\r\n  //         this.record = null;\r\n  //         this.onlyView = false;\r\n  //         this.loaded = true;\r\n  //       },\r\n  //       (err) => {}\r\n  //     );\r\n\r\n  //     // this.record = null;\r\n  //     // this.onlyView = false;\r\n  //     // this.viewMode = DynamicModuleViewModeEnum.COMPILE;\r\n  //   }\r\n  // }\r\n  \r\n}\r\n","<ng-container *ngIf=\"loaded && record && pageState\">\r\n\r\n    <!--#region VISUALIZZA CONTENUTO -->\r\n    <ng-container *ngIf=\"pageState == 'visualizzaContenuto'\">\r\n        <view-form-record \r\n            [endPointConfiguration]=\"endPointConfiguration\"\r\n            [record]=\"record\" \r\n            [showBackButton]=\"false\">\r\n        </view-form-record>\r\n    </ng-container>\r\n    <!--#endregion VISUALIZZA CONTENUTO -->\r\n\r\n    <!--#region MODIFICA RISPOSTA -->\r\n    <ng-container *ngIf=\"pageState == 'modificaContenuto'\">\r\n        <add-form-record\r\n            [onlyView]=\"onlyView\"\r\n            [form]=\"form\"\r\n            [userID]=\"userID\"\r\n            [record]=\"record\"\r\n\r\n            [QueryEditorComponent]=\"QueryEditorComponent\"\r\n            [configurations]=\"outCompileConfigurations\"\r\n            [endPointConfiguration]=\"endPointConfiguration\"\r\n\r\n            (out)=\"onExternalComponentOut($event)\"\r\n            (saveRecordEvent)=\"saveOrExitForm($event)\"\r\n            (afterSaveRecordEvent)=\"onAfterSaveRecord($event)\"\r\n            (fireTrigger)=\"onFireTrigger($event)\"\r\n            >\r\n        </add-form-record>\r\n    </ng-container>\r\n    <!--#endregion MODIFICA RISPOSTA -->\r\n\r\n</ng-container>"]}
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"single-record.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.ts","../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAM/E,OAAO,EAAE,aAAa,EAAE,MAAM,wCAAwC,CAAC;;;;;;AAWvE,MAAM,OAAO,qBAAqB;IAsBhC,YACU,oBAA0C;QAA1C,yBAAoB,GAApB,oBAAoB,CAAsB;QAnB3C,cAAS,GAAc,qBAAqB,CAAC;QAG7C,mBAAc,GAAG,IAAI,CAAC;QAEtB,aAAQ,GAAY,IAAI,CAAC;QACzB,kBAAa,GAAwB,IAAI,KAAK,EAAgB,CAAC;QAG9D,oBAAe,GAAyB,IAAI,YAAY,EAAU,CAAC;QACnE,yBAAoB,GAC5B,IAAI,YAAY,EAAU,CAAC;QACnB,QAAG,GAA2B,IAAI,YAAY,EAAY,CAAC;QAC3D,gBAAW,GAA8B,IAAI,YAAY,EAAe,CAAC;QACzE,eAAU,GAA6B,IAAI,YAAY,EAAc,CAAC;QAEhF,WAAM,GAAG,KAAK,CAAC;IAIX,CAAC;IAEL,QAAQ;QACN,IAAI,CAAC,wBAAwB,CAAC,cAAc,GAAG,KAAK,CAAC;QAErD,aAAa,CAAC,QAAQ,CAAC,0CAA0C,EAAE,IAAI,CAAC,wBAAwB,CAAC,CAAA;QACjG,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;IACrB,CAAC;IAED;;OAEG;IACH,cAAc,CAAC,MAAc;QAC3B,aAAa,CAAC,QAAQ,CAAC,+BAA+B,EAAE,MAAM,CAAC,CAAA;QAC/D,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IACD,iBAAiB,CAAC,KAAK;QACrB,aAAa,CAAC,QAAQ,CAAC,oCAAoC,EAAE,KAAK,CAAC,CAAA;QACnE,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAED,sBAAsB,CAAC,EAAY;QACjC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACpB,CAAC;IAED,aAAa,CAAC,EAAe;QAC3B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC5B,CAAC;IAED,YAAY,CAAC,EAAc;QACzB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC3B,CAAC;;mHAvDU,qBAAqB;uGAArB,qBAAqB,4hBCjBlC,6+CAsCe;4FDrBF,qBAAqB;kBALjC,SAAS;+BACE,mBAAmB;2GAMpB,qBAAqB;sBAA7B,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,wBAAwB;sBAAhC,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBAEI,eAAe;sBAAxB,MAAM;gBACG,oBAAoB;sBAA7B,MAAM;gBAEG,GAAG;sBAAZ,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,UAAU;sBAAnB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { DynamicModuleCompileConfig } from '../../../../../models/dynamicModuleCompileConfig.model';\r\nimport { EndPointConfiguration } from '../../../../../models/endPointConfiguration.model';\r\nimport { Form } from '../../../../../models/form.model';\r\nimport { Record } from \"../../../../../models/record.model\";\r\nimport { UtilityHelperService } from '../../../../../services/utilityHelper.services';\r\nimport { GlobalService } from '../../../../../services/global.service';\r\nimport { DynamicLoaderDirectiveData, eventOut } from '../../../../../directives/dynamic-loader/dynamic-loader.directive';\r\nimport { FireTrigger, FireAction, ActionButton } from '../../../../../models/trigger.model';\r\n\r\ntype PageState = null | 'visualizzaContenuto' | 'modificaContenuto'\r\n\r\n@Component({\r\n  selector: 'lib-single-record',\r\n  templateUrl: './single-record.component.html',\r\n  styleUrls: ['./single-record.component.scss']\r\n})\r\nexport class SingleRecordComponent implements OnInit {\r\n  \r\n  @Input() endPointConfiguration: EndPointConfiguration;\r\n  @Input() record;\r\n  @Input() pageState: PageState = 'visualizzaContenuto';\r\n  @Input() userID: string;\r\n  @Input() form: Form;\r\n  @Input() showBackButton = true;\r\n  @Input() outCompileConfigurations: DynamicModuleCompileConfig;\r\n  @Input() onlyView: boolean = true;\r\n  @Input() actionButtons: Array<ActionButton> = new Array<ActionButton>();\r\n  @Input() QueryEditorComponent: DynamicLoaderDirectiveData; // L'intero componente query Editor\r\n\r\n  @Output() saveRecordEvent: EventEmitter<Record> = new EventEmitter<Record>();\r\n  @Output() afterSaveRecordEvent: EventEmitter<Record> =\r\n    new EventEmitter<Record>();\r\n  @Output() out: EventEmitter<eventOut> = new EventEmitter<eventOut>();\r\n  @Output() fireTrigger: EventEmitter<FireTrigger> = new EventEmitter<FireTrigger>();\r\n  @Output() fireAction: EventEmitter<FireAction> = new EventEmitter<FireAction>();\r\n\r\n  loaded = false;\r\n\r\n  constructor(\r\n    private utilityHelperService: UtilityHelperService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    this.outCompileConfigurations.showBackButton = false;\r\n    \r\n    GlobalService.debugLog(\"single-record - outCompileConfigurations\", this.outCompileConfigurations)\r\n    this.loaded = true;    \r\n  }\r\n\r\n  /**\r\n   * Metodo per salvare i dati inseriti dall'utente una volta conclusa la compilazione della form.\r\n   */\r\n  saveOrExitForm(record: Record) {\r\n    GlobalService.debugLog('single-record saveRecordEvent', record)\r\n    this.saveRecordEvent.emit(record);\r\n  }\r\n  onAfterSaveRecord(event) {\r\n    GlobalService.debugLog('single-record afterSaveRecordEvent', event)\r\n    this.afterSaveRecordEvent.emit(event);\r\n  }\r\n  \r\n  onExternalComponentOut(ev: eventOut){\r\n    this.out.emit(ev);\r\n  }\r\n\r\n  onFireTrigger(ev: FireTrigger){\r\n    this.fireTrigger.emit(ev);\r\n  }\r\n\r\n  onFireAction(ev: FireAction){\r\n    this.fireAction.emit(ev);\r\n  }  \r\n\r\n  /**\r\n   * Metodo invocato quando si vuole aggiungere, visualizzare o modificare un record.\r\n   * Se l'evento è null vuol dire che stiamo aggiungendo un nuovo record altrimenti siamo in modifica\r\n   * o visualizzazione. In questi ultimi due casi, se è stato configurato un endpoint per il recupero\r\n   * del record completo allora viene effettuata una chiamata al server, altrimenti viene usato l'oggetto selezionato.\r\n   * @param event Oggetto con due proprietà:\r\n   * \"record\" = oggetto da modificare/visualizzare,\r\n   * \"onlyView\" = booleano (se TRUE siamo in visualizzazione altrimenti in modifica)\r\n   */\r\n  // onAddViewEditRecord2(event: { record: Record; onlyView: boolean }) {\r\n  //   this.loaded = false;\r\n  //   this.record = null;\r\n\r\n  //   this.onlyView = event.onlyView;\r\n\r\n  //   this.outCompileConfigurations.showBackButton = false;\r\n  //   this.outCompileConfigurations.showSaveButton = !event.onlyView;\r\n  //   this.outCompileConfigurations.showTitle = false;\r\n\r\n  //   if (event != null) {\r\n  //     if (\r\n  //       this.endPointConfiguration &&\r\n  //       this.endPointConfiguration.Records &&\r\n  //       this.endPointConfiguration.Records.GetByIDEndPoint\r\n  //     ) {\r\n  //       // preparo la versione corretta del form\r\n  //       var dynamicModuleParams = [\r\n  //         {\r\n  //           ParamName: \"EntID\",\r\n  //           ParamValue: event.record.EntID,\r\n  //           ParamType: ParamTypeEnum[\"Query param\"],\r\n  //         },\r\n  //         {\r\n  //           ParamName: \"Version\",\r\n  //           ParamValue: event.record.Version,\r\n  //           ParamType: ParamTypeEnum[\"Query param\"],\r\n  //         },\r\n  //       ];\r\n  //       this.utilityHelperService.RunEndPointCall(\r\n  //         this.endPointConfiguration.Forms.GetByIDAndVersionEndPoint,\r\n  //         dynamicModuleParams,\r\n  //         (res: Form) => {\r\n  //           this.form = res;\r\n\r\n  //           // preparo i dati del record\r\n  //           var dynamicRecordParams = [\r\n  //             {\r\n  //               ParamName: \"id\",\r\n  //               ParamValue: event.record.ID,\r\n  //               ParamType: ParamTypeEnum[\"Query param\"],\r\n  //             },\r\n  //           ];\r\n  //           this.utilityHelperService.RunEndPointCall(\r\n  //             this.endPointConfiguration.Records.GetByIDEndPoint,\r\n  //             dynamicRecordParams,\r\n  //             (res: DynRecord) => {\r\n  //               this.record = JSON.parse(res.SerializedValues);\r\n  //               this.record.ID = res.ID;\r\n  //               this.record.EntID = res.EntID;\r\n  //               this.record.userID = res.userID;\r\n  //               this.record.Version = res.Version;\r\n  //               this.record.HTMLreadableValues = res.HTMLreadableValues\r\n\r\n  //               this.loaded = true;\r\n  //             }\r\n  //           );\r\n  //         }\r\n  //       );\r\n  //     } else {\r\n  //       this.record = JSON.parse(JSON.stringify(event.record));\r\n  //       this.loaded = true;\r\n  //     }\r\n  //   } else {\r\n  //     const dynamicModuleParams: Array<EndPointDataParams> =\r\n  //       new Array<EndPointDataParams>();\r\n  //     dynamicModuleParams.push({\r\n  //       ParamName: \"id\",\r\n  //       ParamValue: this.form.ID,\r\n  //       ParamType: ParamTypeEnum[\"Query param\"],\r\n  //     });\r\n  //     this.utilityHelperService.RunEndPointCall(\r\n  //       this.endPointConfiguration.Forms.GetByIDEndPoint,\r\n  //       dynamicModuleParams,\r\n  //       (res: Form) => {\r\n  //         this.form = res;\r\n  //         this.record = null;\r\n  //         this.onlyView = false;\r\n  //         this.loaded = true;\r\n  //       },\r\n  //       (err) => {}\r\n  //     );\r\n\r\n  //     // this.record = null;\r\n  //     // this.onlyView = false;\r\n  //     // this.viewMode = DynamicModuleViewModeEnum.COMPILE;\r\n  //   }\r\n  // }\r\n  \r\n}\r\n","<ng-container *ngIf=\"loaded && record && pageState\">\r\n\r\n    <!--#region VISUALIZZA CONTENUTO -->\r\n    <ng-container *ngIf=\"pageState == 'visualizzaContenuto'\">\r\n        <view-form-record \r\n            [endPointConfiguration]=\"endPointConfiguration\"\r\n            [record]=\"record\" \r\n            [actionButtons]=\"actionButtons\"\r\n            [showBackButton]=\"false\"\r\n            (fireAction)=\"onFireAction($event)\"\r\n            >\r\n        </view-form-record>\r\n    </ng-container>\r\n    <!--#endregion VISUALIZZA CONTENUTO -->\r\n\r\n    <!--#region MODIFICA RISPOSTA -->\r\n    <ng-container *ngIf=\"pageState == 'modificaContenuto'\">\r\n        <add-form-record\r\n            [onlyView]=\"onlyView\"\r\n            [form]=\"form\"\r\n            [userID]=\"userID\"\r\n            [record]=\"record\"\r\n            [actionButtons]=\"actionButtons\"\r\n\r\n            [QueryEditorComponent]=\"QueryEditorComponent\"\r\n            [configurations]=\"outCompileConfigurations\"\r\n            [endPointConfiguration]=\"endPointConfiguration\"\r\n\r\n            (out)=\"onExternalComponentOut($event)\"\r\n            (saveRecordEvent)=\"saveOrExitForm($event)\"\r\n            (afterSaveRecordEvent)=\"onAfterSaveRecord($event)\"\r\n            (fireTrigger)=\"onFireTrigger($event)\"\r\n            (fireAction)=\"onFireAction($event)\"\r\n            >\r\n        </add-form-record>\r\n    </ng-container>\r\n    <!--#endregion MODIFICA RISPOSTA -->\r\n\r\n</ng-container>"]}
@@ -8,17 +8,18 @@ import * as i1 from "../../../../services/utilityHelper.services";
8
8
  import * as i2 from "@angular/platform-browser";
9
9
  import * as i3 from "@angular/material/button";
10
10
  import * as i4 from "@angular/common";
11
- // import { DynamicModuleFieldComponent } from '../../dynamic-module-field/dynamic-module-field.component';
12
11
  export class ViewFormRecordComponent {
13
12
  constructor(utilityService, domSanitizer) {
14
13
  this.utilityService = utilityService;
15
14
  this.domSanitizer = domSanitizer;
16
15
  this.showBackButton = true;
16
+ this.actionButtons = new Array();
17
17
  this.outputString = "";
18
18
  this.loader = false;
19
19
  // per controllare che il campo non sia una scelta multipla
20
20
  this.FieldTypeEnum = FieldTypeEnum;
21
21
  this.goBackEvent = new EventEmitter();
22
+ this.fireAction = new EventEmitter();
22
23
  }
23
24
  ngOnInit() {
24
25
  GlobalService.debugLog('this.record', this.record);
@@ -86,6 +87,9 @@ export class ViewFormRecordComponent {
86
87
  this.createOutput();
87
88
  });
88
89
  }
90
+ onFireAction(ev) {
91
+ this.fireAction.emit(ev);
92
+ }
89
93
  /**
90
94
  * Metodo per creare il FormGroup che rappresenta la form.
91
95
  */
@@ -106,7 +110,7 @@ export class ViewFormRecordComponent {
106
110
  }
107
111
  }
108
112
  ViewFormRecordComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ViewFormRecordComponent, deps: [{ token: i1.UtilityHelperService }, { token: i2.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
109
- ViewFormRecordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ViewFormRecordComponent, selector: "view-form-record", inputs: { endPointConfiguration: "endPointConfiguration", record: "record", showBackButton: "showBackButton" }, outputs: { goBackEvent: "goBackEvent" }, viewQueries: [{ propertyName: "fieldTemplate", predicate: ["fieldTemplate"], descendants: true }], ngImport: i0, template: "<div *ngIf=\"loader\">\r\n <div id=\"output-string\" [innerHTML]=\"outputString\"></div>\r\n <div class=\"row mt-2\" *ngIf=\"showBackButton\">\r\n <div class=\"col-sm-12 text-right\">\r\n <button\r\n class=\"mr-2\"\r\n mat-raised-button\r\n color=\"primary\"\r\n type=\"button\"\r\n (click)=\"goBack()\"\r\n >\r\n Indietro\r\n </button>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "component", type: i3.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
113
+ ViewFormRecordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ViewFormRecordComponent, selector: "view-form-record", inputs: { endPointConfiguration: "endPointConfiguration", record: "record", showBackButton: "showBackButton", actionButtons: "actionButtons" }, outputs: { goBackEvent: "goBackEvent", fireAction: "fireAction" }, viewQueries: [{ propertyName: "fieldTemplate", predicate: ["fieldTemplate"], descendants: true }], ngImport: i0, template: "<div *ngIf=\"loader\">\r\n <div id=\"output-string\" [innerHTML]=\"outputString\"></div>\r\n <div class=\"row mt-2\" *ngIf=\"showBackButton\">\r\n <div class=\"col-sm-12 text-right\">\r\n <button\r\n class=\"mr-2\"\r\n mat-raised-button\r\n color=\"primary\"\r\n type=\"button\"\r\n (click)=\"goBack()\"\r\n >\r\n Indietro\r\n </button>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "component", type: i3.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
110
114
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ViewFormRecordComponent, decorators: [{
111
115
  type: Component,
112
116
  args: [{ selector: "view-form-record", template: "<div *ngIf=\"loader\">\r\n <div id=\"output-string\" [innerHTML]=\"outputString\"></div>\r\n <div class=\"row mt-2\" *ngIf=\"showBackButton\">\r\n <div class=\"col-sm-12 text-right\">\r\n <button\r\n class=\"mr-2\"\r\n mat-raised-button\r\n color=\"primary\"\r\n type=\"button\"\r\n (click)=\"goBack()\"\r\n >\r\n Indietro\r\n </button>\r\n </div>\r\n </div>\r\n</div>\r\n" }]
@@ -116,10 +120,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
116
120
  type: Input
117
121
  }], showBackButton: [{
118
122
  type: Input
123
+ }], actionButtons: [{
124
+ type: Input
119
125
  }], goBackEvent: [{
120
126
  type: Output
127
+ }], fireAction: [{
128
+ type: Output
121
129
  }], fieldTemplate: [{
122
130
  type: ViewChildren,
123
131
  args: ["fieldTemplate"]
124
132
  }] } });
125
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view-form-record.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-records/view-form-record/view-form-record.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-records/view-form-record/view-form-record.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  QueryList,\r\n  ViewChildren,\r\n} from \"@angular/core\";\r\nimport { UntypedFormGroup } from \"@angular/forms\";\r\nimport { DynamicModuleCompileConfig } from \"../../../../models/dynamicModuleCompileConfig.model\";\r\nimport { BaseField, FieldTypeEnum } from \"../../../../models/baseField.model\";\r\nimport { Form, FormScalarTypeEnum } from \"../../../../models/form.model\";\r\nimport { DynRecord, Record } from \"../../../../models/record.model\";\r\nimport { UtilityHelperService } from \"../../../../services/utilityHelper.services\";\r\nimport { DynamicModuleFieldFixComponent } from \"../../dynamic-module-field-fix/dynamic-module-field.component\";\r\nimport {\r\n  EndPointConfiguration,\r\n  ParamTypeEnum,\r\n} from \"./../../../../models/endPointConfiguration.model\";\r\nimport { ListValueField } from \"./../../../../models/fields/listValueField.model\";\r\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\r\nimport { GlobalService } from \"../../../../services/global.service\";\r\n// import { DynamicModuleFieldComponent } from '../../dynamic-module-field/dynamic-module-field.component';\r\n\r\n@Component({\r\n  selector: \"view-form-record\",\r\n  templateUrl: \"./view-form-record.component.html\",\r\n  styleUrls: [\"./view-form-record.component.scss\"],\r\n})\r\nexport class ViewFormRecordComponent implements OnInit {\r\n\r\n  @Input() endPointConfiguration: EndPointConfiguration;\r\n  @Input() record: string | DynRecord;\r\n  @Input() showBackButton = true;\r\n\r\n  outputString: SafeHtml  = \"\";\r\n  form: Form;\r\n  loader: boolean = false;\r\n  // per controllare che il campo non sia una scelta multipla\r\n  FieldTypeEnum = FieldTypeEnum;\r\n\r\n  @Output() goBackEvent: EventEmitter<null> = new EventEmitter<null>();\r\n\r\n  @ViewChildren(\"fieldTemplate\")\r\n  fieldTemplate: QueryList<DynamicModuleFieldFixComponent>;\r\n\r\n  constructor(\r\n    public utilityService: UtilityHelperService,\r\n    public domSanitizer: DomSanitizer) {}\r\n\r\n  ngOnInit(): void {\r\n    GlobalService.debugLog('this.record', this.record)\r\n    if (typeof this.record === \"string\") {\r\n      // allora è un ID\r\n      this.getRecordByID();\r\n    } else {\r\n      // il record viene passato come tale\r\n      // (<Record>this.record).EntID = \"3\";\r\n      // (<Record>this.record).Version;\r\n      // this.getFormByIDandVersion();\r\n      this.createOutput()\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per salvare i dati inseriti dall'utente una volta conclusa la compilazione della form.\r\n   */\r\n  goBack() {\r\n    this.goBackEvent.emit();\r\n  }\r\n\r\n  // ci entro solo se è stato passato il parametro \"record\" come stringa\r\n  getRecordByID() {\r\n    // preparo i dati del record\r\n    var dynamicRecordParams = [\r\n      {\r\n        ParamName: \"id\",\r\n        ParamValue: this.record,\r\n        ParamType: ParamTypeEnum[\"Query param\"],\r\n      },\r\n    ];\r\n    this.utilityService.RunEndPointCall(\r\n      this.endPointConfiguration.Records.GetByIDEndPoint,\r\n      dynamicRecordParams,\r\n      (res: DynRecord) => {\r\n        this.record = new DynRecord();\r\n\r\n        (<Record>this.record) = JSON.parse(res.SerializedValues);\r\n        this.record.ID = res.ID;\r\n        this.record.EntID = res.EntID;\r\n        this.record.userID = res.userID;\r\n        this.record.Version = res.Version;\r\n        this.record.Values = JSON.parse(res.SerializedValues);\r\n        this.record.HTMLreadableValues = res.HTMLreadableValues;\r\n        // this.viewMode = DynamicModuleViewModeEnum.COMPILE;\r\n        // this.loader = true;\r\n        GlobalService.debugLog(\"record\", this.record);\r\n        this.createOutput()\r\n        // this.getFormByIDandVersion();\r\n      }\r\n    );\r\n  }\r\n  getFormByIDandVersion() {\r\n    // preparo la versione corretta del form\r\n    var dynamicModuleParams = [\r\n      {\r\n        ParamName: \"EntID\",\r\n        ParamValue: (<DynRecord>this.record).EntID,\r\n        ParamType: ParamTypeEnum[\"Query param\"],\r\n      },\r\n      {\r\n        ParamName: \"Version\",\r\n        ParamValue: (<DynRecord>this.record).Version,\r\n        ParamType: ParamTypeEnum[\"Query param\"],\r\n      },\r\n    ];\r\n    this.utilityService.RunEndPointCall(\r\n      this.endPointConfiguration.Forms.GetByIDAndVersionEndPoint,\r\n      dynamicModuleParams,\r\n      (res: Form) => {\r\n        this.form = res;\r\n        GlobalService.debugLog(\"form\", this.form);\r\n        this.createOutput();\r\n      }\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Metodo per creare il FormGroup che rappresenta la form.\r\n   */\r\n  private createOutput() {\r\n    this.outputString = this.domSanitizer.bypassSecurityTrustHtml((<DynRecord>this.record).HTMLreadableValues);\r\n    this.loader = true;\r\n    return\r\n    // let outputValuesArray: Array<any> = this.getResponseValues(<DynRecord>this.record, this.form);\r\n    // GlobalService.debugLog(\"outputValuesArray\", outputValuesArray);\r\n    \r\n    // let template: string = this.getResponseTemplate(this.form); // oggetto nel quale viene costruito il template o che prende il valore da un template esterno\r\n    // GlobalService.debugLog(\"template\", template);\r\n\r\n    // const regex = /##([\\w]+)##/g;\r\n    // const outputString = this.replaceTemplatePlaceholdersWithValues(template, outputValuesArray, regex); // oggetto che conterrà l'output elaborato    \r\n    // this.outputString = this.domSanitizer.bypassSecurityTrustHtml(outputString);\r\n    // GlobalService.debugLog(\"outputString\", this.outputString);\r\n\r\n    // STAMPO A SCHERMO\r\n    // this.loader = true;\r\n  }\r\n\r\n  // private getResponseValues(record: Record, form: Form ): Array<any> {\r\n  //   let outputValuesArray: Array<any> = []; // array con i valori delle risposte\r\n  //   //(<DynRecord>this.record).Values è la lista di oggetti {fieldName: valore}\r\n  //   for (let fieldName in (record).Values) {\r\n  //     try {\r\n  //       // fieldName è il nome del campo\r\n  //       // PREPARO VARIABILI VALORI CORRETTI\r\n  //       let foundObject = form.Fields.find(\r\n  //         (obj) => obj.Name === fieldName\r\n  //       );\r\n  //       GlobalService.debugLog(\"fieldName\", fieldName);\r\n  //       GlobalService.debugLog(\"foundObject\", foundObject);\r\n  //       // gestire caso fieldtype 8 [elenco generico]\r\n  //       // fare un eval per popolare i valuePairs se è presente una formula\r\n  //       // prendere la label corretta\r\n  //       ////////////////////////////////////////////////////////////////////////////////\r\n  //       if (foundObject.FieldType == FieldTypeEnum[\"Elenco generico\"]) \r\n  //       {\r\n  //         if (foundObject.Formula) \r\n  //         {\r\n  //           // aggiungo a valuepairs i valori calcolati\r\n  //           // (<ListValueField>foundObject).ValuePairs = {};\r\n  //           var temp = UtilityHelperService.EvaluateFieldFormula(\r\n  //             foundObject.Formula,\r\n  //             record,\r\n  //             null\r\n  //           );\r\n  //           for (let key2 in temp) {\r\n  //             if (UtilityHelperService.isNumeric(temp[key2])) \r\n  //             {\r\n  //               (<ListValueField>foundObject).ValuePairs[Number(key2)] = temp[key2];\r\n  //             } else \r\n  //             {\r\n  //               (<ListValueField>foundObject).ValuePairs[key2] = temp[key2];\r\n  //             }\r\n  //           }\r\n  //           GlobalService.debugLog(\"(record).Values[fieldName]\", (record).Values[fieldName]);\r\n  //           GlobalService.debugLog(\"(<ListValueField>foundObject).ValuePairs[(record).Values[fieldName]]\", (<ListValueField>foundObject).ValuePairs[(record).Values[fieldName]]);\r\n  //           outputValuesArray[fieldName] = (<ListValueField>foundObject).ValuePairs[(record).Values[fieldName]];\r\n  //         }\r\n  //         let inverted = {};\r\n  //         for (let key in (<ListValueField>foundObject).ValuePairs) \r\n  //         { \r\n  //           inverted[(<ListValueField>foundObject).ValuePairs[key]] = key; \r\n  //         }\r\n  //         (<ListValueField>foundObject).ValuePairs = inverted;\r\n  //         outputValuesArray[fieldName] = (<ListValueField>foundObject).ValuePairs[(record).Values[fieldName]];\r\n  //       } else \r\n  //       {\r\n  //         GlobalService.debugLog(\"(record).Values[fieldName]\", (record).Values[fieldName]);\r\n  //         outputValuesArray[fieldName] = (record).Values[fieldName];\r\n  //       }\r\n  //       ////////////////////////////////////////////////////////////////////////////////\r\n  //     } catch (e) {\r\n  //       console.error(e);\r\n  //     }\r\n  //   }\r\n  //   // cancello i valori indefiniti o nulli\r\n  //   for(const chiave in outputValuesArray){\r\n  //     if(outputValuesArray[chiave] == undefined || outputValuesArray[chiave] == null)\r\n  //     outputValuesArray[chiave] = ''\r\n  //   }\r\n  //   return outputValuesArray;\r\n  // }\r\n\r\n  // private getResponseTemplate(form: Form): string {\r\n  //   let template: string = \"\";\r\n  //   // PREPARO O PRENDO LA STRUTTURA DA STAMPARE\r\n  //   form.Fields.forEach((baseField: BaseField) => {\r\n  //     template += '<span style=\"' + baseField.LabelstyleCSS + '\">' + baseField.Description + ':</span> <span style=\"' + baseField.FieldstyleCSS + '\"> ##' + baseField.Name + '##</span> \\n <br> ';\r\n  //   });\r\n  //   // (attualmente non esiste il concetto di tempate di output)\r\n  //   return template;\r\n  // }\r\n\r\n  // private replaceTemplatePlaceholdersWithValues(template: string, outputValuesArray: Array<any>, regex): string {\r\n  //   return template.replace(regex, (match, group) => {\r\n  //     return <string>outputValuesArray[group];\r\n  //   });\r\n  // }\r\n\r\n}\r\n","<div *ngIf=\"loader\">\r\n  <div id=\"output-string\" [innerHTML]=\"outputString\"></div>\r\n  <div class=\"row mt-2\" *ngIf=\"showBackButton\">\r\n    <div class=\"col-sm-12 text-right\">\r\n      <button\r\n        class=\"mr-2\"\r\n        mat-raised-button\r\n        color=\"primary\"\r\n        type=\"button\"\r\n        (click)=\"goBack()\"\r\n      >\r\n        Indietro\r\n      </button>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view-form-record.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-records/view-form-record/view-form-record.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-records/view-form-record/view-form-record.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  QueryList,\r\n  ViewChildren,\r\n} from \"@angular/core\";\r\nimport { FieldTypeEnum } from \"../../../../models/baseField.model\";\r\nimport { Form } from \"../../../../models/form.model\";\r\nimport { DynRecord, Record } from \"../../../../models/record.model\";\r\nimport { UtilityHelperService } from \"../../../../services/utilityHelper.services\";\r\nimport { DynamicModuleFieldFixComponent } from \"../../dynamic-module-field-fix/dynamic-module-field.component\";\r\nimport {\r\n  EndPointConfiguration,\r\n  ParamTypeEnum,\r\n} from \"./../../../../models/endPointConfiguration.model\";\r\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\r\nimport { GlobalService } from \"../../../../services/global.service\";\r\nimport { ActionButton, FireAction } from '../../../../models/trigger.model';\r\n\r\n@Component({\r\n  selector: \"view-form-record\",\r\n  templateUrl: \"./view-form-record.component.html\",\r\n  styleUrls: [\"./view-form-record.component.scss\"],\r\n})\r\nexport class ViewFormRecordComponent implements OnInit {\r\n\r\n  @Input() endPointConfiguration: EndPointConfiguration;\r\n  @Input() record: string | DynRecord;\r\n  @Input() showBackButton = true;\r\n  @Input() actionButtons: Array<ActionButton> = new Array<ActionButton>();\r\n\r\n  outputString: SafeHtml  = \"\";\r\n  form: Form;\r\n  loader: boolean = false;\r\n  // per controllare che il campo non sia una scelta multipla\r\n  FieldTypeEnum = FieldTypeEnum;\r\n\r\n  @Output() goBackEvent: EventEmitter<null> = new EventEmitter<null>();\r\n  @Output() fireAction: EventEmitter<FireAction> = new EventEmitter<FireAction>();\r\n\r\n  @ViewChildren(\"fieldTemplate\")\r\n  fieldTemplate: QueryList<DynamicModuleFieldFixComponent>;\r\n\r\n  constructor(\r\n    public utilityService: UtilityHelperService,\r\n    public domSanitizer: DomSanitizer) {}\r\n\r\n  ngOnInit(): void {\r\n    GlobalService.debugLog('this.record', this.record)\r\n    if (typeof this.record === \"string\") {\r\n      // allora è un ID\r\n      this.getRecordByID();\r\n    } else {\r\n      // il record viene passato come tale\r\n      // (<Record>this.record).EntID = \"3\";\r\n      // (<Record>this.record).Version;\r\n      // this.getFormByIDandVersion();\r\n      this.createOutput()\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per salvare i dati inseriti dall'utente una volta conclusa la compilazione della form.\r\n   */\r\n  goBack() {\r\n    this.goBackEvent.emit();\r\n  }\r\n\r\n  // ci entro solo se è stato passato il parametro \"record\" come stringa\r\n  getRecordByID() {\r\n    // preparo i dati del record\r\n    var dynamicRecordParams = [\r\n      {\r\n        ParamName: \"id\",\r\n        ParamValue: this.record,\r\n        ParamType: ParamTypeEnum[\"Query param\"],\r\n      },\r\n    ];\r\n    this.utilityService.RunEndPointCall(\r\n      this.endPointConfiguration.Records.GetByIDEndPoint,\r\n      dynamicRecordParams,\r\n      (res: DynRecord) => {\r\n        this.record = new DynRecord();\r\n\r\n        (<Record>this.record) = JSON.parse(res.SerializedValues);\r\n        this.record.ID = res.ID;\r\n        this.record.EntID = res.EntID;\r\n        this.record.userID = res.userID;\r\n        this.record.Version = res.Version;\r\n        this.record.Values = JSON.parse(res.SerializedValues);\r\n        this.record.HTMLreadableValues = res.HTMLreadableValues;\r\n        // this.viewMode = DynamicModuleViewModeEnum.COMPILE;\r\n        // this.loader = true;\r\n        GlobalService.debugLog(\"record\", this.record);\r\n        this.createOutput()\r\n        // this.getFormByIDandVersion();\r\n      }\r\n    );\r\n  }\r\n  getFormByIDandVersion() {\r\n    // preparo la versione corretta del form\r\n    var dynamicModuleParams = [\r\n      {\r\n        ParamName: \"EntID\",\r\n        ParamValue: (<DynRecord>this.record).EntID,\r\n        ParamType: ParamTypeEnum[\"Query param\"],\r\n      },\r\n      {\r\n        ParamName: \"Version\",\r\n        ParamValue: (<DynRecord>this.record).Version,\r\n        ParamType: ParamTypeEnum[\"Query param\"],\r\n      },\r\n    ];\r\n    this.utilityService.RunEndPointCall(\r\n      this.endPointConfiguration.Forms.GetByIDAndVersionEndPoint,\r\n      dynamicModuleParams,\r\n      (res: Form) => {\r\n        this.form = res;\r\n        GlobalService.debugLog(\"form\", this.form);\r\n        this.createOutput();\r\n      }\r\n    );\r\n  }\r\n\r\n  onFireAction(ev: FireAction){\r\n    this.fireAction.emit(ev);\r\n  }    \r\n\r\n  /**\r\n   * Metodo per creare il FormGroup che rappresenta la form.\r\n   */\r\n  private createOutput() {\r\n    this.outputString = this.domSanitizer.bypassSecurityTrustHtml((<DynRecord>this.record).HTMLreadableValues);\r\n    this.loader = true;\r\n    return\r\n    // let outputValuesArray: Array<any> = this.getResponseValues(<DynRecord>this.record, this.form);\r\n    // GlobalService.debugLog(\"outputValuesArray\", outputValuesArray);\r\n    \r\n    // let template: string = this.getResponseTemplate(this.form); // oggetto nel quale viene costruito il template o che prende il valore da un template esterno\r\n    // GlobalService.debugLog(\"template\", template);\r\n\r\n    // const regex = /##([\\w]+)##/g;\r\n    // const outputString = this.replaceTemplatePlaceholdersWithValues(template, outputValuesArray, regex); // oggetto che conterrà l'output elaborato    \r\n    // this.outputString = this.domSanitizer.bypassSecurityTrustHtml(outputString);\r\n    // GlobalService.debugLog(\"outputString\", this.outputString);\r\n\r\n    // STAMPO A SCHERMO\r\n    // this.loader = true;\r\n  }\r\n\r\n  // private getResponseValues(record: Record, form: Form ): Array<any> {\r\n  //   let outputValuesArray: Array<any> = []; // array con i valori delle risposte\r\n  //   //(<DynRecord>this.record).Values è la lista di oggetti {fieldName: valore}\r\n  //   for (let fieldName in (record).Values) {\r\n  //     try {\r\n  //       // fieldName è il nome del campo\r\n  //       // PREPARO VARIABILI VALORI CORRETTI\r\n  //       let foundObject = form.Fields.find(\r\n  //         (obj) => obj.Name === fieldName\r\n  //       );\r\n  //       GlobalService.debugLog(\"fieldName\", fieldName);\r\n  //       GlobalService.debugLog(\"foundObject\", foundObject);\r\n  //       // gestire caso fieldtype 8 [elenco generico]\r\n  //       // fare un eval per popolare i valuePairs se è presente una formula\r\n  //       // prendere la label corretta\r\n  //       ////////////////////////////////////////////////////////////////////////////////\r\n  //       if (foundObject.FieldType == FieldTypeEnum[\"Elenco generico\"]) \r\n  //       {\r\n  //         if (foundObject.Formula) \r\n  //         {\r\n  //           // aggiungo a valuepairs i valori calcolati\r\n  //           // (<ListValueField>foundObject).ValuePairs = {};\r\n  //           var temp = UtilityHelperService.EvaluateFieldFormula(\r\n  //             foundObject.Formula,\r\n  //             record,\r\n  //             null\r\n  //           );\r\n  //           for (let key2 in temp) {\r\n  //             if (UtilityHelperService.isNumeric(temp[key2])) \r\n  //             {\r\n  //               (<ListValueField>foundObject).ValuePairs[Number(key2)] = temp[key2];\r\n  //             } else \r\n  //             {\r\n  //               (<ListValueField>foundObject).ValuePairs[key2] = temp[key2];\r\n  //             }\r\n  //           }\r\n  //           GlobalService.debugLog(\"(record).Values[fieldName]\", (record).Values[fieldName]);\r\n  //           GlobalService.debugLog(\"(<ListValueField>foundObject).ValuePairs[(record).Values[fieldName]]\", (<ListValueField>foundObject).ValuePairs[(record).Values[fieldName]]);\r\n  //           outputValuesArray[fieldName] = (<ListValueField>foundObject).ValuePairs[(record).Values[fieldName]];\r\n  //         }\r\n  //         let inverted = {};\r\n  //         for (let key in (<ListValueField>foundObject).ValuePairs) \r\n  //         { \r\n  //           inverted[(<ListValueField>foundObject).ValuePairs[key]] = key; \r\n  //         }\r\n  //         (<ListValueField>foundObject).ValuePairs = inverted;\r\n  //         outputValuesArray[fieldName] = (<ListValueField>foundObject).ValuePairs[(record).Values[fieldName]];\r\n  //       } else \r\n  //       {\r\n  //         GlobalService.debugLog(\"(record).Values[fieldName]\", (record).Values[fieldName]);\r\n  //         outputValuesArray[fieldName] = (record).Values[fieldName];\r\n  //       }\r\n  //       ////////////////////////////////////////////////////////////////////////////////\r\n  //     } catch (e) {\r\n  //       console.error(e);\r\n  //     }\r\n  //   }\r\n  //   // cancello i valori indefiniti o nulli\r\n  //   for(const chiave in outputValuesArray){\r\n  //     if(outputValuesArray[chiave] == undefined || outputValuesArray[chiave] == null)\r\n  //     outputValuesArray[chiave] = ''\r\n  //   }\r\n  //   return outputValuesArray;\r\n  // }\r\n\r\n  // private getResponseTemplate(form: Form): string {\r\n  //   let template: string = \"\";\r\n  //   // PREPARO O PRENDO LA STRUTTURA DA STAMPARE\r\n  //   form.Fields.forEach((baseField: BaseField) => {\r\n  //     template += '<span style=\"' + baseField.LabelstyleCSS + '\">' + baseField.Description + ':</span> <span style=\"' + baseField.FieldstyleCSS + '\"> ##' + baseField.Name + '##</span> \\n <br> ';\r\n  //   });\r\n  //   // (attualmente non esiste il concetto di tempate di output)\r\n  //   return template;\r\n  // }\r\n\r\n  // private replaceTemplatePlaceholdersWithValues(template: string, outputValuesArray: Array<any>, regex): string {\r\n  //   return template.replace(regex, (match, group) => {\r\n  //     return <string>outputValuesArray[group];\r\n  //   });\r\n  // }\r\n\r\n}\r\n","<div *ngIf=\"loader\">\r\n  <div id=\"output-string\" [innerHTML]=\"outputString\"></div>\r\n  <div class=\"row mt-2\" *ngIf=\"showBackButton\">\r\n    <div class=\"col-sm-12 text-right\">\r\n      <button\r\n        class=\"mr-2\"\r\n        mat-raised-button\r\n        color=\"primary\"\r\n        type=\"button\"\r\n        (click)=\"goBack()\"\r\n      >\r\n        Indietro\r\n      </button>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}