@eqproject/eqp-dynamic-module 1.0.4 → 1.0.6

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 (25) hide show
  1. package/esm2020/lib/components/private/add-form-field/add-form-field.component.mjs +21 -3
  2. package/esm2020/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.mjs +9 -3
  3. package/esm2020/lib/components/private/field-templates/date-field-template/date-field-template.component.mjs +3 -3
  4. package/esm2020/lib/components/private/field-templates/image-field-template/image-field-template.component.mjs +1 -1
  5. package/esm2020/lib/components/private/field-templates/list-value-field-template/list-value-field-template.component.mjs +11 -3
  6. package/esm2020/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.mjs +11 -3
  7. package/esm2020/lib/components/private/field-templates/text-field-template/text-field-template.component.mjs +61 -10
  8. package/esm2020/lib/components/private/field-templates/textarea-field-template/textarea-field-template.component.mjs +60 -10
  9. package/esm2020/lib/eqp-dynamic-module.module.mjs +1 -1
  10. package/esm2020/lib/models/baseField.model.mjs +1 -1
  11. package/esm2020/lib/services/utilityHelper.services.mjs +9 -1
  12. package/esm2020/lib/services/voice-recognition.service.mjs +69 -0
  13. package/fesm2015/eqproject-eqp-dynamic-module.mjs +263 -54
  14. package/fesm2015/eqproject-eqp-dynamic-module.mjs.map +1 -1
  15. package/fesm2020/eqproject-eqp-dynamic-module.mjs +263 -54
  16. package/fesm2020/eqproject-eqp-dynamic-module.mjs.map +1 -1
  17. package/lib/components/private/field-templates/boolean-field-template/boolean-field-template.component.d.ts +3 -0
  18. package/lib/components/private/field-templates/list-value-field-template/list-value-field-template.component.d.ts +3 -0
  19. package/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.d.ts +3 -0
  20. package/lib/components/private/field-templates/text-field-template/text-field-template.component.d.ts +14 -1
  21. package/lib/components/private/field-templates/textarea-field-template/textarea-field-template.component.d.ts +14 -1
  22. package/lib/models/baseField.model.d.ts +2 -0
  23. package/lib/services/utilityHelper.services.d.ts +1 -0
  24. package/lib/services/voice-recognition.service.d.ts +18 -0
  25. package/package.json +1 -1
@@ -18,6 +18,14 @@ export class NumericFieldTemplateComponent {
18
18
  this.configureEqpNumericOptions();
19
19
  this.configureControllers();
20
20
  this.updateField();
21
+ this.initStyles();
22
+ }
23
+ initStyles() {
24
+ //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html
25
+ if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)
26
+ this.FieldstyleObj = UtilityHelperService.initStyles(this.field.FieldstyleCSS);
27
+ if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)
28
+ this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);
21
29
  }
22
30
  ngOnChanges(changes) {
23
31
  // Se viene modificato il valore di "ngModelInput" allora aggiorna l'input
@@ -75,10 +83,10 @@ export class NumericFieldTemplateComponent {
75
83
  }
76
84
  }
77
85
  NumericFieldTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: NumericFieldTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
78
- NumericFieldTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.8", type: NumericFieldTemplateComponent, selector: "numeric-field-template", inputs: { field: "field", record: "record" }, outputs: { recordChange: "recordChange" }, usesOnChanges: true, ngImport: i0, template: "<mat-form-field [formGroup]=\"field.FormFormGroup\">\r\n <mat-label> {{field.Description}} </mat-label>\r\n <input matInput eqpNumericMask [formControlName]=\"field.Name\" [readonly]=\"field.Readonly\"\r\n [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\" [options]=\"eqpNumericOptions\"\r\n [step]=\"field.IsInteger ? 1 : null\" (ngModelChange)=\"onRecordValueChange()\" />\r\n <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n Min: {{field.MinValue}} - Max: {{field.MaxValue}}\r\n </mat-error>\r\n</mat-form-field>", styles: ["input.ng-touched.ng-invalid,input.ng-dirty.ng-invalid{border:red 2px solid!important}\n"], dependencies: [{ kind: "directive", type: i1.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatLabel, selector: "mat-label" }, { 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: "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.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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: "directive", type: i5.EqpNumericDirective, selector: "[eqpNumericMask]", inputs: ["options"] }] });
86
+ NumericFieldTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.8", type: NumericFieldTemplateComponent, selector: "numeric-field-template", inputs: { field: "field", record: "record" }, outputs: { recordChange: "recordChange" }, usesOnChanges: true, ngImport: i0, template: "<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 eqpNumericMask [formControlName]=\"field.Name\" [readonly]=\"field.Readonly\"\r\n [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\" [options]=\"eqpNumericOptions\"\r\n [step]=\"field.IsInteger ? 1 : null\" (ngModelChange)=\"onRecordValueChange()\" />\r\n <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n Min: {{field.MinValue}} - Max: {{field.MaxValue}}\r\n </mat-error>\r\n</mat-form-field>", styles: ["input.ng-touched.ng-invalid,input.ng-dirty.ng-invalid{border:red 2px solid!important}::ng-deep .mat-form-field-label{font-size:x-large}\n"], dependencies: [{ kind: "directive", type: i1.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatLabel, selector: "mat-label" }, { 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: "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.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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: "directive", type: i5.EqpNumericDirective, selector: "[eqpNumericMask]", inputs: ["options"] }] });
79
87
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: NumericFieldTemplateComponent, decorators: [{
80
88
  type: Component,
81
- args: [{ selector: 'numeric-field-template', template: "<mat-form-field [formGroup]=\"field.FormFormGroup\">\r\n <mat-label> {{field.Description}} </mat-label>\r\n <input matInput eqpNumericMask [formControlName]=\"field.Name\" [readonly]=\"field.Readonly\"\r\n [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\" [options]=\"eqpNumericOptions\"\r\n [step]=\"field.IsInteger ? 1 : null\" (ngModelChange)=\"onRecordValueChange()\" />\r\n <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n Min: {{field.MinValue}} - Max: {{field.MaxValue}}\r\n </mat-error>\r\n</mat-form-field>", styles: ["input.ng-touched.ng-invalid,input.ng-dirty.ng-invalid{border:red 2px solid!important}\n"] }]
89
+ args: [{ selector: 'numeric-field-template', template: "<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 eqpNumericMask [formControlName]=\"field.Name\" [readonly]=\"field.Readonly\"\r\n [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\" [options]=\"eqpNumericOptions\"\r\n [step]=\"field.IsInteger ? 1 : null\" (ngModelChange)=\"onRecordValueChange()\" />\r\n <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n Min: {{field.MinValue}} - Max: {{field.MaxValue}}\r\n </mat-error>\r\n</mat-form-field>", styles: ["input.ng-touched.ng-invalid,input.ng-dirty.ng-invalid{border:red 2px solid!important}::ng-deep .mat-form-field-label{font-size:x-large}\n"] }]
82
90
  }], ctorParameters: function () { return []; }, propDecorators: { field: [{
83
91
  type: Input
84
92
  }], record: [{
@@ -86,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImpor
86
94
  }], recordChange: [{
87
95
  type: Output
88
96
  }] } });
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"numeric-field-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAiB,MAAM,eAAe,CAAC;AACzG,OAAO,EAAE,mBAAmB,EAAqB,MAAM,wBAAwB,CAAC;AAChF,OAAO,EAAE,oBAAoB,EAAE,MAAM,6CAA6C,CAAC;AAInF,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;;;;;;;AAO5C,MAAM,OAAO,6BAA6B;IAQxC;QAJU,iBAAY,GAAyB,IAAI,YAAY,EAAU,CAAC;QAC1E,oBAAe,GAAU,EAAE,CAAC;QAC5B,sBAAiB,GAA+B,EAAE,CAAC;IAEnC,CAAC;IAEjB,QAAQ;QACN,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAClC,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,0EAA0E;QAC1E,IAAI,OAAO,CAAC,QAAQ,CAAC,IAAI,SAAS,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,WAAW,IAAI,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,EAAE;YACjL,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC;YAC7C,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;IACH,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE;YACtB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,oBAAoB,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;SACjH;QACD,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE;YACxB,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,oBAAoB,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;SAC5G;IACH,CAAC;IAED;;OAEG;IACH,mBAAmB;QACjB,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE;YACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACrC;IACH,CAAC;IAED;;OAEG;IACK,0BAA0B;QAChC,IAAI,CAAC,iBAAiB,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,CAAC;QAC3F,IAAI,CAAC,iBAAiB,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,mBAAmB,CAAC,SAAS,CAAC,CAAC,CAAC,mBAAmB,CAAC,OAAO,CAAC;QAC3H,IAAI,IAAI,CAAC,KAAK,CAAC,gBAAgB,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,gBAAgB,IAAI,SAAS;YACjF,IAAI,CAAC,iBAAiB,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC;QAC/D,IAAI,IAAI,CAAC,KAAK,CAAC,kBAAkB,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,kBAAkB,IAAI,SAAS;YACrF,IAAI,CAAC,iBAAiB,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC;QACnE,IAAI,IAAI,CAAC,KAAK,CAAC,gBAAgB,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,gBAAgB,IAAI,SAAS,EAAE;YAAE,IAAI,CAAC,iBAAiB,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC;SAAE;aACnJ;YAAE,IAAI,CAAC,iBAAiB,CAAC,SAAS,GAAG,CAAC,CAAA;SAAE;IAC/C,CAAC;IACD;;KAEC;IACO,oBAAoB;QAC1B,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;QAC1B,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,SAAS;YACjE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC;QACjE,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,SAAS;YACjE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC;QACjE,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;;0HApEU,6BAA6B;8GAA7B,6BAA6B,4KCb1C,8oBAQiB;2FDKJ,6BAA6B;kBALzC,SAAS;+BACE,wBAAwB;0EAMzB,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACI,YAAY;sBAArB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { EqpNumericInputMode, NumericMaskConfig } from '@eqproject/eqp-numeric';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { NumericField } from '../../../../models/fields/numericField.model';\r\nimport { IBaseFieldComponent } from '../../../../interfaces/iBaseFieldComponent.interface';\r\nimport { Validators } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'numeric-field-template',\r\n  templateUrl: './numeric-field-template.component.html',\r\n  styleUrls: ['./numeric-field-template.component.scss']\r\n})\r\nexport class NumericFieldTemplateComponent implements OnInit, OnChanges, IBaseFieldComponent {\r\n\r\n  @Input() field: NumericField;\r\n  @Input() record: Record;\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n  validatorsArray: any[] = [];\r\n  eqpNumericOptions: Partial<NumericMaskConfig> = {};\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n    this.configureEqpNumericOptions();\r\n    this.configureControllers();   \r\n    this.updateField();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    // Se viene modificato il valore di \"ngModelInput\" allora aggiorna l'input\r\n    if (changes['record'] != undefined && changes['record'].firstChange == false && JSON.stringify(changes['record'].currentValue) != JSON.stringify(changes['record'].previousValue)) {\r\n      this.record = changes['record'].currentValue;\r\n      this.updateField();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.\r\n   */\r\n  updateField() {\r\n    if (this.field.Formula) {\r\n      this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);\r\n    }\r\n    if (this.field.VisibleIf) {\r\n      this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, null);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per emettere l'evento che il valore del record è cambiato.\r\n   */\r\n  onRecordValueChange() {\r\n    if (!this.field.Formula) {\r\n      this.recordChange.emit(this.record);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per configurare eqp-numeric\r\n   */\r\n  private configureEqpNumericOptions() {\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    if (this.field.DecimalSeparator != null && this.field.DecimalSeparator != undefined)\r\n      this.eqpNumericOptions.decimal = this.field.DecimalSeparator;\r\n    if (this.field.ThousandsSeparator != null && this.field.ThousandsSeparator != undefined)\r\n      this.eqpNumericOptions.thousands = this.field.ThousandsSeparator;\r\n    if (this.field.DecimalPrecision != null && this.field.DecimalPrecision != undefined) { this.eqpNumericOptions.precision = this.field.DecimalPrecision; }\r\n    else { this.eqpNumericOptions.precision = 0 }\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    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}","<mat-form-field [formGroup]=\"field.FormFormGroup\">\r\n    <mat-label> {{field.Description}} </mat-label>\r\n    <input matInput eqpNumericMask [formControlName]=\"field.Name\" [readonly]=\"field.Readonly\"\r\n        [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\" [options]=\"eqpNumericOptions\"\r\n        [step]=\"field.IsInteger ? 1 : null\" (ngModelChange)=\"onRecordValueChange()\" />\r\n        <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n            Min: {{field.MinValue}} - Max: {{field.MaxValue}}\r\n          </mat-error>\r\n</mat-form-field>"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"numeric-field-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/numeric-field-template/numeric-field-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { EqpNumericInputMode, NumericMaskConfig } from '@eqproject/eqp-numeric';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { NumericField } from '../../../../models/fields/numericField.model';\r\nimport { IBaseFieldComponent } from '../../../../interfaces/iBaseFieldComponent.interface';\r\nimport { Validators } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'numeric-field-template',\r\n  templateUrl: './numeric-field-template.component.html',\r\n  styleUrls: ['./numeric-field-template.component.scss']\r\n})\r\nexport class NumericFieldTemplateComponent implements OnInit, OnChanges, IBaseFieldComponent {\r\n\r\n  @Input() field: NumericField;\r\n  @Input() record: Record;\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n  validatorsArray: any[] = [];\r\n  eqpNumericOptions: Partial<NumericMaskConfig> = {};\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\n  ngOnInit(): void {\r\n    this.configureEqpNumericOptions();\r\n    this.configureControllers();   \r\n    this.updateField();\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.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)   \r\n         this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);\r\n }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    // Se viene modificato il valore di \"ngModelInput\" allora aggiorna l'input\r\n    if (changes['record'] != undefined && changes['record'].firstChange == false && JSON.stringify(changes['record'].currentValue) != JSON.stringify(changes['record'].previousValue)) {\r\n      this.record = changes['record'].currentValue;\r\n      this.updateField();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.\r\n   */\r\n  updateField() {\r\n    if (this.field.Formula) {\r\n      this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);\r\n    }\r\n    if (this.field.VisibleIf) {\r\n      this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, null);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per emettere l'evento che il valore del record è cambiato.\r\n   */\r\n  onRecordValueChange() {\r\n    if (!this.field.Formula) {\r\n      this.recordChange.emit(this.record);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per configurare eqp-numeric\r\n   */\r\n  private configureEqpNumericOptions() {\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    if (this.field.DecimalSeparator != null && this.field.DecimalSeparator != undefined)\r\n      this.eqpNumericOptions.decimal = this.field.DecimalSeparator;\r\n    if (this.field.ThousandsSeparator != null && this.field.ThousandsSeparator != undefined)\r\n      this.eqpNumericOptions.thousands = this.field.ThousandsSeparator;\r\n    if (this.field.DecimalPrecision != null && this.field.DecimalPrecision != undefined) { this.eqpNumericOptions.precision = this.field.DecimalPrecision; }\r\n    else { this.eqpNumericOptions.precision = 0 }\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    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}","<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 eqpNumericMask [formControlName]=\"field.Name\" [readonly]=\"field.Readonly\"\r\n        [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\" [options]=\"eqpNumericOptions\"\r\n        [step]=\"field.IsInteger ? 1 : null\" (ngModelChange)=\"onRecordValueChange()\" />\r\n        <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n            Min: {{field.MinValue}} - Max: {{field.MaxValue}}\r\n          </mat-error>\r\n</mat-form-field>"]}
@@ -1,18 +1,34 @@
1
1
  import { Component, EventEmitter, Input, Output } from '@angular/core';
2
2
  import { TextMaskEnum } from '../../../../models/fields/textField.model';
3
3
  import { UtilityHelperService } from '../../../../services/utilityHelper.services';
4
+ import { interval } from 'rxjs';
4
5
  import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/material/form-field";
6
- import * as i2 from "@angular/material/input";
7
- import * as i3 from "@angular/forms";
8
- import * as i4 from "@angular/common";
6
+ import * as i1 from "../../../../services/voice-recognition.service";
7
+ import * as i2 from "@angular/material/form-field";
8
+ import * as i3 from "@angular/material/input";
9
+ import * as i4 from "@angular/material/icon";
10
+ import * as i5 from "@angular/forms";
11
+ import * as i6 from "@angular/common";
9
12
  export class TextFieldTemplateComponent {
10
- constructor() {
13
+ constructor(voiceservice) {
14
+ this.voiceservice = voiceservice;
15
+ //Variabili per l'input vocale
16
+ this.isStillRecoginze = false;
17
+ this.source = interval(200);
11
18
  this.recordChange = new EventEmitter();
12
19
  this.InputMaskEnum = TextMaskEnum;
20
+ this.voiceservice.init();
13
21
  }
14
22
  ngOnInit() {
15
23
  this.updateField();
24
+ this.initStyles();
25
+ }
26
+ initStyles() {
27
+ //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html
28
+ if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)
29
+ this.FieldstyleObj = UtilityHelperService.initStyles(this.field.FieldstyleCSS);
30
+ if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)
31
+ this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);
16
32
  }
17
33
  ngOnChanges(changes) {
18
34
  // Se viene modificato il valore di "ngModelInput" allora aggiorna l'input
@@ -21,6 +37,28 @@ export class TextFieldTemplateComponent {
21
37
  this.updateField();
22
38
  }
23
39
  }
40
+ ttsClick() {
41
+ //Gestione del bottone icona del microfono con riempimennto del campo in real time
42
+ if (!this.isStillRecoginze) {
43
+ this.newtext = '';
44
+ this.isStillRecoginze = this.voiceservice.start() === true ? true : false;
45
+ this.subscription = this.source.subscribe(val => {
46
+ if (this.record[this.field.Name] == null || this.record[this.field.Name] == undefined) {
47
+ this.record[this.field.Name] = this.voiceservice.transcript_arr[this.voiceservice.transcript_arr.length - 1];
48
+ }
49
+ else {
50
+ this.newtext = this.voiceservice.transcript_arr[this.voiceservice.transcript_arr.length - 1];
51
+ if (this.newtext != undefined)
52
+ this.updateRTVoiceField();
53
+ }
54
+ });
55
+ }
56
+ else {
57
+ this.isStillRecoginze = this.voiceservice.stop() === false ? false : true;
58
+ this.subscription.unsubscribe();
59
+ this.updateVoiceField();
60
+ }
61
+ }
24
62
  getInputType() {
25
63
  switch (this.field.TextMask) {
26
64
  case TextMaskEnum.Email:
@@ -35,6 +73,14 @@ export class TextFieldTemplateComponent {
35
73
  return 'text';
36
74
  }
37
75
  }
76
+ updateRTVoiceField() {
77
+ this.record[this.field.Name] = this.voiceservice.text + this.newtext;
78
+ this.newtext = '';
79
+ }
80
+ updateVoiceField() {
81
+ this.newtext = '';
82
+ this.record[this.field.Name] = this.voiceservice.text;
83
+ }
38
84
  /**
39
85
  * Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.
40
86
  */
@@ -45,6 +91,11 @@ export class TextFieldTemplateComponent {
45
91
  if (this.field.VisibleIf) {
46
92
  this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, null);
47
93
  }
94
+ if (!this.isStillRecoginze) {
95
+ if (this.record[this.field.Name] != null || this.record[this.field.Name] != undefined) {
96
+ this.voiceservice.text = this.record[this.field.Name];
97
+ }
98
+ }
48
99
  }
49
100
  /**
50
101
  * Metodo per emettere l'evento che il valore del record è cambiato.
@@ -58,16 +109,16 @@ export class TextFieldTemplateComponent {
58
109
  }
59
110
  }
60
111
  }
61
- TextFieldTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: TextFieldTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
62
- TextFieldTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.8", type: TextFieldTemplateComponent, selector: "text-field-template", inputs: { field: "field", record: "record" }, outputs: { recordChange: "recordChange" }, usesOnChanges: true, ngImport: i0, template: "<mat-form-field [formGroup]=\"field.FormFormGroup\">\r\n <mat-label> {{field.Description}} </mat-label>\r\n <input matInput [type]=\"getInputType()\" [formControlName]=\"field.Name\" [readonly]=\"field.Readonly\"\r\n [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\r\n <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n Min. Caratteri: {{field.MinLenght}} - Max. Caratteri: {{field.MaxLenght}}\r\n </mat-error>\r\n</mat-form-field>", styles: ["input.ng-touched.ng-invalid,input.ng-dirty.ng-invalid{border:red 2px solid!important}\n"], dependencies: [{ kind: "directive", type: i1.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatLabel, selector: "mat-label" }, { 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: "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.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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"] }] });
112
+ TextFieldTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: TextFieldTemplateComponent, deps: [{ token: i1.VoiceRecognitionService }], target: i0.ɵɵFactoryTarget.Component });
113
+ TextFieldTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.8", type: TextFieldTemplateComponent, selector: "text-field-template", inputs: { field: "field", record: "record" }, outputs: { recordChange: "recordChange" }, usesOnChanges: true, ngImport: i0, template: "<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 [type]=\"getInputType()\" [formControlName]=\"field.Name\" [readonly]=\"field.Readonly\"\r\n [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\r\n <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n Min. Caratteri: {{field.MinLenght}} - Max. Caratteri: {{field.MaxLenght}}\r\n </mat-error>\r\n <mat-icon (click)=\"ttsClick()\" matSuffix style=\"cursor: pointer;\" [color]=\"!isStillRecoginze ? '' : 'warn'\">keyboard_voice</mat-icon> \r\n</mat-form-field>", styles: ["input.ng-touched.ng-invalid,input.ng-dirty.ng-invalid{border:red 2px solid!important}::ng-deep .mat-form-field-label{font-size:x-large}\n"], dependencies: [{ kind: "directive", type: i2.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.MatSuffix, selector: "[matSuffix]" }, { kind: "directive", type: i3.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: 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.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { 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: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
63
114
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: TextFieldTemplateComponent, decorators: [{
64
115
  type: Component,
65
- args: [{ selector: 'text-field-template', template: "<mat-form-field [formGroup]=\"field.FormFormGroup\">\r\n <mat-label> {{field.Description}} </mat-label>\r\n <input matInput [type]=\"getInputType()\" [formControlName]=\"field.Name\" [readonly]=\"field.Readonly\"\r\n [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\r\n <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n Min. Caratteri: {{field.MinLenght}} - Max. Caratteri: {{field.MaxLenght}}\r\n </mat-error>\r\n</mat-form-field>", styles: ["input.ng-touched.ng-invalid,input.ng-dirty.ng-invalid{border:red 2px solid!important}\n"] }]
66
- }], ctorParameters: function () { return []; }, propDecorators: { field: [{
116
+ args: [{ selector: 'text-field-template', template: "<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 [type]=\"getInputType()\" [formControlName]=\"field.Name\" [readonly]=\"field.Readonly\"\r\n [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\r\n <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n Min. Caratteri: {{field.MinLenght}} - Max. Caratteri: {{field.MaxLenght}}\r\n </mat-error>\r\n <mat-icon (click)=\"ttsClick()\" matSuffix style=\"cursor: pointer;\" [color]=\"!isStillRecoginze ? '' : 'warn'\">keyboard_voice</mat-icon> \r\n</mat-form-field>", styles: ["input.ng-touched.ng-invalid,input.ng-dirty.ng-invalid{border:red 2px solid!important}::ng-deep .mat-form-field-label{font-size:x-large}\n"] }]
117
+ }], ctorParameters: function () { return [{ type: i1.VoiceRecognitionService }]; }, propDecorators: { field: [{
67
118
  type: Input
68
119
  }], record: [{
69
120
  type: Input
70
121
  }], recordChange: [{
71
122
  type: Output
72
123
  }] } });
73
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1maWVsZC10ZW1wbGF0ZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lcXAtZHluYW1pYy1tb2R1bGUvc3JjL2xpYi9jb21wb25lbnRzL3ByaXZhdGUvZmllbGQtdGVtcGxhdGVzL3RleHQtZmllbGQtdGVtcGxhdGUvdGV4dC1maWVsZC10ZW1wbGF0ZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lcXAtZHluYW1pYy1tb2R1bGUvc3JjL2xpYi9jb21wb25lbnRzL3ByaXZhdGUvZmllbGQtdGVtcGxhdGVzL3RleHQtZmllbGQtdGVtcGxhdGUvdGV4dC1maWVsZC10ZW1wbGF0ZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQXFCLE1BQU0sRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFFekcsT0FBTyxFQUFFLFlBQVksRUFBYSxNQUFNLDJDQUEyQyxDQUFDO0FBRXBGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDZDQUE2QyxDQUFDOzs7Ozs7QUFPbkYsTUFBTSxPQUFPLDBCQUEwQjtJQVFyQztRQUpVLGlCQUFZLEdBQXlCLElBQUksWUFBWSxFQUFVLENBQUM7UUFFMUUsa0JBQWEsR0FBRyxZQUFZLENBQUM7SUFFYixDQUFDO0lBRWpCLFFBQVE7UUFDTixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQywwRUFBMEU7UUFDMUUsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksU0FBUyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxXQUFXLElBQUksS0FBSyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLFlBQVksQ0FBQyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxFQUFFO1lBQ2pMLElBQUksQ0FBQyxNQUFNLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLFlBQVksQ0FBQztZQUM3QyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7U0FDcEI7SUFDSCxDQUFDO0lBRUQsWUFBWTtRQUNWLFFBQVEsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUU7WUFDM0IsS0FBSyxZQUFZLENBQUMsS0FBSztnQkFDckIsT0FBTyxPQUFPLENBQUM7WUFDakIsS0FBSyxZQUFZLENBQUMsUUFBUTtnQkFDeEIsT0FBTyxVQUFVLENBQUM7WUFDcEIsS0FBSyxZQUFZLENBQUMsUUFBUTtnQkFDeEIsT0FBTyxLQUFLLENBQUM7WUFDZixLQUFLLFlBQVksQ0FBQyxHQUFHO2dCQUNuQixPQUFPLEtBQUssQ0FBQTtZQUNkO2dCQUNFLE9BQU8sTUFBTSxDQUFDO1NBQ2pCO0lBQ0gsQ0FBQztJQUVEOztPQUVHO0lBQ0gsV0FBVztRQUNULElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUU7WUFDdEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLG9CQUFvQixDQUFDLG9CQUFvQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7U0FDakg7UUFDRCxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxFQUFFO1lBQ3hCLElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxHQUFHLG9CQUFvQixDQUFDLG9CQUFvQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7U0FDNUc7SUFDSCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxtQkFBbUI7UUFDakIsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFO1lBQ3ZCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztTQUNyQztRQUNELElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsRUFBRTtZQUN6QixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7U0FDckM7SUFDSCxDQUFDOzt1SEEzRFUsMEJBQTBCOzJHQUExQiwwQkFBMEIseUtDWHZDLDhsQkFPaUI7MkZESUosMEJBQTBCO2tCQUx0QyxTQUFTOytCQUNFLHFCQUFxQjswRUFNdEIsS0FBSztzQkFBYixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDSSxZQUFZO3NCQUFyQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkNoYW5nZXMsIE9uSW5pdCwgT3V0cHV0LCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFJlY29yZCB9IGZyb20gJy4uLy4uLy4uLy4uL21vZGVscy9yZWNvcmQubW9kZWwnO1xyXG5pbXBvcnQgeyBUZXh0TWFza0VudW0sIFRleHRGaWVsZCB9IGZyb20gJy4uLy4uLy4uLy4uL21vZGVscy9maWVsZHMvdGV4dEZpZWxkLm1vZGVsJztcclxuaW1wb3J0IHsgSUJhc2VGaWVsZENvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uLy4uL2ludGVyZmFjZXMvaUJhc2VGaWVsZENvbXBvbmVudC5pbnRlcmZhY2UnO1xyXG5pbXBvcnQgeyBVdGlsaXR5SGVscGVyU2VydmljZSB9IGZyb20gJy4uLy4uLy4uLy4uL3NlcnZpY2VzL3V0aWxpdHlIZWxwZXIuc2VydmljZXMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd0ZXh0LWZpZWxkLXRlbXBsYXRlJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vdGV4dC1maWVsZC10ZW1wbGF0ZS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vdGV4dC1maWVsZC10ZW1wbGF0ZS5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUZXh0RmllbGRUZW1wbGF0ZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzLCBJQmFzZUZpZWxkQ29tcG9uZW50IHtcclxuXHJcbiAgQElucHV0KCkgZmllbGQ6IFRleHRGaWVsZDtcclxuICBASW5wdXQoKSByZWNvcmQ6IFJlY29yZDtcclxuICBAT3V0cHV0KCkgcmVjb3JkQ2hhbmdlOiBFdmVudEVtaXR0ZXI8UmVjb3JkPiA9IG5ldyBFdmVudEVtaXR0ZXI8UmVjb3JkPigpO1xyXG5cclxuICBJbnB1dE1hc2tFbnVtID0gVGV4dE1hc2tFbnVtO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMudXBkYXRlRmllbGQoKTtcclxuICB9XHJcblxyXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpIHtcclxuICAgIC8vIFNlIHZpZW5lIG1vZGlmaWNhdG8gaWwgdmFsb3JlIGRpIFwibmdNb2RlbElucHV0XCIgYWxsb3JhIGFnZ2lvcm5hIGwnaW5wdXRcclxuICAgIGlmIChjaGFuZ2VzWydyZWNvcmQnXSAhPSB1bmRlZmluZWQgJiYgY2hhbmdlc1sncmVjb3JkJ10uZmlyc3RDaGFuZ2UgPT0gZmFsc2UgJiYgSlNPTi5zdHJpbmdpZnkoY2hhbmdlc1sncmVjb3JkJ10uY3VycmVudFZhbHVlKSAhPSBKU09OLnN0cmluZ2lmeShjaGFuZ2VzWydyZWNvcmQnXS5wcmV2aW91c1ZhbHVlKSkge1xyXG4gICAgICB0aGlzLnJlY29yZCA9IGNoYW5nZXNbJ3JlY29yZCddLmN1cnJlbnRWYWx1ZTtcclxuICAgICAgdGhpcy51cGRhdGVGaWVsZCgpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgZ2V0SW5wdXRUeXBlKCkge1xyXG4gICAgc3dpdGNoICh0aGlzLmZpZWxkLlRleHRNYXNrKSB7XHJcbiAgICAgIGNhc2UgVGV4dE1hc2tFbnVtLkVtYWlsOlxyXG4gICAgICAgIHJldHVybiAnZW1haWwnO1xyXG4gICAgICBjYXNlIFRleHRNYXNrRW51bS5QYXNzd29yZDpcclxuICAgICAgICByZXR1cm4gJ3Bhc3N3b3JkJztcclxuICAgICAgY2FzZSBUZXh0TWFza0VudW0uVGVsZWZvbm86XHJcbiAgICAgICAgcmV0dXJuICd0ZWwnO1xyXG4gICAgICBjYXNlIFRleHRNYXNrRW51bS5Vcmw6XHJcbiAgICAgICAgcmV0dXJuICd1cmwnXHJcbiAgICAgIGRlZmF1bHQ6XHJcbiAgICAgICAgcmV0dXJuICd0ZXh0JztcclxuICAgIH1cclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIE1ldG9kbyBwZXIgYWdnaW9ybmFyZSBpbCB2YWxvcmUgZGVsIGNhbXBvIHF1YW5kbyBxdWVzdG8gw6ggcmFwcHJlc2VudGF0byBkYSB1bmEgZm9ybXVsYS5cclxuICAgKi9cclxuICB1cGRhdGVGaWVsZCgpIHtcclxuICAgIGlmICh0aGlzLmZpZWxkLkZvcm11bGEpIHtcclxuICAgICAgdGhpcy5yZWNvcmRbdGhpcy5maWVsZC5OYW1lXSA9IFV0aWxpdHlIZWxwZXJTZXJ2aWNlLkV2YWx1YXRlRmllbGRGb3JtdWxhKHRoaXMuZmllbGQuRm9ybXVsYSwgdGhpcy5yZWNvcmQsIG51bGwpO1xyXG4gICAgfVxyXG4gICAgaWYgKHRoaXMuZmllbGQuVmlzaWJsZUlmKSB7XHJcbiAgICAgIHRoaXMuZmllbGQuSW5MaXN0VmlldyA9IFV0aWxpdHlIZWxwZXJTZXJ2aWNlLkV2YWx1YXRlRmllbGRGb3JtdWxhKHRoaXMuZmllbGQuVmlzaWJsZUlmLCB0aGlzLnJlY29yZCwgbnVsbCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBNZXRvZG8gcGVyIGVtZXR0ZXJlIGwnZXZlbnRvIGNoZSBpbCB2YWxvcmUgZGVsIHJlY29yZCDDqCBjYW1iaWF0by5cclxuICAgKi9cclxuICBvblJlY29yZFZhbHVlQ2hhbmdlKCkge1xyXG4gICAgaWYgKCF0aGlzLmZpZWxkLkZvcm11bGEpIHtcclxuICAgICAgdGhpcy5yZWNvcmRDaGFuZ2UuZW1pdCh0aGlzLnJlY29yZCk7XHJcbiAgICB9XHJcbiAgICBpZiAoIXRoaXMuZmllbGQuVmlzaWJsZUlmKSB7XHJcbiAgICAgIHRoaXMucmVjb3JkQ2hhbmdlLmVtaXQodGhpcy5yZWNvcmQpO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iLCI8bWF0LWZvcm0tZmllbGQgW2Zvcm1Hcm91cF09XCJmaWVsZC5Gb3JtRm9ybUdyb3VwXCI+XHJcbiAgICA8bWF0LWxhYmVsPiB7e2ZpZWxkLkRlc2NyaXB0aW9ufX0gPC9tYXQtbGFiZWw+XHJcbiAgICA8aW5wdXQgbWF0SW5wdXQgW3R5cGVdPVwiZ2V0SW5wdXRUeXBlKClcIiBbZm9ybUNvbnRyb2xOYW1lXT1cImZpZWxkLk5hbWVcIiBbcmVhZG9ubHldPVwiZmllbGQuUmVhZG9ubHlcIlxyXG4gICAgICAgIFtyZXF1aXJlZF09XCJmaWVsZC5SZXF1aXJlZFwiIFsobmdNb2RlbCldPVwicmVjb3JkW2ZpZWxkLk5hbWVdXCIgKG5nTW9kZWxDaGFuZ2UpPVwib25SZWNvcmRWYWx1ZUNoYW5nZSgpXCI+XHJcbiAgICAgICAgPG1hdC1lcnJvciAqbmdJZj1cIiFmaWVsZC5Gb3JtRm9ybUdyb3VwLnZhbGlkICYmIGZpZWxkLkZvcm1Gb3JtR3JvdXAuY29udHJvbHNbZmllbGQuTmFtZV0udG91Y2hlZCAmJiAhZmllbGQuUmVhZG9ubHlcIj5cclxuICAgICAgICAgICAgTWluLiBDYXJhdHRlcmk6IHt7ZmllbGQuTWluTGVuZ2h0fX0gLSBNYXguIENhcmF0dGVyaToge3tmaWVsZC5NYXhMZW5naHR9fVxyXG4gICAgICAgICAgPC9tYXQtZXJyb3I+XHJcbjwvbWF0LWZvcm0tZmllbGQ+Il19
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-field-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/text-field-template/text-field-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/text-field-template/text-field-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { TextMaskEnum, TextField } from '../../../../models/fields/textField.model';\r\nimport { IBaseFieldComponent } from '../../../../interfaces/iBaseFieldComponent.interface';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { VoiceRecognitionService } from '../../../../services/voice-recognition.service';\r\nimport { interval, Subscription } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'text-field-template',\r\n  templateUrl: './text-field-template.component.html',\r\n  styleUrls: ['./text-field-template.component.scss']\r\n})\r\nexport class TextFieldTemplateComponent implements OnInit, OnChanges, IBaseFieldComponent {\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  //variabili esterne per l'input dei campi\r\n  @Input() field: TextField;\r\n  @Input() record: Record;\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\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n  InputMaskEnum = TextMaskEnum;\r\n\r\n\r\n  constructor(public voiceservice: VoiceRecognitionService) {\r\n    this.voiceservice.init();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.updateField();\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.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)   \r\n      this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);\r\n }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    // Se viene modificato il valore di \"ngModelInput\" allora aggiorna l'input\r\n    if (changes['record'] != undefined && changes['record'].firstChange == false && JSON.stringify(changes['record'].currentValue) != JSON.stringify(changes['record'].previousValue)) {\r\n      this.record = changes['record'].currentValue;\r\n      this.updateField();\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.record[this.field.Name] == null || this.record[this.field.Name] == undefined) {\r\n          this.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  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  updateRTVoiceField() {\r\n    this.record[this.field.Name] = this.voiceservice.text + this.newtext;\r\n    this.newtext = '';\r\n  }\r\n  updateVoiceField() {\r\n    this.newtext = '';\r\n    this.record[this.field.Name] = this.voiceservice.text;\r\n  }\r\n\r\n  /**\r\n   * Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.\r\n   */\r\n  updateField() {\r\n    if (this.field.Formula) {\r\n      this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);\r\n    }\r\n    if (this.field.VisibleIf) {\r\n      this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, null);\r\n    }\r\n    if (!this.isStillRecoginze) {\r\n      if (this.record[this.field.Name] != null || this.record[this.field.Name] != undefined) {\r\n        this.voiceservice.text = this.record[this.field.Name];\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Metodo per emettere l'evento che il valore del record è cambiato.\r\n   */\r\n  onRecordValueChange() {\r\n    if (!this.field.Formula) {\r\n      this.recordChange.emit(this.record);\r\n    }\r\n    if (!this.field.VisibleIf) {\r\n      this.recordChange.emit(this.record);\r\n    }\r\n  }\r\n}\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 [type]=\"getInputType()\"  [formControlName]=\"field.Name\" [readonly]=\"field.Readonly\"\r\n        [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\" (ngModelChange)=\"onRecordValueChange()\">\r\n        <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n            Min. Caratteri: {{field.MinLenght}} - Max. Caratteri: {{field.MaxLenght}}\r\n          </mat-error>\r\n          <mat-icon (click)=\"ttsClick()\" matSuffix style=\"cursor: pointer;\" [color]=\"!isStillRecoginze ? '' : 'warn'\">keyboard_voice</mat-icon> \r\n</mat-form-field>"]}
@@ -1,16 +1,32 @@
1
1
  import { Component, EventEmitter, Input, Output } from '@angular/core';
2
2
  import { UtilityHelperService } from '../../../../services/utilityHelper.services';
3
+ import { VoiceRecognitionService } from '../../../../services/voice-recognition.service';
4
+ import { interval } from 'rxjs';
3
5
  import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/material/form-field";
5
- import * as i2 from "@angular/material/input";
6
- import * as i3 from "@angular/forms";
7
- import * as i4 from "@angular/common";
6
+ import * as i1 from "../../../../services/voice-recognition.service";
7
+ import * as i2 from "@angular/material/form-field";
8
+ import * as i3 from "@angular/material/input";
9
+ import * as i4 from "@angular/material/icon";
10
+ import * as i5 from "@angular/forms";
11
+ import * as i6 from "@angular/common";
8
12
  export class TextareaFieldTemplateComponent {
9
- constructor() {
13
+ constructor(voiceservice) {
14
+ this.voiceservice = voiceservice;
15
+ this.isStillRecoginze = false;
16
+ this.source = interval(200);
10
17
  this.recordChange = new EventEmitter();
18
+ this.voiceservice.init();
11
19
  }
12
20
  ngOnInit() {
13
21
  this.updateField();
22
+ this.initStyles();
23
+ }
24
+ initStyles() {
25
+ //Funzione per parsare il campo stylecss dell'oggetto field ed applicarlo all'html
26
+ if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)
27
+ this.FieldstyleObj = UtilityHelperService.initStyles(this.field.FieldstyleCSS);
28
+ if (this.field.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)
29
+ this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);
14
30
  }
15
31
  ngOnChanges(changes) {
16
32
  // Se viene modificato il valore di "ngModelInput" allora aggiorna l'input
@@ -19,6 +35,27 @@ export class TextareaFieldTemplateComponent {
19
35
  this.updateField();
20
36
  }
21
37
  }
38
+ ttsClick() {
39
+ if (!this.isStillRecoginze) {
40
+ this.newtext = '';
41
+ this.isStillRecoginze = this.voiceservice.start() === true ? true : false;
42
+ this.subscription = this.source.subscribe(val => {
43
+ if (this.record[this.field.Name] == null || this.record[this.field.Name] == undefined) {
44
+ this.record[this.field.Name] = this.voiceservice.transcript_arr[this.voiceservice.transcript_arr.length - 1];
45
+ }
46
+ else {
47
+ this.newtext = this.voiceservice.transcript_arr[this.voiceservice.transcript_arr.length - 1];
48
+ if (this.newtext != undefined)
49
+ this.updateRTVoiceField();
50
+ }
51
+ });
52
+ }
53
+ else {
54
+ this.isStillRecoginze = this.voiceservice.stop() === false ? false : true;
55
+ this.subscription.unsubscribe();
56
+ this.updateVoiceField();
57
+ }
58
+ }
22
59
  /**
23
60
  * Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.
24
61
  */
@@ -29,6 +66,19 @@ export class TextareaFieldTemplateComponent {
29
66
  if (this.field.VisibleIf) {
30
67
  this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, null);
31
68
  }
69
+ if (!this.isStillRecoginze) {
70
+ if (this.record[this.field.Name] != null || this.record[this.field.Name] != undefined) {
71
+ this.voiceservice.text = this.record[this.field.Name];
72
+ }
73
+ }
74
+ }
75
+ updateRTVoiceField() {
76
+ this.record[this.field.Name] = this.voiceservice.text + this.newtext;
77
+ this.newtext = '';
78
+ }
79
+ updateVoiceField() {
80
+ this.newtext = '';
81
+ this.record[this.field.Name] = this.voiceservice.text;
32
82
  }
33
83
  /**
34
84
  * Metodo per emettere l'evento che il valore del record è cambiato.
@@ -39,16 +89,16 @@ export class TextareaFieldTemplateComponent {
39
89
  }
40
90
  }
41
91
  }
42
- TextareaFieldTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: TextareaFieldTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
43
- TextareaFieldTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.8", type: TextareaFieldTemplateComponent, selector: "textarea-field-template", inputs: { field: "field", record: "record" }, outputs: { recordChange: "recordChange" }, usesOnChanges: true, ngImport: i0, template: "<mat-form-field [formGroup]=\"field.FormFormGroup\">\r\n <textarea matInput [placeholder]=\"field.Description\" [rows]=\"field.Rows\" [formControlName]=\"field.Name\"\r\n [readonly]=\"field.Readonly\" [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\"\r\n (ngModelChange)=\"onRecordValueChange()\"></textarea>\r\n <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n Min. Caratteri: {{field.MinLenght}} - Max. Caratteri: {{field.MaxLenght}}\r\n </mat-error>\r\n</mat-form-field>", styles: ["input.ng-touched.ng-invalid,input.ng-dirty.ng-invalid{border:red 2px solid!important}\n"], dependencies: [{ kind: "directive", type: i1.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { 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: "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.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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"] }] });
92
+ TextareaFieldTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: TextareaFieldTemplateComponent, deps: [{ token: i1.VoiceRecognitionService }], target: i0.ɵɵFactoryTarget.Component });
93
+ TextareaFieldTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.8", type: TextareaFieldTemplateComponent, selector: "textarea-field-template", inputs: { field: "field", record: "record" }, outputs: { recordChange: "recordChange" }, providers: [VoiceRecognitionService], usesOnChanges: true, ngImport: i0, template: "<mat-form-field [formGroup]=\"field.FormFormGroup\"> \r\n <mat-label class=\"ps-3\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n <textarea class=\"pt-2 mt-2\" [ngStyle]=\"FieldstyleObj\" matInput [placeholder]=\"field.Description\" [rows]=\"field.Rows\" [formControlName]=\"field.Name\"\r\n [readonly]=\"field.Readonly\" [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\"\r\n (ngModelChange)=\"onRecordValueChange()\"></textarea>\r\n <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n Min. Caratteri: {{field.MinLenght}} - Max. Caratteri: {{field.MaxLenght}}\r\n </mat-error>\r\n <mat-icon (click)=\"ttsClick()\" matSuffix style=\"cursor: pointer;\" [color]=\"!isStillRecoginze ? '' : 'warn'\">keyboard_voice</mat-icon> \r\n</mat-form-field>\r\n", styles: ["input.ng-touched.ng-invalid,input.ng-dirty.ng-invalid{border:red 2px solid!important}::ng-deep .mat-input-element{background-color:#fff}::ng-deep .mat-form-field-label{font-size:x-large}::ng-deep textarea#mat-input-50{min-height:55px}::ng-deep label#mat-form-field-label-133{padding-top:7px}\n"], dependencies: [{ kind: "directive", type: i2.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.MatSuffix, selector: "[matSuffix]" }, { kind: "directive", type: i3.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: 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.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { 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: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
44
94
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: TextareaFieldTemplateComponent, decorators: [{
45
95
  type: Component,
46
- args: [{ selector: 'textarea-field-template', template: "<mat-form-field [formGroup]=\"field.FormFormGroup\">\r\n <textarea matInput [placeholder]=\"field.Description\" [rows]=\"field.Rows\" [formControlName]=\"field.Name\"\r\n [readonly]=\"field.Readonly\" [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\"\r\n (ngModelChange)=\"onRecordValueChange()\"></textarea>\r\n <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n Min. Caratteri: {{field.MinLenght}} - Max. Caratteri: {{field.MaxLenght}}\r\n </mat-error>\r\n</mat-form-field>", styles: ["input.ng-touched.ng-invalid,input.ng-dirty.ng-invalid{border:red 2px solid!important}\n"] }]
47
- }], ctorParameters: function () { return []; }, propDecorators: { field: [{
96
+ args: [{ selector: 'textarea-field-template', providers: [VoiceRecognitionService], template: "<mat-form-field [formGroup]=\"field.FormFormGroup\"> \r\n <mat-label class=\"ps-3\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n <textarea class=\"pt-2 mt-2\" [ngStyle]=\"FieldstyleObj\" matInput [placeholder]=\"field.Description\" [rows]=\"field.Rows\" [formControlName]=\"field.Name\"\r\n [readonly]=\"field.Readonly\" [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\"\r\n (ngModelChange)=\"onRecordValueChange()\"></textarea>\r\n <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n Min. Caratteri: {{field.MinLenght}} - Max. Caratteri: {{field.MaxLenght}}\r\n </mat-error>\r\n <mat-icon (click)=\"ttsClick()\" matSuffix style=\"cursor: pointer;\" [color]=\"!isStillRecoginze ? '' : 'warn'\">keyboard_voice</mat-icon> \r\n</mat-form-field>\r\n", styles: ["input.ng-touched.ng-invalid,input.ng-dirty.ng-invalid{border:red 2px solid!important}::ng-deep .mat-input-element{background-color:#fff}::ng-deep .mat-form-field-label{font-size:x-large}::ng-deep textarea#mat-input-50{min-height:55px}::ng-deep label#mat-form-field-label-133{padding-top:7px}\n"] }]
97
+ }], ctorParameters: function () { return [{ type: i1.VoiceRecognitionService }]; }, propDecorators: { field: [{
48
98
  type: Input
49
99
  }], record: [{
50
100
  type: Input
51
101
  }], recordChange: [{
52
102
  type: Output
53
103
  }] } });
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGFyZWEtZmllbGQtdGVtcGxhdGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXFwLWR5bmFtaWMtbW9kdWxlL3NyYy9saWIvY29tcG9uZW50cy9wcml2YXRlL2ZpZWxkLXRlbXBsYXRlcy90ZXh0YXJlYS1maWVsZC10ZW1wbGF0ZS90ZXh0YXJlYS1maWVsZC10ZW1wbGF0ZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lcXAtZHluYW1pYy1tb2R1bGUvc3JjL2xpYi9jb21wb25lbnRzL3ByaXZhdGUvZmllbGQtdGVtcGxhdGVzL3RleHRhcmVhLWZpZWxkLXRlbXBsYXRlL3RleHRhcmVhLWZpZWxkLXRlbXBsYXRlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBcUIsTUFBTSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUV6RyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQzs7Ozs7O0FBU25GLE1BQU0sT0FBTyw4QkFBOEI7SUFNekM7UUFGVSxpQkFBWSxHQUF5QixJQUFJLFlBQVksRUFBVSxDQUFDO0lBRTFELENBQUM7SUFFakIsUUFBUTtRQUNOLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBQ2hDLDBFQUEwRTtRQUMxRSxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxTQUFTLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLFdBQVcsSUFBSSxLQUFLLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsWUFBWSxDQUFDLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsYUFBYSxDQUFDLEVBQUU7WUFDakwsSUFBSSxDQUFDLE1BQU0sR0FBRyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsWUFBWSxDQUFDO1lBQzdDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUNwQjtJQUNILENBQUM7SUFFRDs7T0FFRztJQUNILFdBQVc7UUFDVCxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFO1lBQ3RCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxvQkFBb0IsQ0FBQyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO1NBQ2pIO1FBQ0QsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsRUFBRTtZQUN4QixJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsR0FBRyxvQkFBb0IsQ0FBQyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO1NBQzVHO0lBQ0gsQ0FBQztJQUVEOztPQUVHO0lBQ0gsbUJBQW1CO1FBQ2pCLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRTtZQUN2QixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7U0FDckM7SUFDSCxDQUFDOzsySEF2Q1UsOEJBQThCOytHQUE5Qiw4QkFBOEIsNktDWDNDLDZsQkFPaUI7MkZESUosOEJBQThCO2tCQUwxQyxTQUFTOytCQUNFLHlCQUF5QjswRUFNMUIsS0FBSztzQkFBYixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDSSxZQUFZO3NCQUFyQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkNoYW5nZXMsIE9uSW5pdCwgT3V0cHV0LCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IElCYXNlRmllbGRDb21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi8uLi9pbnRlcmZhY2VzL2lCYXNlRmllbGRDb21wb25lbnQuaW50ZXJmYWNlJztcclxuaW1wb3J0IHsgVXRpbGl0eUhlbHBlclNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi8uLi9zZXJ2aWNlcy91dGlsaXR5SGVscGVyLnNlcnZpY2VzJztcclxuaW1wb3J0IHsgUmVjb3JkIH0gZnJvbSAnLi4vLi4vLi4vLi4vbW9kZWxzL3JlY29yZC5tb2RlbCc7XHJcbmltcG9ydCB7IFRleHRhcmVhRmllbGQgfSBmcm9tICcuLi8uLi8uLi8uLi9tb2RlbHMvZmllbGRzL3RleHRhcmVhRmllbGQubW9kZWwnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICd0ZXh0YXJlYS1maWVsZC10ZW1wbGF0ZScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3RleHRhcmVhLWZpZWxkLXRlbXBsYXRlLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi90ZXh0YXJlYS1maWVsZC10ZW1wbGF0ZS5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUZXh0YXJlYUZpZWxkVGVtcGxhdGVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcywgSUJhc2VGaWVsZENvbXBvbmVudCB7XHJcblxyXG4gIEBJbnB1dCgpIGZpZWxkOiBUZXh0YXJlYUZpZWxkO1xyXG4gIEBJbnB1dCgpIHJlY29yZDogUmVjb3JkO1xyXG4gIEBPdXRwdXQoKSByZWNvcmRDaGFuZ2U6IEV2ZW50RW1pdHRlcjxSZWNvcmQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxSZWNvcmQ+KCk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy51cGRhdGVGaWVsZCgpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcykge1xyXG4gICAgLy8gU2UgdmllbmUgbW9kaWZpY2F0byBpbCB2YWxvcmUgZGkgXCJuZ01vZGVsSW5wdXRcIiBhbGxvcmEgYWdnaW9ybmEgbCdpbnB1dFxyXG4gICAgaWYgKGNoYW5nZXNbJ3JlY29yZCddICE9IHVuZGVmaW5lZCAmJiBjaGFuZ2VzWydyZWNvcmQnXS5maXJzdENoYW5nZSA9PSBmYWxzZSAmJiBKU09OLnN0cmluZ2lmeShjaGFuZ2VzWydyZWNvcmQnXS5jdXJyZW50VmFsdWUpICE9IEpTT04uc3RyaW5naWZ5KGNoYW5nZXNbJ3JlY29yZCddLnByZXZpb3VzVmFsdWUpKSB7XHJcbiAgICAgIHRoaXMucmVjb3JkID0gY2hhbmdlc1sncmVjb3JkJ10uY3VycmVudFZhbHVlO1xyXG4gICAgICB0aGlzLnVwZGF0ZUZpZWxkKCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBNZXRvZG8gcGVyIGFnZ2lvcm5hcmUgaWwgdmFsb3JlIGRlbCBjYW1wbyBxdWFuZG8gcXVlc3RvIMOoIHJhcHByZXNlbnRhdG8gZGEgdW5hIGZvcm11bGEuXHJcbiAgICovXHJcbiAgdXBkYXRlRmllbGQoKSB7XHJcbiAgICBpZiAodGhpcy5maWVsZC5Gb3JtdWxhKSB7XHJcbiAgICAgIHRoaXMucmVjb3JkW3RoaXMuZmllbGQuTmFtZV0gPSBVdGlsaXR5SGVscGVyU2VydmljZS5FdmFsdWF0ZUZpZWxkRm9ybXVsYSh0aGlzLmZpZWxkLkZvcm11bGEsIHRoaXMucmVjb3JkLCBudWxsKTtcclxuICAgIH1cclxuICAgIGlmICh0aGlzLmZpZWxkLlZpc2libGVJZikge1xyXG4gICAgICB0aGlzLmZpZWxkLkluTGlzdFZpZXcgPSBVdGlsaXR5SGVscGVyU2VydmljZS5FdmFsdWF0ZUZpZWxkRm9ybXVsYSh0aGlzLmZpZWxkLlZpc2libGVJZiwgdGhpcy5yZWNvcmQsIG51bGwpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogTWV0b2RvIHBlciBlbWV0dGVyZSBsJ2V2ZW50byBjaGUgaWwgdmFsb3JlIGRlbCByZWNvcmQgw6ggY2FtYmlhdG8uXHJcbiAgICovXHJcbiAgb25SZWNvcmRWYWx1ZUNoYW5nZSgpIHtcclxuICAgIGlmICghdGhpcy5maWVsZC5Gb3JtdWxhKSB7XHJcbiAgICAgIHRoaXMucmVjb3JkQ2hhbmdlLmVtaXQodGhpcy5yZWNvcmQpO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iLCI8bWF0LWZvcm0tZmllbGQgW2Zvcm1Hcm91cF09XCJmaWVsZC5Gb3JtRm9ybUdyb3VwXCI+XHJcbiAgICA8dGV4dGFyZWEgbWF0SW5wdXQgW3BsYWNlaG9sZGVyXT1cImZpZWxkLkRlc2NyaXB0aW9uXCIgW3Jvd3NdPVwiZmllbGQuUm93c1wiIFtmb3JtQ29udHJvbE5hbWVdPVwiZmllbGQuTmFtZVwiXHJcbiAgICBbcmVhZG9ubHldPVwiZmllbGQuUmVhZG9ubHlcIiBbcmVxdWlyZWRdPVwiZmllbGQuUmVxdWlyZWRcIiBbKG5nTW9kZWwpXT1cInJlY29yZFtmaWVsZC5OYW1lXVwiXHJcbiAgICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwib25SZWNvcmRWYWx1ZUNoYW5nZSgpXCI+PC90ZXh0YXJlYT5cclxuICAgICAgICA8bWF0LWVycm9yICpuZ0lmPVwiIWZpZWxkLkZvcm1Gb3JtR3JvdXAudmFsaWQgJiYgZmllbGQuRm9ybUZvcm1Hcm91cC5jb250cm9sc1tmaWVsZC5OYW1lXS50b3VjaGVkICYmICFmaWVsZC5SZWFkb25seVwiPlxyXG4gICAgICAgICAgICBNaW4uIENhcmF0dGVyaToge3tmaWVsZC5NaW5MZW5naHR9fSAtIE1heC4gQ2FyYXR0ZXJpOiB7e2ZpZWxkLk1heExlbmdodH19XHJcbiAgICAgICAgICA8L21hdC1lcnJvcj5cclxuPC9tYXQtZm9ybS1maWVsZD4iXX0=
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textarea-field-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/textarea-field-template/textarea-field-template.component.ts","../../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/field-templates/textarea-field-template/textarea-field-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { IBaseFieldComponent } from '../../../../interfaces/iBaseFieldComponent.interface';\r\nimport { UtilityHelperService } from '../../../../services/utilityHelper.services';\r\nimport { Record } from '../../../../models/record.model';\r\nimport { TextareaField } from '../../../../models/fields/textareaField.model';\r\nimport { VoiceRecognitionService } from '../../../../services/voice-recognition.service';\r\nimport { interval, Subscription } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'textarea-field-template',\r\n  templateUrl: './textarea-field-template.component.html',\r\n  styleUrls: ['./textarea-field-template.component.scss'],\r\n  providers: [VoiceRecognitionService],\r\n})\r\nexport class TextareaFieldTemplateComponent implements OnInit, OnChanges, IBaseFieldComponent {\r\n  isStillRecoginze = false;\r\n  @Input() field: TextareaField;\r\n  @Input() record: Record;\r\n  source = interval(200);\r\n  newtext: string;\r\n  @Output() recordChange: EventEmitter<Record> = new EventEmitter<Record>();\r\n  subscription: Subscription;\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\n  constructor(public voiceservice: VoiceRecognitionService) {\r\n    this.voiceservice.init();\r\n  }\r\n  ngOnInit(): void {\r\n    this.updateField();\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.FieldstyleCSS != null || this.field.FieldstyleCSS != undefined)   \r\n      this.LabelstyleObj = UtilityHelperService.initStyles(this.field.LabelstyleCSS);\r\n }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    // Se viene modificato il valore di \"ngModelInput\" allora aggiorna l'input\r\n    if (changes['record'] != undefined && changes['record'].firstChange == false && JSON.stringify(changes['record'].currentValue) != JSON.stringify(changes['record'].previousValue)) {\r\n      this.record = changes['record'].currentValue;\r\n      this.updateField();\r\n    }\r\n  }\r\n  ttsClick() {\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.record[this.field.Name] == null || this.record[this.field.Name] == undefined) {\r\n          this.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   * Metodo per aggiornare il valore del campo quando questo è rappresentato da una formula.\r\n   */\r\n  updateField() {\r\n    if (this.field.Formula) {\r\n      this.record[this.field.Name] = UtilityHelperService.EvaluateFieldFormula(this.field.Formula, this.record, null);\r\n    }\r\n    if (this.field.VisibleIf) {\r\n      this.field.InListView = UtilityHelperService.EvaluateFieldFormula(this.field.VisibleIf, this.record, null);\r\n    }\r\n    if (!this.isStillRecoginze) {\r\n      if (this.record[this.field.Name] != null || this.record[this.field.Name] != undefined) {\r\n        this.voiceservice.text = this.record[this.field.Name];\r\n      }\r\n    }\r\n  }\r\n  updateRTVoiceField() {\r\n    this.record[this.field.Name] = this.voiceservice.text + this.newtext;\r\n    this.newtext = '';\r\n  }\r\n  updateVoiceField() {\r\n    this.newtext = '';\r\n    this.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  onRecordValueChange() {\r\n    if (!this.field.Formula) {\r\n      this.recordChange.emit(this.record);\r\n    }\r\n  }\r\n}\r\n","<mat-form-field [formGroup]=\"field.FormFormGroup\">  \r\n    <mat-label class=\"ps-3\" [ngStyle]=\"LabelstyleObj\"> {{field.Description}} </mat-label>\r\n    <textarea class=\"pt-2 mt-2\" [ngStyle]=\"FieldstyleObj\" matInput [placeholder]=\"field.Description\" [rows]=\"field.Rows\" [formControlName]=\"field.Name\"\r\n    [readonly]=\"field.Readonly\" [required]=\"field.Required\" [(ngModel)]=\"record[field.Name]\"\r\n        (ngModelChange)=\"onRecordValueChange()\"></textarea>\r\n        <mat-error *ngIf=\"!field.FormFormGroup.valid && field.FormFormGroup.controls[field.Name].touched && !field.Readonly\">\r\n            Min. Caratteri: {{field.MinLenght}} - Max. Caratteri: {{field.MaxLenght}}\r\n          </mat-error>\r\n          <mat-icon (click)=\"ttsClick()\" matSuffix style=\"cursor: pointer;\" [color]=\"!isStillRecoginze ? '' : 'warn'\">keyboard_voice</mat-icon> \r\n</mat-form-field>\r\n"]}
@@ -107,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImpor
107
107
  ]
108
108
  }]
109
109
  }] });
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eqp-dynamic-module.module.js","sourceRoot":"","sources":["../../../../projects/eqp-dynamic-module/src/lib/eqp-dynamic-module.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { NgModule } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { EqpDynamicModuleComponent } from './components/exported/eqp-dynamic-module/eqp-dynamic-module.component';\r\nimport { MaterialModule } from './modules/material.module';\r\n\r\nimport { EqpTableModule } from '@eqproject/eqp-table';\r\nimport { EqpAttachmentsModule } from '@eqproject/eqp-attachments';\r\nimport { EqpSelectModule } from '@eqproject/eqp-select';\r\nimport { EqpDatetimepickerModule } from '@eqproject/eqp-datetimepicker';\r\nimport { EqpImgDrawingModule } from '@eqproject/eqp-img-drawing';\r\nimport { EqpFiltersModule } from '@eqproject/eqp-filters';\r\nimport { EqpNumericModule } from '@eqproject/eqp-numeric';\r\nimport { EqpDynamicModuleConfiguratorComponent } from './components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component';\r\nimport { AddFormFieldComponent } from './components/private/add-form-field/add-form-field.component';\r\nimport { TextFieldTemplateComponent } from './components/private/field-templates/text-field-template/text-field-template.component';\r\nimport { BooleanFieldTemplateComponent } from './components/private/field-templates/boolean-field-template/boolean-field-template.component';\r\nimport { DateFieldTemplateComponent } from './components/private/field-templates/date-field-template/date-field-template.component';\r\nimport { TextareaFieldTemplateComponent } from './components/private/field-templates/textarea-field-template/textarea-field-template.component';\r\nimport { NumericFieldTemplateComponent } from './components/private/field-templates/numeric-field-template/numeric-field-template.component';\r\nimport { ListValueFieldTemplateComponent } from './components/private/field-templates/list-value-field-template/list-value-field-template.component';\r\nimport { AttachmentFieldTemplateComponent } from './components/private/field-templates/attachment-field-template/attachment-field-template.component';\r\nimport { ImageFieldTemplateComponent } from './components/private/field-templates/image-field-template/image-field-template.component';\r\nimport { ListFormRecordComponent } from './components/private/form-records/list-form-record/list-form-record.component';\r\nimport { AddFormRecordComponent } from './components/private/form-records/add-form-record/add-form-record.component';\r\nimport { DynamicModuleFieldComponent } from './components/private/dynamic-module-field/dynamic-module-field.component';\r\nimport { SpinnerComponent } from './components/private/spinner/spinner.component';\r\nimport { DynamicModuleFieldFixComponent } from './components/private/dynamic-module-field-fix/dynamic-module-field.component';\r\n\r\n@NgModule({\r\n  declarations: [\r\n    EqpDynamicModuleComponent,\r\n    EqpDynamicModuleConfiguratorComponent,\r\n    AddFormFieldComponent,\r\n    TextFieldTemplateComponent,\r\n    BooleanFieldTemplateComponent,\r\n    DateFieldTemplateComponent,\r\n    TextareaFieldTemplateComponent,\r\n    NumericFieldTemplateComponent,\r\n    ListValueFieldTemplateComponent,\r\n    AttachmentFieldTemplateComponent,\r\n    ImageFieldTemplateComponent,\r\n    ListFormRecordComponent,\r\n    AddFormRecordComponent,\r\n    DynamicModuleFieldComponent,\r\n    DynamicModuleFieldFixComponent,\r\n    SpinnerComponent,\r\n  ],\r\n  imports: [\r\n    MaterialModule,\r\n    FormsModule,\r\n    CommonModule,\r\n    ReactiveFormsModule,\r\n    EqpTableModule,\r\n    EqpAttachmentsModule,\r\n    EqpSelectModule,\r\n    EqpDatetimepickerModule,\r\n    EqpFiltersModule,\r\n    EqpNumericModule,\r\n    EqpImgDrawingModule\r\n  ],\r\n  exports: [\r\n    EqpDynamicModuleComponent,\r\n    EqpDynamicModuleConfiguratorComponent\r\n  ]\r\n})\r\nexport class EqpDynamicModuleModule { }\r\n"]}
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eqp-dynamic-module.module.js","sourceRoot":"","sources":["../../../../projects/eqp-dynamic-module/src/lib/eqp-dynamic-module.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { NgModule } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { EqpDynamicModuleComponent } from './components/exported/eqp-dynamic-module/eqp-dynamic-module.component';\r\nimport { MaterialModule } from './modules/material.module';\r\nimport { EqpTableModule } from '@eqproject/eqp-table';\r\nimport { EqpAttachmentsModule } from '@eqproject/eqp-attachments';\r\nimport { EqpSelectModule } from '@eqproject/eqp-select';\r\nimport { EqpDatetimepickerModule } from '@eqproject/eqp-datetimepicker';\r\nimport { EqpImgDrawingModule } from '@eqproject/eqp-img-drawing';\r\nimport { EqpFiltersModule } from '@eqproject/eqp-filters';\r\nimport { EqpNumericModule } from '@eqproject/eqp-numeric';\r\nimport { EqpDynamicModuleConfiguratorComponent } from './components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component';\r\nimport { AddFormFieldComponent } from './components/private/add-form-field/add-form-field.component';\r\nimport { TextFieldTemplateComponent } from './components/private/field-templates/text-field-template/text-field-template.component';\r\nimport { BooleanFieldTemplateComponent } from './components/private/field-templates/boolean-field-template/boolean-field-template.component';\r\nimport { DateFieldTemplateComponent } from './components/private/field-templates/date-field-template/date-field-template.component';\r\nimport { TextareaFieldTemplateComponent } from './components/private/field-templates/textarea-field-template/textarea-field-template.component';\r\nimport { NumericFieldTemplateComponent } from './components/private/field-templates/numeric-field-template/numeric-field-template.component';\r\nimport { ListValueFieldTemplateComponent } from './components/private/field-templates/list-value-field-template/list-value-field-template.component';\r\nimport { AttachmentFieldTemplateComponent } from './components/private/field-templates/attachment-field-template/attachment-field-template.component';\r\nimport { ImageFieldTemplateComponent } from './components/private/field-templates/image-field-template/image-field-template.component';\r\nimport { ListFormRecordComponent } from './components/private/form-records/list-form-record/list-form-record.component';\r\nimport { AddFormRecordComponent } from './components/private/form-records/add-form-record/add-form-record.component';\r\nimport { DynamicModuleFieldComponent } from './components/private/dynamic-module-field/dynamic-module-field.component';\r\nimport { SpinnerComponent } from './components/private/spinner/spinner.component';\r\nimport { DynamicModuleFieldFixComponent } from './components/private/dynamic-module-field-fix/dynamic-module-field.component';\r\n\r\n@NgModule({\r\n  declarations: [\r\n    EqpDynamicModuleComponent,\r\n    EqpDynamicModuleConfiguratorComponent,\r\n    AddFormFieldComponent,\r\n    TextFieldTemplateComponent,\r\n    BooleanFieldTemplateComponent,\r\n    DateFieldTemplateComponent,\r\n    TextareaFieldTemplateComponent,\r\n    NumericFieldTemplateComponent,\r\n    ListValueFieldTemplateComponent,\r\n    AttachmentFieldTemplateComponent,\r\n    ImageFieldTemplateComponent,\r\n    ListFormRecordComponent,\r\n    AddFormRecordComponent,\r\n    DynamicModuleFieldComponent,\r\n    DynamicModuleFieldFixComponent,\r\n    SpinnerComponent,\r\n  ],\r\n  imports: [\r\n    MaterialModule,\r\n    FormsModule,\r\n    CommonModule,\r\n    ReactiveFormsModule,\r\n    EqpTableModule,\r\n    EqpAttachmentsModule,\r\n    EqpSelectModule,\r\n    EqpDatetimepickerModule,\r\n    EqpFiltersModule,\r\n    EqpNumericModule,\r\n    EqpImgDrawingModule\r\n  ],\r\n  exports: [\r\n    EqpDynamicModuleComponent,\r\n    EqpDynamicModuleConfiguratorComponent\r\n  ]\r\n})\r\nexport class EqpDynamicModuleModule { }\r\n"]}
@@ -33,4 +33,4 @@ export var ColSpanSizesEnum;
33
33
  ColSpanSizesEnum[ColSpanSizesEnum["col-lg-6"] = 11] = "col-lg-6";
34
34
  ColSpanSizesEnum[ColSpanSizesEnum["col-lg-12"] = 12] = "col-lg-12";
35
35
  })(ColSpanSizesEnum || (ColSpanSizesEnum = {}));
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZUZpZWxkLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXFwLWR5bmFtaWMtbW9kdWxlL3NyYy9saWIvbW9kZWxzL2Jhc2VGaWVsZC5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFMUM7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLFNBQVUsU0FBUSxPQUFPO0NBOEJyQztBQUVELE1BQU0sQ0FBTixJQUFZLGFBV1g7QUFYRCxXQUFZLGFBQWE7SUFDckIscUVBQW9CLENBQUE7SUFDcEIsbUVBQW1CLENBQUE7SUFDbkIseURBQWMsQ0FBQTtJQUNkLGlFQUFrQixDQUFBO0lBQ2xCLHFFQUFvQixDQUFBO0lBQ3BCLHlEQUFjLENBQUE7SUFDZCx5REFBYyxDQUFBO0lBQ2QsdUVBQXFCLENBQUE7SUFDckIscURBQVksQ0FBQTtJQUNaLDRFQUF3QixDQUFBO0FBQzVCLENBQUMsRUFYVyxhQUFhLEtBQWIsYUFBYSxRQVd4QjtBQUVELE1BQU0sQ0FBTixJQUFZLGdCQWVYO0FBZkQsV0FBWSxnQkFBZ0I7SUFDeEIsK0RBQWMsQ0FBQTtJQUNkLCtEQUFjLENBQUE7SUFDZCwrREFBYyxDQUFBO0lBQ2QsaUVBQWUsQ0FBQTtJQUVmLCtEQUFjLENBQUE7SUFDZCwrREFBYyxDQUFBO0lBQ2QsK0RBQWMsQ0FBQTtJQUNkLGlFQUFlLENBQUE7SUFFZiwrREFBYyxDQUFBO0lBQ2QsZ0VBQWUsQ0FBQTtJQUNmLGdFQUFlLENBQUE7SUFDZixrRUFBZ0IsQ0FBQTtBQUNwQixDQUFDLEVBZlcsZ0JBQWdCLEtBQWhCLGdCQUFnQixRQWUzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVudHlwZWRGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IEJhc2VPYmogfSBmcm9tICcuL2Jhc2VPYmoubW9kZWwnO1xyXG5cclxuLyoqXHJcbiAqIENvbnRpZW5lIGxlIGluZm9ybWF6aW9uaSBkaSBiYXNlIGRlbCBjYW1wbywgaW5kaXBlbmRlbnRlbWVudGUgZGFsIHRpcG8uXHJcbiAqIFF1ZXN0YSBjbGFzc2Ugw6ggdm9sdXRhbWVudGUgYXN0cmF0dGEgcGVyY2jDqSBpbCB0aXBvIGRpIGNhbXBvIMOoIGRldHRhdG8gZGFsIHRpcG9cclxuICovXHJcbmV4cG9ydCBjbGFzcyBCYXNlRmllbGQgZXh0ZW5kcyBCYXNlT2JqIHtcclxuICAgIC8qKlxyXG4gICAgICogTm9tZSBkZWwgY2FtcG8gY2hlIHBlciBwcm9nZXR0YXppb25lIMOoIHVuYSBzb3N0aXR1emlvbmUgZGVsbGEgbGFiZWxcclxuICAgICAqIElsIHZlcm8gaWRlbnRpZmljYXRpdm8gZGVsIGNhbXBvIMOoIGwnSURcclxuICAgICAqL1xyXG4gICAgTmFtZTogc3RyaW5nO1xyXG4gICAgTGFiZWw6IHN0cmluZztcclxuICAgIERlc2NyaXB0aW9uOiBzdHJpbmc7XHJcbiAgICBSZXF1aXJlZDogYm9vbGVhbjtcclxuICAgIEZvcm11bGE6IHN0cmluZztcclxuICAgIFRvb2x0aXA6IHN0cmluZztcclxuICAgIE9yZGluYWxQb3NpdGlvbjogbnVtYmVyO1xyXG4gICAgRGlzYWJsZWQ6IGJvb2xlYW47XHJcbiAgICBSZWFkb25seTogYm9vbGVhbjtcclxuICAgIFZpc2libGVJZjogc3RyaW5nO1xyXG4gICAgLyoqXHJcbiAgICAgKiBFbnRpdMOgIGEgY3VpIGFwcGFydGllbmUgaWwgY2FtcG8uIFNpIHRlbmdhIHByZXNlbnRlIGNoZSBzb25vIGFtbWVzc2kgYW5jaGUgY2FtcGlcclxuICAgICAqIGRpIHNvbGEgdmlzdWFsaXp6YXppb25lIGUgY2FsY29sYXRpLCBkYSB1dGlsaXp6YXJlIG5lbGxlIGZvcm0sIFxyXG4gICAgICogZSBwZXIgcXVlc3RvIG1vdGl2byBwb3Nzb25vIGVzc2VyZSBjb24gRW50aXR5ID09IG51bGxcclxuICAgICAqL1xyXG4gICAgRW50aXR5SUQ6IHN0cmluZztcclxuXHJcbiAgICBGaWVsZEdyb3VwOiBzdHJpbmc7XHJcbiAgICBDb2xTcGFuU2l6ZXM6IEFycmF5PENvbFNwYW5TaXplc0VudW0+O1xyXG4gICAgSW5MaXN0VmlldzogYm9vbGVhbjtcclxuXHJcbiAgICAvLyBQcm9wcml0w6AgY2xpZW50XHJcbiAgICBGaWVsZFR5cGU6IEZpZWxkVHlwZUVudW07XHJcbiAgICBGaWVsZFZhbHVlOiBhbnk7XHJcbiAgICBGb3JtRm9ybUdyb3VwOiBVbnR5cGVkRm9ybUdyb3VwO1xyXG59XHJcblxyXG5leHBvcnQgZW51bSBGaWVsZFR5cGVFbnVtIHtcclxuICAgICdDYW1wbyBkaSB0ZXN0bycgPSAxLFxyXG4gICAgJ0FyZWEgZGkgdGVzdG8nID0gMixcclxuICAgICdCb29sZWFubycgPSAzLFxyXG4gICAgJ0RhdGEgZS9vIG9yYScgPSA0LFxyXG4gICAgJ0NhbXBvIG51bWVyaWNvJyA9IDUsXHJcbiAgICAnQWxsZWdhdG8nID0gNixcclxuICAgICdJbW1hZ2luZScgPSA3LFxyXG4gICAgJ0VsZW5jbyBnZW5lcmljbycgPSA4LFxyXG4gICAgJ0xvb2t1cCcgPSA5LFxyXG4gICAgJ0Zvcm0gZGkgZGV0dGFnbGlvJyA9IDEwXHJcbn1cclxuXHJcbmV4cG9ydCBlbnVtIENvbFNwYW5TaXplc0VudW0ge1xyXG4gICAgJ2NvbC1zbS0zJyA9IDEsXHJcbiAgICAnY29sLXNtLTQnID0gMixcclxuICAgICdjb2wtc20tNicgPSAzLFxyXG4gICAgJ2NvbC1zbS0xMicgPSA0LFxyXG5cclxuICAgICdjb2wtbWQtMycgPSA1LFxyXG4gICAgJ2NvbC1tZC00JyA9IDYsXHJcbiAgICAnY29sLW1kLTYnID0gNyxcclxuICAgICdjb2wtbWQtMTInID0gOCxcclxuXHJcbiAgICAnY29sLWxnLTMnID0gOSxcclxuICAgICdjb2wtbGctNCcgPSAxMCxcclxuICAgICdjb2wtbGctNicgPSAxMSxcclxuICAgICdjb2wtbGctMTInID0gMTIsXHJcbn1cclxuIl19
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZUZpZWxkLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZXFwLWR5bmFtaWMtbW9kdWxlL3NyYy9saWIvbW9kZWxzL2Jhc2VGaWVsZC5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFMUM7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLFNBQVUsU0FBUSxPQUFPO0NBaUNyQztBQUVELE1BQU0sQ0FBTixJQUFZLGFBV1g7QUFYRCxXQUFZLGFBQWE7SUFDckIscUVBQW9CLENBQUE7SUFDcEIsbUVBQW1CLENBQUE7SUFDbkIseURBQWMsQ0FBQTtJQUNkLGlFQUFrQixDQUFBO0lBQ2xCLHFFQUFvQixDQUFBO0lBQ3BCLHlEQUFjLENBQUE7SUFDZCx5REFBYyxDQUFBO0lBQ2QsdUVBQXFCLENBQUE7SUFDckIscURBQVksQ0FBQTtJQUNaLDRFQUF3QixDQUFBO0FBQzVCLENBQUMsRUFYVyxhQUFhLEtBQWIsYUFBYSxRQVd4QjtBQUVELE1BQU0sQ0FBTixJQUFZLGdCQWVYO0FBZkQsV0FBWSxnQkFBZ0I7SUFDeEIsK0RBQWMsQ0FBQTtJQUNkLCtEQUFjLENBQUE7SUFDZCwrREFBYyxDQUFBO0lBQ2QsaUVBQWUsQ0FBQTtJQUVmLCtEQUFjLENBQUE7SUFDZCwrREFBYyxDQUFBO0lBQ2QsK0RBQWMsQ0FBQTtJQUNkLGlFQUFlLENBQUE7SUFFZiwrREFBYyxDQUFBO0lBQ2QsZ0VBQWUsQ0FBQTtJQUNmLGdFQUFlLENBQUE7SUFDZixrRUFBZ0IsQ0FBQTtBQUNwQixDQUFDLEVBZlcsZ0JBQWdCLEtBQWhCLGdCQUFnQixRQWUzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVudHlwZWRGb3JtR3JvdXAgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IEJhc2VPYmogfSBmcm9tICcuL2Jhc2VPYmoubW9kZWwnO1xyXG5cclxuLyoqXHJcbiAqIENvbnRpZW5lIGxlIGluZm9ybWF6aW9uaSBkaSBiYXNlIGRlbCBjYW1wbywgaW5kaXBlbmRlbnRlbWVudGUgZGFsIHRpcG8uXHJcbiAqIFF1ZXN0YSBjbGFzc2Ugw6ggdm9sdXRhbWVudGUgYXN0cmF0dGEgcGVyY2jDqSBpbCB0aXBvIGRpIGNhbXBvIMOoIGRldHRhdG8gZGFsIHRpcG9cclxuICovXHJcbmV4cG9ydCBjbGFzcyBCYXNlRmllbGQgZXh0ZW5kcyBCYXNlT2JqIHtcclxuICAgIC8qKlxyXG4gICAgICogTm9tZSBkZWwgY2FtcG8gY2hlIHBlciBwcm9nZXR0YXppb25lIMOoIHVuYSBzb3N0aXR1emlvbmUgZGVsbGEgbGFiZWxcclxuICAgICAqIElsIHZlcm8gaWRlbnRpZmljYXRpdm8gZGVsIGNhbXBvIMOoIGwnSURcclxuICAgICAqL1xyXG4gICAgTmFtZTogc3RyaW5nO1xyXG4gICAgTGFiZWw6IHN0cmluZztcclxuICAgIERlc2NyaXB0aW9uOiBzdHJpbmc7XHJcbiAgICBSZXF1aXJlZDogYm9vbGVhbjtcclxuICAgIEZvcm11bGE6IHN0cmluZztcclxuICAgIFRvb2x0aXA6IHN0cmluZztcclxuICAgIE9yZGluYWxQb3NpdGlvbjogbnVtYmVyO1xyXG4gICAgRGlzYWJsZWQ6IGJvb2xlYW47XHJcbiAgICBSZWFkb25seTogYm9vbGVhbjtcclxuICAgIFZpc2libGVJZjogc3RyaW5nO1xyXG4gICAgRmllbGRzdHlsZUNTUzogc3RyaW5nO1xyXG4gICAgTGFiZWxzdHlsZUNTUzogc3RyaW5nO1xyXG4gICAgXHJcbiAgICAvKipcclxuICAgICAqIEVudGl0w6AgYSBjdWkgYXBwYXJ0aWVuZSBpbCBjYW1wby4gU2kgdGVuZ2EgcHJlc2VudGUgY2hlIHNvbm8gYW1tZXNzaSBhbmNoZSBjYW1waVxyXG4gICAgICogZGkgc29sYSB2aXN1YWxpenphemlvbmUgZSBjYWxjb2xhdGksIGRhIHV0aWxpenphcmUgbmVsbGUgZm9ybSwgXHJcbiAgICAgKiBlIHBlciBxdWVzdG8gbW90aXZvIHBvc3Nvbm8gZXNzZXJlIGNvbiBFbnRpdHkgPT0gbnVsbFxyXG4gICAgICovXHJcbiAgICBFbnRpdHlJRDogc3RyaW5nO1xyXG5cclxuICAgIEZpZWxkR3JvdXA6IHN0cmluZztcclxuICAgIENvbFNwYW5TaXplczogQXJyYXk8Q29sU3BhblNpemVzRW51bT47XHJcbiAgICBJbkxpc3RWaWV3OiBib29sZWFuO1xyXG5cclxuICAgIC8vIFByb3ByaXTDoCBjbGllbnRcclxuICAgIEZpZWxkVHlwZTogRmllbGRUeXBlRW51bTtcclxuICAgIEZpZWxkVmFsdWU6IGFueTtcclxuICAgIEZvcm1Gb3JtR3JvdXA6IFVudHlwZWRGb3JtR3JvdXA7XHJcbn1cclxuXHJcbmV4cG9ydCBlbnVtIEZpZWxkVHlwZUVudW0ge1xyXG4gICAgJ0NhbXBvIGRpIHRlc3RvJyA9IDEsXHJcbiAgICAnQXJlYSBkaSB0ZXN0bycgPSAyLFxyXG4gICAgJ0Jvb2xlYW5vJyA9IDMsXHJcbiAgICAnRGF0YSBlL28gb3JhJyA9IDQsXHJcbiAgICAnQ2FtcG8gbnVtZXJpY28nID0gNSxcclxuICAgICdBbGxlZ2F0bycgPSA2LFxyXG4gICAgJ0ltbWFnaW5lJyA9IDcsXHJcbiAgICAnRWxlbmNvIGdlbmVyaWNvJyA9IDgsXHJcbiAgICAnTG9va3VwJyA9IDksXHJcbiAgICAnRm9ybSBkaSBkZXR0YWdsaW8nID0gMTBcclxufVxyXG5cclxuZXhwb3J0IGVudW0gQ29sU3BhblNpemVzRW51bSB7XHJcbiAgICAnY29sLXNtLTMnID0gMSxcclxuICAgICdjb2wtc20tNCcgPSAyLFxyXG4gICAgJ2NvbC1zbS02JyA9IDMsXHJcbiAgICAnY29sLXNtLTEyJyA9IDQsXHJcblxyXG4gICAgJ2NvbC1tZC0zJyA9IDUsXHJcbiAgICAnY29sLW1kLTQnID0gNixcclxuICAgICdjb2wtbWQtNicgPSA3LFxyXG4gICAgJ2NvbC1tZC0xMicgPSA4LFxyXG5cclxuICAgICdjb2wtbGctMycgPSA5LFxyXG4gICAgJ2NvbC1sZy00JyA9IDEwLFxyXG4gICAgJ2NvbC1sZy02JyA9IDExLFxyXG4gICAgJ2NvbC1sZy0xMicgPSAxMixcclxufVxyXG4iXX0=