@eqproject/eqp-dynamic-module 2.10.9 → 2.10.12

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.
@@ -41,7 +41,7 @@ export class NumericFilterTemplateComponent {
41
41
  if (changes.hasOwnProperty('Statistic') && !changes['Statistic'].firstChange) {
42
42
  this.isX = changes['Statistic'].currentValue.isX;
43
43
  this.isY = changes['Statistic'].currentValue.isY;
44
- this.aggregations = changes['aggregations'].currentValue.aggregations;
44
+ this.aggregations = changes['Statistic'].currentValue.aggregations;
45
45
  }
46
46
  }
47
47
  //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html
@@ -142,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
142
142
  }], filterChange: [{
143
143
  type: Output
144
144
  }] } });
145
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"numeric-filter-template.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-statistics/filter-templates/numeric-filter-template/numeric-filter-template.component.ts","../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-statistics/filter-templates/numeric-filter-template/numeric-filter-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { Validators } from '@angular/forms';\r\nimport { EqpNumericInputMode, NumericMaskConfig } from '@eqproject/eqp-numeric';\r\nimport { UtilityHelperService } from '../../../../../services/utilityHelper.services';\r\nimport { Record } from '../../../../../models/record.model';\r\nimport { NumericField } from '../../../../../models/fields/numericField.model';\r\nimport { LogicOperatorNumeric } from '../../../../../models/logicOperator.model';\r\nimport { NotNumberAggregationFunctionEnum, NumberAggregationFunctionEnum, Statistic } from '../../../../../models/statistic.model';\r\nimport { DynamicModuleFilterResultViewModeEnum } from '../../../../../models/dynamicModuleFilterResultViewModeEnum.model';\r\n\r\n@Component({\r\n  selector: 'numeric-filter-template',\r\n  templateUrl: './numeric-filter-template.component.html',\r\n  styleUrls: ['./numeric-filter-template.component.scss']\r\n})\r\nexport class NumericFilterTemplateComponent implements OnInit {\r\n\r\n  @Input() field: NumericField;\r\n  @Input() record: Record;\r\n  @Input() Statistic: Statistic = null;\r\n  @Input() filterResultViewMode: DynamicModuleFilterResultViewModeEnum;\r\n  @Output() filterChange: EventEmitter<any> = new EventEmitter<any>();\r\n  validatorsArray: any[] = [];\r\n  eqpNumericOptions: Partial<NumericMaskConfig> = {};\r\n  logicOperatorNumeric = LogicOperatorNumeric;\r\n  selectedLogicOperator: LogicOperatorNumeric;\r\n  activeCondition: boolean = false;\r\n  visible: boolean = false;\r\n  currentStatistic: Statistic = null;\r\n\r\n//variabili per gestire il css della label e del field\r\nFieldstyleObj: any;\r\nLabelstyleObj: any;\r\n\r\nisX: boolean;\r\nisY: boolean;\r\n\r\naggregations: Array<NumberAggregationFunctionEnum> | Array<NotNumberAggregationFunctionEnum>;\r\naggregationFunctionEnum = NumberAggregationFunctionEnum;\r\n\r\nconstructor() {\r\n}\r\n\r\nngOnInit(): void {\r\n\r\n  if (this.Statistic != null){\r\n    this.selectedLogicOperator = (this.Statistic.logicoperator as LogicOperatorNumeric);\r\n    this.record[this.field.Name] = this.Statistic.value;\r\n    this.visible = this.Statistic.visible;\r\n    this.isX = this.Statistic.isX;\r\n    this.isY = this.Statistic.isY;\r\n    this.aggregations = this.Statistic.aggregations;\r\n  }  \r\n  \r\n  this.configureEqpNumericOptions();\r\n  this.configureControllers();\r\n  this.initStyles();\r\n\r\n}\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n      if (changes.hasOwnProperty('Statistic') && !changes['Statistic'].firstChange){\r\n        this.isX = changes['Statistic'].currentValue.isX;\r\n        this.isY = changes['Statistic'].currentValue.isY;\r\n        this.aggregations = changes['aggregations'].currentValue.aggregations;\r\n      }   \r\n  }  \r\n\r\n  //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html\r\n  initStyles() {\r\n    if(this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)   \r\n    this.FieldstyleObj= UtilityHelperService.initStyles(this.field.FieldstyleCSS);\r\n    if(this.field.LabelstyleCSS != null || this.field.LabelstyleCSS != undefined)   \r\n    this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);\r\n}\r\n\r\n/**\r\n* Metodo per emettere l'evento che il valore del record è cambiato.\r\n*/\r\nonFilterChange() {   \r\n    var statistic = this.createStatistic();\r\n    this.filterChange.emit(statistic);\r\n}\r\n\r\ncreateStatistic(){\r\n\r\n  var statistic: Statistic = {\r\n    key: this.field.Name,\r\n    value: this.record[this.field.Name],\r\n    logicoperator: this.selectedLogicOperator,\r\n    fieldtype: this.field.FieldType,\r\n    visible: this.visible,\r\n    isX: this.isX,\r\n    isY: this.isY,\r\n    aggregations: this.aggregations\r\n  }\r\n\r\n  return statistic;\r\n}\r\n\r\n/**\r\n* Metodo per configurare eqp-numeric\r\n*/\r\nprivate configureEqpNumericOptions() {\r\n\r\n  this.eqpNumericOptions.suffix = this.field.MeasureUnit ? \"  \"+this.field.MeasureUnit+\"  \" : \"\";\r\n  this.eqpNumericOptions.prefix = this.field.CurrencySymbol ? this.field.CurrencySymbol+\" \" : \"\";\r\n  this.eqpNumericOptions.inputMode = this.field.CurrencySymbol ? EqpNumericInputMode.FINANCIAL : EqpNumericInputMode.NATURAL;\r\n  this.eqpNumericOptions.allowNegative=true;\r\n  if (this.field.DecimalSeparator != null && this.field.DecimalSeparator != undefined)\r\n  this.eqpNumericOptions.decimal = this.field.DecimalSeparator;\r\n  else\r\n  this.eqpNumericOptions.decimal=\".\";\r\n  if (this.field.ThousandsSeparator != null && this.field.ThousandsSeparator != undefined)\r\n  this.eqpNumericOptions.thousands = this.field.ThousandsSeparator;\r\n  if(this.field.IsInteger== false){\r\n    if (this.field.DecimalPrecision != null && this.field.DecimalPrecision != undefined) { this.eqpNumericOptions.precision = this.field.DecimalPrecision; }\r\n    else { this.eqpNumericOptions.precision = 2; }\r\n  }else{\r\n    this.eqpNumericOptions.precision = 0;\r\n  }\r\n}\r\n\r\n/**\r\n* Metodo di aggiunta dei validator dell'input\r\n*/\r\nprivate configureControllers() {\r\n  this.validatorsArray = [];\r\n  if (this.field.MinValue != null && this.field.MinValue != undefined)\r\n  this.validatorsArray.push(Validators.min(this.field.MinValue));\r\n  if (this.field.MaxValue != null && this.field.MaxValue != undefined)\r\n  this.validatorsArray.push(Validators.max(this.field.MaxValue));\r\n}\r\n\r\n/**\r\n * Gestione visibilità\r\n */\r\n\r\n  public changeVisibility(){\r\n    this.visible = !this.visible;\r\n    this.onFilterChange();\r\n  }\r\n\r\n  public becomeTheCoord(theCoord: string){\r\n    if (theCoord == \"X\"){ \r\n      this.isY = false;\r\n      this.isX = !this.isX; \r\n    } \r\n    if (theCoord == \"Y\"){ \r\n      this.isX = false;\r\n      this.isY = !this.isY; \r\n    } \r\n    this.onFilterChange();\r\n  }\r\n\r\n\r\n  \r\n}\r\n","<div class=\"row\">\r\n    <div class=\"col-12 rowCol\">\r\n        <div class=\"valueCol\">\r\n            <mat-form-field [formGroup]=\"field.FormFormGroup\">\r\n                <mat-label  class=\"pt-1\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n                        <input [ngStyle]=\"FieldstyleObj\" matInput eqpNumericMask [formControlName]=\"field.Name\" [readonly]=\"false\"\r\n                        [required]=\"false\" [(ngModel)]=\"record[field.Name]\" [options]=\"eqpNumericOptions\"\r\n                        [step]=\"field.IsInteger ? 1 : null\" (ngModelChange)=\"onFilterChange()\" />\r\n                        <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched\">\r\n                            Min: {{field.MinValue}} - Max: {{field.MaxValue}}\r\n                        </mat-error>\r\n            </mat-form-field>\r\n        </div>\r\n        <div class=\"operatorCol\">\r\n            <eqp-select [enumData]=\"logicOperatorNumeric\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onFilterChange()\"></eqp-select>\r\n        </div>\r\n        <div class=\"visibleCol\">\r\n            <button class=\"btn\" [ngClass]=\"{'btn-success': visible , 'btn-danger': !visible }\" (click)=\"changeVisibility()\">\r\n                <mat-icon *ngIf=\"visible\">visibility</mat-icon>\r\n                <mat-icon *ngIf=\"!visible\">visibility_off</mat-icon>\r\n            </button>\r\n        </div>     \r\n        <div class=\"coordinatesCol\">\r\n            <button class=\"btn\" [ngClass]=\"{'btn-primary': !isX , 'btn-success': isX }\" (click)=\"becomeTheCoord('X')\">X</button>\r\n            <button class=\"btn\" [ngClass]=\"{'btn-primary': !isY , 'btn-success': isY }\" (click)=\"becomeTheCoord('Y')\">Y</button>\r\n        </div>  \r\n        <div class=\"aggregatorCol\">\r\n            <eqp-select\r\n                [isMultiSelect]=\"true\"\r\n                [enumData]=\"aggregationFunctionEnum\"\r\n                [(ngModelInput)]=\"aggregations\"\r\n                (ngModelInputChange)=\"onFilterChange()\"\r\n            ></eqp-select>\r\n        </div>                   \r\n    </div>\r\n</div>"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"numeric-filter-template.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-statistics/filter-templates/numeric-filter-template/numeric-filter-template.component.ts","../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/form-statistics/filter-templates/numeric-filter-template/numeric-filter-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { Validators } from '@angular/forms';\r\nimport { EqpNumericInputMode, NumericMaskConfig } from '@eqproject/eqp-numeric';\r\nimport { UtilityHelperService } from '../../../../../services/utilityHelper.services';\r\nimport { Record } from '../../../../../models/record.model';\r\nimport { NumericField } from '../../../../../models/fields/numericField.model';\r\nimport { LogicOperatorNumeric } from '../../../../../models/logicOperator.model';\r\nimport { NotNumberAggregationFunctionEnum, NumberAggregationFunctionEnum, Statistic } from '../../../../../models/statistic.model';\r\nimport { DynamicModuleFilterResultViewModeEnum } from '../../../../../models/dynamicModuleFilterResultViewModeEnum.model';\r\n\r\n@Component({\r\n  selector: 'numeric-filter-template',\r\n  templateUrl: './numeric-filter-template.component.html',\r\n  styleUrls: ['./numeric-filter-template.component.scss']\r\n})\r\nexport class NumericFilterTemplateComponent implements OnInit {\r\n\r\n  @Input() field: NumericField;\r\n  @Input() record: Record;\r\n  @Input() Statistic: Statistic = null;\r\n  @Input() filterResultViewMode: DynamicModuleFilterResultViewModeEnum;\r\n  @Output() filterChange: EventEmitter<any> = new EventEmitter<any>();\r\n  validatorsArray: any[] = [];\r\n  eqpNumericOptions: Partial<NumericMaskConfig> = {};\r\n  logicOperatorNumeric = LogicOperatorNumeric;\r\n  selectedLogicOperator: LogicOperatorNumeric;\r\n  activeCondition: boolean = false;\r\n  visible: boolean = false;\r\n  currentStatistic: Statistic = null;\r\n\r\n//variabili per gestire il css della label e del field\r\nFieldstyleObj: any;\r\nLabelstyleObj: any;\r\n\r\nisX: boolean;\r\nisY: boolean;\r\n\r\naggregations: Array<NumberAggregationFunctionEnum> | Array<NotNumberAggregationFunctionEnum>;\r\naggregationFunctionEnum = NumberAggregationFunctionEnum;\r\n\r\nconstructor() {\r\n}\r\n\r\nngOnInit(): void {\r\n\r\n  if (this.Statistic != null){\r\n    this.selectedLogicOperator = (this.Statistic.logicoperator as LogicOperatorNumeric);\r\n    this.record[this.field.Name] = this.Statistic.value;\r\n    this.visible = this.Statistic.visible;\r\n    this.isX = this.Statistic.isX;\r\n    this.isY = this.Statistic.isY;\r\n    this.aggregations = this.Statistic.aggregations;\r\n  }  \r\n  \r\n  this.configureEqpNumericOptions();\r\n  this.configureControllers();\r\n  this.initStyles();\r\n\r\n}\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n      if (changes.hasOwnProperty('Statistic') && !changes['Statistic'].firstChange){\r\n        this.isX = changes['Statistic'].currentValue.isX;\r\n        this.isY = changes['Statistic'].currentValue.isY;\r\n        this.aggregations = changes['Statistic'].currentValue.aggregations;\r\n      }   \r\n  }  \r\n\r\n  //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html\r\n  initStyles() {\r\n    if(this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)   \r\n    this.FieldstyleObj= UtilityHelperService.initStyles(this.field.FieldstyleCSS);\r\n    if(this.field.LabelstyleCSS != null || this.field.LabelstyleCSS != undefined)   \r\n    this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);\r\n}\r\n\r\n/**\r\n* Metodo per emettere l'evento che il valore del record è cambiato.\r\n*/\r\nonFilterChange() {   \r\n    var statistic = this.createStatistic();\r\n    this.filterChange.emit(statistic);\r\n}\r\n\r\ncreateStatistic(){\r\n\r\n  var statistic: Statistic = {\r\n    key: this.field.Name,\r\n    value: this.record[this.field.Name],\r\n    logicoperator: this.selectedLogicOperator,\r\n    fieldtype: this.field.FieldType,\r\n    visible: this.visible,\r\n    isX: this.isX,\r\n    isY: this.isY,\r\n    aggregations: this.aggregations\r\n  }\r\n\r\n  return statistic;\r\n}\r\n\r\n/**\r\n* Metodo per configurare eqp-numeric\r\n*/\r\nprivate configureEqpNumericOptions() {\r\n\r\n  this.eqpNumericOptions.suffix = this.field.MeasureUnit ? \"  \"+this.field.MeasureUnit+\"  \" : \"\";\r\n  this.eqpNumericOptions.prefix = this.field.CurrencySymbol ? this.field.CurrencySymbol+\" \" : \"\";\r\n  this.eqpNumericOptions.inputMode = this.field.CurrencySymbol ? EqpNumericInputMode.FINANCIAL : EqpNumericInputMode.NATURAL;\r\n  this.eqpNumericOptions.allowNegative=true;\r\n  if (this.field.DecimalSeparator != null && this.field.DecimalSeparator != undefined)\r\n  this.eqpNumericOptions.decimal = this.field.DecimalSeparator;\r\n  else\r\n  this.eqpNumericOptions.decimal=\".\";\r\n  if (this.field.ThousandsSeparator != null && this.field.ThousandsSeparator != undefined)\r\n  this.eqpNumericOptions.thousands = this.field.ThousandsSeparator;\r\n  if(this.field.IsInteger== false){\r\n    if (this.field.DecimalPrecision != null && this.field.DecimalPrecision != undefined) { this.eqpNumericOptions.precision = this.field.DecimalPrecision; }\r\n    else { this.eqpNumericOptions.precision = 2; }\r\n  }else{\r\n    this.eqpNumericOptions.precision = 0;\r\n  }\r\n}\r\n\r\n/**\r\n* Metodo di aggiunta dei validator dell'input\r\n*/\r\nprivate configureControllers() {\r\n  this.validatorsArray = [];\r\n  if (this.field.MinValue != null && this.field.MinValue != undefined)\r\n  this.validatorsArray.push(Validators.min(this.field.MinValue));\r\n  if (this.field.MaxValue != null && this.field.MaxValue != undefined)\r\n  this.validatorsArray.push(Validators.max(this.field.MaxValue));\r\n}\r\n\r\n/**\r\n * Gestione visibilità\r\n */\r\n\r\n  public changeVisibility(){\r\n    this.visible = !this.visible;\r\n    this.onFilterChange();\r\n  }\r\n\r\n  public becomeTheCoord(theCoord: string){\r\n    if (theCoord == \"X\"){ \r\n      this.isY = false;\r\n      this.isX = !this.isX; \r\n    } \r\n    if (theCoord == \"Y\"){ \r\n      this.isX = false;\r\n      this.isY = !this.isY; \r\n    } \r\n    this.onFilterChange();\r\n  }\r\n\r\n\r\n  \r\n}\r\n","<div class=\"row\">\r\n    <div class=\"col-12 rowCol\">\r\n        <div class=\"valueCol\">\r\n            <mat-form-field [formGroup]=\"field.FormFormGroup\">\r\n                <mat-label  class=\"pt-1\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n                        <input [ngStyle]=\"FieldstyleObj\" matInput eqpNumericMask [formControlName]=\"field.Name\" [readonly]=\"false\"\r\n                        [required]=\"false\" [(ngModel)]=\"record[field.Name]\" [options]=\"eqpNumericOptions\"\r\n                        [step]=\"field.IsInteger ? 1 : null\" (ngModelChange)=\"onFilterChange()\" />\r\n                        <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched\">\r\n                            Min: {{field.MinValue}} - Max: {{field.MaxValue}}\r\n                        </mat-error>\r\n            </mat-form-field>\r\n        </div>\r\n        <div class=\"operatorCol\">\r\n            <eqp-select [enumData]=\"logicOperatorNumeric\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onFilterChange()\"></eqp-select>\r\n        </div>\r\n        <div class=\"visibleCol\">\r\n            <button class=\"btn\" [ngClass]=\"{'btn-success': visible , 'btn-danger': !visible }\" (click)=\"changeVisibility()\">\r\n                <mat-icon *ngIf=\"visible\">visibility</mat-icon>\r\n                <mat-icon *ngIf=\"!visible\">visibility_off</mat-icon>\r\n            </button>\r\n        </div>     \r\n        <div class=\"coordinatesCol\">\r\n            <button class=\"btn\" [ngClass]=\"{'btn-primary': !isX , 'btn-success': isX }\" (click)=\"becomeTheCoord('X')\">X</button>\r\n            <button class=\"btn\" [ngClass]=\"{'btn-primary': !isY , 'btn-success': isY }\" (click)=\"becomeTheCoord('Y')\">Y</button>\r\n        </div>  \r\n        <div class=\"aggregatorCol\">\r\n            <eqp-select\r\n                [isMultiSelect]=\"true\"\r\n                [enumData]=\"aggregationFunctionEnum\"\r\n                [(ngModelInput)]=\"aggregations\"\r\n                (ngModelInputChange)=\"onFilterChange()\"\r\n            ></eqp-select>\r\n        </div>                   \r\n    </div>\r\n</div>"]}
@@ -163,10 +163,10 @@ export class GraphComponent {
163
163
  }
164
164
  }
165
165
  GraphComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GraphComponent, deps: [{ token: i1.DatePipe }], target: i0.ɵɵFactoryTarget.Component });
166
- GraphComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: GraphComponent, selector: "graph", inputs: { data: "data", title: "title" }, host: { listeners: { "window:resize": "onResize($event)" } }, 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: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.CanvasJSStockChart, selector: "canvasjs-stockchart", inputs: ["options", "styles"], outputs: ["stockChartInstance"] }] });
166
+ GraphComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: GraphComponent, selector: "graph", inputs: { data: "data", title: "title" }, host: { listeners: { "window:resize": "onResize($event)" } }, ngImport: i0, template: "<canvasjs-stockchart *ngIf=\"loaded\" [options]=\"stockChartOptions\"></canvasjs-stockchart>\n<div class=\"error\" *ngIf=\"!loaded\"><b>{{title}}:</b> Nessun dato trovato nell'intervallo specificato!</div>", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.CanvasJSStockChart, selector: "canvasjs-stockchart", inputs: ["options", "styles"], outputs: ["stockChartInstance"] }] });
167
167
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GraphComponent, decorators: [{
168
168
  type: Component,
169
- 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>" }]
169
+ args: [{ selector: 'graph', template: "<canvasjs-stockchart *ngIf=\"loaded\" [options]=\"stockChartOptions\"></canvasjs-stockchart>\n<div class=\"error\" *ngIf=\"!loaded\"><b>{{title}}:</b> Nessun dato trovato nell'intervallo specificato!</div>" }]
170
170
  }], ctorParameters: function () { return [{ type: i1.DatePipe }]; }, propDecorators: { onResize: [{
171
171
  type: HostListener,
172
172
  args: ['window:resize', ['$event']]
@@ -177,4 +177,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
177
177
  type: Input,
178
178
  args: ["title"]
179
179
  }] } });
180
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"graph.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/graphs/graph/graph.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/graphs/graph/graph.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, Input, OnInit } from '@angular/core';\r\nimport { Coords } from '../../../../models/graph.model';\r\nimport { DatePipe } from '@angular/common';\r\nimport * as ss from 'simple-statistics';\r\n\r\n\r\n@Component({\r\n  selector: 'graph',\r\n  templateUrl: './graph.component.html',\r\n  styleUrls: ['./graph.component.scss']\r\n})\r\n\r\nexport class GraphComponent implements OnInit {\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onResize() {\r\n    this.loaded = false;\r\n    this.loadGraph(Math.floor(window.innerWidth/2));\r\n  }\r\n\r\n  @Input(\"data\") data: Array<Coords> = new Array<Coords>();\r\n  @Input(\"title\") title: string = \"\";\r\n\r\n  trendColor: string = '#EB0102';\r\n  mainColor: string = '#006cad';\r\n\r\n  m: number; // m of the linear regression\r\n  q: number; // q of the linear regression\r\n  trend: string; // trend string\r\n  linearRegression: Array<Coords>; // variable used to store the linear regression points to plot\r\n\r\n\r\n\r\n  stockChartOptions: any;\r\n\r\n  loaded: boolean = false;\r\n  counter: number = 0;\r\n\r\n  constructor(\r\n    private datePipe: DatePipe\r\n    ) {}  \r\n\r\n  ngOnInit() {\r\n\r\n    var self = this;\r\n\r\n    // Aggiustamento e scrittura dati\r\n    if (this.data.length > 0){\r\n      this.loadGraph(Math.floor(window.innerWidth/2));\r\n    }\r\n  }\r\n\r\n  loadGraph(width: number){\r\n\r\n    var lastvalue = this.data[0];\r\n    var firstvalue = this.data[this.data.length-1];\r\n\r\n    var stockChartMinimum = new Date(firstvalue.x);\r\n    var stockChartMaximum = new Date(lastvalue.x);\r\n    var stockChartTitleText = this.title;\r\n    var stockChartdataPoints = this.data;\r\n\r\n    this.linearRegression = new Array<Coords>();\r\n    this.trend = \"\";\r\n\r\n    stockChartdataPoints.reverse();\r\n    if (stockChartdataPoints.length > 2) {\r\n      let x = [];\r\n      for (let i = 0; i<stockChartdataPoints.length; i ++) {\r\n        x.push([i, stockChartdataPoints[i].y]);\r\n      }\r\n      let parameters = ss.linearRegression(x);\r\n      this.m = parameters.m;\r\n      this.q = parameters.b;\r\n      if (this.m > 0) {\r\n          this.trend += \" ↗\";\r\n        } else if (this.m < 0) {\r\n          this.trend += \" ↘\";\r\n      }\r\n      // console.log(x);\r\n      // console.log(stockChartdataPoints);\r\n      \r\n      for (let i = 0; i<stockChartdataPoints.length; i ++) {\r\n        if (i == 0 || i == stockChartdataPoints.length - 1) {\r\n          this.linearRegression.push({x: stockChartdataPoints[i].x,\r\n            y: this.m*i + this.q,\r\n            label: stockChartdataPoints[i].label,\r\n            name: stockChartdataPoints[i].name\r\n          })\r\n        }\r\n      }\r\n      //this.linearRegression.reverse();\r\n      // console.log(this.linearRegression);\r\n      // console.log(this.m);\r\n      // console.log(this.q);\r\n    }\r\n\r\n    this.stockChartOptions = {\r\n      theme: 'light2',\r\n      animationEnabled: true,\r\n      width: width,\r\n      height: 500,\r\n      creditText: \"\",\r\n      creditHref: \"\",\r\n      title: {\r\n        text: stockChartTitleText\r\n      },\r\n      charts: [{\r\n        axisX: {\r\n          labelFormatter: this.labelFormatterFunction,\r\n        },\r\n        data: [\r\n          {\r\n            toolTipContent: null,\r\n            type: 'line',\r\n            color: this.trendColor,\r\n            showInLegend: true,\r\n            legendMarkerType: \"none\",\r\n            markerType: \"none\",\r\n            legendText: \"Trend\" + this.trend,\r\n            dataPoints: this.linearRegression\r\n          },\r\n          {\r\n            type: \"spline\",\r\n            dataPoints: stockChartdataPoints,\r\n            color: this.mainColor,\r\n          }\r\n        ],\r\n        culture: \"it\"\r\n      }],\r\n      rangeSelector: {\r\n        enabled: false\r\n      },\r\n      navigator: {\r\n        slider: {\r\n          minimum: stockChartMinimum,\r\n          maximum: stockChartMaximum\r\n        }\r\n      },\r\n      options: {\r\n        responsive: true,\r\n        maintainAspectRatio: false\r\n      }\r\n    };\r\n\r\n    this.loaded = true;\r\n  }\r\n\r\n  labelFormatterFunction(e) {\r\n    let label = \"\";\r\n    let dirtyLabel;\r\n    let date = e.value;\r\n\r\n      let newYear: number = date.getFullYear();\r\n      let newMonth: number = date.getMonth() + 1;\r\n      let newMonthString: string;\r\n      if (newMonth < 10) {\r\n      newMonthString = \"0\" + newMonth.toString();\r\n      } else {\r\n      newMonthString = newMonth.toString();\r\n      }\r\n      let newDay: number = date.getDate();\r\n      let newDayString: string;\r\n      if (newDay < 10) {\r\n      newDayString = \"0\" + newDay.toString();\r\n      } else {\r\n      newDayString = newDay.toString();\r\n      }\r\n      let newHour: number = date.getHours();\r\n      let newHourString: string;\r\n      if (newHour < 10) {\r\n      newHourString = \"0\" + newHour.toString();\r\n      } else {\r\n      newHourString = newHour.toString();\r\n      }\r\n      let newMinute: number = date.getMinutes();\r\n      let newMinuteString: string;\r\n      if (newMinute < 10) {\r\n      newMinuteString = \"0\" + newMinute.toString();\r\n      } else {\r\n      newMinuteString = newMinute.toString();\r\n      }\r\n\r\n      dirtyLabel = newDayString + \"/\" + newMonthString + \"/\" + newYear.toString() + \" \" + newHourString  + \":\" + newMinuteString;\r\n\r\n      for (let i = 0; i < 5; i++) {\r\n        label += dirtyLabel[i];\r\n      }\r\n      label += \" \";\r\n      for (let i = 11; i < 16; i++) {\r\n        label += dirtyLabel[i];\r\n      }\r\n\r\n      //label = label.replace(\"00:00\",\"\");\r\n    \r\n    return label;\r\n  }  \r\n  \r\n\r\n}\r\n","<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>"]}
180
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"graph.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/graphs/graph/graph.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/graphs/graph/graph.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, Input, OnInit } from '@angular/core';\r\nimport { Coords } from '../../../../models/graph.model';\r\nimport { DatePipe } from '@angular/common';\r\nimport * as ss from 'simple-statistics';\r\n\r\n\r\n@Component({\r\n  selector: 'graph',\r\n  templateUrl: './graph.component.html',\r\n  styleUrls: ['./graph.component.scss']\r\n})\r\n\r\nexport class GraphComponent implements OnInit {\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onResize() {\r\n    this.loaded = false;\r\n    this.loadGraph(Math.floor(window.innerWidth/2));\r\n  }\r\n\r\n  @Input(\"data\") data: Array<Coords> = new Array<Coords>();\r\n  @Input(\"title\") title: string = \"\";\r\n\r\n  trendColor: string = '#EB0102';\r\n  mainColor: string = '#006cad';\r\n\r\n  m: number; // m of the linear regression\r\n  q: number; // q of the linear regression\r\n  trend: string; // trend string\r\n  linearRegression: Array<Coords>; // variable used to store the linear regression points to plot\r\n\r\n\r\n\r\n  stockChartOptions: any;\r\n\r\n  loaded: boolean = false;\r\n  counter: number = 0;\r\n\r\n  constructor(\r\n    private datePipe: DatePipe\r\n    ) {}  \r\n\r\n  ngOnInit() {\r\n\r\n    var self = this;\r\n\r\n    // Aggiustamento e scrittura dati\r\n    if (this.data.length > 0){\r\n      this.loadGraph(Math.floor(window.innerWidth/2));\r\n    }\r\n  }\r\n\r\n  loadGraph(width: number){\r\n\r\n    var lastvalue = this.data[0];\r\n    var firstvalue = this.data[this.data.length-1];\r\n\r\n    var stockChartMinimum = new Date(firstvalue.x);\r\n    var stockChartMaximum = new Date(lastvalue.x);\r\n    var stockChartTitleText = this.title;\r\n    var stockChartdataPoints = this.data;\r\n\r\n    this.linearRegression = new Array<Coords>();\r\n    this.trend = \"\";\r\n\r\n    stockChartdataPoints.reverse();\r\n    if (stockChartdataPoints.length > 2) {\r\n      let x = [];\r\n      for (let i = 0; i<stockChartdataPoints.length; i ++) {\r\n        x.push([i, stockChartdataPoints[i].y]);\r\n      }\r\n      let parameters = ss.linearRegression(x);\r\n      this.m = parameters.m;\r\n      this.q = parameters.b;\r\n      if (this.m > 0) {\r\n          this.trend += \" ↗\";\r\n        } else if (this.m < 0) {\r\n          this.trend += \" ↘\";\r\n      }\r\n      // console.log(x);\r\n      // console.log(stockChartdataPoints);\r\n      \r\n      for (let i = 0; i<stockChartdataPoints.length; i ++) {\r\n        if (i == 0 || i == stockChartdataPoints.length - 1) {\r\n          this.linearRegression.push({x: stockChartdataPoints[i].x,\r\n            y: this.m*i + this.q,\r\n            label: stockChartdataPoints[i].label,\r\n            name: stockChartdataPoints[i].name\r\n          })\r\n        }\r\n      }\r\n      //this.linearRegression.reverse();\r\n      // console.log(this.linearRegression);\r\n      // console.log(this.m);\r\n      // console.log(this.q);\r\n    }\r\n\r\n    this.stockChartOptions = {\r\n      theme: 'light2',\r\n      animationEnabled: true,\r\n      width: width,\r\n      height: 500,\r\n      creditText: \"\",\r\n      creditHref: \"\",\r\n      title: {\r\n        text: stockChartTitleText\r\n      },\r\n      charts: [{\r\n        axisX: {\r\n          labelFormatter: this.labelFormatterFunction,\r\n        },\r\n        data: [\r\n          {\r\n            toolTipContent: null,\r\n            type: 'line',\r\n            color: this.trendColor,\r\n            showInLegend: true,\r\n            legendMarkerType: \"none\",\r\n            markerType: \"none\",\r\n            legendText: \"Trend\" + this.trend,\r\n            dataPoints: this.linearRegression\r\n          },\r\n          {\r\n            type: \"spline\",\r\n            dataPoints: stockChartdataPoints,\r\n            color: this.mainColor,\r\n          }\r\n        ],\r\n        culture: \"it\"\r\n      }],\r\n      rangeSelector: {\r\n        enabled: false\r\n      },\r\n      navigator: {\r\n        slider: {\r\n          minimum: stockChartMinimum,\r\n          maximum: stockChartMaximum\r\n        }\r\n      },\r\n      options: {\r\n        responsive: true,\r\n        maintainAspectRatio: false\r\n      }\r\n    };\r\n\r\n    this.loaded = true;\r\n  }\r\n\r\n  labelFormatterFunction(e) {\r\n    let label = \"\";\r\n    let dirtyLabel;\r\n    let date = e.value;\r\n\r\n      let newYear: number = date.getFullYear();\r\n      let newMonth: number = date.getMonth() + 1;\r\n      let newMonthString: string;\r\n      if (newMonth < 10) {\r\n      newMonthString = \"0\" + newMonth.toString();\r\n      } else {\r\n      newMonthString = newMonth.toString();\r\n      }\r\n      let newDay: number = date.getDate();\r\n      let newDayString: string;\r\n      if (newDay < 10) {\r\n      newDayString = \"0\" + newDay.toString();\r\n      } else {\r\n      newDayString = newDay.toString();\r\n      }\r\n      let newHour: number = date.getHours();\r\n      let newHourString: string;\r\n      if (newHour < 10) {\r\n      newHourString = \"0\" + newHour.toString();\r\n      } else {\r\n      newHourString = newHour.toString();\r\n      }\r\n      let newMinute: number = date.getMinutes();\r\n      let newMinuteString: string;\r\n      if (newMinute < 10) {\r\n      newMinuteString = \"0\" + newMinute.toString();\r\n      } else {\r\n      newMinuteString = newMinute.toString();\r\n      }\r\n\r\n      dirtyLabel = newDayString + \"/\" + newMonthString + \"/\" + newYear.toString() + \" \" + newHourString  + \":\" + newMinuteString;\r\n\r\n      for (let i = 0; i < 5; i++) {\r\n        label += dirtyLabel[i];\r\n      }\r\n      label += \" \";\r\n      for (let i = 11; i < 16; i++) {\r\n        label += dirtyLabel[i];\r\n      }\r\n\r\n      //label = label.replace(\"00:00\",\"\");\r\n    \r\n    return label;\r\n  }  \r\n  \r\n\r\n}\r\n","<canvasjs-stockchart *ngIf=\"loaded\" [options]=\"stockChartOptions\"></canvasjs-stockchart>\n<div class=\"error\" *ngIf=\"!loaded\"><b>{{title}}:</b> Nessun dato trovato nell'intervallo specificato!</div>"]}
@@ -7151,10 +7151,10 @@ class AddFormRecordComponent {
7151
7151
  }
7152
7152
  }
7153
7153
  AddFormRecordComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: AddFormRecordComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: UtilityHelperService }, { token: i2$1.DatePipe }], target: i0.ɵɵFactoryTarget.Component });
7154
- AddFormRecordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: AddFormRecordComponent, selector: "add-form-record", inputs: { configurations: "configurations", endPointConfiguration: "endPointConfiguration", userID: "userID", orgaID: "orgaID", formID: "formID", form: "form", record: "record", formulaObject: "formulaObject", onlyView: "onlyView", isDuplicate: "isDuplicate", inConfig: "inConfig", showAllFields: "showAllFields", showTitle: "showTitle", actionButtons: "actionButtons", QueryEditorComponent: "QueryEditorComponent" }, outputs: { saveRecordEvent: "saveRecordEvent", afterSaveRecordEvent: "afterSaveRecordEvent", out: "out", fireTrigger: "fireTrigger" }, viewQueries: [{ propertyName: "fieldTemplate", predicate: ["fieldTemplate"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"loader\">\r\n\r\n <div class=\"row eqp-dynamic-module-title add-form-record-header\" *ngIf=\"showTitle || visibleActionButtons.length > 0\">\r\n <div *ngIf=\"showTitle\">\r\n <span>{{form.Name}}</span>\r\n </div>\r\n <div *ngIf=\"visibleActionButtons.length > 0\">\r\n <button class=\"btn btn-primary mr-2\" *ngFor=\"let actionButton of visibleActionButtons\" (click)=\"generateAction(actionButton)\">\r\n <mat-icon *ngIf=\"actionButton.Icon\">{{actionButton.Icon}}</mat-icon> {{actionButton.ButtonLabel}}\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <form [formGroup]=\"formForm\" class=\"add-form-record-form\">\r\n\r\n <!-- VISUALIZZAZIONE SEMPLICE -->\r\n <ng-container *ngIf=\"form.FormScalarType == FormScalarTypeEnum.Semplice\" [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: form.Fields }\" class=\"add-form-record-semplice\">\r\n </ng-container>\r\n\r\n <!-- VISUALIZZAZIONE A STEPPER -->\r\n <mat-horizontal-stepper linear *ngIf=\"form.FormScalarType == FormScalarTypeEnum['A step']\"\r\n class=\"add-form-record-stepper\" (selectionChange)=\"onStepChange($event)\">\r\n <mat-step *ngFor=\"let group of form.FormFieldsGroups; let i = index; let first = first; let last = last\">\r\n \r\n <ng-template matStepLabel>\r\n {{group.Name}}\r\n </ng-template>\r\n\r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n\r\n <div class=\"mt-2 d-flex justify-content-end add-form-record-buttons\">\r\n <button *ngIf=\"!first\" class=\"mr-2 previous\" mat-raised-button matStepperPrevious>\r\n Precedente\r\n </button>\r\n <button *ngIf=\"!last\" class=\"button-next\" color=\"primary\" mat-raised-button matStepperNext>\r\n Successivo\r\n </button>\r\n <button *ngIf=\"last && showSaveButton\" (click)=\"saveOrExitForm(false)\" class=\"button-next\" [disabled]=\"formForm.invalid || formForm.disabled\"\r\n color=\"primary\" mat-raised-button>\r\n Salva\r\n </button>\r\n </div>\r\n\r\n </mat-step>\r\n </mat-horizontal-stepper>\r\n\r\n <!-- VISUALIZZAZIONE A TAB -->\r\n <mat-tab-group *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In tab']\" class=\"add-form-record-tab\">\r\n <mat-tab *ngFor=\"let group of form.FormFieldsGroups\" [label]=\"group.Name\"> \r\n <div class=\"mt-3\"> \r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n </div>\r\n </mat-tab>\r\n </mat-tab-group>\r\n\r\n <!-- VISUALIZZAZIONE AD ACCORDION -->\r\n <mat-accordion multi *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In accordion']\"\r\n class=\"add-form-record-accordion\">\r\n <mat-expansion-panel *ngFor=\"let group of form.FormFieldsGroups\">\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{group.Name}}\r\n </mat-panel-title>\r\n </mat-expansion-panel-header>\r\n\r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n </mat-expansion-panel>\r\n </mat-accordion>\r\n </form>\r\n\r\n <div class=\"row mt-2 add-form-record-buttons\"\r\n *ngIf=\"(showBackButton || showSaveButton) && form.FormScalarType != FormScalarTypeEnum['A step']\">\r\n <div class=\"col-sm-12 text-right\">\r\n <button class=\"mr-2\" mat-raised-button type=\"button\" *ngIf=\"showBackButton\" (click)=\"saveOrExitForm(true)\">\r\n Annulla\r\n </button>\r\n <button class=\"mr-2\" mat-raised-button color=\"primary\" type=\"button\" *ngIf=\"showSaveButton\"\r\n (click)=\"saveOrExitForm(false)\" [disabled]=\"formForm.invalid || formForm.disabled || isSaving\">\r\n <span *ngIf=\"!isSaving\">Salva</span>\r\n <span *ngIf=\"isSaving\">Salvataggio in Corso...</span>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n</ng-container>\r\n\r\n\r\n\r\n<!-- TEMPLATE PER LA VISUALIZZAZIONE DEI CAMPI DELLA FORM -->\r\n<ng-template #fieldTemplates let-fields='fields'>\r\n <div class=\"row\" *ngIf=\"formloaded\">\r\n <div class=\"mt-2\" *ngFor=\"let field of fields\"\r\n [ngClass]=\"utilityService.getFieldSyleClass(field, showAllFields)\">\r\n <dynamic-module-field-fix #fieldTemplate [field]=\"field\" [QueryEditorComponent]=\"QueryEditorComponent\" [form]=\"form\" [record]=\"record\" [formulaObject]=\"formulaObject\" [configurations]=\"configurations\" [endPointConfiguration]=\"endPointConfiguration\" [userID]=\"userID\" [inConfig]=\"inConfig\"\r\n (recordChange)=\"onRecordChange()\" (fireTrigger)=\"onFireTrigger($event)\">\r\n </dynamic-module-field-fix>\r\n </div>\r\n </div>\r\n</ng-template>", styles: [".visibility_hidden{display:none}.visibility_transparent{visibility:hidden}.eqp-dynamic-module-title>*{display:flex;flex-direction:row;justify-content:flex-start;width:-moz-fit-content;width:fit-content;align-items:center}\n"], dependencies: [{ kind: "component", type: i2.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: i12.MatStep, selector: "mat-step", inputs: ["color"], exportAs: ["matStep"] }, { kind: "directive", type: i12.MatStepLabel, selector: "[matStepLabel]" }, { kind: "component", type: i12.MatStepper, selector: "mat-stepper, mat-vertical-stepper, mat-horizontal-stepper, [matStepper]", inputs: ["selectedIndex", "disableRipple", "color", "labelPosition", "headerPosition", "animationDuration"], outputs: ["animationDone"], exportAs: ["matStepper", "matVerticalStepper", "matHorizontalStepper"] }, { kind: "directive", type: i12.MatStepperNext, selector: "button[matStepperNext]", inputs: ["type"] }, { kind: "directive", type: i12.MatStepperPrevious, selector: "button[matStepperPrevious]", inputs: ["type"] }, { kind: "component", type: i5$2.MatTab, selector: "mat-tab", inputs: ["disabled"], exportAs: ["matTab"] }, { kind: "component", type: i5$2.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "disableRipple", "fitInkBarToContent", "mat-stretch-tabs"], exportAs: ["matTabGroup"] }, { kind: "directive", type: i8$2.MatAccordion, selector: "mat-accordion", inputs: ["multi", "hideToggle", "displayMode", "togglePosition"], exportAs: ["matAccordion"] }, { kind: "component", type: i8$2.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "component", type: i8$2.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { kind: "directive", type: i8$2.MatExpansionPanelTitle, selector: "mat-panel-title" }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2$1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: DynamicModuleFieldFixComponent, selector: "dynamic-module-field-fix", inputs: ["configurations", "endPointConfiguration", "field", "form", "record", "formulaObject", "inConfig", "userID", "QueryEditorComponent"], outputs: ["recordChange", "out", "fireTrigger"] }] });
7154
+ AddFormRecordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: AddFormRecordComponent, selector: "add-form-record", inputs: { configurations: "configurations", endPointConfiguration: "endPointConfiguration", userID: "userID", orgaID: "orgaID", formID: "formID", form: "form", record: "record", formulaObject: "formulaObject", onlyView: "onlyView", isDuplicate: "isDuplicate", inConfig: "inConfig", showAllFields: "showAllFields", showTitle: "showTitle", actionButtons: "actionButtons", QueryEditorComponent: "QueryEditorComponent" }, outputs: { saveRecordEvent: "saveRecordEvent", afterSaveRecordEvent: "afterSaveRecordEvent", out: "out", fireTrigger: "fireTrigger" }, viewQueries: [{ propertyName: "fieldTemplate", predicate: ["fieldTemplate"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"loader\">\r\n\r\n <div class=\"row eqp-dynamic-module-title add-form-record-header\" *ngIf=\"showTitle || visibleActionButtons.length > 0\">\r\n <div *ngIf=\"showTitle\">\r\n <span>{{form.Name}}</span>\r\n </div>\r\n <div *ngIf=\"visibleActionButtons.length > 0\">\r\n <button class=\"btn btn-primary mr-2\" *ngFor=\"let actionButton of visibleActionButtons\" (click)=\"generateAction(actionButton)\">\r\n <mat-icon *ngIf=\"actionButton.Icon\">{{actionButton.Icon}}</mat-icon> {{actionButton.ButtonLabel}}\r\n </button>\r\n </div> \r\n </div>\r\n\r\n <form [formGroup]=\"formForm\" class=\"add-form-record-form\">\r\n\r\n <!-- VISUALIZZAZIONE SEMPLICE -->\r\n <ng-container *ngIf=\"form.FormScalarType == FormScalarTypeEnum.Semplice\" [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: form.Fields }\" class=\"add-form-record-semplice\">\r\n </ng-container>\r\n\r\n <!-- VISUALIZZAZIONE A STEPPER -->\r\n <mat-horizontal-stepper linear *ngIf=\"form.FormScalarType == FormScalarTypeEnum['A step']\"\r\n class=\"add-form-record-stepper\" (selectionChange)=\"onStepChange($event)\">\r\n <mat-step *ngFor=\"let group of form.FormFieldsGroups; let i = index; let first = first; let last = last\">\r\n \r\n <ng-template matStepLabel>\r\n {{group.Name}}\r\n </ng-template>\r\n\r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n\r\n <div class=\"mt-2 d-flex justify-content-end add-form-record-buttons\">\r\n <button *ngIf=\"!first\" class=\"mr-2 previous\" mat-raised-button matStepperPrevious>\r\n Precedente\r\n </button>\r\n <button *ngIf=\"!last\" class=\"button-next\" color=\"primary\" mat-raised-button matStepperNext>\r\n Successivo\r\n </button>\r\n <button *ngIf=\"last && showSaveButton\" (click)=\"saveOrExitForm(false)\" class=\"button-next\" [disabled]=\"formForm.invalid || formForm.disabled\"\r\n color=\"primary\" mat-raised-button>\r\n Salva\r\n </button>\r\n </div>\r\n\r\n </mat-step>\r\n </mat-horizontal-stepper>\r\n\r\n <!-- VISUALIZZAZIONE A TAB -->\r\n <mat-tab-group *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In tab']\" class=\"add-form-record-tab\">\r\n <mat-tab *ngFor=\"let group of form.FormFieldsGroups\" [label]=\"group.Name\"> \r\n <div class=\"mt-3\"> \r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n </div>\r\n </mat-tab>\r\n </mat-tab-group>\r\n\r\n <!-- VISUALIZZAZIONE AD ACCORDION -->\r\n <mat-accordion multi *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In accordion']\"\r\n class=\"add-form-record-accordion\">\r\n <mat-expansion-panel *ngFor=\"let group of form.FormFieldsGroups\">\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{group.Name}}\r\n </mat-panel-title>\r\n </mat-expansion-panel-header>\r\n\r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n </mat-expansion-panel>\r\n </mat-accordion>\r\n </form>\r\n\r\n <div class=\"row mt-2 add-form-record-buttons\"\r\n *ngIf=\"(showBackButton || showSaveButton) && form.FormScalarType != FormScalarTypeEnum['A step']\">\r\n <div class=\"col-sm-12 text-right\">\r\n <button class=\"mr-2\" mat-raised-button type=\"button\" *ngIf=\"showBackButton\" (click)=\"saveOrExitForm(true)\">\r\n Annulla\r\n </button>\r\n <button class=\"mr-2\" mat-raised-button color=\"primary\" type=\"button\" *ngIf=\"showSaveButton\"\r\n (click)=\"saveOrExitForm(false)\" [disabled]=\"formForm.invalid || formForm.disabled || isSaving\">\r\n <span *ngIf=\"!isSaving\">Salva</span>\r\n <span *ngIf=\"isSaving\">Salvataggio in Corso...</span>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n</ng-container>\r\n\r\n\r\n\r\n<!-- TEMPLATE PER LA VISUALIZZAZIONE DEI CAMPI DELLA FORM -->\r\n<ng-template #fieldTemplates let-fields='fields'>\r\n <div class=\"row\" *ngIf=\"formloaded\">\r\n <div class=\"mt-2\" *ngFor=\"let field of fields\"\r\n [ngClass]=\"utilityService.getFieldSyleClass(field, showAllFields)\">\r\n <dynamic-module-field-fix #fieldTemplate [field]=\"field\" [QueryEditorComponent]=\"QueryEditorComponent\" [form]=\"form\" [record]=\"record\" [formulaObject]=\"formulaObject\" [configurations]=\"configurations\" [endPointConfiguration]=\"endPointConfiguration\" [userID]=\"userID\" [inConfig]=\"inConfig\"\r\n (recordChange)=\"onRecordChange()\" (fireTrigger)=\"onFireTrigger($event)\">\r\n </dynamic-module-field-fix>\r\n </div>\r\n </div>\r\n</ng-template>", styles: [".visibility_hidden{display:none}.visibility_transparent{visibility:hidden}.eqp-dynamic-module-title>*{display:flex;flex-direction:row;justify-content:flex-start;width:-moz-fit-content;width:fit-content;align-items:center}\n"], dependencies: [{ kind: "component", type: i2.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: i12.MatStep, selector: "mat-step", inputs: ["color"], exportAs: ["matStep"] }, { kind: "directive", type: i12.MatStepLabel, selector: "[matStepLabel]" }, { kind: "component", type: i12.MatStepper, selector: "mat-stepper, mat-vertical-stepper, mat-horizontal-stepper, [matStepper]", inputs: ["selectedIndex", "disableRipple", "color", "labelPosition", "headerPosition", "animationDuration"], outputs: ["animationDone"], exportAs: ["matStepper", "matVerticalStepper", "matHorizontalStepper"] }, { kind: "directive", type: i12.MatStepperNext, selector: "button[matStepperNext]", inputs: ["type"] }, { kind: "directive", type: i12.MatStepperPrevious, selector: "button[matStepperPrevious]", inputs: ["type"] }, { kind: "component", type: i5$2.MatTab, selector: "mat-tab", inputs: ["disabled"], exportAs: ["matTab"] }, { kind: "component", type: i5$2.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "disableRipple", "fitInkBarToContent", "mat-stretch-tabs"], exportAs: ["matTabGroup"] }, { kind: "directive", type: i8$2.MatAccordion, selector: "mat-accordion", inputs: ["multi", "hideToggle", "displayMode", "togglePosition"], exportAs: ["matAccordion"] }, { kind: "component", type: i8$2.MatExpansionPanel, selector: "mat-expansion-panel", inputs: ["disabled", "expanded", "hideToggle", "togglePosition"], outputs: ["opened", "closed", "expandedChange", "afterExpand", "afterCollapse"], exportAs: ["matExpansionPanel"] }, { kind: "component", type: i8$2.MatExpansionPanelHeader, selector: "mat-expansion-panel-header", inputs: ["tabIndex", "expandedHeight", "collapsedHeight"] }, { kind: "directive", type: i8$2.MatExpansionPanelTitle, selector: "mat-panel-title" }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2$1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: DynamicModuleFieldFixComponent, selector: "dynamic-module-field-fix", inputs: ["configurations", "endPointConfiguration", "field", "form", "record", "formulaObject", "inConfig", "userID", "QueryEditorComponent"], outputs: ["recordChange", "out", "fireTrigger"] }] });
7155
7155
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: AddFormRecordComponent, decorators: [{
7156
7156
  type: Component,
7157
- args: [{ selector: "add-form-record", template: "<ng-container *ngIf=\"loader\">\r\n\r\n <div class=\"row eqp-dynamic-module-title add-form-record-header\" *ngIf=\"showTitle || visibleActionButtons.length > 0\">\r\n <div *ngIf=\"showTitle\">\r\n <span>{{form.Name}}</span>\r\n </div>\r\n <div *ngIf=\"visibleActionButtons.length > 0\">\r\n <button class=\"btn btn-primary mr-2\" *ngFor=\"let actionButton of visibleActionButtons\" (click)=\"generateAction(actionButton)\">\r\n <mat-icon *ngIf=\"actionButton.Icon\">{{actionButton.Icon}}</mat-icon> {{actionButton.ButtonLabel}}\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <form [formGroup]=\"formForm\" class=\"add-form-record-form\">\r\n\r\n <!-- VISUALIZZAZIONE SEMPLICE -->\r\n <ng-container *ngIf=\"form.FormScalarType == FormScalarTypeEnum.Semplice\" [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: form.Fields }\" class=\"add-form-record-semplice\">\r\n </ng-container>\r\n\r\n <!-- VISUALIZZAZIONE A STEPPER -->\r\n <mat-horizontal-stepper linear *ngIf=\"form.FormScalarType == FormScalarTypeEnum['A step']\"\r\n class=\"add-form-record-stepper\" (selectionChange)=\"onStepChange($event)\">\r\n <mat-step *ngFor=\"let group of form.FormFieldsGroups; let i = index; let first = first; let last = last\">\r\n \r\n <ng-template matStepLabel>\r\n {{group.Name}}\r\n </ng-template>\r\n\r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n\r\n <div class=\"mt-2 d-flex justify-content-end add-form-record-buttons\">\r\n <button *ngIf=\"!first\" class=\"mr-2 previous\" mat-raised-button matStepperPrevious>\r\n Precedente\r\n </button>\r\n <button *ngIf=\"!last\" class=\"button-next\" color=\"primary\" mat-raised-button matStepperNext>\r\n Successivo\r\n </button>\r\n <button *ngIf=\"last && showSaveButton\" (click)=\"saveOrExitForm(false)\" class=\"button-next\" [disabled]=\"formForm.invalid || formForm.disabled\"\r\n color=\"primary\" mat-raised-button>\r\n Salva\r\n </button>\r\n </div>\r\n\r\n </mat-step>\r\n </mat-horizontal-stepper>\r\n\r\n <!-- VISUALIZZAZIONE A TAB -->\r\n <mat-tab-group *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In tab']\" class=\"add-form-record-tab\">\r\n <mat-tab *ngFor=\"let group of form.FormFieldsGroups\" [label]=\"group.Name\"> \r\n <div class=\"mt-3\"> \r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n </div>\r\n </mat-tab>\r\n </mat-tab-group>\r\n\r\n <!-- VISUALIZZAZIONE AD ACCORDION -->\r\n <mat-accordion multi *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In accordion']\"\r\n class=\"add-form-record-accordion\">\r\n <mat-expansion-panel *ngFor=\"let group of form.FormFieldsGroups\">\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{group.Name}}\r\n </mat-panel-title>\r\n </mat-expansion-panel-header>\r\n\r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n </mat-expansion-panel>\r\n </mat-accordion>\r\n </form>\r\n\r\n <div class=\"row mt-2 add-form-record-buttons\"\r\n *ngIf=\"(showBackButton || showSaveButton) && form.FormScalarType != FormScalarTypeEnum['A step']\">\r\n <div class=\"col-sm-12 text-right\">\r\n <button class=\"mr-2\" mat-raised-button type=\"button\" *ngIf=\"showBackButton\" (click)=\"saveOrExitForm(true)\">\r\n Annulla\r\n </button>\r\n <button class=\"mr-2\" mat-raised-button color=\"primary\" type=\"button\" *ngIf=\"showSaveButton\"\r\n (click)=\"saveOrExitForm(false)\" [disabled]=\"formForm.invalid || formForm.disabled || isSaving\">\r\n <span *ngIf=\"!isSaving\">Salva</span>\r\n <span *ngIf=\"isSaving\">Salvataggio in Corso...</span>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n</ng-container>\r\n\r\n\r\n\r\n<!-- TEMPLATE PER LA VISUALIZZAZIONE DEI CAMPI DELLA FORM -->\r\n<ng-template #fieldTemplates let-fields='fields'>\r\n <div class=\"row\" *ngIf=\"formloaded\">\r\n <div class=\"mt-2\" *ngFor=\"let field of fields\"\r\n [ngClass]=\"utilityService.getFieldSyleClass(field, showAllFields)\">\r\n <dynamic-module-field-fix #fieldTemplate [field]=\"field\" [QueryEditorComponent]=\"QueryEditorComponent\" [form]=\"form\" [record]=\"record\" [formulaObject]=\"formulaObject\" [configurations]=\"configurations\" [endPointConfiguration]=\"endPointConfiguration\" [userID]=\"userID\" [inConfig]=\"inConfig\"\r\n (recordChange)=\"onRecordChange()\" (fireTrigger)=\"onFireTrigger($event)\">\r\n </dynamic-module-field-fix>\r\n </div>\r\n </div>\r\n</ng-template>", styles: [".visibility_hidden{display:none}.visibility_transparent{visibility:hidden}.eqp-dynamic-module-title>*{display:flex;flex-direction:row;justify-content:flex-start;width:-moz-fit-content;width:fit-content;align-items:center}\n"] }]
7157
+ args: [{ selector: "add-form-record", template: "<ng-container *ngIf=\"loader\">\r\n\r\n <div class=\"row eqp-dynamic-module-title add-form-record-header\" *ngIf=\"showTitle || visibleActionButtons.length > 0\">\r\n <div *ngIf=\"showTitle\">\r\n <span>{{form.Name}}</span>\r\n </div>\r\n <div *ngIf=\"visibleActionButtons.length > 0\">\r\n <button class=\"btn btn-primary mr-2\" *ngFor=\"let actionButton of visibleActionButtons\" (click)=\"generateAction(actionButton)\">\r\n <mat-icon *ngIf=\"actionButton.Icon\">{{actionButton.Icon}}</mat-icon> {{actionButton.ButtonLabel}}\r\n </button>\r\n </div> \r\n </div>\r\n\r\n <form [formGroup]=\"formForm\" class=\"add-form-record-form\">\r\n\r\n <!-- VISUALIZZAZIONE SEMPLICE -->\r\n <ng-container *ngIf=\"form.FormScalarType == FormScalarTypeEnum.Semplice\" [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: form.Fields }\" class=\"add-form-record-semplice\">\r\n </ng-container>\r\n\r\n <!-- VISUALIZZAZIONE A STEPPER -->\r\n <mat-horizontal-stepper linear *ngIf=\"form.FormScalarType == FormScalarTypeEnum['A step']\"\r\n class=\"add-form-record-stepper\" (selectionChange)=\"onStepChange($event)\">\r\n <mat-step *ngFor=\"let group of form.FormFieldsGroups; let i = index; let first = first; let last = last\">\r\n \r\n <ng-template matStepLabel>\r\n {{group.Name}}\r\n </ng-template>\r\n\r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n\r\n <div class=\"mt-2 d-flex justify-content-end add-form-record-buttons\">\r\n <button *ngIf=\"!first\" class=\"mr-2 previous\" mat-raised-button matStepperPrevious>\r\n Precedente\r\n </button>\r\n <button *ngIf=\"!last\" class=\"button-next\" color=\"primary\" mat-raised-button matStepperNext>\r\n Successivo\r\n </button>\r\n <button *ngIf=\"last && showSaveButton\" (click)=\"saveOrExitForm(false)\" class=\"button-next\" [disabled]=\"formForm.invalid || formForm.disabled\"\r\n color=\"primary\" mat-raised-button>\r\n Salva\r\n </button>\r\n </div>\r\n\r\n </mat-step>\r\n </mat-horizontal-stepper>\r\n\r\n <!-- VISUALIZZAZIONE A TAB -->\r\n <mat-tab-group *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In tab']\" class=\"add-form-record-tab\">\r\n <mat-tab *ngFor=\"let group of form.FormFieldsGroups\" [label]=\"group.Name\"> \r\n <div class=\"mt-3\"> \r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n </div>\r\n </mat-tab>\r\n </mat-tab-group>\r\n\r\n <!-- VISUALIZZAZIONE AD ACCORDION -->\r\n <mat-accordion multi *ngIf=\"form.FormScalarType == FormScalarTypeEnum['In accordion']\"\r\n class=\"add-form-record-accordion\">\r\n <mat-expansion-panel *ngFor=\"let group of form.FormFieldsGroups\">\r\n <mat-expansion-panel-header>\r\n <mat-panel-title>\r\n {{group.Name}}\r\n </mat-panel-title>\r\n </mat-expansion-panel-header>\r\n\r\n <ng-container [ngTemplateOutlet]=\"fieldTemplates\"\r\n [ngTemplateOutletContext]=\"{ fields: fieldGroups[group.Name] }\">\r\n </ng-container>\r\n </mat-expansion-panel>\r\n </mat-accordion>\r\n </form>\r\n\r\n <div class=\"row mt-2 add-form-record-buttons\"\r\n *ngIf=\"(showBackButton || showSaveButton) && form.FormScalarType != FormScalarTypeEnum['A step']\">\r\n <div class=\"col-sm-12 text-right\">\r\n <button class=\"mr-2\" mat-raised-button type=\"button\" *ngIf=\"showBackButton\" (click)=\"saveOrExitForm(true)\">\r\n Annulla\r\n </button>\r\n <button class=\"mr-2\" mat-raised-button color=\"primary\" type=\"button\" *ngIf=\"showSaveButton\"\r\n (click)=\"saveOrExitForm(false)\" [disabled]=\"formForm.invalid || formForm.disabled || isSaving\">\r\n <span *ngIf=\"!isSaving\">Salva</span>\r\n <span *ngIf=\"isSaving\">Salvataggio in Corso...</span>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n</ng-container>\r\n\r\n\r\n\r\n<!-- TEMPLATE PER LA VISUALIZZAZIONE DEI CAMPI DELLA FORM -->\r\n<ng-template #fieldTemplates let-fields='fields'>\r\n <div class=\"row\" *ngIf=\"formloaded\">\r\n <div class=\"mt-2\" *ngFor=\"let field of fields\"\r\n [ngClass]=\"utilityService.getFieldSyleClass(field, showAllFields)\">\r\n <dynamic-module-field-fix #fieldTemplate [field]=\"field\" [QueryEditorComponent]=\"QueryEditorComponent\" [form]=\"form\" [record]=\"record\" [formulaObject]=\"formulaObject\" [configurations]=\"configurations\" [endPointConfiguration]=\"endPointConfiguration\" [userID]=\"userID\" [inConfig]=\"inConfig\"\r\n (recordChange)=\"onRecordChange()\" (fireTrigger)=\"onFireTrigger($event)\">\r\n </dynamic-module-field-fix>\r\n </div>\r\n </div>\r\n</ng-template>", styles: [".visibility_hidden{display:none}.visibility_transparent{visibility:hidden}.eqp-dynamic-module-title>*{display:flex;flex-direction:row;justify-content:flex-start;width:-moz-fit-content;width:fit-content;align-items:center}\n"] }]
7158
7158
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: UtilityHelperService }, { type: i2$1.DatePipe }]; }, propDecorators: { configurations: [{
7159
7159
  type: Input
7160
7160
  }], endPointConfiguration: [{
@@ -7566,10 +7566,10 @@ class GraphComponent {
7566
7566
  }
7567
7567
  }
7568
7568
  GraphComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GraphComponent, deps: [{ token: i2$1.DatePipe }], target: i0.ɵɵFactoryTarget.Component });
7569
- GraphComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: GraphComponent, selector: "graph", inputs: { data: "data", title: "title" }, host: { listeners: { "window:resize": "onResize($event)" } }, 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: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2$4.CanvasJSStockChart, selector: "canvasjs-stockchart", inputs: ["options", "styles"], outputs: ["stockChartInstance"] }] });
7569
+ GraphComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: GraphComponent, selector: "graph", inputs: { data: "data", title: "title" }, host: { listeners: { "window:resize": "onResize($event)" } }, ngImport: i0, template: "<canvasjs-stockchart *ngIf=\"loaded\" [options]=\"stockChartOptions\"></canvasjs-stockchart>\n<div class=\"error\" *ngIf=\"!loaded\"><b>{{title}}:</b> Nessun dato trovato nell'intervallo specificato!</div>", styles: [""], dependencies: [{ kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2$4.CanvasJSStockChart, selector: "canvasjs-stockchart", inputs: ["options", "styles"], outputs: ["stockChartInstance"] }] });
7570
7570
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GraphComponent, decorators: [{
7571
7571
  type: Component,
7572
- 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>" }]
7572
+ args: [{ selector: 'graph', template: "<canvasjs-stockchart *ngIf=\"loaded\" [options]=\"stockChartOptions\"></canvasjs-stockchart>\n<div class=\"error\" *ngIf=\"!loaded\"><b>{{title}}:</b> Nessun dato trovato nell'intervallo specificato!</div>" }]
7573
7573
  }], ctorParameters: function () { return [{ type: i2$1.DatePipe }]; }, propDecorators: { onResize: [{
7574
7574
  type: HostListener,
7575
7575
  args: ['window:resize', ['$event']]
@@ -8859,7 +8859,7 @@ class NumericFilterTemplateComponent {
8859
8859
  if (changes.hasOwnProperty('Statistic') && !changes['Statistic'].firstChange) {
8860
8860
  this.isX = changes['Statistic'].currentValue.isX;
8861
8861
  this.isY = changes['Statistic'].currentValue.isY;
8862
- this.aggregations = changes['aggregations'].currentValue.aggregations;
8862
+ this.aggregations = changes['Statistic'].currentValue.aggregations;
8863
8863
  }
8864
8864
  }
8865
8865
  //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html
@@ -11879,10 +11879,10 @@ class DynamicModuleFieldExtraFixComponent {
11879
11879
  }
11880
11880
  }
11881
11881
  DynamicModuleFieldExtraFixComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DynamicModuleFieldExtraFixComponent, deps: [{ token: i4.UntypedFormBuilder }], target: i0.ɵɵFactoryTarget.Component });
11882
- DynamicModuleFieldExtraFixComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DynamicModuleFieldExtraFixComponent, selector: "dynamic-module-field-extra-fix", inputs: { fieldExtraConfig: "fieldExtraConfig", form: "form", field: "field", endPointConfiguration: "endPointConfiguration" }, outputs: { configValueChange: "configValueChange" }, ngImport: i0, template: "\r\n\r\n<div [formGroup]=\"formExtraGroup\">\r\n\r\n <mat-form-field appearance=\"outline\" *ngIf=\"fieldExtraConfig.FieldConfigType == FieldTypeEnum['Campo di testo'] && loaded\">\r\n <mat-label class=\"pt-1\">\r\n {{ fieldExtraConfig.FieldConfigLabel }}\r\n </mat-label>\r\n <input\r\n matInput\r\n [formControlName]=\"'element'\"\r\n [(ngModel)]=\"FieldExtraValues.FieldConfigValue\"\r\n />\r\n\r\n <mat-icon\r\n matSuffix\r\n SpeechToText\r\n [(bindedText)]=\"FieldExtraValues.FieldConfigValue\"\r\n style=\"cursor: pointer\">keyboard_voice</mat-icon>\r\n </mat-form-field>\r\n\r\n <mat-slide-toggle color=\"primary\" *ngIf=\"fieldExtraConfig.FieldConfigType == FieldTypeEnum['Booleano'] && loaded\"\r\n [formControlName]=\"'element'\"\r\n [(ngModel)]=\"FieldExtraValues.FieldConfigValue\">\r\n {{ fieldExtraConfig.FieldConfigLabel }}\r\n </mat-slide-toggle>\r\n\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i1$1.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i2$2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2$2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2$2.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i4$2.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["disabled", "disableRipple", "color", "tabIndex"], exportAs: ["matSlideToggle"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: SpeechToTextDirective, selector: "[SpeechToText]", inputs: ["bindedText"], outputs: ["bindedTextChange"] }] });
11882
+ DynamicModuleFieldExtraFixComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DynamicModuleFieldExtraFixComponent, selector: "dynamic-module-field-extra-fix", inputs: { fieldExtraConfig: "fieldExtraConfig", form: "form", field: "field", endPointConfiguration: "endPointConfiguration" }, outputs: { configValueChange: "configValueChange" }, ngImport: i0, template: "\n\n<div [formGroup]=\"formExtraGroup\">\n\n <mat-form-field appearance=\"outline\" *ngIf=\"fieldExtraConfig.FieldConfigType == FieldTypeEnum['Campo di testo'] && loaded\">\n <mat-label class=\"pt-1\">\n {{ fieldExtraConfig.FieldConfigLabel }}\n </mat-label>\n <input\n matInput\n [formControlName]=\"'element'\"\n [(ngModel)]=\"FieldExtraValues.FieldConfigValue\"\n />\n\n <mat-icon\n matSuffix\n SpeechToText\n [(bindedText)]=\"FieldExtraValues.FieldConfigValue\"\n style=\"cursor: pointer\">keyboard_voice</mat-icon>\n </mat-form-field>\n\n <mat-slide-toggle color=\"primary\" *ngIf=\"fieldExtraConfig.FieldConfigType == FieldTypeEnum['Booleano'] && loaded\"\n [formControlName]=\"'element'\"\n [(ngModel)]=\"FieldExtraValues.FieldConfigValue\">\n {{ fieldExtraConfig.FieldConfigLabel }}\n </mat-slide-toggle>\n\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i1$1.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i2$2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2$2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2$2.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i4$2.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["disabled", "disableRipple", "color", "tabIndex"], exportAs: ["matSlideToggle"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: SpeechToTextDirective, selector: "[SpeechToText]", inputs: ["bindedText"], outputs: ["bindedTextChange"] }] });
11883
11883
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DynamicModuleFieldExtraFixComponent, decorators: [{
11884
11884
  type: Component,
11885
- args: [{ selector: 'dynamic-module-field-extra-fix', template: "\r\n\r\n<div [formGroup]=\"formExtraGroup\">\r\n\r\n <mat-form-field appearance=\"outline\" *ngIf=\"fieldExtraConfig.FieldConfigType == FieldTypeEnum['Campo di testo'] && loaded\">\r\n <mat-label class=\"pt-1\">\r\n {{ fieldExtraConfig.FieldConfigLabel }}\r\n </mat-label>\r\n <input\r\n matInput\r\n [formControlName]=\"'element'\"\r\n [(ngModel)]=\"FieldExtraValues.FieldConfigValue\"\r\n />\r\n\r\n <mat-icon\r\n matSuffix\r\n SpeechToText\r\n [(bindedText)]=\"FieldExtraValues.FieldConfigValue\"\r\n style=\"cursor: pointer\">keyboard_voice</mat-icon>\r\n </mat-form-field>\r\n\r\n <mat-slide-toggle color=\"primary\" *ngIf=\"fieldExtraConfig.FieldConfigType == FieldTypeEnum['Booleano'] && loaded\"\r\n [formControlName]=\"'element'\"\r\n [(ngModel)]=\"FieldExtraValues.FieldConfigValue\">\r\n {{ fieldExtraConfig.FieldConfigLabel }}\r\n </mat-slide-toggle>\r\n\r\n</div>" }]
11885
+ args: [{ selector: 'dynamic-module-field-extra-fix', template: "\n\n<div [formGroup]=\"formExtraGroup\">\n\n <mat-form-field appearance=\"outline\" *ngIf=\"fieldExtraConfig.FieldConfigType == FieldTypeEnum['Campo di testo'] && loaded\">\n <mat-label class=\"pt-1\">\n {{ fieldExtraConfig.FieldConfigLabel }}\n </mat-label>\n <input\n matInput\n [formControlName]=\"'element'\"\n [(ngModel)]=\"FieldExtraValues.FieldConfigValue\"\n />\n\n <mat-icon\n matSuffix\n SpeechToText\n [(bindedText)]=\"FieldExtraValues.FieldConfigValue\"\n style=\"cursor: pointer\">keyboard_voice</mat-icon>\n </mat-form-field>\n\n <mat-slide-toggle color=\"primary\" *ngIf=\"fieldExtraConfig.FieldConfigType == FieldTypeEnum['Booleano'] && loaded\"\n [formControlName]=\"'element'\"\n [(ngModel)]=\"FieldExtraValues.FieldConfigValue\">\n {{ fieldExtraConfig.FieldConfigLabel }}\n </mat-slide-toggle>\n\n</div>" }]
11886
11886
  }], ctorParameters: function () { return [{ type: i4.UntypedFormBuilder }]; }, propDecorators: { fieldExtraConfig: [{
11887
11887
  type: Input
11888
11888
  }], form: [{