@bnsights/bbsf-controls 1.0.145 → 1.0.147

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/README.md CHANGED
@@ -5,6 +5,14 @@ BBSF Controls package is part of BBSF 3 packages. It has all the form controls t
5
5
  For more info please visit [BBSF Controls documenation](https://bbsfadmin.bnsights.com/controls) or [BBSF documentation](https://bnsightsprojects.visualstudio.com/BBSF%203/_wiki/wikis/BBSF-3.wiki/65/BBSF-Documentation)
6
6
 
7
7
  # Change Log
8
+ ## 1.0.147 / 4-8-2024
9
+ ===================
10
+ * fixed bug in speech to text of TextAreaComponent
11
+
12
+ ## 1.0.146 / 4-8-2024
13
+ ===================
14
+ * added feature spech to text into TextAreaComponent
15
+
8
16
  ## 1.0.145 / 24-7-2024
9
17
  ===================
10
18
  * fix naming in file upload control
@@ -1,4 +1,16 @@
1
1
  import { ControlOptionsBase } from './ControlOptionsBase';
2
2
  export class TextAreaOptions extends ControlOptionsBase {
3
+ constructor() {
4
+ super(...arguments);
5
+ /**To set value to Control */
6
+ this.value = '';
7
+ //** Set flag to enable or disable speech (mic) in textarea*/
8
+ this.enableSpeechRecognition = false;
9
+ //** Set array of available languages for speech to text*/
10
+ this.speechLanguages = undefined;
11
+ this.selectedSpeechLanguage = '';
12
+ //Enable auto save speech language into local storage
13
+ this.autoSaveSpeechLanguagetoLocalStorage = true;
14
+ }
3
15
  }
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGV4dEFyZWFPcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmJzZi1jb250cm9scy9zcmMvbGliL1NoYXJlZC9Nb2RlbHMvVGV4dEFyZWFPcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRzFELE1BQU0sT0FBTyxlQUFnQixTQUFRLGtCQUFrQjtDQXVCdEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGb3JjZURpcmVjdGlvbiB9IGZyb20gJy4uL0VudW1zL0ZvcmNlRGlyZWN0aW9uJztcclxuaW1wb3J0IHsgQ29udHJvbE9wdGlvbnNCYXNlIH0gZnJvbSAnLi9Db250cm9sT3B0aW9uc0Jhc2UnO1xyXG5cclxuXHJcbmV4cG9ydCBjbGFzcyBUZXh0QXJlYU9wdGlvbnMgZXh0ZW5kcyBDb250cm9sT3B0aW9uc0Jhc2Uge1xyXG4gIC8qKlRvIHNldCAgdmFsdWUgIHRvIENvbnRyb2wgKi9cclxuICB2YWx1ZTogYW55XHJcbiAgLy8qKiBTZXQgdGhlIE1heExlbmd0aCBvZiBjaGFyYWN0ZXJzIEluIFRleHRBcmVhICovXHJcbiAgbWF4TGVuZ3RoPzogbnVtYmVyXHJcbiAgLyoqU2V0IHRoZSBNaW5MZW5ndGggb2YgY2hhcmFjdGVycyBJbiBUZXh0QXJlYSAgKi9cclxuICBtaW5MZW5ndGg/OiBudW1iZXJcclxuICAvKipTZXQgTnVtYmVyIE9mIFJvd3MgICovXHJcbiAgcm93czogbnVtYmVyXHJcbiAgLyoqU2V0IE51bWJlciBPZiBjb2x1bW5zICAqL1xyXG4gIGNvbHM6IG51bWJlclxyXG4gIC8vKiogU2V0IHRoZSBNYXhXb3JkQ291bnQgb2YgY2hhcmFjdGVycyBJbiBUZXh0QXJlYSAqL1xyXG4gIG1heFdvcmRDb3VudDogbnVtYmVyO1xyXG4gIC8qKlByZXZlbnQgQXV0b0NvbXBsZXRlIG9mIFRleHRBcmVhKi9cclxuICBhdXRvQ29tcGxldGU6IGJvb2xlYW5cclxuICAvKiogIHRleHQgaW5wdXQgb24gY2hhbmdlICAqL1xyXG4gIHRyaW1UZXh0T25DaGFuZ2U6IGJvb2xlYW5cclxuICAvKiogYWRkIGJ1dHRvbiB0byBmb3IgY29waW5nIHRvIGNsaXBib2FyZCAqL1xyXG4gIGVuYWJsZUNvcHlUb0NsaXBib2FyZDogYm9vbGVhblxyXG4gIC8qKiB0byBzZXQgRGlyZWN0aW9uIG9mIFRleHRBcmVhICBpZiBUZXh0QXJlYSBpcyBBcmFiaWMgb3IgRW5nbGlzaCAgKi9cclxuICBmb3JjZURpcmVjdGlvbjogRm9yY2VEaXJlY3Rpb25cclxuICAvLyoqIFNldCB0aGUgTWF4TGVuZ3RoIExpbWl0IHRvIHNob3cgd2FybmluZyBtZXNzYWdlKi9cclxuICBtYXhMZW5ndGhXYXJuaW5nTGltaXQ6IG51bWJlcjtcclxufVxyXG4iXX0=
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiVGV4dEFyZWFPcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmJzZi1jb250cm9scy9zcmMvbGliL1NoYXJlZC9Nb2RlbHMvVGV4dEFyZWFPcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRzFELE1BQU0sT0FDTixlQUFnQixTQUFRLGtCQUFrQjtJQUQxQzs7UUFFRSwrQkFBK0I7UUFDL0IsVUFBSyxHQUFNLEVBQUUsQ0FBQTtRQXFCYiw2REFBNkQ7UUFDN0QsNEJBQXVCLEdBQVMsS0FBSyxDQUFDO1FBQ3RDLDBEQUEwRDtRQUMxRCxvQkFBZSxHQUFrQixTQUFTLENBQUM7UUFDM0MsMkJBQXNCLEdBQVMsRUFBRSxDQUFDO1FBT2xDLHFEQUFxRDtRQUNyRCx5Q0FBb0MsR0FBWSxJQUFJLENBQUM7SUFFdkQsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTGFuZ3VhZ2VEVE8gfSBmcm9tICdAYm5zaWdodHMvYmJzZi11dGlsaXRpZXMvbGliL3NoYXJlZC9tb2RlbHMnO1xyXG5pbXBvcnQgeyBGb3JjZURpcmVjdGlvbiB9IGZyb20gJy4uL0VudW1zL0ZvcmNlRGlyZWN0aW9uJztcclxuaW1wb3J0IHsgQ29udHJvbE9wdGlvbnNCYXNlIH0gZnJvbSAnLi9Db250cm9sT3B0aW9uc0Jhc2UnO1xyXG5cclxuXHJcbmV4cG9ydCBjbGFzcyBcclxuVGV4dEFyZWFPcHRpb25zIGV4dGVuZHMgQ29udHJvbE9wdGlvbnNCYXNlIHtcclxuICAvKipUbyBzZXQgIHZhbHVlICB0byBDb250cm9sICovXHJcbiAgdmFsdWU6IGFueT0nJ1xyXG4gIC8vKiogU2V0IHRoZSBNYXhMZW5ndGggb2YgY2hhcmFjdGVycyBJbiBUZXh0QXJlYSAqL1xyXG4gIG1heExlbmd0aD86IG51bWJlclxyXG4gIC8qKlNldCB0aGUgTWluTGVuZ3RoIG9mIGNoYXJhY3RlcnMgSW4gVGV4dEFyZWEgICovXHJcbiAgbWluTGVuZ3RoPzogbnVtYmVyXHJcbiAgLyoqU2V0IE51bWJlciBPZiBSb3dzICAqL1xyXG4gIHJvd3M6IG51bWJlclxyXG4gIC8qKlNldCBOdW1iZXIgT2YgY29sdW1ucyAgKi9cclxuICBjb2xzOiBudW1iZXJcclxuICAvLyoqIFNldCB0aGUgTWF4V29yZENvdW50IG9mIGNoYXJhY3RlcnMgSW4gVGV4dEFyZWEgKi9cclxuICBtYXhXb3JkQ291bnQ6IG51bWJlcjtcclxuICAvKipQcmV2ZW50IEF1dG9Db21wbGV0ZSBvZiBUZXh0QXJlYSovXHJcbiAgYXV0b0NvbXBsZXRlOiBib29sZWFuXHJcbiAgLyoqICB0ZXh0IGlucHV0IG9uIGNoYW5nZSAgKi9cclxuICB0cmltVGV4dE9uQ2hhbmdlOiBib29sZWFuXHJcbiAgLyoqIGFkZCBidXR0b24gdG8gZm9yIGNvcGluZyB0byBjbGlwYm9hcmQgKi9cclxuICBlbmFibGVDb3B5VG9DbGlwYm9hcmQ6IGJvb2xlYW4gIFxyXG4gIC8qKiB0byBzZXQgRGlyZWN0aW9uIG9mIFRleHRBcmVhICBpZiBUZXh0QXJlYSBpcyBBcmFiaWMgb3IgRW5nbGlzaCAgKi9cclxuICBmb3JjZURpcmVjdGlvbjogRm9yY2VEaXJlY3Rpb25cclxuICAvLyoqIFNldCB0aGUgTWF4TGVuZ3RoIExpbWl0IHRvIHNob3cgd2FybmluZyBtZXNzYWdlKi9cclxuICBtYXhMZW5ndGhXYXJuaW5nTGltaXQ6IG51bWJlcjtcclxuICAvLyoqIFNldCBmbGFnIHRvIGVuYWJsZSBvciBkaXNhYmxlIHNwZWVjaCAobWljKSBpbiB0ZXh0YXJlYSovXHJcbiAgZW5hYmxlU3BlZWNoUmVjb2duaXRpb246Ym9vbGVhbj1mYWxzZTtcclxuICAvLyoqIFNldCBhcnJheSBvZiBhdmFpbGFibGUgbGFuZ3VhZ2VzIGZvciBzcGVlY2ggdG8gdGV4dCovXHJcbiAgc3BlZWNoTGFuZ3VhZ2VzOiBMYW5ndWFnZURUT1tdID0gdW5kZWZpbmVkO1xyXG4gIHNlbGVjdGVkU3BlZWNoTGFuZ3VhZ2U6IHN0cmluZz0nJztcclxuICAvLyptaWMgaWNvbiAqL1xyXG4gIGljb25NaWM6IHN0cmluZztcclxuICAvLyptaWMgaWNvbiBvZmYqL1xyXG4gIGljb25NaWNPZmY6IHN0cmluZztcclxuICAvLyphZGQgZXh0cmEgY2xhc3MgZm9yIG1pYyBsYW5ndWFnZSBjb250YWluZXIqL1xyXG4gIGV4dHJhQ2xhc3NNaWNMYW5ndWFnZTogc3RyaW5nO1xyXG4gIC8vRW5hYmxlIGF1dG8gc2F2ZSBzcGVlY2ggbGFuZ3VhZ2UgaW50byBsb2NhbCBzdG9yYWdlXHJcbiAgYXV0b1NhdmVTcGVlY2hMYW5ndWFnZXRvTG9jYWxTdG9yYWdlOiBib29sZWFuID0gdHJ1ZTtcclxuICBcclxufVxyXG4iXX0=
@@ -8,15 +8,18 @@ import * as i4 from "../../Shared/services/GlobalSettings.service";
8
8
  import * as i5 from "@angular/common";
9
9
  import * as i6 from "@angular/cdk/bidi";
10
10
  import * as i7 from "ngx-intl-tel-input";
11
+ import * as i8 from "ng-inline-svg-2";
11
12
  export class TextAreaComponent {
12
13
  static { this.controlContainerstatic = null; }
13
- constructor(controlUtility, controlContainer, textAreaControlHost, utilityService, controlValidationService, globalSettings) {
14
+ constructor(controlUtility, controlContainer, textAreaControlHost, utilityService, controlValidationService, globalSettings, speechRecognitionService, languageService) {
14
15
  this.controlUtility = controlUtility;
15
16
  this.controlContainer = controlContainer;
16
17
  this.textAreaControlHost = textAreaControlHost;
17
18
  this.utilityService = utilityService;
18
19
  this.controlValidationService = controlValidationService;
19
20
  this.globalSettings = globalSettings;
21
+ this.speechRecognitionService = speechRecognitionService;
22
+ this.languageService = languageService;
20
23
  this.onChange = new EventEmitter();
21
24
  this.wordCount = 0;
22
25
  this.wordCountArray = 0;
@@ -30,6 +33,7 @@ export class TextAreaComponent {
30
33
  this.hasCharsLimitValidationError = false;
31
34
  this.minCharsLimit = -1; //To disable chars limit feature by default
32
35
  this.maxLimitWarningMsg = "";
36
+ this.isMicOn = false;
33
37
  this.resetError = () => {
34
38
  this.controlValidationService.removeGlobalError();
35
39
  };
@@ -54,6 +58,7 @@ export class TextAreaComponent {
54
58
  this.controlUtility.isValid(this.textAreaFormControl);
55
59
  };
56
60
  TextAreaComponent.controlContainerstatic = this.controlContainer;
61
+ this.currentLanguage = localStorage.getItem('language');
57
62
  }
58
63
  ngOnInit() {
59
64
  if (this.options.isReadonly && !this.options.value)
@@ -65,12 +70,27 @@ export class TextAreaComponent {
65
70
  this.controlValidationService.isCreatedBefor = false;
66
71
  this.group.addControl(this.options.name, new FormControl(''));
67
72
  this.textAreaFormControl = this.group.controls[this.options.name]; // new FormControl('',validationRules);
73
+ // Initialize language form control
74
+ const languageControlName = this.options.name + 'Language';
75
+ this.group.addControl(languageControlName, new FormControl(this.options.selectedSpeechLanguage || ''));
68
76
  if (!this.options.maxLength)
69
77
  this.options.maxLength = this.globalSettings.maxLengthTextArea;
70
78
  if (!this.options.viewType)
71
79
  this.options.viewType = this.globalSettings.viewType;
72
80
  if (this.options.labelKey != null && this.options.labelKey != "")
73
81
  this.options.labelValue = this.utilityService.getResourceValue(this.options.labelKey);
82
+ if (this.options.enableSpeechRecognition) {
83
+ //Get all languages if not set
84
+ if (!this.options.speechLanguages) {
85
+ this.languageService.getLanguages().subscribe(result => {
86
+ this.options.speechLanguages = result;
87
+ this.setSpeechLanguage();
88
+ });
89
+ }
90
+ else {
91
+ this.setSpeechLanguage();
92
+ }
93
+ }
74
94
  this.textAreaFormControl.setValue(this.options.value);
75
95
  if (this.options.customValidation.length > 0) {
76
96
  let Validations = this.options.customValidation;
@@ -180,19 +200,103 @@ export class TextAreaComponent {
180
200
  else //onFocusOut
181
201
  this.showCharsLimitMsg = false;
182
202
  }
183
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: TextAreaComponent, deps: [{ token: i1.ControlUtility }, { token: i2.ControlContainer, optional: true }, { token: i2.FormGroupDirective }, { token: i3.UtilityService }, { token: i3.ControlValidationService }, { token: i4.GlobalSettings }], target: i0.ɵɵFactoryTarget.Component }); }
184
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.6", type: TextAreaComponent, selector: "BBSF-TextArea", inputs: { group: "group", options: "options" }, outputs: { onChange: "onChange" }, ngImport: i0, template: "<div class=\"form-group bbsf-control bbsf-textarea\" [formGroup]=\"group\">\r\n <div [ngClass]=\"(options.viewType==1)?'bbsf-vertical':'bbsf-horizontal'\">\r\n <!--label-->\r\n <label *ngIf=\"!options.hideLabel\" class=\"bbsf-label {{options.labelExtraClasses}}\">\r\n {{options.labelValue}}\r\n <!--Asterisk-->\r\n <span *ngIf=\"((options.showAsterisk&&options.isRequired)||(options.isRequired))&&!options.isReadonly\"\r\n class=\"text-danger\">*</span>\r\n </label>\r\n <div *ngIf=\"!options.isReadonly\" class=\"bbsf-input-container\"\r\n [ngClass]=\"options.enableCopyToClipboard? 'p-40px' : '' \">\r\n <!--input-->\r\n <textarea class=\"form-control {{options.extraClasses}}\" (focus)=\"onFocus(true)\" (focusout)=\"onFocus(false)\"\r\n [dir]=\"textDir\" aria-describedby=\"email-error\" aria-invalid=\"true\" formControlName=\"{{options.name}}\"\r\n [class.is-invalid]=\"textAreaFormControl.invalid && textAreaFormControl.touched\"\r\n placeholder=\"{{options.placeholder}}\" id=\"{{options.name}}\" autocomplete=\"{{options.autoComplete}}\"\r\n (change)=\"trimControlValue()\" rows=\"{{options.rows}}\" (keyup)=\"onTextChange()\" cols=\"{{options.cols}}\"\r\n maxlength=\"{{options.maxLength}}\" minlength=\"{{options.minLength}}\" [(ngModel)]=\"options.value\"\r\n (keydown)=\"wordCountArray>options.maxWordCount&&$event.keyCode !=8?$event.preventDefault():null\"\r\n #TextAreainput></textarea>\r\n <!--CopyToClipboard-->\r\n <div class=\"copy-clipboard\" *ngIf=\"options.enableCopyToClipboard\" (click)=\"copyInputMessage(TextAreainput)\">\r\n <i class=\"fas fa-copy\"></i>\r\n </div>\r\n </div>\r\n <!-- readonly -->\r\n <div *ngIf=\"options.isReadonly\"><span class=\"readonly-view\">{{options.value}}</span>\r\n </div>\r\n <div class=\"subtext-container\">\r\n <!--wordCount-->\r\n <div class=\"bbsf-word-count\" *ngIf=\"options.maxWordCount>0&&isShowWordCount\">\r\n {{wordCount}}/{{options.maxWordCount}} Words</div>\r\n <!-- CharsLimitMsg-->\r\n <div class=\"bbsf-character-count\" *ngIf=\"showCharsLimitMsg\"\r\n [ngClass]=\"{'badge-light-warning': charsLimitMsgClass === 'warning', 'badge-light-danger' : charsLimitMsgClass === 'danger' }\">\r\n {{maxLimitWarningMsg}}\r\n </div>\r\n <!-- LabelDescription-->\r\n <div class=\"bbsf-control-desc\" *ngIf=\"options.labelDescription!=null\">{{options.labelDescription}}</div>\r\n <!-- requiredText-->\r\n <div class=\"bbsf-validation\" [dir]=\"textDir\" *ngIf=\"(textAreaFormControl.invalid && textAreaFormControl.touched)\">\r\n {{getErrorValidation(textAreaFormControl.errors|keyvalue)}}\r\n </div>\r\n </div>\r\n <div *ngIf=\"(group.valid&&group.dirty&&group.touched )||(group.untouched&&group.invalid&&group.dirty) \">\r\n {{resetError()}}</div>\r\n </div>", dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { kind: "directive", type: i7.NativeElementInjectorDirective, selector: "[ngModel], [formControl], [formControlName]" }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { kind: "directive", type: i2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "pipe", type: i5.KeyValuePipe, name: "keyvalue" }] }); }
203
+ //region Speech Recognition
204
+ setSpeechLanguage() {
205
+ const languageControlName = this.options.name + 'Language';
206
+ if (this.options.autoSaveSpeechLanguagetoLocalStorage) {
207
+ let savedLanguage = localStorage.getItem("speechLanguage");
208
+ if (savedLanguage) {
209
+ this.options.selectedSpeechLanguage = savedLanguage;
210
+ }
211
+ else {
212
+ this.loadSelectedSpeechLanguage();
213
+ localStorage.setItem("speechLanguage", this.options.selectedSpeechLanguage);
214
+ }
215
+ }
216
+ else {
217
+ this.loadSelectedSpeechLanguage();
218
+ }
219
+ this.group.get(languageControlName).setValue(this.options.selectedSpeechLanguage);
220
+ }
221
+ loadSelectedSpeechLanguage() {
222
+ if (!this.options.selectedSpeechLanguage) {
223
+ if (this.currentLanguage == "en" && this.options.speechLanguages.some(language => language.englishName === 'English')) {
224
+ this.options.selectedSpeechLanguage = this.options.speechLanguages.find(language => language.englishName === 'English').dialect;
225
+ }
226
+ else if (this.currentLanguage == "ar" && this.options.speechLanguages.some(language => language.englishName === 'Arabic')) {
227
+ this.options.selectedSpeechLanguage = this.options.speechLanguages.find(language => language.englishName === 'Arabic').dialect;
228
+ }
229
+ else {
230
+ this.options.selectedSpeechLanguage = this.options.speechLanguages[0].dialect;
231
+ }
232
+ }
233
+ }
234
+ startSpeechRecognition() {
235
+ if (!this.speechRecognitionService.isSupported) {
236
+ this.utilityService.notifyErrorMessage(this.utilityService.getResourceValue("BrowserNotSupportSpeechRecognition"));
237
+ return;
238
+ }
239
+ this.isMicOn = true;
240
+ this.subscription = this.speechRecognitionService.startListening(this.options.selectedSpeechLanguage).subscribe({
241
+ next: (transcript) => {
242
+ if (transcript) {
243
+ if (this.options.value) {
244
+ this.options.value += ' ';
245
+ }
246
+ let charIndex = 0;
247
+ const interval = setInterval(() => {
248
+ this.options.value += transcript[charIndex];
249
+ charIndex++;
250
+ if (charIndex === transcript.length) {
251
+ clearInterval(interval);
252
+ }
253
+ }, 10);
254
+ }
255
+ },
256
+ error: (error) => {
257
+ console.error(error);
258
+ this.stopSpeechRecognition();
259
+ },
260
+ complete: () => {
261
+ this.isMicOn = false;
262
+ }
263
+ });
264
+ }
265
+ stopSpeechRecognition() {
266
+ if (!this.speechRecognitionService.isSupported) {
267
+ return;
268
+ }
269
+ this.isMicOn = false;
270
+ this.speechRecognitionService.stopListening();
271
+ if (this.subscription) {
272
+ this.subscription.unsubscribe();
273
+ }
274
+ }
275
+ ngOnDestroy() {
276
+ this.stopSpeechRecognition();
277
+ }
278
+ onSpeechLanguageChange(event) {
279
+ let selectedLang = event.target.value;
280
+ this.options.selectedSpeechLanguage = selectedLang;
281
+ const languageControlName = this.options.name + 'Language';
282
+ this.group.get(languageControlName).setValue(selectedLang);
283
+ if (this.options.autoSaveSpeechLanguagetoLocalStorage) {
284
+ localStorage.setItem("speechLanguage", selectedLang);
285
+ }
286
+ }
287
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: TextAreaComponent, deps: [{ token: i1.ControlUtility }, { token: i2.ControlContainer, optional: true }, { token: i2.FormGroupDirective }, { token: i3.UtilityService }, { token: i3.ControlValidationService }, { token: i4.GlobalSettings }, { token: i3.SpeechRecognitionService }, { token: i3.LanguageService }], target: i0.ɵɵFactoryTarget.Component }); }
288
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.6", type: TextAreaComponent, selector: "BBSF-TextArea", inputs: { group: "group", options: "options" }, outputs: { onChange: "onChange" }, ngImport: i0, template: "<div class=\"form-group bbsf-control bbsf-textarea\" [formGroup]=\"group\">\r\n <div [ngClass]=\"(options.viewType==1)?'bbsf-vertical':'bbsf-horizontal'\">\r\n <!--label-->\r\n <label *ngIf=\"!options.hideLabel\" class=\"bbsf-label {{options.labelExtraClasses}}\">\r\n {{options.labelValue}}\r\n <!--Asterisk-->\r\n <span *ngIf=\"((options.showAsterisk&&options.isRequired)||(options.isRequired))&&!options.isReadonly\"\r\n class=\"text-danger\">*</span>\r\n </label>\r\n <div *ngIf=\"!options.isReadonly\" class=\"bbsf-input-container\" [ngClass]=\"{\r\n 'p-120px': options.enableSpeechRecognition && options.enableCopyToClipboard,\r\n 'p-80px': options.enableSpeechRecognition && !options.enableCopyToClipboard,\r\n 'p-40px': !options.enableSpeechRecognition && options.enableCopyToClipboard\r\n }\">\r\n <!--input-->\r\n <textarea class=\"form-control {{options.extraClasses}}\" (focus)=\"onFocus(true)\" (focusout)=\"onFocus(false)\"\r\n [dir]=\"textDir\" aria-describedby=\"email-error\" aria-invalid=\"true\" formControlName=\"{{options.name}}\"\r\n [class.is-invalid]=\"textAreaFormControl.invalid && textAreaFormControl.touched\"\r\n placeholder=\"{{options.placeholder}}\" id=\"{{options.name}}\" autocomplete=\"{{options.autoComplete}}\"\r\n (change)=\"trimControlValue()\" rows=\"{{options.rows}}\" (keyup)=\"onTextChange()\" cols=\"{{options.cols}}\"\r\n maxlength=\"{{options.maxLength}}\" minlength=\"{{options.minLength}}\" [(ngModel)]=\"options.value\"\r\n (keydown)=\"wordCountArray>options.maxWordCount&&$event.keyCode !=8?$event.preventDefault():null\"\r\n #TextAreainput></textarea>\r\n <!--CopyToClipboard-->\r\n <div class=\"copy-clipboard\" *ngIf=\"options.enableCopyToClipboard\" (click)=\"copyInputMessage(TextAreainput)\">\r\n <i class=\"fas fa-copy\"></i>\r\n </div>\r\n <div [ngClass]=\"{'expanded': isFocused}\" class=\"language-container {{options.extraClassMicLanguage}}\" *ngIf=\"options.enableSpeechRecognition\">\r\n <span class=\"svg-icon svg-icon-5\" [inlineSVG]=\"options.iconMic? options.iconMic : './src/assets/images/mic.svg'\" (click)=\"startSpeechRecognition()\"\r\n *ngIf=\"!isMicOn\">\r\n </span>\r\n <span class=\"svg-icon svg-icon-5\" [inlineSVG]=\"options.iconMicOff? options.iconMicOff : './src/assets/images/mic-off.svg'\" (click)=\"stopSpeechRecognition()\"\r\n *ngIf=\"isMicOn\">\r\n </span>\r\n <select class=\"language-select\" [formControlName]=\"options.name + 'Language'\" (change)=\"onSpeechLanguageChange($event)\">\r\n <option *ngFor=\"let language of options.speechLanguages\" [value]=\"language.dialect\">{{language.displayName}}</option>\r\n </select>\r\n </div>\r\n </div>\r\n <!-- readonly -->\r\n <div *ngIf=\"options.isReadonly\"><span class=\"readonly-view\">{{options.value}}</span>\r\n </div>\r\n <div class=\"subtext-container\">\r\n <!--wordCount-->\r\n <div class=\"bbsf-word-count\" *ngIf=\"options.maxWordCount>0&&isShowWordCount\">\r\n {{wordCount}}/{{options.maxWordCount}} Words</div>\r\n <!-- CharsLimitMsg-->\r\n <div class=\"bbsf-character-count\" *ngIf=\"showCharsLimitMsg\"\r\n [ngClass]=\"{'badge-light-warning': charsLimitMsgClass === 'warning', 'badge-light-danger' : charsLimitMsgClass === 'danger' }\">\r\n {{maxLimitWarningMsg}}\r\n </div>\r\n <!-- LabelDescription-->\r\n <div class=\"bbsf-control-desc\" *ngIf=\"options.labelDescription!=null\">{{options.labelDescription}}</div>\r\n <!-- requiredText-->\r\n <div class=\"bbsf-validation\" [dir]=\"textDir\" *ngIf=\"(textAreaFormControl.invalid && textAreaFormControl.touched)\">\r\n {{getErrorValidation(textAreaFormControl.errors|keyvalue)}}\r\n </div>\r\n </div>\r\n <div *ngIf=\"(group.valid&&group.dirty&&group.touched )||(group.untouched&&group.invalid&&group.dirty) \">\r\n {{resetError()}}</div>\r\n </div>\r\n", dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { kind: "directive", type: i7.NativeElementInjectorDirective, selector: "[ngModel], [formControl], [formControlName]" }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.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: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { kind: "directive", type: i2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i8.InlineSVGDirective, selector: "[inlineSVG]", inputs: ["inlineSVG", "resolveSVGUrl", "replaceContents", "prepend", "injectComponent", "cacheSVG", "setSVGAttributes", "removeSVGAttributes", "forceEvalStyles", "evalScripts", "fallbackImgUrl", "fallbackSVG", "onSVGLoaded"], outputs: ["onSVGInserted", "onSVGFailed"] }, { kind: "pipe", type: i5.KeyValuePipe, name: "keyvalue" }] }); }
185
289
  }
186
290
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: TextAreaComponent, decorators: [{
187
291
  type: Component,
188
- args: [{ selector: 'BBSF-TextArea', template: "<div class=\"form-group bbsf-control bbsf-textarea\" [formGroup]=\"group\">\r\n <div [ngClass]=\"(options.viewType==1)?'bbsf-vertical':'bbsf-horizontal'\">\r\n <!--label-->\r\n <label *ngIf=\"!options.hideLabel\" class=\"bbsf-label {{options.labelExtraClasses}}\">\r\n {{options.labelValue}}\r\n <!--Asterisk-->\r\n <span *ngIf=\"((options.showAsterisk&&options.isRequired)||(options.isRequired))&&!options.isReadonly\"\r\n class=\"text-danger\">*</span>\r\n </label>\r\n <div *ngIf=\"!options.isReadonly\" class=\"bbsf-input-container\"\r\n [ngClass]=\"options.enableCopyToClipboard? 'p-40px' : '' \">\r\n <!--input-->\r\n <textarea class=\"form-control {{options.extraClasses}}\" (focus)=\"onFocus(true)\" (focusout)=\"onFocus(false)\"\r\n [dir]=\"textDir\" aria-describedby=\"email-error\" aria-invalid=\"true\" formControlName=\"{{options.name}}\"\r\n [class.is-invalid]=\"textAreaFormControl.invalid && textAreaFormControl.touched\"\r\n placeholder=\"{{options.placeholder}}\" id=\"{{options.name}}\" autocomplete=\"{{options.autoComplete}}\"\r\n (change)=\"trimControlValue()\" rows=\"{{options.rows}}\" (keyup)=\"onTextChange()\" cols=\"{{options.cols}}\"\r\n maxlength=\"{{options.maxLength}}\" minlength=\"{{options.minLength}}\" [(ngModel)]=\"options.value\"\r\n (keydown)=\"wordCountArray>options.maxWordCount&&$event.keyCode !=8?$event.preventDefault():null\"\r\n #TextAreainput></textarea>\r\n <!--CopyToClipboard-->\r\n <div class=\"copy-clipboard\" *ngIf=\"options.enableCopyToClipboard\" (click)=\"copyInputMessage(TextAreainput)\">\r\n <i class=\"fas fa-copy\"></i>\r\n </div>\r\n </div>\r\n <!-- readonly -->\r\n <div *ngIf=\"options.isReadonly\"><span class=\"readonly-view\">{{options.value}}</span>\r\n </div>\r\n <div class=\"subtext-container\">\r\n <!--wordCount-->\r\n <div class=\"bbsf-word-count\" *ngIf=\"options.maxWordCount>0&&isShowWordCount\">\r\n {{wordCount}}/{{options.maxWordCount}} Words</div>\r\n <!-- CharsLimitMsg-->\r\n <div class=\"bbsf-character-count\" *ngIf=\"showCharsLimitMsg\"\r\n [ngClass]=\"{'badge-light-warning': charsLimitMsgClass === 'warning', 'badge-light-danger' : charsLimitMsgClass === 'danger' }\">\r\n {{maxLimitWarningMsg}}\r\n </div>\r\n <!-- LabelDescription-->\r\n <div class=\"bbsf-control-desc\" *ngIf=\"options.labelDescription!=null\">{{options.labelDescription}}</div>\r\n <!-- requiredText-->\r\n <div class=\"bbsf-validation\" [dir]=\"textDir\" *ngIf=\"(textAreaFormControl.invalid && textAreaFormControl.touched)\">\r\n {{getErrorValidation(textAreaFormControl.errors|keyvalue)}}\r\n </div>\r\n </div>\r\n <div *ngIf=\"(group.valid&&group.dirty&&group.touched )||(group.untouched&&group.invalid&&group.dirty) \">\r\n {{resetError()}}</div>\r\n </div>" }]
292
+ args: [{ selector: 'BBSF-TextArea', template: "<div class=\"form-group bbsf-control bbsf-textarea\" [formGroup]=\"group\">\r\n <div [ngClass]=\"(options.viewType==1)?'bbsf-vertical':'bbsf-horizontal'\">\r\n <!--label-->\r\n <label *ngIf=\"!options.hideLabel\" class=\"bbsf-label {{options.labelExtraClasses}}\">\r\n {{options.labelValue}}\r\n <!--Asterisk-->\r\n <span *ngIf=\"((options.showAsterisk&&options.isRequired)||(options.isRequired))&&!options.isReadonly\"\r\n class=\"text-danger\">*</span>\r\n </label>\r\n <div *ngIf=\"!options.isReadonly\" class=\"bbsf-input-container\" [ngClass]=\"{\r\n 'p-120px': options.enableSpeechRecognition && options.enableCopyToClipboard,\r\n 'p-80px': options.enableSpeechRecognition && !options.enableCopyToClipboard,\r\n 'p-40px': !options.enableSpeechRecognition && options.enableCopyToClipboard\r\n }\">\r\n <!--input-->\r\n <textarea class=\"form-control {{options.extraClasses}}\" (focus)=\"onFocus(true)\" (focusout)=\"onFocus(false)\"\r\n [dir]=\"textDir\" aria-describedby=\"email-error\" aria-invalid=\"true\" formControlName=\"{{options.name}}\"\r\n [class.is-invalid]=\"textAreaFormControl.invalid && textAreaFormControl.touched\"\r\n placeholder=\"{{options.placeholder}}\" id=\"{{options.name}}\" autocomplete=\"{{options.autoComplete}}\"\r\n (change)=\"trimControlValue()\" rows=\"{{options.rows}}\" (keyup)=\"onTextChange()\" cols=\"{{options.cols}}\"\r\n maxlength=\"{{options.maxLength}}\" minlength=\"{{options.minLength}}\" [(ngModel)]=\"options.value\"\r\n (keydown)=\"wordCountArray>options.maxWordCount&&$event.keyCode !=8?$event.preventDefault():null\"\r\n #TextAreainput></textarea>\r\n <!--CopyToClipboard-->\r\n <div class=\"copy-clipboard\" *ngIf=\"options.enableCopyToClipboard\" (click)=\"copyInputMessage(TextAreainput)\">\r\n <i class=\"fas fa-copy\"></i>\r\n </div>\r\n <div [ngClass]=\"{'expanded': isFocused}\" class=\"language-container {{options.extraClassMicLanguage}}\" *ngIf=\"options.enableSpeechRecognition\">\r\n <span class=\"svg-icon svg-icon-5\" [inlineSVG]=\"options.iconMic? options.iconMic : './src/assets/images/mic.svg'\" (click)=\"startSpeechRecognition()\"\r\n *ngIf=\"!isMicOn\">\r\n </span>\r\n <span class=\"svg-icon svg-icon-5\" [inlineSVG]=\"options.iconMicOff? options.iconMicOff : './src/assets/images/mic-off.svg'\" (click)=\"stopSpeechRecognition()\"\r\n *ngIf=\"isMicOn\">\r\n </span>\r\n <select class=\"language-select\" [formControlName]=\"options.name + 'Language'\" (change)=\"onSpeechLanguageChange($event)\">\r\n <option *ngFor=\"let language of options.speechLanguages\" [value]=\"language.dialect\">{{language.displayName}}</option>\r\n </select>\r\n </div>\r\n </div>\r\n <!-- readonly -->\r\n <div *ngIf=\"options.isReadonly\"><span class=\"readonly-view\">{{options.value}}</span>\r\n </div>\r\n <div class=\"subtext-container\">\r\n <!--wordCount-->\r\n <div class=\"bbsf-word-count\" *ngIf=\"options.maxWordCount>0&&isShowWordCount\">\r\n {{wordCount}}/{{options.maxWordCount}} Words</div>\r\n <!-- CharsLimitMsg-->\r\n <div class=\"bbsf-character-count\" *ngIf=\"showCharsLimitMsg\"\r\n [ngClass]=\"{'badge-light-warning': charsLimitMsgClass === 'warning', 'badge-light-danger' : charsLimitMsgClass === 'danger' }\">\r\n {{maxLimitWarningMsg}}\r\n </div>\r\n <!-- LabelDescription-->\r\n <div class=\"bbsf-control-desc\" *ngIf=\"options.labelDescription!=null\">{{options.labelDescription}}</div>\r\n <!-- requiredText-->\r\n <div class=\"bbsf-validation\" [dir]=\"textDir\" *ngIf=\"(textAreaFormControl.invalid && textAreaFormControl.touched)\">\r\n {{getErrorValidation(textAreaFormControl.errors|keyvalue)}}\r\n </div>\r\n </div>\r\n <div *ngIf=\"(group.valid&&group.dirty&&group.touched )||(group.untouched&&group.invalid&&group.dirty) \">\r\n {{resetError()}}</div>\r\n </div>\r\n" }]
189
293
  }], ctorParameters: () => [{ type: i1.ControlUtility }, { type: i2.ControlContainer, decorators: [{
190
294
  type: Optional
191
- }] }, { type: i2.FormGroupDirective }, { type: i3.UtilityService }, { type: i3.ControlValidationService }, { type: i4.GlobalSettings }], propDecorators: { group: [{
295
+ }] }, { type: i2.FormGroupDirective }, { type: i3.UtilityService }, { type: i3.ControlValidationService }, { type: i4.GlobalSettings }, { type: i3.SpeechRecognitionService }, { type: i3.LanguageService }], propDecorators: { group: [{
192
296
  type: Input
193
297
  }], options: [{
194
298
  type: Input
195
299
  }], onChange: [{
196
300
  type: Output
197
301
  }] } });
198
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"TextArea.component.js","sourceRoot":"","sources":["../../../../../../projects/bbsf-controls/src/lib/controls/TextArea/TextArea.component.ts","../../../../../../projects/bbsf-controls/src/lib/controls/TextArea/TextArea.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Optional, Output, EventEmitter } from '@angular/core';\r\nimport { FormControl, Validators, FormGroup, AbstractControl, ControlContainer, FormGroupDirective } from '@angular/forms';\r\nimport { ControlValidationService, UtilityService } from '@bnsights/bbsf-utilities';\r\nimport { ControlUtility } from '../../Shared/services/ControlUtility';\r\nimport { TextAreaOptions } from '../../Shared/Models/TextAreaOptions';\r\nimport { GlobalSettings } from '../../Shared/services/GlobalSettings.service';\r\nimport { Observable } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'BBSF-TextArea',\r\n  templateUrl: './TextArea.component.html'\r\n})\r\nexport class TextAreaComponent implements OnInit {\r\n\r\n\r\n  static controlContainerstatic = null;\r\n  constructor(private controlUtility: ControlUtility, @Optional() private controlContainer: ControlContainer,\r\n    public textAreaControlHost: FormGroupDirective, private utilityService: UtilityService,\r\n    private controlValidationService: ControlValidationService, private globalSettings: GlobalSettings) {\r\n    TextAreaComponent.controlContainerstatic = this.controlContainer;\r\n  }\r\n  @Input() group: FormGroup;\r\n  @Input() options: TextAreaOptions;\r\n  @Output() onChange = new EventEmitter();\r\n\r\n  textAreaFormControl: AbstractControl;\r\n  wordCount: number = 0;\r\n  wordCountArray: number = 0;\r\n  isShowWordCount: boolean = false;\r\n  markAllAsTouched: boolean = false;\r\n  validationRules = [];\r\n  validationRulesasync = [];\r\n  //For Show warning message of max length limit\r\n  currentCharsCount: number = 0;\r\n  showCharsLimitMsg: boolean = false;\r\n  hasCharsLimitValidationError: boolean = false;\r\n  charsLimitMsgClass: string;\r\n  minCharsLimit: number = -1; //To disable chars limit feature by default\r\n  maxLimitWarningMsg: string = \"\";\r\n  public textDir;\r\n\r\n  ngOnInit() {\r\n    if (this.options.isReadonly && !this.options.value)\r\n      this.options.value = this.utilityService.getResourceValue('NA');\r\n\r\n    if (this.options.forceDirection)\r\n      this.textDir = this.options.forceDirection == 2 ? 'rtl' : 'ltr';\r\n    else\r\n      this.textDir = localStorage.getItem('language') == 'ar' ? 'rtl' : 'ltr';\r\n\r\n    this.controlValidationService.isCreatedBefor = false\r\n\r\n    this.group.addControl(this.options.name, new FormControl(''));\r\n    this.textAreaFormControl = this.group.controls[this.options.name]; //  new FormControl('',validationRules);\r\n\r\n    if (!this.options.maxLength)\r\n      this.options.maxLength = this.globalSettings.maxLengthTextArea;\r\n\r\n    if (!this.options.viewType)\r\n      this.options.viewType = this.globalSettings.viewType;\r\n\r\n    if (this.options.labelKey != null && this.options.labelKey != \"\")\r\n      this.options.labelValue = this.utilityService.getResourceValue(this.options.labelKey);\r\n\r\n    this.textAreaFormControl.setValue(this.options.value);\r\n    if (this.options.customValidation.length > 0) {\r\n      let Validations = this.options.customValidation\r\n      for (let index = 0; index < Validations.length; index++) {\r\n        const Validation = Validations[index];\r\n        this.validationRules.push(Validation.functionBody);\r\n      }\r\n\r\n    }\r\n    if (this.options.minLength > 0) {\r\n      this.validationRules.push(Validators.minLength(this.options.minLength));\r\n    }\r\n    if (this.options.maxLength > 0) {\r\n      this.validationRules.push(Validators.maxLength(this.options.maxLength));\r\n\r\n      if (!this.options.maxLengthWarningLimit)\r\n        this.options.maxLengthWarningLimit = this.globalSettings.maxLengthWarningLimit;\r\n\r\n      this.minCharsLimit = this.options.maxLength - this.options.maxLengthWarningLimit;\r\n    }\r\n    if (this.options.isRequired) {\r\n      this.validationRules.push(Validators.required);\r\n    }\r\n    this.textAreaFormControl.setValidators(this.validationRules);\r\n    this.textAreaFormControl.setAsyncValidators(this.validationRulesasync);\r\n    if (this.options.isDisabled) {\r\n      this.textAreaFormControl.disable();\r\n    }\r\n\r\n    this.textAreaControlHost.ngSubmit.subscribe((value) => {\r\n      this.group.markAllAsTouched()\r\n      this.markAllAsTouched = true\r\n    })\r\n\r\n  }\r\n\r\n\r\n  ngAfterViewInit(): void {\r\n    this.controlUtility.setAttributeForControl(this.options)\r\n  }\r\n\r\n  resetError = () => {\r\n    this.controlValidationService.removeGlobalError();\r\n  }\r\n\r\n  showGlobalError() {\r\n    this.controlUtility.showGlobalError()\r\n  }\r\n\r\n  getErrorValidation(ErrorList) {\r\n    if (this.markAllAsTouched && this.group.invalid) {\r\n      this.showGlobalError()\r\n      this.markAllAsTouched = false\r\n    }\r\n    return this.controlUtility.getErrorValidationMassage(ErrorList, this.group, this.options);\r\n  }\r\n  getInputType(type: number) {\r\n    return this.controlUtility.getInputType(type)\r\n  }\r\n\r\n  trimControlValue() {\r\n    let originalValue = this.controlUtility.trimControlValue(this.textAreaFormControl.value);\r\n    this.textAreaFormControl.patchValue(originalValue)\r\n    if (this.options.patchFunction && this.options.patchPath && this.textAreaFormControl.valid) {\r\n      this.controlUtility.patchControlValue(originalValue, this.options.patchFunction, this.options.patchPath)\r\n    }\r\n  }\r\n\r\n  copyInputMessage(inputElement) {\r\n    this.controlUtility.CopyInputMessage(inputElement)\r\n  }\r\n\r\n  onTextChange() {\r\n\r\n    if (this.textAreaFormControl.value == \"\") {\r\n      this.wordCountArray = 0;\r\n      this.wordCount = 0;\r\n    }\r\n\r\n    else {\r\n      this.wordCountArray = this.textAreaFormControl.value.split(\" \").length;\r\n      if (this.wordCountArray > 0) {\r\n        if (this.wordCountArray > this.options.maxWordCount) {\r\n          this.wordCount = this.options.maxWordCount;\r\n          this.textAreaFormControl.setErrors({ \"errorMassage\": `  Word count must be less then or equal  ${this.options.maxWordCount}` });\r\n          this.textAreaFormControl.markAsTouched();\r\n          this.textAreaFormControl.invalid;\r\n        }\r\n        else {\r\n          this.wordCount = this.wordCountArray;\r\n\r\n        }\r\n\r\n      }\r\n    }\r\n    //Check for maxlength limit count\r\n    //MaxLength should be gretaer than or equals chars limit so that minCharsLimit would be >= 0\r\n    if (this.options.maxLength && this.minCharsLimit >= 0) {\r\n      this.currentCharsCount = this.textAreaFormControl.value.length;\r\n      if (this.currentCharsCount > this.minCharsLimit) {\r\n        this.showCharsLimitMsg = true;\r\n        this.hasCharsLimitValidationError = true;\r\n\r\n        if (this.currentCharsCount == this.options.maxLength)\r\n          this.charsLimitMsgClass = \"danger\";\r\n        else\r\n          this.charsLimitMsgClass = \"warning\";\r\n      }\r\n      else {\r\n        this.showCharsLimitMsg = false;\r\n        this.hasCharsLimitValidationError = false;\r\n      }\r\n\r\n      let max: number = this.options.maxLength;\r\n      let current: number = this.currentCharsCount;\r\n      let msg: string = this.utilityService.getResourceValue(\"MaxLengthLimitWarning\");\r\n\r\n      // Replace placeholders with actual values\r\n      this.maxLimitWarningMsg = msg.replace(\"${max}\", max.toString()).replace(\"${current}\", current.toString());\r\n    }\r\n    this.onChange.emit(this.textAreaFormControl.value)\r\n\r\n  }\r\n\r\n  onFocus(isFocus: boolean) {\r\n    this.isShowWordCount = isFocus;\r\n\r\n    //onFocus\r\n    if (isFocus) {\r\n      if (this.hasCharsLimitValidationError) //check if there was previous validation error\r\n        this.showCharsLimitMsg = true;\r\n    }\r\n    else //onFocusOut\r\n      this.showCharsLimitMsg = false;\r\n  }\r\n\r\n  //External Method\r\n  removeRequiredValidation = () => {\r\n    this.controlUtility.removeRequiredValidation(this.textAreaFormControl, this.validationRules, this.options)\r\n  }\r\n  //External Method\r\n  addRequiredValidation = () => {\r\n    this.controlUtility.addRequiredValidation(this.textAreaFormControl, this.validationRules, this.options)\r\n  }\r\n\r\n  //External Method\r\n  removeCustomValidation = (customValidation) => {\r\n    this.controlUtility.removeCustomValidation(this.textAreaFormControl, this.validationRules, customValidation)\r\n  }\r\n  //External Method\r\n  addCustomValidation = (customValidation) => {\r\n    this.controlUtility.addCustomValidation(this.textAreaFormControl, this.validationRules, customValidation)\r\n  }\r\n  //External Method\r\n  isValid = () => {\r\n    this.controlUtility.isValid(this.textAreaFormControl)\r\n  }\r\n}\r\n\r\n\r\n","<div class=\"form-group bbsf-control bbsf-textarea\" [formGroup]=\"group\">\r\n  <div [ngClass]=\"(options.viewType==1)?'bbsf-vertical':'bbsf-horizontal'\">\r\n    <!--label-->\r\n    <label *ngIf=\"!options.hideLabel\" class=\"bbsf-label {{options.labelExtraClasses}}\">\r\n      {{options.labelValue}}\r\n      <!--Asterisk-->\r\n      <span *ngIf=\"((options.showAsterisk&&options.isRequired)||(options.isRequired))&&!options.isReadonly\"\r\n        class=\"text-danger\">*</span>\r\n    </label>\r\n    <div *ngIf=\"!options.isReadonly\" class=\"bbsf-input-container\"\r\n      [ngClass]=\"options.enableCopyToClipboard? 'p-40px' : '' \">\r\n      <!--input-->\r\n      <textarea class=\"form-control {{options.extraClasses}}\" (focus)=\"onFocus(true)\" (focusout)=\"onFocus(false)\"\r\n        [dir]=\"textDir\" aria-describedby=\"email-error\" aria-invalid=\"true\" formControlName=\"{{options.name}}\"\r\n        [class.is-invalid]=\"textAreaFormControl.invalid && textAreaFormControl.touched\"\r\n        placeholder=\"{{options.placeholder}}\" id=\"{{options.name}}\" autocomplete=\"{{options.autoComplete}}\"\r\n        (change)=\"trimControlValue()\" rows=\"{{options.rows}}\" (keyup)=\"onTextChange()\" cols=\"{{options.cols}}\"\r\n        maxlength=\"{{options.maxLength}}\" minlength=\"{{options.minLength}}\" [(ngModel)]=\"options.value\"\r\n        (keydown)=\"wordCountArray>options.maxWordCount&&$event.keyCode !=8?$event.preventDefault():null\"\r\n        #TextAreainput></textarea>\r\n      <!--CopyToClipboard-->\r\n      <div class=\"copy-clipboard\" *ngIf=\"options.enableCopyToClipboard\" (click)=\"copyInputMessage(TextAreainput)\">\r\n        <i class=\"fas fa-copy\"></i>\r\n      </div>\r\n    </div>\r\n    <!-- readonly -->\r\n    <div *ngIf=\"options.isReadonly\"><span class=\"readonly-view\">{{options.value}}</span>\r\n    </div>\r\n    <div class=\"subtext-container\">\r\n      <!--wordCount-->\r\n      <div class=\"bbsf-word-count\" *ngIf=\"options.maxWordCount>0&&isShowWordCount\">\r\n        {{wordCount}}/{{options.maxWordCount}} Words</div>\r\n      <!-- CharsLimitMsg-->\r\n      <div class=\"bbsf-character-count\" *ngIf=\"showCharsLimitMsg\"\r\n        [ngClass]=\"{'badge-light-warning': charsLimitMsgClass === 'warning', 'badge-light-danger' : charsLimitMsgClass === 'danger' }\">\r\n        {{maxLimitWarningMsg}}\r\n      </div>\r\n      <!-- LabelDescription-->\r\n      <div class=\"bbsf-control-desc\" *ngIf=\"options.labelDescription!=null\">{{options.labelDescription}}</div>\r\n      <!-- requiredText-->\r\n      <div class=\"bbsf-validation\" [dir]=\"textDir\" *ngIf=\"(textAreaFormControl.invalid && textAreaFormControl.touched)\">\r\n        {{getErrorValidation(textAreaFormControl.errors|keyvalue)}}\r\n      </div>\r\n    </div>\r\n    <div *ngIf=\"(group.valid&&group.dirty&&group.touched )||(group.untouched&&group.invalid&&group.dirty) \">\r\n      {{resetError()}}</div>\r\n  </div>"]}
302
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"TextArea.component.js","sourceRoot":"","sources":["../../../../../../projects/bbsf-controls/src/lib/controls/TextArea/TextArea.component.ts","../../../../../../projects/bbsf-controls/src/lib/controls/TextArea/TextArea.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Optional, Output, EventEmitter, ChangeDetectorRef } from '@angular/core';\r\nimport { FormControl, Validators, FormGroup, AbstractControl, ControlContainer, FormGroupDirective } from '@angular/forms';\r\nimport { ControlValidationService, LanguageService, UtilityService,SpeechRecognitionService } from '@bnsights/bbsf-utilities';\r\nimport { ControlUtility } from '../../Shared/services/ControlUtility';\r\nimport { TextAreaOptions } from '../../Shared/Models/TextAreaOptions';\r\nimport { GlobalSettings } from '../../Shared/services/GlobalSettings.service';\r\nimport { Observable, Subscription } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'BBSF-TextArea',\r\n  templateUrl: './TextArea.component.html'\r\n})\r\nexport class TextAreaComponent implements OnInit {\r\n\r\n\r\n  static controlContainerstatic = null;\r\n  constructor(private controlUtility: ControlUtility, @Optional() private controlContainer: ControlContainer,\r\n    public textAreaControlHost: FormGroupDirective, private utilityService: UtilityService,\r\n    private controlValidationService: ControlValidationService, private globalSettings: GlobalSettings,\r\n    private speechRecognitionService: SpeechRecognitionService, private languageService:LanguageService) {\r\n    TextAreaComponent.controlContainerstatic = this.controlContainer;\r\n    this.currentLanguage=localStorage.getItem('language');\r\n  }\r\n  @Input() group: FormGroup;\r\n  @Input() options: TextAreaOptions;\r\n  @Output() onChange = new EventEmitter();\r\n\r\n  textAreaFormControl: AbstractControl;\r\n  wordCount: number = 0;\r\n  wordCountArray: number = 0;\r\n  isShowWordCount: boolean = false;\r\n  markAllAsTouched: boolean = false;\r\n  validationRules = [];\r\n  validationRulesasync = [];\r\n  //For Show warning message of max length limit\r\n  currentCharsCount: number = 0;\r\n  showCharsLimitMsg: boolean = false;\r\n  hasCharsLimitValidationError: boolean = false;\r\n  charsLimitMsgClass: string;\r\n  minCharsLimit: number = -1; //To disable chars limit feature by default\r\n  maxLimitWarningMsg: string = \"\";\r\n  isMicOn: boolean = false;\r\n  public textDir;\r\n  isFocused: boolean;\r\ncurrentLanguage:String;\r\nsubscription: Subscription;\r\n\r\n  ngOnInit() {\r\n    if (this.options.isReadonly && !this.options.value)\r\n      this.options.value = this.utilityService.getResourceValue('NA');\r\n\r\n    if (this.options.forceDirection)\r\n      this.textDir = this.options.forceDirection == 2 ? 'rtl' : 'ltr';\r\n    else\r\n      this.textDir = localStorage.getItem('language') == 'ar' ? 'rtl' : 'ltr';\r\n\r\n    this.controlValidationService.isCreatedBefor = false\r\n\r\n    this.group.addControl(this.options.name, new FormControl(''));\r\n    this.textAreaFormControl = this.group.controls[this.options.name]; //  new FormControl('',validationRules);\r\n\r\n      // Initialize language form control\r\n  const languageControlName = this.options.name + 'Language';\r\n  this.group.addControl(languageControlName, new FormControl(this.options.selectedSpeechLanguage || ''));\r\n\r\n    if (!this.options.maxLength)\r\n      this.options.maxLength = this.globalSettings.maxLengthTextArea;\r\n\r\n    if (!this.options.viewType)\r\n      this.options.viewType = this.globalSettings.viewType;\r\n\r\n    if (this.options.labelKey != null && this.options.labelKey != \"\")\r\n      this.options.labelValue = this.utilityService.getResourceValue(this.options.labelKey);\r\n\r\n    if(this.options.enableSpeechRecognition)\r\n    {\r\n      //Get all languages if not set\r\n      if (!this.options.speechLanguages) {\r\n        this.languageService.getLanguages().subscribe(result => {\r\n          this.options.speechLanguages = result;\r\n          this.setSpeechLanguage();\r\n        })\r\n      }\r\n      else{\r\n        this.setSpeechLanguage();\r\n      }\r\n\r\n      \r\n    }\r\n    this.textAreaFormControl.setValue(this.options.value);\r\n    if (this.options.customValidation.length > 0) {\r\n      let Validations = this.options.customValidation\r\n      for (let index = 0; index < Validations.length; index++) {\r\n        const Validation = Validations[index];\r\n        this.validationRules.push(Validation.functionBody);\r\n      }\r\n\r\n    }\r\n    if (this.options.minLength > 0) {\r\n      this.validationRules.push(Validators.minLength(this.options.minLength));\r\n    }\r\n    if (this.options.maxLength > 0) {\r\n      this.validationRules.push(Validators.maxLength(this.options.maxLength));\r\n\r\n      if (!this.options.maxLengthWarningLimit)\r\n        this.options.maxLengthWarningLimit = this.globalSettings.maxLengthWarningLimit;\r\n\r\n      this.minCharsLimit = this.options.maxLength - this.options.maxLengthWarningLimit;\r\n    }\r\n    if (this.options.isRequired) {\r\n      this.validationRules.push(Validators.required);\r\n    }\r\n    this.textAreaFormControl.setValidators(this.validationRules);\r\n    this.textAreaFormControl.setAsyncValidators(this.validationRulesasync);\r\n    if (this.options.isDisabled) {\r\n      this.textAreaFormControl.disable();\r\n    }\r\n\r\n    this.textAreaControlHost.ngSubmit.subscribe((value) => {\r\n      this.group.markAllAsTouched()\r\n      this.markAllAsTouched = true\r\n    })\r\n\r\n  }\r\n\r\n\r\n  ngAfterViewInit(): void {\r\n    this.controlUtility.setAttributeForControl(this.options)\r\n  }\r\n\r\n  resetError = () => {\r\n    this.controlValidationService.removeGlobalError();\r\n  }\r\n\r\n  showGlobalError() {\r\n    this.controlUtility.showGlobalError()\r\n  }\r\n\r\n  getErrorValidation(ErrorList) {\r\n    if (this.markAllAsTouched && this.group.invalid) {\r\n      this.showGlobalError()\r\n      this.markAllAsTouched = false\r\n    }\r\n    return this.controlUtility.getErrorValidationMassage(ErrorList, this.group, this.options);\r\n  }\r\n  getInputType(type: number) {\r\n    return this.controlUtility.getInputType(type)\r\n  }\r\n\r\n  trimControlValue() {\r\n    let originalValue = this.controlUtility.trimControlValue(this.textAreaFormControl.value);\r\n    this.textAreaFormControl.patchValue(originalValue)\r\n    if (this.options.patchFunction && this.options.patchPath && this.textAreaFormControl.valid) {\r\n      this.controlUtility.patchControlValue(originalValue, this.options.patchFunction, this.options.patchPath)\r\n    }\r\n  }\r\n\r\n  copyInputMessage(inputElement) {\r\n    this.controlUtility.CopyInputMessage(inputElement)\r\n  }\r\n\r\n  onTextChange() {\r\n\r\n    if (this.textAreaFormControl.value == \"\") {\r\n      this.wordCountArray = 0;\r\n      this.wordCount = 0;\r\n    }\r\n\r\n    else {\r\n      this.wordCountArray = this.textAreaFormControl.value.split(\" \").length;\r\n      if (this.wordCountArray > 0) {\r\n        if (this.wordCountArray > this.options.maxWordCount) {\r\n          this.wordCount = this.options.maxWordCount;\r\n          this.textAreaFormControl.setErrors({ \"errorMassage\": `  Word count must be less then or equal  ${this.options.maxWordCount}` });\r\n          this.textAreaFormControl.markAsTouched();\r\n          this.textAreaFormControl.invalid;\r\n        }\r\n        else {\r\n          this.wordCount = this.wordCountArray;\r\n\r\n        }\r\n\r\n      }\r\n    }\r\n    //Check for maxlength limit count\r\n    //MaxLength should be gretaer than or equals chars limit so that minCharsLimit would be >= 0\r\n    if (this.options.maxLength && this.minCharsLimit >= 0) {\r\n      this.currentCharsCount = this.textAreaFormControl.value.length;\r\n      if (this.currentCharsCount > this.minCharsLimit) {\r\n        this.showCharsLimitMsg = true;\r\n        this.hasCharsLimitValidationError = true;\r\n\r\n        if (this.currentCharsCount == this.options.maxLength)\r\n          this.charsLimitMsgClass = \"danger\";\r\n        else\r\n          this.charsLimitMsgClass = \"warning\";\r\n      }\r\n      else {\r\n        this.showCharsLimitMsg = false;\r\n        this.hasCharsLimitValidationError = false;\r\n      }\r\n\r\n      let max: number = this.options.maxLength;\r\n      let current: number = this.currentCharsCount;\r\n      let msg: string = this.utilityService.getResourceValue(\"MaxLengthLimitWarning\");\r\n\r\n      // Replace placeholders with actual values\r\n      this.maxLimitWarningMsg = msg.replace(\"${max}\", max.toString()).replace(\"${current}\", current.toString());\r\n    }\r\n    this.onChange.emit(this.textAreaFormControl.value)\r\n\r\n  }\r\n\r\n  onFocus(isFocus: boolean) {\r\n    this.isShowWordCount = isFocus;\r\n\r\n    //onFocus\r\n    if (isFocus) {\r\n      if (this.hasCharsLimitValidationError) //check if there was previous validation error\r\n        this.showCharsLimitMsg = true;\r\n    }\r\n    else //onFocusOut\r\n      this.showCharsLimitMsg = false;\r\n  }\r\n\r\n  //External Method\r\n  removeRequiredValidation = () => {\r\n    this.controlUtility.removeRequiredValidation(this.textAreaFormControl, this.validationRules, this.options)\r\n  }\r\n  //External Method\r\n  addRequiredValidation = () => {\r\n    this.controlUtility.addRequiredValidation(this.textAreaFormControl, this.validationRules, this.options)\r\n  }\r\n\r\n  //External Method\r\n  removeCustomValidation = (customValidation) => {\r\n    this.controlUtility.removeCustomValidation(this.textAreaFormControl, this.validationRules, customValidation)\r\n  }\r\n  //External Method\r\n  addCustomValidation = (customValidation) => {\r\n    this.controlUtility.addCustomValidation(this.textAreaFormControl, this.validationRules, customValidation)\r\n  }\r\n  //External Method\r\n  isValid = () => {\r\n    this.controlUtility.isValid(this.textAreaFormControl)\r\n  }\r\n  //region Speech Recognition\r\n  setSpeechLanguage(){\r\n    const languageControlName = this.options.name + 'Language';\r\n\r\n    if(this.options.autoSaveSpeechLanguagetoLocalStorage){\r\n      let savedLanguage=localStorage.getItem(\"speechLanguage\");\r\n      if(savedLanguage){\r\n        this.options.selectedSpeechLanguage=savedLanguage;\r\n      }\r\n      else{\r\n        this.loadSelectedSpeechLanguage();\r\n        localStorage.setItem(\"speechLanguage\",this.options.selectedSpeechLanguage);\r\n      }\r\n    }\r\n    else{\r\n      this.loadSelectedSpeechLanguage(); \r\n    }\r\n    this.group.get(languageControlName).setValue(this.options.selectedSpeechLanguage);\r\n  }\r\n  loadSelectedSpeechLanguage(){\r\n    if (!this.options.selectedSpeechLanguage){\r\n      if(this.currentLanguage==\"en\" && this.options.speechLanguages.some(language => language.englishName === 'English')){\r\n        this.options.selectedSpeechLanguage=this.options.speechLanguages.find(language => language.englishName === 'English').dialect;\r\n      }\r\n      else if(this.currentLanguage==\"ar\" && this.options.speechLanguages.some(language => language.englishName === 'Arabic')){\r\n        this.options.selectedSpeechLanguage=this.options.speechLanguages.find(language => language.englishName === 'Arabic').dialect;\r\n      }\r\n      else{\r\n        this.options.selectedSpeechLanguage = this.options.speechLanguages[0].dialect;\r\n      }\r\n  }\r\n}\r\n  startSpeechRecognition(): void {\r\n    if (!this.speechRecognitionService.isSupported) {\r\n      this.utilityService.notifyErrorMessage(this.utilityService.getResourceValue(\"BrowserNotSupportSpeechRecognition\"));\r\n      return;\r\n    }\r\n    this.isMicOn = true;\r\n    this.subscription = this.speechRecognitionService.startListening(this.options.selectedSpeechLanguage).subscribe({\r\n      next: (transcript: string) => {\r\n        if(transcript){\r\n          if(this.options.value){\r\n            this.options.value+=' ';\r\n          }\r\n          let charIndex = 0;\r\n          const interval = setInterval(() => {\r\n            this.options.value += transcript[charIndex];\r\n            charIndex++;\r\n            if (charIndex === transcript.length) {\r\n              clearInterval(interval);\r\n            }\r\n          }, 10);\r\n        }\r\n      },\r\n      error: (error: any) => {\r\n        console.error(error);\r\n        this.stopSpeechRecognition();\r\n      },\r\n      complete: () => {\r\n        this.isMicOn = false;\r\n      }\r\n    });\r\n  }\r\n\r\n  stopSpeechRecognition(): void {\r\n    if (!this.speechRecognitionService.isSupported) {\r\n      return;\r\n    }\r\n    this.isMicOn = false;\r\n    this.speechRecognitionService.stopListening();\r\n    if (this.subscription) {\r\n      this.subscription.unsubscribe();\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.stopSpeechRecognition();\r\n  }\r\n\r\n  onSpeechLanguageChange(event) {\r\n    let selectedLang=event.target.value;\r\n    this.options.selectedSpeechLanguage = selectedLang;\r\n\r\n    const languageControlName = this.options.name + 'Language';\r\n    this.group.get(languageControlName).setValue(selectedLang);\r\n    \r\n    if(this.options.autoSaveSpeechLanguagetoLocalStorage){\r\n      localStorage.setItem(\"speechLanguage\",selectedLang)\r\n    }\r\n  }\r\n  //#endRegion\r\n}\r\n\r\n\r\n","<div class=\"form-group bbsf-control bbsf-textarea\" [formGroup]=\"group\">\r\n  <div [ngClass]=\"(options.viewType==1)?'bbsf-vertical':'bbsf-horizontal'\">\r\n    <!--label-->\r\n    <label *ngIf=\"!options.hideLabel\" class=\"bbsf-label {{options.labelExtraClasses}}\">\r\n      {{options.labelValue}}\r\n      <!--Asterisk-->\r\n      <span *ngIf=\"((options.showAsterisk&&options.isRequired)||(options.isRequired))&&!options.isReadonly\"\r\n        class=\"text-danger\">*</span>\r\n    </label>\r\n    <div *ngIf=\"!options.isReadonly\" class=\"bbsf-input-container\" [ngClass]=\"{\r\n      'p-120px': options.enableSpeechRecognition && options.enableCopyToClipboard,\r\n      'p-80px': options.enableSpeechRecognition && !options.enableCopyToClipboard,\r\n      'p-40px': !options.enableSpeechRecognition && options.enableCopyToClipboard\r\n    }\">\r\n      <!--input-->\r\n      <textarea class=\"form-control {{options.extraClasses}}\" (focus)=\"onFocus(true)\" (focusout)=\"onFocus(false)\"\r\n        [dir]=\"textDir\" aria-describedby=\"email-error\" aria-invalid=\"true\" formControlName=\"{{options.name}}\"\r\n        [class.is-invalid]=\"textAreaFormControl.invalid && textAreaFormControl.touched\"\r\n        placeholder=\"{{options.placeholder}}\" id=\"{{options.name}}\" autocomplete=\"{{options.autoComplete}}\"\r\n        (change)=\"trimControlValue()\" rows=\"{{options.rows}}\" (keyup)=\"onTextChange()\" cols=\"{{options.cols}}\"\r\n        maxlength=\"{{options.maxLength}}\" minlength=\"{{options.minLength}}\" [(ngModel)]=\"options.value\"\r\n        (keydown)=\"wordCountArray>options.maxWordCount&&$event.keyCode !=8?$event.preventDefault():null\"\r\n        #TextAreainput></textarea>\r\n      <!--CopyToClipboard-->\r\n      <div class=\"copy-clipboard\" *ngIf=\"options.enableCopyToClipboard\" (click)=\"copyInputMessage(TextAreainput)\">\r\n        <i class=\"fas fa-copy\"></i>\r\n      </div>\r\n      <div [ngClass]=\"{'expanded': isFocused}\" class=\"language-container {{options.extraClassMicLanguage}}\" *ngIf=\"options.enableSpeechRecognition\">\r\n        <span class=\"svg-icon svg-icon-5\" [inlineSVG]=\"options.iconMic? options.iconMic : './src/assets/images/mic.svg'\" (click)=\"startSpeechRecognition()\"\r\n            *ngIf=\"!isMicOn\">\r\n        </span>\r\n        <span class=\"svg-icon svg-icon-5\"  [inlineSVG]=\"options.iconMicOff? options.iconMicOff : './src/assets/images/mic-off.svg'\" (click)=\"stopSpeechRecognition()\"\r\n            *ngIf=\"isMicOn\">\r\n        </span>\r\n        <select class=\"language-select\" [formControlName]=\"options.name + 'Language'\" (change)=\"onSpeechLanguageChange($event)\">\r\n          <option *ngFor=\"let language of options.speechLanguages\" [value]=\"language.dialect\">{{language.displayName}}</option>\r\n        </select>\r\n    </div>\r\n    </div>\r\n    <!-- readonly -->\r\n    <div *ngIf=\"options.isReadonly\"><span class=\"readonly-view\">{{options.value}}</span>\r\n    </div>\r\n    <div class=\"subtext-container\">\r\n      <!--wordCount-->\r\n      <div class=\"bbsf-word-count\" *ngIf=\"options.maxWordCount>0&&isShowWordCount\">\r\n        {{wordCount}}/{{options.maxWordCount}} Words</div>\r\n      <!-- CharsLimitMsg-->\r\n      <div class=\"bbsf-character-count\" *ngIf=\"showCharsLimitMsg\"\r\n        [ngClass]=\"{'badge-light-warning': charsLimitMsgClass === 'warning', 'badge-light-danger' : charsLimitMsgClass === 'danger' }\">\r\n        {{maxLimitWarningMsg}}\r\n      </div>\r\n      <!-- LabelDescription-->\r\n      <div class=\"bbsf-control-desc\" *ngIf=\"options.labelDescription!=null\">{{options.labelDescription}}</div>\r\n      <!-- requiredText-->\r\n      <div class=\"bbsf-validation\" [dir]=\"textDir\" *ngIf=\"(textAreaFormControl.invalid && textAreaFormControl.touched)\">\r\n        {{getErrorValidation(textAreaFormControl.errors|keyvalue)}}\r\n      </div>\r\n    </div>\r\n    <div *ngIf=\"(group.valid&&group.dirty&&group.touched )||(group.untouched&&group.invalid&&group.dirty) \">\r\n      {{resetError()}}</div>\r\n  </div>\r\n"]}