@eqproject/eqp-dynamic-module 2.3.36 → 2.3.37

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.
@@ -115,8 +115,8 @@ export class GraphsComponent {
115
115
  // Azzero le coordinate
116
116
  this.selectedGeneratedFields.forEach((field) => { field.Coords = new Array(); });
117
117
  this.eligibleAnswers = JSON.parse(JSON.stringify(this.answers));
118
- this.minperiodS = this.datePipe.transform(this.minperiod, "YYYY-MM-dd");
119
- this.maxperiodS = this.datePipe.transform(this.maxperiod, "YYYY-MM-dd");
118
+ this.minperiodS = this.datePipe.transform(this.minperiod, "yyyy-MM-dd");
119
+ this.maxperiodS = this.datePipe.transform(this.maxperiod, "yyyy-MM-dd");
120
120
  // Filtro minimo periodo
121
121
  if (this.minperiod != null) {
122
122
  this.eligibleAnswers = this.eligibleAnswers.filter(x => x.AnswerDate.split("T")[0] >= this.minperiodS);
@@ -131,8 +131,10 @@ export class GraphsComponent {
131
131
  this.selectedGeneratedFields.forEach((field) => {
132
132
  if (answervalues[field.Name] != null) {
133
133
  var coords = new Coords();
134
- coords.x = new Date(answer.AnswerDate.split("T")[0]);
134
+ coords.x = new Date(answer.AnswerDate);
135
135
  coords.y = parseFloat(answervalues[field.Name]);
136
+ coords.label = this.datePipe.transform(coords.x, "dd/MM HH:mm");
137
+ coords.name = coords.label;
136
138
  field.Coords.push(coords);
137
139
  }
138
140
  });
@@ -156,4 +158,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
156
158
  }], form: [{
157
159
  type: Input
158
160
  }] } });
159
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"graphs.component.js","sourceRoot":"","sources":["../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/graphs/graphs.component.ts","../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/graphs/graphs.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { Form } from \"../../../models/form.model\";\r\nimport { DynamicModuleCompileConfig } from '../../../models/dynamicModuleCompileConfig.model';\r\nimport { EndPointConfiguration, EndPointDataParams, ParamTypeEnum } from '../../../models/endPointConfiguration.model';\r\nimport { PickerModeEnum } from '@eqproject/eqp-datetimepicker';\r\nimport { UntypedFormBuilder, UntypedFormGroup } from '@angular/forms';\r\nimport { Coords, GraphField } from '../../../models/graph.model';\r\nimport { UtilityHelperService } from '../../../services/utilityHelper.services';\r\nimport { DynRecord } from '../../../models/record.model';\r\nimport { FieldTypeEnum } from '../../../models/baseField.model';\r\nimport { DatePipe } from '@angular/common';\r\n\r\n@Component({\r\n  selector: 'graphs',\r\n  templateUrl: './graphs.component.html',\r\n  styleUrls: ['./graphs.component.scss']\r\n})\r\nexport class GraphsComponent implements OnInit {\r\n\r\n  @Input() configurations: DynamicModuleCompileConfig;\r\n  @Input() endPointConfiguration: EndPointConfiguration;\r\n  @Input() userID: string;\r\n  @Input() formID: string = null; // preview\r\n  @Input() form: Form = null; // preview config\r\n\r\n  pickerModeEnum = PickerModeEnum;\r\n  fieldFormGroup: UntypedFormGroup;\r\n\r\n  loaded: boolean = false;\r\n  generated: boolean = false;\r\n\r\n  minperiod: Date = new Date();\r\n  maxperiod: Date = new Date();\r\n  minperiodS: string;\r\n  maxperiodS: string;\r\n\r\n  fields: Array<GraphField> = new Array<GraphField>();\r\n  selectedFields: Array<GraphField>;\r\n  selectedGeneratedFields: Array<GraphField>;\r\n\r\n  answers: Array<DynRecord> = null;\r\n  eligibleAnswers: Array<DynRecord> = null;\r\n\r\n  constructor(\r\n    private utilityHelperService: UtilityHelperService,\r\n    private datePipe: DatePipe\r\n    ) {}\r\n\r\n  ngOnInit() {\r\n    if (this.formID != null){\r\n      this.getFormByID();\r\n    } else {\r\n      this.loaded = true;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per recuperare tutti i record salvati per una particolare Form.\r\n   * La chiamata viene effettuata solo se è stato configurato l'endPoint da usare.\r\n   */\r\n  getFormByID() {\r\n    if (\r\n      this.formID &&\r\n      this.endPointConfiguration &&\r\n      this.endPointConfiguration.Forms &&\r\n      this.endPointConfiguration.Forms.GetByIDEndPoint\r\n    ) {\r\n      const dynamicModuleParams: Array<EndPointDataParams> =\r\n        new Array<EndPointDataParams>();\r\n      dynamicModuleParams.push({\r\n        ParamName: \"id\",\r\n        ParamValue: this.formID,\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\r\n          this.form = res;\r\n\r\n          this.form.Fields.filter(x => x.FieldType == FieldTypeEnum['Campo numerico']).forEach((field) => {\r\n            var graphField: GraphField = new GraphField();\r\n            graphField.Name = field.Label;\r\n            this.fields.push(graphField);\r\n          });\r\n\r\n          this.getRecordsByFormID();\r\n\r\n        },\r\n        (err) => {\r\n        }\r\n      );\r\n    }\r\n  }\r\n\r\n  async getRecordsByFormID() {\r\n    var dynamicModuleParams = [\r\n      {\r\n        ParamName: \"EntID\",\r\n        ParamValue: this.form.ID,\r\n        ParamType: ParamTypeEnum[\"Query param\"],\r\n      },\r\n    ];\r\n\r\n    if (\r\n      this.configurations.userID == null &&\r\n      this.endPointConfiguration &&\r\n      this.endPointConfiguration.Records &&\r\n      this.endPointConfiguration.Records.GetByFormIDEndPoint\r\n    ) {\r\n      // se non conosco l'utente\r\n      this.utilityHelperService.RunEndPointCall(\r\n        this.endPointConfiguration.Records.GetByFormIDEndPoint,\r\n        dynamicModuleParams,\r\n        (res: Array<DynRecord>) => {\r\n          this.answers = res;\r\n        }\r\n      );\r\n    } else if (\r\n      this.configurations.userID != null &&\r\n      this.endPointConfiguration &&\r\n      this.endPointConfiguration.Records &&\r\n      this.endPointConfiguration.Records.GetAllByEntAndUserIDEndPoint\r\n    ) {\r\n    // se conosco l'utente\r\n      let dynamicModuleParams = [\r\n        {\r\n          ParamName: \"EntID\",\r\n          ParamValue: this.form.ID,\r\n          ParamType: ParamTypeEnum[\"Query param\"],\r\n        },\r\n        {\r\n          ParamName: \"UserID\",\r\n          ParamValue: this.configurations.userID,\r\n          ParamType: ParamTypeEnum[\"Query param\"],\r\n        },\r\n      ];\r\n\r\n      await this.utilityHelperService.RunEndPointCall(\r\n        this.endPointConfiguration.Records.GetAllByEntAndUserIDEndPoint,\r\n        dynamicModuleParams,\r\n        (res: Array<DynRecord>) => {\r\n          this.answers = res;\r\n          this.loaded = true;\r\n        }\r\n      );\r\n    } else {\r\n      console.error(\"controllare le configurazioni dell'endpoint\");\r\n    }\r\n  }  \r\n\r\n  generateGraph(){\r\n    this.generated = false;\r\n    this.selectedGeneratedFields = JSON.parse(JSON.stringify(this.selectedFields));\r\n    this.getEligibleAnswers();\r\n  }\r\n\r\n  getEligibleAnswers(){\r\n    // Azzero le coordinate\r\n    this.selectedGeneratedFields.forEach((field) => { field.Coords = new Array<Coords>(); });\r\n    this.eligibleAnswers = JSON.parse(JSON.stringify(this.answers));\r\n\r\n    this.minperiodS = this.datePipe.transform(this.minperiod,\"YYYY-MM-dd\");\r\n    this.maxperiodS = this.datePipe.transform(this.maxperiod,\"YYYY-MM-dd\");\r\n\r\n    // Filtro minimo periodo\r\n    if (this.minperiod != null){\r\n      this.eligibleAnswers = this.eligibleAnswers.filter(x => x.AnswerDate.split(\"T\")[0] >= this.minperiodS);\r\n    }\r\n\r\n    // Filtro massimo periodo\r\n    if (this.maxperiod != null){\r\n      this.eligibleAnswers = this.eligibleAnswers.filter(x => x.AnswerDate.split(\"T\")[0] <= this.maxperiodS);\r\n    }\r\n\r\n    // Inserisco i dati trovati\r\n    this.eligibleAnswers.forEach((answer) => {\r\n      var answervalues = JSON.parse(answer.SerializedValues);\r\n      this.selectedGeneratedFields.forEach((field) => {\r\n        if (answervalues[field.Name] != null){\r\n          var coords: Coords = new Coords();\r\n          coords.x = new Date(answer.AnswerDate.split(\"T\")[0]);\r\n          coords.y = parseFloat(answervalues[field.Name]);\r\n          field.Coords.push(coords);\r\n        }\r\n      });\r\n    });\r\n\r\n    setTimeout(() => { this.generated = true; }, 1000);\r\n\r\n  }\r\n\r\n}\r\n","<mat-card class=\"list-view-form-record\" *ngIf=\"loaded\">\r\n    <mat-card-content>\r\n      \r\n\r\n        <div class=\"row\">\r\n            <div class=\"col-sm-12 col-md-3 mt-2\">\r\n                <eqp-datetimepicker class=\"date\" [placeholder]=\"'Periodo inizio'\"\r\n                    [(ngModelInput)]=\"minperiod\"\r\n                    [pickerMode]=\"pickerModeEnum.DATE\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n                </eqp-datetimepicker>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-3 mt-2\">\r\n                <eqp-datetimepicker class=\"date\" [placeholder]=\"'Periodo fine'\"\r\n                    [(ngModelInput)]=\"maxperiod\"\r\n                    [pickerMode]=\"pickerModeEnum.DATE\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n                </eqp-datetimepicker>\r\n            </div>       \r\n            <div class=\"col-sm-12 col-md-3 mt-2\">\r\n                <eqp-select [arrayData]=\"fields\" [(ngModelInput)]=\"selectedFields\" [placeholder]=\"'Selezione dei campi'\"\r\n                [arrayKeyProperty]=\"'Name'\" [arrayValueProperty]=\"'Name'\" [isMultiSelect]=\"true\">\r\n                </eqp-select>\r\n            </div>       \r\n            <div class=\"col-sm-12 col-md-3 mt-2\">\r\n                <button\r\n                [disabled]=\"selectedFields == null || selectedFields.length == 0\"\r\n                class=\"btn btn-graph-generate button-next me-2\"\r\n                mat-raised-button\r\n                color=\"primary\"\r\n                (click)=\"generateGraph()\"\r\n                >\r\n                Genera\r\n              </button>\r\n            </div>                   \r\n        </div>\r\n        <div class=\"generation_box\" *ngIf=\"generated\">\r\n            <div class=\"row\">\r\n                <div class=\"col-3\">\r\n                    <div class=\"generation_options\" *ngFor=\"let selectedField of selectedGeneratedFields\">\r\n                        <mat-checkbox class=\"mr-2\" [(ngModel)]=\"selectedField.Visible\">\r\n                        {{selectedField.Name}}\r\n                        </mat-checkbox>\r\n                    </div>\r\n                </div>\r\n                <div class=\"col-9\">\r\n                        <div class=\"generation_graph\" *ngFor=\"let selectedField of selectedGeneratedFields\">\r\n                            <div class=\"generation_divider\" [hidden]=\"!selectedField.Visible\">\r\n                                <graph [data]=\"selectedField.Coords\" [title]=\"selectedField.Name\"></graph>\r\n                            </div>\r\n                        </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n  \r\n  \r\n    </mat-card-content>\r\n    <mat-card-footer>\r\n    </mat-card-footer>\r\n  </mat-card>"]}
161
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"graphs.component.js","sourceRoot":"","sources":["../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/graphs/graphs.component.ts","../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/graphs/graphs.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport { Form } from \"../../../models/form.model\";\r\nimport { DynamicModuleCompileConfig } from '../../../models/dynamicModuleCompileConfig.model';\r\nimport { EndPointConfiguration, EndPointDataParams, ParamTypeEnum } from '../../../models/endPointConfiguration.model';\r\nimport { PickerModeEnum } from '@eqproject/eqp-datetimepicker';\r\nimport { UntypedFormBuilder, UntypedFormGroup } from '@angular/forms';\r\nimport { Coords, GraphField } from '../../../models/graph.model';\r\nimport { UtilityHelperService } from '../../../services/utilityHelper.services';\r\nimport { DynRecord } from '../../../models/record.model';\r\nimport { FieldTypeEnum } from '../../../models/baseField.model';\r\nimport { DatePipe } from '@angular/common';\r\n\r\n@Component({\r\n  selector: 'graphs',\r\n  templateUrl: './graphs.component.html',\r\n  styleUrls: ['./graphs.component.scss']\r\n})\r\nexport class GraphsComponent implements OnInit {\r\n\r\n  @Input() configurations: DynamicModuleCompileConfig;\r\n  @Input() endPointConfiguration: EndPointConfiguration;\r\n  @Input() userID: string;\r\n  @Input() formID: string = null; // preview\r\n  @Input() form: Form = null; // preview config\r\n\r\n  pickerModeEnum = PickerModeEnum;\r\n  fieldFormGroup: UntypedFormGroup;\r\n\r\n  loaded: boolean = false;\r\n  generated: boolean = false;\r\n\r\n  minperiod: Date = new Date();\r\n  maxperiod: Date = new Date();\r\n  minperiodS: string;\r\n  maxperiodS: string;\r\n\r\n  fields: Array<GraphField> = new Array<GraphField>();\r\n  selectedFields: Array<GraphField>;\r\n  selectedGeneratedFields: Array<GraphField>;\r\n\r\n  answers: Array<DynRecord> = null;\r\n  eligibleAnswers: Array<DynRecord> = null;\r\n\r\n  constructor(\r\n    private utilityHelperService: UtilityHelperService,\r\n    private datePipe: DatePipe\r\n    ) {}\r\n\r\n  ngOnInit() {\r\n    if (this.formID != null){\r\n      this.getFormByID();\r\n    } else {\r\n      this.loaded = true;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per recuperare tutti i record salvati per una particolare Form.\r\n   * La chiamata viene effettuata solo se è stato configurato l'endPoint da usare.\r\n   */\r\n  getFormByID() {\r\n    if (\r\n      this.formID &&\r\n      this.endPointConfiguration &&\r\n      this.endPointConfiguration.Forms &&\r\n      this.endPointConfiguration.Forms.GetByIDEndPoint\r\n    ) {\r\n      const dynamicModuleParams: Array<EndPointDataParams> =\r\n        new Array<EndPointDataParams>();\r\n      dynamicModuleParams.push({\r\n        ParamName: \"id\",\r\n        ParamValue: this.formID,\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\r\n          this.form = res;\r\n\r\n          this.form.Fields.filter(x => x.FieldType == FieldTypeEnum['Campo numerico']).forEach((field) => {\r\n            var graphField: GraphField = new GraphField();\r\n            graphField.Name = field.Label;\r\n            this.fields.push(graphField);\r\n          });\r\n\r\n          this.getRecordsByFormID();\r\n\r\n        },\r\n        (err) => {\r\n        }\r\n      );\r\n    }\r\n  }\r\n\r\n  async getRecordsByFormID() {\r\n    var dynamicModuleParams = [\r\n      {\r\n        ParamName: \"EntID\",\r\n        ParamValue: this.form.ID,\r\n        ParamType: ParamTypeEnum[\"Query param\"],\r\n      },\r\n    ];\r\n\r\n    if (\r\n      this.configurations.userID == null &&\r\n      this.endPointConfiguration &&\r\n      this.endPointConfiguration.Records &&\r\n      this.endPointConfiguration.Records.GetByFormIDEndPoint\r\n    ) {\r\n      // se non conosco l'utente\r\n      this.utilityHelperService.RunEndPointCall(\r\n        this.endPointConfiguration.Records.GetByFormIDEndPoint,\r\n        dynamicModuleParams,\r\n        (res: Array<DynRecord>) => {\r\n          this.answers = res;\r\n        }\r\n      );\r\n    } else if (\r\n      this.configurations.userID != null &&\r\n      this.endPointConfiguration &&\r\n      this.endPointConfiguration.Records &&\r\n      this.endPointConfiguration.Records.GetAllByEntAndUserIDEndPoint\r\n    ) {\r\n    // se conosco l'utente\r\n      let dynamicModuleParams = [\r\n        {\r\n          ParamName: \"EntID\",\r\n          ParamValue: this.form.ID,\r\n          ParamType: ParamTypeEnum[\"Query param\"],\r\n        },\r\n        {\r\n          ParamName: \"UserID\",\r\n          ParamValue: this.configurations.userID,\r\n          ParamType: ParamTypeEnum[\"Query param\"],\r\n        },\r\n      ];\r\n\r\n      await this.utilityHelperService.RunEndPointCall(\r\n        this.endPointConfiguration.Records.GetAllByEntAndUserIDEndPoint,\r\n        dynamicModuleParams,\r\n        (res: Array<DynRecord>) => {\r\n          this.answers = res;\r\n          this.loaded = true;\r\n        }\r\n      );\r\n    } else {\r\n      console.error(\"controllare le configurazioni dell'endpoint\");\r\n    }\r\n  }  \r\n\r\n  generateGraph(){\r\n    this.generated = false;\r\n    this.selectedGeneratedFields = JSON.parse(JSON.stringify(this.selectedFields));\r\n    this.getEligibleAnswers();\r\n  }\r\n\r\n  getEligibleAnswers(){\r\n    // Azzero le coordinate\r\n    this.selectedGeneratedFields.forEach((field) => { field.Coords = new Array<Coords>(); });\r\n    this.eligibleAnswers = JSON.parse(JSON.stringify(this.answers));\r\n\r\n    this.minperiodS = this.datePipe.transform(this.minperiod,\"yyyy-MM-dd\");\r\n    this.maxperiodS = this.datePipe.transform(this.maxperiod,\"yyyy-MM-dd\");\r\n\r\n    // Filtro minimo periodo\r\n    if (this.minperiod != null){\r\n      this.eligibleAnswers = this.eligibleAnswers.filter(x => x.AnswerDate.split(\"T\")[0] >= this.minperiodS);\r\n    }\r\n\r\n    // Filtro massimo periodo\r\n    if (this.maxperiod != null){\r\n      this.eligibleAnswers = this.eligibleAnswers.filter(x => x.AnswerDate.split(\"T\")[0] <= this.maxperiodS);\r\n    }\r\n\r\n    // Inserisco i dati trovati\r\n    this.eligibleAnswers.forEach((answer) => {\r\n      var answervalues = JSON.parse(answer.SerializedValues);\r\n      this.selectedGeneratedFields.forEach((field) => {\r\n        if (answervalues[field.Name] != null){\r\n          var coords: Coords = new Coords();\r\n          coords.x = new Date(answer.AnswerDate);\r\n          coords.y = parseFloat(answervalues[field.Name]);\r\n          coords.label = this.datePipe.transform(coords.x,\"dd/MM HH:mm\");\r\n          coords.name = coords.label;\r\n          field.Coords.push(coords);\r\n        }\r\n      });\r\n    });\r\n\r\n    setTimeout(() => { this.generated = true; }, 1000);\r\n\r\n  }\r\n\r\n}\r\n","<mat-card class=\"list-view-form-record\" *ngIf=\"loaded\">\r\n    <mat-card-content>\r\n      \r\n\r\n        <div class=\"row\">\r\n            <div class=\"col-sm-12 col-md-3 mt-2\">\r\n                <eqp-datetimepicker class=\"date\" [placeholder]=\"'Periodo inizio'\"\r\n                    [(ngModelInput)]=\"minperiod\"\r\n                    [pickerMode]=\"pickerModeEnum.DATE\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n                </eqp-datetimepicker>\r\n            </div>\r\n            <div class=\"col-sm-12 col-md-3 mt-2\">\r\n                <eqp-datetimepicker class=\"date\" [placeholder]=\"'Periodo fine'\"\r\n                    [(ngModelInput)]=\"maxperiod\"\r\n                    [pickerMode]=\"pickerModeEnum.DATE\" [UTCDate]=\"true\" [showSeconds]=\"false\">\r\n                </eqp-datetimepicker>\r\n            </div>       \r\n            <div class=\"col-sm-12 col-md-3 mt-2\">\r\n                <eqp-select [arrayData]=\"fields\" [(ngModelInput)]=\"selectedFields\" [placeholder]=\"'Selezione dei campi'\"\r\n                [arrayKeyProperty]=\"'Name'\" [arrayValueProperty]=\"'Name'\" [isMultiSelect]=\"true\">\r\n                </eqp-select>\r\n            </div>       \r\n            <div class=\"col-sm-12 col-md-3 mt-2\">\r\n                <button\r\n                [disabled]=\"selectedFields == null || selectedFields.length == 0\"\r\n                class=\"btn btn-graph-generate button-next me-2\"\r\n                mat-raised-button\r\n                color=\"primary\"\r\n                (click)=\"generateGraph()\"\r\n                >\r\n                Genera\r\n              </button>\r\n            </div>                   \r\n        </div>\r\n        <div class=\"generation_box\" *ngIf=\"generated\">\r\n            <div class=\"row\">\r\n                <div class=\"col-3\">\r\n                    <div class=\"generation_options\" *ngFor=\"let selectedField of selectedGeneratedFields\">\r\n                        <mat-checkbox class=\"mr-2\" [(ngModel)]=\"selectedField.Visible\">\r\n                        {{selectedField.Name}}\r\n                        </mat-checkbox>\r\n                    </div>\r\n                </div>\r\n                <div class=\"col-9\">\r\n                        <div class=\"generation_graph\" *ngFor=\"let selectedField of selectedGeneratedFields\">\r\n                            <div class=\"generation_divider\" [hidden]=\"!selectedField.Visible\">\r\n                                <graph [data]=\"selectedField.Coords\" [title]=\"selectedField.Name\"></graph>\r\n                            </div>\r\n                        </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n  \r\n  \r\n    </mat-card-content>\r\n    <mat-card-footer>\r\n    </mat-card-footer>\r\n  </mat-card>"]}
@@ -12,4 +12,4 @@ export class GraphField {
12
12
  }
13
13
  export class Coords {
14
14
  }
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhcGgubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lcXAtZHluYW1pYy1tb2R1bGUvc3JjL2xpYi9tb2RlbHMvZ3JhcGgubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0dBS0c7QUFDSCxNQUFNLE9BQU8sVUFBVTtJQUF2QjtRQUVJLFdBQU0sR0FBa0IsSUFBSSxLQUFLLEVBQVUsQ0FBQztRQUM1QyxZQUFPLEdBQVksSUFBSSxDQUFDO0lBQzVCLENBQUM7Q0FBQTtBQUVELE1BQU0sT0FBTyxNQUFNO0NBR2xCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIENsYXNzZSBiYXNlIGNoZSBpbXBsZW1lbnRhIGxhIHZhbG9yaXp6YXppb25lIGRlbGwnSUQgKHNlIG51bGwpIGNvbiB1bmEgbnVvdmEgR1VJRCBcclxuICogaW4gY3JlYXppb25lIGRlbGwnb2dnZXR0by5cclxuICogUGVyIHNjZWx0YSBhcmNoaXRldHR1cmFsZSwgdmlzdG8gY2hlIG5vbiBwb3NzaWFtbyBhc3N1bWVyZSBsYSBwZXJzaXN0ZW56YSBzdSBEQiByZWxhemlvbmFsZSBvIHN1IE5PU1FMLCBvZ25pXHJcbiAqIG9nZ2V0dG8gZGVsbGEgY29uZmlndXJhemlvbmUgdmllbmUgcGVyc2lzdGl0bywgZSBnZXN0aXRvIGNvbiBJRCBkaSB0aXBvIHN0cmluZ2EgY3JlYXRvIGRhIHVuYSBHVUlELlxyXG4gKi9cclxuZXhwb3J0IGNsYXNzIEdyYXBoRmllbGQge1xyXG4gICAgTmFtZTogc3RyaW5nO1xyXG4gICAgQ29vcmRzOiBBcnJheTxDb29yZHM+ID0gbmV3IEFycmF5PENvb3Jkcz4oKTtcclxuICAgIFZpc2libGU6IGJvb2xlYW4gPSB0cnVlO1xyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgQ29vcmRzIHtcclxuICAgIHg6IERhdGU7XHJcbiAgICB5OiBudW1iZXI7XHJcbn0iXX0=
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhcGgubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lcXAtZHluYW1pYy1tb2R1bGUvc3JjL2xpYi9tb2RlbHMvZ3JhcGgubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0dBS0c7QUFDSCxNQUFNLE9BQU8sVUFBVTtJQUF2QjtRQUVJLFdBQU0sR0FBa0IsSUFBSSxLQUFLLEVBQVUsQ0FBQztRQUM1QyxZQUFPLEdBQVksSUFBSSxDQUFDO0lBQzVCLENBQUM7Q0FBQTtBQUVELE1BQU0sT0FBTyxNQUFNO0NBS2xCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIENsYXNzZSBiYXNlIGNoZSBpbXBsZW1lbnRhIGxhIHZhbG9yaXp6YXppb25lIGRlbGwnSUQgKHNlIG51bGwpIGNvbiB1bmEgbnVvdmEgR1VJRCBcclxuICogaW4gY3JlYXppb25lIGRlbGwnb2dnZXR0by5cclxuICogUGVyIHNjZWx0YSBhcmNoaXRldHR1cmFsZSwgdmlzdG8gY2hlIG5vbiBwb3NzaWFtbyBhc3N1bWVyZSBsYSBwZXJzaXN0ZW56YSBzdSBEQiByZWxhemlvbmFsZSBvIHN1IE5PU1FMLCBvZ25pXHJcbiAqIG9nZ2V0dG8gZGVsbGEgY29uZmlndXJhemlvbmUgdmllbmUgcGVyc2lzdGl0bywgZSBnZXN0aXRvIGNvbiBJRCBkaSB0aXBvIHN0cmluZ2EgY3JlYXRvIGRhIHVuYSBHVUlELlxyXG4gKi9cclxuZXhwb3J0IGNsYXNzIEdyYXBoRmllbGQge1xyXG4gICAgTmFtZTogc3RyaW5nO1xyXG4gICAgQ29vcmRzOiBBcnJheTxDb29yZHM+ID0gbmV3IEFycmF5PENvb3Jkcz4oKTtcclxuICAgIFZpc2libGU6IGJvb2xlYW4gPSB0cnVlO1xyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgQ29vcmRzIHtcclxuICAgIHg6IERhdGU7XHJcbiAgICB5OiBudW1iZXI7XHJcbiAgICBsYWJlbDogc3RyaW5nO1xyXG4gICAgbmFtZTogc3RyaW5nO1xyXG59Il19
@@ -3346,56 +3346,112 @@ class Coords {
3346
3346
  }
3347
3347
 
3348
3348
  class GraphComponent {
3349
- constructor() {
3349
+ constructor(datePipe) {
3350
+ this.datePipe = datePipe;
3350
3351
  this.data = new Array();
3351
3352
  this.title = "";
3352
- this.stockChartOptions = {
3353
- width: 1000,
3354
- height: 500,
3355
- title: {
3356
- text: ""
3357
- },
3358
- theme: "light2",
3359
- charts: [{
3360
- data: [{
3361
- xValueType: "dateTime",
3362
- type: "line",
3363
- dataPoints: []
3364
- }]
3365
- }],
3366
- navigator: {
3367
- slider: {
3368
- minimum: new Date("2018-07-01"),
3369
- maximum: new Date("2019-06-30")
3370
- }
3371
- },
3372
- options: {
3373
- responsive: true,
3374
- maintainAspectRatio: false
3375
- }
3376
- };
3377
3353
  this.loaded = false;
3354
+ this.counter = 0;
3378
3355
  }
3379
3356
  ngOnInit() {
3357
+ var self = this;
3380
3358
  // Aggiustamento e scrittura dati
3381
3359
  if (this.data.length > 0) {
3382
3360
  var lastvalue = this.data[0];
3383
3361
  var firstvalue = this.data[this.data.length - 1];
3384
- this.stockChartOptions.navigator.slider.minimum = new Date(firstvalue.x);
3385
- this.stockChartOptions.navigator.slider.maximum = new Date(lastvalue.x);
3386
- this.stockChartOptions.title.text = this.title;
3387
- this.stockChartOptions.charts[0].data[0].dataPoints = this.data;
3388
- console.log(this.title, this.stockChartOptions);
3362
+ var stockChartMinimum = new Date(firstvalue.x);
3363
+ var stockChartMaximum = new Date(lastvalue.x);
3364
+ var stockChartTitleText = this.title;
3365
+ var stockChartdataPoints = this.data;
3366
+ this.stockChartOptions = {
3367
+ width: 1000,
3368
+ height: 500,
3369
+ title: {
3370
+ text: stockChartTitleText
3371
+ },
3372
+ theme: "light2",
3373
+ charts: [{
3374
+ axisX: {
3375
+ labelFormatter: this.labelFormatterFunction,
3376
+ },
3377
+ data: [{
3378
+ type: "line",
3379
+ dataPoints: stockChartdataPoints
3380
+ }],
3381
+ culture: "it"
3382
+ }],
3383
+ rangeSelector: {
3384
+ enabled: false
3385
+ },
3386
+ navigator: {
3387
+ slider: {
3388
+ minimum: stockChartMinimum,
3389
+ maximum: stockChartMaximum
3390
+ }
3391
+ },
3392
+ options: {
3393
+ responsive: true,
3394
+ maintainAspectRatio: false
3395
+ }
3396
+ };
3389
3397
  this.loaded = true;
3390
3398
  }
3391
3399
  }
3400
+ labelFormatterFunction(e) {
3401
+ let label = "";
3402
+ let dirtyLabel;
3403
+ let date = e.value;
3404
+ let newYear = date.getFullYear();
3405
+ let newMonth = date.getMonth() + 1;
3406
+ let newMonthString;
3407
+ if (newMonth < 10) {
3408
+ newMonthString = "0" + newMonth.toString();
3409
+ }
3410
+ else {
3411
+ newMonthString = newMonth.toString();
3412
+ }
3413
+ let newDay = date.getDate();
3414
+ let newDayString;
3415
+ if (newDay < 10) {
3416
+ newDayString = "0" + newDay.toString();
3417
+ }
3418
+ else {
3419
+ newDayString = newDay.toString();
3420
+ }
3421
+ let newHour = date.getHours();
3422
+ let newHourString;
3423
+ if (newHour < 10) {
3424
+ newHourString = "0" + newHour.toString();
3425
+ }
3426
+ else {
3427
+ newHourString = newHour.toString();
3428
+ }
3429
+ let newMinute = date.getMinutes();
3430
+ let newMinuteString;
3431
+ if (newMinute < 10) {
3432
+ newMinuteString = "0" + newMinute.toString();
3433
+ }
3434
+ else {
3435
+ newMinuteString = newMinute.toString();
3436
+ }
3437
+ dirtyLabel = newDayString + "/" + newMonthString + "/" + newYear.toString() + " " + newHourString + ":" + newMinuteString;
3438
+ for (let i = 0; i < 5; i++) {
3439
+ label += dirtyLabel[i];
3440
+ }
3441
+ label += " ";
3442
+ for (let i = 11; i < 16; i++) {
3443
+ label += dirtyLabel[i];
3444
+ }
3445
+ //label = label.replace("00:00","");
3446
+ return label;
3447
+ }
3392
3448
  }
3393
- GraphComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GraphComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
3449
+ GraphComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GraphComponent, deps: [{ token: i6.DatePipe }], target: i0.ɵɵFactoryTarget.Component });
3394
3450
  GraphComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: GraphComponent, selector: "graph", inputs: { data: "data", title: "title" }, ngImport: i0, template: "<canvasjs-stockchart *ngIf=\"loaded\" [options]=\"stockChartOptions\"></canvasjs-stockchart>\r\n<div class=\"error\" *ngIf=\"!loaded\"><b>{{title}}:</b> Nessun dato trovato nell'intervallo specificato!</div>", styles: [""], dependencies: [{ kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2$5.CanvasJSStockChart, selector: "canvasjs-stockchart", inputs: ["options", "styles"], outputs: ["stockChartInstance"] }] });
3395
3451
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GraphComponent, decorators: [{
3396
3452
  type: Component,
3397
3453
  args: [{ selector: 'graph', template: "<canvasjs-stockchart *ngIf=\"loaded\" [options]=\"stockChartOptions\"></canvasjs-stockchart>\r\n<div class=\"error\" *ngIf=\"!loaded\"><b>{{title}}:</b> Nessun dato trovato nell'intervallo specificato!</div>" }]
3398
- }], ctorParameters: function () { return []; }, propDecorators: { data: [{
3454
+ }], ctorParameters: function () { return [{ type: i6.DatePipe }]; }, propDecorators: { data: [{
3399
3455
  type: Input,
3400
3456
  args: ["data"]
3401
3457
  }], title: [{
@@ -3507,8 +3563,8 @@ class GraphsComponent {
3507
3563
  // Azzero le coordinate
3508
3564
  this.selectedGeneratedFields.forEach((field) => { field.Coords = new Array(); });
3509
3565
  this.eligibleAnswers = JSON.parse(JSON.stringify(this.answers));
3510
- this.minperiodS = this.datePipe.transform(this.minperiod, "YYYY-MM-dd");
3511
- this.maxperiodS = this.datePipe.transform(this.maxperiod, "YYYY-MM-dd");
3566
+ this.minperiodS = this.datePipe.transform(this.minperiod, "yyyy-MM-dd");
3567
+ this.maxperiodS = this.datePipe.transform(this.maxperiod, "yyyy-MM-dd");
3512
3568
  // Filtro minimo periodo
3513
3569
  if (this.minperiod != null) {
3514
3570
  this.eligibleAnswers = this.eligibleAnswers.filter(x => x.AnswerDate.split("T")[0] >= this.minperiodS);
@@ -3523,8 +3579,10 @@ class GraphsComponent {
3523
3579
  this.selectedGeneratedFields.forEach((field) => {
3524
3580
  if (answervalues[field.Name] != null) {
3525
3581
  var coords = new Coords();
3526
- coords.x = new Date(answer.AnswerDate.split("T")[0]);
3582
+ coords.x = new Date(answer.AnswerDate);
3527
3583
  coords.y = parseFloat(answervalues[field.Name]);
3584
+ coords.label = this.datePipe.transform(coords.x, "dd/MM HH:mm");
3585
+ coords.name = coords.label;
3528
3586
  field.Coords.push(coords);
3529
3587
  }
3530
3588
  });
@@ -3565,6 +3623,7 @@ class ListViewFormRecordComponent {
3565
3623
  this.showTitle = true;
3566
3624
  // values: Array<Record>;
3567
3625
  this.test = false;
3626
+ this.loadedform = false;
3568
3627
  this.panelOpenState = new Array();
3569
3628
  this.selectedIndex = null;
3570
3629
  this.visualizzaContenuto = false;
@@ -3655,6 +3714,7 @@ class ListViewFormRecordComponent {
3655
3714
  });
3656
3715
  this.utilityHelperService.RunEndPointCall(this.endPointConfiguration.Forms.GetByIDEndPoint, dynamicModuleParams, (res) => {
3657
3716
  this.form = res;
3717
+ this.loadedform = true;
3658
3718
  this.configureColumns();
3659
3719
  }, (err) => { });
3660
3720
  }
@@ -4012,10 +4072,10 @@ class ListViewFormRecordComponent {
4012
4072
  }
4013
4073
  }
4014
4074
  ListViewFormRecordComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ListViewFormRecordComponent, deps: [{ token: UtilityHelperService }, { token: i0.ChangeDetectorRef }, { token: i1$2.MatDialog }, { token: i3$3.Router }], target: i0.ɵɵFactoryTarget.Component });
4015
- ListViewFormRecordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ListViewFormRecordComponent, selector: "list-view-form-record", inputs: { configurations: "configurations", compileConfigurations: "compileConfigurations", endPointConfiguration: "endPointConfiguration", userID: "userID", formID: "formID", form: "form", defaultListViewFunction: "defaultListViewFunction", externalButtons: "externalButtons", onlyView: "onlyView", records: "records", highlightFilter: "highlightFilter" }, outputs: { onAddViewEditRecord: "onAddViewEditRecord", onDeleteRecord: "onDeleteRecord", saveRecordEvent: "saveRecordEvent", afterSaveRecordEvent: "afterSaveRecordEvent" }, viewQueries: [{ propertyName: "tableRecords", first: true, predicate: ["tableRecords"], descendants: true, static: true }, { propertyName: "openAddDialog", first: true, predicate: ["openAddDialog"], descendants: true }, { propertyName: "openGraphDialog", first: true, predicate: ["openGraphDialog"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<mat-card class=\"list-view-form-record\">\r\n <mat-card-header *ngIf=\"showTitle || defaultListActions.add\" class=\"align-items-center justify-content-between\">\r\n <mat-card-title *ngIf=\"showTitle\">Elenco {{ form.Name }} </mat-card-title>\r\n <mat-card-actions *ngIf=\"defaultListActions.add || defaultListActions.graphs\">\r\n <button \r\n *ngIf=\"defaultListActions.graphs\"\r\n class=\"btn btn-primary mr-2\" \r\n mat-raised-button \r\n color=\"primary\" \r\n type=\"button\"\r\n (click)=\"openGraphs()\">\r\n <mat-icon>pie_chart</mat-icon>\r\n <span style=\"margin-left: 10px\">Grafici</span>\r\n </button>\r\n <button \r\n *ngIf=\"defaultListActions.add\"\r\n class=\"btn btn-primary\" \r\n mat-raised-button \r\n color=\"primary\" \r\n type=\"button\"\r\n (click)=\"openAddPopup()\">\r\n <mat-icon>add</mat-icon>\r\n <span style=\"margin-left: 10px\">Aggiungi</span>\r\n </button> \r\n </mat-card-actions>\r\n </mat-card-header>\r\n\r\n \r\n <mat-card-content>\r\n <mat-accordion [hideToggle]=\"test\" [multi]=\"true\" class=\"df-list-view-accordion\">\r\n <mat-expansion-panel *ngFor=\"let panel of panels; index as i\" \r\n [expanded]=\"panel.isOpen\"\r\n [disabled]=\"1\" \r\n [class]=\"panel.highlighted ? 'dm_panel_highlighted' : '0'\"\r\n >\r\n <mat-expansion-panel-header\r\n (click)=\"togglePanel(panel, panel.record)\">\r\n <mat-panel-title>\r\n {{ form.Name }} v.{{ panel.record.Version }} - {{ panel.record.AnswerDate | date : \"EEEE, d MMMM y, H:mm:ss\" }}\r\n </mat-panel-title>\r\n <!--#region BOTTONI PER LE AZIONI -->\r\n <mat-panel-description>\r\n <button *ngFor=\"let button of buttons\" \r\n mat-icon-button \r\n class=\"record-icon {{button.extraClass}}\" \r\n [matTooltip]=\"button.text\"\r\n [hidden]=\"button.icon == 'file_copy' && (panels.length == 0 || panel.record.Version != panels[0].record.Version)\"\r\n (click)=\"button.fn(panel,i,$event)\">\r\n <mat-icon>{{button.icon}}</mat-icon>\r\n </button>\r\n <button *ngFor=\"let button of externalButtons\" \r\n mat-icon-button \r\n class=\"record-icon {{button.extraClass}}\"\r\n [matTooltip]=\"button.text\"\r\n (click)=\"externalCallback($event,button.fn,panel.record)\">\r\n <mat-icon>{{button.icon}}</mat-icon>\r\n </button> \r\n <span class=\"example-spacer\"></span>\r\n \r\n </mat-panel-description>\r\n <!--#endregion BOTTONI PER LE AZIONI -->\r\n </mat-expansion-panel-header>\r\n\r\n <!-- #region CONTENUTO -->\r\n <ng-container *ngIf=\"panel.pageState != null\">\r\n <lib-single-record\r\n [onlyView]=\"onlyView\"\r\n [record] = \"panel.record\" \r\n [endPointConfiguration] = \"endPointConfiguration\"\r\n [form]=\"form\"\r\n [userID]=\"userID\"\r\n [outCompileConfigurations]=\"outCompileConfigurations\"\r\n [pageState]=\"panel.pageState\"\r\n (saveRecordEvent)=\"saveOrExitForm($event)\"\r\n (afterSaveRecordEvent)=\"onAfterSaveRecord($event)\"\r\n >\r\n\r\n </lib-single-record>\r\n </ng-container>\r\n <!--#endregion CONTENUTO -->\r\n </mat-expansion-panel>\r\n </mat-accordion>\r\n\r\n\r\n </mat-card-content>\r\n <mat-card-footer>\r\n </mat-card-footer>\r\n</mat-card>\r\n\r\n<!-- DIALOG RECIPIENTS EMAIL PER FIRMA -->\r\n<ng-template #openAddDialog>\r\n <mat-card class=\"card-default overlay-card card-inmodal-true\">\r\n <mat-card-content>\r\n\r\n <add-form-record\r\n class=\"dynamic-module-compile\"\r\n [formID]=\"formID\"\r\n [onlyView]=\"false\"\r\n [record]=\"selectedRecord\"\r\n\r\n [endPointConfiguration]=\"endPointConfiguration\"\r\n [userID]=\"userID\"\r\n\r\n [configurations]=\"compileConfigurations\"\r\n [additionalParams]=\"compileConfigurations.additionalParams\"\r\n\r\n (saveRecordEvent)=\"onAddSaveRecord($event)\"\r\n (afterSaveRecordEvent)=\"onAddAfterSaveRecord($event)\"\r\n >\r\n </add-form-record>\r\n\r\n </mat-card-content>\r\n </mat-card>\r\n</ng-template>\r\n\r\n<!-- DIALOG RECIPIENTS EMAIL PER FIRMA -->\r\n<ng-template #openGraphDialog>\r\n <mat-card class=\"card-default overlay-card card-inmodal-true graphCard\">\r\n \r\n <mat-card-header class=\"align-items-center justify-content-between\">\r\n <mat-card-title>\r\n <div class=\"row eqp-dynamic-module-title graph-header\">\r\n <div class=\"col-md-12\">\r\n <span>Grafico {{ form.Name }} </span>\r\n </div>\r\n </div>\r\n </mat-card-title>\r\n <mat-card-actions>\r\n <button \r\n class=\"btn btn-primary mr-2\" \r\n mat-raised-button \r\n color=\"primary\" \r\n type=\"button\"\r\n (click)=\"closeGraphs()\">\r\n <span class=\"material-icons\">\r\n arrow_back\r\n </span>\r\n <span style=\"margin-left: 10px\">Indietro</span>\r\n </button>\r\n </mat-card-actions>\r\n </mat-card-header>\r\n <mat-card-content>\r\n\r\n <graphs\r\n [formID]=\"formID\"\r\n [userID]=\"userID\"\r\n [configurations] = \"outCompileConfigurations\"\r\n [endPointConfiguration] = \"endPointConfiguration\"\r\n >\r\n </graphs>\r\n\r\n </mat-card-content>\r\n </mat-card>\r\n</ng-template>", styles: ["::ng-deep .error-color{color:var(--danger)}::ng-deep .success-color{color:var(--success)}::ng-deep .dynaform-question{font-size:1em;font-weight:lighter}::ng-deep .dynaform-response{font-size:1.2em;font-weight:700}::ng-deep .df-list-view-accordion .mat-expansion-panel-header-description{flex-grow:0!important}::ng-deep .mat-expansion-panel-header[aria-disabled=true]{color:#0000008a}\n"], dependencies: [{ kind: "component", type: i2$1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i2$1.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5$1.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i5$1.MatCardActions, selector: "mat-card-actions", inputs: ["align"], exportAs: ["matCardActions"] }, { kind: "directive", type: i5$1.MatCardContent, selector: "mat-card-content" }, { kind: "directive", type: i5$1.MatCardFooter, selector: "mat-card-footer" }, { kind: "component", type: i5$1.MatCardHeader, selector: "mat-card-header" }, { kind: "directive", type: i5$1.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { kind: "directive", type: i6$2.MatAccordion, selector: "mat-accordion", inputs: ["multi", "hideToggle", "displayMode", "togglePosition"], exportAs: ["matAccordion"] }, { kind: "component", type: i6$2.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "component", type: i6$2.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { kind: "directive", type: i6$2.MatExpansionPanelTitle, selector: "mat-panel-title" }, { kind: "directive", type: i6$2.MatExpansionPanelDescription, selector: "mat-panel-description" }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i2$3.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: AddFormRecordComponent, selector: "add-form-record", inputs: ["configurations", "endPointConfiguration", "userID", "formID", "form", "record", "onlyView", "isDuplicate", "additionalParams"], outputs: ["saveRecordEvent", "afterSaveRecordEvent"] }, { kind: "component", type: SingleRecordComponent, selector: "lib-single-record", inputs: ["endPointConfiguration", "record", "pageState", "userID", "form", "showBackButton", "outCompileConfigurations", "onlyView"], outputs: ["saveRecordEvent", "afterSaveRecordEvent"] }, { kind: "component", type: GraphsComponent, selector: "graphs", inputs: ["configurations", "endPointConfiguration", "userID", "formID", "form"] }, { kind: "pipe", type: i6.DatePipe, name: "date" }] });
4075
+ ListViewFormRecordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ListViewFormRecordComponent, selector: "list-view-form-record", inputs: { configurations: "configurations", compileConfigurations: "compileConfigurations", endPointConfiguration: "endPointConfiguration", userID: "userID", formID: "formID", form: "form", defaultListViewFunction: "defaultListViewFunction", externalButtons: "externalButtons", onlyView: "onlyView", records: "records", highlightFilter: "highlightFilter" }, outputs: { onAddViewEditRecord: "onAddViewEditRecord", onDeleteRecord: "onDeleteRecord", saveRecordEvent: "saveRecordEvent", afterSaveRecordEvent: "afterSaveRecordEvent" }, viewQueries: [{ propertyName: "tableRecords", first: true, predicate: ["tableRecords"], descendants: true, static: true }, { propertyName: "openAddDialog", first: true, predicate: ["openAddDialog"], descendants: true }, { propertyName: "openGraphDialog", first: true, predicate: ["openGraphDialog"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<mat-card class=\"list-view-form-record\">\n <mat-card-header *ngIf=\"showTitle || defaultListActions.add\" class=\"align-items-center justify-content-between\">\n <mat-card-title *ngIf=\"showTitle && loadedform\">Elenco {{ form.Name }} </mat-card-title>\n <mat-card-actions *ngIf=\"defaultListActions.add || defaultListActions.graphs\">\n <button \n *ngIf=\"defaultListActions.graphs\"\n class=\"btn btn-primary mr-2\" \n mat-raised-button \n color=\"primary\" \n type=\"button\"\n (click)=\"openGraphs()\">\n <mat-icon>pie_chart</mat-icon>\n <span style=\"margin-left: 10px\">Grafici</span>\n </button>\n <button \n *ngIf=\"defaultListActions.add\"\n class=\"btn btn-primary\" \n mat-raised-button \n color=\"primary\" \n type=\"button\"\n (click)=\"openAddPopup()\">\n <mat-icon>add</mat-icon>\n <span style=\"margin-left: 10px\">Aggiungi</span>\n </button> \n </mat-card-actions>\n </mat-card-header>\n\n \n <mat-card-content>\n <mat-accordion [hideToggle]=\"test\" [multi]=\"true\" class=\"df-list-view-accordion\">\n <mat-expansion-panel *ngFor=\"let panel of panels; index as i\" \n [expanded]=\"panel.isOpen\"\n [disabled]=\"1\" \n [class]=\"panel.highlighted ? 'dm_panel_highlighted' : '0'\"\n >\n <mat-expansion-panel-header\n (click)=\"togglePanel(panel, panel.record)\">\n <mat-panel-title>\n {{ form.Name }} v.{{ panel.record.Version }} - {{ panel.record.AnswerDate | date : \"EEEE, d MMMM y, H:mm:ss\" }}\n </mat-panel-title>\n <!--#region BOTTONI PER LE AZIONI -->\n <mat-panel-description>\n <button *ngFor=\"let button of buttons\" \n mat-icon-button \n class=\"record-icon {{button.extraClass}}\" \n [matTooltip]=\"button.text\"\n [hidden]=\"button.icon == 'file_copy' && (panels.length == 0 || panel.record.Version != panels[0].record.Version)\"\n (click)=\"button.fn(panel,i,$event)\">\n <mat-icon>{{button.icon}}</mat-icon>\n </button>\n <button *ngFor=\"let button of externalButtons\" \n mat-icon-button \n class=\"record-icon {{button.extraClass}}\"\n [matTooltip]=\"button.text\"\n (click)=\"externalCallback($event,button.fn,panel.record)\">\n <mat-icon>{{button.icon}}</mat-icon>\n </button> \n <span class=\"example-spacer\"></span>\n \n </mat-panel-description>\n <!--#endregion BOTTONI PER LE AZIONI -->\n </mat-expansion-panel-header>\n\n <!-- #region CONTENUTO -->\n <ng-container *ngIf=\"panel.pageState != null\">\n <lib-single-record\n [onlyView]=\"onlyView\"\n [record] = \"panel.record\" \n [endPointConfiguration] = \"endPointConfiguration\"\n [form]=\"form\"\n [userID]=\"userID\"\n [outCompileConfigurations]=\"outCompileConfigurations\"\n [pageState]=\"panel.pageState\"\n (saveRecordEvent)=\"saveOrExitForm($event)\"\n (afterSaveRecordEvent)=\"onAfterSaveRecord($event)\"\n >\n\n </lib-single-record>\n </ng-container>\n <!--#endregion CONTENUTO -->\n </mat-expansion-panel>\n </mat-accordion>\n\n\n </mat-card-content>\n <mat-card-footer>\n </mat-card-footer>\n</mat-card>\n\n<!-- DIALOG RECIPIENTS EMAIL PER FIRMA -->\n<ng-template #openAddDialog>\n <mat-card class=\"card-default overlay-card card-inmodal-true\">\n <mat-card-content>\n\n <add-form-record\n class=\"dynamic-module-compile\"\n [formID]=\"formID\"\n [onlyView]=\"false\"\n [record]=\"selectedRecord\"\n\n [endPointConfiguration]=\"endPointConfiguration\"\n [userID]=\"userID\"\n\n [configurations]=\"compileConfigurations\"\n [additionalParams]=\"compileConfigurations.additionalParams\"\n\n (saveRecordEvent)=\"onAddSaveRecord($event)\"\n (afterSaveRecordEvent)=\"onAddAfterSaveRecord($event)\"\n >\n </add-form-record>\n\n </mat-card-content>\n </mat-card>\n</ng-template>\n\n<!-- DIALOG RECIPIENTS EMAIL PER FIRMA -->\n<ng-template #openGraphDialog>\n <mat-card class=\"card-default overlay-card card-inmodal-true graphCard\">\n \n <mat-card-header class=\"align-items-center justify-content-between\">\n <mat-card-title>\n <div class=\"row eqp-dynamic-module-title graph-header\">\n <div class=\"col-md-12\">\n <span>Grafico {{ form.Name }} </span>\n </div>\n </div>\n </mat-card-title>\n <mat-card-actions>\n <button \n class=\"btn btn-primary mr-2\" \n mat-raised-button \n color=\"primary\" \n type=\"button\"\n (click)=\"closeGraphs()\">\n <span class=\"material-icons\">\n arrow_back\n </span>\n <span style=\"margin-left: 10px\">Indietro</span>\n </button>\n </mat-card-actions>\n </mat-card-header>\n <mat-card-content>\n\n <graphs\n [formID]=\"formID\"\n [userID]=\"userID\"\n [configurations] = \"outCompileConfigurations\"\n [endPointConfiguration] = \"endPointConfiguration\"\n >\n </graphs>\n\n </mat-card-content>\n </mat-card>\n</ng-template>", styles: ["::ng-deep .error-color{color:var(--danger)}::ng-deep .success-color{color:var(--success)}::ng-deep .dynaform-question{font-size:1em;font-weight:lighter}::ng-deep .dynaform-response{font-size:1.2em;font-weight:700}::ng-deep .df-list-view-accordion .mat-expansion-panel-header-description{flex-grow:0!important}::ng-deep .mat-expansion-panel-header[aria-disabled=true]{color:#0000008a}\n"], dependencies: [{ kind: "component", type: i2$1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i2$1.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5$1.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i5$1.MatCardActions, selector: "mat-card-actions", inputs: ["align"], exportAs: ["matCardActions"] }, { kind: "directive", type: i5$1.MatCardContent, selector: "mat-card-content" }, { kind: "directive", type: i5$1.MatCardFooter, selector: "mat-card-footer" }, { kind: "component", type: i5$1.MatCardHeader, selector: "mat-card-header" }, { kind: "directive", type: i5$1.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { kind: "directive", type: i6$2.MatAccordion, selector: "mat-accordion", inputs: ["multi", "hideToggle", "displayMode", "togglePosition"], exportAs: ["matAccordion"] }, { kind: "component", type: i6$2.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "component", type: i6$2.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { kind: "directive", type: i6$2.MatExpansionPanelTitle, selector: "mat-panel-title" }, { kind: "directive", type: i6$2.MatExpansionPanelDescription, selector: "mat-panel-description" }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i2$3.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: AddFormRecordComponent, selector: "add-form-record", inputs: ["configurations", "endPointConfiguration", "userID", "formID", "form", "record", "onlyView", "isDuplicate", "additionalParams"], outputs: ["saveRecordEvent", "afterSaveRecordEvent"] }, { kind: "component", type: SingleRecordComponent, selector: "lib-single-record", inputs: ["endPointConfiguration", "record", "pageState", "userID", "form", "showBackButton", "outCompileConfigurations", "onlyView"], outputs: ["saveRecordEvent", "afterSaveRecordEvent"] }, { kind: "component", type: GraphsComponent, selector: "graphs", inputs: ["configurations", "endPointConfiguration", "userID", "formID", "form"] }, { kind: "pipe", type: i6.DatePipe, name: "date" }] });
4016
4076
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ListViewFormRecordComponent, decorators: [{
4017
4077
  type: Component,
4018
- args: [{ selector: "list-view-form-record", template: "<mat-card class=\"list-view-form-record\">\r\n <mat-card-header *ngIf=\"showTitle || defaultListActions.add\" class=\"align-items-center justify-content-between\">\r\n <mat-card-title *ngIf=\"showTitle\">Elenco {{ form.Name }} </mat-card-title>\r\n <mat-card-actions *ngIf=\"defaultListActions.add || defaultListActions.graphs\">\r\n <button \r\n *ngIf=\"defaultListActions.graphs\"\r\n class=\"btn btn-primary mr-2\" \r\n mat-raised-button \r\n color=\"primary\" \r\n type=\"button\"\r\n (click)=\"openGraphs()\">\r\n <mat-icon>pie_chart</mat-icon>\r\n <span style=\"margin-left: 10px\">Grafici</span>\r\n </button>\r\n <button \r\n *ngIf=\"defaultListActions.add\"\r\n class=\"btn btn-primary\" \r\n mat-raised-button \r\n color=\"primary\" \r\n type=\"button\"\r\n (click)=\"openAddPopup()\">\r\n <mat-icon>add</mat-icon>\r\n <span style=\"margin-left: 10px\">Aggiungi</span>\r\n </button> \r\n </mat-card-actions>\r\n </mat-card-header>\r\n\r\n \r\n <mat-card-content>\r\n <mat-accordion [hideToggle]=\"test\" [multi]=\"true\" class=\"df-list-view-accordion\">\r\n <mat-expansion-panel *ngFor=\"let panel of panels; index as i\" \r\n [expanded]=\"panel.isOpen\"\r\n [disabled]=\"1\" \r\n [class]=\"panel.highlighted ? 'dm_panel_highlighted' : '0'\"\r\n >\r\n <mat-expansion-panel-header\r\n (click)=\"togglePanel(panel, panel.record)\">\r\n <mat-panel-title>\r\n {{ form.Name }} v.{{ panel.record.Version }} - {{ panel.record.AnswerDate | date : \"EEEE, d MMMM y, H:mm:ss\" }}\r\n </mat-panel-title>\r\n <!--#region BOTTONI PER LE AZIONI -->\r\n <mat-panel-description>\r\n <button *ngFor=\"let button of buttons\" \r\n mat-icon-button \r\n class=\"record-icon {{button.extraClass}}\" \r\n [matTooltip]=\"button.text\"\r\n [hidden]=\"button.icon == 'file_copy' && (panels.length == 0 || panel.record.Version != panels[0].record.Version)\"\r\n (click)=\"button.fn(panel,i,$event)\">\r\n <mat-icon>{{button.icon}}</mat-icon>\r\n </button>\r\n <button *ngFor=\"let button of externalButtons\" \r\n mat-icon-button \r\n class=\"record-icon {{button.extraClass}}\"\r\n [matTooltip]=\"button.text\"\r\n (click)=\"externalCallback($event,button.fn,panel.record)\">\r\n <mat-icon>{{button.icon}}</mat-icon>\r\n </button> \r\n <span class=\"example-spacer\"></span>\r\n \r\n </mat-panel-description>\r\n <!--#endregion BOTTONI PER LE AZIONI -->\r\n </mat-expansion-panel-header>\r\n\r\n <!-- #region CONTENUTO -->\r\n <ng-container *ngIf=\"panel.pageState != null\">\r\n <lib-single-record\r\n [onlyView]=\"onlyView\"\r\n [record] = \"panel.record\" \r\n [endPointConfiguration] = \"endPointConfiguration\"\r\n [form]=\"form\"\r\n [userID]=\"userID\"\r\n [outCompileConfigurations]=\"outCompileConfigurations\"\r\n [pageState]=\"panel.pageState\"\r\n (saveRecordEvent)=\"saveOrExitForm($event)\"\r\n (afterSaveRecordEvent)=\"onAfterSaveRecord($event)\"\r\n >\r\n\r\n </lib-single-record>\r\n </ng-container>\r\n <!--#endregion CONTENUTO -->\r\n </mat-expansion-panel>\r\n </mat-accordion>\r\n\r\n\r\n </mat-card-content>\r\n <mat-card-footer>\r\n </mat-card-footer>\r\n</mat-card>\r\n\r\n<!-- DIALOG RECIPIENTS EMAIL PER FIRMA -->\r\n<ng-template #openAddDialog>\r\n <mat-card class=\"card-default overlay-card card-inmodal-true\">\r\n <mat-card-content>\r\n\r\n <add-form-record\r\n class=\"dynamic-module-compile\"\r\n [formID]=\"formID\"\r\n [onlyView]=\"false\"\r\n [record]=\"selectedRecord\"\r\n\r\n [endPointConfiguration]=\"endPointConfiguration\"\r\n [userID]=\"userID\"\r\n\r\n [configurations]=\"compileConfigurations\"\r\n [additionalParams]=\"compileConfigurations.additionalParams\"\r\n\r\n (saveRecordEvent)=\"onAddSaveRecord($event)\"\r\n (afterSaveRecordEvent)=\"onAddAfterSaveRecord($event)\"\r\n >\r\n </add-form-record>\r\n\r\n </mat-card-content>\r\n </mat-card>\r\n</ng-template>\r\n\r\n<!-- DIALOG RECIPIENTS EMAIL PER FIRMA -->\r\n<ng-template #openGraphDialog>\r\n <mat-card class=\"card-default overlay-card card-inmodal-true graphCard\">\r\n \r\n <mat-card-header class=\"align-items-center justify-content-between\">\r\n <mat-card-title>\r\n <div class=\"row eqp-dynamic-module-title graph-header\">\r\n <div class=\"col-md-12\">\r\n <span>Grafico {{ form.Name }} </span>\r\n </div>\r\n </div>\r\n </mat-card-title>\r\n <mat-card-actions>\r\n <button \r\n class=\"btn btn-primary mr-2\" \r\n mat-raised-button \r\n color=\"primary\" \r\n type=\"button\"\r\n (click)=\"closeGraphs()\">\r\n <span class=\"material-icons\">\r\n arrow_back\r\n </span>\r\n <span style=\"margin-left: 10px\">Indietro</span>\r\n </button>\r\n </mat-card-actions>\r\n </mat-card-header>\r\n <mat-card-content>\r\n\r\n <graphs\r\n [formID]=\"formID\"\r\n [userID]=\"userID\"\r\n [configurations] = \"outCompileConfigurations\"\r\n [endPointConfiguration] = \"endPointConfiguration\"\r\n >\r\n </graphs>\r\n\r\n </mat-card-content>\r\n </mat-card>\r\n</ng-template>", styles: ["::ng-deep .error-color{color:var(--danger)}::ng-deep .success-color{color:var(--success)}::ng-deep .dynaform-question{font-size:1em;font-weight:lighter}::ng-deep .dynaform-response{font-size:1.2em;font-weight:700}::ng-deep .df-list-view-accordion .mat-expansion-panel-header-description{flex-grow:0!important}::ng-deep .mat-expansion-panel-header[aria-disabled=true]{color:#0000008a}\n"] }]
4078
+ args: [{ selector: "list-view-form-record", template: "<mat-card class=\"list-view-form-record\">\n <mat-card-header *ngIf=\"showTitle || defaultListActions.add\" class=\"align-items-center justify-content-between\">\n <mat-card-title *ngIf=\"showTitle && loadedform\">Elenco {{ form.Name }} </mat-card-title>\n <mat-card-actions *ngIf=\"defaultListActions.add || defaultListActions.graphs\">\n <button \n *ngIf=\"defaultListActions.graphs\"\n class=\"btn btn-primary mr-2\" \n mat-raised-button \n color=\"primary\" \n type=\"button\"\n (click)=\"openGraphs()\">\n <mat-icon>pie_chart</mat-icon>\n <span style=\"margin-left: 10px\">Grafici</span>\n </button>\n <button \n *ngIf=\"defaultListActions.add\"\n class=\"btn btn-primary\" \n mat-raised-button \n color=\"primary\" \n type=\"button\"\n (click)=\"openAddPopup()\">\n <mat-icon>add</mat-icon>\n <span style=\"margin-left: 10px\">Aggiungi</span>\n </button> \n </mat-card-actions>\n </mat-card-header>\n\n \n <mat-card-content>\n <mat-accordion [hideToggle]=\"test\" [multi]=\"true\" class=\"df-list-view-accordion\">\n <mat-expansion-panel *ngFor=\"let panel of panels; index as i\" \n [expanded]=\"panel.isOpen\"\n [disabled]=\"1\" \n [class]=\"panel.highlighted ? 'dm_panel_highlighted' : '0'\"\n >\n <mat-expansion-panel-header\n (click)=\"togglePanel(panel, panel.record)\">\n <mat-panel-title>\n {{ form.Name }} v.{{ panel.record.Version }} - {{ panel.record.AnswerDate | date : \"EEEE, d MMMM y, H:mm:ss\" }}\n </mat-panel-title>\n <!--#region BOTTONI PER LE AZIONI -->\n <mat-panel-description>\n <button *ngFor=\"let button of buttons\" \n mat-icon-button \n class=\"record-icon {{button.extraClass}}\" \n [matTooltip]=\"button.text\"\n [hidden]=\"button.icon == 'file_copy' && (panels.length == 0 || panel.record.Version != panels[0].record.Version)\"\n (click)=\"button.fn(panel,i,$event)\">\n <mat-icon>{{button.icon}}</mat-icon>\n </button>\n <button *ngFor=\"let button of externalButtons\" \n mat-icon-button \n class=\"record-icon {{button.extraClass}}\"\n [matTooltip]=\"button.text\"\n (click)=\"externalCallback($event,button.fn,panel.record)\">\n <mat-icon>{{button.icon}}</mat-icon>\n </button> \n <span class=\"example-spacer\"></span>\n \n </mat-panel-description>\n <!--#endregion BOTTONI PER LE AZIONI -->\n </mat-expansion-panel-header>\n\n <!-- #region CONTENUTO -->\n <ng-container *ngIf=\"panel.pageState != null\">\n <lib-single-record\n [onlyView]=\"onlyView\"\n [record] = \"panel.record\" \n [endPointConfiguration] = \"endPointConfiguration\"\n [form]=\"form\"\n [userID]=\"userID\"\n [outCompileConfigurations]=\"outCompileConfigurations\"\n [pageState]=\"panel.pageState\"\n (saveRecordEvent)=\"saveOrExitForm($event)\"\n (afterSaveRecordEvent)=\"onAfterSaveRecord($event)\"\n >\n\n </lib-single-record>\n </ng-container>\n <!--#endregion CONTENUTO -->\n </mat-expansion-panel>\n </mat-accordion>\n\n\n </mat-card-content>\n <mat-card-footer>\n </mat-card-footer>\n</mat-card>\n\n<!-- DIALOG RECIPIENTS EMAIL PER FIRMA -->\n<ng-template #openAddDialog>\n <mat-card class=\"card-default overlay-card card-inmodal-true\">\n <mat-card-content>\n\n <add-form-record\n class=\"dynamic-module-compile\"\n [formID]=\"formID\"\n [onlyView]=\"false\"\n [record]=\"selectedRecord\"\n\n [endPointConfiguration]=\"endPointConfiguration\"\n [userID]=\"userID\"\n\n [configurations]=\"compileConfigurations\"\n [additionalParams]=\"compileConfigurations.additionalParams\"\n\n (saveRecordEvent)=\"onAddSaveRecord($event)\"\n (afterSaveRecordEvent)=\"onAddAfterSaveRecord($event)\"\n >\n </add-form-record>\n\n </mat-card-content>\n </mat-card>\n</ng-template>\n\n<!-- DIALOG RECIPIENTS EMAIL PER FIRMA -->\n<ng-template #openGraphDialog>\n <mat-card class=\"card-default overlay-card card-inmodal-true graphCard\">\n \n <mat-card-header class=\"align-items-center justify-content-between\">\n <mat-card-title>\n <div class=\"row eqp-dynamic-module-title graph-header\">\n <div class=\"col-md-12\">\n <span>Grafico {{ form.Name }} </span>\n </div>\n </div>\n </mat-card-title>\n <mat-card-actions>\n <button \n class=\"btn btn-primary mr-2\" \n mat-raised-button \n color=\"primary\" \n type=\"button\"\n (click)=\"closeGraphs()\">\n <span class=\"material-icons\">\n arrow_back\n </span>\n <span style=\"margin-left: 10px\">Indietro</span>\n </button>\n </mat-card-actions>\n </mat-card-header>\n <mat-card-content>\n\n <graphs\n [formID]=\"formID\"\n [userID]=\"userID\"\n [configurations] = \"outCompileConfigurations\"\n [endPointConfiguration] = \"endPointConfiguration\"\n >\n </graphs>\n\n </mat-card-content>\n </mat-card>\n</ng-template>", styles: ["::ng-deep .error-color{color:var(--danger)}::ng-deep .success-color{color:var(--success)}::ng-deep .dynaform-question{font-size:1em;font-weight:lighter}::ng-deep .dynaform-response{font-size:1.2em;font-weight:700}::ng-deep .df-list-view-accordion .mat-expansion-panel-header-description{flex-grow:0!important}::ng-deep .mat-expansion-panel-header[aria-disabled=true]{color:#0000008a}\n"] }]
4019
4079
  }], ctorParameters: function () { return [{ type: UtilityHelperService }, { type: i0.ChangeDetectorRef }, { type: i1$2.MatDialog }, { type: i3$3.Router }]; }, propDecorators: { configurations: [{
4020
4080
  type: Input
4021
4081
  }], compileConfigurations: [{