@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,102 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { Validators } from '@angular/forms';
3
+ import { EqpNumericInputMode } from '@eqproject/eqp-numeric';
4
+ import { UtilityHelperService } from '../../../../../services/utilityHelper.services';
5
+ import { LogicOperatorNumeric } from '../../../../../models/logicOperator.model';
6
+ import { BooleanLogicOperatorType, Condition } from '../../../../../models/trigger.model';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/material/input";
9
+ import * as i2 from "@angular/material/form-field";
10
+ import * as i3 from "@angular/forms";
11
+ import * as i4 from "@angular/common";
12
+ import * as i5 from "@eqproject/eqp-select";
13
+ import * as i6 from "@eqproject/eqp-numeric";
14
+ export class NumericTriggerTemplateComponent {
15
+ constructor() {
16
+ this.triggerChange = new EventEmitter();
17
+ this.validatorsArray = [];
18
+ this.eqpNumericOptions = {};
19
+ this.logicOperatorNumeric = LogicOperatorNumeric;
20
+ this.selectedLogicOperator = LogicOperatorNumeric['='];
21
+ this.activeCondition = false;
22
+ this.booleanLogicOperatorType = BooleanLogicOperatorType;
23
+ this.selectedBooleanLogicOperator = BooleanLogicOperatorType.AND;
24
+ }
25
+ ngOnInit() {
26
+ this.field = this.condition.Field;
27
+ this.selectedBooleanLogicOperator = this.condition.booleanlogicoperator;
28
+ this.selectedLogicOperator = this.condition.logicoperator;
29
+ this.configureEqpNumericOptions();
30
+ this.configureControllers();
31
+ this.initStyles();
32
+ }
33
+ //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html
34
+ initStyles() {
35
+ if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)
36
+ this.FieldstyleObj = UtilityHelperService.initStyles(this.field.FieldstyleCSS);
37
+ if (this.field.LabelstyleCSS != null || this.field.LabelstyleCSS != undefined)
38
+ this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);
39
+ }
40
+ /**
41
+ * Metodo per emettere l'evento che il valore del record è cambiato.
42
+ */
43
+ onTriggerChange() {
44
+ let output = new Condition();
45
+ output = {
46
+ key: this.field.Name,
47
+ value: this.condition.record[this.field.Name],
48
+ logicoperator: this.selectedLogicOperator,
49
+ fieldType: this.field.FieldType,
50
+ booleanlogicoperator: this.selectedBooleanLogicOperator
51
+ };
52
+ this.triggerChange.emit(output);
53
+ }
54
+ /**
55
+ * Metodo per configurare eqp-numeric
56
+ */
57
+ configureEqpNumericOptions() {
58
+ this.eqpNumericOptions.suffix = this.field.MeasureUnit ? " " + this.field.MeasureUnit + " " : "";
59
+ this.eqpNumericOptions.prefix = this.field.CurrencySymbol ? this.field.CurrencySymbol + " " : "";
60
+ this.eqpNumericOptions.inputMode = this.field.CurrencySymbol ? EqpNumericInputMode.FINANCIAL : EqpNumericInputMode.NATURAL;
61
+ this.eqpNumericOptions.allowNegative = true;
62
+ if (this.field.DecimalSeparator != null && this.field.DecimalSeparator != undefined)
63
+ this.eqpNumericOptions.decimal = this.field.DecimalSeparator;
64
+ else
65
+ this.eqpNumericOptions.decimal = ".";
66
+ if (this.field.ThousandsSeparator != null && this.field.ThousandsSeparator != undefined)
67
+ this.eqpNumericOptions.thousands = this.field.ThousandsSeparator;
68
+ if (this.field.IsInteger == false) {
69
+ if (this.field.DecimalPrecision != null && this.field.DecimalPrecision != undefined) {
70
+ this.eqpNumericOptions.precision = this.field.DecimalPrecision;
71
+ }
72
+ else {
73
+ this.eqpNumericOptions.precision = 2;
74
+ }
75
+ }
76
+ else {
77
+ this.eqpNumericOptions.precision = 0;
78
+ }
79
+ }
80
+ /**
81
+ * Metodo di aggiunta dei validator dell'input
82
+ */
83
+ configureControllers() {
84
+ this.validatorsArray = [];
85
+ if (this.field.MinValue != null && this.field.MinValue != undefined)
86
+ this.validatorsArray.push(Validators.min(this.field.MinValue));
87
+ if (this.field.MaxValue != null && this.field.MaxValue != undefined)
88
+ this.validatorsArray.push(Validators.max(this.field.MaxValue));
89
+ this.field.FormFormGroup.get([this.field.Name]).setValidators(this.validatorsArray);
90
+ }
91
+ }
92
+ NumericTriggerTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: NumericTriggerTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
93
+ NumericTriggerTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: NumericTriggerTemplateComponent, selector: "numeric-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]=\"logicOperatorNumeric\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-6 valueCol\">\r\n <mat-form-field>\r\n <mat-label class=\"pt-1\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n <input [ngStyle]=\"FieldstyleObj\" matInput eqpNumericMask [readonly]=\"false\"\r\n [required]=\"false\" [(ngModel)]=\"this.condition.record[field.Name]\" [options]=\"eqpNumericOptions\"\r\n [step]=\"field.IsInteger ? 1 : null\" (ngModelChange)=\"onTriggerChange()\" />\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>", 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.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { 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"] }, { kind: "directive", type: i6.EqpNumericDirective, selector: "[eqpNumericMask]", inputs: ["options"] }] });
94
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: NumericTriggerTemplateComponent, decorators: [{
95
+ type: Component,
96
+ args: [{ selector: 'numeric-trigger-template', template: "<div class=\"row\">\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorNumeric\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-6 valueCol\">\r\n <mat-form-field>\r\n <mat-label class=\"pt-1\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n <input [ngStyle]=\"FieldstyleObj\" matInput eqpNumericMask [readonly]=\"false\"\r\n [required]=\"false\" [(ngModel)]=\"this.condition.record[field.Name]\" [options]=\"eqpNumericOptions\"\r\n [step]=\"field.IsInteger ? 1 : null\" (ngModelChange)=\"onTriggerChange()\" />\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>", 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"] }]
97
+ }], ctorParameters: function () { return []; }, propDecorators: { condition: [{
98
+ type: Input
99
+ }], triggerChange: [{
100
+ type: Output
101
+ }] } });
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"numeric-trigger-template.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/trigger-creator/trigger-templates/numeric-trigger-template/numeric-trigger-template.component.ts","../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/trigger-creator/trigger-templates/numeric-trigger-template/numeric-trigger-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { Validators } from '@angular/forms';\r\nimport { EqpNumericInputMode, NumericMaskConfig } from '@eqproject/eqp-numeric';\r\nimport { UtilityHelperService } from '../../../../../services/utilityHelper.services';\r\nimport { NumericField } from '../../../../../models/fields/numericField.model';\r\nimport { LogicOperatorNumeric } from '../../../../../models/logicOperator.model';\r\nimport { TriggerCondition, BooleanLogicOperatorType, Condition } from '../../../../../models/trigger.model';\r\n\r\n@Component({\r\n  selector: 'numeric-trigger-template',\r\n  templateUrl: './numeric-trigger-template.component.html',\r\n  styleUrls: ['./numeric-trigger-template.component.scss']\r\n})\r\nexport class NumericTriggerTemplateComponent implements OnInit {\r\n\r\n  @Input() condition: TriggerCondition;\r\n  @Output() triggerChange: EventEmitter<any> = new EventEmitter<any>();\r\n  validatorsArray: any[] = [];\r\n  eqpNumericOptions: Partial<NumericMaskConfig> = {};\r\n  logicOperatorNumeric = LogicOperatorNumeric;\r\n  selectedLogicOperator: LogicOperatorNumeric = LogicOperatorNumeric['='];\r\n  activeCondition: boolean = false;\r\n\r\n  booleanLogicOperatorType = BooleanLogicOperatorType;\r\n  selectedBooleanLogicOperator: BooleanLogicOperatorType = BooleanLogicOperatorType.AND;\r\n\r\n  field: NumericField;\r\n\r\n  //variabili per gestire il css della label e del field\r\n  FieldstyleObj: any;\r\n  LabelstyleObj: any;\r\n\r\nconstructor() {\r\n}\r\n\r\nngOnInit(): void {\r\n  this.field = this.condition.Field as NumericField;\r\n  this.selectedBooleanLogicOperator = this.condition.booleanlogicoperator;\r\n  this.selectedLogicOperator = this.condition.logicoperator as LogicOperatorNumeric;\r\n\r\n  this.configureEqpNumericOptions();\r\n  this.configureControllers();\r\n  this.initStyles();\r\n}\r\n\r\n  //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html\r\n  initStyles() {\r\n    if(this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)   \r\n    this.FieldstyleObj= UtilityHelperService.initStyles(this.field.FieldstyleCSS);\r\n    if(this.field.LabelstyleCSS != null || this.field.LabelstyleCSS != undefined)   \r\n    this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);\r\n}\r\n\r\n/**\r\n* Metodo per emettere l'evento che il valore del record è cambiato.\r\n*/\r\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\nprivate configureEqpNumericOptions() {\r\n\r\n  this.eqpNumericOptions.suffix = this.field.MeasureUnit ? \"  \"+this.field.MeasureUnit+\"  \" : \"\";\r\n  this.eqpNumericOptions.prefix = this.field.CurrencySymbol ? this.field.CurrencySymbol+\" \" : \"\";\r\n  this.eqpNumericOptions.inputMode = this.field.CurrencySymbol ? EqpNumericInputMode.FINANCIAL : EqpNumericInputMode.NATURAL;\r\n  this.eqpNumericOptions.allowNegative=true;\r\n  if (this.field.DecimalSeparator != null && this.field.DecimalSeparator != undefined)\r\n  this.eqpNumericOptions.decimal = this.field.DecimalSeparator;\r\n  else\r\n  this.eqpNumericOptions.decimal=\".\";\r\n  if (this.field.ThousandsSeparator != null && this.field.ThousandsSeparator != undefined)\r\n  this.eqpNumericOptions.thousands = this.field.ThousandsSeparator;\r\n  if(this.field.IsInteger== false){\r\n    if (this.field.DecimalPrecision != null && this.field.DecimalPrecision != undefined) { this.eqpNumericOptions.precision = this.field.DecimalPrecision; }\r\n    else { this.eqpNumericOptions.precision = 2; }\r\n  }else{\r\n    this.eqpNumericOptions.precision = 0;\r\n  }\r\n}\r\n\r\n/**\r\n* Metodo di aggiunta dei validator dell'input\r\n*/\r\nprivate configureControllers() {\r\n  this.validatorsArray = [];\r\n  if (this.field.MinValue != null && this.field.MinValue != undefined)\r\n  this.validatorsArray.push(Validators.min(this.field.MinValue));\r\n  if (this.field.MaxValue != null && this.field.MaxValue != undefined)\r\n  this.validatorsArray.push(Validators.max(this.field.MaxValue));\r\n  this.field.FormFormGroup.get([this.field.Name]).setValidators(this.validatorsArray);\r\n}\r\n\r\n}\r\n","<div class=\"row\">\r\n    <div class=\"col-md-3 operatorCol\">\r\n        <eqp-select [enumData]=\"logicOperatorNumeric\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n    </div>\r\n    <div class=\"col-md-6 valueCol\">\r\n        <mat-form-field>\r\n            <mat-label  class=\"pt-1\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n                    <input [ngStyle]=\"FieldstyleObj\" matInput eqpNumericMask [readonly]=\"false\"\r\n                    [required]=\"false\" [(ngModel)]=\"this.condition.record[field.Name]\" [options]=\"eqpNumericOptions\"\r\n                    [step]=\"field.IsInteger ? 1 : null\" (ngModelChange)=\"onTriggerChange()\" />\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>"]}
@@ -0,0 +1,116 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { TextMaskEnum } from '../../../../../models/fields/textField.model';
3
+ import { UtilityHelperService } from '../../../../../services/utilityHelper.services';
4
+ import { interval } from 'rxjs';
5
+ import { LogicOperatorText } from '../../../../../models/logicOperator.model';
6
+ import { BooleanLogicOperatorType, Condition } from '../../../../../models/trigger.model';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "../../../../../services/voice-recognition.service";
9
+ import * as i2 from "@angular/material/input";
10
+ import * as i3 from "@angular/material/form-field";
11
+ import * as i4 from "@angular/material/icon";
12
+ import * as i5 from "@angular/forms";
13
+ import * as i6 from "@angular/common";
14
+ import * as i7 from "@eqproject/eqp-select";
15
+ export class TextTriggerTemplateComponent {
16
+ constructor(voiceservice) {
17
+ this.voiceservice = voiceservice;
18
+ this.recordChange = new EventEmitter();
19
+ this.triggerChange = new EventEmitter();
20
+ //Variabili per l'input vocale
21
+ this.isStillRecoginze = false;
22
+ this.source = interval(200);
23
+ this.STT = true;
24
+ this.InputMaskEnum = TextMaskEnum;
25
+ this.logicOperatorText = LogicOperatorText;
26
+ this.selectedLogicOperator = LogicOperatorText['='];
27
+ this.activeCondition = false;
28
+ this.booleanLogicOperatorType = BooleanLogicOperatorType;
29
+ this.selectedBooleanLogicOperator = BooleanLogicOperatorType.AND;
30
+ this.voiceservice.init();
31
+ }
32
+ ngOnInit() {
33
+ this.field = this.condition.Field;
34
+ this.selectedBooleanLogicOperator = this.condition.booleanlogicoperator;
35
+ this.selectedLogicOperator = this.condition.logicoperator;
36
+ this.initStyles();
37
+ }
38
+ initStyles() {
39
+ //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html
40
+ if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)
41
+ this.FieldstyleObj = UtilityHelperService.initStyles(this.field.FieldstyleCSS);
42
+ if (this.field.LabelstyleCSS != null || this.field.LabelstyleCSS != undefined)
43
+ this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);
44
+ }
45
+ ttsClick() {
46
+ //Gestione del bottone icona del microfono con riempimennto del campo in real time
47
+ if (!this.isStillRecoginze) {
48
+ this.newtext = '';
49
+ this.isStillRecoginze = this.voiceservice.start() === true ? true : false;
50
+ this.subscription = this.source.subscribe(val => {
51
+ if (this.condition.record[this.field.Name] == null || this.condition.record[this.field.Name] == undefined) {
52
+ this.condition.record[this.field.Name] = this.voiceservice.transcript_arr[this.voiceservice.transcript_arr.length - 1];
53
+ }
54
+ else {
55
+ this.newtext = this.voiceservice.transcript_arr[this.voiceservice.transcript_arr.length - 1];
56
+ if (this.newtext != undefined)
57
+ this.updateRTVoiceField();
58
+ }
59
+ });
60
+ }
61
+ else {
62
+ this.isStillRecoginze = this.voiceservice.stop() === false ? false : true;
63
+ this.subscription.unsubscribe();
64
+ this.updateVoiceField();
65
+ }
66
+ }
67
+ getInputType() {
68
+ switch (this.field.TextMask) {
69
+ case TextMaskEnum.Email:
70
+ return 'email';
71
+ case TextMaskEnum.Password:
72
+ return 'password';
73
+ case TextMaskEnum.Telefono:
74
+ return 'tel';
75
+ case TextMaskEnum.Url:
76
+ return 'url';
77
+ default:
78
+ return 'text';
79
+ }
80
+ }
81
+ updateRTVoiceField() {
82
+ this.condition.record[this.field.Name] = this.voiceservice.text + this.newtext;
83
+ this.newtext = '';
84
+ }
85
+ updateVoiceField() {
86
+ this.newtext = '';
87
+ this.condition.record[this.field.Name] = this.voiceservice.text;
88
+ }
89
+ /**
90
+ * Metodo per emettere l'evento che il valore del record è cambiato.
91
+ */
92
+ onTriggerChange() {
93
+ let output = new Condition();
94
+ output = {
95
+ key: this.field.Name,
96
+ value: this.condition.record[this.field.Name],
97
+ logicoperator: this.selectedLogicOperator,
98
+ fieldType: this.field.FieldType,
99
+ booleanlogicoperator: this.selectedBooleanLogicOperator
100
+ };
101
+ this.triggerChange.emit(output);
102
+ }
103
+ }
104
+ TextTriggerTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TextTriggerTemplateComponent, deps: [{ token: i1.VoiceRecognitionService }], target: i0.ɵɵFactoryTarget.Component });
105
+ TextTriggerTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TextTriggerTemplateComponent, selector: "text-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]=\"logicOperatorText\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-6 valueCol\">\r\n <mat-form-field>\r\n <mat-label class=\"pt-1\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n <input [ngStyle]=\"FieldstyleObj\" matInput [type]=\"getInputType()\" [readonly]=\"false\"\r\n [required]=\"false\" [(ngModel)]=\"this.condition.record[field.Name]\" (ngModelChange)=\"onTriggerChange()\">\r\n <mat-icon [hidden]=\"!field.Microphone\" (click)=\"ttsClick()\" matSuffix style=\"cursor: pointer;\" [color]=\"!isStillRecoginze ? '' : 'warn'\">keyboard_voice</mat-icon> \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>", 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.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: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.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: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i6.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"] }] });
106
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TextTriggerTemplateComponent, decorators: [{
107
+ type: Component,
108
+ args: [{ selector: 'text-trigger-template', template: "<div class=\"row\">\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorText\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div>\r\n <div class=\"col-md-6 valueCol\">\r\n <mat-form-field>\r\n <mat-label class=\"pt-1\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n <input [ngStyle]=\"FieldstyleObj\" matInput [type]=\"getInputType()\" [readonly]=\"false\"\r\n [required]=\"false\" [(ngModel)]=\"this.condition.record[field.Name]\" (ngModelChange)=\"onTriggerChange()\">\r\n <mat-icon [hidden]=\"!field.Microphone\" (click)=\"ttsClick()\" matSuffix style=\"cursor: pointer;\" [color]=\"!isStillRecoginze ? '' : 'warn'\">keyboard_voice</mat-icon> \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>", 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"] }]
109
+ }], ctorParameters: function () { return [{ type: i1.VoiceRecognitionService }]; }, propDecorators: { condition: [{
110
+ type: Input
111
+ }], recordChange: [{
112
+ type: Output
113
+ }], triggerChange: [{
114
+ type: Output
115
+ }] } });
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-trigger-template.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/trigger-creator/trigger-templates/text-trigger-template/text-trigger-template.component.ts","../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/trigger-creator/trigger-templates/text-trigger-template/text-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 { TextMaskEnum, TextField } from '../../../../../models/fields/textField.model';\r\nimport { UtilityHelperService } from '../../../../../services/utilityHelper.services';\r\nimport { VoiceRecognitionService } from '../../../../../services/voice-recognition.service';\r\nimport { interval, Subscription } from 'rxjs';\r\nimport { LogicOperatorText } from '../../../../../models/logicOperator.model';\r\nimport { BooleanLogicOperatorType, Condition, TriggerCondition } from '../../../../../models/trigger.model';\r\n\r\n@Component({\r\n  selector: 'text-trigger-template',\r\n  templateUrl: './text-trigger-template.component.html',\r\n  styleUrls: ['./text-trigger-template.component.scss']\r\n})\r\nexport class TextTriggerTemplateComponent {\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  //Variabili per l'input vocale\r\n  isStillRecoginze = false;\r\n  source = interval(200);\r\n  newtext: string;\r\n  subscription: Subscription;\r\n\r\n  STT:boolean =true;\r\n  //variabili per gestire il css della label e del field\r\n  FieldstyleObj: any;\r\n  LabelstyleObj: any;\r\n\r\n  InputMaskEnum = TextMaskEnum;\r\n\r\n  logicOperatorText = LogicOperatorText;\r\n  selectedLogicOperator: LogicOperatorText = LogicOperatorText['='];\r\n  activeCondition: boolean = false;\r\n\r\n  booleanLogicOperatorType = BooleanLogicOperatorType;\r\n  selectedBooleanLogicOperator: BooleanLogicOperatorType = BooleanLogicOperatorType.AND;\r\n  field: TextField;\r\n\r\n  constructor(public voiceservice: VoiceRecognitionService) {\r\n    this.voiceservice.init();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.field = this.condition.Field as TextField;\r\n    this.selectedBooleanLogicOperator = this.condition.booleanlogicoperator;\r\n    this.selectedLogicOperator = this.condition.logicoperator as LogicOperatorText;\r\n    this.initStyles();\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  ttsClick() {\r\n    //Gestione del bottone icona del microfono con riempimennto del campo in real time\r\n    if (!this.isStillRecoginze) {\r\n      this.newtext = '';\r\n      this.isStillRecoginze = this.voiceservice.start() === true ? true : false;\r\n      this.subscription = this.source.subscribe(val => {\r\n\r\n        if (this.condition.record[this.field.Name] == null || this.condition.record[this.field.Name] == undefined) {\r\n          this.condition.record[this.field.Name] = this.voiceservice.transcript_arr[this.voiceservice.transcript_arr.length - 1];\r\n        }\r\n        else {\r\n          this.newtext = this.voiceservice.transcript_arr[this.voiceservice.transcript_arr.length - 1];\r\n          if (this.newtext != undefined)\r\n            this.updateRTVoiceField();\r\n        }\r\n      });\r\n    }\r\n    else {\r\n      this.isStillRecoginze = this.voiceservice.stop() === false ? false : true;\r\n      this.subscription.unsubscribe();\r\n      this.updateVoiceField();\r\n    }\r\n  }\r\n\r\n  getInputType() {\r\n    switch (this.field.TextMask) {\r\n      case TextMaskEnum.Email:\r\n        return 'email';\r\n      case TextMaskEnum.Password:\r\n        return 'password';\r\n      case TextMaskEnum.Telefono:\r\n        return 'tel';\r\n      case TextMaskEnum.Url:\r\n        return 'url'\r\n      default:\r\n        return 'text';\r\n    }\r\n  }\r\n\r\n  updateRTVoiceField() {\r\n    this.condition.record[this.field.Name] = this.voiceservice.text + this.newtext;\r\n    this.newtext = '';\r\n  }\r\n\r\n  updateVoiceField() {\r\n    this.newtext = '';\r\n    this.condition.record[this.field.Name] = this.voiceservice.text;\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.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","<div class=\"row\">\r\n    <div class=\"col-md-3 operatorCol\">\r\n        <eqp-select [enumData]=\"logicOperatorText\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n    </div>\r\n    <div class=\"col-md-6 valueCol\">\r\n        <mat-form-field>\r\n            <mat-label  class=\"pt-1\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n            <input [ngStyle]=\"FieldstyleObj\" matInput [type]=\"getInputType()\" [readonly]=\"false\"\r\n                [required]=\"false\" [(ngModel)]=\"this.condition.record[field.Name]\" (ngModelChange)=\"onTriggerChange()\">\r\n                <mat-icon [hidden]=\"!field.Microphone\" (click)=\"ttsClick()\" matSuffix style=\"cursor: pointer;\" [color]=\"!isStillRecoginze ? '' : 'warn'\">keyboard_voice</mat-icon> \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>"]}
@@ -0,0 +1,116 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { TextMaskEnum } from '../../../../../models/fields/textField.model';
3
+ import { UtilityHelperService } from '../../../../../services/utilityHelper.services';
4
+ import { interval } from 'rxjs';
5
+ import { LogicOperatorText } from '../../../../../models/logicOperator.model';
6
+ import { Condition, BooleanLogicOperatorType } from '../../../../../models/trigger.model';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "../../../../../services/voice-recognition.service";
9
+ import * as i2 from "@angular/material/input";
10
+ import * as i3 from "@angular/material/form-field";
11
+ import * as i4 from "@angular/material/icon";
12
+ import * as i5 from "@angular/forms";
13
+ import * as i6 from "@angular/common";
14
+ import * as i7 from "@eqproject/eqp-select";
15
+ export class TextareaTriggerTemplateComponent {
16
+ constructor(voiceservice) {
17
+ this.voiceservice = voiceservice;
18
+ this.recordChange = new EventEmitter();
19
+ this.triggerChange = new EventEmitter();
20
+ //Variabili per l'input vocale
21
+ this.isStillRecoginze = false;
22
+ this.source = interval(200);
23
+ this.STT = true;
24
+ this.InputMaskEnum = TextMaskEnum;
25
+ this.logicOperatorText = LogicOperatorText;
26
+ this.selectedLogicOperator = LogicOperatorText['='];
27
+ this.activeCondition = false;
28
+ this.booleanLogicOperatorType = BooleanLogicOperatorType;
29
+ this.selectedBooleanLogicOperator = BooleanLogicOperatorType.AND;
30
+ this.voiceservice.init();
31
+ }
32
+ ngOnInit() {
33
+ this.field = this.condition.Field;
34
+ this.selectedBooleanLogicOperator = this.condition.booleanlogicoperator;
35
+ this.selectedLogicOperator = this.condition.logicoperator;
36
+ this.initStyles();
37
+ }
38
+ initStyles() {
39
+ //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html
40
+ if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)
41
+ this.FieldstyleObj = UtilityHelperService.initStyles(this.field.FieldstyleCSS);
42
+ if (this.field.LabelstyleCSS != null || this.field.LabelstyleCSS != undefined)
43
+ this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);
44
+ }
45
+ ttsClick() {
46
+ //Gestione del bottone icona del microfono con riempimennto del campo in real time
47
+ if (!this.isStillRecoginze) {
48
+ this.newtext = '';
49
+ this.isStillRecoginze = this.voiceservice.start() === true ? true : false;
50
+ this.subscription = this.source.subscribe(val => {
51
+ if (this.condition.record[this.field.Name] == null || this.condition.record[this.field.Name] == undefined) {
52
+ this.condition.record[this.field.Name] = this.voiceservice.transcript_arr[this.voiceservice.transcript_arr.length - 1];
53
+ }
54
+ else {
55
+ this.newtext = this.voiceservice.transcript_arr[this.voiceservice.transcript_arr.length - 1];
56
+ if (this.newtext != undefined)
57
+ this.updateRTVoiceField();
58
+ }
59
+ });
60
+ }
61
+ else {
62
+ this.isStillRecoginze = this.voiceservice.stop() === false ? false : true;
63
+ this.subscription.unsubscribe();
64
+ this.updateVoiceField();
65
+ }
66
+ }
67
+ getInputType() {
68
+ switch (this.field.TextMask) {
69
+ case TextMaskEnum.Email:
70
+ return 'email';
71
+ case TextMaskEnum.Password:
72
+ return 'password';
73
+ case TextMaskEnum.Telefono:
74
+ return 'tel';
75
+ case TextMaskEnum.Url:
76
+ return 'url';
77
+ default:
78
+ return 'text';
79
+ }
80
+ }
81
+ updateRTVoiceField() {
82
+ this.condition.record[this.field.Name] = this.voiceservice.text + this.newtext;
83
+ this.newtext = '';
84
+ }
85
+ updateVoiceField() {
86
+ this.newtext = '';
87
+ this.condition.record[this.field.Name] = this.voiceservice.text;
88
+ }
89
+ /**
90
+ * Metodo per emettere l'evento che il valore del record è cambiato.
91
+ */
92
+ onTriggerChange() {
93
+ let output = new Condition();
94
+ output = {
95
+ key: this.field.Name,
96
+ value: this.condition.record[this.field.Name],
97
+ logicoperator: this.selectedLogicOperator,
98
+ fieldType: this.field.FieldType,
99
+ booleanlogicoperator: this.selectedBooleanLogicOperator
100
+ };
101
+ this.triggerChange.emit(output);
102
+ }
103
+ }
104
+ TextareaTriggerTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TextareaTriggerTemplateComponent, deps: [{ token: i1.VoiceRecognitionService }], target: i0.ɵɵFactoryTarget.Component });
105
+ TextareaTriggerTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TextareaTriggerTemplateComponent, selector: "textarea-trigger-template", inputs: { condition: "condition" }, outputs: { recordChange: "recordChange", triggerChange: "triggerChange" }, ngImport: i0, template: "<div class=\"row textareaFilterTemplate\">\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorText\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div> \r\n <div class=\"col-md-6 valueCol\">\r\n <mat-form-field >\r\n <mat-label class=\"pt-1\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n <textarea [ngStyle]=\"FieldstyleObj\" matInput [type]=\"getInputType()\" [readonly]=\"false\"\r\n [required]=\"false\" [(ngModel)]=\"this.condition.record[field.Name]\" (ngModelChange)=\"onTriggerChange()\"></textarea>\r\n <mat-icon [hidden]=\"!field.Microphone\" (click)=\"ttsClick()\" matSuffix style=\"cursor: pointer;\" [color]=\"!isStillRecoginze ? '' : 'warn'\">keyboard_voice</mat-icon> \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>", styles: [".valueCol{padding-right:0}.operatorCol{padding-left:0}::ng-deep .textareaFilterTemplate .operatorCol .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:#a5afc0!important;min-height:80px!important}::ng-deep .textareaFilterTemplate .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.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: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.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: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i6.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"] }] });
106
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TextareaTriggerTemplateComponent, decorators: [{
107
+ type: Component,
108
+ args: [{ selector: 'textarea-trigger-template', template: "<div class=\"row textareaFilterTemplate\">\r\n <div class=\"col-md-3 operatorCol\">\r\n <eqp-select [enumData]=\"logicOperatorText\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n </div> \r\n <div class=\"col-md-6 valueCol\">\r\n <mat-form-field >\r\n <mat-label class=\"pt-1\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n <textarea [ngStyle]=\"FieldstyleObj\" matInput [type]=\"getInputType()\" [readonly]=\"false\"\r\n [required]=\"false\" [(ngModel)]=\"this.condition.record[field.Name]\" (ngModelChange)=\"onTriggerChange()\"></textarea>\r\n <mat-icon [hidden]=\"!field.Microphone\" (click)=\"ttsClick()\" matSuffix style=\"cursor: pointer;\" [color]=\"!isStillRecoginze ? '' : 'warn'\">keyboard_voice</mat-icon> \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>", styles: [".valueCol{padding-right:0}.operatorCol{padding-left:0}::ng-deep .textareaFilterTemplate .operatorCol .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:#a5afc0!important;min-height:80px!important}::ng-deep .textareaFilterTemplate .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"] }]
109
+ }], ctorParameters: function () { return [{ type: i1.VoiceRecognitionService }]; }, propDecorators: { condition: [{
110
+ type: Input
111
+ }], recordChange: [{
112
+ type: Output
113
+ }], triggerChange: [{
114
+ type: Output
115
+ }] } });
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textarea-trigger-template.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/trigger-creator/trigger-templates/textarea-trigger-template/textarea-trigger-template.component.ts","../../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/trigger-creator/trigger-templates/textarea-trigger-template/textarea-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 { TextMaskEnum, TextField } from '../../../../../models/fields/textField.model';\r\nimport { UtilityHelperService } from '../../../../../services/utilityHelper.services';\r\nimport { VoiceRecognitionService } from '../../../../../services/voice-recognition.service';\r\nimport { interval, Subscription } from 'rxjs';\r\nimport { LogicOperatorText } from '../../../../../models/logicOperator.model';\r\nimport { TriggerCondition, Condition, BooleanLogicOperatorType } from '../../../../../models/trigger.model';\r\n\r\n@Component({\r\n  selector: 'textarea-trigger-template',\r\n  templateUrl: './textarea-trigger-template.component.html',\r\n  styleUrls: ['./textarea-trigger-template.component.scss']\r\n})\r\nexport class TextareaTriggerTemplateComponent {\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    field: TextField;\r\n\r\n  //Variabili per l'input vocale\r\n  isStillRecoginze = false;\r\n  source = interval(200);\r\n  newtext: string;\r\n  subscription: Subscription;\r\n\r\n  STT:boolean =true;\r\n  //variabili per gestire il css della label e del field\r\n  FieldstyleObj: any;\r\n  LabelstyleObj: any;\r\n\r\n  \r\n  InputMaskEnum = TextMaskEnum;\r\n\r\n  logicOperatorText = LogicOperatorText;\r\n  selectedLogicOperator: LogicOperatorText = LogicOperatorText['='];\r\n  activeCondition: boolean = false;\r\n\r\n  booleanLogicOperatorType = BooleanLogicOperatorType;\r\n  selectedBooleanLogicOperator: BooleanLogicOperatorType = BooleanLogicOperatorType.AND;\r\n\r\n  constructor(public voiceservice: VoiceRecognitionService) {\r\n    this.voiceservice.init();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.field = this.condition.Field as TextField;\r\n    this.selectedBooleanLogicOperator = this.condition.booleanlogicoperator;\r\n    this.selectedLogicOperator = this.condition.logicoperator as LogicOperatorText;\r\n    this.initStyles();\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  ttsClick() {\r\n    //Gestione del bottone icona del microfono con riempimennto del campo in real time\r\n    if (!this.isStillRecoginze) {\r\n      this.newtext = '';\r\n      this.isStillRecoginze = this.voiceservice.start() === true ? true : false;\r\n      this.subscription = this.source.subscribe(val => {\r\n\r\n        if (this.condition.record[this.field.Name] == null || this.condition.record[this.field.Name] == undefined) {\r\n          this.condition.record[this.field.Name] = this.voiceservice.transcript_arr[this.voiceservice.transcript_arr.length - 1];\r\n        }\r\n        else {\r\n          this.newtext = this.voiceservice.transcript_arr[this.voiceservice.transcript_arr.length - 1];\r\n          if (this.newtext != undefined)\r\n            this.updateRTVoiceField();\r\n        }\r\n      });\r\n    }\r\n    else {\r\n      this.isStillRecoginze = this.voiceservice.stop() === false ? false : true;\r\n      this.subscription.unsubscribe();\r\n      this.updateVoiceField();\r\n    }\r\n  }\r\n\r\n  getInputType() {\r\n    switch (this.field.TextMask) {\r\n      case TextMaskEnum.Email:\r\n        return 'email';\r\n      case TextMaskEnum.Password:\r\n        return 'password';\r\n      case TextMaskEnum.Telefono:\r\n        return 'tel';\r\n      case TextMaskEnum.Url:\r\n        return 'url'\r\n      default:\r\n        return 'text';\r\n    }\r\n  }\r\n\r\n  updateRTVoiceField() {\r\n    this.condition.record[this.field.Name] = this.voiceservice.text + this.newtext;\r\n    this.newtext = '';\r\n  }\r\n\r\n  updateVoiceField() {\r\n    this.newtext = '';\r\n    this.condition.record[this.field.Name] = this.voiceservice.text;\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","<div class=\"row textareaFilterTemplate\">\r\n    <div class=\"col-md-3 operatorCol\">\r\n        <eqp-select [enumData]=\"logicOperatorText\" [(ngModelInput)]=\"selectedLogicOperator\" (ngModelInputChange)=\"onTriggerChange()\"></eqp-select>\r\n    </div>    \r\n    <div class=\"col-md-6 valueCol\">\r\n        <mat-form-field >\r\n            <mat-label  class=\"pt-1\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n            <textarea [ngStyle]=\"FieldstyleObj\" matInput [type]=\"getInputType()\" [readonly]=\"false\"\r\n                [required]=\"false\" [(ngModel)]=\"this.condition.record[field.Name]\" (ngModelChange)=\"onTriggerChange()\"></textarea>\r\n                <mat-icon [hidden]=\"!field.Microphone\" (click)=\"ttsClick()\" matSuffix style=\"cursor: pointer;\" [color]=\"!isStillRecoginze ? '' : 'warn'\">keyboard_voice</mat-icon> \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>"]}