@bnsights/bbsf-controls 1.0.181 → 1.0.183

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.
@@ -1,16 +1,14 @@
1
- import { Component, Input, Optional, Output, EventEmitter } from '@angular/core';
1
+ import { Component, Input, Optional, Output, EventEmitter, SkipSelf } from '@angular/core';
2
2
  import { FormControl, Validators } from '@angular/forms';
3
3
  import * as i0 from "@angular/core";
4
- import * as i1 from "../../Shared/services/ControlUtility";
4
+ import * as i1 from "../../Shared/services";
5
5
  import * as i2 from "@angular/forms";
6
6
  import * as i3 from "@bnsights/bbsf-utilities";
7
- import * as i4 from "../../Shared/services/GlobalSettings.service";
8
- import * as i5 from "@angular/common";
9
- import * as i6 from "@angular/cdk/bidi";
10
- import * as i7 from "ngx-intl-tel-input";
11
- import * as i8 from "ng-inline-svg-2";
7
+ import * as i4 from "@angular/common";
8
+ import * as i5 from "@angular/cdk/bidi";
9
+ import * as i6 from "ngx-intl-tel-input";
10
+ import * as i7 from "ng-inline-svg-2";
12
11
  export class TextAreaComponent {
13
- static { this.controlContainerstatic = null; }
14
12
  constructor(controlUtility, controlContainer, textAreaControlHost, utilityService, controlValidationService, globalSettings, speechRecognitionService, languageService) {
15
13
  this.controlUtility = controlUtility;
16
14
  this.controlContainer = controlContainer;
@@ -34,6 +32,12 @@ export class TextAreaComponent {
34
32
  this.minCharsLimit = -1; //To disable chars limit feature by default
35
33
  this.maxLimitWarningMsg = '';
36
34
  this.isMicOn = false;
35
+ this.selectedSpeechLanguageDisplayText = '';
36
+ // Accessibility properties
37
+ this.ariaDescribedBy = '';
38
+ this.errorMessageId = '';
39
+ this.characterCountId = '';
40
+ this.wordCountId = '';
37
41
  this.resetError = () => {
38
42
  this.controlValidationService.removeGlobalError();
39
43
  };
@@ -57,10 +61,23 @@ export class TextAreaComponent {
57
61
  this.isValid = () => {
58
62
  this.controlUtility.isValid(this.textAreaFormControl);
59
63
  };
60
- TextAreaComponent.controlContainerstatic = this.controlContainer;
61
64
  this.currentLanguage = localStorage.getItem('language');
62
65
  }
63
66
  ngOnInit() {
67
+ // Initialize accessibility IDs
68
+ this.errorMessageId = `${this.options.name}-error`;
69
+ this.characterCountId = `${this.options.name}-char-count`;
70
+ this.wordCountId = `${this.options.name}-word-count`;
71
+ this.updateAriaDescribedBy();
72
+ // Initialize speech recognition properties only if enabled
73
+ if (this.options.enableSpeechRecognition) {
74
+ this.isMicOn = false;
75
+ this.selectedSpeechLanguageDisplayText = '';
76
+ }
77
+ else {
78
+ // Reset speech-related properties when disabled
79
+ this.resetSpeechProperties();
80
+ }
64
81
  if (this.options.isReadonly && !this.options.value)
65
82
  this.options.value = this.utilityService.getResourceValue('NA');
66
83
  if (this.options.forceDirection)
@@ -116,9 +133,24 @@ export class TextAreaComponent {
116
133
  if (this.options.isDisabled) {
117
134
  this.textAreaFormControl.disable();
118
135
  }
119
- this.textAreaControlHost.ngSubmit.subscribe((value) => {
120
- this.group.markAllAsTouched();
121
- this.markAllAsTouched = true;
136
+ // Only subscribe to ngSubmit if FormGroupDirective is available
137
+ if (this.textAreaControlHost) {
138
+ this.textAreaControlHost.ngSubmit.subscribe((value) => {
139
+ this.group.markAllAsTouched();
140
+ this.markAllAsTouched = true;
141
+ });
142
+ }
143
+ // Subscribe to value changes to ensure warning messages are properly reset
144
+ this.valueChangesSubscription = this.textAreaFormControl.valueChanges.subscribe((value) => {
145
+ // Reset warning message when control is empty or null
146
+ if (!value || value.trim().length === 0) {
147
+ this.showCharsLimitMsg = false;
148
+ this.hasCharsLimitValidationError = false;
149
+ this.maxLimitWarningMsg = '';
150
+ this.currentCharsCount = 0;
151
+ this.wordCount = 0;
152
+ this.wordCountArray = 0;
153
+ }
122
154
  });
123
155
  }
124
156
  ngAfterViewInit() {
@@ -137,6 +169,55 @@ export class TextAreaComponent {
137
169
  getInputType(type) {
138
170
  return this.controlUtility.getInputType(type);
139
171
  }
172
+ // Accessibility helper methods
173
+ updateAriaDescribedBy() {
174
+ const describedByIds = [];
175
+ if (this.options.labelDescription) {
176
+ describedByIds.push(`${this.options.name}-description`);
177
+ }
178
+ if (this.options.maxWordCount > 0) {
179
+ describedByIds.push(this.wordCountId);
180
+ }
181
+ if (this.showCharsLimitMsg) {
182
+ describedByIds.push(this.characterCountId);
183
+ }
184
+ if (this.textAreaFormControl?.invalid && this.textAreaFormControl?.touched) {
185
+ describedByIds.push(this.errorMessageId);
186
+ }
187
+ // Only add speech-related descriptions if speech recognition is enabled
188
+ if (this.options.enableSpeechRecognition && this.selectedSpeechLanguageDisplayText) {
189
+ describedByIds.push(`${this.options.name}-language-display`);
190
+ }
191
+ this.ariaDescribedBy = describedByIds.join(' ');
192
+ }
193
+ announceToScreenReader(message) {
194
+ // Create temporary element for screen reader announcement
195
+ const announcement = document.createElement('div');
196
+ announcement.setAttribute('aria-live', 'polite');
197
+ announcement.setAttribute('aria-atomic', 'true');
198
+ announcement.className = 'sr-only';
199
+ announcement.textContent = message;
200
+ document.body.appendChild(announcement);
201
+ // Remove after announcement
202
+ setTimeout(() => {
203
+ document.body.removeChild(announcement);
204
+ }, 1000);
205
+ }
206
+ resetSpeechProperties() {
207
+ // Reset all speech-related properties when speech recognition is disabled
208
+ this.isMicOn = false;
209
+ this.selectedSpeechLanguageDisplayText = '';
210
+ // Clean up any active speech recognition subscriptions
211
+ if (this.subscription) {
212
+ this.subscription.unsubscribe();
213
+ this.subscription = null;
214
+ }
215
+ // Remove speech language form control if it exists
216
+ const languageControlName = 'Language_' + this.options.name;
217
+ if (this.group?.get(languageControlName)) {
218
+ this.group.removeControl(languageControlName);
219
+ }
220
+ }
140
221
  trimControlValue() {
141
222
  let originalValue = this.controlUtility.trimControlValue(this.textAreaFormControl.value);
142
223
  this.textAreaFormControl.patchValue(originalValue);
@@ -144,8 +225,53 @@ export class TextAreaComponent {
144
225
  this.controlUtility.patchControlValue(originalValue, this.options.patchFunction, this.options.patchPath);
145
226
  }
146
227
  }
228
+ onKeyDown(event) {
229
+ const textarea = event.target;
230
+ const currentValue = textarea.value || '';
231
+ const key = event.key;
232
+ // Allow navigation keys (arrows, home, end, etc.)
233
+ const allowedKeys = ['Backspace', 'Delete', 'Tab', 'Escape', 'Enter', 'Home', 'End', 'ArrowLeft', 'ArrowRight', 'ArrowUp', 'ArrowDown'];
234
+ // Allow Ctrl/Cmd + keys (copy, paste, select all, etc.)
235
+ if (event.ctrlKey || event.metaKey) {
236
+ return; // Allow all Ctrl/Cmd combinations
237
+ }
238
+ // If it's a navigation key, allow it
239
+ if (allowedKeys.includes(key)) {
240
+ // Special handling for word count on Backspace
241
+ if (key === 'Backspace' && this.options.maxWordCount > 0) {
242
+ return; // Always allow backspace for word count correction
243
+ }
244
+ return;
245
+ }
246
+ // Check word count limit
247
+ if (this.options.maxWordCount > 0) {
248
+ const currentWordCount = currentValue.trim() ? currentValue.trim().split(/\s+/).length : 0;
249
+ if (currentWordCount >= this.options.maxWordCount && key !== 'Backspace' && key !== 'Delete') {
250
+ // Check if adding this character would create a new word
251
+ const cursorPosition = textarea.selectionStart;
252
+ const charBefore = cursorPosition > 0 ? currentValue[cursorPosition - 1] : '';
253
+ const charAfter = cursorPosition < currentValue.length ? currentValue[cursorPosition] : '';
254
+ // If we're typing a space or the character before/after is a space, this might create a new word
255
+ if (key === ' ' || (/\s/.test(charBefore) && !(/\s/.test(key)))) {
256
+ event.preventDefault();
257
+ return;
258
+ }
259
+ }
260
+ }
261
+ // Check character count limit
262
+ if (this.options.maxLength && currentValue.length >= this.options.maxLength) {
263
+ // Only allow if we have selected text (which will be replaced) or navigation keys
264
+ const hasSelection = textarea.selectionStart !== textarea.selectionEnd;
265
+ if (!hasSelection && !allowedKeys.includes(key)) {
266
+ event.preventDefault();
267
+ return;
268
+ }
269
+ }
270
+ }
147
271
  copyInputMessage(inputElement) {
148
272
  this.controlUtility.CopyInputMessage(inputElement);
273
+ // Announce to screen readers
274
+ this.announceToScreenReader('Text copied to clipboard');
149
275
  }
150
276
  onTextChange() {
151
277
  if (this.textAreaFormControl.value == '') {
@@ -158,7 +284,7 @@ export class TextAreaComponent {
158
284
  if (this.wordCountArray > this.options.maxWordCount) {
159
285
  this.wordCount = this.options.maxWordCount;
160
286
  this.textAreaFormControl.setErrors({
161
- errorMassage: ` Word count must be less then or equal ${this.options.maxWordCount}`
287
+ errorMessage: `Word count must be less than or equal to ${this.options.maxWordCount}`
162
288
  });
163
289
  this.textAreaFormControl.markAsTouched();
164
290
  this.textAreaFormControl.invalid;
@@ -169,30 +295,47 @@ export class TextAreaComponent {
169
295
  }
170
296
  }
171
297
  //Check for maxlength limit count
172
- //MaxLength should be gretaer than or equals chars limit so that minCharsLimit would be >= 0
298
+ //MaxLength should be greater than or equals chars limit so that minCharsLimit would be >= 0
173
299
  if (this.options.maxLength && this.minCharsLimit >= 0) {
174
- this.currentCharsCount = this.textAreaFormControl.value.length;
175
- if (this.currentCharsCount > this.minCharsLimit) {
176
- this.showCharsLimitMsg = true;
177
- this.hasCharsLimitValidationError = true;
178
- if (this.currentCharsCount == this.options.maxLength)
179
- this.charsLimitMsgClass = 'danger';
180
- else
181
- this.charsLimitMsgClass = 'warning';
300
+ // Check if value exists and is not empty
301
+ const controlValue = this.textAreaFormControl.value;
302
+ if (controlValue && controlValue.trim().length > 0) {
303
+ this.currentCharsCount = controlValue.length;
304
+ if (this.currentCharsCount > this.minCharsLimit) {
305
+ this.showCharsLimitMsg = true;
306
+ this.hasCharsLimitValidationError = true;
307
+ if (this.currentCharsCount == this.options.maxLength)
308
+ this.charsLimitMsgClass = 'danger';
309
+ else
310
+ this.charsLimitMsgClass = 'warning';
311
+ // Only generate warning message when we actually want to show it
312
+ let max = this.options.maxLength;
313
+ let current = this.currentCharsCount;
314
+ let msg = this.utilityService.getResourceValue('MaxLengthLimitWarning');
315
+ this.maxLimitWarningMsg = msg
316
+ .replace('${max}', max.toString())
317
+ .replace('${current}', current.toString());
318
+ }
319
+ else {
320
+ this.showCharsLimitMsg = false;
321
+ this.hasCharsLimitValidationError = false;
322
+ }
182
323
  }
183
324
  else {
325
+ // Reset everything when value is empty
326
+ this.currentCharsCount = 0;
184
327
  this.showCharsLimitMsg = false;
185
328
  this.hasCharsLimitValidationError = false;
329
+ this.maxLimitWarningMsg = '';
186
330
  }
187
- let max = this.options.maxLength;
188
- let current = this.currentCharsCount;
189
- let msg = this.utilityService.getResourceValue('MaxLengthLimitWarning');
190
- // Replace placeholders with actual values
191
- this.maxLimitWarningMsg = msg
192
- .replace('${max}', max.toString())
193
- .replace('${current}', current.toString());
194
331
  }
195
332
  this.onChange.emit(this.textAreaFormControl.value);
333
+ // Update accessibility attributes
334
+ this.updateAriaDescribedBy();
335
+ // Announce character limit warnings to screen readers
336
+ if (this.showCharsLimitMsg && this.charsLimitMsgClass === 'danger') {
337
+ this.announceToScreenReader(`Character limit reached: ${this.maxLimitWarningMsg}`);
338
+ }
196
339
  }
197
340
  onFocus(isFocus) {
198
341
  this.isShowWordCount = isFocus;
@@ -207,6 +350,10 @@ export class TextAreaComponent {
207
350
  }
208
351
  //region Speech Recognition
209
352
  setSpeechLanguage() {
353
+ // Guard: Only execute if speech recognition is enabled
354
+ if (!this.options.enableSpeechRecognition) {
355
+ return;
356
+ }
210
357
  const languageControlName = 'Language_' + this.options.name;
211
358
  if (this.options.autoSaveSpeechLanguagetoLocalStorage) {
212
359
  let savedLanguage = localStorage.getItem('speechLanguage');
@@ -222,9 +369,14 @@ export class TextAreaComponent {
222
369
  this.loadSelectedSpeechLanguage();
223
370
  }
224
371
  this.group.get(languageControlName).setValue(this.options.selectedSpeechLanguage);
225
- this.selectedSpeechLanguageDisplayText = this.options.speechLanguages.find((l) => l.dialect == this.options.selectedSpeechLanguage).prefix;
372
+ const language = this.options.speechLanguages?.find((l) => l.dialect == this.options.selectedSpeechLanguage);
373
+ this.selectedSpeechLanguageDisplayText = language?.prefix || '';
226
374
  }
227
375
  loadSelectedSpeechLanguage() {
376
+ // Guard: Only execute if speech recognition is enabled
377
+ if (!this.options.enableSpeechRecognition) {
378
+ return;
379
+ }
228
380
  if (!this.options.selectedSpeechLanguage) {
229
381
  if (this.currentLanguage == 'en' &&
230
382
  this.options.speechLanguages.some((language) => language.englishName === 'English')) {
@@ -240,13 +392,21 @@ export class TextAreaComponent {
240
392
  }
241
393
  }
242
394
  startSpeechRecognition() {
395
+ // Guard: Only execute if speech recognition is enabled
396
+ if (!this.options.enableSpeechRecognition) {
397
+ return;
398
+ }
243
399
  if (!this.speechRecognitionService.isSupported) {
244
- this.utilityService.notifyErrorMessage(this.utilityService.getResourceValue('BrowserNotSupportSpeechRecognition'));
400
+ const errorMessage = this.utilityService.getResourceValue('BrowserNotSupportSpeechRecognition');
401
+ this.utilityService.notifyErrorMessage(errorMessage);
402
+ this.announceToScreenReader(errorMessage);
245
403
  return;
246
404
  }
247
405
  //Disable Select Language
248
406
  this.enableOrDisableLanguageSelect(false);
249
407
  this.isMicOn = true;
408
+ // Announce to screen readers
409
+ this.announceToScreenReader('Speech recognition started. Speak now.');
250
410
  this.subscription = this.speechRecognitionService
251
411
  .startListening(this.options.selectedSpeechLanguage)
252
412
  .subscribe({
@@ -275,10 +435,15 @@ export class TextAreaComponent {
275
435
  //Enable Select Language
276
436
  this.enableOrDisableLanguageSelect();
277
437
  this.isMicOn = false;
438
+ this.announceToScreenReader('Speech recognition stopped.');
278
439
  }
279
440
  });
280
441
  }
281
442
  stopSpeechRecognition() {
443
+ // Guard: Only execute if speech recognition is enabled
444
+ if (!this.options.enableSpeechRecognition) {
445
+ return;
446
+ }
282
447
  this.enableOrDisableLanguageSelect();
283
448
  if (!this.speechRecognitionService.isSupported) {
284
449
  return;
@@ -288,6 +453,8 @@ export class TextAreaComponent {
288
453
  if (this.subscription) {
289
454
  this.subscription.unsubscribe();
290
455
  }
456
+ // Announce to screen readers
457
+ this.announceToScreenReader('Speech recognition stopped.');
291
458
  }
292
459
  fireOnChange(text) {
293
460
  if (this.onChange) {
@@ -295,13 +462,48 @@ export class TextAreaComponent {
295
462
  }
296
463
  }
297
464
  ngOnDestroy() {
465
+ // Always clean up subscriptions
466
+ if (this.subscription) {
467
+ this.subscription.unsubscribe();
468
+ }
469
+ if (this.valueChangesSubscription) {
470
+ this.valueChangesSubscription.unsubscribe();
471
+ }
472
+ // Only call speech recognition cleanup if it was enabled
298
473
  if (this.options.enableSpeechRecognition) {
299
474
  this.stopSpeechRecognition();
300
475
  }
301
476
  }
477
+ // Keyboard accessibility for speech recognition controls
478
+ onMicKeydown(event, action) {
479
+ // Guard: Only execute if speech recognition is enabled
480
+ if (!this.options.enableSpeechRecognition) {
481
+ return;
482
+ }
483
+ if (event.key === 'Enter' || event.key === ' ') {
484
+ event.preventDefault();
485
+ if (action === 'start') {
486
+ this.startSpeechRecognition();
487
+ }
488
+ else {
489
+ this.stopSpeechRecognition();
490
+ }
491
+ }
492
+ }
493
+ onCopyKeydown(event, inputElement) {
494
+ if (event.key === 'Enter' || event.key === ' ') {
495
+ event.preventDefault();
496
+ this.copyInputMessage(inputElement);
497
+ }
498
+ }
302
499
  onSpeechLanguageChange(event) {
500
+ // Guard: Only execute if speech recognition is enabled
501
+ if (!this.options.enableSpeechRecognition) {
502
+ return;
503
+ }
303
504
  let selectedLang_Dialect = event.target.value;
304
- this.selectedSpeechLanguageDisplayText = this.options.speechLanguages.find((l) => l.dialect == selectedLang_Dialect).prefix;
505
+ const language = this.options.speechLanguages?.find((l) => l.dialect == selectedLang_Dialect);
506
+ this.selectedSpeechLanguageDisplayText = language?.prefix || '';
305
507
  this.options.selectedSpeechLanguage = selectedLang_Dialect;
306
508
  const languageControlName = 'Language_' + this.options.name;
307
509
  let select = this.group.get(languageControlName);
@@ -309,8 +511,14 @@ export class TextAreaComponent {
309
511
  if (this.options.autoSaveSpeechLanguagetoLocalStorage) {
310
512
  localStorage.setItem('speechLanguage', selectedLang_Dialect);
311
513
  }
514
+ // Announce language change to screen readers
515
+ this.announceToScreenReader(`Speech recognition language changed to ${language?.name || selectedLang_Dialect}`);
312
516
  }
313
517
  enableOrDisableLanguageSelect(isEnabled = true) {
518
+ // Guard: Only execute if speech recognition is enabled
519
+ if (!this.options.enableSpeechRecognition) {
520
+ return;
521
+ }
314
522
  const languageControlName = 'Language_' + this.options.name;
315
523
  let select = this.group.get(languageControlName);
316
524
  if (isEnabled) {
@@ -320,19 +528,23 @@ export class TextAreaComponent {
320
528
  select.disable();
321
529
  }
322
530
  }
323
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", 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 }); }
324
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", 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 <div>\r\n <span class=\"language-text\">{{ selectedSpeechLanguageDisplayText }}</span>\r\n <select class=\"language-select\" [formControlName]=\"'Language_'+options.name\" (change)=\"onSpeechLanguageChange($event)\">\r\n <option *ngFor=\"let language of options.speechLanguages\" [value]=\"language.dialect\">\r\n {{language.name}}\r\n </option>\r\n </select>\r\n\r\n </div>\r\n\r\n\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" }] }); }
531
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TextAreaComponent, deps: [{ token: i1.ControlUtility }, { token: i2.ControlContainer, optional: true, skipSelf: true }, { token: i2.FormGroupDirective, optional: true }, { token: i3.UtilityService }, { token: i3.ControlValidationService }, { token: i1.GlobalSettings }, { token: i3.SpeechRecognitionService }, { token: i3.LanguageService }], target: i0.ɵɵFactoryTarget.Component }); }
532
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", 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\" [attr.aria-invalid]=\"textAreaFormControl.invalid && textAreaFormControl.touched\"\r\n [attr.aria-describedby]=\"ariaDescribedBy\" [attr.aria-label]=\"options.labelValue || options.placeholder\"\r\n 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 [attr.minlength]=\"options.minLength\" [(ngModel)]=\"options.value\" (keydown)=\"onKeyDown($event)\"\r\n [attr.maxlength]=\"options.maxLength\" role=\"textbox\" [attr.aria-multiline]=\"true\" #TextAreainput></textarea>\r\n <!--CopyToClipboard-->\r\n <button type=\"button\" class=\"copy-clipboard\" *ngIf=\"options.enableCopyToClipboard\"\r\n (click)=\"copyInputMessage(TextAreainput)\" (keydown)=\"onCopyKeydown($event, TextAreainput)\"\r\n [attr.aria-label]=\"'Copy text to clipboard'\" title=\"Copy text to clipboard\" tabindex=\"0\">\r\n <i class=\"fas fa-copy\" aria-hidden=\"true\"></i>\r\n </button>\r\n <div [ngClass]=\"{'expanded': isFocused}\" class=\"language-container {{options.extraClassMicLanguage}}\"\r\n *ngIf=\"options.enableSpeechRecognition\" role=\"region\" [attr.aria-label]=\"'Speech recognition controls'\">\r\n\r\n <!-- Start Speech Recognition Button -->\r\n <button type=\"button\" class=\"svg-icon svg-icon-5 speech-control-btn\"\r\n [inlineSVG]=\"options.iconMic || 'assets/bbsf-controls/images/mic.svg'\" (click)=\"startSpeechRecognition()\"\r\n (keydown)=\"onMicKeydown($event, 'start')\" *ngIf=\"options.enableSpeechRecognition && !isMicOn\"\r\n [attr.aria-label]=\"'Start speech recognition'\" title=\"Start speech recognition\" tabindex=\"0\"\r\n [attr.aria-pressed]=\"false\">\r\n </button>\r\n\r\n <!-- Stop Speech Recognition Button -->\r\n <button type=\"button\" class=\"svg-icon svg-icon-5 speech-control-btn\"\r\n [inlineSVG]=\"options.iconMicOff || 'assets/bbsf-controls/images/mic-off.svg'\"\r\n (click)=\"stopSpeechRecognition()\" (keydown)=\"onMicKeydown($event, 'stop')\"\r\n *ngIf=\"options.enableSpeechRecognition && isMicOn\" [attr.aria-label]=\"'Stop speech recognition'\"\r\n title=\"Stop speech recognition\" tabindex=\"0\" [attr.aria-pressed]=\"true\">\r\n </button>\r\n\r\n <div class=\"language-controls\">\r\n <span class=\"language-text\" [attr.id]=\"options.name + '-language-display'\"\r\n aria-live=\"polite\">{{ options.enableSpeechRecognition ? selectedSpeechLanguageDisplayText : '' }}</span>\r\n\r\n <label [for]=\"'Language_'+options.name\" class=\"sr-only\">\r\n Select speech recognition language\r\n </label>\r\n <select class=\"language-select\" [formControlName]=\"'Language_'+options.name\" [id]=\"'Language_'+options.name\"\r\n (change)=\"onSpeechLanguageChange($event)\" [attr.aria-describedby]=\"options.name + '-language-display'\">\r\n <option *ngFor=\"let language of options.speechLanguages\" [value]=\"language.dialect\">\r\n {{language.name}}\r\n </option>\r\n </select>\r\n </div>\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\" [attr.id]=\"wordCountId\"\r\n aria-live=\"polite\" [attr.aria-label]=\"'Word count: ' + wordCount + ' of ' + options.maxWordCount + ' words'\">\r\n {{wordCount}}/{{options.maxWordCount}} Words\r\n </div>\r\n\r\n <!-- CharsLimitMsg-->\r\n <div class=\"bbsf-character-count\" *ngIf=\"showCharsLimitMsg\" [attr.id]=\"characterCountId\" aria-live=\"polite\"\r\n [attr.aria-atomic]=\"true\"\r\n [ngClass]=\"{'badge-light-warning': charsLimitMsgClass === 'warning', 'badge-light-danger' : charsLimitMsgClass === 'danger' }\">\r\n {{maxLimitWarningMsg}}\r\n </div>\r\n\r\n <!-- LabelDescription-->\r\n <div class=\"bbsf-control-desc\" *ngIf=\"options.labelDescription!=null\" [attr.id]=\"options.name + '-description'\">\r\n {{options.labelDescription}}\r\n </div>\r\n\r\n <!-- requiredText-->\r\n <div class=\"bbsf-validation\" [dir]=\"textDir\" *ngIf=\"(textAreaFormControl.invalid && textAreaFormControl.touched)\"\r\n [attr.id]=\"errorMessageId\" role=\"alert\" aria-live=\"assertive\" [attr.aria-atomic]=\"true\">\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: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { kind: "directive", type: i6.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.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: i7.InlineSVGDirective, selector: "[inlineSVG]", inputs: ["inlineSVG", "resolveSVGUrl", "replaceContents", "prepend", "injectComponent", "cacheSVG", "setSVGAttributes", "removeSVGAttributes", "forceEvalStyles", "evalScripts", "fallbackImgUrl", "fallbackSVG", "onSVGLoaded"], outputs: ["onSVGInserted", "onSVGFailed"] }, { kind: "pipe", type: i4.KeyValuePipe, name: "keyvalue" }] }); }
325
533
  }
326
534
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TextAreaComponent, decorators: [{
327
535
  type: Component,
328
- 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 <div>\r\n <span class=\"language-text\">{{ selectedSpeechLanguageDisplayText }}</span>\r\n <select class=\"language-select\" [formControlName]=\"'Language_'+options.name\" (change)=\"onSpeechLanguageChange($event)\">\r\n <option *ngFor=\"let language of options.speechLanguages\" [value]=\"language.dialect\">\r\n {{language.name}}\r\n </option>\r\n </select>\r\n\r\n </div>\r\n\r\n\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" }]
536
+ 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\" [attr.aria-invalid]=\"textAreaFormControl.invalid && textAreaFormControl.touched\"\r\n [attr.aria-describedby]=\"ariaDescribedBy\" [attr.aria-label]=\"options.labelValue || options.placeholder\"\r\n 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 [attr.minlength]=\"options.minLength\" [(ngModel)]=\"options.value\" (keydown)=\"onKeyDown($event)\"\r\n [attr.maxlength]=\"options.maxLength\" role=\"textbox\" [attr.aria-multiline]=\"true\" #TextAreainput></textarea>\r\n <!--CopyToClipboard-->\r\n <button type=\"button\" class=\"copy-clipboard\" *ngIf=\"options.enableCopyToClipboard\"\r\n (click)=\"copyInputMessage(TextAreainput)\" (keydown)=\"onCopyKeydown($event, TextAreainput)\"\r\n [attr.aria-label]=\"'Copy text to clipboard'\" title=\"Copy text to clipboard\" tabindex=\"0\">\r\n <i class=\"fas fa-copy\" aria-hidden=\"true\"></i>\r\n </button>\r\n <div [ngClass]=\"{'expanded': isFocused}\" class=\"language-container {{options.extraClassMicLanguage}}\"\r\n *ngIf=\"options.enableSpeechRecognition\" role=\"region\" [attr.aria-label]=\"'Speech recognition controls'\">\r\n\r\n <!-- Start Speech Recognition Button -->\r\n <button type=\"button\" class=\"svg-icon svg-icon-5 speech-control-btn\"\r\n [inlineSVG]=\"options.iconMic || 'assets/bbsf-controls/images/mic.svg'\" (click)=\"startSpeechRecognition()\"\r\n (keydown)=\"onMicKeydown($event, 'start')\" *ngIf=\"options.enableSpeechRecognition && !isMicOn\"\r\n [attr.aria-label]=\"'Start speech recognition'\" title=\"Start speech recognition\" tabindex=\"0\"\r\n [attr.aria-pressed]=\"false\">\r\n </button>\r\n\r\n <!-- Stop Speech Recognition Button -->\r\n <button type=\"button\" class=\"svg-icon svg-icon-5 speech-control-btn\"\r\n [inlineSVG]=\"options.iconMicOff || 'assets/bbsf-controls/images/mic-off.svg'\"\r\n (click)=\"stopSpeechRecognition()\" (keydown)=\"onMicKeydown($event, 'stop')\"\r\n *ngIf=\"options.enableSpeechRecognition && isMicOn\" [attr.aria-label]=\"'Stop speech recognition'\"\r\n title=\"Stop speech recognition\" tabindex=\"0\" [attr.aria-pressed]=\"true\">\r\n </button>\r\n\r\n <div class=\"language-controls\">\r\n <span class=\"language-text\" [attr.id]=\"options.name + '-language-display'\"\r\n aria-live=\"polite\">{{ options.enableSpeechRecognition ? selectedSpeechLanguageDisplayText : '' }}</span>\r\n\r\n <label [for]=\"'Language_'+options.name\" class=\"sr-only\">\r\n Select speech recognition language\r\n </label>\r\n <select class=\"language-select\" [formControlName]=\"'Language_'+options.name\" [id]=\"'Language_'+options.name\"\r\n (change)=\"onSpeechLanguageChange($event)\" [attr.aria-describedby]=\"options.name + '-language-display'\">\r\n <option *ngFor=\"let language of options.speechLanguages\" [value]=\"language.dialect\">\r\n {{language.name}}\r\n </option>\r\n </select>\r\n </div>\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\" [attr.id]=\"wordCountId\"\r\n aria-live=\"polite\" [attr.aria-label]=\"'Word count: ' + wordCount + ' of ' + options.maxWordCount + ' words'\">\r\n {{wordCount}}/{{options.maxWordCount}} Words\r\n </div>\r\n\r\n <!-- CharsLimitMsg-->\r\n <div class=\"bbsf-character-count\" *ngIf=\"showCharsLimitMsg\" [attr.id]=\"characterCountId\" aria-live=\"polite\"\r\n [attr.aria-atomic]=\"true\"\r\n [ngClass]=\"{'badge-light-warning': charsLimitMsgClass === 'warning', 'badge-light-danger' : charsLimitMsgClass === 'danger' }\">\r\n {{maxLimitWarningMsg}}\r\n </div>\r\n\r\n <!-- LabelDescription-->\r\n <div class=\"bbsf-control-desc\" *ngIf=\"options.labelDescription!=null\" [attr.id]=\"options.name + '-description'\">\r\n {{options.labelDescription}}\r\n </div>\r\n\r\n <!-- requiredText-->\r\n <div class=\"bbsf-validation\" [dir]=\"textDir\" *ngIf=\"(textAreaFormControl.invalid && textAreaFormControl.touched)\"\r\n [attr.id]=\"errorMessageId\" role=\"alert\" aria-live=\"assertive\" [attr.aria-atomic]=\"true\">\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>" }]
329
537
  }], ctorParameters: () => [{ type: i1.ControlUtility }, { type: i2.ControlContainer, decorators: [{
330
538
  type: Optional
331
- }] }, { type: i2.FormGroupDirective }, { type: i3.UtilityService }, { type: i3.ControlValidationService }, { type: i4.GlobalSettings }, { type: i3.SpeechRecognitionService }, { type: i3.LanguageService }], propDecorators: { group: [{
539
+ }, {
540
+ type: SkipSelf
541
+ }] }, { type: i2.FormGroupDirective, decorators: [{
542
+ type: Optional
543
+ }] }, { type: i3.UtilityService }, { type: i3.ControlValidationService }, { type: i1.GlobalSettings }, { type: i3.SpeechRecognitionService }, { type: i3.LanguageService }], propDecorators: { group: [{
332
544
  type: Input
333
545
  }], options: [{
334
546
  type: Input
335
547
  }], onChange: [{
336
548
  type: Output
337
549
  }] } });
338
- //# 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, HostListener, ViewChild, ElementRef } 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  static controlContainerstatic = null;\r\n  constructor(\r\n    private controlUtility: ControlUtility,\r\n    @Optional() private controlContainer: ControlContainer,\r\n    public textAreaControlHost: FormGroupDirective,\r\n    private utilityService: UtilityService,\r\n    private controlValidationService: ControlValidationService,\r\n    private globalSettings: GlobalSettings,\r\n    private speechRecognitionService: SpeechRecognitionService,\r\n    private languageService: LanguageService\r\n  ) {\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\n  currentLanguage: String;\r\n  subscription: Subscription;\r\n  selectedSpeechLanguageDisplayText: string;\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 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) this.options.maxLength = this.globalSettings.maxLengthTextArea;\r\n\r\n    if (!this.options.viewType) 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      // Initialize language form control\r\n      const languageControlName = 'Language_' + this.options.name;\r\n      this.group.addControl(\r\n        languageControlName,\r\n        new FormControl(this.options.selectedSpeechLanguage || '')\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      } else {\r\n        this.setSpeechLanguage();\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    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  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(\r\n        originalValue,\r\n        this.options.patchFunction,\r\n        this.options.patchPath\r\n      );\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    if (this.textAreaFormControl.value == '') {\r\n      this.wordCountArray = 0;\r\n      this.wordCount = 0;\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({\r\n            errorMassage: `  Word count must be less then or equal  ${this.options.maxWordCount}`\r\n          });\r\n          this.textAreaFormControl.markAsTouched();\r\n          this.textAreaFormControl.invalid;\r\n        } else {\r\n          this.wordCount = this.wordCountArray;\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) this.charsLimitMsgClass = 'danger';\r\n        else this.charsLimitMsgClass = 'warning';\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\r\n        .replace('${max}', max.toString())\r\n        .replace('${current}', current.toString());\r\n    }\r\n    this.onChange.emit(this.textAreaFormControl.value);\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)\r\n        //check if there was previous validation error\r\n        this.showCharsLimitMsg = true;\r\n    } //onFocusOut\r\n    else this.showCharsLimitMsg = false;\r\n  }\r\n\r\n  //External Method\r\n  removeRequiredValidation = () => {\r\n    this.controlUtility.removeRequiredValidation(\r\n      this.textAreaFormControl,\r\n      this.validationRules,\r\n      this.options\r\n    );\r\n  };\r\n  //External Method\r\n  addRequiredValidation = () => {\r\n    this.controlUtility.addRequiredValidation(\r\n      this.textAreaFormControl,\r\n      this.validationRules,\r\n      this.options\r\n    );\r\n  };\r\n\r\n  //External Method\r\n  removeCustomValidation = (customValidation) => {\r\n    this.controlUtility.removeCustomValidation(\r\n      this.textAreaFormControl,\r\n      this.validationRules,\r\n      customValidation\r\n    );\r\n  };\r\n  //External Method\r\n  addCustomValidation = (customValidation) => {\r\n    this.controlUtility.addCustomValidation(\r\n      this.textAreaFormControl,\r\n      this.validationRules,\r\n      customValidation\r\n    );\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 = 'Language_' + this.options.name;\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      } else {\r\n        this.loadSelectedSpeechLanguage();\r\n        localStorage.setItem('speechLanguage', this.options.selectedSpeechLanguage);\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    this.selectedSpeechLanguageDisplayText = this.options.speechLanguages.find(\r\n      (l) => l.dialect == this.options.selectedSpeechLanguage\r\n    ).prefix;\r\n  }\r\n  loadSelectedSpeechLanguage() {\r\n    if (!this.options.selectedSpeechLanguage) {\r\n      if (\r\n        this.currentLanguage == 'en' &&\r\n        this.options.speechLanguages.some((language) => language.englishName === 'English')\r\n      ) {\r\n        this.options.selectedSpeechLanguage = this.options.speechLanguages.find(\r\n          (language) => language.englishName === 'English'\r\n        ).dialect;\r\n      } else if (\r\n        this.currentLanguage == 'ar' &&\r\n        this.options.speechLanguages.some((language) => language.englishName === 'Arabic')\r\n      ) {\r\n        this.options.selectedSpeechLanguage = this.options.speechLanguages.find(\r\n          (language) => language.englishName === 'Arabic'\r\n        ).dialect;\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(\r\n        this.utilityService.getResourceValue('BrowserNotSupportSpeechRecognition')\r\n      );\r\n      return;\r\n    }\r\n    //Disable Select Language\r\n    this.enableOrDisableLanguageSelect(false);\r\n    this.isMicOn = true;\r\n    this.subscription = this.speechRecognitionService\r\n      .startListening(this.options.selectedSpeechLanguage)\r\n      .subscribe({\r\n        next: (transcript: string) => {\r\n          if (transcript) {\r\n            if (this.options.value) {\r\n              this.options.value += ' ';\r\n              this.fireOnChange(this.options.value);\r\n            }\r\n            let charIndex = 0;\r\n            const interval = setInterval(() => {\r\n              this.options.value += transcript[charIndex];\r\n              this.fireOnChange(this.options.value);\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          //Enable Select Language\r\n          this.enableOrDisableLanguageSelect();\r\n          this.isMicOn = false;\r\n        }\r\n      });\r\n  }\r\n\r\n  stopSpeechRecognition(): void {\r\n    this.enableOrDisableLanguageSelect();\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  fireOnChange(text): void {\r\n    if (this.onChange) {\r\n      this.onChange.emit(text);\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    if (this.options.enableSpeechRecognition) {\r\n      this.stopSpeechRecognition();\r\n    }\r\n  }\r\n\r\n  onSpeechLanguageChange(event) {\r\n    let selectedLang_Dialect = event.target.value;\r\n    this.selectedSpeechLanguageDisplayText = this.options.speechLanguages.find(\r\n      (l) => l.dialect == selectedLang_Dialect\r\n    ).prefix;\r\n    this.options.selectedSpeechLanguage = selectedLang_Dialect;\r\n\r\n    const languageControlName = 'Language_' + this.options.name;\r\n    let select = this.group.get(languageControlName);\r\n    select.setValue(selectedLang_Dialect);\r\n\r\n    if (this.options.autoSaveSpeechLanguagetoLocalStorage) {\r\n      localStorage.setItem('speechLanguage', selectedLang_Dialect);\r\n    }\r\n  }\r\n  enableOrDisableLanguageSelect(isEnabled: boolean = true) {\r\n    const languageControlName = 'Language_' + this.options.name;\r\n    let select = this.group.get(languageControlName);\r\n    if (isEnabled) {\r\n      select.enable();\r\n    } else {\r\n      select.disable();\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        <div>\r\n          <span class=\"language-text\">{{ selectedSpeechLanguageDisplayText }}</span>\r\n          <select class=\"language-select\" [formControlName]=\"'Language_'+options.name\" (change)=\"onSpeechLanguageChange($event)\">\r\n            <option *ngFor=\"let language of options.speechLanguages\" [value]=\"language.dialect\">\r\n              {{language.name}}\r\n            </option>\r\n          </select>\r\n\r\n        </div>\r\n\r\n\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"]}
550
+ //# 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":"AAAA,OAAO,EAAE,SAAS,EAAqB,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAC9G,OAAO,EAAE,WAAW,EAAE,UAAU,EAAoE,MAAM,gBAAgB,CAAC;;;;;;;;;AAU3H,MAAM,OAAO,iBAAiB;IAC5B,YACU,cAA8B,EACN,gBAAkC,EAC/C,mBAAuC,EAClD,cAA8B,EAC9B,wBAAkD,EAClD,cAA8B,EAC9B,wBAAkD,EAClD,eAAgC;QAPhC,mBAAc,GAAd,cAAc,CAAgB;QACN,qBAAgB,GAAhB,gBAAgB,CAAkB;QAC/C,wBAAmB,GAAnB,mBAAmB,CAAoB;QAClD,mBAAc,GAAd,cAAc,CAAgB;QAC9B,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,mBAAc,GAAd,cAAc,CAAgB;QAC9B,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,oBAAe,GAAf,eAAe,CAAiB;QAMhC,aAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;QAGxC,cAAS,GAAW,CAAC,CAAC;QACtB,mBAAc,GAAW,CAAC,CAAC;QAC3B,oBAAe,GAAY,KAAK,CAAC;QACjC,qBAAgB,GAAY,KAAK,CAAC;QAClC,oBAAe,GAAG,EAAE,CAAC;QACrB,yBAAoB,GAAG,EAAE,CAAC;QAC1B,8CAA8C;QAC9C,sBAAiB,GAAW,CAAC,CAAC;QAC9B,sBAAiB,GAAY,KAAK,CAAC;QACnC,iCAA4B,GAAY,KAAK,CAAC;QAE9C,kBAAa,GAAW,CAAC,CAAC,CAAC,CAAC,2CAA2C;QACvE,uBAAkB,GAAW,EAAE,CAAC;QAChC,YAAO,GAAY,KAAK,CAAC;QAMzB,sCAAiC,GAAW,EAAE,CAAC;QAE/C,2BAA2B;QAC3B,oBAAe,GAAW,EAAE,CAAC;QAC7B,mBAAc,GAAW,EAAE,CAAC;QAC5B,qBAAgB,GAAW,EAAE,CAAC;QAC9B,gBAAW,GAAW,EAAE,CAAC;QA2GzB,eAAU,GAAG,GAAG,EAAE;YAChB,IAAI,CAAC,wBAAwB,CAAC,iBAAiB,EAAE,CAAC;QACpD,CAAC,CAAC;QA+NF,iBAAiB;QACjB,6BAAwB,GAAG,GAAG,EAAE;YAC9B,IAAI,CAAC,cAAc,CAAC,wBAAwB,CAC1C,IAAI,CAAC,mBAAmB,EACxB,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,OAAO,CACb,CAAC;QACJ,CAAC,CAAC;QACF,iBAAiB;QACjB,0BAAqB,GAAG,GAAG,EAAE;YAC3B,IAAI,CAAC,cAAc,CAAC,qBAAqB,CACvC,IAAI,CAAC,mBAAmB,EACxB,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,OAAO,CACb,CAAC;QACJ,CAAC,CAAC;QAEF,iBAAiB;QACjB,2BAAsB,GAAG,CAAC,gBAAgB,EAAE,EAAE;YAC5C,IAAI,CAAC,cAAc,CAAC,sBAAsB,CACxC,IAAI,CAAC,mBAAmB,EACxB,IAAI,CAAC,eAAe,EACpB,gBAAgB,CACjB,CAAC;QACJ,CAAC,CAAC;QACF,iBAAiB;QACjB,wBAAmB,GAAG,CAAC,gBAAgB,EAAE,EAAE;YACzC,IAAI,CAAC,cAAc,CAAC,mBAAmB,CACrC,IAAI,CAAC,mBAAmB,EACxB,IAAI,CAAC,eAAe,EACpB,gBAAgB,CACjB,CAAC;QACJ,CAAC,CAAC;QACF,iBAAiB;QACjB,YAAO,GAAG,GAAG,EAAE;YACb,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QACxD,CAAC,CAAC;QAhZA,IAAI,CAAC,eAAe,GAAG,YAAY,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC1D,CAAC;IAiCD,QAAQ;QACN,+BAA+B;QAC/B,IAAI,CAAC,cAAc,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,QAAQ,CAAC;QACnD,IAAI,CAAC,gBAAgB,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,aAAa,CAAC;QAC1D,IAAI,CAAC,WAAW,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,aAAa,CAAC;QACrD,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAE7B,2DAA2D;QAC3D,IAAI,IAAI,CAAC,OAAO,CAAC,uBAAuB,EAAE;YACxC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,iCAAiC,GAAG,EAAE,CAAC;SAC7C;aAAM;YACL,gDAAgD;YAChD,IAAI,CAAC,qBAAqB,EAAE,CAAC;SAC9B;QACD,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK;YAChD,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAElE,IAAI,IAAI,CAAC,OAAO,CAAC,cAAc;YAC7B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,cAAc,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;;YAC7D,IAAI,CAAC,OAAO,GAAG,YAAY,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;QAE7E,IAAI,CAAC,wBAAwB,CAAC,cAAc,GAAG,KAAK,CAAC;QAErD,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;QAC9D,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,wCAAwC;QAE3G,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS;YAAE,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC;QAE5F,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ;YAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC;QAEjF,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,EAAE;YAC9D,IAAI,CAAC,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QAExF,IAAI,IAAI,CAAC,OAAO,CAAC,uBAAuB,EAAE;YACxC,mCAAmC;YACnC,MAAM,mBAAmB,GAAG,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;YAC5D,IAAI,CAAC,KAAK,CAAC,UAAU,CACnB,mBAAmB,EACnB,IAAI,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,sBAAsB,IAAI,EAAE,CAAC,CAC3D,CAAC;YACF,8BAA8B;YAC9B,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,eAAe,EAAE;gBACjC,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;oBACvD,IAAI,CAAC,OAAO,CAAC,eAAe,GAAG,MAAM,CAAC;oBACtC,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBAC3B,CAAC,CAAC,CAAC;aACJ;iBAAM;gBACL,IAAI,CAAC,iBAAiB,EAAE,CAAC;aAC1B;SACF;QACD,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACtD,IAAI,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE;YAC5C,IAAI,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC;YAChD,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,WAAW,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;gBACvD,MAAM,UAAU,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC;gBACtC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;aACpD;SACF;QACD,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,CAAC,EAAE;YAC9B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC;SACzE;QACD,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,CAAC,EAAE;YAC9B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC;YAExE,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,qBAAqB;gBACrC,IAAI,CAAC,OAAO,CAAC,qBAAqB,GAAG,IAAI,CAAC,cAAc,CAAC,qBAAqB,CAAC;YAEjF,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,qBAAqB,CAAC;SAClF;QACD,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE;YAC3B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;SAChD;QACD,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAC7D,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QACvE,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE;YAC3B,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,CAAC;SACpC;QAED,gEAAgE;QAChE,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC5B,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;gBACpD,IAAI,CAAC,KAAK,CAAC,gBAAgB,EAAE,CAAC;gBAC9B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YAC/B,CAAC,CAAC,CAAC;SACJ;QAED,2EAA2E;QAC3E,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACxF,sDAAsD;YACtD,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE;gBACvC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;gBAC/B,IAAI,CAAC,4BAA4B,GAAG,KAAK,CAAC;gBAC1C,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC;gBAC7B,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;gBAC3B,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;gBACnB,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;aACzB;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,eAAe;QACb,IAAI,CAAC,cAAc,CAAC,sBAAsB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC3D,CAAC;IAMD,eAAe;QACb,IAAI,CAAC,cAAc,CAAC,eAAe,EAAE,CAAC;IACxC,CAAC;IAED,kBAAkB,CAAC,SAAS;QAC1B,IAAI,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE;YAC/C,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;SAC/B;QACD,OAAO,IAAI,CAAC,cAAc,CAAC,yBAAyB,CAAC,SAAS,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IAC5F,CAAC;IACD,YAAY,CAAC,IAAY;QACvB,OAAO,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;IAChD,CAAC;IAED,+BAA+B;IAC/B,qBAAqB;QACnB,MAAM,cAAc,GAAG,EAAE,CAAC;QAE1B,IAAI,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE;YACjC,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,cAAc,CAAC,CAAC;SACzD;QAED,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,GAAG,CAAC,EAAE;YACjC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACvC;QAED,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;SAC5C;QAED,IAAI,IAAI,CAAC,mBAAmB,EAAE,OAAO,IAAI,IAAI,CAAC,mBAAmB,EAAE,OAAO,EAAE;YAC1E,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SAC1C;QAED,wEAAwE;QACxE,IAAI,IAAI,CAAC,OAAO,CAAC,uBAAuB,IAAI,IAAI,CAAC,iCAAiC,EAAE;YAClF,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,mBAAmB,CAAC,CAAC;SAC9D;QAED,IAAI,CAAC,eAAe,GAAG,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAClD,CAAC;IAED,sBAAsB,CAAC,OAAe;QACpC,0DAA0D;QAC1D,MAAM,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACnD,YAAY,CAAC,YAAY,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QACjD,YAAY,CAAC,YAAY,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;QACjD,YAAY,CAAC,SAAS,GAAG,SAAS,CAAC;QACnC,YAAY,CAAC,WAAW,GAAG,OAAO,CAAC;QAEnC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;QAExC,4BAA4B;QAC5B,UAAU,CAAC,GAAG,EAAE;YACd,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;QAC1C,CAAC,EAAE,IAAI,CAAC,CAAC;IACX,CAAC;IAED,qBAAqB;QACnB,0EAA0E;QAC1E,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,iCAAiC,GAAG,EAAE,CAAC;QAE5C,uDAAuD;QACvD,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;YAChC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;SAC1B;QAED,mDAAmD;QACnD,MAAM,mBAAmB,GAAG,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;QAC5D,IAAI,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,mBAAmB,CAAC,EAAE;YACxC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAC;SAC/C;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;QACzF,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;QACnD,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,mBAAmB,CAAC,KAAK,EAAE;YAC1F,IAAI,CAAC,cAAc,CAAC,iBAAiB,CACnC,aAAa,EACb,IAAI,CAAC,OAAO,CAAC,aAAa,EAC1B,IAAI,CAAC,OAAO,CAAC,SAAS,CACvB,CAAC;SACH;IACH,CAAC;IAED,SAAS,CAAC,KAAoB;QAC5B,MAAM,QAAQ,GAAG,KAAK,CAAC,MAA6B,CAAC;QACrD,MAAM,YAAY,GAAG,QAAQ,CAAC,KAAK,IAAI,EAAE,CAAC;QAC1C,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC;QAEtB,kDAAkD;QAClD,MAAM,WAAW,GAAG,CAAC,WAAW,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;QAExI,wDAAwD;QACxD,IAAI,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,EAAE;YAClC,OAAO,CAAC,kCAAkC;SAC3C;QAED,qCAAqC;QACrC,IAAI,WAAW,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;YAC7B,+CAA+C;YAC/C,IAAI,GAAG,KAAK,WAAW,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,GAAG,CAAC,EAAE;gBACxD,OAAO,CAAC,mDAAmD;aAC5D;YACD,OAAO;SACR;QAED,yBAAyB;QACzB,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,GAAG,CAAC,EAAE;YACjC,MAAM,gBAAgB,GAAG,YAAY,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YAC3F,IAAI,gBAAgB,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,IAAI,GAAG,KAAK,WAAW,IAAI,GAAG,KAAK,QAAQ,EAAE;gBAC5F,yDAAyD;gBACzD,MAAM,cAAc,GAAG,QAAQ,CAAC,cAAc,CAAC;gBAC/C,MAAM,UAAU,GAAG,cAAc,GAAG,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,cAAc,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;gBAC9E,MAAM,SAAS,GAAG,cAAc,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;gBAE3F,iGAAiG;gBACjG,IAAI,GAAG,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;oBAC/D,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,OAAO;iBACR;aACF;SACF;QAED,8BAA8B;QAC9B,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,YAAY,CAAC,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;YAC3E,kFAAkF;YAClF,MAAM,YAAY,GAAG,QAAQ,CAAC,cAAc,KAAK,QAAQ,CAAC,YAAY,CAAC;YACvE,IAAI,CAAC,YAAY,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;gBAC/C,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,OAAO;aACR;SACF;IACH,CAAC;IAED,gBAAgB,CAAC,YAAY;QAC3B,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC;QACnD,6BAA6B;QAC7B,IAAI,CAAC,sBAAsB,CAAC,0BAA0B,CAAC,CAAC;IAC1D,CAAC;IAED,YAAY;QACV,IAAI,IAAI,CAAC,mBAAmB,CAAC,KAAK,IAAI,EAAE,EAAE;YACxC,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;YACxB,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;SACpB;aAAM;YACL,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC;YACvE,IAAI,IAAI,CAAC,cAAc,GAAG,CAAC,EAAE;gBAC3B,IAAI,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE;oBACnD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;oBAC3C,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC;wBACjC,YAAY,EAAE,4CAA4C,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE;qBACtF,CAAC,CAAC;oBACH,IAAI,CAAC,mBAAmB,CAAC,aAAa,EAAE,CAAC;oBACzC,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC;iBAClC;qBAAM;oBACL,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC;iBACtC;aACF;SACF;QACD,iCAAiC;QACjC,4FAA4F;QAC5F,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,aAAa,IAAI,CAAC,EAAE;YACrD,yCAAyC;YACzC,MAAM,YAAY,GAAG,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC;YACpD,IAAI,YAAY,IAAI,YAAY,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE;gBAClD,IAAI,CAAC,iBAAiB,GAAG,YAAY,CAAC,MAAM,CAAC;gBAC7C,IAAI,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,aAAa,EAAE;oBAC/C,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;oBAC9B,IAAI,CAAC,4BAA4B,GAAG,IAAI,CAAC;oBAEzC,IAAI,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS;wBAAE,IAAI,CAAC,kBAAkB,GAAG,QAAQ,CAAC;;wBACpF,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAC;oBAEzC,iEAAiE;oBACjE,IAAI,GAAG,GAAW,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;oBACzC,IAAI,OAAO,GAAW,IAAI,CAAC,iBAAiB,CAAC;oBAC7C,IAAI,GAAG,GAAW,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,uBAAuB,CAAC,CAAC;oBAEhF,IAAI,CAAC,kBAAkB,GAAG,GAAG;yBAC1B,OAAO,CAAC,QAAQ,EAAE,GAAG,CAAC,QAAQ,EAAE,CAAC;yBACjC,OAAO,CAAC,YAAY,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;iBAC9C;qBAAM;oBACL,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;oBAC/B,IAAI,CAAC,4BAA4B,GAAG,KAAK,CAAC;iBAC3C;aACF;iBAAM;gBACL,uCAAuC;gBACvC,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;gBAC3B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;gBAC/B,IAAI,CAAC,4BAA4B,GAAG,KAAK,CAAC;gBAC1C,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC;aAC9B;SACF;QACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;QAEnD,kCAAkC;QAClC,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAE7B,sDAAsD;QACtD,IAAI,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,kBAAkB,KAAK,QAAQ,EAAE;YAClE,IAAI,CAAC,sBAAsB,CAAC,4BAA4B,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC;SACpF;IACH,CAAC;IAED,OAAO,CAAC,OAAgB;QACtB,IAAI,CAAC,eAAe,GAAG,OAAO,CAAC;QAE/B,SAAS;QACT,IAAI,OAAO,EAAE;YACX,IAAI,IAAI,CAAC,4BAA4B;gBACnC,8CAA8C;gBAC9C,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;SACjC,CAAC,YAAY;;YACT,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACtC,CAAC;IAuCD,2BAA2B;IAC3B,iBAAiB;QACf,uDAAuD;QACvD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,uBAAuB,EAAE;YACzC,OAAO;SACR;QAED,MAAM,mBAAmB,GAAG,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;QAE5D,IAAI,IAAI,CAAC,OAAO,CAAC,oCAAoC,EAAE;YACrD,IAAI,aAAa,GAAG,YAAY,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;YAC3D,IAAI,aAAa,EAAE;gBACjB,IAAI,CAAC,OAAO,CAAC,sBAAsB,GAAG,aAAa,CAAC;aACrD;iBAAM;gBACL,IAAI,CAAC,0BAA0B,EAAE,CAAC;gBAClC,YAAY,CAAC,OAAO,CAAC,gBAAgB,EAAE,IAAI,CAAC,OAAO,CAAC,sBAAsB,CAAC,CAAC;aAC7E;SACF;aAAM;YACL,IAAI,CAAC,0BAA0B,EAAE,CAAC;SACnC;QACD,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,sBAAsB,CAAC,CAAC;QAElF,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,EAAE,IAAI,CACjD,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,sBAAsB,CACxD,CAAC;QACF,IAAI,CAAC,iCAAiC,GAAG,QAAQ,EAAE,MAAM,IAAI,EAAE,CAAC;IAClE,CAAC;IACD,0BAA0B;QACxB,uDAAuD;QACvD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,uBAAuB,EAAE;YACzC,OAAO;SACR;QAED,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,sBAAsB,EAAE;YACxC,IACE,IAAI,CAAC,eAAe,IAAI,IAAI;gBAC5B,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,WAAW,KAAK,SAAS,CAAC,EACnF;gBACA,IAAI,CAAC,OAAO,CAAC,sBAAsB,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CACrE,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,WAAW,KAAK,SAAS,CACjD,CAAC,OAAO,CAAC;aACX;iBAAM,IACL,IAAI,CAAC,eAAe,IAAI,IAAI;gBAC5B,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,WAAW,KAAK,QAAQ,CAAC,EAClF;gBACA,IAAI,CAAC,OAAO,CAAC,sBAAsB,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CACrE,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,WAAW,KAAK,QAAQ,CAChD,CAAC,OAAO,CAAC;aACX;iBAAM;gBACL,IAAI,CAAC,OAAO,CAAC,sBAAsB,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;aAC/E;SACF;IACH,CAAC;IACD,sBAAsB;QACpB,uDAAuD;QACvD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,uBAAuB,EAAE;YACzC,OAAO;SACR;QAED,IAAI,CAAC,IAAI,CAAC,wBAAwB,CAAC,WAAW,EAAE;YAC9C,MAAM,YAAY,GAAG,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,oCAAoC,CAAC,CAAC;YAChG,IAAI,CAAC,cAAc,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC;YACrD,IAAI,CAAC,sBAAsB,CAAC,YAAY,CAAC,CAAC;YAC1C,OAAO;SACR;QACD,yBAAyB;QACzB,IAAI,CAAC,6BAA6B,CAAC,KAAK,CAAC,CAAC;QAC1C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QAEpB,6BAA6B;QAC7B,IAAI,CAAC,sBAAsB,CAAC,wCAAwC,CAAC,CAAC;QACtE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,wBAAwB;aAC9C,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,sBAAsB,CAAC;aACnD,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,UAAkB,EAAE,EAAE;gBAC3B,IAAI,UAAU,EAAE;oBACd,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE;wBACtB,IAAI,CAAC,OAAO,CAAC,KAAK,IAAI,GAAG,CAAC;wBAC1B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;qBACvC;oBACD,IAAI,SAAS,GAAG,CAAC,CAAC;oBAClB,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE;wBAChC,IAAI,CAAC,OAAO,CAAC,KAAK,IAAI,UAAU,CAAC,SAAS,CAAC,CAAC;wBAC5C,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;wBACtC,SAAS,EAAE,CAAC;wBACZ,IAAI,SAAS,KAAK,UAAU,CAAC,MAAM,EAAE;4BACnC,aAAa,CAAC,QAAQ,CAAC,CAAC;yBACzB;oBACH,CAAC,EAAE,EAAE,CAAC,CAAC;iBACR;YACH,CAAC;YACD,KAAK,EAAE,CAAC,KAAU,EAAE,EAAE;gBACpB,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBACrB,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC/B,CAAC;YACD,QAAQ,EAAE,GAAG,EAAE;gBACb,wBAAwB;gBACxB,IAAI,CAAC,6BAA6B,EAAE,CAAC;gBACrC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACrB,IAAI,CAAC,sBAAsB,CAAC,6BAA6B,CAAC,CAAC;YAC7D,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAED,qBAAqB;QACnB,uDAAuD;QACvD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,uBAAuB,EAAE;YACzC,OAAO;SACR;QAED,IAAI,CAAC,6BAA6B,EAAE,CAAC;QACrC,IAAI,CAAC,IAAI,CAAC,wBAAwB,CAAC,WAAW,EAAE;YAC9C,OAAO;SACR;QACD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,wBAAwB,CAAC,aAAa,EAAE,CAAC;QAC9C,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;SACjC;QAED,6BAA6B;QAC7B,IAAI,CAAC,sBAAsB,CAAC,6BAA6B,CAAC,CAAC;IAC7D,CAAC;IACD,YAAY,CAAC,IAAI;QACf,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC1B;IACH,CAAC;IACD,WAAW;QACT,gCAAgC;QAChC,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;SACjC;QACD,IAAI,IAAI,CAAC,wBAAwB,EAAE;YACjC,IAAI,CAAC,wBAAwB,CAAC,WAAW,EAAE,CAAC;SAC7C;QAED,yDAAyD;QACzD,IAAI,IAAI,CAAC,OAAO,CAAC,uBAAuB,EAAE;YACxC,IAAI,CAAC,qBAAqB,EAAE,CAAC;SAC9B;IACH,CAAC;IAED,yDAAyD;IACzD,YAAY,CAAC,KAAoB,EAAE,MAAwB;QACzD,uDAAuD;QACvD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,uBAAuB,EAAE;YACzC,OAAO;SACR;QAED,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,IAAI,KAAK,CAAC,GAAG,KAAK,GAAG,EAAE;YAC9C,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,MAAM,KAAK,OAAO,EAAE;gBACtB,IAAI,CAAC,sBAAsB,EAAE,CAAC;aAC/B;iBAAM;gBACL,IAAI,CAAC,qBAAqB,EAAE,CAAC;aAC9B;SACF;IACH,CAAC;IAED,aAAa,CAAC,KAAoB,EAAE,YAAiC;QACnE,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,IAAI,KAAK,CAAC,GAAG,KAAK,GAAG,EAAE;YAC9C,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC;SACrC;IACH,CAAC;IAED,sBAAsB,CAAC,KAAY;QACjC,uDAAuD;QACvD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,uBAAuB,EAAE;YACzC,OAAO;SACR;QAED,IAAI,oBAAoB,GAAI,KAAK,CAAC,MAA4B,CAAC,KAAK,CAAC;QACrE,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,EAAE,IAAI,CACjD,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,IAAI,oBAAoB,CACzC,CAAC;QACF,IAAI,CAAC,iCAAiC,GAAG,QAAQ,EAAE,MAAM,IAAI,EAAE,CAAC;QAChE,IAAI,CAAC,OAAO,CAAC,sBAAsB,GAAG,oBAAoB,CAAC;QAE3D,MAAM,mBAAmB,GAAG,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;QAC5D,IAAI,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;QACjD,MAAM,CAAC,QAAQ,CAAC,oBAAoB,CAAC,CAAC;QAEtC,IAAI,IAAI,CAAC,OAAO,CAAC,oCAAoC,EAAE;YACrD,YAAY,CAAC,OAAO,CAAC,gBAAgB,EAAE,oBAAoB,CAAC,CAAC;SAC9D;QAED,6CAA6C;QAC7C,IAAI,CAAC,sBAAsB,CAAC,0CAA0C,QAAQ,EAAE,IAAI,IAAI,oBAAoB,EAAE,CAAC,CAAC;IAClH,CAAC;IACD,6BAA6B,CAAC,YAAqB,IAAI;QACrD,uDAAuD;QACvD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,uBAAuB,EAAE;YACzC,OAAO;SACR;QAED,MAAM,mBAAmB,GAAG,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;QAC5D,IAAI,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;QACjD,IAAI,SAAS,EAAE;YACb,MAAM,CAAC,MAAM,EAAE,CAAC;SACjB;aAAM;YACL,MAAM,CAAC,OAAO,EAAE,CAAC;SAClB;IACH,CAAC;+GAxmBU,iBAAiB;mGAAjB,iBAAiB,wICX9B,yhMA+FQ;;4FDpFK,iBAAiB;kBAJ7B,SAAS;+BACE,eAAe;;0BAMtB,QAAQ;;0BAAI,QAAQ;;0BACpB,QAAQ;+MASF,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACI,QAAQ;sBAAjB,MAAM","sourcesContent":["import { Component, OnInit, OnDestroy, Input, Optional, Output, EventEmitter, SkipSelf } 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 { Subscription } from 'rxjs';\r\nimport { ControlUtility, GlobalSettings } from '../../Shared/services';\r\nimport { TextAreaOptions } from '../../Shared/Models';\r\n\r\n@Component({\r\n  selector: 'BBSF-TextArea',\r\n  templateUrl: './TextArea.component.html'\r\n})\r\nexport class TextAreaComponent implements OnInit, OnDestroy {\r\n  constructor(\r\n    private controlUtility: ControlUtility,\r\n    @Optional() @SkipSelf() private controlContainer: ControlContainer,\r\n    @Optional() public textAreaControlHost: FormGroupDirective,\r\n    private utilityService: UtilityService,\r\n    private controlValidationService: ControlValidationService,\r\n    private globalSettings: GlobalSettings,\r\n    private speechRecognitionService: SpeechRecognitionService,\r\n    private languageService: LanguageService\r\n  ) {\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\n  currentLanguage: String;\r\n  subscription: Subscription;\r\n  valueChangesSubscription: Subscription;\r\n  selectedSpeechLanguageDisplayText: string = '';\r\n\r\n  // Accessibility properties\r\n  ariaDescribedBy: string = '';\r\n  errorMessageId: string = '';\r\n  characterCountId: string = '';\r\n  wordCountId: string = '';\r\n\r\n  ngOnInit() {\r\n    // Initialize accessibility IDs\r\n    this.errorMessageId = `${this.options.name}-error`;\r\n    this.characterCountId = `${this.options.name}-char-count`;\r\n    this.wordCountId = `${this.options.name}-word-count`;\r\n    this.updateAriaDescribedBy();\r\n\r\n    // Initialize speech recognition properties only if enabled\r\n    if (this.options.enableSpeechRecognition) {\r\n      this.isMicOn = false;\r\n      this.selectedSpeechLanguageDisplayText = '';\r\n    } else {\r\n      // Reset speech-related properties when disabled\r\n      this.resetSpeechProperties();\r\n    }\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 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) this.options.maxLength = this.globalSettings.maxLengthTextArea;\r\n\r\n    if (!this.options.viewType) 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      // Initialize language form control\r\n      const languageControlName = 'Language_' + this.options.name;\r\n      this.group.addControl(\r\n        languageControlName,\r\n        new FormControl(this.options.selectedSpeechLanguage || '')\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      } else {\r\n        this.setSpeechLanguage();\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    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    // Only subscribe to ngSubmit if FormGroupDirective is available\r\n    if (this.textAreaControlHost) {\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    // Subscribe to value changes to ensure warning messages are properly reset\r\n    this.valueChangesSubscription = this.textAreaFormControl.valueChanges.subscribe((value) => {\r\n      // Reset warning message when control is empty or null\r\n      if (!value || value.trim().length === 0) {\r\n        this.showCharsLimitMsg = false;\r\n        this.hasCharsLimitValidationError = false;\r\n        this.maxLimitWarningMsg = '';\r\n        this.currentCharsCount = 0;\r\n        this.wordCount = 0;\r\n        this.wordCountArray = 0;\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  // Accessibility helper methods\r\n  updateAriaDescribedBy() {\r\n    const describedByIds = [];\r\n\r\n    if (this.options.labelDescription) {\r\n      describedByIds.push(`${this.options.name}-description`);\r\n    }\r\n\r\n    if (this.options.maxWordCount > 0) {\r\n      describedByIds.push(this.wordCountId);\r\n    }\r\n\r\n    if (this.showCharsLimitMsg) {\r\n      describedByIds.push(this.characterCountId);\r\n    }\r\n\r\n    if (this.textAreaFormControl?.invalid && this.textAreaFormControl?.touched) {\r\n      describedByIds.push(this.errorMessageId);\r\n    }\r\n\r\n    // Only add speech-related descriptions if speech recognition is enabled\r\n    if (this.options.enableSpeechRecognition && this.selectedSpeechLanguageDisplayText) {\r\n      describedByIds.push(`${this.options.name}-language-display`);\r\n    }\r\n\r\n    this.ariaDescribedBy = describedByIds.join(' ');\r\n  }\r\n\r\n  announceToScreenReader(message: string) {\r\n    // Create temporary element for screen reader announcement\r\n    const announcement = document.createElement('div');\r\n    announcement.setAttribute('aria-live', 'polite');\r\n    announcement.setAttribute('aria-atomic', 'true');\r\n    announcement.className = 'sr-only';\r\n    announcement.textContent = message;\r\n\r\n    document.body.appendChild(announcement);\r\n\r\n    // Remove after announcement\r\n    setTimeout(() => {\r\n      document.body.removeChild(announcement);\r\n    }, 1000);\r\n  }\r\n\r\n  resetSpeechProperties() {\r\n    // Reset all speech-related properties when speech recognition is disabled\r\n    this.isMicOn = false;\r\n    this.selectedSpeechLanguageDisplayText = '';\r\n\r\n    // Clean up any active speech recognition subscriptions\r\n    if (this.subscription) {\r\n      this.subscription.unsubscribe();\r\n      this.subscription = null;\r\n    }\r\n\r\n    // Remove speech language form control if it exists\r\n    const languageControlName = 'Language_' + this.options.name;\r\n    if (this.group?.get(languageControlName)) {\r\n      this.group.removeControl(languageControlName);\r\n    }\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(\r\n        originalValue,\r\n        this.options.patchFunction,\r\n        this.options.patchPath\r\n      );\r\n    }\r\n  }\r\n\r\n  onKeyDown(event: KeyboardEvent) {\r\n    const textarea = event.target as HTMLTextAreaElement;\r\n    const currentValue = textarea.value || '';\r\n    const key = event.key;\r\n\r\n    // Allow navigation keys (arrows, home, end, etc.)\r\n    const allowedKeys = ['Backspace', 'Delete', 'Tab', 'Escape', 'Enter', 'Home', 'End', 'ArrowLeft', 'ArrowRight', 'ArrowUp', 'ArrowDown'];\r\n\r\n    // Allow Ctrl/Cmd + keys (copy, paste, select all, etc.)\r\n    if (event.ctrlKey || event.metaKey) {\r\n      return; // Allow all Ctrl/Cmd combinations\r\n    }\r\n\r\n    // If it's a navigation key, allow it\r\n    if (allowedKeys.includes(key)) {\r\n      // Special handling for word count on Backspace\r\n      if (key === 'Backspace' && this.options.maxWordCount > 0) {\r\n        return; // Always allow backspace for word count correction\r\n      }\r\n      return;\r\n    }\r\n\r\n    // Check word count limit\r\n    if (this.options.maxWordCount > 0) {\r\n      const currentWordCount = currentValue.trim() ? currentValue.trim().split(/\\s+/).length : 0;\r\n      if (currentWordCount >= this.options.maxWordCount && key !== 'Backspace' && key !== 'Delete') {\r\n        // Check if adding this character would create a new word\r\n        const cursorPosition = textarea.selectionStart;\r\n        const charBefore = cursorPosition > 0 ? currentValue[cursorPosition - 1] : '';\r\n        const charAfter = cursorPosition < currentValue.length ? currentValue[cursorPosition] : '';\r\n\r\n        // If we're typing a space or the character before/after is a space, this might create a new word\r\n        if (key === ' ' || (/\\s/.test(charBefore) && !(/\\s/.test(key)))) {\r\n          event.preventDefault();\r\n          return;\r\n        }\r\n      }\r\n    }\r\n\r\n    // Check character count limit\r\n    if (this.options.maxLength && currentValue.length >= this.options.maxLength) {\r\n      // Only allow if we have selected text (which will be replaced) or navigation keys\r\n      const hasSelection = textarea.selectionStart !== textarea.selectionEnd;\r\n      if (!hasSelection && !allowedKeys.includes(key)) {\r\n        event.preventDefault();\r\n        return;\r\n      }\r\n    }\r\n  }\r\n\r\n  copyInputMessage(inputElement) {\r\n    this.controlUtility.CopyInputMessage(inputElement);\r\n    // Announce to screen readers\r\n    this.announceToScreenReader('Text copied to clipboard');\r\n  }\r\n\r\n  onTextChange() {\r\n    if (this.textAreaFormControl.value == '') {\r\n      this.wordCountArray = 0;\r\n      this.wordCount = 0;\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({\r\n            errorMessage: `Word count must be less than or equal to ${this.options.maxWordCount}`\r\n          });\r\n          this.textAreaFormControl.markAsTouched();\r\n          this.textAreaFormControl.invalid;\r\n        } else {\r\n          this.wordCount = this.wordCountArray;\r\n        }\r\n      }\r\n    }\r\n    //Check for maxlength limit count\r\n    //MaxLength should be greater than or equals chars limit so that minCharsLimit would be >= 0\r\n    if (this.options.maxLength && this.minCharsLimit >= 0) {\r\n      // Check if value exists and is not empty\r\n      const controlValue = this.textAreaFormControl.value;\r\n      if (controlValue && controlValue.trim().length > 0) {\r\n        this.currentCharsCount = controlValue.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) this.charsLimitMsgClass = 'danger';\r\n          else this.charsLimitMsgClass = 'warning';\r\n\r\n          // Only generate warning message when we actually want to show it\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          this.maxLimitWarningMsg = msg\r\n            .replace('${max}', max.toString())\r\n            .replace('${current}', current.toString());\r\n        } else {\r\n          this.showCharsLimitMsg = false;\r\n          this.hasCharsLimitValidationError = false;\r\n        }\r\n      } else {\r\n        // Reset everything when value is empty\r\n        this.currentCharsCount = 0;\r\n        this.showCharsLimitMsg = false;\r\n        this.hasCharsLimitValidationError = false;\r\n        this.maxLimitWarningMsg = '';\r\n      }\r\n    }\r\n    this.onChange.emit(this.textAreaFormControl.value);\r\n\r\n    // Update accessibility attributes\r\n    this.updateAriaDescribedBy();\r\n\r\n    // Announce character limit warnings to screen readers\r\n    if (this.showCharsLimitMsg && this.charsLimitMsgClass === 'danger') {\r\n      this.announceToScreenReader(`Character limit reached: ${this.maxLimitWarningMsg}`);\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)\r\n        //check if there was previous validation error\r\n        this.showCharsLimitMsg = true;\r\n    } //onFocusOut\r\n    else this.showCharsLimitMsg = false;\r\n  }\r\n\r\n  //External Method\r\n  removeRequiredValidation = () => {\r\n    this.controlUtility.removeRequiredValidation(\r\n      this.textAreaFormControl,\r\n      this.validationRules,\r\n      this.options\r\n    );\r\n  };\r\n  //External Method\r\n  addRequiredValidation = () => {\r\n    this.controlUtility.addRequiredValidation(\r\n      this.textAreaFormControl,\r\n      this.validationRules,\r\n      this.options\r\n    );\r\n  };\r\n\r\n  //External Method\r\n  removeCustomValidation = (customValidation) => {\r\n    this.controlUtility.removeCustomValidation(\r\n      this.textAreaFormControl,\r\n      this.validationRules,\r\n      customValidation\r\n    );\r\n  };\r\n  //External Method\r\n  addCustomValidation = (customValidation) => {\r\n    this.controlUtility.addCustomValidation(\r\n      this.textAreaFormControl,\r\n      this.validationRules,\r\n      customValidation\r\n    );\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    // Guard: Only execute if speech recognition is enabled\r\n    if (!this.options.enableSpeechRecognition) {\r\n      return;\r\n    }\r\n\r\n    const languageControlName = 'Language_' + this.options.name;\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      } else {\r\n        this.loadSelectedSpeechLanguage();\r\n        localStorage.setItem('speechLanguage', this.options.selectedSpeechLanguage);\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    const language = this.options.speechLanguages?.find(\r\n      (l) => l.dialect == this.options.selectedSpeechLanguage\r\n    );\r\n    this.selectedSpeechLanguageDisplayText = language?.prefix || '';\r\n  }\r\n  loadSelectedSpeechLanguage() {\r\n    // Guard: Only execute if speech recognition is enabled\r\n    if (!this.options.enableSpeechRecognition) {\r\n      return;\r\n    }\r\n\r\n    if (!this.options.selectedSpeechLanguage) {\r\n      if (\r\n        this.currentLanguage == 'en' &&\r\n        this.options.speechLanguages.some((language) => language.englishName === 'English')\r\n      ) {\r\n        this.options.selectedSpeechLanguage = this.options.speechLanguages.find(\r\n          (language) => language.englishName === 'English'\r\n        ).dialect;\r\n      } else if (\r\n        this.currentLanguage == 'ar' &&\r\n        this.options.speechLanguages.some((language) => language.englishName === 'Arabic')\r\n      ) {\r\n        this.options.selectedSpeechLanguage = this.options.speechLanguages.find(\r\n          (language) => language.englishName === 'Arabic'\r\n        ).dialect;\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    // Guard: Only execute if speech recognition is enabled\r\n    if (!this.options.enableSpeechRecognition) {\r\n      return;\r\n    }\r\n\r\n    if (!this.speechRecognitionService.isSupported) {\r\n      const errorMessage = this.utilityService.getResourceValue('BrowserNotSupportSpeechRecognition');\r\n      this.utilityService.notifyErrorMessage(errorMessage);\r\n      this.announceToScreenReader(errorMessage);\r\n      return;\r\n    }\r\n    //Disable Select Language\r\n    this.enableOrDisableLanguageSelect(false);\r\n    this.isMicOn = true;\r\n\r\n    // Announce to screen readers\r\n    this.announceToScreenReader('Speech recognition started. Speak now.');\r\n    this.subscription = this.speechRecognitionService\r\n      .startListening(this.options.selectedSpeechLanguage)\r\n      .subscribe({\r\n        next: (transcript: string) => {\r\n          if (transcript) {\r\n            if (this.options.value) {\r\n              this.options.value += ' ';\r\n              this.fireOnChange(this.options.value);\r\n            }\r\n            let charIndex = 0;\r\n            const interval = setInterval(() => {\r\n              this.options.value += transcript[charIndex];\r\n              this.fireOnChange(this.options.value);\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          //Enable Select Language\r\n          this.enableOrDisableLanguageSelect();\r\n          this.isMicOn = false;\r\n          this.announceToScreenReader('Speech recognition stopped.');\r\n        }\r\n      });\r\n  }\r\n\r\n  stopSpeechRecognition(): void {\r\n    // Guard: Only execute if speech recognition is enabled\r\n    if (!this.options.enableSpeechRecognition) {\r\n      return;\r\n    }\r\n\r\n    this.enableOrDisableLanguageSelect();\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    // Announce to screen readers\r\n    this.announceToScreenReader('Speech recognition stopped.');\r\n  }\r\n  fireOnChange(text): void {\r\n    if (this.onChange) {\r\n      this.onChange.emit(text);\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    // Always clean up subscriptions\r\n    if (this.subscription) {\r\n      this.subscription.unsubscribe();\r\n    }\r\n    if (this.valueChangesSubscription) {\r\n      this.valueChangesSubscription.unsubscribe();\r\n    }\r\n\r\n    // Only call speech recognition cleanup if it was enabled\r\n    if (this.options.enableSpeechRecognition) {\r\n      this.stopSpeechRecognition();\r\n    }\r\n  }\r\n\r\n  // Keyboard accessibility for speech recognition controls\r\n  onMicKeydown(event: KeyboardEvent, action: 'start' | 'stop'): void {\r\n    // Guard: Only execute if speech recognition is enabled\r\n    if (!this.options.enableSpeechRecognition) {\r\n      return;\r\n    }\r\n\r\n    if (event.key === 'Enter' || event.key === ' ') {\r\n      event.preventDefault();\r\n      if (action === 'start') {\r\n        this.startSpeechRecognition();\r\n      } else {\r\n        this.stopSpeechRecognition();\r\n      }\r\n    }\r\n  }\r\n\r\n  onCopyKeydown(event: KeyboardEvent, inputElement: HTMLTextAreaElement): void {\r\n    if (event.key === 'Enter' || event.key === ' ') {\r\n      event.preventDefault();\r\n      this.copyInputMessage(inputElement);\r\n    }\r\n  }\r\n\r\n  onSpeechLanguageChange(event: Event) {\r\n    // Guard: Only execute if speech recognition is enabled\r\n    if (!this.options.enableSpeechRecognition) {\r\n      return;\r\n    }\r\n\r\n    let selectedLang_Dialect = (event.target as HTMLSelectElement).value;\r\n    const language = this.options.speechLanguages?.find(\r\n      (l) => l.dialect == selectedLang_Dialect\r\n    );\r\n    this.selectedSpeechLanguageDisplayText = language?.prefix || '';\r\n    this.options.selectedSpeechLanguage = selectedLang_Dialect;\r\n\r\n    const languageControlName = 'Language_' + this.options.name;\r\n    let select = this.group.get(languageControlName);\r\n    select.setValue(selectedLang_Dialect);\r\n\r\n    if (this.options.autoSaveSpeechLanguagetoLocalStorage) {\r\n      localStorage.setItem('speechLanguage', selectedLang_Dialect);\r\n    }\r\n\r\n    // Announce language change to screen readers\r\n    this.announceToScreenReader(`Speech recognition language changed to ${language?.name || selectedLang_Dialect}`);\r\n  }\r\n  enableOrDisableLanguageSelect(isEnabled: boolean = true) {\r\n    // Guard: Only execute if speech recognition is enabled\r\n    if (!this.options.enableSpeechRecognition) {\r\n      return;\r\n    }\r\n\r\n    const languageControlName = 'Language_' + this.options.name;\r\n    let select = this.group.get(languageControlName);\r\n    if (isEnabled) {\r\n      select.enable();\r\n    } else {\r\n      select.disable();\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\" [attr.aria-invalid]=\"textAreaFormControl.invalid && textAreaFormControl.touched\"\r\n        [attr.aria-describedby]=\"ariaDescribedBy\" [attr.aria-label]=\"options.labelValue || options.placeholder\"\r\n        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        [attr.minlength]=\"options.minLength\" [(ngModel)]=\"options.value\" (keydown)=\"onKeyDown($event)\"\r\n        [attr.maxlength]=\"options.maxLength\" role=\"textbox\" [attr.aria-multiline]=\"true\" #TextAreainput></textarea>\r\n      <!--CopyToClipboard-->\r\n      <button type=\"button\" class=\"copy-clipboard\" *ngIf=\"options.enableCopyToClipboard\"\r\n        (click)=\"copyInputMessage(TextAreainput)\" (keydown)=\"onCopyKeydown($event, TextAreainput)\"\r\n        [attr.aria-label]=\"'Copy text to clipboard'\" title=\"Copy text to clipboard\" tabindex=\"0\">\r\n        <i class=\"fas fa-copy\" aria-hidden=\"true\"></i>\r\n      </button>\r\n      <div [ngClass]=\"{'expanded': isFocused}\" class=\"language-container {{options.extraClassMicLanguage}}\"\r\n        *ngIf=\"options.enableSpeechRecognition\" role=\"region\" [attr.aria-label]=\"'Speech recognition controls'\">\r\n\r\n        <!-- Start Speech Recognition Button -->\r\n        <button type=\"button\" class=\"svg-icon svg-icon-5 speech-control-btn\"\r\n          [inlineSVG]=\"options.iconMic || 'assets/bbsf-controls/images/mic.svg'\" (click)=\"startSpeechRecognition()\"\r\n          (keydown)=\"onMicKeydown($event, 'start')\" *ngIf=\"options.enableSpeechRecognition && !isMicOn\"\r\n          [attr.aria-label]=\"'Start speech recognition'\" title=\"Start speech recognition\" tabindex=\"0\"\r\n          [attr.aria-pressed]=\"false\">\r\n        </button>\r\n\r\n        <!-- Stop Speech Recognition Button -->\r\n        <button type=\"button\" class=\"svg-icon svg-icon-5 speech-control-btn\"\r\n          [inlineSVG]=\"options.iconMicOff || 'assets/bbsf-controls/images/mic-off.svg'\"\r\n          (click)=\"stopSpeechRecognition()\" (keydown)=\"onMicKeydown($event, 'stop')\"\r\n          *ngIf=\"options.enableSpeechRecognition && isMicOn\" [attr.aria-label]=\"'Stop speech recognition'\"\r\n          title=\"Stop speech recognition\" tabindex=\"0\" [attr.aria-pressed]=\"true\">\r\n        </button>\r\n\r\n        <div class=\"language-controls\">\r\n          <span class=\"language-text\" [attr.id]=\"options.name + '-language-display'\"\r\n            aria-live=\"polite\">{{ options.enableSpeechRecognition ? selectedSpeechLanguageDisplayText : '' }}</span>\r\n\r\n          <label [for]=\"'Language_'+options.name\" class=\"sr-only\">\r\n            Select speech recognition language\r\n          </label>\r\n          <select class=\"language-select\" [formControlName]=\"'Language_'+options.name\" [id]=\"'Language_'+options.name\"\r\n            (change)=\"onSpeechLanguageChange($event)\" [attr.aria-describedby]=\"options.name + '-language-display'\">\r\n            <option *ngFor=\"let language of options.speechLanguages\" [value]=\"language.dialect\">\r\n              {{language.name}}\r\n            </option>\r\n          </select>\r\n        </div>\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\" [attr.id]=\"wordCountId\"\r\n        aria-live=\"polite\" [attr.aria-label]=\"'Word count: ' + wordCount + ' of ' + options.maxWordCount + ' words'\">\r\n        {{wordCount}}/{{options.maxWordCount}} Words\r\n      </div>\r\n\r\n      <!-- CharsLimitMsg-->\r\n      <div class=\"bbsf-character-count\" *ngIf=\"showCharsLimitMsg\" [attr.id]=\"characterCountId\" aria-live=\"polite\"\r\n        [attr.aria-atomic]=\"true\"\r\n        [ngClass]=\"{'badge-light-warning': charsLimitMsgClass === 'warning', 'badge-light-danger' : charsLimitMsgClass === 'danger' }\">\r\n        {{maxLimitWarningMsg}}\r\n      </div>\r\n\r\n      <!-- LabelDescription-->\r\n      <div class=\"bbsf-control-desc\" *ngIf=\"options.labelDescription!=null\" [attr.id]=\"options.name + '-description'\">\r\n        {{options.labelDescription}}\r\n      </div>\r\n\r\n      <!-- requiredText-->\r\n      <div class=\"bbsf-validation\" [dir]=\"textDir\" *ngIf=\"(textAreaFormControl.invalid && textAreaFormControl.touched)\"\r\n        [attr.id]=\"errorMessageId\" role=\"alert\" aria-live=\"assertive\" [attr.aria-atomic]=\"true\">\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>"]}