@eqproject/eqp-dynamic-module 2.6.54 → 2.6.56

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.
@@ -1,138 +1,66 @@
1
1
  import { Component, EventEmitter, Input, Output } from '@angular/core';
2
- import { LogicOperatorListValue } from '../../../../../models/logicOperator.model';
3
- import { Statistic } from '../../../../../models/statistic.model';
2
+ import { BooleanLogicOperatorType, Condition } from '../../../../../models/trigger.model';
4
3
  import { UtilityHelperService } from '../../../../../services/utilityHelper.services';
4
+ import { ListPresentationEnum } from '../../../../../models/fields/listValueField.model';
5
+ import { LogicOperatorListValue } from '../../../../../models/logicOperator.model';
5
6
  import { GlobalService } from '../../../../../services/global.service';
6
- import { BooleanLogicOperatorType } from '../../../../../models/trigger.model';
7
7
  import * as i0 from "@angular/core";
8
- import * as i1 from "@angular/forms";
9
- import * as i2 from "@angular/common";
10
- import * as i3 from "@eqproject/eqp-select";
8
+ import * as i1 from "@angular/common";
9
+ import * as i2 from "@eqproject/eqp-select";
11
10
  export class ListValueTriggerTemplateComponent {
12
11
  constructor() {
13
- this.filterChange = new EventEmitter();
14
- this.validatorsArray = [];
12
+ this.recordChange = new EventEmitter();
13
+ this.triggerChange = new EventEmitter();
15
14
  this.logicOperatorListValue = LogicOperatorListValue;
16
- this.activeCondition = false;
15
+ this.selectedLogicOperatorListValue = LogicOperatorListValue['CONTIENE ALMENO UNO'];
17
16
  this.booleanLogicOperatorType = BooleanLogicOperatorType;
18
17
  this.selectedBooleanLogicOperator = BooleanLogicOperatorType.AND;
18
+ this.ListPresentationEnum = ListPresentationEnum;
19
19
  this.arrayData = [];
20
20
  }
21
21
  ngOnInit() {
22
- this.configureControllers();
22
+ this.field = this.condition.Field;
23
23
  this.initStyles();
24
24
  this.setArrayData();
25
25
  }
26
- //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html
27
26
  initStyles() {
27
+ //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html
28
28
  if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)
29
29
  this.FieldstyleObj = UtilityHelperService.initStyles(this.field.FieldstyleCSS);
30
+ if (this.field.LabelstyleCSS != null || this.field.LabelstyleCSS != undefined)
31
+ this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);
30
32
  }
31
33
  /**
32
34
  * Metodo per emettere l'evento che il valore del record è cambiato.
33
35
  */
34
36
  onTriggerChange() {
35
- if (this.selectedLogicOperator != null) {
36
- this.activeCondition = true;
37
- this.filterChange.emit(this.generateCondition("active"));
38
- }
39
- if (this.activeCondition && this.selectedLogicOperator == null) {
40
- this.activeCondition = false;
41
- this.filterChange.emit(this.generateCondition("deactivated"));
42
- }
43
- }
44
- /**
45
- * Metodo che genera l'oggetto da inviare all'esterno
46
- */
47
- generateCondition(mode) {
48
- let output = new Statistic();
49
- if (mode == "active") {
50
- output = {
51
- key: this.field.Name,
52
- value: this.record[this.field.Name],
53
- logicoperator: this.selectedLogicOperator,
54
- fieldtype: this.field.FieldType
55
- };
56
- }
57
- else {
58
- output = {
59
- key: this.field.Name,
60
- value: null,
61
- logicoperator: null,
62
- fieldtype: null
63
- };
64
- }
65
- return output;
66
- }
67
- /**
68
- * Metodo di aggiunta dei validator dell'input
69
- */
70
- configureControllers() {
71
- this.validatorsArray = [];
72
- this.field.FormFormGroup.get([this.field.Name]).setValidators(this.validatorsArray);
37
+ let output = new Condition();
38
+ output = {
39
+ key: this.field.Name,
40
+ value: this.condition.record[this.field.Name],
41
+ logicoperator: this.selectedLogicOperatorListValue,
42
+ fieldType: this.field.FieldType,
43
+ booleanlogicoperator: this.selectedBooleanLogicOperator
44
+ };
45
+ this.triggerChange.emit(output);
73
46
  }
74
- /**
75
- * Metodo per creare un array di oggetti del tipo { Key: string, Value: any } da usare come sorgente dati per la eqp-select.
76
- */
77
47
  setArrayData() {
78
- this.prepareValuePairs();
79
- if (this.field.ValuePairs != null) {
80
- if (UtilityHelperService.isNumeric(this.field.ValuePairs[Object.keys(this.field.ValuePairs)[0]])) {
81
- Object.keys(this.field.ValuePairs).forEach(k => this.createNumberArrayDataElement(k, Number(this.field.ValuePairs[k])));
82
- }
83
- else {
84
- Object.keys(this.field.ValuePairs).forEach(k => this.createArrayDataElement(k, this.field.ValuePairs[k]));
85
- }
86
- }
87
- }
88
- prepareValuePairs() {
89
- if (this.field.Formula) {
90
- this.field.ValuePairs = {};
91
- const temp = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);
92
- // temp dovrebbe essere una stringa del tipo "chiave1! valore 1 ; chiave2 | valore 2 "
93
- // dobbiamo ottenere un dizionario di quei valori
94
- this.field.ValuePairs = GlobalService.stringToValuePairs(temp);
95
- //this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);
96
- }
97
- else if (this.field.ValuePairs != null && this.field.ValuePairs.lenght > 0) {
98
- // va bene così
99
- }
100
- else if (this.field.ValueString != null && this.field.ValueString != "") {
101
- // va presa la strigna e rimappata nel diario
102
- this.field.ValuePairs = GlobalService.stringToValuePairs(this.field.ValueString);
103
- }
104
- }
105
- createArrayDataElement(key, value, imgUrl = null) {
106
- let isOptionSelected;
107
- if (this.field.IsMultiChoiche && this.record[this.field.Name] && this.record[this.field.Name].length > 0) {
108
- isOptionSelected = !!this.record[this.field.Name].find(v => v == value);
109
- }
110
- else {
111
- isOptionSelected = this.record[this.field.Name] === value;
112
- }
113
- this.arrayData.push({ Key: key, Value: value, Selected: isOptionSelected, ImgUrl: imgUrl });
114
- }
115
- createNumberArrayDataElement(key, value, imgUrl = null) {
116
- let isOptionSelected;
117
- if (this.field.IsMultiChoiche && this.record[this.field.Name] && this.record[this.field.Name].length > 0) {
118
- isOptionSelected = !!this.record[this.field.Name].find(v => v == value);
119
- }
120
- else {
121
- isOptionSelected = this.record[this.field.Name] === value;
122
- }
123
- this.arrayData.push({ Key: key, Value: value, Selected: isOptionSelected, ImgUrl: imgUrl });
48
+ this.field.ValuePairs = GlobalService.stringToValuePairs(this.field.ValueString);
49
+ Object.keys(this.field.ValuePairs).forEach((k) => {
50
+ this.arrayData.push({ Key: k, Value: this.field.ValuePairs[k], Selected: false });
51
+ });
124
52
  }
125
53
  }
126
54
  ListValueTriggerTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ListValueTriggerTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
127
- ListValueTriggerTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ListValueTriggerTemplateComponent, selector: "list-value-trigger-template", inputs: { field: "field", record: "record" }, outputs: { filterChange: "filterChange" }, ngImport: i0, template: "<div class=\"row\">\r\n <div class=\"col-md-6 valueCol\">\r\n <eqp-select [ngStyle]=\"FieldstyleObj\" [arrayData]=\"arrayData\"\r\n [arrayKeyProperty]=\"'Value'\" [showCancelButton]=\"true\" [arrayValueProperty]=\"'Key'\"\r\n [placeholder]=\"field.Description\"\r\n [includeFullObject]=\"false\" [isRequired]=\"false\" [isDisabled]=\"false\"\r\n [(ngModelInput)]=\"record[field.Name]\" [isMultiSelect]=\"false\"\r\n (ngModelInputChange)=\"onTriggerChange()\">\r\n </eqp-select>\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorListValue\" [(ngModel)]=\"selectedLogicOperator\" (ngModelChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"booleanLogicOperatorType\" [(ngModel)]=\"selectedBooleanLogicOperator\" (ngModelChange)=\"onTriggerChange()\"></eqp-select>\r\n </div> \r\n</div>", styles: [".valueCol{padding-right:0}.operatorCol{padding-left:0}::ng-deep .operatorCol .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:#a5afc0!important}::ng-deep .operatorCol .mat-mdc-select-value{color:#081c45;font-size:16px;font-weight:700;position:relative;top:-6px}::ng-deep eqp-select .mat-form-field-appearance-fill.ng-touched label.mdc-floating-label.mat-mdc-floating-label{background-color:transparent!important}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.EqpSelectComponent, selector: "eqp-select", inputs: ["placeholder", "enumData", "enumDataToExclude", "arrayData", "arrayKeyProperty", "arrayValueProperty", "ngModelOptions", "ngModelInput", "formGroupInput", "formControlNameInput", "isRequired", "isDisabled", "isMultiLanguage", "multilanguagePrefixKey", "isAlphabeticalOrderable", "suffixIcon", "prefixIcon", "isMultiSelect", "includeFullObject", "showCancelButton", "isSearchable", "searchText", "noResultSearchText", "data"], outputs: ["ngModelInputChange"] }] });
55
+ ListValueTriggerTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ListValueTriggerTemplateComponent, selector: "list-value-trigger-template", inputs: { condition: "condition" }, outputs: { recordChange: "recordChange", triggerChange: "triggerChange" }, ngImport: i0, template: "<div class=\"row\">\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorListValue\" [(ngModelInput)]=\"selectedLogicOperatorListValue\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-6 valueCol\">\r\n\r\n <eqp-select [ngStyle]=\"FieldstyleObj\" *ngIf=\"field.PresentationMode == ListPresentationEnum['Combo box']\" [arrayData]=\"arrayData\"\r\n [arrayKeyProperty]=\"'Value'\" [showCancelButton]=\"!field.Required\" [arrayValueProperty]=\"'Key'\"\r\n [includeFullObject]=\"false\" [isRequired]=\"true\"\r\n [(ngModelInput)]=\"condition.record[field.Name]\" [isMultiSelect]=\"field.IsMultiChoiche\">\r\n </eqp-select>\r\n\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"booleanLogicOperatorType\" [(ngModelInput)]=\"selectedBooleanLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div> \r\n</div>", styles: [".valueCol{padding-right:0}.operatorCol{padding-left:0}::ng-deep .operatorCol .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:#a5afc0!important}::ng-deep .operatorCol .mat-mdc-select-value{color:#081c45;font-size:16px;font-weight:700;position:relative;top:-6px}::ng-deep eqp-select .mat-form-field-appearance-fill.ng-touched label.mdc-floating-label.mat-mdc-floating-label{background-color:transparent!important}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.EqpSelectComponent, selector: "eqp-select", inputs: ["placeholder", "enumData", "enumDataToExclude", "arrayData", "arrayKeyProperty", "arrayValueProperty", "ngModelOptions", "ngModelInput", "formGroupInput", "formControlNameInput", "isRequired", "isDisabled", "isMultiLanguage", "multilanguagePrefixKey", "isAlphabeticalOrderable", "suffixIcon", "prefixIcon", "isMultiSelect", "includeFullObject", "showCancelButton", "isSearchable", "searchText", "noResultSearchText", "data"], outputs: ["ngModelInputChange"] }] });
128
56
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ListValueTriggerTemplateComponent, decorators: [{
129
57
  type: Component,
130
- args: [{ selector: 'list-value-trigger-template', template: "<div class=\"row\">\r\n <div class=\"col-md-6 valueCol\">\r\n <eqp-select [ngStyle]=\"FieldstyleObj\" [arrayData]=\"arrayData\"\r\n [arrayKeyProperty]=\"'Value'\" [showCancelButton]=\"true\" [arrayValueProperty]=\"'Key'\"\r\n [placeholder]=\"field.Description\"\r\n [includeFullObject]=\"false\" [isRequired]=\"false\" [isDisabled]=\"false\"\r\n [(ngModelInput)]=\"record[field.Name]\" [isMultiSelect]=\"false\"\r\n (ngModelInputChange)=\"onTriggerChange()\">\r\n </eqp-select>\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorListValue\" [(ngModel)]=\"selectedLogicOperator\" (ngModelChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"booleanLogicOperatorType\" [(ngModel)]=\"selectedBooleanLogicOperator\" (ngModelChange)=\"onTriggerChange()\"></eqp-select>\r\n </div> \r\n</div>", styles: [".valueCol{padding-right:0}.operatorCol{padding-left:0}::ng-deep .operatorCol .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:#a5afc0!important}::ng-deep .operatorCol .mat-mdc-select-value{color:#081c45;font-size:16px;font-weight:700;position:relative;top:-6px}::ng-deep eqp-select .mat-form-field-appearance-fill.ng-touched label.mdc-floating-label.mat-mdc-floating-label{background-color:transparent!important}\n"] }]
131
- }], ctorParameters: function () { return []; }, propDecorators: { field: [{
132
- type: Input
133
- }], record: [{
58
+ args: [{ selector: 'list-value-trigger-template', template: "<div class=\"row\">\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorListValue\" [(ngModelInput)]=\"selectedLogicOperatorListValue\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-6 valueCol\">\r\n\r\n <eqp-select [ngStyle]=\"FieldstyleObj\" *ngIf=\"field.PresentationMode == ListPresentationEnum['Combo box']\" [arrayData]=\"arrayData\"\r\n [arrayKeyProperty]=\"'Value'\" [showCancelButton]=\"!field.Required\" [arrayValueProperty]=\"'Key'\"\r\n [includeFullObject]=\"false\" [isRequired]=\"true\"\r\n [(ngModelInput)]=\"condition.record[field.Name]\" [isMultiSelect]=\"field.IsMultiChoiche\">\r\n </eqp-select>\r\n\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"booleanLogicOperatorType\" [(ngModelInput)]=\"selectedBooleanLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div> \r\n</div>", styles: [".valueCol{padding-right:0}.operatorCol{padding-left:0}::ng-deep .operatorCol .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:#a5afc0!important}::ng-deep .operatorCol .mat-mdc-select-value{color:#081c45;font-size:16px;font-weight:700;position:relative;top:-6px}::ng-deep eqp-select .mat-form-field-appearance-fill.ng-touched label.mdc-floating-label.mat-mdc-floating-label{background-color:transparent!important}\n"] }]
59
+ }], propDecorators: { condition: [{
134
60
  type: Input
135
- }], filterChange: [{
61
+ }], recordChange: [{
62
+ type: Output
63
+ }], triggerChange: [{
136
64
  type: Output
137
65
  }] } });
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-value-trigger-template.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/trigger-creator/trigger-templates/list-value-trigger-template/list-value-trigger-template.component.ts","../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/trigger-creator/trigger-templates/list-value-trigger-template/list-value-trigger-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { Record } from '../../../../../models/record.model';\r\nimport { LogicOperatorListValue } from '../../../../../models/logicOperator.model';\r\nimport { Statistic } from '../../../../../models/statistic.model';\r\nimport { ListPresentationEnum, ListValueField } from '../../../../../models/fields/listValueField.model';\r\nimport { UtilityHelperService } from '../../../../../services/utilityHelper.services';\r\nimport { GlobalService } from '../../../../../services/global.service';\r\nimport { BooleanLogicOperatorType } from '../../../../../models/trigger.model';\r\n@Component({\r\n  selector: 'list-value-trigger-template',\r\n  templateUrl: './list-value-trigger-template.component.html',\r\n  styleUrls: ['./list-value-trigger-template.component.scss']\r\n})\r\nexport class ListValueTriggerTemplateComponent {\r\n  @Input() field: ListValueField;\r\n  @Input() record: Record;\r\n  @Output() filterChange: EventEmitter<Statistic> = new EventEmitter<Statistic>();\r\n  validatorsArray: any[] = [];\r\n  logicOperatorListValue = LogicOperatorListValue;\r\n  selectedLogicOperator: LogicOperatorListValue;\r\n  activeCondition: boolean = false;\r\n\r\n  booleanLogicOperatorType = BooleanLogicOperatorType;\r\n  selectedBooleanLogicOperator: BooleanLogicOperatorType = BooleanLogicOperatorType.AND;  \r\n\r\n//variabili per gestire il css della label e del field\r\nFieldstyleObj: any;\r\nLabelstyleObj: any;\r\n\r\narrayData: { Key: string, Value: any, Selected?: boolean, ImgUrl?: string }[] = [];\r\n\r\nconstructor() {\r\n}\r\n\r\nngOnInit(): void {\r\n  this.configureControllers();\r\n  this.initStyles();\r\n  this.setArrayData();\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}\r\n\r\n/**\r\n* Metodo per emettere l'evento che il valore del record è cambiato.\r\n*/\r\nonTriggerChange() {\r\n  if (this.selectedLogicOperator != null){\r\n    this.activeCondition = true;\r\n    this.filterChange.emit(this.generateCondition(\"active\"));\r\n  }\r\n  if (this.activeCondition &&  this.selectedLogicOperator == null){\r\n    this.activeCondition = false;\r\n    this.filterChange.emit(this.generateCondition(\"deactivated\"));\r\n  }\r\n}\r\n\r\n/**\r\n * Metodo che genera l'oggetto da inviare all'esterno\r\n */\r\n\r\ngenerateCondition(mode){\r\n  let output:Statistic = new Statistic();\r\n  if (mode == \"active\"){\r\n    output = {\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    };\r\n  } else {\r\n    output = {\r\n      key: this.field.Name,\r\n      value: null,\r\n      logicoperator: null,\r\n      fieldtype: null\r\n    };\r\n  }\r\n\r\n  return output;\r\n}\r\n\r\n/**\r\n* Metodo di aggiunta dei validator dell'input\r\n*/\r\n  private configureControllers() {\r\n    this.validatorsArray = [];\r\n    this.field.FormFormGroup.get([this.field.Name]).setValidators(this.validatorsArray);\r\n  }\r\n\r\n   /**\r\n   * Metodo per creare un array di oggetti del tipo { Key: string, Value: any } da usare come sorgente dati per la eqp-select.\r\n   */\r\n   private setArrayData() {\r\n    this.prepareValuePairs();\r\n    if (this.field.ValuePairs != null){\r\n      if (UtilityHelperService.isNumeric(this.field.ValuePairs[Object.keys(this.field.ValuePairs)[0]])) {\r\n        Object.keys(this.field.ValuePairs).forEach\r\n          (k => this.createNumberArrayDataElement(k, Number(this.field.ValuePairs[k])));\r\n      } else {\r\n        Object.keys(this.field.ValuePairs).forEach\r\n          (k => this.createArrayDataElement(k, this.field.ValuePairs[k]));\r\n      }\r\n    }\r\n  }\r\n\r\n  prepareValuePairs() {\r\n    if (this.field.Formula) {\r\n      this.field.ValuePairs = {};\r\n      const temp: string = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);\r\n      // temp dovrebbe essere una stringa del tipo \"chiave1! valore 1 ; chiave2 | valore 2 \"\r\n      // dobbiamo ottenere un dizionario di quei valori\r\n      this.field.ValuePairs = GlobalService.stringToValuePairs(temp);\r\n\r\n      //this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);\r\n    } else if (this.field.ValuePairs != null && this.field.ValuePairs.lenght > 0) {\r\n      // va bene così\r\n\r\n    } else if (this.field.ValueString != null && this.field.ValueString != \"\") {\r\n      // va presa la strigna e rimappata nel diario\r\n      this.field.ValuePairs = GlobalService.stringToValuePairs(this.field.ValueString);\r\n\r\n    }\r\n  }\r\n  \r\n  private createArrayDataElement(key: string, value: string, imgUrl: string = null) {\r\n    let isOptionSelected: boolean;\r\n    if (this.field.IsMultiChoiche && this.record[this.field.Name] && this.record[this.field.Name].length > 0) {\r\n      isOptionSelected = !!this.record[this.field.Name].find(v => v == value);\r\n    } else {\r\n      isOptionSelected = this.record[this.field.Name] === value;\r\n    }\r\n    this.arrayData.push({ Key: key, Value: value, Selected: isOptionSelected, ImgUrl: imgUrl });\r\n  }\r\n\r\n  private createNumberArrayDataElement(key: string, value: number, imgUrl: string = null) {\r\n    let isOptionSelected: boolean;\r\n    if (this.field.IsMultiChoiche && this.record[this.field.Name] && this.record[this.field.Name].length > 0) {\r\n      isOptionSelected = !!this.record[this.field.Name].find(v => v == value);\r\n    } else {\r\n      isOptionSelected = this.record[this.field.Name] === value;\r\n    }\r\n    this.arrayData.push({ Key: key, Value: value, Selected: isOptionSelected, ImgUrl: imgUrl });\r\n  }\r\n\r\n}\r\n","<div class=\"row\">\r\n    <div class=\"col-md-6 valueCol\">\r\n        <eqp-select [ngStyle]=\"FieldstyleObj\" [arrayData]=\"arrayData\"\r\n            [arrayKeyProperty]=\"'Value'\" [showCancelButton]=\"true\" [arrayValueProperty]=\"'Key'\"\r\n            [placeholder]=\"field.Description\"\r\n            [includeFullObject]=\"false\" [isRequired]=\"false\" [isDisabled]=\"false\"\r\n            [(ngModelInput)]=\"record[field.Name]\" [isMultiSelect]=\"false\"\r\n            (ngModelInputChange)=\"onTriggerChange()\">\r\n        </eqp-select>\r\n    </div>\r\n    <div class=\"col-md-3 operatorCol\">\r\n        <eqp-select [enumData]=\"logicOperatorListValue\" [(ngModel)]=\"selectedLogicOperator\" (ngModelChange)=\"onTriggerChange()\"></eqp-select>\r\n    </div>\r\n    <div class=\"col-md-3 operatorCol\">\r\n        <eqp-select [enumData]=\"booleanLogicOperatorType\" [(ngModel)]=\"selectedBooleanLogicOperator\" (ngModelChange)=\"onTriggerChange()\"></eqp-select>\r\n    </div>     \r\n</div>"]}
66
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-value-trigger-template.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/trigger-creator/trigger-templates/list-value-trigger-template/list-value-trigger-template.component.ts","../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/trigger-creator/trigger-templates/list-value-trigger-template/list-value-trigger-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { Record } from '../../../../../models/record.model';\r\nimport { BooleanLogicOperatorType, Condition, TriggerCondition } from '../../../../../models/trigger.model';\r\nimport { UtilityHelperService } from '../../../../../services/utilityHelper.services';\r\nimport { ListPresentationEnum, ListValueField } from '../../../../../models/fields/listValueField.model';\r\nimport { LogicOperatorListValue} from '../../../../../models/logicOperator.model';\r\nimport { GlobalService } from '../../../../../services/global.service';\r\n\r\n@Component({\r\n  selector: 'list-value-trigger-template',\r\n  templateUrl: './list-value-trigger-template.component.html',\r\n  styleUrls: ['./list-value-trigger-template.component.scss']\r\n})\r\nexport class ListValueTriggerTemplateComponent {\r\n\r\n    //variabili esterne per l'input dei campi\r\n    @Input() condition: TriggerCondition;\r\n\r\n    @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n    @Output() triggerChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    logicOperatorListValue = LogicOperatorListValue;\r\n    selectedLogicOperatorListValue: LogicOperatorListValue = LogicOperatorListValue['CONTIENE ALMENO UNO'];\r\n    \r\n    FieldstyleObj: any;\r\n    LabelstyleObj: any;\r\n\r\n    booleanLogicOperatorType = BooleanLogicOperatorType;\r\n    selectedBooleanLogicOperator: BooleanLogicOperatorType = BooleanLogicOperatorType.AND;    \r\n    field: ListValueField;\r\n    ListPresentationEnum = ListPresentationEnum;\r\n\r\n    arrayData: { Key: string, Value: any, Selected?: boolean, ImgUrl?: string }[] = [];\r\n\r\n    ngOnInit(): void {\r\n      this.field = this.condition.Field as ListValueField;\r\n      this.initStyles();\r\n      this.setArrayData();\r\n    }\r\n\r\n    initStyles() {\r\n        //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html\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\n  \r\n    onTriggerChange() {\r\n\r\n      let output:Condition = new Condition();\r\n      output = {\r\n        key: this.field.Name,\r\n        value: this.condition.record[this.field.Name],\r\n        logicoperator: this.selectedLogicOperatorListValue,\r\n        fieldType: this.field.FieldType,\r\n        booleanlogicoperator: this.selectedBooleanLogicOperator\r\n      };\r\n\r\n      this.triggerChange.emit(output);\r\n    }    \r\n\r\n    private setArrayData() {\r\n      this.field.ValuePairs = GlobalService.stringToValuePairs(this.field.ValueString);\r\n\r\n      Object.keys(this.field.ValuePairs).forEach((k) => {\r\n        this.arrayData.push({Key: k, Value: this.field.ValuePairs[k], Selected: false});\r\n      });\r\n    }\r\n \r\n\r\n}","<div class=\"row\">\r\n    <div class=\"col-md-3 operatorCol\">\r\n        <eqp-select [enumData]=\"logicOperatorListValue\" [(ngModelInput)]=\"selectedLogicOperatorListValue\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n    </div>\r\n    <div class=\"col-md-6 valueCol\">\r\n\r\n            <eqp-select [ngStyle]=\"FieldstyleObj\" *ngIf=\"field.PresentationMode == ListPresentationEnum['Combo box']\" [arrayData]=\"arrayData\"\r\n            [arrayKeyProperty]=\"'Value'\" [showCancelButton]=\"!field.Required\" [arrayValueProperty]=\"'Key'\"\r\n            [includeFullObject]=\"false\" [isRequired]=\"true\"\r\n            [(ngModelInput)]=\"condition.record[field.Name]\" [isMultiSelect]=\"field.IsMultiChoiche\">\r\n            </eqp-select>\r\n\r\n    </div>\r\n    <div class=\"col-md-3 operatorCol\">\r\n        <eqp-select [enumData]=\"booleanLogicOperatorType\" [(ngModelInput)]=\"selectedBooleanLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n    </div>         \r\n</div>"]}
@@ -30,8 +30,8 @@ export var LogicOperatorBoolean;
30
30
  })(LogicOperatorBoolean || (LogicOperatorBoolean = {}));
31
31
  export var LogicOperatorListValue;
32
32
  (function (LogicOperatorListValue) {
33
- LogicOperatorListValue[LogicOperatorListValue["="] = 1] = "=";
34
- LogicOperatorListValue[LogicOperatorListValue["!="] = 2] = "!=";
33
+ LogicOperatorListValue[LogicOperatorListValue["CONTIENE ALMENO UNO"] = 11] = "CONTIENE ALMENO UNO";
34
+ LogicOperatorListValue[LogicOperatorListValue["CONTIENE TUTTI"] = 12] = "CONTIENE TUTTI";
35
35
  })(LogicOperatorListValue || (LogicOperatorListValue = {}));
36
36
  export var LogicOperatorImageSelector;
37
37
  (function (LogicOperatorImageSelector) {
@@ -50,5 +50,7 @@ export var LogicOperator;
50
50
  LogicOperator[LogicOperator["<="] = 8] = "<=";
51
51
  LogicOperator[LogicOperator["Si"] = 9] = "Si";
52
52
  LogicOperator[LogicOperator["No"] = 10] = "No";
53
+ LogicOperator[LogicOperator["CONTIENE ALMENO UNO"] = 11] = "CONTIENE ALMENO UNO";
54
+ LogicOperator[LogicOperator["CONTIENE TUTTI"] = 12] = "CONTIENE TUTTI";
53
55
  })(LogicOperator || (LogicOperator = {}));
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naWNPcGVyYXRvci5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VxcC1keW5hbWljLW1vZHVsZS9zcmMvbGliL21vZGVscy9sb2dpY09wZXJhdG9yLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLG9CQU9YO0FBUEQsV0FBWSxvQkFBb0I7SUFDNUIseURBQU8sQ0FBQTtJQUNQLDJEQUFRLENBQUE7SUFDUix5REFBTyxDQUFBO0lBQ1AsMkRBQVEsQ0FBQTtJQUNSLHlEQUFPLENBQUE7SUFDUCwyREFBUSxDQUFBO0FBQ1osQ0FBQyxFQVBXLG9CQUFvQixLQUFwQixvQkFBb0IsUUFPL0I7QUFFRCxNQUFNLENBQU4sSUFBWSxpQkFPWDtBQVBELFdBQVksaUJBQWlCO0lBQ3pCLG1EQUFPLENBQUE7SUFDUCxxREFBUSxDQUFBO0lBQ1IsbURBQU8sQ0FBQTtJQUNQLHFEQUFRLENBQUE7SUFDUixtREFBTyxDQUFBO0lBQ1AscURBQVEsQ0FBQTtBQUNaLENBQUMsRUFQVyxpQkFBaUIsS0FBakIsaUJBQWlCLFFBTzVCO0FBRUQsTUFBTSxDQUFOLElBQVksaUJBS1g7QUFMRCxXQUFZLGlCQUFpQjtJQUN6QixtREFBTyxDQUFBO0lBQ1AscURBQVEsQ0FBQTtJQUNSLHlEQUFVLENBQUE7SUFDVixpRUFBYyxDQUFBO0FBQ2xCLENBQUMsRUFMVyxpQkFBaUIsS0FBakIsaUJBQWlCLFFBSzVCO0FBRUQsTUFBTSxDQUFOLElBQVksb0JBR1g7QUFIRCxXQUFZLG9CQUFvQjtJQUM1QiwyREFBUSxDQUFBO0lBQ1IsNERBQVMsQ0FBQTtBQUNiLENBQUMsRUFIVyxvQkFBb0IsS0FBcEIsb0JBQW9CLFFBRy9CO0FBRUQsTUFBTSxDQUFOLElBQVksc0JBR1g7QUFIRCxXQUFZLHNCQUFzQjtJQUM5Qiw2REFBTyxDQUFBO0lBQ1AsK0RBQVEsQ0FBQTtBQUNaLENBQUMsRUFIVyxzQkFBc0IsS0FBdEIsc0JBQXNCLFFBR2pDO0FBRUQsTUFBTSxDQUFOLElBQVksMEJBR1g7QUFIRCxXQUFZLDBCQUEwQjtJQUNsQyxxRUFBTyxDQUFBO0lBQ1AsdUVBQVEsQ0FBQTtBQUNaLENBQUMsRUFIVywwQkFBMEIsS0FBMUIsMEJBQTBCLFFBR3JDO0FBRUQsTUFBTSxDQUFOLElBQVksYUFXWDtBQVhELFdBQVksYUFBYTtJQUNyQiwyQ0FBTyxDQUFBO0lBQ1AsNkNBQVEsQ0FBQTtJQUNSLGlEQUFVLENBQUE7SUFDVix5REFBYyxDQUFBO0lBQ2QsMkNBQU8sQ0FBQTtJQUNQLDZDQUFRLENBQUE7SUFDUiwyQ0FBTyxDQUFBO0lBQ1AsNkNBQVEsQ0FBQTtJQUNSLDZDQUFRLENBQUE7SUFDUiw4Q0FBUyxDQUFBO0FBQ2IsQ0FBQyxFQVhXLGFBQWEsS0FBYixhQUFhLFFBV3hCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gTG9naWNPcGVyYXRvck51bWVyaWMge1xyXG4gICAgXCI9XCIgPSAxLFxyXG4gICAgXCIhPVwiID0gMixcclxuICAgIFwiPlwiID0gNSxcclxuICAgIFwiPj1cIiA9IDYsXHJcbiAgICBcIjxcIiA9IDcsXHJcbiAgICBcIjw9XCIgPSA4LFxyXG59XHJcblxyXG5leHBvcnQgZW51bSBMb2dpY09wZXJhdG9yRGF0ZSB7XHJcbiAgICBcIj1cIiA9IDEsXHJcbiAgICBcIiE9XCIgPSAyLFxyXG4gICAgXCI+XCIgPSA1LFxyXG4gICAgXCI+PVwiID0gNixcclxuICAgIFwiPFwiID0gNyxcclxuICAgIFwiPD1cIiA9IDgsXHJcbn1cclxuXHJcbmV4cG9ydCBlbnVtIExvZ2ljT3BlcmF0b3JUZXh0IHtcclxuICAgIFwiPVwiID0gMSxcclxuICAgIFwiIT1cIiA9IDIsXHJcbiAgICBcIkxJS0VcIiA9IDMsXHJcbiAgICBcIk5PVCBMSUtFXCIgPSA0LFxyXG59XHJcblxyXG5leHBvcnQgZW51bSBMb2dpY09wZXJhdG9yQm9vbGVhbiB7XHJcbiAgICBcIlNpXCIgPSA5LFxyXG4gICAgXCJOb1wiID0gMTBcclxufVxyXG5cclxuZXhwb3J0IGVudW0gTG9naWNPcGVyYXRvckxpc3RWYWx1ZSB7XHJcbiAgICBcIj1cIiA9IDEsXHJcbiAgICBcIiE9XCIgPSAyXHJcbn1cclxuXHJcbmV4cG9ydCBlbnVtIExvZ2ljT3BlcmF0b3JJbWFnZVNlbGVjdG9yIHtcclxuICAgIFwiPVwiID0gMSxcclxuICAgIFwiIT1cIiA9IDJcclxufVxyXG5cclxuZXhwb3J0IGVudW0gTG9naWNPcGVyYXRvciB7XHJcbiAgICBcIj1cIiA9IDEsXHJcbiAgICBcIiE9XCIgPSAyLFxyXG4gICAgXCJMSUtFXCIgPSAzLFxyXG4gICAgXCJOT1QgTElLRVwiID0gNCwgICAgXHJcbiAgICBcIj5cIiA9IDUsXHJcbiAgICBcIj49XCIgPSA2LFxyXG4gICAgXCI8XCIgPSA3LFxyXG4gICAgXCI8PVwiID0gOCxcclxuICAgIFwiU2lcIiA9IDksXHJcbiAgICBcIk5vXCIgPSAxMCAgICBcclxufSJdfQ==
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9naWNPcGVyYXRvci5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VxcC1keW5hbWljLW1vZHVsZS9zcmMvbGliL21vZGVscy9sb2dpY09wZXJhdG9yLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLG9CQU9YO0FBUEQsV0FBWSxvQkFBb0I7SUFDNUIseURBQU8sQ0FBQTtJQUNQLDJEQUFRLENBQUE7SUFDUix5REFBTyxDQUFBO0lBQ1AsMkRBQVEsQ0FBQTtJQUNSLHlEQUFPLENBQUE7SUFDUCwyREFBUSxDQUFBO0FBQ1osQ0FBQyxFQVBXLG9CQUFvQixLQUFwQixvQkFBb0IsUUFPL0I7QUFFRCxNQUFNLENBQU4sSUFBWSxpQkFPWDtBQVBELFdBQVksaUJBQWlCO0lBQ3pCLG1EQUFPLENBQUE7SUFDUCxxREFBUSxDQUFBO0lBQ1IsbURBQU8sQ0FBQTtJQUNQLHFEQUFRLENBQUE7SUFDUixtREFBTyxDQUFBO0lBQ1AscURBQVEsQ0FBQTtBQUNaLENBQUMsRUFQVyxpQkFBaUIsS0FBakIsaUJBQWlCLFFBTzVCO0FBRUQsTUFBTSxDQUFOLElBQVksaUJBS1g7QUFMRCxXQUFZLGlCQUFpQjtJQUN6QixtREFBTyxDQUFBO0lBQ1AscURBQVEsQ0FBQTtJQUNSLHlEQUFVLENBQUE7SUFDVixpRUFBYyxDQUFBO0FBQ2xCLENBQUMsRUFMVyxpQkFBaUIsS0FBakIsaUJBQWlCLFFBSzVCO0FBRUQsTUFBTSxDQUFOLElBQVksb0JBR1g7QUFIRCxXQUFZLG9CQUFvQjtJQUM1QiwyREFBUSxDQUFBO0lBQ1IsNERBQVMsQ0FBQTtBQUNiLENBQUMsRUFIVyxvQkFBb0IsS0FBcEIsb0JBQW9CLFFBRy9CO0FBRUQsTUFBTSxDQUFOLElBQVksc0JBR1g7QUFIRCxXQUFZLHNCQUFzQjtJQUM5QixrR0FBMEIsQ0FBQTtJQUMxQix3RkFBcUIsQ0FBQTtBQUN6QixDQUFDLEVBSFcsc0JBQXNCLEtBQXRCLHNCQUFzQixRQUdqQztBQUVELE1BQU0sQ0FBTixJQUFZLDBCQUdYO0FBSEQsV0FBWSwwQkFBMEI7SUFDbEMscUVBQU8sQ0FBQTtJQUNQLHVFQUFRLENBQUE7QUFDWixDQUFDLEVBSFcsMEJBQTBCLEtBQTFCLDBCQUEwQixRQUdyQztBQUVELE1BQU0sQ0FBTixJQUFZLGFBYVg7QUFiRCxXQUFZLGFBQWE7SUFDckIsMkNBQU8sQ0FBQTtJQUNQLDZDQUFRLENBQUE7SUFDUixpREFBVSxDQUFBO0lBQ1YseURBQWMsQ0FBQTtJQUNkLDJDQUFPLENBQUE7SUFDUCw2Q0FBUSxDQUFBO0lBQ1IsMkNBQU8sQ0FBQTtJQUNQLDZDQUFRLENBQUE7SUFDUiw2Q0FBUSxDQUFBO0lBQ1IsOENBQVMsQ0FBQTtJQUNULGdGQUEwQixDQUFBO0lBQzFCLHNFQUFxQixDQUFBO0FBQ3pCLENBQUMsRUFiVyxhQUFhLEtBQWIsYUFBYSxRQWF4QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIExvZ2ljT3BlcmF0b3JOdW1lcmljIHtcclxuICAgIFwiPVwiID0gMSxcclxuICAgIFwiIT1cIiA9IDIsXHJcbiAgICBcIj5cIiA9IDUsXHJcbiAgICBcIj49XCIgPSA2LFxyXG4gICAgXCI8XCIgPSA3LFxyXG4gICAgXCI8PVwiID0gOCxcclxufVxyXG5cclxuZXhwb3J0IGVudW0gTG9naWNPcGVyYXRvckRhdGUge1xyXG4gICAgXCI9XCIgPSAxLFxyXG4gICAgXCIhPVwiID0gMixcclxuICAgIFwiPlwiID0gNSxcclxuICAgIFwiPj1cIiA9IDYsXHJcbiAgICBcIjxcIiA9IDcsXHJcbiAgICBcIjw9XCIgPSA4LFxyXG59XHJcblxyXG5leHBvcnQgZW51bSBMb2dpY09wZXJhdG9yVGV4dCB7XHJcbiAgICBcIj1cIiA9IDEsXHJcbiAgICBcIiE9XCIgPSAyLFxyXG4gICAgXCJMSUtFXCIgPSAzLFxyXG4gICAgXCJOT1QgTElLRVwiID0gNCxcclxufVxyXG5cclxuZXhwb3J0IGVudW0gTG9naWNPcGVyYXRvckJvb2xlYW4ge1xyXG4gICAgXCJTaVwiID0gOSxcclxuICAgIFwiTm9cIiA9IDEwXHJcbn1cclxuXHJcbmV4cG9ydCBlbnVtIExvZ2ljT3BlcmF0b3JMaXN0VmFsdWUge1xyXG4gICAgXCJDT05USUVORSBBTE1FTk8gVU5PXCIgPSAxMSxcclxuICAgIFwiQ09OVElFTkUgVFVUVElcIiA9IDEyLFxyXG59XHJcblxyXG5leHBvcnQgZW51bSBMb2dpY09wZXJhdG9ySW1hZ2VTZWxlY3RvciB7XHJcbiAgICBcIj1cIiA9IDEsXHJcbiAgICBcIiE9XCIgPSAyXHJcbn1cclxuXHJcbmV4cG9ydCBlbnVtIExvZ2ljT3BlcmF0b3Ige1xyXG4gICAgXCI9XCIgPSAxLFxyXG4gICAgXCIhPVwiID0gMixcclxuICAgIFwiTElLRVwiID0gMyxcclxuICAgIFwiTk9UIExJS0VcIiA9IDQsICAgIFxyXG4gICAgXCI+XCIgPSA1LFxyXG4gICAgXCI+PVwiID0gNixcclxuICAgIFwiPFwiID0gNyxcclxuICAgIFwiPD1cIiA9IDgsXHJcbiAgICBcIlNpXCIgPSA5LFxyXG4gICAgXCJOb1wiID0gMTAsXHJcbiAgICBcIkNPTlRJRU5FIEFMTUVOTyBVTk9cIiA9IDExLFxyXG4gICAgXCJDT05USUVORSBUVVRUSVwiID0gMTIsICAgIFxyXG59Il19
@@ -1933,8 +1933,8 @@ var LogicOperatorBoolean;
1933
1933
  })(LogicOperatorBoolean || (LogicOperatorBoolean = {}));
1934
1934
  var LogicOperatorListValue;
1935
1935
  (function (LogicOperatorListValue) {
1936
- LogicOperatorListValue[LogicOperatorListValue["="] = 1] = "=";
1937
- LogicOperatorListValue[LogicOperatorListValue["!="] = 2] = "!=";
1936
+ LogicOperatorListValue[LogicOperatorListValue["CONTIENE ALMENO UNO"] = 11] = "CONTIENE ALMENO UNO";
1937
+ LogicOperatorListValue[LogicOperatorListValue["CONTIENE TUTTI"] = 12] = "CONTIENE TUTTI";
1938
1938
  })(LogicOperatorListValue || (LogicOperatorListValue = {}));
1939
1939
  var LogicOperatorImageSelector;
1940
1940
  (function (LogicOperatorImageSelector) {
@@ -1953,6 +1953,8 @@ var LogicOperator;
1953
1953
  LogicOperator[LogicOperator["<="] = 8] = "<=";
1954
1954
  LogicOperator[LogicOperator["Si"] = 9] = "Si";
1955
1955
  LogicOperator[LogicOperator["No"] = 10] = "No";
1956
+ LogicOperator[LogicOperator["CONTIENE ALMENO UNO"] = 11] = "CONTIENE ALMENO UNO";
1957
+ LogicOperator[LogicOperator["CONTIENE TUTTI"] = 12] = "CONTIENE TUTTI";
1956
1958
  })(LogicOperator || (LogicOperator = {}));
1957
1959
 
1958
1960
  class Trigger {
@@ -5461,24 +5463,36 @@ class AddFormRecordComponent {
5461
5463
  this.logTrigger(trigger, condition, record);
5462
5464
  return;
5463
5465
  }
5466
+ if (logicOperator == LogicOperator['CONTIENE ALMENO UNO'] && !conditionValue.some(c => recordValue.includes(c))) {
5467
+ fireTrigger = false;
5468
+ this.logTrigger(trigger, condition, record);
5469
+ return;
5470
+ }
5471
+ if (logicOperator == LogicOperator['CONTIENE TUTTI'] && !conditionValue.every(c => recordValue.includes(c))) {
5472
+ fireTrigger = false;
5473
+ this.logTrigger(trigger, condition, record);
5474
+ return;
5475
+ }
5464
5476
  });
5465
5477
  GlobalService.debugLog("checkTriggers - fireTrigger? ", fireTrigger);
5466
5478
  if (fireTrigger) {
5467
5479
  // Il trigger va sparato. Valuto le funzioni interne
5468
5480
  var formulas = JSON.parse(JSON.stringify(trigger.formulas));
5469
5481
  GlobalService.debugLog("checkTriggers - evaluate formulas ", formulas);
5470
- Object.keys(formulas).forEach((key) => {
5471
- var formula = formulas[key].value;
5472
- GlobalService.debugLog("checkTriggers - formulas[key] ", formulas[key]);
5473
- var temp;
5474
- if (formulas[key].type == TriggerPropertyTypeEnum.DMMODULE) {
5475
- temp = formula;
5476
- }
5477
- else {
5478
- temp = UtilityHelperService.EvaluateFieldFormula(formula, record, null);
5479
- }
5480
- formulas[key] = temp;
5481
- });
5482
+ if (formulas != null && formulas.length > 0) {
5483
+ Object.keys(formulas).forEach((key) => {
5484
+ var formula = formulas[key].value;
5485
+ GlobalService.debugLog("checkTriggers - formulas[key] ", formulas[key]);
5486
+ var temp;
5487
+ if (formulas[key].type == TriggerPropertyTypeEnum.DMMODULE) {
5488
+ temp = formula;
5489
+ }
5490
+ else {
5491
+ temp = UtilityHelperService.EvaluateFieldFormula(formula, record, null);
5492
+ }
5493
+ formulas[key] = temp;
5494
+ });
5495
+ }
5482
5496
  // Sparo il trigger all'esterno
5483
5497
  var triggerToFire = new FireTrigger();
5484
5498
  triggerToFire.form = this.form; // Il form che ha provocato il trigger
@@ -5486,7 +5500,7 @@ class AddFormRecordComponent {
5486
5500
  triggerToFire.trigger = trigger; // Il trigger
5487
5501
  triggerToFire.formulas = formulas; // Le formule inviate in input al modulo dinamico, valutate nel contesto del trigger e del record
5488
5502
  triggerToFire.userPatient = this.userID; // UserID
5489
- GlobalService.debugLog("checkTriggers - Trigger Fired ", triggerToFire);
5503
+ console.log("checkTriggers - Trigger Fired ", triggerToFire.trigger.description, triggerToFire);
5490
5504
  this.fireTrigger.emit(triggerToFire);
5491
5505
  }
5492
5506
  });
@@ -10870,6 +10884,63 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
10870
10884
  type: Output
10871
10885
  }] } });
10872
10886
 
10887
+ class ListValueTriggerTemplateComponent {
10888
+ constructor() {
10889
+ this.recordChange = new EventEmitter();
10890
+ this.triggerChange = new EventEmitter();
10891
+ this.logicOperatorListValue = LogicOperatorListValue;
10892
+ this.selectedLogicOperatorListValue = LogicOperatorListValue['CONTIENE ALMENO UNO'];
10893
+ this.booleanLogicOperatorType = BooleanLogicOperatorType;
10894
+ this.selectedBooleanLogicOperator = BooleanLogicOperatorType.AND;
10895
+ this.ListPresentationEnum = ListPresentationEnum;
10896
+ this.arrayData = [];
10897
+ }
10898
+ ngOnInit() {
10899
+ this.field = this.condition.Field;
10900
+ this.initStyles();
10901
+ this.setArrayData();
10902
+ }
10903
+ initStyles() {
10904
+ //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html
10905
+ if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)
10906
+ this.FieldstyleObj = UtilityHelperService.initStyles(this.field.FieldstyleCSS);
10907
+ if (this.field.LabelstyleCSS != null || this.field.LabelstyleCSS != undefined)
10908
+ this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);
10909
+ }
10910
+ /**
10911
+ * Metodo per emettere l'evento che il valore del record è cambiato.
10912
+ */
10913
+ onTriggerChange() {
10914
+ let output = new Condition();
10915
+ output = {
10916
+ key: this.field.Name,
10917
+ value: this.condition.record[this.field.Name],
10918
+ logicoperator: this.selectedLogicOperatorListValue,
10919
+ fieldType: this.field.FieldType,
10920
+ booleanlogicoperator: this.selectedBooleanLogicOperator
10921
+ };
10922
+ this.triggerChange.emit(output);
10923
+ }
10924
+ setArrayData() {
10925
+ this.field.ValuePairs = GlobalService.stringToValuePairs(this.field.ValueString);
10926
+ Object.keys(this.field.ValuePairs).forEach((k) => {
10927
+ this.arrayData.push({ Key: k, Value: this.field.ValuePairs[k], Selected: false });
10928
+ });
10929
+ }
10930
+ }
10931
+ ListValueTriggerTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ListValueTriggerTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
10932
+ ListValueTriggerTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ListValueTriggerTemplateComponent, selector: "list-value-trigger-template", inputs: { condition: "condition" }, outputs: { recordChange: "recordChange", triggerChange: "triggerChange" }, ngImport: i0, template: "<div class=\"row\">\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorListValue\" [(ngModelInput)]=\"selectedLogicOperatorListValue\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-6 valueCol\">\r\n\r\n <eqp-select [ngStyle]=\"FieldstyleObj\" *ngIf=\"field.PresentationMode == ListPresentationEnum['Combo box']\" [arrayData]=\"arrayData\"\r\n [arrayKeyProperty]=\"'Value'\" [showCancelButton]=\"!field.Required\" [arrayValueProperty]=\"'Key'\"\r\n [includeFullObject]=\"false\" [isRequired]=\"true\"\r\n [(ngModelInput)]=\"condition.record[field.Name]\" [isMultiSelect]=\"field.IsMultiChoiche\">\r\n </eqp-select>\r\n\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"booleanLogicOperatorType\" [(ngModelInput)]=\"selectedBooleanLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div> \r\n</div>", styles: [".valueCol{padding-right:0}.operatorCol{padding-left:0}::ng-deep .operatorCol .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:#a5afc0!important}::ng-deep .operatorCol .mat-mdc-select-value{color:#081c45;font-size:16px;font-weight:700;position:relative;top:-6px}::ng-deep eqp-select .mat-form-field-appearance-fill.ng-touched label.mdc-floating-label.mat-mdc-floating-label{background-color:transparent!important}\n"], dependencies: [{ kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2$1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i7.EqpSelectComponent, selector: "eqp-select", inputs: ["placeholder", "enumData", "enumDataToExclude", "arrayData", "arrayKeyProperty", "arrayValueProperty", "ngModelOptions", "ngModelInput", "formGroupInput", "formControlNameInput", "isRequired", "isDisabled", "isMultiLanguage", "multilanguagePrefixKey", "isAlphabeticalOrderable", "suffixIcon", "prefixIcon", "isMultiSelect", "includeFullObject", "showCancelButton", "isSearchable", "searchText", "noResultSearchText", "data"], outputs: ["ngModelInputChange"] }] });
10933
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ListValueTriggerTemplateComponent, decorators: [{
10934
+ type: Component,
10935
+ args: [{ selector: 'list-value-trigger-template', template: "<div class=\"row\">\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorListValue\" [(ngModelInput)]=\"selectedLogicOperatorListValue\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-6 valueCol\">\r\n\r\n <eqp-select [ngStyle]=\"FieldstyleObj\" *ngIf=\"field.PresentationMode == ListPresentationEnum['Combo box']\" [arrayData]=\"arrayData\"\r\n [arrayKeyProperty]=\"'Value'\" [showCancelButton]=\"!field.Required\" [arrayValueProperty]=\"'Key'\"\r\n [includeFullObject]=\"false\" [isRequired]=\"true\"\r\n [(ngModelInput)]=\"condition.record[field.Name]\" [isMultiSelect]=\"field.IsMultiChoiche\">\r\n </eqp-select>\r\n\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"booleanLogicOperatorType\" [(ngModelInput)]=\"selectedBooleanLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div> \r\n</div>", styles: [".valueCol{padding-right:0}.operatorCol{padding-left:0}::ng-deep .operatorCol .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:#a5afc0!important}::ng-deep .operatorCol .mat-mdc-select-value{color:#081c45;font-size:16px;font-weight:700;position:relative;top:-6px}::ng-deep eqp-select .mat-form-field-appearance-fill.ng-touched label.mdc-floating-label.mat-mdc-floating-label{background-color:transparent!important}\n"] }]
10936
+ }], propDecorators: { condition: [{
10937
+ type: Input
10938
+ }], recordChange: [{
10939
+ type: Output
10940
+ }], triggerChange: [{
10941
+ type: Output
10942
+ }] } });
10943
+
10873
10944
  class TextareaTriggerTemplateComponent {
10874
10945
  constructor(voiceservice) {
10875
10946
  this.voiceservice = voiceservice;
@@ -11007,10 +11078,10 @@ class DynamicModuleTriggerFixComponent {
11007
11078
  }
11008
11079
  }
11009
11080
  DynamicModuleTriggerFixComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DynamicModuleTriggerFixComponent, deps: [{ token: i1$3.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
11010
- DynamicModuleTriggerFixComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DynamicModuleTriggerFixComponent, selector: "dynamic-module-trigger-fix", inputs: { condition: "condition", form: "form" }, outputs: { triggerChange: "triggerChange" }, viewQueries: [{ propertyName: "dialogInnerFormRecord", first: true, predicate: ["dialogInnerFormRecord"], descendants: true, static: true }, { propertyName: "fieldTemplate", predicate: ["fieldTemplate"], descendants: true }, { propertyName: "listInnerFormRecords", predicate: ["listInnerFormRecords"], descendants: true }], ngImport: i0, template: "\r\n<text-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Campo di testo']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</text-trigger-template>\r\n\r\n<numeric-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Campo numerico']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</numeric-trigger-template>\r\n\r\n<textarea-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Area di testo']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</textarea-trigger-template>\r\n\r\n<boolean-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Booleano']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</boolean-trigger-template>\r\n\r\n<date-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Data e/o ora']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</date-trigger-template>", styles: [""], dependencies: [{ kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: TextTriggerTemplateComponent, selector: "text-trigger-template", inputs: ["condition"], outputs: ["recordChange", "triggerChange"] }, { kind: "component", type: NumericTriggerTemplateComponent, selector: "numeric-trigger-template", inputs: ["condition"], outputs: ["triggerChange"] }, { kind: "component", type: BooleanTriggerTemplateComponent, selector: "boolean-trigger-template", inputs: ["condition"], outputs: ["triggerChange"] }, { kind: "component", type: DateTriggerTemplateComponent, selector: "date-trigger-template", inputs: ["condition"], outputs: ["triggerChange"] }, { kind: "component", type: TextareaTriggerTemplateComponent, selector: "textarea-trigger-template", inputs: ["condition"], outputs: ["recordChange", "triggerChange"] }] });
11081
+ DynamicModuleTriggerFixComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DynamicModuleTriggerFixComponent, selector: "dynamic-module-trigger-fix", inputs: { condition: "condition", form: "form" }, outputs: { triggerChange: "triggerChange" }, viewQueries: [{ propertyName: "dialogInnerFormRecord", first: true, predicate: ["dialogInnerFormRecord"], descendants: true, static: true }, { propertyName: "fieldTemplate", predicate: ["fieldTemplate"], descendants: true }, { propertyName: "listInnerFormRecords", predicate: ["listInnerFormRecords"], descendants: true }], ngImport: i0, template: "\r\n<text-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Campo di testo']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</text-trigger-template>\r\n\r\n<numeric-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Campo numerico']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</numeric-trigger-template>\r\n\r\n<textarea-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Area di testo']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</textarea-trigger-template>\r\n\r\n<boolean-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Booleano']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</boolean-trigger-template>\r\n\r\n<date-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Data e/o ora']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</date-trigger-template>\r\n\r\n<list-value-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Elenco generico']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</list-value-trigger-template>", styles: [""], dependencies: [{ kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: TextTriggerTemplateComponent, selector: "text-trigger-template", inputs: ["condition"], outputs: ["recordChange", "triggerChange"] }, { kind: "component", type: NumericTriggerTemplateComponent, selector: "numeric-trigger-template", inputs: ["condition"], outputs: ["triggerChange"] }, { kind: "component", type: BooleanTriggerTemplateComponent, selector: "boolean-trigger-template", inputs: ["condition"], outputs: ["triggerChange"] }, { kind: "component", type: DateTriggerTemplateComponent, selector: "date-trigger-template", inputs: ["condition"], outputs: ["triggerChange"] }, { kind: "component", type: ListValueTriggerTemplateComponent, selector: "list-value-trigger-template", inputs: ["condition"], outputs: ["recordChange", "triggerChange"] }, { kind: "component", type: TextareaTriggerTemplateComponent, selector: "textarea-trigger-template", inputs: ["condition"], outputs: ["recordChange", "triggerChange"] }] });
11011
11082
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DynamicModuleTriggerFixComponent, decorators: [{
11012
11083
  type: Component,
11013
- args: [{ selector: 'dynamic-module-trigger-fix', template: "\r\n<text-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Campo di testo']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</text-trigger-template>\r\n\r\n<numeric-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Campo numerico']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</numeric-trigger-template>\r\n\r\n<textarea-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Area di testo']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</textarea-trigger-template>\r\n\r\n<boolean-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Booleano']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</boolean-trigger-template>\r\n\r\n<date-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Data e/o ora']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</date-trigger-template>" }]
11084
+ args: [{ selector: 'dynamic-module-trigger-fix', template: "\r\n<text-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Campo di testo']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</text-trigger-template>\r\n\r\n<numeric-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Campo numerico']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</numeric-trigger-template>\r\n\r\n<textarea-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Area di testo']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</textarea-trigger-template>\r\n\r\n<boolean-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Booleano']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</boolean-trigger-template>\r\n\r\n<date-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Data e/o ora']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</date-trigger-template>\r\n\r\n<list-value-trigger-template #fieldTemplate *ngIf=\"condition.Field.FieldType == FieldTypeEnum['Elenco generico']\"\r\n [condition]=\"condition\" (triggerChange)=\"onTriggerChange($event)\">\r\n</list-value-trigger-template>" }]
11014
11085
  }], ctorParameters: function () { return [{ type: i1$3.MatDialog }]; }, propDecorators: { condition: [{
11015
11086
  type: Input
11016
11087
  }], form: [{
@@ -12465,134 +12536,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
12465
12536
  args: ['listInnerFormRecords']
12466
12537
  }] } });
12467
12538
 
12468
- class ListValueTriggerTemplateComponent {
12469
- constructor() {
12470
- this.filterChange = new EventEmitter();
12471
- this.validatorsArray = [];
12472
- this.logicOperatorListValue = LogicOperatorListValue;
12473
- this.activeCondition = false;
12474
- this.booleanLogicOperatorType = BooleanLogicOperatorType;
12475
- this.selectedBooleanLogicOperator = BooleanLogicOperatorType.AND;
12476
- this.arrayData = [];
12477
- }
12478
- ngOnInit() {
12479
- this.configureControllers();
12480
- this.initStyles();
12481
- this.setArrayData();
12482
- }
12483
- //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html
12484
- initStyles() {
12485
- if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)
12486
- this.FieldstyleObj = UtilityHelperService.initStyles(this.field.FieldstyleCSS);
12487
- }
12488
- /**
12489
- * Metodo per emettere l'evento che il valore del record è cambiato.
12490
- */
12491
- onTriggerChange() {
12492
- if (this.selectedLogicOperator != null) {
12493
- this.activeCondition = true;
12494
- this.filterChange.emit(this.generateCondition("active"));
12495
- }
12496
- if (this.activeCondition && this.selectedLogicOperator == null) {
12497
- this.activeCondition = false;
12498
- this.filterChange.emit(this.generateCondition("deactivated"));
12499
- }
12500
- }
12501
- /**
12502
- * Metodo che genera l'oggetto da inviare all'esterno
12503
- */
12504
- generateCondition(mode) {
12505
- let output = new Statistic();
12506
- if (mode == "active") {
12507
- output = {
12508
- key: this.field.Name,
12509
- value: this.record[this.field.Name],
12510
- logicoperator: this.selectedLogicOperator,
12511
- fieldtype: this.field.FieldType
12512
- };
12513
- }
12514
- else {
12515
- output = {
12516
- key: this.field.Name,
12517
- value: null,
12518
- logicoperator: null,
12519
- fieldtype: null
12520
- };
12521
- }
12522
- return output;
12523
- }
12524
- /**
12525
- * Metodo di aggiunta dei validator dell'input
12526
- */
12527
- configureControllers() {
12528
- this.validatorsArray = [];
12529
- this.field.FormFormGroup.get([this.field.Name]).setValidators(this.validatorsArray);
12530
- }
12531
- /**
12532
- * Metodo per creare un array di oggetti del tipo { Key: string, Value: any } da usare come sorgente dati per la eqp-select.
12533
- */
12534
- setArrayData() {
12535
- this.prepareValuePairs();
12536
- if (this.field.ValuePairs != null) {
12537
- if (UtilityHelperService.isNumeric(this.field.ValuePairs[Object.keys(this.field.ValuePairs)[0]])) {
12538
- Object.keys(this.field.ValuePairs).forEach(k => this.createNumberArrayDataElement(k, Number(this.field.ValuePairs[k])));
12539
- }
12540
- else {
12541
- Object.keys(this.field.ValuePairs).forEach(k => this.createArrayDataElement(k, this.field.ValuePairs[k]));
12542
- }
12543
- }
12544
- }
12545
- prepareValuePairs() {
12546
- if (this.field.Formula) {
12547
- this.field.ValuePairs = {};
12548
- const temp = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);
12549
- // temp dovrebbe essere una stringa del tipo "chiave1! valore 1 ; chiave2 | valore 2 "
12550
- // dobbiamo ottenere un dizionario di quei valori
12551
- this.field.ValuePairs = GlobalService.stringToValuePairs(temp);
12552
- //this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);
12553
- }
12554
- else if (this.field.ValuePairs != null && this.field.ValuePairs.lenght > 0) {
12555
- // va bene così
12556
- }
12557
- else if (this.field.ValueString != null && this.field.ValueString != "") {
12558
- // va presa la strigna e rimappata nel diario
12559
- this.field.ValuePairs = GlobalService.stringToValuePairs(this.field.ValueString);
12560
- }
12561
- }
12562
- createArrayDataElement(key, value, imgUrl = null) {
12563
- let isOptionSelected;
12564
- if (this.field.IsMultiChoiche && this.record[this.field.Name] && this.record[this.field.Name].length > 0) {
12565
- isOptionSelected = !!this.record[this.field.Name].find(v => v == value);
12566
- }
12567
- else {
12568
- isOptionSelected = this.record[this.field.Name] === value;
12569
- }
12570
- this.arrayData.push({ Key: key, Value: value, Selected: isOptionSelected, ImgUrl: imgUrl });
12571
- }
12572
- createNumberArrayDataElement(key, value, imgUrl = null) {
12573
- let isOptionSelected;
12574
- if (this.field.IsMultiChoiche && this.record[this.field.Name] && this.record[this.field.Name].length > 0) {
12575
- isOptionSelected = !!this.record[this.field.Name].find(v => v == value);
12576
- }
12577
- else {
12578
- isOptionSelected = this.record[this.field.Name] === value;
12579
- }
12580
- this.arrayData.push({ Key: key, Value: value, Selected: isOptionSelected, ImgUrl: imgUrl });
12581
- }
12582
- }
12583
- ListValueTriggerTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ListValueTriggerTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
12584
- ListValueTriggerTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ListValueTriggerTemplateComponent, selector: "list-value-trigger-template", inputs: { field: "field", record: "record" }, outputs: { filterChange: "filterChange" }, ngImport: i0, template: "<div class=\"row\">\r\n <div class=\"col-md-6 valueCol\">\r\n <eqp-select [ngStyle]=\"FieldstyleObj\" [arrayData]=\"arrayData\"\r\n [arrayKeyProperty]=\"'Value'\" [showCancelButton]=\"true\" [arrayValueProperty]=\"'Key'\"\r\n [placeholder]=\"field.Description\"\r\n [includeFullObject]=\"false\" [isRequired]=\"false\" [isDisabled]=\"false\"\r\n [(ngModelInput)]=\"record[field.Name]\" [isMultiSelect]=\"false\"\r\n (ngModelInputChange)=\"onTriggerChange()\">\r\n </eqp-select>\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorListValue\" [(ngModel)]=\"selectedLogicOperator\" (ngModelChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"booleanLogicOperatorType\" [(ngModel)]=\"selectedBooleanLogicOperator\" (ngModelChange)=\"onTriggerChange()\"></eqp-select>\r\n </div> \r\n</div>", styles: [".valueCol{padding-right:0}.operatorCol{padding-left:0}::ng-deep .operatorCol .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:#a5afc0!important}::ng-deep .operatorCol .mat-mdc-select-value{color:#081c45;font-size:16px;font-weight:700;position:relative;top:-6px}::ng-deep eqp-select .mat-form-field-appearance-fill.ng-touched label.mdc-floating-label.mat-mdc-floating-label{background-color:transparent!important}\n"], dependencies: [{ kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2$1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i7.EqpSelectComponent, selector: "eqp-select", inputs: ["placeholder", "enumData", "enumDataToExclude", "arrayData", "arrayKeyProperty", "arrayValueProperty", "ngModelOptions", "ngModelInput", "formGroupInput", "formControlNameInput", "isRequired", "isDisabled", "isMultiLanguage", "multilanguagePrefixKey", "isAlphabeticalOrderable", "suffixIcon", "prefixIcon", "isMultiSelect", "includeFullObject", "showCancelButton", "isSearchable", "searchText", "noResultSearchText", "data"], outputs: ["ngModelInputChange"] }] });
12585
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ListValueTriggerTemplateComponent, decorators: [{
12586
- type: Component,
12587
- args: [{ selector: 'list-value-trigger-template', template: "<div class=\"row\">\r\n <div class=\"col-md-6 valueCol\">\r\n <eqp-select [ngStyle]=\"FieldstyleObj\" [arrayData]=\"arrayData\"\r\n [arrayKeyProperty]=\"'Value'\" [showCancelButton]=\"true\" [arrayValueProperty]=\"'Key'\"\r\n [placeholder]=\"field.Description\"\r\n [includeFullObject]=\"false\" [isRequired]=\"false\" [isDisabled]=\"false\"\r\n [(ngModelInput)]=\"record[field.Name]\" [isMultiSelect]=\"false\"\r\n (ngModelInputChange)=\"onTriggerChange()\">\r\n </eqp-select>\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorListValue\" [(ngModel)]=\"selectedLogicOperator\" (ngModelChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"booleanLogicOperatorType\" [(ngModel)]=\"selectedBooleanLogicOperator\" (ngModelChange)=\"onTriggerChange()\"></eqp-select>\r\n </div> \r\n</div>", styles: [".valueCol{padding-right:0}.operatorCol{padding-left:0}::ng-deep .operatorCol .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:#a5afc0!important}::ng-deep .operatorCol .mat-mdc-select-value{color:#081c45;font-size:16px;font-weight:700;position:relative;top:-6px}::ng-deep eqp-select .mat-form-field-appearance-fill.ng-touched label.mdc-floating-label.mat-mdc-floating-label{background-color:transparent!important}\n"] }]
12588
- }], ctorParameters: function () { return []; }, propDecorators: { field: [{
12589
- type: Input
12590
- }], record: [{
12591
- type: Input
12592
- }], filterChange: [{
12593
- type: Output
12594
- }] } });
12595
-
12596
12539
  class ListFormRecordTriggerTemplateComponent {
12597
12540
  constructor() {
12598
12541
  this.filterChange = new EventEmitter();