@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.
- package/esm2020/lib/components/private/form-records/add-form-record/add-form-record.component.mjs +26 -14
- package/esm2020/lib/components/private/trigger-creator/dynamic-module-trigger-fix/dynamic-module-trigger-fix.component.mjs +5 -4
- package/esm2020/lib/components/private/trigger-creator/trigger-templates/list-value-trigger-template/list-value-trigger-template.component.mjs +33 -105
- package/esm2020/lib/models/logicOperator.model.mjs +5 -3
- package/fesm2015/eqproject-eqp-dynamic-module.mjs +88 -145
- package/fesm2015/eqproject-eqp-dynamic-module.mjs.map +1 -1
- package/fesm2020/eqproject-eqp-dynamic-module.mjs +88 -145
- package/fesm2020/eqproject-eqp-dynamic-module.mjs.map +1 -1
- package/lib/components/private/trigger-creator/trigger-templates/list-value-trigger-template/list-value-trigger-template.component.d.ts +11 -27
- package/lib/models/logicOperator.model.d.ts +5 -3
- package/package.json +1 -1
|
@@ -1,138 +1,66 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
-
import {
|
|
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/
|
|
9
|
-
import * as i2 from "@
|
|
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.
|
|
14
|
-
this.
|
|
12
|
+
this.recordChange = new EventEmitter();
|
|
13
|
+
this.triggerChange = new EventEmitter();
|
|
15
14
|
this.logicOperatorListValue = LogicOperatorListValue;
|
|
16
|
-
this.
|
|
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.
|
|
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
|
-
|
|
36
|
-
|
|
37
|
-
this.
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
this.
|
|
41
|
-
this.
|
|
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.
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
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: {
|
|
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
|
|
131
|
-
}],
|
|
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
|
-
}],
|
|
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["
|
|
34
|
-
LogicOperatorListValue[LogicOperatorListValue["
|
|
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,
|
|
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["
|
|
1937
|
-
LogicOperatorListValue[LogicOperatorListValue["
|
|
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
|
-
|
|
5471
|
-
|
|
5472
|
-
|
|
5473
|
-
|
|
5474
|
-
|
|
5475
|
-
|
|
5476
|
-
|
|
5477
|
-
|
|
5478
|
-
|
|
5479
|
-
|
|
5480
|
-
|
|
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
|
-
|
|
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();
|