@eqproject/eqp-dynamic-module 2.6.3 → 2.6.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (44) hide show
  1. package/esm2020/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.mjs +9 -3
  2. package/esm2020/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.mjs +80 -3
  3. package/esm2020/lib/components/private/dynamic-module-field/dynamic-module-field.component.mjs +1 -1
  4. package/esm2020/lib/components/private/form-records/add-form-record/add-form-record.component.mjs +84 -4
  5. package/esm2020/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.mjs +13 -3
  6. package/esm2020/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.mjs +9 -3
  7. package/esm2020/lib/components/private/form-statistics/filter-form-statistic/filter-form-statistic.component.mjs +1 -1
  8. package/esm2020/lib/components/private/graphs/graphs.component.mjs +3 -3
  9. package/esm2020/lib/components/private/trigger-creator/dynamic-module-trigger-fix/dynamic-module-trigger-fix.component.mjs +68 -0
  10. package/esm2020/lib/components/private/trigger-creator/trigger-creator.component.mjs +142 -0
  11. package/esm2020/lib/components/private/trigger-creator/trigger-templates/boolean-trigger-template/boolean-trigger-template.component.mjs +86 -0
  12. package/esm2020/lib/components/private/trigger-creator/trigger-templates/date-trigger-template/date-trigger-template.component.mjs +86 -0
  13. package/esm2020/lib/components/private/trigger-creator/trigger-templates/list-form-record-trigger-template/list-form-record-trigger-template.component.mjs +60 -0
  14. package/esm2020/lib/components/private/trigger-creator/trigger-templates/list-value-trigger-template/list-value-trigger-template.component.mjs +136 -0
  15. package/esm2020/lib/components/private/trigger-creator/trigger-templates/numeric-trigger-template/numeric-trigger-template.component.mjs +102 -0
  16. package/esm2020/lib/components/private/trigger-creator/trigger-templates/text-trigger-template/text-trigger-template.component.mjs +116 -0
  17. package/esm2020/lib/components/private/trigger-creator/trigger-templates/textarea-trigger-template/textarea-trigger-template.component.mjs +116 -0
  18. package/esm2020/lib/eqp-dynamic-module.module.mjs +29 -2
  19. package/esm2020/lib/models/form.model.mjs +1 -1
  20. package/esm2020/lib/models/logicOperator.model.mjs +14 -1
  21. package/esm2020/lib/models/trigger.model.mjs +31 -0
  22. package/fesm2015/eqproject-eqp-dynamic-module.mjs +1228 -182
  23. package/fesm2015/eqproject-eqp-dynamic-module.mjs.map +1 -1
  24. package/fesm2020/eqproject-eqp-dynamic-module.mjs +1228 -182
  25. package/fesm2020/eqproject-eqp-dynamic-module.mjs.map +1 -1
  26. package/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.d.ts +4 -1
  27. package/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.d.ts +14 -1
  28. package/lib/components/private/form-records/add-form-record/add-form-record.component.d.ts +4 -1
  29. package/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.d.ts +4 -1
  30. package/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.d.ts +4 -1
  31. package/lib/components/private/trigger-creator/dynamic-module-trigger-fix/dynamic-module-trigger-fix.component.d.ts +42 -0
  32. package/lib/components/private/trigger-creator/trigger-creator.component.d.ts +34 -0
  33. package/lib/components/private/trigger-creator/trigger-templates/boolean-trigger-template/boolean-trigger-template.component.d.ts +34 -0
  34. package/lib/components/private/trigger-creator/trigger-templates/date-trigger-template/date-trigger-template.component.d.ts +34 -0
  35. package/lib/components/private/trigger-creator/trigger-templates/list-form-record-trigger-template/list-form-record-trigger-template.component.d.ts +24 -0
  36. package/lib/components/private/trigger-creator/trigger-templates/list-value-trigger-template/list-value-trigger-template.component.d.ts +50 -0
  37. package/lib/components/private/trigger-creator/trigger-templates/numeric-trigger-template/numeric-trigger-template.component.d.ts +37 -0
  38. package/lib/components/private/trigger-creator/trigger-templates/text-trigger-template/text-trigger-template.component.d.ts +41 -0
  39. package/lib/components/private/trigger-creator/trigger-templates/textarea-trigger-template/textarea-trigger-template.component.d.ts +41 -0
  40. package/lib/eqp-dynamic-module.module.d.ts +42 -33
  41. package/lib/models/form.model.d.ts +6 -0
  42. package/lib/models/logicOperator.model.d.ts +12 -0
  43. package/lib/models/trigger.model.d.ts +39 -0
  44. package/package.json +1 -1
@@ -0,0 +1,86 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { LogicOperatorBoolean } from '../../../../../models/logicOperator.model';
3
+ import { UtilityHelperService } from '../../../../../services/utilityHelper.services';
4
+ import { Condition, BooleanLogicOperatorType } from '../../../../../models/trigger.model';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/material/input";
7
+ import * as i2 from "@angular/material/form-field";
8
+ import * as i3 from "@angular/forms";
9
+ import * as i4 from "@angular/common";
10
+ import * as i5 from "@eqproject/eqp-select";
11
+ export class BooleanTriggerTemplateComponent {
12
+ constructor() {
13
+ this.triggerChange = new EventEmitter();
14
+ this.validatorsArray = [];
15
+ this.logicOperatorBoolean = LogicOperatorBoolean;
16
+ this.selectedLogicOperator = LogicOperatorBoolean.Si;
17
+ this.activeCondition = false;
18
+ this.booleanLogicOperatorType = BooleanLogicOperatorType;
19
+ this.selectedBooleanLogicOperator = BooleanLogicOperatorType.AND;
20
+ }
21
+ ngOnInit() {
22
+ this.field = this.condition.Field;
23
+ this.selectedBooleanLogicOperator = this.condition.booleanlogicoperator;
24
+ this.selectedLogicOperator = this.condition.logicoperator;
25
+ this.configureControllers();
26
+ this.initStyles();
27
+ }
28
+ //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html
29
+ initStyles() {
30
+ if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)
31
+ this.FieldstyleObj = UtilityHelperService.initStyles(this.field.FieldstyleCSS);
32
+ }
33
+ /**
34
+ * Metodo per emettere l'evento che il valore del record è cambiato.
35
+ */
36
+ onTriggerChange() {
37
+ let output = new Condition();
38
+ output = {
39
+ key: this.field.Name,
40
+ value: this.condition.record[this.field.Name],
41
+ logicoperator: this.selectedLogicOperator,
42
+ fieldType: this.field.FieldType,
43
+ booleanlogicoperator: this.selectedBooleanLogicOperator
44
+ };
45
+ this.triggerChange.emit(output);
46
+ }
47
+ /**
48
+ * Metodo per configurare eqp-numeric
49
+ */
50
+ // private configureEqpNumericOptions() {
51
+ // this.eqpNumericOptions.suffix = this.field.MeasureUnit ? " "+this.field.MeasureUnit+" " : "";
52
+ // this.eqpNumericOptions.prefix = this.field.CurrencySymbol ? this.field.CurrencySymbol+" " : "";
53
+ // this.eqpNumericOptions.inputMode = this.field.CurrencySymbol ? EqpNumericInputMode.FINANCIAL : EqpNumericInputMode.NATURAL;
54
+ // this.eqpNumericOptions.allowNegative=true;
55
+ // if (this.field.DecimalSeparator != null && this.field.DecimalSeparator != undefined)
56
+ // this.eqpNumericOptions.decimal = this.field.DecimalSeparator;
57
+ // else
58
+ // this.eqpNumericOptions.decimal=".";
59
+ // if (this.field.ThousandsSeparator != null && this.field.ThousandsSeparator != undefined)
60
+ // this.eqpNumericOptions.thousands = this.field.ThousandsSeparator;
61
+ // if(this.field.IsInteger== false){
62
+ // if (this.field.DecimalPrecision != null && this.field.DecimalPrecision != undefined) { this.eqpNumericOptions.precision = this.field.DecimalPrecision; }
63
+ // else { this.eqpNumericOptions.precision = 2; }
64
+ // }else{
65
+ // this.eqpNumericOptions.precision = 0;
66
+ // }
67
+ // }
68
+ /**
69
+ * Metodo di aggiunta dei validator dell'input
70
+ */
71
+ configureControllers() {
72
+ this.validatorsArray = [];
73
+ this.field.FormFormGroup.get([this.field.Name]).setValidators(this.validatorsArray);
74
+ }
75
+ }
76
+ BooleanTriggerTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BooleanTriggerTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
77
+ BooleanTriggerTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: BooleanTriggerTemplateComponent, selector: "boolean-trigger-template", inputs: { condition: "condition" }, outputs: { triggerChange: "triggerChange" }, ngImport: i0, template: "<div class=\"row\">\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorBoolean\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-6 valueCol\">\r\n <mat-form-field [formGroup]=\"field.FormFormGroup\">\r\n <mat-label class=\"pt-1 ps-3\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n <input [ngStyle]=\"FieldstyleObj\" matInput [formControlName]=\"field.Name\" [disabled] [readonly]=\"true\"\r\n [required]=\"false\" [(ngModel)]=\"this.condition.record[field.Name]\" \r\n />\r\n </mat-form-field>\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>\r\n", 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.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i5.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"] }] });
78
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BooleanTriggerTemplateComponent, decorators: [{
79
+ type: Component,
80
+ args: [{ selector: 'boolean-trigger-template', template: "<div class=\"row\">\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorBoolean\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-6 valueCol\">\r\n <mat-form-field [formGroup]=\"field.FormFormGroup\">\r\n <mat-label class=\"pt-1 ps-3\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n <input [ngStyle]=\"FieldstyleObj\" matInput [formControlName]=\"field.Name\" [disabled] [readonly]=\"true\"\r\n [required]=\"false\" [(ngModel)]=\"this.condition.record[field.Name]\" \r\n />\r\n </mat-form-field>\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>\r\n", 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"] }]
81
+ }], ctorParameters: function () { return []; }, propDecorators: { condition: [{
82
+ type: Input
83
+ }], triggerChange: [{
84
+ type: Output
85
+ }] } });
86
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"boolean-trigger-template.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/trigger-creator/trigger-templates/boolean-trigger-template/boolean-trigger-template.component.ts","../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/trigger-creator/trigger-templates/boolean-trigger-template/boolean-trigger-template.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvE,OAAO,EAAE,oBAAoB,EAAE,MAAM,2CAA2C,CAAC;AAEjF,OAAO,EAAE,oBAAoB,EAAE,MAAM,gDAAgD,CAAC;AACtF,OAAO,EAAoB,SAAS,EAAE,wBAAwB,EAAE,MAAM,qCAAqC,CAAC;;;;;;;AAM5G,MAAM,OAAO,+BAA+B;IAmB5C;QAhBY,kBAAa,GAAsB,IAAI,YAAY,EAAO,CAAC;QAIrE,oBAAe,GAAU,EAAE,CAAC;QAC5B,yBAAoB,GAAG,oBAAoB,CAAC;QAC5C,0BAAqB,GAAyB,oBAAoB,CAAC,EAAE,CAAC;QACtE,oBAAe,GAAY,KAAK,CAAC;QAEjC,6BAAwB,GAAG,wBAAwB,CAAC;QACpD,iCAA4B,GAA6B,wBAAwB,CAAC,GAAG,CAAC;IAOxF,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,KAAqB,CAAC;QAClD,IAAI,CAAC,4BAA4B,GAAG,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC;QACxE,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,SAAS,CAAC,aAAqC,CAAC;QAClF,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,UAAU,EAAE,CAAC;IAGpB,CAAC;IAEC,kFAAkF;IAClF,UAAU;QACR,IAAG,IAAI,CAAC,KAAK,CAAC,aAAa,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,IAAI,SAAS;YAC5E,IAAI,CAAC,aAAa,GAAE,oBAAoB,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;IAClF,CAAC;IAED;;MAEE;IACF,eAAe;QAEb,IAAI,MAAM,GAAa,IAAI,SAAS,EAAE,CAAC;QACvC,MAAM,GAAG;YACP,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI;YACpB,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;YAC7C,aAAa,EAAE,IAAI,CAAC,qBAAqB;YACzC,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS;YAC/B,oBAAoB,EAAE,IAAI,CAAC,4BAA4B;SACxD,CAAC;QAEF,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IAED;;MAEE;IACF,yCAAyC;IAEzC,oGAAoG;IACpG,oGAAoG;IACpG,gIAAgI;IAChI,+CAA+C;IAC/C,yFAAyF;IACzF,kEAAkE;IAClE,SAAS;IACT,wCAAwC;IACxC,6FAA6F;IAC7F,sEAAsE;IACtE,sCAAsC;IACtC,+JAA+J;IAC/J,qDAAqD;IACrD,WAAW;IACX,4CAA4C;IAC5C,MAAM;IACN,IAAI;IAEJ;;MAEE;IACM,oBAAoB;QAC1B,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;QAC1B,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACtF,CAAC;;6HApFY,+BAA+B;iHAA/B,+BAA+B,iJCV5C,++BAgBA;4FDNa,+BAA+B;kBAL3C,SAAS;+BACE,0BAA0B;0EAM3B,SAAS;sBAAjB,KAAK;gBACI,aAAa;sBAAtB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { LogicOperatorBoolean } from '../../../../../models/logicOperator.model';\r\nimport { BooleanField } from '../../../../../models/fields/booleanField.model';\r\nimport { UtilityHelperService } from '../../../../../services/utilityHelper.services';\r\nimport { TriggerCondition, Condition, BooleanLogicOperatorType } from '../../../../../models/trigger.model';\r\n@Component({\r\n  selector: 'boolean-trigger-template',\r\n  templateUrl: './boolean-trigger-template.component.html',\r\n  styleUrls: ['./boolean-trigger-template.component.scss']\r\n})\r\nexport class BooleanTriggerTemplateComponent {\r\n\r\n  @Input() condition: TriggerCondition;\r\n  @Output() triggerChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  field: BooleanField;\r\n\r\n  validatorsArray: any[] = [];\r\n  logicOperatorBoolean = LogicOperatorBoolean;\r\n  selectedLogicOperator: LogicOperatorBoolean = LogicOperatorBoolean.Si;\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\nconstructor() {\r\n}\r\n\r\nngOnInit(): void {\r\n  this.field = this.condition.Field as BooleanField;\r\n  this.selectedBooleanLogicOperator = this.condition.booleanlogicoperator;\r\n  this.selectedLogicOperator = this.condition.logicoperator as LogicOperatorBoolean;\r\n  this.configureControllers();\r\n  this.initStyles();\r\n\r\n\r\n}\r\n\r\n  //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html\r\n  initStyles() {\r\n    if(this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)   \r\n    this.FieldstyleObj= UtilityHelperService.initStyles(this.field.FieldstyleCSS);\r\n}\r\n\r\n/**\r\n* Metodo per emettere l'evento che il valore del record è cambiato.\r\n*/\r\nonTriggerChange() {\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.selectedLogicOperator,\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/**\r\n* Metodo per configurare eqp-numeric\r\n*/\r\n// private configureEqpNumericOptions() {\r\n\r\n//   this.eqpNumericOptions.suffix = this.field.MeasureUnit ? \"  \"+this.field.MeasureUnit+\"  \" : \"\";\r\n//   this.eqpNumericOptions.prefix = this.field.CurrencySymbol ? this.field.CurrencySymbol+\" \" : \"\";\r\n//   this.eqpNumericOptions.inputMode = this.field.CurrencySymbol ? EqpNumericInputMode.FINANCIAL : EqpNumericInputMode.NATURAL;\r\n//   this.eqpNumericOptions.allowNegative=true;\r\n//   if (this.field.DecimalSeparator != null && this.field.DecimalSeparator != undefined)\r\n//   this.eqpNumericOptions.decimal = this.field.DecimalSeparator;\r\n//   else\r\n//   this.eqpNumericOptions.decimal=\".\";\r\n//   if (this.field.ThousandsSeparator != null && this.field.ThousandsSeparator != undefined)\r\n//   this.eqpNumericOptions.thousands = this.field.ThousandsSeparator;\r\n//   if(this.field.IsInteger== false){\r\n//     if (this.field.DecimalPrecision != null && this.field.DecimalPrecision != undefined) { this.eqpNumericOptions.precision = this.field.DecimalPrecision; }\r\n//     else { this.eqpNumericOptions.precision = 2; }\r\n//   }else{\r\n//     this.eqpNumericOptions.precision = 0;\r\n//   }\r\n// }\r\n\r\n/**\r\n* Metodo di aggiunta dei validator dell'input\r\n*/\r\nprivate configureControllers() {\r\n  this.validatorsArray = [];\r\n  this.field.FormFormGroup.get([this.field.Name]).setValidators(this.validatorsArray);\r\n}\r\n}\r\n","<div class=\"row\">\r\n    <div class=\"col-md-3 operatorCol\">\r\n        <eqp-select [enumData]=\"logicOperatorBoolean\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n    </div>\r\n    <div class=\"col-md-6 valueCol\">\r\n        <mat-form-field [formGroup]=\"field.FormFormGroup\">\r\n            <mat-label  class=\"pt-1 ps-3\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n                    <input [ngStyle]=\"FieldstyleObj\" matInput [formControlName]=\"field.Name\" [disabled] [readonly]=\"true\"\r\n                            [required]=\"false\" [(ngModel)]=\"this.condition.record[field.Name]\"  \r\n                    />\r\n        </mat-form-field>\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>\r\n"]}
@@ -0,0 +1,86 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { DateTimeTypeEnum } from '../../../../../models/fields/dateField.model';
3
+ import { LogicOperatorDate } from '../../../../../models/logicOperator.model';
4
+ import { ModeEnum, TimeTypeEnum } from 'tmw-picker';
5
+ import { Condition, BooleanLogicOperatorType } from '../../../../../models/trigger.model';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@eqproject/eqp-select";
8
+ import * as i2 from "tmw-picker";
9
+ export class DateTriggerTemplateComponent {
10
+ constructor() {
11
+ this.triggerChange = new EventEmitter();
12
+ this.logicOperatorDate = LogicOperatorDate;
13
+ this.selectedLogicOperator = LogicOperatorDate['='];
14
+ this.activeCondition = false;
15
+ this.modes = ModeEnum;
16
+ this.timeType = TimeTypeEnum;
17
+ this.booleanLogicOperatorType = BooleanLogicOperatorType;
18
+ this.selectedBooleanLogicOperator = BooleanLogicOperatorType.AND;
19
+ this.outputFormat = null;
20
+ }
21
+ ngOnInit() {
22
+ this.field = this.condition.Field;
23
+ this.selectedBooleanLogicOperator = this.condition.booleanlogicoperator;
24
+ this.selectedLogicOperator = this.condition.logicoperator;
25
+ this.setTimeType();
26
+ this.setOutputFormat();
27
+ }
28
+ /**
29
+ * In base al formato della data richiesta nel DateField (solo data, solo orario o data e ora)
30
+ * imposta la visualizzazione corretta del componente eqp-datetimepicker.
31
+ */
32
+ setTimeType() {
33
+ switch (this.field.IsOnlyDate) {
34
+ case DateTimeTypeEnum["Solo data"]:
35
+ this.mode = ModeEnum.DATEPICKER;
36
+ break;
37
+ case DateTimeTypeEnum["Solo orario"]:
38
+ this.mode = ModeEnum.TIMEPICKER;
39
+ break;
40
+ case DateTimeTypeEnum["Data e ora"]:
41
+ this.mode = ModeEnum.DATETIMEPICKER;
42
+ break;
43
+ }
44
+ }
45
+ /**
46
+ * Metodo per emettere l'evento che il valore del record è cambiato.
47
+ */
48
+ onTriggerChange() {
49
+ let output = new Condition();
50
+ output = {
51
+ key: this.field.Name,
52
+ value: this.condition.record[this.field.Name],
53
+ logicoperator: this.selectedLogicOperator,
54
+ fieldType: this.field.FieldType,
55
+ booleanlogicoperator: this.selectedBooleanLogicOperator
56
+ };
57
+ this.triggerChange.emit(output);
58
+ }
59
+ setOutputFormat() {
60
+ if (this.outputFormat != null) {
61
+ this.outputFormat = this.field.DateFormat;
62
+ }
63
+ else {
64
+ if (this.field.IsOnlyDate == DateTimeTypeEnum['Solo data']) {
65
+ this.outputFormat = 'DD/MM/YYYY';
66
+ }
67
+ if (this.field.IsOnlyDate == DateTimeTypeEnum['Data e ora']) {
68
+ this.outputFormat = 'DD/MM/YYYY HH:mm';
69
+ }
70
+ if (this.field.IsOnlyDate == DateTimeTypeEnum['Solo orario']) {
71
+ this.outputFormat = 'HH:mm';
72
+ }
73
+ }
74
+ }
75
+ }
76
+ DateTriggerTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateTriggerTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
77
+ DateTriggerTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DateTriggerTemplateComponent, selector: "date-trigger-template", inputs: { condition: "condition" }, outputs: { triggerChange: "triggerChange" }, ngImport: i0, template: "<div class=\"row\">\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorDate\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-6 valueCol\">\r\n <tmw-datetimepicker [placeholder]=\"field.Description\" [label]=\"field.Description\" [pickerMode]=\"mode\"\r\n [minDate]=\"field.MinDate ? field.MinDate : null\" [maxDate]=\"field.MaxDate ? field.MaxDate : null\"\r\n [(ngModelInput)]=\"this.condition.record[field.Name]\" (ngModelInputChange)=\"onTriggerChange()\" [outputFormat]=\"outputFormat\" >\r\n </tmw-datetimepicker>\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: "component", type: i1.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"] }, { kind: "component", type: i2.TmwDateTimePickerComponent, selector: "tmw-datetimepicker", inputs: ["debugMode", "ngModelInput", "formGroupInput", "formControlNameInput", "pickerMode", "timeType", "label", "placeholder", "hint", "minDate", "maxDate", "locale", "inputFormat", "outputFormat", "forSaveLocalOnDB", "disabled", "readonly", "currentDateAsDefault", "showSpinners", "touchUi", "enableMeridian", "hideTime", "stepHour", "showHours", "hourLabel", "stepMinute", "showMinutes", "minuteLabel", "stepSecond", "showSeconds", "secondLabel", "disableMinute", "dayLabel", "monthLabel", "yearLabel", "highLightedDates", "highLightedAriaFormat"], outputs: ["ngModelInputChange"] }] });
78
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateTriggerTemplateComponent, decorators: [{
79
+ type: Component,
80
+ args: [{ selector: 'date-trigger-template', template: "<div class=\"row\">\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorDate\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-6 valueCol\">\r\n <tmw-datetimepicker [placeholder]=\"field.Description\" [label]=\"field.Description\" [pickerMode]=\"mode\"\r\n [minDate]=\"field.MinDate ? field.MinDate : null\" [maxDate]=\"field.MaxDate ? field.MaxDate : null\"\r\n [(ngModelInput)]=\"this.condition.record[field.Name]\" (ngModelInputChange)=\"onTriggerChange()\" [outputFormat]=\"outputFormat\" >\r\n </tmw-datetimepicker>\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"] }]
81
+ }], ctorParameters: function () { return []; }, propDecorators: { condition: [{
82
+ type: Input
83
+ }], triggerChange: [{
84
+ type: Output
85
+ }] } });
86
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-trigger-template.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/trigger-creator/trigger-templates/date-trigger-template/date-trigger-template.component.ts","../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/trigger-creator/trigger-templates/date-trigger-template/date-trigger-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { DateField, DateTimeTypeEnum } from '../../../../../models/fields/dateField.model';\r\nimport { LogicOperatorDate } from '../../../../../models/logicOperator.model';\r\nimport { ModeEnum, TimeTypeEnum } from 'tmw-picker';\r\nimport { TriggerCondition, Condition, BooleanLogicOperatorType } from '../../../../../models/trigger.model';\r\n\r\n@Component({\r\n  selector: 'date-trigger-template',\r\n  templateUrl: './date-trigger-template.component.html',\r\n  styleUrls: ['./date-trigger-template.component.scss']\r\n})\r\nexport class DateTriggerTemplateComponent {\r\n\r\n  @Input() condition: TriggerCondition;\r\n  @Output() triggerChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  field: DateField;\r\n\r\n  logicOperatorDate = LogicOperatorDate;\r\n  selectedLogicOperator: LogicOperatorDate = LogicOperatorDate['='];\r\n  activeCondition: boolean = false;  \r\n\r\n  modes = ModeEnum;\r\n  timeType = TimeTypeEnum;\r\n  mode: ModeEnum;\r\n\r\n  booleanLogicOperatorType = BooleanLogicOperatorType;\r\n  selectedBooleanLogicOperator: BooleanLogicOperatorType = BooleanLogicOperatorType.AND;\r\n\r\n  outputFormat: string = null;\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.field = this.condition.Field as DateField;\r\n    this.selectedBooleanLogicOperator = this.condition.booleanlogicoperator;\r\n    this.selectedLogicOperator = this.condition.logicoperator as LogicOperatorDate;\r\n    this.setTimeType();\r\n    this.setOutputFormat();\r\n  }\r\n\r\n  /**\r\n   * In base al formato della data richiesta nel DateField (solo data, solo orario o data e ora)\r\n   * imposta la visualizzazione corretta del componente eqp-datetimepicker.\r\n   */\r\n  private setTimeType() {\r\n    switch (this.field.IsOnlyDate) {\r\n      case DateTimeTypeEnum[\"Solo data\"]:\r\n        this.mode = ModeEnum.DATEPICKER;\r\n        break;\r\n      case DateTimeTypeEnum[\"Solo orario\"]:\r\n        this.mode = ModeEnum.TIMEPICKER;\r\n        break;\r\n      case DateTimeTypeEnum[\"Data e ora\"]:\r\n        this.mode = ModeEnum.DATETIMEPICKER;\r\n        break;\r\n    }\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\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.selectedLogicOperator,\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\nsetOutputFormat(){\r\n  if (this.outputFormat != null){\r\n    this.outputFormat = this.field.DateFormat;  \r\n  } else {\r\n    if (this.field.IsOnlyDate == DateTimeTypeEnum['Solo data']){\r\n      this.outputFormat = 'DD/MM/YYYY';\r\n    }\r\n    if (this.field.IsOnlyDate == DateTimeTypeEnum['Data e ora']){\r\n      this.outputFormat = 'DD/MM/YYYY HH:mm';\r\n    }      \r\n    if (this.field.IsOnlyDate == DateTimeTypeEnum['Solo orario']){\r\n      this.outputFormat = 'HH:mm';\r\n    }          \r\n  }\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]=\"logicOperatorDate\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n    </div>\r\n    <div class=\"col-md-6 valueCol\">\r\n        <tmw-datetimepicker  [placeholder]=\"field.Description\" [label]=\"field.Description\" [pickerMode]=\"mode\"\r\n        [minDate]=\"field.MinDate ? field.MinDate : null\" [maxDate]=\"field.MaxDate ? field.MaxDate : null\"\r\n        [(ngModelInput)]=\"this.condition.record[field.Name]\" (ngModelInputChange)=\"onTriggerChange()\" [outputFormat]=\"outputFormat\" >\r\n        </tmw-datetimepicker>\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>"]}
@@ -0,0 +1,60 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { LogicOperatorText } from '../../../../../models/logicOperator.model';
3
+ import { Statistic } from '../../../../../models/statistic.model';
4
+ import { BooleanLogicOperatorType } from '../../../../../models/trigger.model';
5
+ import * as i0 from "@angular/core";
6
+ export class ListFormRecordTriggerTemplateComponent {
7
+ constructor() {
8
+ this.filterChange = new EventEmitter();
9
+ this.logicOperatorText = LogicOperatorText;
10
+ this.activeCondition = false;
11
+ this.booleanLogicOperatorType = BooleanLogicOperatorType;
12
+ this.selectedBooleanLogicOperator = BooleanLogicOperatorType.AND;
13
+ }
14
+ onTriggerChange() {
15
+ if (this.record[this.field.Name] != null && this.record[this.field.Name] != "" && this.selectedLogicOperator != null) {
16
+ this.activeCondition = true;
17
+ this.filterChange.emit(this.generateCondition("active"));
18
+ }
19
+ if (this.activeCondition && (this.record[this.field.Name] == null || this.record[this.field.Name] == "" || this.selectedLogicOperator == null)) {
20
+ this.activeCondition = false;
21
+ this.filterChange.emit(this.generateCondition("deactivated"));
22
+ }
23
+ }
24
+ /**
25
+ * Metodo che genera l'oggetto da inviare all'esterno
26
+ */
27
+ generateCondition(mode) {
28
+ let output = new Statistic();
29
+ if (mode == "active") {
30
+ output = {
31
+ key: this.field.Name,
32
+ value: this.record[this.field.Name],
33
+ logicoperator: this.selectedLogicOperator,
34
+ fieldtype: this.field.FieldType
35
+ };
36
+ }
37
+ else {
38
+ output = {
39
+ key: this.field.Name,
40
+ value: null,
41
+ logicoperator: null,
42
+ fieldtype: null
43
+ };
44
+ }
45
+ return output;
46
+ }
47
+ }
48
+ ListFormRecordTriggerTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ListFormRecordTriggerTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
49
+ ListFormRecordTriggerTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ListFormRecordTriggerTemplateComponent, selector: "list-form-record-trigger-template", inputs: { field: "field", record: "record" }, outputs: { filterChange: "filterChange" }, ngImport: i0, template: "", styles: [""] });
50
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ListFormRecordTriggerTemplateComponent, decorators: [{
51
+ type: Component,
52
+ args: [{ selector: 'list-form-record-trigger-template', template: "" }]
53
+ }], propDecorators: { field: [{
54
+ type: Input
55
+ }], record: [{
56
+ type: Input
57
+ }], filterChange: [{
58
+ type: Output
59
+ }] } });
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1mb3JtLXJlY29yZC10cmlnZ2VyLXRlbXBsYXRlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VxcC1keW5hbWljLW1vZHVsZS9zcmMvbGliL2NvbXBvbmVudHMvcHJpdmF0ZS90cmlnZ2VyLWNyZWF0b3IvdHJpZ2dlci10ZW1wbGF0ZXMvbGlzdC1mb3JtLXJlY29yZC10cmlnZ2VyLXRlbXBsYXRlL2xpc3QtZm9ybS1yZWNvcmQtdHJpZ2dlci10ZW1wbGF0ZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lcXAtZHluYW1pYy1tb2R1bGUvc3JjL2xpYi9jb21wb25lbnRzL3ByaXZhdGUvdHJpZ2dlci1jcmVhdG9yL3RyaWdnZXItdGVtcGxhdGVzL2xpc3QtZm9ybS1yZWNvcmQtdHJpZ2dlci10ZW1wbGF0ZS9saXN0LWZvcm0tcmVjb3JkLXRyaWdnZXItdGVtcGxhdGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUU5RSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFFbEUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0scUNBQXFDLENBQUM7O0FBTy9FLE1BQU0sT0FBTyxzQ0FBc0M7SUFMbkQ7UUFTWSxpQkFBWSxHQUFzQixJQUFJLFlBQVksRUFBTyxDQUFDO1FBQ3BFLHNCQUFpQixHQUFHLGlCQUFpQixDQUFDO1FBRXRDLG9CQUFlLEdBQVksS0FBSyxDQUFDO1FBRWpDLDZCQUF3QixHQUFHLHdCQUF3QixDQUFDO1FBQ3BELGlDQUE0QixHQUE2Qix3QkFBd0IsQ0FBQyxHQUFHLENBQUM7S0FzQ3ZGO0lBcENDLGVBQWU7UUFDYixJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsSUFBSSxJQUFJLENBQUMscUJBQXFCLElBQUksSUFBSSxFQUFDO1lBQ25ILElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDO1lBQzVCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO1NBQzFEO1FBQ0QsSUFBSSxJQUFJLENBQUMsZUFBZSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxJQUFJLElBQUksQ0FBQyxxQkFBcUIsSUFBSSxJQUFJLENBQUMsRUFBQztZQUM3SSxJQUFJLENBQUMsZUFBZSxHQUFHLEtBQUssQ0FBQztZQUM3QixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztTQUMvRDtJQUNILENBQUM7SUFFSDs7T0FFRztJQUVELGlCQUFpQixDQUFDLElBQUk7UUFDcEIsSUFBSSxNQUFNLEdBQWEsSUFBSSxTQUFTLEVBQUUsQ0FBQztRQUN2QyxJQUFJLElBQUksSUFBSSxRQUFRLEVBQUM7WUFDbkIsTUFBTSxHQUFHO2dCQUNQLEdBQUcsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUk7Z0JBQ3BCLEtBQUssRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDO2dCQUNuQyxhQUFhLEVBQUUsSUFBSSxDQUFDLHFCQUFxQjtnQkFDekMsU0FBUyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUzthQUNoQyxDQUFDO1NBQ0g7YUFBTTtZQUNMLE1BQU0sR0FBRztnQkFDUCxHQUFHLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJO2dCQUNwQixLQUFLLEVBQUUsSUFBSTtnQkFDWCxhQUFhLEVBQUUsSUFBSTtnQkFDbkIsU0FBUyxFQUFFLElBQUk7YUFDaEIsQ0FBQztTQUNIO1FBRUQsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQzs7b0lBOUNVLHNDQUFzQzt3SEFBdEMsc0NBQXNDLGtLQ1puRCxFQUFBOzRGRFlhLHNDQUFzQztrQkFMbEQsU0FBUzsrQkFDRSxtQ0FBbUM7OEJBTXBDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0ksWUFBWTtzQkFBckIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IExvZ2ljT3BlcmF0b3JUZXh0IH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vbW9kZWxzL2xvZ2ljT3BlcmF0b3IubW9kZWwnO1xyXG5pbXBvcnQgeyBSZWNvcmQgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi9tb2RlbHMvcmVjb3JkLm1vZGVsJztcclxuaW1wb3J0IHsgU3RhdGlzdGljIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vbW9kZWxzL3N0YXRpc3RpYy5tb2RlbCc7XHJcbmltcG9ydCB7IFRleHRGaWVsZCB9IGZyb20gJy4uLy4uLy4uLy4uLy4uL21vZGVscy9maWVsZHMvdGV4dEZpZWxkLm1vZGVsJztcclxuaW1wb3J0IHsgQm9vbGVhbkxvZ2ljT3BlcmF0b3JUeXBlIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vbW9kZWxzL3RyaWdnZXIubW9kZWwnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdsaXN0LWZvcm0tcmVjb3JkLXRyaWdnZXItdGVtcGxhdGUnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9saXN0LWZvcm0tcmVjb3JkLXRyaWdnZXItdGVtcGxhdGUuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2xpc3QtZm9ybS1yZWNvcmQtdHJpZ2dlci10ZW1wbGF0ZS5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMaXN0Rm9ybVJlY29yZFRyaWdnZXJUZW1wbGF0ZUNvbXBvbmVudCB7XHJcblxyXG4gIEBJbnB1dCgpIGZpZWxkOiBUZXh0RmllbGQ7XHJcbiAgQElucHV0KCkgcmVjb3JkOiBSZWNvcmQ7XHJcbiAgQE91dHB1dCgpIGZpbHRlckNoYW5nZTogRXZlbnRFbWl0dGVyPGFueT4gPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcclxuICBsb2dpY09wZXJhdG9yVGV4dCA9IExvZ2ljT3BlcmF0b3JUZXh0O1xyXG4gIHNlbGVjdGVkTG9naWNPcGVyYXRvcjogTG9naWNPcGVyYXRvclRleHQ7XHJcbiAgYWN0aXZlQ29uZGl0aW9uOiBib29sZWFuID0gZmFsc2U7ICBcclxuXHJcbiAgYm9vbGVhbkxvZ2ljT3BlcmF0b3JUeXBlID0gQm9vbGVhbkxvZ2ljT3BlcmF0b3JUeXBlO1xyXG4gIHNlbGVjdGVkQm9vbGVhbkxvZ2ljT3BlcmF0b3I6IEJvb2xlYW5Mb2dpY09wZXJhdG9yVHlwZSA9IEJvb2xlYW5Mb2dpY09wZXJhdG9yVHlwZS5BTkQ7XHJcblxyXG4gIG9uVHJpZ2dlckNoYW5nZSgpIHtcclxuICAgIGlmICh0aGlzLnJlY29yZFt0aGlzLmZpZWxkLk5hbWVdICE9IG51bGwgJiYgdGhpcy5yZWNvcmRbdGhpcy5maWVsZC5OYW1lXSAhPSBcIlwiICYmIHRoaXMuc2VsZWN0ZWRMb2dpY09wZXJhdG9yICE9IG51bGwpe1xyXG4gICAgICB0aGlzLmFjdGl2ZUNvbmRpdGlvbiA9IHRydWU7XHJcbiAgICAgIHRoaXMuZmlsdGVyQ2hhbmdlLmVtaXQodGhpcy5nZW5lcmF0ZUNvbmRpdGlvbihcImFjdGl2ZVwiKSk7XHJcbiAgICB9XHJcbiAgICBpZiAodGhpcy5hY3RpdmVDb25kaXRpb24gJiYgKHRoaXMucmVjb3JkW3RoaXMuZmllbGQuTmFtZV0gPT0gbnVsbCB8fCB0aGlzLnJlY29yZFt0aGlzLmZpZWxkLk5hbWVdID09IFwiXCIgfHwgdGhpcy5zZWxlY3RlZExvZ2ljT3BlcmF0b3IgPT0gbnVsbCkpe1xyXG4gICAgICB0aGlzLmFjdGl2ZUNvbmRpdGlvbiA9IGZhbHNlO1xyXG4gICAgICB0aGlzLmZpbHRlckNoYW5nZS5lbWl0KHRoaXMuZ2VuZXJhdGVDb25kaXRpb24oXCJkZWFjdGl2YXRlZFwiKSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuLyoqXHJcbiAqIE1ldG9kbyBjaGUgZ2VuZXJhIGwnb2dnZXR0byBkYSBpbnZpYXJlIGFsbCdlc3Rlcm5vXHJcbiAqL1xyXG5cclxuICBnZW5lcmF0ZUNvbmRpdGlvbihtb2RlKXtcclxuICAgIGxldCBvdXRwdXQ6U3RhdGlzdGljID0gbmV3IFN0YXRpc3RpYygpO1xyXG4gICAgaWYgKG1vZGUgPT0gXCJhY3RpdmVcIil7XHJcbiAgICAgIG91dHB1dCA9IHtcclxuICAgICAgICBrZXk6IHRoaXMuZmllbGQuTmFtZSxcclxuICAgICAgICB2YWx1ZTogdGhpcy5yZWNvcmRbdGhpcy5maWVsZC5OYW1lXSxcclxuICAgICAgICBsb2dpY29wZXJhdG9yOiB0aGlzLnNlbGVjdGVkTG9naWNPcGVyYXRvcixcclxuICAgICAgICBmaWVsZHR5cGU6IHRoaXMuZmllbGQuRmllbGRUeXBlXHJcbiAgICAgIH07XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICBvdXRwdXQgPSB7XHJcbiAgICAgICAga2V5OiB0aGlzLmZpZWxkLk5hbWUsXHJcbiAgICAgICAgdmFsdWU6IG51bGwsXHJcbiAgICAgICAgbG9naWNvcGVyYXRvcjogbnVsbCxcclxuICAgICAgICBmaWVsZHR5cGU6IG51bGxcclxuICAgICAgfTtcclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gb3V0cHV0O1xyXG4gIH0gIFxyXG5cclxufVxyXG4iLCIiXX0=
@@ -0,0 +1,136 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { LogicOperatorListValue } from '../../../../../models/logicOperator.model';
3
+ import { Statistic } from '../../../../../models/statistic.model';
4
+ import { UtilityHelperService } from '../../../../../services/utilityHelper.services';
5
+ import { GlobalService } from '../../../../../services/global.service';
6
+ import { BooleanLogicOperatorType } from '../../../../../models/trigger.model';
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";
11
+ export class ListValueTriggerTemplateComponent {
12
+ constructor() {
13
+ this.filterChange = new EventEmitter();
14
+ this.validatorsArray = [];
15
+ this.logicOperatorListValue = LogicOperatorListValue;
16
+ this.activeCondition = false;
17
+ this.booleanLogicOperatorType = BooleanLogicOperatorType;
18
+ this.selectedBooleanLogicOperator = BooleanLogicOperatorType.AND;
19
+ this.arrayData = [];
20
+ }
21
+ ngOnInit() {
22
+ this.configureControllers();
23
+ this.initStyles();
24
+ this.setArrayData();
25
+ }
26
+ //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html
27
+ initStyles() {
28
+ if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)
29
+ this.FieldstyleObj = UtilityHelperService.initStyles(this.field.FieldstyleCSS);
30
+ }
31
+ /**
32
+ * Metodo per emettere l'evento che il valore del record è cambiato.
33
+ */
34
+ 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);
73
+ }
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
+ setArrayData() {
78
+ this.prepareValuePairs();
79
+ if (UtilityHelperService.isNumeric(this.field.ValuePairs[Object.keys(this.field.ValuePairs)[0]])) {
80
+ Object.keys(this.field.ValuePairs).forEach(k => this.createNumberArrayDataElement(k, Number(this.field.ValuePairs[k])));
81
+ }
82
+ else {
83
+ Object.keys(this.field.ValuePairs).forEach(k => this.createArrayDataElement(k, this.field.ValuePairs[k]));
84
+ }
85
+ }
86
+ prepareValuePairs() {
87
+ if (this.field.Formula) {
88
+ this.field.ValuePairs = {};
89
+ const temp = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);
90
+ // temp dovrebbe essere una stringa del tipo "chiave1! valore 1 ; chiave2 | valore 2 "
91
+ // dobbiamo ottenere un dizionario di quei valori
92
+ this.field.ValuePairs = GlobalService.stringToValuePairs(temp);
93
+ //this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);
94
+ }
95
+ else if (this.field.ValuePairs != null && this.field.ValuePairs.lenght > 0) {
96
+ // va bene così
97
+ }
98
+ else if (this.field.ValueString != null && this.field.ValueString != "") {
99
+ // va presa la strigna e rimappata nel diario
100
+ this.field.ValuePairs = GlobalService.stringToValuePairs(this.field.ValueString);
101
+ }
102
+ }
103
+ createArrayDataElement(key, value, imgUrl = null) {
104
+ let isOptionSelected;
105
+ if (this.field.IsMultiChoiche && this.record[this.field.Name] && this.record[this.field.Name].length > 0) {
106
+ isOptionSelected = !!this.record[this.field.Name].find(v => v == value);
107
+ }
108
+ else {
109
+ isOptionSelected = this.record[this.field.Name] === value;
110
+ }
111
+ this.arrayData.push({ Key: key, Value: value, Selected: isOptionSelected, ImgUrl: imgUrl });
112
+ }
113
+ createNumberArrayDataElement(key, value, imgUrl = null) {
114
+ let isOptionSelected;
115
+ if (this.field.IsMultiChoiche && this.record[this.field.Name] && this.record[this.field.Name].length > 0) {
116
+ isOptionSelected = !!this.record[this.field.Name].find(v => v == value);
117
+ }
118
+ else {
119
+ isOptionSelected = this.record[this.field.Name] === value;
120
+ }
121
+ this.arrayData.push({ Key: key, Value: value, Selected: isOptionSelected, ImgUrl: imgUrl });
122
+ }
123
+ }
124
+ ListValueTriggerTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ListValueTriggerTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
125
+ 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"] }] });
126
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ListValueTriggerTemplateComponent, decorators: [{
127
+ type: Component,
128
+ 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"] }]
129
+ }], ctorParameters: function () { return []; }, propDecorators: { field: [{
130
+ type: Input
131
+ }], record: [{
132
+ type: Input
133
+ }], filterChange: [{
134
+ type: Output
135
+ }] } });
136
+ //# 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 (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  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>"]}