@seniorsistemas/angular-components 17.26.5 → 17.26.7-bugfix-sds-305-b2309d98
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/seniorsistemas-angular-components.umd.js +2695 -2587
- package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js +2 -2
- package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
- package/components/bignumber-input/{number-input.directive.d.ts → bignumber-input.directive.d.ts} +6 -4
- package/components/bignumber-input/index.d.ts +2 -2
- package/components/card/card.component.d.ts +5 -2
- package/components/dynamic-form/components/fields/text-area-ia/text-area-ia-field.component.d.ts +7 -6
- package/components/dynamic-form/configurations/fields/text-area-ia-field.d.ts +4 -6
- package/components/number-input/number-input.directive.d.ts +11 -9
- package/components/speech-recognition/speech-recognition/speech-recognition.component.d.ts +3 -8
- package/components/speech-recognition/speech-recognition.service.d.ts +1 -0
- package/components/speech-recognition/text-to-speech.service.d.ts +1 -0
- package/components/text-area/text-area/text-area.component.d.ts +9 -2
- package/components/text-area-ia/text-area-ia.component.d.ts +4 -1
- package/esm2015/components/bignumber-input/bignumber-input.directive.js +149 -0
- package/esm2015/components/bignumber-input/bignumber-input.module.js +15 -0
- package/esm2015/components/bignumber-input/index.js +3 -3
- package/esm2015/components/card/card.component.js +22 -7
- package/esm2015/components/dynamic-form/components/fields/bignumber/bignumber-field.module.js +2 -2
- package/esm2015/components/dynamic-form/components/fields/text-area/text-area-field.component.js +2 -2
- package/esm2015/components/dynamic-form/components/fields/text-area-ia/text-area-ia-field.component.js +15 -13
- package/esm2015/components/dynamic-form/configurations/fields/text-area-ia-field.js +7 -2
- package/esm2015/components/dynamic-form/dynamic-form.module.js +2 -2
- package/esm2015/components/inline-edit/inline-edit.module.js +2 -2
- package/esm2015/components/number-input/number-input.directive.js +41 -21
- package/esm2015/components/speech-recognition/speech-recognition/speech-recognition.component.js +9 -25
- package/esm2015/components/speech-recognition/speech-recognition.service.js +8 -3
- package/esm2015/components/speech-recognition/text-to-speech.service.js +13 -4
- package/esm2015/components/text-area/text-area/text-area.component.js +33 -5
- package/esm2015/components/text-area-ia/text-area-ia.component.js +13 -5
- package/esm2015/components/text-area-ia/text-area-ia.module.js +3 -3
- package/esm2015/locale/fallback.js +4 -4
- package/esm2015/seniorsistemas-angular-components.js +113 -112
- package/esm5/components/bignumber-input/bignumber-input.directive.js +154 -0
- package/esm5/components/bignumber-input/bignumber-input.module.js +18 -0
- package/esm5/components/bignumber-input/index.js +3 -3
- package/esm5/components/card/card.component.js +26 -7
- package/esm5/components/dynamic-form/components/fields/bignumber/bignumber-field.module.js +2 -2
- package/esm5/components/dynamic-form/components/fields/text-area/text-area-field.component.js +2 -2
- package/esm5/components/dynamic-form/components/fields/text-area-ia/text-area-ia-field.component.js +15 -13
- package/esm5/components/dynamic-form/configurations/fields/text-area-ia-field.js +8 -3
- package/esm5/components/dynamic-form/dynamic-form.module.js +2 -2
- package/esm5/components/inline-edit/inline-edit.module.js +2 -2
- package/esm5/components/number-input/number-input.directive.js +42 -22
- package/esm5/components/speech-recognition/speech-recognition/speech-recognition.component.js +13 -26
- package/esm5/components/speech-recognition/speech-recognition.service.js +9 -3
- package/esm5/components/speech-recognition/text-to-speech.service.js +13 -4
- package/esm5/components/text-area/text-area/text-area.component.js +42 -6
- package/esm5/components/text-area-ia/text-area-ia.component.js +13 -5
- package/esm5/components/text-area-ia/text-area-ia.module.js +3 -3
- package/esm5/locale/fallback.js +4 -4
- package/esm5/seniorsistemas-angular-components.js +113 -112
- package/fesm2015/seniorsistemas-angular-components.js +2445 -2354
- package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
- package/fesm5/seniorsistemas-angular-components.js +2583 -2476
- package/fesm5/seniorsistemas-angular-components.js.map +1 -1
- package/package.json +2 -2
- package/seniorsistemas-angular-components.d.ts +112 -111
- package/seniorsistemas-angular-components.metadata.json +1 -1
- package/esm2015/components/bignumber-input/number-input.directive.js +0 -132
- package/esm2015/components/bignumber-input/number-input.module.js +0 -15
- package/esm5/components/bignumber-input/number-input.directive.js +0 -137
- package/esm5/components/bignumber-input/number-input.module.js +0 -18
- /package/components/bignumber-input/{number-input.module.d.ts → bignumber-input.module.d.ts} +0 -0
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { __decorate, __extends } from "tslib";
|
|
2
|
-
import { Directive, ElementRef, forwardRef, HostBinding,
|
|
1
|
+
import { __decorate, __extends, __read } from "tslib";
|
|
2
|
+
import { Directive, ElementRef, EventEmitter, forwardRef, HostBinding, Input, KeyValueDiffers, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, } from "@angular/core";
|
|
3
3
|
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
4
4
|
import { LocaleService } from "../locale/locale.service";
|
|
5
5
|
import { CurrencyMaskDirective } from "ng2-currency-mask";
|
|
@@ -17,14 +17,15 @@ export var NumberAlignmentOption;
|
|
|
17
17
|
*/
|
|
18
18
|
var NumberInputDirective = /** @class */ (function (_super) {
|
|
19
19
|
__extends(NumberInputDirective, _super);
|
|
20
|
-
function NumberInputDirective(
|
|
20
|
+
function NumberInputDirective(_keyValueDiffers, _elementRef, localeService) {
|
|
21
21
|
var _this = _super.call(this, null, _elementRef, _keyValueDiffers) || this;
|
|
22
|
+
_this._elementRef = _elementRef;
|
|
22
23
|
_this.localeService = localeService;
|
|
23
24
|
_this.precision = 15;
|
|
24
25
|
_this.scale = 0;
|
|
25
26
|
_this.alignTo = NumberAlignmentOption.LEFT;
|
|
26
27
|
_this.allowNegative = true;
|
|
27
|
-
_this.
|
|
28
|
+
_this.pasteRejected = new EventEmitter();
|
|
28
29
|
_this.onLocaleService();
|
|
29
30
|
return _this;
|
|
30
31
|
}
|
|
@@ -32,6 +33,10 @@ var NumberInputDirective = /** @class */ (function (_super) {
|
|
|
32
33
|
NumberInputDirective.prototype.ngOnInit = function () {
|
|
33
34
|
this.updateVariables();
|
|
34
35
|
_super.prototype.ngOnInit.call(this);
|
|
36
|
+
this.pasteListener = this._onPaste.bind(this);
|
|
37
|
+
this._elementRef.nativeElement.addEventListener("paste", this.pasteListener);
|
|
38
|
+
this.keypressListener = this._onKeypress.bind(this);
|
|
39
|
+
this._elementRef.nativeElement.addEventListener("keypress", this.keypressListener);
|
|
35
40
|
};
|
|
36
41
|
NumberInputDirective.prototype.ngOnChanges = function (changes) {
|
|
37
42
|
var placeholderChange = changes.placeholder && changes.placeholder.currentValue;
|
|
@@ -46,6 +51,33 @@ var NumberInputDirective = /** @class */ (function (_super) {
|
|
|
46
51
|
this.updateVariables();
|
|
47
52
|
}
|
|
48
53
|
};
|
|
54
|
+
NumberInputDirective.prototype.ngOnDestroy = function () {
|
|
55
|
+
this._elementRef.nativeElement.removeEventListener("paste", this.pasteListener);
|
|
56
|
+
this._elementRef.nativeElement.removeEventListener("keypress", this.keypressListener);
|
|
57
|
+
};
|
|
58
|
+
NumberInputDirective.prototype._onPaste = function (event) {
|
|
59
|
+
var _a, _b;
|
|
60
|
+
var pastedText = (_b = (_a = event.clipboardData) === null || _a === void 0 ? void 0 : _a.getData("text")) !== null && _b !== void 0 ? _b : "";
|
|
61
|
+
var numericText = pastedText.replace(new RegExp("\\" + this.thousandsSeparator, "g"), "").replace(this.decimalSeparator, ".");
|
|
62
|
+
var _c = __read(numericText.split("."), 2), intPart = _c[0], _d = _c[1], decimalPart = _d === void 0 ? "" : _d;
|
|
63
|
+
var totalDigits = intPart.replace(/\D/g, "").length + decimalPart.slice(0, this.scale).length;
|
|
64
|
+
if (totalDigits > this.precision) {
|
|
65
|
+
event.preventDefault();
|
|
66
|
+
event.stopPropagation();
|
|
67
|
+
this.pasteRejected.emit(pastedText);
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
NumberInputDirective.prototype._onKeypress = function (event) {
|
|
71
|
+
var code = event.code;
|
|
72
|
+
if (code === "Minus" || code === "NumpadSubtract") {
|
|
73
|
+
if (this.allowNegative) {
|
|
74
|
+
this.maxLength = this._maxLength + 1;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
else if (code === "Equal" || code === "NumpadAdd") {
|
|
78
|
+
this.maxLength = this._maxLength;
|
|
79
|
+
}
|
|
80
|
+
};
|
|
49
81
|
/**
|
|
50
82
|
* Update the options values according to the directive input values.
|
|
51
83
|
*/
|
|
@@ -69,24 +101,9 @@ var NumberInputDirective = /** @class */ (function (_super) {
|
|
|
69
101
|
var thoSepLength = this.thousandsSeparator.length;
|
|
70
102
|
var maxLength = this.precision + (this.scale ? decSepLength : 0);
|
|
71
103
|
maxLength += Math.ceil((this.precision - (this.scale ? this.scale : 0)) / 3 - 1) * thoSepLength;
|
|
104
|
+
this._maxLength = maxLength;
|
|
72
105
|
this.maxLength = maxLength;
|
|
73
106
|
};
|
|
74
|
-
/**
|
|
75
|
-
* Prevents the default CurrencyMask behavior when typed a incorrect value.
|
|
76
|
-
* By default the CurrencyMask inputs the mask value to the component value when typed a incorrect value.
|
|
77
|
-
*/
|
|
78
|
-
NumberInputDirective.prototype.handleKeypress = function (event) {
|
|
79
|
-
var negativeOperator = "-";
|
|
80
|
-
var key = event.key;
|
|
81
|
-
if (this.thousandsSeparator.includes(key) ||
|
|
82
|
-
this.decimalSeparator.includes(key) ||
|
|
83
|
-
negativeOperator.includes(key) ||
|
|
84
|
-
this.regex.test(key) ||
|
|
85
|
-
"Enter".toUpperCase() === key.toUpperCase())
|
|
86
|
-
_super.prototype.handleKeypress.call(this, event);
|
|
87
|
-
else
|
|
88
|
-
event.preventDefault();
|
|
89
|
-
};
|
|
90
107
|
NumberInputDirective.prototype.onLocaleService = function () {
|
|
91
108
|
var _this = this;
|
|
92
109
|
this.localeService
|
|
@@ -100,8 +117,8 @@ var NumberInputDirective = /** @class */ (function (_super) {
|
|
|
100
117
|
};
|
|
101
118
|
var NumberInputDirective_1;
|
|
102
119
|
NumberInputDirective.ctorParameters = function () { return [
|
|
103
|
-
{ type: ElementRef },
|
|
104
120
|
{ type: KeyValueDiffers },
|
|
121
|
+
{ type: ElementRef },
|
|
105
122
|
{ type: LocaleService }
|
|
106
123
|
]; };
|
|
107
124
|
__decorate([
|
|
@@ -129,6 +146,9 @@ var NumberInputDirective = /** @class */ (function (_super) {
|
|
|
129
146
|
__decorate([
|
|
130
147
|
HostBinding("attr.maxLength")
|
|
131
148
|
], NumberInputDirective.prototype, "maxLength", void 0);
|
|
149
|
+
__decorate([
|
|
150
|
+
Output()
|
|
151
|
+
], NumberInputDirective.prototype, "pasteRejected", void 0);
|
|
132
152
|
NumberInputDirective = NumberInputDirective_1 = __decorate([
|
|
133
153
|
Directive({
|
|
134
154
|
selector: "input[sNumberInput]",
|
|
@@ -144,4 +164,4 @@ var NumberInputDirective = /** @class */ (function (_super) {
|
|
|
144
164
|
return NumberInputDirective;
|
|
145
165
|
}(CurrencyMaskDirective));
|
|
146
166
|
export { NumberInputDirective };
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-input.directive.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/number-input/number-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    Injectable,\n    Input,\n    KeyValueDiffers,\n    OnChanges,\n    OnInit,\n    SimpleChanges,\n} from \"@angular/core\";\nimport { NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { LocaleService } from \"../locale/locale.service\";\nimport { CurrencyMaskDirective } from \"ng2-currency-mask\";\nimport { first } from \"rxjs/operators\";\n\n/**\n * @deprecated Should use 'AlignmentOptions' from @seniorsistemas/ng2-currency-mask instead\n */\nexport enum NumberAlignmentOption {\n    RIGHT = \"right\",\n    LEFT = \"left\",\n}\n\n/**\n * @deprecated Should use BigNumberInput directive instead\n */\n@Directive({\n    selector: \"input[sNumberInput]\",\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => NumberInputDirective),\n            multi: true,\n        },\n    ],\n})\nexport class NumberInputDirective extends CurrencyMaskDirective implements OnInit, OnChanges {\n    @Input()\n    public precision = 15;\n\n    @Input()\n    public scale = 0;\n\n    @Input()\n    public decimalSeparator: string;\n\n    @Input()\n    public thousandsSeparator: string;\n\n    @Input()\n    public alignTo = NumberAlignmentOption.LEFT;\n\n    @Input()\n    public allowNegative = true;\n\n    @Input()\n    @HostBinding(\"attr.placeholder\")\n    public placeholder: string;\n\n    @HostBinding(\"attr.maxLength\")\n    public maxLength: number;\n\n    private regex: RegExp = /\\d/;\n\n    constructor(\n        _elementRef: ElementRef,\n        _keyValueDiffers: KeyValueDiffers,\n        private readonly localeService: LocaleService\n    ) {\n        super(null, _elementRef, _keyValueDiffers);\n\n        this.onLocaleService();\n    }\n\n    ngOnInit(): void {\n        this.updateVariables();\n\n        super.ngOnInit();\n    }\n\n    public ngOnChanges(changes: SimpleChanges) {\n        const placeholderChange = changes.placeholder && changes.placeholder.currentValue;\n        if (!placeholderChange && this.scale) this.placeholder = `0${this.decimalSeparator}${\"\".padEnd(this.scale, \"0\")}`;\n\n        if (\n            changes.scale ||\n            changes.decimalSeparator ||\n            changes.thousandsSeparator ||\n            changes.alignTo ||\n            changes.precision ||\n            changes.allowNegative\n        ) {\n            this.updateVariables();\n        }\n    }\n\n    /**\n     * Update the options values according to the directive input values.\n     */\n    private updateVariables(): void {\n        this.options = {\n            align: this.alignTo,\n            decimal: this.decimalSeparator,\n            thousands: this.thousandsSeparator,\n            precision: this.scale || 0,\n            prefix: \"\",\n            suffix: \"\",\n            allowNegative: this.allowNegative,\n        };\n        this.calculateMaxLength();\n    }\n\n    /**\n     * Responsible to calculate the field maximum length considering the separators.\n     */\n    private calculateMaxLength(): void {\n        const decSepLength = this.decimalSeparator.length;\n        const thoSepLength = this.thousandsSeparator.length;\n\n        let maxLength = this.precision + (this.scale ? decSepLength : 0);\n        maxLength += Math.ceil((this.precision - (this.scale ? this.scale : 0)) / 3 - 1) * thoSepLength;\n\n        this.maxLength = maxLength;\n    }\n\n    /**\n     * Prevents the default CurrencyMask behavior when typed a incorrect value.\n     * By default the CurrencyMask inputs the mask value to the component value when typed a incorrect value.\n     */\n    public handleKeypress(event: KeyboardEvent): void {\n        const negativeOperator = \"-\";\n        const { key } = event;\n\n        if (\n            this.thousandsSeparator.includes(key) ||\n            this.decimalSeparator.includes(key) ||\n            negativeOperator.includes(key) ||\n            this.regex.test(key) ||\n            \"Enter\".toUpperCase() === key.toUpperCase()\n        )\n            super.handleKeypress(event);\n        else event.preventDefault();\n    }\n\n    private onLocaleService(): void {\n        this.localeService\n            .getLocale()\n            .pipe(first())\n            .subscribe(() => {\n                this.decimalSeparator = this.decimalSeparator ?? this.localeService.getDecimalSeparator();\n                this.thousandsSeparator = this.thousandsSeparator ?? this.localeService.getGroupingSeparator();\n            });\n    }\n}\n"]}
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-input.directive.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/number-input/number-input.directive.ts"],"names":[],"mappings":";AAAA,OAAO,EACH,SAAS,EACT,UAAU,EACV,YAAY,EACZ,UAAU,EACV,WAAW,EACX,KAAK,EACL,eAAe,EACf,SAAS,EACT,SAAS,EACT,MAAM,EACN,MAAM,EACN,aAAa,GAChB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAEvC;;GAEG;AACH,MAAM,CAAN,IAAY,qBAGX;AAHD,WAAY,qBAAqB;IAC7B,wCAAe,CAAA;IACf,sCAAa,CAAA;AACjB,CAAC,EAHW,qBAAqB,KAArB,qBAAqB,QAGhC;AAED;;GAEG;AAWH;IAA0C,wCAAqB;IAkC3D,8BACI,gBAAiC,EAChB,WAAuB,EACvB,aAA4B;QAHjD,YAKI,kBAAM,IAAI,EAAE,WAAW,EAAE,gBAAgB,CAAC,SAG7C;QANoB,iBAAW,GAAX,WAAW,CAAY;QACvB,mBAAa,GAAb,aAAa,CAAe;QAnC1C,eAAS,GAAG,EAAE,CAAC;QAGf,WAAK,GAAG,CAAC,CAAC;QASV,aAAO,GAAG,qBAAqB,CAAC,IAAI,CAAC;QAGrC,mBAAa,GAAG,IAAI,CAAC;QAUrB,mBAAa,GAAG,IAAI,YAAY,EAAU,CAAC;QAc9C,KAAI,CAAC,eAAe,EAAE,CAAC;;IAC3B,CAAC;6BA1CQ,oBAAoB;IA4CtB,uCAAQ,GAAf;QACI,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,iBAAM,QAAQ,WAAE,CAAC;QAEjB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9C,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAE7E,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpD,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,gBAAgB,CAAC,UAAU,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;IACvF,CAAC;IAEM,0CAAW,GAAlB,UAAmB,OAAsB;QACrC,IAAM,iBAAiB,GAAG,OAAO,CAAC,WAAW,IAAI,OAAO,CAAC,WAAW,CAAC,YAAY,CAAC;QAClF,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,WAAW,GAAG,MAAI,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,CAAG,CAAC;QAElH,IACI,OAAO,CAAC,KAAK;YACb,OAAO,CAAC,gBAAgB;YACxB,OAAO,CAAC,kBAAkB;YAC1B,OAAO,CAAC,OAAO;YACf,OAAO,CAAC,SAAS;YACjB,OAAO,CAAC,aAAa,EACvB;YACE,IAAI,CAAC,eAAe,EAAE,CAAC;SAC1B;IACL,CAAC;IAEM,0CAAW,GAAlB;QACI,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAChF,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,mBAAmB,CAAC,UAAU,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC1F,CAAC;IAEO,uCAAQ,GAAhB,UAAiB,KAAqB;;QAClC,IAAM,UAAU,eAAG,KAAK,CAAC,aAAa,0CAAE,OAAO,CAAC,MAAM,oCAAK,EAAE,CAAC;QAC9D,IAAM,WAAW,GAAG,UAAU,CAAC,OAAO,CAAC,IAAI,MAAM,CAAC,OAAK,IAAI,CAAC,kBAAoB,EAAE,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC;QAC1H,IAAA,sCAAoD,EAAnD,eAAO,EAAE,UAAgB,EAAhB,qCAA0C,CAAC;QAC3D,IAAM,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,MAAM,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC;QAEhG,IAAI,WAAW,GAAG,IAAI,CAAC,SAAS,EAAE;YAC9B,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACvC;IACL,CAAC;IAEO,0CAAW,GAAnB,UAAoB,KAAoB;QACpC,IAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;QAExB,IAAI,IAAI,KAAK,OAAO,IAAI,IAAI,KAAK,gBAAgB,EAAE;YAC/C,IAAI,IAAI,CAAC,aAAa,EAAE;gBACpB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;aACxC;SACJ;aAAM,IAAI,IAAI,KAAK,OAAO,IAAI,IAAI,KAAK,WAAW,EAAE;YACjD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC;SACpC;IACL,CAAC;IAED;;OAEG;IACK,8CAAe,GAAvB;QACI,IAAI,CAAC,OAAO,GAAG;YACX,KAAK,EAAE,IAAI,CAAC,OAAO;YACnB,OAAO,EAAE,IAAI,CAAC,gBAAgB;YAC9B,SAAS,EAAE,IAAI,CAAC,kBAAkB;YAClC,SAAS,EAAE,IAAI,CAAC,KAAK,IAAI,CAAC;YAC1B,MAAM,EAAE,EAAE;YACV,MAAM,EAAE,EAAE;YACV,aAAa,EAAE,IAAI,CAAC,aAAa;SACpC,CAAC;QACF,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;IAED;;OAEG;IACK,iDAAkB,GAA1B;QACI,IAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC;QAClD,IAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC;QAEpD,IAAI,SAAS,GAAG,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACjE,SAAS,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,YAAY,CAAC;QAEhG,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC/B,CAAC;IAEO,8CAAe,GAAvB;QAAA,iBAQC;QAPG,IAAI,CAAC,aAAa;aACb,SAAS,EAAE;aACX,IAAI,CAAC,KAAK,EAAE,CAAC;aACb,SAAS,CAAC;;YACP,KAAI,CAAC,gBAAgB,SAAG,KAAI,CAAC,gBAAgB,mCAAI,KAAI,CAAC,aAAa,CAAC,mBAAmB,EAAE,CAAC;YAC1F,KAAI,CAAC,kBAAkB,SAAG,KAAI,CAAC,kBAAkB,mCAAI,KAAI,CAAC,aAAa,CAAC,oBAAoB,EAAE,CAAC;QACnG,CAAC,CAAC,CAAC;IACX,CAAC;;;gBAzGqB,eAAe;gBACH,UAAU;gBACR,aAAa;;IAnCjD;QADC,KAAK,EAAE;2DACc;IAGtB;QADC,KAAK,EAAE;uDACS;IAGjB;QADC,KAAK,EAAE;kEACwB;IAGhC;QADC,KAAK,EAAE;oEAC0B;IAGlC;QADC,KAAK,EAAE;yDACoC;IAG5C;QADC,KAAK,EAAE;+DACoB;IAI5B;QAFC,KAAK,EAAE;QACP,WAAW,CAAC,kBAAkB,CAAC;6DACL;IAG3B;QADC,WAAW,CAAC,gBAAgB,CAAC;2DACL;IAGzB;QADC,MAAM,EAAE;+DACyC;IA3BzC,oBAAoB;QAVhC,SAAS,CAAC;YACP,QAAQ,EAAE,qBAAqB;YAC/B,SAAS,EAAE;gBACP;oBACI,OAAO,EAAE,iBAAiB;oBAC1B,WAAW,EAAE,UAAU,CAAC,cAAM,OAAA,sBAAoB,EAApB,CAAoB,CAAC;oBACnD,KAAK,EAAE,IAAI;iBACd;aACJ;SACJ,CAAC;OACW,oBAAoB,CA6IhC;IAAD,2BAAC;CAAA,AA7ID,CAA0C,qBAAqB,GA6I9D;SA7IY,oBAAoB","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Input,\n    KeyValueDiffers,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n} from \"@angular/core\";\nimport { NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { LocaleService } from \"../locale/locale.service\";\nimport { CurrencyMaskDirective } from \"ng2-currency-mask\";\nimport { first } from \"rxjs/operators\";\n\n/**\n * @deprecated Should use 'AlignmentOptions' from @seniorsistemas/ng2-currency-mask instead\n */\nexport enum NumberAlignmentOption {\n    RIGHT = \"right\",\n    LEFT = \"left\",\n}\n\n/**\n * @deprecated Should use BigNumberInput directive instead\n */\n@Directive({\n    selector: \"input[sNumberInput]\",\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => NumberInputDirective),\n            multi: true,\n        },\n    ],\n})\nexport class NumberInputDirective extends CurrencyMaskDirective implements OnInit, OnChanges, OnDestroy {\n    @Input()\n    public precision = 15;\n\n    @Input()\n    public scale = 0;\n\n    @Input()\n    public decimalSeparator: string;\n\n    @Input()\n    public thousandsSeparator: string;\n\n    @Input()\n    public alignTo = NumberAlignmentOption.LEFT;\n\n    @Input()\n    public allowNegative = true;\n\n    @Input()\n    @HostBinding(\"attr.placeholder\")\n    public placeholder: string;\n\n    @HostBinding(\"attr.maxLength\")\n    public maxLength: number;\n\n    @Output()\n    public pasteRejected = new EventEmitter<string>();\n\n    private _maxLength: number;\n\n    private pasteListener: any;\n    private keypressListener: any;\n\n    constructor(\n        _keyValueDiffers: KeyValueDiffers,\n        private readonly _elementRef: ElementRef,\n        private readonly localeService: LocaleService\n    ) {\n        super(null, _elementRef, _keyValueDiffers);\n\n        this.onLocaleService();\n    }\n\n    public ngOnInit(): void {\n        this.updateVariables();\n\n        super.ngOnInit();\n\n        this.pasteListener = this._onPaste.bind(this);\n        this._elementRef.nativeElement.addEventListener(\"paste\", this.pasteListener);\n\n        this.keypressListener = this._onKeypress.bind(this);\n        this._elementRef.nativeElement.addEventListener(\"keypress\", this.keypressListener);\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        const placeholderChange = changes.placeholder && changes.placeholder.currentValue;\n        if (!placeholderChange && this.scale) this.placeholder = `0${this.decimalSeparator}${\"\".padEnd(this.scale, \"0\")}`;\n\n        if (\n            changes.scale ||\n            changes.decimalSeparator ||\n            changes.thousandsSeparator ||\n            changes.alignTo ||\n            changes.precision ||\n            changes.allowNegative\n        ) {\n            this.updateVariables();\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this._elementRef.nativeElement.removeEventListener(\"paste\", this.pasteListener);\n        this._elementRef.nativeElement.removeEventListener(\"keypress\", this.keypressListener);\n    }\n\n    private _onPaste(event: ClipboardEvent): void {\n        const pastedText = event.clipboardData?.getData(\"text\") ?? \"\";\n        const numericText = pastedText.replace(new RegExp(`\\\\${this.thousandsSeparator}`, \"g\"), \"\").replace(this.decimalSeparator, \".\");\n        const [intPart, decimalPart = \"\"] = numericText.split(\".\");\n        const totalDigits = intPart.replace(/\\D/g, \"\").length + decimalPart.slice(0, this.scale).length;\n\n        if (totalDigits > this.precision) {\n            event.preventDefault();\n            event.stopPropagation();\n            this.pasteRejected.emit(pastedText);\n        }\n    }\n\n    private _onKeypress(event: KeyboardEvent): void {\n        const code = event.code;\n\n        if (code === \"Minus\" || code === \"NumpadSubtract\") {\n            if (this.allowNegative) {\n                this.maxLength = this._maxLength + 1;\n            }\n        } else if (code === \"Equal\" || code === \"NumpadAdd\") {\n            this.maxLength = this._maxLength;\n        }\n    }\n\n    /**\n     * Update the options values according to the directive input values.\n     */\n    private updateVariables(): void {\n        this.options = {\n            align: this.alignTo,\n            decimal: this.decimalSeparator,\n            thousands: this.thousandsSeparator,\n            precision: this.scale || 0,\n            prefix: \"\",\n            suffix: \"\",\n            allowNegative: this.allowNegative,\n        };\n        this.calculateMaxLength();\n    }\n\n    /**\n     * Responsible to calculate the field maximum length considering the separators.\n     */\n    private calculateMaxLength(): void {\n        const decSepLength = this.decimalSeparator.length;\n        const thoSepLength = this.thousandsSeparator.length;\n\n        let maxLength = this.precision + (this.scale ? decSepLength : 0);\n        maxLength += Math.ceil((this.precision - (this.scale ? this.scale : 0)) / 3 - 1) * thoSepLength;\n\n        this._maxLength = maxLength;\n        this.maxLength = maxLength;\n    }\n\n    private onLocaleService(): void {\n        this.localeService\n            .getLocale()\n            .pipe(first())\n            .subscribe(() => {\n                this.decimalSeparator = this.decimalSeparator ?? this.localeService.getDecimalSeparator();\n                this.thousandsSeparator = this.thousandsSeparator ?? this.localeService.getGroupingSeparator();\n            });\n    }\n}\n"]}
|
package/esm5/components/speech-recognition/speech-recognition/speech-recognition.component.js
CHANGED
|
@@ -16,19 +16,11 @@ var SpeechRecognitionComponent = /** @class */ (function () {
|
|
|
16
16
|
this.isDoneSpeaking = false;
|
|
17
17
|
this.onDestroy$ = new Subject();
|
|
18
18
|
this.VOICE_SPEEDS = [0.5, 1, 1.5, 2];
|
|
19
|
-
this.SPEECH_RECOGNITION_MARGIN_OFFSET = 13;
|
|
20
19
|
this.keydownEventListener = function (event) {
|
|
21
20
|
if (_this.disabled) {
|
|
22
21
|
event.preventDefault();
|
|
23
22
|
}
|
|
24
23
|
};
|
|
25
|
-
this.TEXT_AREA_ELEMENT_MUTATION_OBSERVER = new MutationObserver(function () {
|
|
26
|
-
_this.SPEECH_CONTAINER_WIDTH_CALLBACK();
|
|
27
|
-
});
|
|
28
|
-
this.SPEECH_CONTAINER_WIDTH_CALLBACK = function () {
|
|
29
|
-
_this.setSpeechContainerWidth();
|
|
30
|
-
};
|
|
31
|
-
this.speechRecognitionContainerWidth = 0;
|
|
32
24
|
this.disabled = false;
|
|
33
25
|
this.isSpeaking = false;
|
|
34
26
|
this.voiceSpeed = 1;
|
|
@@ -43,20 +35,14 @@ var SpeechRecognitionComponent = /** @class */ (function () {
|
|
|
43
35
|
this.recognizedText = new EventEmitter();
|
|
44
36
|
}
|
|
45
37
|
SpeechRecognitionComponent.prototype.ngOnInit = function () {
|
|
38
|
+
if (!this.hasSpeechRecognitionBrowserApi) {
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
46
41
|
if (!this.textAreaElement) {
|
|
47
42
|
throw new Error('textAreaElement is required');
|
|
48
43
|
}
|
|
49
44
|
this.textAreaElement.placeholder = this.translateService.instant("platform.angular_components.text_area_speech_recognition_placeholder");
|
|
50
45
|
this.textAreaElement.addEventListener('keydown', this.keydownEventListener);
|
|
51
|
-
var config = { attributes: true, childList: true, subtree: true };
|
|
52
|
-
this.TEXT_AREA_ELEMENT_MUTATION_OBSERVER.observe(this.textAreaElement, config);
|
|
53
|
-
window.addEventListener('resize', this.SPEECH_CONTAINER_WIDTH_CALLBACK);
|
|
54
|
-
};
|
|
55
|
-
SpeechRecognitionComponent.prototype.ngAfterViewInit = function () {
|
|
56
|
-
var _this = this;
|
|
57
|
-
setTimeout(function () {
|
|
58
|
-
_this.setSpeechContainerWidth();
|
|
59
|
-
});
|
|
60
46
|
};
|
|
61
47
|
SpeechRecognitionComponent.prototype.onListen = function () {
|
|
62
48
|
var _this = this;
|
|
@@ -130,9 +116,6 @@ var SpeechRecognitionComponent = /** @class */ (function () {
|
|
|
130
116
|
SpeechRecognitionComponent.prototype.ngOnDestroy = function () {
|
|
131
117
|
this.onDestroy$.next();
|
|
132
118
|
this.onDestroy$.complete();
|
|
133
|
-
this.textAreaElement.removeEventListener('keydown', this.keydownEventListener);
|
|
134
|
-
window.removeEventListener('resize', this.SPEECH_CONTAINER_WIDTH_CALLBACK);
|
|
135
|
-
this.TEXT_AREA_ELEMENT_MUTATION_OBSERVER.disconnect();
|
|
136
119
|
};
|
|
137
120
|
SpeechRecognitionComponent.prototype.toggleTextToSpeech = function () {
|
|
138
121
|
if (this.isPlayingTextToSpeech) {
|
|
@@ -170,6 +153,13 @@ var SpeechRecognitionComponent = /** @class */ (function () {
|
|
|
170
153
|
enumerable: true,
|
|
171
154
|
configurable: true
|
|
172
155
|
});
|
|
156
|
+
Object.defineProperty(SpeechRecognitionComponent.prototype, "hasSpeechRecognitionBrowserApi", {
|
|
157
|
+
get: function () {
|
|
158
|
+
return this.speechRecognitionService.hasSupportSpeechRecognition;
|
|
159
|
+
},
|
|
160
|
+
enumerable: true,
|
|
161
|
+
configurable: true
|
|
162
|
+
});
|
|
173
163
|
Object.defineProperty(SpeechRecognitionComponent.prototype, "isDisabledTextToSpeech", {
|
|
174
164
|
get: function () {
|
|
175
165
|
var hasTextToSpeechVoice = this.textToSpeechService.hasVoice;
|
|
@@ -189,9 +179,6 @@ var SpeechRecognitionComponent = /** @class */ (function () {
|
|
|
189
179
|
_this.isDoneSpeaking = true;
|
|
190
180
|
});
|
|
191
181
|
};
|
|
192
|
-
SpeechRecognitionComponent.prototype.setSpeechContainerWidth = function () {
|
|
193
|
-
this.speechRecognitionContainerWidth = this.textAreaElement.getBoundingClientRect().width - this.SPEECH_RECOGNITION_MARGIN_OFFSET;
|
|
194
|
-
};
|
|
195
182
|
SpeechRecognitionComponent.ctorParameters = function () { return [
|
|
196
183
|
{ type: SpeechRecognitionService },
|
|
197
184
|
{ type: TextToSpeechService },
|
|
@@ -206,11 +193,11 @@ var SpeechRecognitionComponent = /** @class */ (function () {
|
|
|
206
193
|
SpeechRecognitionComponent = __decorate([
|
|
207
194
|
Component({
|
|
208
195
|
selector: 's-speech-recognition',
|
|
209
|
-
template: "<section class=\"speech-recognition\"
|
|
210
|
-
styles: [".speech-recognition{display:-ms-flexbox;display:flex;gap:10px;-ms-flex-pack:justify;justify-content:space-between}.speech-recognition-buttons{display:-ms-flexbox;display:flex;gap:10px;position:relative;bottom:15px}.speech-recognition-item{display:-ms-inline-flexbox;display:inline-flex;height:25px;padding:4px 12px;-ms-flex-pack:center;justify-content:center;-ms-flex-align:center;align-items:center;gap:8px;border-radius:15px;cursor:pointer;transition:background .1s ease-in}.speech-recognition-item i,.speech-recognition-item span{color:#fff}.speech-recognition-item-disabled{cursor:default!important}.speech-recognition-item-disabled *{opacity:.5}.speech-recognition-item-microphone{background:#428bca}.speech-recognition-item-microphone:not(.speech-recognition-item-disabled):hover{background:#063951}.speech-recognition-item-regular{background:#7892a1}.speech-recognition-item-regular:not(.speech-recognition-item-disabled):hover{background:#697882}.speech-recognition-item-aprove{background:#0c9348}.speech-recognition-item-aprove:not(.speech-recognition-item-disabled):hover{background:#063951}.speech-recognition-item-discard{background:#c13018}.speech-recognition-item-discard:not(.speech-recognition-item-disabled):hover{background:#063951}.speech-recognition-item-toolbar{background:#7892a1;display:-ms-flexbox;display:flex;border-radius:15px;-ms-flex-align:center;align-items:center;color:#fff}.speech-recognition-item-toolbar i,.speech-recognition-item-toolbar span{cursor:pointer}.speech-recognition-item-toolbar i:not(:first-child),.speech-recognition-item-toolbar i:not(:last-child){padding:6px}.speech-recognition-item-toolbar i:first-child{padding-left:10px}.speech-recognition-item-toolbar i:last-child{padding-right:10px}.speech-recognition-item-toolbar span{height:25px}.speech-recognition-text{color:#212533;font-size:12px;font-style:normal;font-weight:400;word-break:break-word}"]
|
|
196
|
+
template: "<section class=\"speech-recognition\" *ngIf=\"hasSpeechRecognitionBrowserApi\">\n <div class=\"speech-recognition-text\">\n <ng-container *ngIf=\"canRenderMicrophone\">\n {{ 'platform.angular_components.text_area_before_speech' | translate }}\n </ng-container>\n\n <ng-container *ngIf=\"isSpeaking\">\n {{ 'platform.angular_components.text_area_while_speech' | translate }}\n </ng-container>\n\n <ng-container *ngIf=\"canRenderAprove && canRenderDiscard\">\n {{ 'platform.angular_components.text_area_end_speech' | translate }}\n </ng-container>\n </div>\n <div class=\"speech-recognition-buttons\">\n <span\n *ngIf=\"canRenderListeningText\"\n (click)=\"stopListening()\"\n class=\"speech-recognition-item speech-recognition-item-regular\">\n <i class=\"far fa-ellipsis-h\"></i>\n </span>\n\n <span\n *ngIf=\"canRenderMicrophone\"\n (click)=\"onListen()\"\n class=\"speech-recognition-item speech-recognition-item-microphone\"\n [class.speech-recognition-item-disabled]=\"isDisabledMicrophone || isListening || disabled\">\n <i class=\"fas fa-microphone\"></i>\n </span>\n\n <span\n *ngIf=\"canRenderAprove\"\n (click)=\"onAprove()\"\n class=\"speech-recognition-item speech-recognition-item-aprove\">\n <i class=\"fas fa-check\"></i>\n </span>\n\n <span *ngIf=\"canRenderDiscard\"\n (click)=\"onDiscard()\"\n class=\"speech-recognition-item speech-recognition-item-discard\">\n <i class=\"fas fa-times\"></i>\n </span>\n\n <span\n *ngIf=\"canRenderTextToSpeech\"\n (click)=\"onOpenToolbar()\"\n class=\"speech-recognition-item speech-recognition-item-regular\"\n [class.speech-recognition-item-disabled]=\"isDisabledTextToSpeech\">\n <i class=\"fas fa-volume-down\"></i>\n </span>\n\n <span\n *ngIf=\"canRenderTextToSpeechToolbar\"\n class=\"speech-recognition-item-toolbar\">\n <i class=\"fas\" [class.fa-pause]=\"isPlayingTextToSpeech\" [class.fa-play]=\"!isPlayingTextToSpeech\"\n (click)=\"toggleTextToSpeech()\"></i>\n <i class=\"fas fa-backward\" (click)=\"restartTextToSpeech()\"></i>\n <span (click)=\"updateVoiceSpeed()\">\n {{ voiceSpeed }}x\n </span>\n <i class=\"fas fa-times\" (click)=\"onCloseToolbar()\"></i>\n </span>\n </div>\n</section>\n",
|
|
197
|
+
styles: [".speech-recognition{display:-ms-flexbox;display:flex;gap:10px;-ms-flex-pack:justify;justify-content:space-between;width:100%}.speech-recognition-buttons{display:-ms-flexbox;display:flex;gap:10px;position:relative;bottom:15px;margin-right:16px}.speech-recognition-item{display:-ms-inline-flexbox;display:inline-flex;height:25px;padding:4px 12px;-ms-flex-pack:center;justify-content:center;-ms-flex-align:center;align-items:center;gap:8px;border-radius:15px;cursor:pointer;transition:background .1s ease-in}.speech-recognition-item i,.speech-recognition-item span{color:#fff}.speech-recognition-item-disabled{cursor:default!important}.speech-recognition-item-disabled *{opacity:.5}.speech-recognition-item-microphone{background:#428bca}.speech-recognition-item-microphone:not(.speech-recognition-item-disabled):hover{background:#063951}.speech-recognition-item-regular{background:#7892a1}.speech-recognition-item-regular:not(.speech-recognition-item-disabled):hover{background:#697882}.speech-recognition-item-aprove{background:#0c9348}.speech-recognition-item-aprove:not(.speech-recognition-item-disabled):hover{background:#063951}.speech-recognition-item-discard{background:#c13018}.speech-recognition-item-discard:not(.speech-recognition-item-disabled):hover{background:#063951}.speech-recognition-item-toolbar{background:#7892a1;display:-ms-flexbox;display:flex;border-radius:15px;-ms-flex-align:center;align-items:center;color:#fff}.speech-recognition-item-toolbar i,.speech-recognition-item-toolbar span{cursor:pointer}.speech-recognition-item-toolbar i:not(:first-child),.speech-recognition-item-toolbar i:not(:last-child){padding:6px}.speech-recognition-item-toolbar i:first-child{padding-left:10px}.speech-recognition-item-toolbar i:last-child{padding-right:10px}.speech-recognition-item-toolbar span{height:25px}.speech-recognition-text{color:#212533;font-size:12px;font-style:normal;font-weight:400;word-break:break-word}"]
|
|
211
198
|
})
|
|
212
199
|
], SpeechRecognitionComponent);
|
|
213
200
|
return SpeechRecognitionComponent;
|
|
214
201
|
}());
|
|
215
202
|
export { SpeechRecognitionComponent };
|
|
216
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"speech-recognition.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/speech-recognition/speech-recognition/speech-recognition.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { SpeechRecognitionService } from '../speech-recognition.service';\nimport { TextToSpeechService } from '../text-to-speech.service';\n\n@Component({\n  selector: 's-speech-recognition',\n  templateUrl: './speech-recognition.component.html',\n  styleUrls: ['./speech-recognition.component.scss']\n})\nexport class SpeechRecognitionComponent implements OnInit, OnDestroy, AfterViewInit {\n  @Input() textAreaElement: HTMLTextAreaElement;\n  private _recognizedText = '';\n  private originalTextAreaElementText = '';\n  private isDoneSpeaking = false;\n  private readonly onDestroy$ = new Subject<void>();\n  private readonly VOICE_SPEEDS = [0.5, 1, 1.5, 2];\n  private readonly SPEECH_RECOGNITION_MARGIN_OFFSET = 13;\n  private readonly keydownEventListener = (event: KeyboardEvent) => {\n    if (this.disabled) {\n      event.preventDefault();\n    }\n  }\n  private readonly TEXT_AREA_ELEMENT_MUTATION_OBSERVER = new MutationObserver(() => {\n    this.SPEECH_CONTAINER_WIDTH_CALLBACK();\n  })\n\n  private readonly SPEECH_CONTAINER_WIDTH_CALLBACK = () => {\n    this.setSpeechContainerWidth();\n  }\n  speechRecognitionContainerWidth = 0;\n\n  disabled = false;\n  isSpeaking = false;\n  voiceSpeed = 1;\n  isDisabledMicrophone = false;\n\n  canRenderMicrophone = true;\n  canRenderTextToSpeech = true;\n  canRenderListeningText = false;\n  canRenderDiscard = false;\n  canRenderAprove = false;\n  canRenderTextToSpeechToolbar = false;\n\n  isPlayingTextToSpeech = false;\n\n  @Output() recognizedText = new EventEmitter<string>();\n  constructor(\n    private readonly speechRecognitionService: SpeechRecognitionService,\n    private readonly textToSpeechService: TextToSpeechService,\n    private readonly translateService: TranslateService\n  ) { }\n\n  ngOnInit(): void {\n    if (!this.textAreaElement) {\n      throw new Error('textAreaElement is required');\n    }\n    this.textAreaElement.placeholder = this.translateService.instant(\"platform.angular_components.text_area_speech_recognition_placeholder\");\n    this.textAreaElement.addEventListener('keydown', this.keydownEventListener)\n    const config: MutationObserverInit = { attributes: true, childList: true, subtree: true };\n    this.TEXT_AREA_ELEMENT_MUTATION_OBSERVER.observe(this.textAreaElement, config);\n    window.addEventListener('resize', this.SPEECH_CONTAINER_WIDTH_CALLBACK)\n  }\n\n  ngAfterViewInit(): void {\n    setTimeout(() => {\n      this.setSpeechContainerWidth();\n    })\n  }\n\n  onListen() {\n    if (this.isDisabledMicrophone || this.isListening) {\n      return;\n    }\n    this.disabled = true;\n    this.canRenderMicrophone = false;\n    this.canRenderListeningText = true;\n    if (this.textAreaElement.value && !this.originalTextAreaElementText) {\n      this.originalTextAreaElementText = this.textAreaElement.value;\n    }\n\n\n    this.textAreaElement.value = '';\n    this.isSpeaking = true;\n    this.speechRecognitionService.listen()\n      .pipe(takeUntil(this.onDestroy$))\n      .subscribe(({ text, isFinal }) => {\n        this._recognizedText = text;\n        this.setTextAreaValue(text);\n        setTimeout(() => {\n          this.textAreaElement.scrollTop = this.textAreaElement.scrollHeight;\n        }, 120)\n        if (isFinal) {\n          this.canRenderAprove = true;\n          this.canRenderDiscard = true;\n          this.canRenderListeningText = false;\n          this.isSpeaking = false;\n        }\n      })\n  }\n\n  onOpenToolbar() {\n    if (this.isDisabledTextToSpeech) {\n      return;\n    }\n    this.canRenderTextToSpeechToolbar = true;\n    this.canRenderTextToSpeech = false;\n    this.isPlayingTextToSpeech = true;\n    this.speak();\n  }\n\n  onCloseToolbar() {\n    this.canRenderTextToSpeechToolbar = false;\n    this.canRenderTextToSpeech = true;\n    this.isPlayingTextToSpeech = false;\n    this.textToSpeechService.cancel();\n    this.voiceSpeed = 1;\n  }\n  onDiscard() {\n    this.canRenderAprove = false;\n    this.canRenderDiscard = false;\n    this.canRenderMicrophone = true;\n    this.canRenderTextToSpeechToolbar = false;\n    this.canRenderTextToSpeech = true;\n    this._recognizedText = '';\n    this.setTextAreaValue(this.originalTextAreaElementText);\n    this.disabled = false;\n    this.textToSpeechService.cancel();\n  }\n\n  onAprove() {\n    this.canRenderAprove = false;\n    this.canRenderDiscard = false;\n    this.canRenderMicrophone = true;\n    this.canRenderTextToSpeechToolbar = false;\n    this.canRenderTextToSpeech = true;\n    this.originalTextAreaElementText = this._recognizedText\n    this.recognizedText.emit(this._recognizedText);\n    this._recognizedText = '';\n    this.disabled = false;\n    this.textToSpeechService.cancel();\n  }\n\n  ngOnDestroy(): void {\n    this.onDestroy$.next();\n    this.onDestroy$.complete();\n    this.textAreaElement.removeEventListener('keydown', this.keydownEventListener);\n    window.removeEventListener('resize', this.SPEECH_CONTAINER_WIDTH_CALLBACK);\n    this.TEXT_AREA_ELEMENT_MUTATION_OBSERVER.disconnect();\n  }\n\n  toggleTextToSpeech() {\n    if (this.isPlayingTextToSpeech) {\n      this.textToSpeechService.pause();\n    } else {\n      if (this.isDoneSpeaking) {\n        this.speak();\n      } else {\n        this.textToSpeechService.resume();\n      }\n    }\n    this.isPlayingTextToSpeech = !this.isPlayingTextToSpeech;\n  }\n\n  restartTextToSpeech() {\n    this.isPlayingTextToSpeech = true;\n    this.textToSpeechService.cancel();\n    this.speak();\n  }\n\n  updateVoiceSpeed() {\n    const voiceSpeedIndex = this.VOICE_SPEEDS.indexOf(this.voiceSpeed);\n    const nextVoiceSpeedIndex = this.VOICE_SPEEDS[voiceSpeedIndex + 1] ? voiceSpeedIndex + 1 : 0;\n    this.voiceSpeed = this.VOICE_SPEEDS[nextVoiceSpeedIndex];\n    this.textToSpeechService.cancel();\n    this.speak()\n  }\n\n  stopListening() {\n    this.speechRecognitionService.stop();\n  }\n\n  get isListening() {\n    return this.speechRecognitionService.isListening\n  }\n\n  get isDisabledTextToSpeech() {\n    const hasTextToSpeechVoice = this.textToSpeechService.hasVoice;\n    return !this._recognizedText || !hasTextToSpeechVoice || this.isListening;\n  }\n  private setTextAreaValue(value: string) {\n    this.textAreaElement.value = value;\n  }\n\n  private speak() {\n    this.isDoneSpeaking = false;\n    this.textToSpeechService.speak(this._recognizedText, this.voiceSpeed).then(() => {\n      this.isPlayingTextToSpeech = false;\n      this.isDoneSpeaking = true;\n    });\n  }\n\n  private setSpeechContainerWidth() {\n    this.speechRecognitionContainerWidth = this.textAreaElement.getBoundingClientRect().width - this.SPEECH_RECOGNITION_MARGIN_OFFSET;\n  }\n}\n"]}
|
|
203
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"speech-recognition.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/speech-recognition/speech-recognition/speech-recognition.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { SpeechRecognitionService } from '../speech-recognition.service';\nimport { TextToSpeechService } from '../text-to-speech.service';\n\n@Component({\n  selector: 's-speech-recognition',\n  templateUrl: './speech-recognition.component.html',\n  styleUrls: ['./speech-recognition.component.scss']\n})\nexport class SpeechRecognitionComponent implements OnInit, OnDestroy {\n  @Input() textAreaElement: HTMLTextAreaElement;\n  private _recognizedText = '';\n  private originalTextAreaElementText = '';\n  private isDoneSpeaking = false;\n  private readonly onDestroy$ = new Subject<void>();\n  private readonly VOICE_SPEEDS = [0.5, 1, 1.5, 2];\n  private readonly keydownEventListener = (event: KeyboardEvent) => {\n    if (this.disabled) {\n      event.preventDefault();\n    }\n  }\n\n  disabled = false;\n  isSpeaking = false;\n  voiceSpeed = 1;\n  isDisabledMicrophone = false;\n\n  canRenderMicrophone = true;\n  canRenderTextToSpeech = true;\n  canRenderListeningText = false;\n  canRenderDiscard = false;\n  canRenderAprove = false;\n  canRenderTextToSpeechToolbar = false;\n\n  isPlayingTextToSpeech = false;\n\n  @Output() recognizedText = new EventEmitter<string>();\n  constructor(\n    private readonly speechRecognitionService: SpeechRecognitionService,\n    private readonly textToSpeechService: TextToSpeechService,\n    private readonly translateService: TranslateService\n  ) { }\n\n  ngOnInit(): void {\n    if (!this.hasSpeechRecognitionBrowserApi) {\n      return;\n    }\n    if (!this.textAreaElement) {\n      throw new Error('textAreaElement is required');\n    }\n    this.textAreaElement.placeholder = this.translateService.instant(\"platform.angular_components.text_area_speech_recognition_placeholder\");\n    this.textAreaElement.addEventListener('keydown', this.keydownEventListener)\n  }\n\n  onListen() {\n    if (this.isDisabledMicrophone || this.isListening) {\n      return;\n    }\n    this.disabled = true;\n    this.canRenderMicrophone = false;\n    this.canRenderListeningText = true;\n    if (this.textAreaElement.value && !this.originalTextAreaElementText) {\n      this.originalTextAreaElementText = this.textAreaElement.value;\n    }\n\n\n    this.textAreaElement.value = '';\n    this.isSpeaking = true;\n    this.speechRecognitionService.listen()\n      .pipe(takeUntil(this.onDestroy$))\n      .subscribe(({ text, isFinal }) => {\n        this._recognizedText = text;\n        this.setTextAreaValue(text);\n        setTimeout(() => {\n          this.textAreaElement.scrollTop = this.textAreaElement.scrollHeight;\n        }, 120)\n        if (isFinal) {\n          this.canRenderAprove = true;\n          this.canRenderDiscard = true;\n          this.canRenderListeningText = false;\n          this.isSpeaking = false;\n        }\n      })\n  }\n\n  onOpenToolbar() {\n    if (this.isDisabledTextToSpeech) {\n      return;\n    }\n    this.canRenderTextToSpeechToolbar = true;\n    this.canRenderTextToSpeech = false;\n    this.isPlayingTextToSpeech = true;\n    this.speak();\n  }\n\n  onCloseToolbar() {\n    this.canRenderTextToSpeechToolbar = false;\n    this.canRenderTextToSpeech = true;\n    this.isPlayingTextToSpeech = false;\n    this.textToSpeechService.cancel();\n    this.voiceSpeed = 1;\n  }\n  onDiscard() {\n    this.canRenderAprove = false;\n    this.canRenderDiscard = false;\n    this.canRenderMicrophone = true;\n    this.canRenderTextToSpeechToolbar = false;\n    this.canRenderTextToSpeech = true;\n    this._recognizedText = '';\n    this.setTextAreaValue(this.originalTextAreaElementText);\n    this.disabled = false;\n    this.textToSpeechService.cancel();\n  }\n\n  onAprove() {\n    this.canRenderAprove = false;\n    this.canRenderDiscard = false;\n    this.canRenderMicrophone = true;\n    this.canRenderTextToSpeechToolbar = false;\n    this.canRenderTextToSpeech = true;\n    this.originalTextAreaElementText = this._recognizedText\n    this.recognizedText.emit(this._recognizedText);\n    this._recognizedText = '';\n    this.disabled = false;\n    this.textToSpeechService.cancel();\n  }\n\n  ngOnDestroy(): void {\n    this.onDestroy$.next();\n    this.onDestroy$.complete();\n  }\n\n  toggleTextToSpeech() {\n    if (this.isPlayingTextToSpeech) {\n      this.textToSpeechService.pause();\n    } else {\n      if (this.isDoneSpeaking) {\n        this.speak();\n      } else {\n        this.textToSpeechService.resume();\n      }\n    }\n    this.isPlayingTextToSpeech = !this.isPlayingTextToSpeech;\n  }\n\n  restartTextToSpeech() {\n    this.isPlayingTextToSpeech = true;\n    this.textToSpeechService.cancel();\n    this.speak();\n  }\n\n  updateVoiceSpeed() {\n    const voiceSpeedIndex = this.VOICE_SPEEDS.indexOf(this.voiceSpeed);\n    const nextVoiceSpeedIndex = this.VOICE_SPEEDS[voiceSpeedIndex + 1] ? voiceSpeedIndex + 1 : 0;\n    this.voiceSpeed = this.VOICE_SPEEDS[nextVoiceSpeedIndex];\n    this.textToSpeechService.cancel();\n    this.speak()\n  }\n\n  stopListening() {\n    this.speechRecognitionService.stop();\n  }\n\n  get isListening() {\n    return this.speechRecognitionService.isListening\n  }\n\n  get hasSpeechRecognitionBrowserApi() {\n    return this.speechRecognitionService.hasSupportSpeechRecognition;\n  }\n\n  get isDisabledTextToSpeech() {\n    const hasTextToSpeechVoice = this.textToSpeechService.hasVoice;\n    return !this._recognizedText || !hasTextToSpeechVoice || this.isListening;\n  }\n  private setTextAreaValue(value: string) {\n    this.textAreaElement.value = value;\n  }\n\n  private speak() {\n    this.isDoneSpeaking = false;\n    this.textToSpeechService.speak(this._recognizedText, this.voiceSpeed).then(() => {\n      this.isPlayingTextToSpeech = false;\n      this.isDoneSpeaking = true;\n    });\n  }\n\n}\n"]}
|
|
@@ -8,6 +8,7 @@ var SpeechRecognitionService = /** @class */ (function () {
|
|
|
8
8
|
function SpeechRecognitionService(localeService, ngZone) {
|
|
9
9
|
this.localeService = localeService;
|
|
10
10
|
this.ngZone = ngZone;
|
|
11
|
+
this.hasSupportSpeechRecognition = false;
|
|
11
12
|
this.isListening = false;
|
|
12
13
|
this.TIMEOUT_NO_MESSAGE = 3000;
|
|
13
14
|
this.setRecognition();
|
|
@@ -79,14 +80,19 @@ var SpeechRecognitionService = /** @class */ (function () {
|
|
|
79
80
|
this.recognition.stop();
|
|
80
81
|
};
|
|
81
82
|
SpeechRecognitionService.prototype.setRecognition = function () {
|
|
83
|
+
var _this = this;
|
|
84
|
+
var _a;
|
|
82
85
|
var SpeechRecognitionConstructor = window.SpeechRecognition || window.webkitSpeechRecognition;
|
|
83
86
|
if (!SpeechRecognitionConstructor) {
|
|
84
|
-
|
|
87
|
+
console.warn('Speech recognition is not supported in this browser.');
|
|
88
|
+
return;
|
|
85
89
|
}
|
|
90
|
+
this.hasSupportSpeechRecognition = true;
|
|
86
91
|
this.recognition = new SpeechRecognitionConstructor();
|
|
87
|
-
this.recognition.lang = this.localeService.getLocaleOptions().locale || 'pt-BR';
|
|
92
|
+
this.recognition.lang = ((_a = this.localeService.getLocaleOptions()) === null || _a === void 0 ? void 0 : _a.locale) || 'pt-BR';
|
|
88
93
|
this.recognition.interimResults = false;
|
|
89
94
|
this.recognition.maxAlternatives = 1;
|
|
95
|
+
this.localeService.getLocale().subscribe(function (locale) { return _this.recognition.lang = locale; });
|
|
90
96
|
};
|
|
91
97
|
SpeechRecognitionService.ctorParameters = function () { return [
|
|
92
98
|
{ type: LocaleService },
|
|
@@ -101,4 +107,4 @@ var SpeechRecognitionService = /** @class */ (function () {
|
|
|
101
107
|
return SpeechRecognitionService;
|
|
102
108
|
}());
|
|
103
109
|
export { SpeechRecognitionService };
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"speech-recognition.service.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/speech-recognition/speech-recognition.service.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;;;AAUzD;IAME,kCAA6B,aAA4B,EAAmB,MAAc;QAA7D,kBAAa,GAAb,aAAa,CAAe;QAAmB,WAAM,GAAN,MAAM,CAAQ;QAL1F,gCAA2B,GAAG,KAAK,CAAC;QACpC,gBAAW,GAAG,KAAK,CAAC;QAEH,uBAAkB,GAAG,IAAI,CAAC;QAGzC,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,yCAAM,GAAN;QAAA,iBAiEC;QAhEC,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,OAAO;SACR;QACD,IAAM,aAAa,GAAG,IAAI,OAAO,EAAgB,CAAC;QAClD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,WAAW,CAAC,UAAU,GAAG,IAAI,CAAC;QACnC,IAAI,CAAC,WAAW,CAAC,cAAc,GAAG,IAAI,CAAC;QACvC,IAAI,CAAC,WAAW,CAAC,eAAe,GAAG,CAAC,CAAC;QACrC,IAAI,YAAiB,CAAC;QACtB,IAAM,mBAAmB,GAAG;YAC1B,IAAI,YAAY,KAAK,SAAS,EAAE;gBAC9B,YAAY,CAAC,YAAY,CAAC,CAAC;aAC5B;YAED,YAAY,GAAG,UAAU,CAAC;gBACxB,KAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;YAC1B,CAAC,EAAE,KAAI,CAAC,kBAAkB,CAAC,CAAC;QAC9B,CAAC,CAAC;QACF,IAAI,cAAc,GAAG,EAAE,CAAC;QACxB,IAAI,iBAAiB,GAAG,EAAE,CAAC;QAE3B,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,UAAC,KAA6B;YACxD,KAAI,CAAC,MAAM,CAAC,GAAG,CAAC;gBACd,mBAAmB,EAAE,CAAC;gBACtB,IAAI,iBAAiB,GAAG,EAAE,CAAC;gBAC3B,KAAK,IAAI,CAAC,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;oBAC7D,IAAM,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC;oBAClD,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE;wBAC5B,cAAc,IAAI,UAAU,GAAG,IAAI,CAAC;qBACrC;yBAAM;wBACL,iBAAiB,IAAI,UAAU,CAAC;qBACjC;iBACF;gBACD,iBAAiB,GAAG,iBAAiB,CAAC;gBACtC,aAAa,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,cAAc,GAAG,iBAAiB,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;YACnF,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC;QAGF,IAAI,CAAC,WAAW,CAAC,OAAO,GAAG;YACzB,KAAI,CAAC,MAAM,CAAC,GAAG,CAAC;gBACd,IAAI,YAAY,KAAK,SAAS,EAAE;oBAC9B,YAAY,CAAC,YAAY,CAAC,CAAC;iBAC5B;gBACD,KAAI,CAAC,WAAW,GAAG,KAAK,CAAC;gBACzB,aAAa,CAAC,IAAI,CAAC;oBACjB,OAAO,EAAE,IAAI;oBACb,IAAI,EAAE,EAAE;iBACT,CAAC,CAAA;YACJ,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC;QAEF,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG;YACvB,KAAI,CAAC,MAAM,CAAC,GAAG,CAAC;gBACd,IAAI,YAAY,KAAK,SAAS,EAAE;oBAC9B,YAAY,CAAC,YAAY,CAAC,CAAC;iBAC5B;gBACD,aAAa,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,cAAc,GAAG,iBAAiB,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;gBAChF,KAAI,CAAC,WAAW,GAAG,KAAK,CAAC;gBACzB,aAAa,CAAC,QAAQ,EAAE,CAAC;YAC3B,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC;QACF,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;QACzB,OAAO,aAAa,CAAC;IACvB,CAAC;IAED,uCAAI,GAAJ;QACE,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;IAC1B,CAAC;IAEO,iDAAc,GAAtB;QAAA,iBAcC;;QAbC,IAAM,4BAA4B,GAC/B,MAAc,CAAC,iBAAiB,IAAK,MAAc,CAAC,uBAAuB,CAAC;QAE/E,IAAI,CAAC,4BAA4B,EAAE;YACjC,OAAO,CAAC,IAAI,CAAC,sDAAsD,CAAC,CAAC;YACrE,OAAO;SACR;QACD,IAAI,CAAC,2BAA2B,GAAG,IAAI,CAAC;QACxC,IAAI,CAAC,WAAW,GAAG,IAAI,4BAA4B,EAAE,CAAC;QACtD,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,OAAA,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE,0CAAE,MAAM,KAAI,OAAO,CAAC;QACjF,IAAI,CAAC,WAAW,CAAC,cAAc,GAAG,KAAK,CAAC;QACxC,IAAI,CAAC,WAAW,CAAC,eAAe,GAAG,CAAC,CAAC;QACrC,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC,SAAS,CAAC,UAAA,MAAM,IAAI,OAAA,KAAI,CAAC,WAAW,CAAC,IAAI,GAAG,MAAM,EAA9B,CAA8B,CAAC,CAAC;IACrF,CAAC;;gBAzF2C,aAAa;gBAA2B,MAAM;;;IAN/E,wBAAwB;QAHpC,UAAU,CAAC;YACV,UAAU,EAAE,MAAM;SACnB,CAAC;OACW,wBAAwB,CAgGpC;mCA5GD;CA4GC,AAhGD,IAgGC;SAhGY,wBAAwB","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { LocaleService } from '../locale/locale.service';\n\nexport interface SpeechResult {\n  text: string;\n  isFinal: boolean;\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class SpeechRecognitionService {\n  hasSupportSpeechRecognition = false;\n  isListening = false;\n  private recognition!: SpeechRecognition;\n  private readonly TIMEOUT_NO_MESSAGE = 3000;\n\n  constructor(private readonly localeService: LocaleService, private readonly ngZone: NgZone) {\n    this.setRecognition();\n  }\n\n  listen(): Subject<SpeechResult> {\n    if (this.isListening) {\n      return;\n    }\n    const speechSubject = new Subject<SpeechResult>();\n    this.isListening = true;\n    this.recognition.continuous = true;\n    this.recognition.interimResults = true;\n    this.recognition.maxAlternatives = 1;\n    let silenceTimer: any;\n    const restartSilenceTimer = () => {\n      if (silenceTimer !== undefined) {\n        clearTimeout(silenceTimer);\n      }\n\n      silenceTimer = setTimeout(() => {\n        this.recognition.stop();\n      }, this.TIMEOUT_NO_MESSAGE);\n    };\n    let fullTranscript = '';\n    let interimTranscript = '';\n\n    this.recognition.onresult = (event: SpeechRecognitionEvent) => {\n      this.ngZone.run(() => {\n        restartSilenceTimer();\n        let interimTranscript = '';\n        for (let i = event.resultIndex; i < event.results.length; ++i) {\n          const transcript = event.results[i][0].transcript;\n          if (event.results[i].isFinal) {\n            fullTranscript += transcript + '\\n';\n          } else {\n            interimTranscript += transcript;\n          }\n        }\n        interimTranscript = interimTranscript;\n        speechSubject.next({ text: fullTranscript + interimTranscript, isFinal: false });\n      })\n    };\n\n\n    this.recognition.onerror = () => {\n      this.ngZone.run(() => {\n        if (silenceTimer !== undefined) {\n          clearTimeout(silenceTimer);\n        }\n        this.isListening = false;\n        speechSubject.next({\n          isFinal: true,\n          text: ''\n        })\n      })\n    };\n\n    this.recognition.onend = () => {\n      this.ngZone.run(() => {\n        if (silenceTimer !== undefined) {\n          clearTimeout(silenceTimer);\n        }\n        speechSubject.next({ text: fullTranscript + interimTranscript, isFinal: true });\n        this.isListening = false;\n        speechSubject.complete();\n      })\n    };\n    this.recognition.start();\n    return speechSubject;\n  }\n\n  stop() {\n    this.recognition.stop();\n  }\n\n  private setRecognition() {\n    const SpeechRecognitionConstructor =\n      (window as any).SpeechRecognition || (window as any).webkitSpeechRecognition;\n\n    if (!SpeechRecognitionConstructor) {\n      console.warn('Speech recognition is not supported in this browser.');\n      return;\n    }\n    this.hasSupportSpeechRecognition = true;\n    this.recognition = new SpeechRecognitionConstructor();\n    this.recognition.lang = this.localeService.getLocaleOptions()?.locale || 'pt-BR';\n    this.recognition.interimResults = false;\n    this.recognition.maxAlternatives = 1;\n    this.localeService.getLocale().subscribe(locale => this.recognition.lang = locale);\n  }\n}\n"]}
|
|
@@ -17,10 +17,13 @@ var TextToSpeechService = /** @class */ (function () {
|
|
|
17
17
|
if (!_voices.length) {
|
|
18
18
|
speechSynthesis.onvoiceschanged = function () {
|
|
19
19
|
_this.ngZone.run(function () {
|
|
20
|
+
var _a;
|
|
20
21
|
_voices = speechSynthesis.getVoices();
|
|
21
|
-
var currentLang = _this.locale.getLocaleOptions().locale || 'pt-BR';
|
|
22
|
-
_this.
|
|
23
|
-
_this.
|
|
22
|
+
var currentLang = ((_a = _this.locale.getLocaleOptions()) === null || _a === void 0 ? void 0 : _a.locale) || 'pt-BR';
|
|
23
|
+
_this.setActiveVoice(_voices, currentLang);
|
|
24
|
+
_this.locale.getLocale().subscribe(function (locale) {
|
|
25
|
+
_this.setActiveVoice(_voices, locale);
|
|
26
|
+
});
|
|
24
27
|
});
|
|
25
28
|
};
|
|
26
29
|
}
|
|
@@ -67,6 +70,12 @@ var TextToSpeechService = /** @class */ (function () {
|
|
|
67
70
|
enumerable: true,
|
|
68
71
|
configurable: true
|
|
69
72
|
});
|
|
73
|
+
TextToSpeechService.prototype.setActiveVoice = function (voices, lang) {
|
|
74
|
+
var _voice = voices.find(function (voice) { return voice.lang === lang; });
|
|
75
|
+
if (_voice) {
|
|
76
|
+
this.activeVoice = _voice;
|
|
77
|
+
}
|
|
78
|
+
};
|
|
70
79
|
TextToSpeechService.ctorParameters = function () { return [
|
|
71
80
|
{ type: LocaleService },
|
|
72
81
|
{ type: NgZone }
|
|
@@ -80,4 +89,4 @@ var TextToSpeechService = /** @class */ (function () {
|
|
|
80
89
|
return TextToSpeechService;
|
|
81
90
|
}());
|
|
82
91
|
export { TextToSpeechService };
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC10by1zcGVlY2guc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL3NwZWVjaC1yZWNvZ25pdGlvbi90ZXh0LXRvLXNwZWVjaC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7OztBQUt6RDtJQUtFLDZCQUE2QixNQUFxQixFQUFtQixNQUFjO1FBQXRELFdBQU0sR0FBTixNQUFNLENBQWU7UUFBbUIsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUpsRSxjQUFTLEdBQUcsSUFBSSx3QkFBd0IsRUFBRSxDQUFDO1FBRTVELFdBQU0sR0FBMkIsRUFBRSxDQUFDO1FBR2xDLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztJQUNuQixDQUFDO0lBRU8sdUNBQVMsR0FBakI7UUFBQSxpQkFlQztRQWRDLElBQUksT0FBTyxHQUFHLGVBQWUsQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUUxQyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRTtZQUNuQixlQUFlLENBQUMsZUFBZSxHQUFHO2dCQUNoQyxLQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQzs7b0JBQ2QsT0FBTyxHQUFHLGVBQWUsQ0FBQyxTQUFTLEVBQUUsQ0FBQztvQkFDdEMsSUFBTSxXQUFXLEdBQUcsT0FBQSxLQUFJLENBQUMsTUFBTSxDQUFDLGdCQUFnQixFQUFFLDBDQUFFLE1BQU0sS0FBSSxPQUFPLENBQUM7b0JBQ3RFLEtBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxFQUFFLFdBQVcsQ0FBQyxDQUFDO29CQUMxQyxLQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxDQUFDLFNBQVMsQ0FBQyxVQUFDLE1BQU07d0JBQ3ZDLEtBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDO29CQUN2QyxDQUFDLENBQUMsQ0FBQTtnQkFDSixDQUFDLENBQUMsQ0FBQTtZQUNKLENBQUMsQ0FBQTtTQUNGO0lBQ0gsQ0FBQztJQUVEOzs7O09BSUc7SUFDSCx5Q0FBVyxHQUFYLFVBQVksUUFBZ0I7UUFDMUIsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFDLEtBQUssSUFBSyxPQUFBLEtBQUssQ0FBQyxRQUFRLEtBQUssUUFBUSxFQUEzQixDQUEyQixDQUFDLENBQUM7SUFDOUUsQ0FBQztJQUdELG1DQUFLLEdBQUwsVUFBTSxJQUFZLEVBQUUsS0FBaUI7UUFBckMsaUJBZUM7UUFmbUIsc0JBQUEsRUFBQSxTQUFpQjtRQUNuQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNyQixPQUFPO1NBQ1I7UUFDRCxPQUFPLElBQUksT0FBTyxDQUFDLFVBQUMsT0FBTztZQUN6QixLQUFJLENBQUMsU0FBUyxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7WUFDM0IsS0FBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEdBQUcsS0FBSSxDQUFDLFdBQVcsQ0FBQztZQUN4QyxLQUFJLENBQUMsU0FBUyxDQUFDLElBQUksR0FBRyxLQUFLLENBQUM7WUFDNUIsZUFBZSxDQUFDLEtBQUssQ0FBQyxLQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDdEMsS0FBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEdBQUc7Z0JBQ3JCLEtBQUksQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDO29CQUNkLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDaEIsQ0FBQyxDQUFDLENBQUE7WUFDSixDQUFDLENBQUE7UUFDSCxDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7SUFFRCxtQ0FBSyxHQUFMO1FBQ0UsZUFBZSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFRCxvQ0FBTSxHQUFOO1FBQ0UsZUFBZSxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRCxvQ0FBTSxHQUFOO1FBQ0UsZUFBZSxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRCxzQkFBSSx5Q0FBUTthQUFaO1lBQ0UsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQztRQUM1QixDQUFDOzs7T0FBQTtJQUVPLDRDQUFjLEdBQXRCLFVBQXVCLE1BQThCLEVBQUUsSUFBWTtRQUNqRSxJQUFNLE1BQU0sR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLFVBQUMsS0FBSyxJQUFLLE9BQUEsS0FBSyxDQUFDLElBQUksS0FBSyxJQUFJLEVBQW5CLENBQW1CLENBQUMsQ0FBQztRQUMzRCxJQUFJLE1BQU0sRUFBRTtZQUNWLElBQUksQ0FBQyxXQUFXLEdBQUcsTUFBTSxDQUFDO1NBQzNCO0lBQ0gsQ0FBQzs7Z0JBckVvQyxhQUFhO2dCQUEyQixNQUFNOzs7SUFMeEUsbUJBQW1CO1FBSC9CLFVBQVUsQ0FBQztZQUNWLFVBQVUsRUFBRSxNQUFNO1NBQ25CLENBQUM7T0FDVyxtQkFBbUIsQ0EyRS9COzhCQWpGRDtDQWlGQyxBQTNFRCxJQTJFQztTQTNFWSxtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBOZ1pvbmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IExvY2FsZVNlcnZpY2UgfSBmcm9tICcuLi9sb2NhbGUvbG9jYWxlLnNlcnZpY2UnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBUZXh0VG9TcGVlY2hTZXJ2aWNlIHtcbiAgcHJpdmF0ZSByZWFkb25seSB1dHRlcmFuY2UgPSBuZXcgU3BlZWNoU3ludGhlc2lzVXR0ZXJhbmNlKCk7XG4gIHByaXZhdGUgYWN0aXZlVm9pY2U6IFNwZWVjaFN5bnRoZXNpc1ZvaWNlO1xuICB2b2ljZXM6IFNwZWVjaFN5bnRoZXNpc1ZvaWNlW10gPSBbXTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGxvY2FsZTogTG9jYWxlU2VydmljZSwgcHJpdmF0ZSByZWFkb25seSBuZ1pvbmU6IE5nWm9uZSkge1xuICAgIHRoaXMuc2V0Vm9pY2VzKCk7XG4gIH1cblxuICBwcml2YXRlIHNldFZvaWNlcygpIHtcbiAgICBsZXQgX3ZvaWNlcyA9IHNwZWVjaFN5bnRoZXNpcy5nZXRWb2ljZXMoKTtcblxuICAgIGlmICghX3ZvaWNlcy5sZW5ndGgpIHtcbiAgICAgIHNwZWVjaFN5bnRoZXNpcy5vbnZvaWNlc2NoYW5nZWQgPSAoKSA9PiB7XG4gICAgICAgIHRoaXMubmdab25lLnJ1bigoKSA9PiB7XG4gICAgICAgICAgX3ZvaWNlcyA9IHNwZWVjaFN5bnRoZXNpcy5nZXRWb2ljZXMoKTtcbiAgICAgICAgICBjb25zdCBjdXJyZW50TGFuZyA9IHRoaXMubG9jYWxlLmdldExvY2FsZU9wdGlvbnMoKT8ubG9jYWxlIHx8ICdwdC1CUic7XG4gICAgICAgICAgdGhpcy5zZXRBY3RpdmVWb2ljZShfdm9pY2VzLCBjdXJyZW50TGFuZyk7XG4gICAgICAgICAgdGhpcy5sb2NhbGUuZ2V0TG9jYWxlKCkuc3Vic2NyaWJlKChsb2NhbGUpID0+IHtcbiAgICAgICAgICAgIHRoaXMuc2V0QWN0aXZlVm9pY2UoX3ZvaWNlcywgbG9jYWxlKTtcbiAgICAgICAgICB9KVxuICAgICAgICB9KVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBVcGRhdGVzIHRoZSBhY3RpdmUgdm9pY2VcbiAgICogW01ETiBSZWZlcmVuY2VdKGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2RvY3MvV2ViL0FQSS9TcGVlY2hTeW50aGVzaXNWb2ljZS92b2ljZVVSSSlcbiAgICogQHBhcmFtIHZvaWNlVXJpXG4gICAqL1xuICB1cGRhdGVWb2ljZSh2b2ljZVVyaTogc3RyaW5nKSB7XG4gICAgdGhpcy5hY3RpdmVWb2ljZSA9IHRoaXMudm9pY2VzLmZpbmQoKHZvaWNlKSA9PiB2b2ljZS52b2ljZVVSSSA9PT0gdm9pY2VVcmkpO1xuICB9XG5cblxuICBzcGVhayh0ZXh0OiBzdHJpbmcsIHNwZWVkOiBudW1iZXIgPSAxKSB7XG4gICAgaWYgKCF0aGlzLmFjdGl2ZVZvaWNlKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSkgPT4ge1xuICAgICAgdGhpcy51dHRlcmFuY2UudGV4dCA9IHRleHQ7XG4gICAgICB0aGlzLnV0dGVyYW5jZS52b2ljZSA9IHRoaXMuYWN0aXZlVm9pY2U7XG4gICAgICB0aGlzLnV0dGVyYW5jZS5yYXRlID0gc3BlZWQ7XG4gICAgICBzcGVlY2hTeW50aGVzaXMuc3BlYWsodGhpcy51dHRlcmFuY2UpO1xuICAgICAgdGhpcy51dHRlcmFuY2Uub25lbmQgPSAoKSA9PiB7XG4gICAgICAgIHRoaXMubmdab25lLnJ1bigoKSA9PiB7XG4gICAgICAgICAgcmVzb2x2ZSh0cnVlKTtcbiAgICAgICAgfSlcbiAgICAgIH1cbiAgICB9KVxuICB9XG5cbiAgcGF1c2UoKSB7XG4gICAgc3BlZWNoU3ludGhlc2lzLnBhdXNlKCk7XG4gIH1cblxuICByZXN1bWUoKSB7XG4gICAgc3BlZWNoU3ludGhlc2lzLnJlc3VtZSgpO1xuICB9XG5cbiAgY2FuY2VsKCkge1xuICAgIHNwZWVjaFN5bnRoZXNpcy5jYW5jZWwoKTtcbiAgfVxuXG4gIGdldCBoYXNWb2ljZSgpIHtcbiAgICByZXR1cm4gISF0aGlzLmFjdGl2ZVZvaWNlO1xuICB9XG5cbiAgcHJpdmF0ZSBzZXRBY3RpdmVWb2ljZSh2b2ljZXM6IFNwZWVjaFN5bnRoZXNpc1ZvaWNlW10sIGxhbmc6IHN0cmluZykge1xuICAgIGNvbnN0IF92b2ljZSA9IHZvaWNlcy5maW5kKCh2b2ljZSkgPT4gdm9pY2UubGFuZyA9PT0gbGFuZyk7XG4gICAgaWYgKF92b2ljZSkge1xuICAgICAgdGhpcy5hY3RpdmVWb2ljZSA9IF92b2ljZTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { __decorate } from "tslib";
|
|
2
|
-
import { Component, ElementRef, forwardRef, Input, ViewChild } from '@angular/core';
|
|
1
|
+
import { __assign, __decorate } from "tslib";
|
|
2
|
+
import { ChangeDetectorRef, Component, ElementRef, forwardRef, Input, ViewChild } from '@angular/core';
|
|
3
3
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
4
|
var TextAreaComponent = /** @class */ (function () {
|
|
5
|
-
function TextAreaComponent() {
|
|
5
|
+
function TextAreaComponent(cdr) {
|
|
6
|
+
this.cdr = cdr;
|
|
6
7
|
this.onChange = function () { };
|
|
7
8
|
this.onTouched = function () { };
|
|
8
9
|
this.disabled = false;
|
|
@@ -10,6 +11,9 @@ var TextAreaComponent = /** @class */ (function () {
|
|
|
10
11
|
this.inputId = "textarea-" + Math.random();
|
|
11
12
|
this.rows = 5;
|
|
12
13
|
this.speechRecognition = false;
|
|
14
|
+
this._inputStyle = {
|
|
15
|
+
resize: 'vertical'
|
|
16
|
+
};
|
|
13
17
|
this.readOnly = false;
|
|
14
18
|
this.renderTextArea = false;
|
|
15
19
|
}
|
|
@@ -23,11 +27,37 @@ var TextAreaComponent = /** @class */ (function () {
|
|
|
23
27
|
this._textAreaElement = value;
|
|
24
28
|
setTimeout(function () {
|
|
25
29
|
_this.renderTextArea = true;
|
|
30
|
+
_this.cdr.detectChanges();
|
|
26
31
|
});
|
|
27
32
|
},
|
|
28
33
|
enumerable: true,
|
|
29
34
|
configurable: true
|
|
30
35
|
});
|
|
36
|
+
Object.defineProperty(TextAreaComponent.prototype, "placeholder", {
|
|
37
|
+
get: function () {
|
|
38
|
+
return this._placeholder;
|
|
39
|
+
},
|
|
40
|
+
set: function (value) {
|
|
41
|
+
if (value) {
|
|
42
|
+
this._placeholder = value;
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
this._placeholder = '';
|
|
46
|
+
}
|
|
47
|
+
},
|
|
48
|
+
enumerable: true,
|
|
49
|
+
configurable: true
|
|
50
|
+
});
|
|
51
|
+
Object.defineProperty(TextAreaComponent.prototype, "inputStyle", {
|
|
52
|
+
get: function () {
|
|
53
|
+
return this._inputStyle;
|
|
54
|
+
},
|
|
55
|
+
set: function (value) {
|
|
56
|
+
this._inputStyle = __assign(__assign({}, value), this._inputStyle);
|
|
57
|
+
},
|
|
58
|
+
enumerable: true,
|
|
59
|
+
configurable: true
|
|
60
|
+
});
|
|
31
61
|
TextAreaComponent.prototype.writeValue = function (obj) {
|
|
32
62
|
this.value = obj;
|
|
33
63
|
};
|
|
@@ -53,6 +83,9 @@ var TextAreaComponent = /** @class */ (function () {
|
|
|
53
83
|
this.setValue(recognizedText);
|
|
54
84
|
};
|
|
55
85
|
var TextAreaComponent_1;
|
|
86
|
+
TextAreaComponent.ctorParameters = function () { return [
|
|
87
|
+
{ type: ChangeDetectorRef }
|
|
88
|
+
]; };
|
|
56
89
|
__decorate([
|
|
57
90
|
ViewChild('textArea', { read: ElementRef })
|
|
58
91
|
], TextAreaComponent.prototype, "textAreaElement", null);
|
|
@@ -70,14 +103,17 @@ var TextAreaComponent = /** @class */ (function () {
|
|
|
70
103
|
], TextAreaComponent.prototype, "keyFilter", void 0);
|
|
71
104
|
__decorate([
|
|
72
105
|
Input()
|
|
73
|
-
], TextAreaComponent.prototype, "
|
|
106
|
+
], TextAreaComponent.prototype, "placeholder", null);
|
|
107
|
+
__decorate([
|
|
108
|
+
Input()
|
|
109
|
+
], TextAreaComponent.prototype, "inputStyle", null);
|
|
74
110
|
__decorate([
|
|
75
111
|
Input()
|
|
76
112
|
], TextAreaComponent.prototype, "readOnly", void 0);
|
|
77
113
|
TextAreaComponent = TextAreaComponent_1 = __decorate([
|
|
78
114
|
Component({
|
|
79
115
|
selector: 's-textarea',
|
|
80
|
-
template: "<textarea\n *ngIf=\"keyFilter\"\n #textArea\n class=\"textarea\"\n [pKeyFilter]=\"keyFilter\"\n [id]=\"inputId\"\n [rows]=\"rows\"\n [(ngModel)]=\"value\"\n [disabled]=\"disabled\"\n [ngStyle]=\"inputStyle\"\n [readOnly]=\"readOnly\"\n (ngModelChange)=\"setValue($event)\">\n</textarea>\n\n<textarea\n *ngIf=\"!keyFilter\"\n #textArea\n class=\"textarea\"\n [id]=\"inputId\"\n [rows]=\"rows\"\n [(ngModel)]=\"value\"\n [disabled]=\"disabled\"\n [ngStyle]=\"inputStyle\"\n [readOnly]=\"readOnly\"\n (ngModelChange)=\"setValue($event)\">\n</textarea>\n\n<s-speech-recognition\n *ngIf=\"speechRecognition && renderTextArea\"\n [textAreaElement]=\"textAreaElement.nativeElement\"\n (recognizedText)=\"handleRecognizedText($event)\">\n</s-speech-recognition>\n",
|
|
116
|
+
template: "<textarea\n *ngIf=\"keyFilter\"\n #textArea\n class=\"textarea\"\n [pKeyFilter]=\"keyFilter\"\n [id]=\"inputId\"\n [rows]=\"rows\"\n [(ngModel)]=\"value\"\n [disabled]=\"disabled\"\n [ngStyle]=\"inputStyle\"\n [readOnly]=\"readOnly\"\n [placeholder]=\"placeholder\"\n (ngModelChange)=\"setValue($event)\">\n</textarea>\n\n<textarea\n *ngIf=\"!keyFilter\"\n #textArea\n class=\"textarea\"\n [id]=\"inputId\"\n [rows]=\"rows\"\n [(ngModel)]=\"value\"\n [disabled]=\"disabled\"\n [ngStyle]=\"inputStyle\"\n [readOnly]=\"readOnly\"\n [placeholder]=\"placeholder\"\n (ngModelChange)=\"setValue($event)\">\n</textarea>\n\n<s-speech-recognition\n *ngIf=\"speechRecognition && renderTextArea\"\n [textAreaElement]=\"textAreaElement.nativeElement\"\n (recognizedText)=\"handleRecognizedText($event)\">\n</s-speech-recognition>\n",
|
|
81
117
|
providers: [
|
|
82
118
|
{
|
|
83
119
|
provide: NG_VALUE_ACCESSOR,
|
|
@@ -91,4 +127,4 @@ var TextAreaComponent = /** @class */ (function () {
|
|
|
91
127
|
return TextAreaComponent;
|
|
92
128
|
}());
|
|
93
129
|
export { TextAreaComponent };
|
|
94
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1hcmVhLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL3RleHQtYXJlYS90ZXh0LWFyZWEvdGV4dC1hcmVhLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLGlCQUFpQixFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkcsT0FBTyxFQUF3QixpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBY3pFO0lBbURFLDJCQUE2QixHQUFzQjtRQUF0QixRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQWxEbkQsYUFBUSxHQUE0QixjQUFRLENBQUMsQ0FBQztRQUM5QyxjQUFTLEdBQTRCLGNBQVEsQ0FBQyxDQUFDO1FBQy9DLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDakIsVUFBSyxHQUFHLEVBQUUsQ0FBQztRQWdCRixZQUFPLEdBQUcsY0FBWSxJQUFJLENBQUMsTUFBTSxFQUFJLENBQUM7UUFDdEMsU0FBSSxHQUFHLENBQUMsQ0FBQztRQUNULHNCQUFpQixHQUFHLEtBQUssQ0FBQztRQWEzQixnQkFBVyxHQUFpQztZQUNsRCxNQUFNLEVBQUUsVUFBVTtTQUNuQixDQUFBO1FBVVEsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUUxQixtQkFBYyxHQUFHLEtBQUssQ0FBQztJQUVnQyxDQUFDOzBCQW5EN0MsaUJBQWlCO0lBUTVCLHNCQUFXLDhDQUFlO2FBQTFCO1lBQ0UsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUM7UUFDL0IsQ0FBQzthQUVELFVBQTJCLEtBQXNDO1lBQWpFLGlCQU1DO1lBTEMsSUFBSSxDQUFDLGdCQUFnQixHQUFHLEtBQUssQ0FBQztZQUM5QixVQUFVLENBQUM7Z0JBQ1QsS0FBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUM7Z0JBQzNCLEtBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDM0IsQ0FBQyxDQUFDLENBQUE7UUFDSixDQUFDOzs7T0FSQTtJQWVRLHNCQUFJLDBDQUFXO2FBQWY7WUFDUCxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7UUFDM0IsQ0FBQzthQUNELFVBQWdCLEtBQWE7WUFDM0IsSUFBSSxLQUFLLEVBQUU7Z0JBQ1QsSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUM7YUFDM0I7aUJBQU07Z0JBQ0wsSUFBSSxDQUFDLFlBQVksR0FBRyxFQUFFLENBQUM7YUFDeEI7UUFDSCxDQUFDOzs7T0FQQTtJQVdRLHNCQUFJLHlDQUFVO2FBQWQ7WUFDUCxPQUFPLElBQUksQ0FBQyxXQUFXLENBQUM7UUFDMUIsQ0FBQzthQUNELFVBQWUsS0FBbUM7WUFDaEQsSUFBSSxDQUFDLFdBQVcseUJBQ1gsS0FBSyxHQUNMLElBQUksQ0FBQyxXQUFXLENBQ3BCLENBQUM7UUFDSixDQUFDOzs7T0FOQTtJQWFELHNDQUFVLEdBQVYsVUFBVyxHQUFXO1FBQ3BCLElBQUksQ0FBQyxLQUFLLEdBQUcsR0FBRyxDQUFDO0lBQ25CLENBQUM7SUFFRCw0Q0FBZ0IsR0FBaEIsVUFBaUIsRUFBMkI7UUFDMUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELDZDQUFpQixHQUFqQixVQUFrQixFQUFjO1FBQzlCLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFFRCw0Q0FBZ0IsR0FBaEIsVUFBaUIsVUFBbUI7UUFDbEMsSUFBSSxDQUFDLFFBQVEsR0FBRyxVQUFVLENBQUM7SUFDN0IsQ0FBQztJQUVELG9DQUFRLEdBQVIsVUFBUyxLQUFhO1FBQ3BCLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNqQixPQUFPO1NBQ1I7UUFDRCxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNuQixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM1QixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMxQixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM3QixDQUFDO0lBRUQsZ0RBQW9CLEdBQXBCLFVBQXFCLGNBQXNCO1FBQ3pDLElBQUksQ0FBQyxRQUFRLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDaEMsQ0FBQzs7O2dCQTlCaUMsaUJBQWlCOztJQTNDbkQ7UUFEQyxTQUFTLENBQUMsVUFBVSxFQUFFLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxDQUFDOzREQUczQztJQVVRO1FBQVIsS0FBSyxFQUFFO3NEQUF1QztJQUN0QztRQUFSLEtBQUssRUFBRTttREFBVTtJQUNUO1FBQVIsS0FBSyxFQUFFO2dFQUEyQjtJQUMxQjtRQUFSLEtBQUssRUFBRTt3REFBNEI7SUFFM0I7UUFBUixLQUFLLEVBQUU7d0RBRVA7SUFXUTtRQUFSLEtBQUssRUFBRTt1REFFUDtJQU9RO1FBQVIsS0FBSyxFQUFFO3VEQUFrQjtJQS9DZixpQkFBaUI7UUFaN0IsU0FBUyxDQUFDO1lBQ1QsUUFBUSxFQUFFLFlBQVk7WUFDdEIseTVCQUF5QztZQUV6QyxTQUFTLEVBQUU7Z0JBQ1Q7b0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtvQkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxjQUFNLE9BQUEsbUJBQWlCLEVBQWpCLENBQWlCLENBQUM7b0JBQ2hELEtBQUssRUFBRSxJQUFJO2lCQUNaO2FBQ0Y7O1NBQ0YsQ0FBQztPQUNXLGlCQUFpQixDQWtGN0I7SUFBRCx3QkFBQztDQUFBLEFBbEZELElBa0ZDO1NBbEZZLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIEVsZW1lbnRSZWYsIGZvcndhcmRSZWYsIElucHV0LCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncy10ZXh0YXJlYScsXG4gIHRlbXBsYXRlVXJsOiAnLi90ZXh0LWFyZWEuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi90ZXh0LWFyZWEuY29tcG9uZW50LnNjc3MnXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBUZXh0QXJlYUNvbXBvbmVudCksXG4gICAgICBtdWx0aTogdHJ1ZSxcbiAgICB9LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBUZXh0QXJlYUNvbXBvbmVudCBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcbiAgb25DaGFuZ2U6ICh2YWx1ZTogc3RyaW5nKSA9PiB2b2lkID0gKCkgPT4geyB9O1xuICBvblRvdWNoZWQ6ICh2YWx1ZTogc3RyaW5nKSA9PiB2b2lkID0gKCkgPT4geyB9O1xuICBkaXNhYmxlZCA9IGZhbHNlO1xuICB2YWx1ZSA9ICcnO1xuICBwcml2YXRlIF90ZXh0QXJlYUVsZW1lbnQ6IEVsZW1lbnRSZWY8SFRNTFRleHRBcmVhRWxlbWVudD47XG5cbiAgQFZpZXdDaGlsZCgndGV4dEFyZWEnLCB7IHJlYWQ6IEVsZW1lbnRSZWYgfSlcbiAgcHVibGljIGdldCB0ZXh0QXJlYUVsZW1lbnQoKTogRWxlbWVudFJlZjxIVE1MVGV4dEFyZWFFbGVtZW50PiB7XG4gICAgcmV0dXJuIHRoaXMuX3RleHRBcmVhRWxlbWVudDtcbiAgfVxuXG4gIHB1YmxpYyBzZXQgdGV4dEFyZWFFbGVtZW50KHZhbHVlOiBFbGVtZW50UmVmPEhUTUxUZXh0QXJlYUVsZW1lbnQ+KSB7XG4gICAgdGhpcy5fdGV4dEFyZWFFbGVtZW50ID0gdmFsdWU7XG4gICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICB0aGlzLnJlbmRlclRleHRBcmVhID0gdHJ1ZTtcbiAgICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgICB9KVxuICB9XG5cbiAgQElucHV0KCkgaW5wdXRJZCA9IGB0ZXh0YXJlYS0ke01hdGgucmFuZG9tKCl9YDtcbiAgQElucHV0KCkgcm93cyA9IDU7XG4gIEBJbnB1dCgpIHNwZWVjaFJlY29nbml0aW9uID0gZmFsc2U7XG4gIEBJbnB1dCgpIGtleUZpbHRlcjogc3RyaW5nIHwgUmVnRXhwO1xuICBwcml2YXRlIF9wbGFjZWhvbGRlcjogc3RyaW5nO1xuICBASW5wdXQoKSBnZXQgcGxhY2Vob2xkZXIoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5fcGxhY2Vob2xkZXI7XG4gIH1cbiAgc2V0IHBsYWNlaG9sZGVyKHZhbHVlOiBzdHJpbmcpIHtcbiAgICBpZiAodmFsdWUpIHtcbiAgICAgIHRoaXMuX3BsYWNlaG9sZGVyID0gdmFsdWU7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX3BsYWNlaG9sZGVyID0gJyc7XG4gICAgfVxuICB9XG4gIHByaXZhdGUgX2lucHV0U3R5bGU6IFBhcnRpYWw8Q1NTU3R5bGVEZWNsYXJhdGlvbj4gPSB7XG4gICAgcmVzaXplOiAndmVydGljYWwnXG4gIH1cbiAgQElucHV0KCkgZ2V0IGlucHV0U3R5bGUoKTogUGFydGlhbDxDU1NTdHlsZURlY2xhcmF0aW9uPiB7XG4gICAgcmV0dXJuIHRoaXMuX2lucHV0U3R5bGU7XG4gIH1cbiAgc2V0IGlucHV0U3R5bGUodmFsdWU6IFBhcnRpYWw8Q1NTU3R5bGVEZWNsYXJhdGlvbj4pIHtcbiAgICB0aGlzLl9pbnB1dFN0eWxlID0ge1xuICAgICAgLi4udmFsdWUsXG4gICAgICAuLi50aGlzLl9pbnB1dFN0eWxlLFxuICAgIH07XG4gIH1cbiAgQElucHV0KCkgcmVhZE9ubHkgPSBmYWxzZTtcblxuICByZW5kZXJUZXh0QXJlYSA9IGZhbHNlO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikgeyB9XG5cbiAgd3JpdGVWYWx1ZShvYmo6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMudmFsdWUgPSBvYmo7XG4gIH1cblxuICByZWdpc3Rlck9uQ2hhbmdlKGZuOiAodmFsdWU6IHN0cmluZykgPT4gdm9pZCk6IHZvaWQge1xuICAgIHRoaXMub25DaGFuZ2UgPSBmbjtcbiAgfVxuXG4gIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiAoKSA9PiB2b2lkKTogdm9pZCB7XG4gICAgdGhpcy5vblRvdWNoZWQgPSBmbjtcbiAgfVxuXG4gIHNldERpc2FibGVkU3RhdGUoaXNEaXNhYmxlZDogYm9vbGVhbik6IHZvaWQge1xuICAgIHRoaXMuZGlzYWJsZWQgPSBpc0Rpc2FibGVkO1xuICB9XG5cbiAgc2V0VmFsdWUodmFsdWU6IHN0cmluZykge1xuICAgIGlmICh0aGlzLmRpc2FibGVkKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHRoaXMudmFsdWUgPSB2YWx1ZTtcbiAgICB0aGlzLndyaXRlVmFsdWUodGhpcy52YWx1ZSk7XG4gICAgdGhpcy5vbkNoYW5nZSh0aGlzLnZhbHVlKTtcbiAgICB0aGlzLm9uVG91Y2hlZCh0aGlzLnZhbHVlKTtcbiAgfVxuXG4gIGhhbmRsZVJlY29nbml6ZWRUZXh0KHJlY29nbml6ZWRUZXh0OiBzdHJpbmcpIHtcbiAgICB0aGlzLnNldFZhbHVlKHJlY29nbml6ZWRUZXh0KTtcbiAgfVxufVxuIl19
|