@testgorilla/tgo-ui 3.10.11 → 3.10.12

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.
@@ -383,7 +383,7 @@ export class FieldComponent {
383
383
  this.value = '0';
384
384
  }
385
385
  else {
386
- this.onChange(this.type === 'number' ? +this.value : this.value);
386
+ this.onChange(this.type === 'number' && this.value !== '' ? +this.value : this.value);
387
387
  }
388
388
  }
389
389
  writeValue(value) {
@@ -541,4 +541,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
541
541
  type: ViewChild,
542
542
  args: ['autosize']
543
543
  }] } });
544
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/field/field.component.ts","../../../../../projects/tgo-canopy-ui/components/field/field.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-underscore-dangle */\r\nimport { FocusMonitor } from '@angular/cdk/a11y';\r\nimport {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  computed,\r\n  DestroyRef,\r\n  DoCheck,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Inject,\r\n  input,\r\n  Input,\r\n  NgZone,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  Self,\r\n  signal,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\r\nimport { MatIconRegistry } from '@angular/material/icon';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\nimport { CdkTextareaAutosize } from '@angular/cdk/text-field';\r\nimport { FieldType } from '../../components/field/field.model';\r\nimport { ApplicationTheme } from '../../models/application-theme.model';\r\nimport { BadgeVariant } from '../badge/badge.model';\r\nimport { IconName } from '../icon/icon.model';\r\n\r\n/**\r\n * A global counter used to generate unique field IDs.\r\n * This variable is incremented each time a new field ID is needed.\r\n *\r\n * @remarks\r\n * This is primarily used to ensure that each field component\r\n * has a unique identifier within the application / useful for their Aria Labels.\r\n */\r\nexport let fieldID = 0;\r\n\r\n@Component({\r\n  selector: 'ui-field',\r\n  templateUrl: './field.component.html',\r\n  styleUrls: ['./field.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class FieldComponent implements OnInit, ControlValueAccessor, DoCheck, AfterViewInit {\r\n  @HostBinding() class = 'ui-field';\r\n\r\n  /**\r\n   * Indicator of the autocomplete width\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @HostBinding('class.full-width')\r\n  @Input()\r\n  fullWidth = true;\r\n\r\n  /**\r\n   * Form field label\r\n   *\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() label? = '';\r\n\r\n  /**\r\n   * Form field label from html\r\n   *\r\n   * @memberof FieldComponent\r\n   */\r\n  labelHtml = input(null, {\r\n    transform: (value: string) => this.domSanitizer.bypassSecurityTrustHtml(value)\r\n  });\r\n\r\n  /**\r\n   * Icon to display alongside the label\r\n   *\r\n   * @type {IconName}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() labelIcon?: IconName;\r\n\r\n  /**\r\n   * Input name attribute\r\n   *\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() fieldName?: string;\r\n\r\n  /**\r\n   * Input placeholder\r\n   *\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() placeholder? = '';\r\n\r\n  /**\r\n   * Input id\r\n   *\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  id = input(`field-${fieldID++}`);\r\n\r\n  /**\r\n   * Input value\r\n   *\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() value = '';\r\n\r\n  /**\r\n   * Variant of badge to use\r\n   *\r\n   * @type {BadgeVariant}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() badgeVariant?: BadgeVariant | undefined;\r\n\r\n  _errors: SafeHtml[];\r\n  /**\r\n   * Input field errors\r\n   *\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() set errors(errors: string[]) {\r\n    this._errors = errors?.filter(Boolean).map(error => this.domSanitizer.bypassSecurityTrustHtml(error));\r\n    this.errorsLength = this.setErrorsLength();\r\n  }\r\n\r\n  /**\r\n   * Determines if input is disabled\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() disabled: boolean;\r\n\r\n  /**\r\n   * Input is required or not\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() required: boolean;\r\n\r\n  /**\r\n   * Input is readonly or not\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() readOnly = false;\r\n\r\n  /**\r\n   * Hint text\r\n   *\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() hintMessage = '';\r\n\r\n  /**\r\n   * Input type\r\n   *\r\n   * @type {FieldType}\r\n   * @memberof FieldComponent\r\n   */\r\n  @HostBinding('attr.field-class')\r\n  @Input()\r\n  type: FieldType = 'text';\r\n\r\n  /**\r\n   * Input is update only on blur\r\n   *\r\n   * @type {Boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() updateOnBlur = false;\r\n\r\n  /**\r\n   * allow only digits in input\r\n   *\r\n   * @type {Boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() allowOnlyDigits = false;\r\n\r\n  /**\r\n   * allow negative numbers\r\n   *\r\n   * @type {Boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() allowNegative = true;\r\n\r\n  /**\r\n   * Show reserved content below form field\r\n   * @property showBottomContent\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() showBottomContent = true;\r\n\r\n  /**\r\n   *\r\n   * Defines the application theme\r\n   *\r\n   * @type {ApplicationTheme}\r\n   * @memberof FieldComponent\r\n   */\r\n  @HostBinding('attr.theme')\r\n  @Input()\r\n  applicationTheme: ApplicationTheme = 'light';\r\n\r\n  /**\r\n   * A string representing the ARIA label for accessibility.\r\n   * This label is used to provide an accessible name for the input element.\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() ariaLabel: string;\r\n\r\n  /**\r\n   * Show loading button. Only for text\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() loading = false;\r\n\r\n  /**\r\n   * Show icon when field is valid\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() isValid = false;\r\n\r\n  /**\r\n   * Max characters number\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() maxCharacters = 255;\r\n\r\n  /**\r\n   * Trim text on blur\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() trimOnBlur = false;\r\n  /**\r\n   * Trim text on submit\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() trimOnSubmit = false;\r\n  /**\r\n   * Max rows for multi-line type\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() maxRows = 0;\r\n  /**\r\n   * has text area counter\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() hasTextAreaCounter = true;\r\n\r\n  /**\r\n   * Hide in build errors for Reactive Forms\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() hideBuiltInErrors = false;\r\n\r\n  /**\r\n   * Hide label in errors\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() hideLabelInErrors = false;\r\n\r\n  /**\r\n   * Set maximum number\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() max: number | undefined;\r\n\r\n  /**\r\n   * Set minimum number\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() min: number | undefined;\r\n\r\n  /**\r\n   * Sets textarea height. Default 110\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() textareaHeight = 110;\r\n\r\n  /**\r\n   * Sets textarea borderless. Default false\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() borderless = false;\r\n\r\n  /**\r\n   * Indicates if this field is filled by AI\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() isAIVariant = false;\r\n\r\n  /**\r\n   * A string representing the ARIA requirement for accessibility.\r\n   * This attribute is used for input field Aria Labeled By Element Id.\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  protected readonly ariaLabelledbyId = computed(() => `${this.id()}-labeledBy`);\r\n\r\n  /**\r\n   * A string representing the ARIA requirement for accessibility.\r\n   * This attribute is used for input field Aria LabeledBy Text.\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  protected readonly ariaLabelledby = input<string | undefined>(undefined);\r\n  /**\r\n   * A string representing the ARIA requirement for accessibility.\r\n   * This attribute is used for input field Aria Described By Element Id.\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  protected readonly ariaDescribedbyId = computed(() => `${this.id()}-describedBy`);\r\n\r\n  /**\r\n   * A string representing the ARIA requirement for accessibility.\r\n   * This attribute is used for input field Aria DescribedBy Text.\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  protected readonly ariaDescribedby = input<string | undefined>(undefined);\r\n\r\n  /**\r\n   * Show state of error\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() hasError = false;\r\n\r\n  @Output() validateEvent = new EventEmitter<string>();\r\n  @Output() fieldBlur = new EventEmitter<void>();\r\n\r\n  @ViewChild('inputElement', { read: ElementRef }) field: ElementRef<HTMLInputElement>;\r\n  @ViewChild('autosize') autosize: CdkTextareaAutosize;\r\n\r\n  get getPasswordIcon(): IconName {\r\n    if (this.applicationTheme === 'classic') {\r\n      return this.showPassword ? 'Eye-hide' : 'Eye-view';\r\n    } else {\r\n      if (!this.isActiveField && !this.isActiveHover) {\r\n        return this.showPassword ? 'View-in-line' : 'Hide-in-line';\r\n      } else {\r\n        return this.showPassword ? 'View-filled' : 'Hide-filled';\r\n      }\r\n    }\r\n  }\r\n\r\n  isActiveField = false;\r\n  isActiveHover = false;\r\n\r\n  keyboardFocused = signal(false);\r\n\r\n  protected readonly translationContext = 'FIELD.';\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  onChange = (_: any) => {};\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  onTouch = () => {};\r\n\r\n  constructor(\r\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\r\n    private matIconRegistry: MatIconRegistry,\r\n    private domSanitizer: DomSanitizer,\r\n    private cdr: ChangeDetectorRef,\r\n    @Optional() @Self() public ngControl: NgControl,\r\n    private focusMonitor: FocusMonitor,\r\n    private ngZone: NgZone,\r\n    private destroyRef: DestroyRef\r\n  ) {\r\n    if (defaultAppTheme) {\r\n      this.applicationTheme = defaultAppTheme;\r\n    }\r\n\r\n    if (this.ngControl != null) {\r\n      this.ngControl.valueAccessor = this;\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.focusMonitor\r\n      .monitor(this.field)\r\n      .pipe(takeUntilDestroyed(this.destroyRef))\r\n      .subscribe(origin =>\r\n        this.ngZone.run(() => {\r\n          this.keyboardFocused.set(origin === 'keyboard');\r\n        })\r\n      );\r\n\r\n    if (this.type === 'multi-line') {\r\n      this.autosize.resizeToFitContent(true);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Used to mark component view as dirty when touched programmatically with markAsTouched/markAllAsTouched or errors\r\n   * to display validation errors that might happen (e.g. required)\r\n   */\r\n  ngDoCheck(): void {\r\n    if (this.ngControl?.touched || this.ngControl?.errors) {\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  showClose: boolean;\r\n  showPassword: boolean;\r\n  currentType: string;\r\n  errorsLength: boolean;\r\n\r\n  ngOnInit(): void {\r\n    this.setSearchInput();\r\n    this.currentType = this.getType();\r\n  }\r\n\r\n  validate(): void {\r\n    this.validateEvent.emit(this.value);\r\n  }\r\n\r\n  //set search input initial value\r\n  setSearchInput(): void {\r\n    if (this.type === 'search' || this.type === 'collapsed-search') {\r\n      this.matIconRegistry.addSvgIcon('Search', this.domSanitizer.bypassSecurityTrustResourceUrl('/icons/Search.svg'));\r\n    } else {\r\n      this.showClose = false;\r\n    }\r\n  }\r\n\r\n  //change type for reveal password\r\n  getType(): string {\r\n    if (this.type === 'password' && this.showPassword) {\r\n      return 'text';\r\n    }\r\n    return this.type;\r\n  }\r\n\r\n  //Clear input value\r\n  clearValue(): void {\r\n    this.value = '';\r\n    this.onChange(this.value);\r\n    this.onChangeInputSearch();\r\n  }\r\n\r\n  //toggle for password\r\n  showPasswordClick() {\r\n    this.showPassword = !this.showPassword;\r\n    this.currentType = this.getType();\r\n  }\r\n\r\n  //Set options for search input\r\n  onChangeInputSearch() {\r\n    if (this.type === 'search' || this.type === 'collapsed-search') {\r\n      if (!this.value) {\r\n        this.showClose = false;\r\n      }\r\n      if (this.value) {\r\n        this.showClose = true;\r\n      }\r\n    }\r\n  }\r\n\r\n  // Set errors length for validation\r\n  // Consider only those errors which which are not empty\r\n  setErrorsLength(): boolean {\r\n    if (!!this._errors) {\r\n      return this._errors.filter(err => !!err).length > 0 ? true : false;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  //Save input value\r\n  onInput(event: any) {\r\n    this.value = event.target.value;\r\n    this.errorsLength = this.setErrorsLength();\r\n    if (!this.updateOnBlur) {\r\n      this.onTouch();\r\n    }\r\n    if (this.allowOnlyDigits && !this.allowNegative && +this.value < 0) {\r\n      this.value = '0';\r\n    } else {\r\n      this.onChange(this.type === 'number' ? +this.value : this.value);\r\n    }\r\n  }\r\n\r\n  writeValue(value?: any): void {\r\n    if (value !== null && value !== undefined) {\r\n      this.value = value;\r\n    } else {\r\n      this.value = '';\r\n    }\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  onActive(state: boolean, action: string): void {\r\n    if (action === 'hover') {\r\n      this.isActiveHover = state;\r\n    } else if (action === 'focus') {\r\n      this.isActiveField = state;\r\n\r\n      if (!state && this.trimOnBlur) {\r\n        this.clearSpace();\r\n      }\r\n    }\r\n  }\r\n\r\n  onSubmit(): void {\r\n    if (this.trimOnSubmit) {\r\n      this.clearSpace();\r\n    }\r\n  }\r\n\r\n  private clearSpace(): void {\r\n    this.value = this.value.trim();\r\n    this.onChange(this.value);\r\n  }\r\n\r\n  onBlur(): void {\r\n    this.fieldBlur.emit();\r\n  }\r\n\r\n  trackByFn = (index: number, value: any) => value.changingThisBreaksApplicationSecurity;\r\n\r\n  focus(): void {\r\n    this.field.nativeElement.focus();\r\n  }\r\n\r\n  refocusPasswordButton(btn: any) {\r\n    setTimeout(() => {\r\n      btn.focus('keyboard');\r\n    }, 0);\r\n  }\r\n}\r\n","<ng-container>\r\n  <mat-form-field\r\n    [ngStyle]=\"{\r\n      '--textarea-height': textareaHeight - 10 + 'px',\r\n      '--textarea-height-container': textareaHeight + 'px',\r\n    }\"\r\n    #uiField\r\n    appearance=\"outline\"\r\n    hideRequiredMarker=\"true\"\r\n    [color]=\"errorsLength || (ngControl?.errors && ngControl?.touched) || hasError ? 'warn' : 'accent'\"\r\n    [ngClass]=\"{\r\n      'hide-bottom-content': !showBottomContent,\r\n      textarea: type === 'textarea',\r\n      'multi-line': type === 'multi-line',\r\n      'keyboard-focused': keyboardFocused(),\r\n      'has-label': !!label,\r\n      'has-value': !!value,\r\n      'text-area-borderless': type === 'textarea' && borderless,\r\n    }\"\r\n    (mouseenter)=\"onActive(true, 'hover')\"\r\n    (mouseleave)=\"onActive(false, 'hover')\"\r\n  >\r\n    <span [style.display]=\"'none'\" [id]=\"ariaDescribedbyId()\">\r\n      @if (required) {\r\n        <span>{{ 'ERRORS.REQUIRED' | uiTranslate | async }}</span>\r\n      }\r\n      {{ ariaDescribedby() }}\r\n    </span>\r\n    <span [style.display]=\"'none'\" [id]=\"ariaLabelledbyId()\">\r\n      {{ ariaLabelledby() ?? label }}\r\n    </span>\r\n    <mat-label\r\n      *ngIf=\"(label || labelHtml()) && ((type !== 'search' && applicationTheme === 'classic') || applicationTheme !== 'classic')\"\r\n      class=\"label-with-icon\"\r\n    >\r\n      @if(isAIVariant || labelIcon) {\r\n        <ui-icon\r\n          [name]=\"isAIVariant ? 'Sparkle-in-line' : labelIcon!\"\r\n          [size]=\"'16'\"\r\n          class=\"label-icon\"\r\n        ></ui-icon>\r\n      }\r\n      <span>\r\n        @if(labelHtml()) {\r\n          <span [innerHTML]=\"labelHtml()\"></span>\r\n        } @else {\r\n          {{ label }}\r\n        }@if(required) {<span>*</span>}\r\n      </span>\r\n    </mat-label>\r\n    <mat-icon\r\n      *ngIf=\"type === 'search' || type === 'collapsed-search'\"\r\n      matIconPrefix\r\n      class=\"search-icon\"\r\n      [svgIcon]=\"'Search'\"\r\n    ></mat-icon>\r\n    <input\r\n      [readonly]=\"readOnly\"\r\n      *ngIf=\"type !== 'textarea' && type !== 'multi-line'; else textarea\"\r\n      matInput\r\n      #inputElement\r\n      (blur)=\"onTouch(); onActive(false, 'focus'); onBlur()\"\r\n      (input)=\"onInput($event)\"\r\n      [id]=\"id()\"\r\n      (keyup)=\"onChangeInputSearch()\"\r\n      [placeholder]=\"placeholder!\"\r\n      [value]=\"value\"\r\n      [disabled]=\"disabled || loading\"\r\n      [type]=\"currentType\"\r\n      (keyup.enter)=\"onSubmit()\"\r\n      [max]=\"max\"\r\n      [min]=\"min\"\r\n      [name]=\"fieldName!\"\r\n      [required]=\"required\"\r\n      [attr.aria-label]=\"ariaLabel\"\r\n      [attr.aria-invalid]=\"errorsLength || (ngControl?.errors && ngControl?.touched) || hasError\"\r\n      [attr.aria-labelledby]=\"ariaLabelledbyId()\"\r\n      [attr.aria-describedby]=\"ariaDescribedbyId()\"\r\n      role=\"textbox\"\r\n      digitsOnly\r\n      [allowOnlyDigits]=\"allowOnlyDigits\"\r\n      [allowNegative]=\"allowNegative\"\r\n      (focusin)=\"onActive(true, 'focus')\"\r\n    />\r\n\r\n    <ng-template #textarea>\r\n      <textarea\r\n        matInput\r\n        #inputElement\r\n        #autosize=\"cdkTextareaAutosize\"\r\n        [readonly]=\"readOnly\"\r\n        (blur)=\"onTouch(); onActive(false, 'focus'); onBlur()\"\r\n        (input)=\"onInput($event)\"\r\n        [id]=\"id()\"\r\n        (keyup)=\"onChangeInputSearch()\"\r\n        (keyup.enter)=\"onSubmit()\"\r\n        [placeholder]=\"placeholder!\"\r\n        [value]=\"value\"\r\n        [disabled]=\"disabled\"\r\n        [type]=\"currentType\"\r\n        [name]=\"fieldName!\"\r\n        [required]=\"required\"\r\n        [attr.aria-label]=\"!label ? ariaLabel : ''\"\r\n        [attr.aria-invalid]=\"errorsLength || (ngControl?.errors && ngControl?.touched) || hasError\"\r\n        [attr.aria-labelledby]=\"ariaLabelledbyId()\"\r\n        [attr.aria-describedby]=\"ariaDescribedbyId()\"\r\n        role=\"textbox\"\r\n        [cdkTextareaAutosize]=\"type === 'multi-line'\"\r\n        [cdkAutosizeMinRows]=\"type === 'multi-line' ? 1 : 5\"\r\n        [cdkAutosizeMaxRows]=\"type === 'multi-line' ? maxRows : 5\"\r\n        (focusin)=\"onActive(true, 'focus')\"\r\n      ></textarea>\r\n    </ng-template>\r\n\r\n    <div class=\"options\" *ngIf=\"type === 'search' || type === 'collapsed-search' || type === 'password' || type === 'validation-text'\">\r\n      <div class=\"options-container\">\r\n        <ui-button\r\n          *ngIf=\"showClose\"\r\n          variant=\"secondary\"\r\n          [justIcon]=\"true\"\r\n          class=\"close\"\r\n          iconName=\"Close\"\r\n          [label]=\"('COMMON.CLEAR' | uiTranslate | async)!\"\r\n          (buttonClickEvent)=\"clearValue()\"\r\n          [ariaLabel]=\"ariaLabel + '--' + ('COMMON.CLEAR' | uiTranslate | async)\"\r\n        ></ui-button>\r\n        <ui-button\r\n          class=\"password\"\r\n          variant=\"secondary\"\r\n          [tooltip]=\"((showPassword ? 'FIELD.HIDE_PASSWORD' : 'FIELD.SHOW_PASSWORD') | uiTranslate | async)!\"\r\n          *ngIf=\"type === 'password'\"\r\n          [justIcon]=\"true\"\r\n          role=\"switch\"\r\n          [attr.aria-checked]=\"showPassword\"\r\n          [iconName]=\"getPasswordIcon\"\r\n          [applicationTheme]=\"applicationTheme\"\r\n          (click)=\"showPasswordClick()\"\r\n          #btn\r\n          (keydown.enter)=\"refocusPasswordButton(btn)\"\r\n          (keydown.space)=\"refocusPasswordButton(btn)\"\r\n        ></ui-button>\r\n\r\n        <ng-container\r\n          *ngIf=\"\r\n            type === 'validation-text' && (applicationTheme === 'dark' || applicationTheme === 'light') && value.length\r\n          \"\r\n        >\r\n          <ui-button\r\n            *ngIf=\"!isValid\"\r\n            class=\"validation\"\r\n            [variant]=\"'text'\"\r\n            [applicationTheme]=\"'light'\"\r\n            [label]=\"'Validate'\"\r\n            [loading]=\"loading\"\r\n            (click)=\"validate()\"\r\n            [disabled]=\"disabled\"\r\n            [size]=\"'small'\"\r\n          ></ui-button>\r\n          <ui-icon class=\"valid\" [color]=\"'white'\" applicationTheme=\"light\" [name]=\"'Check'\" *ngIf=\"isValid\"></ui-icon>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n    @if (hasTextAreaCounter) {\r\n      <mat-hint class=\"info\" *ngIf=\"type === 'textarea' && !errorsLength && !(ngControl?.errors | hasValidationError)\"\r\n        >{{ value.length }} / {{ maxCharacters }}</mat-hint\r\n      >\r\n    }\r\n\r\n    <mat-hint\r\n      class=\"info\"\r\n      *ngIf=\"hintMessage && !errorsLength && !(ngControl?.errors | hasValidationError) && type !== 'textarea'\"\r\n      >{{ hintMessage }}</mat-hint\r\n    >\r\n    <mat-hint class=\"error\" *ngIf=\"errorsLength || (ngControl?.errors | hasValidationError)\">\r\n      <ng-template [ngIf]=\"errorsLength\">\r\n        <div class=\"errors\" *ngFor=\"let error of _errors; trackBy: trackByFn\">\r\n          <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\r\n          <span [innerHTML]=\"error\"></span>\r\n        </div>\r\n      </ng-template>\r\n\r\n      <ui-validation-error\r\n        *ngIf=\"ngControl && !hideBuiltInErrors\"\r\n        [ngControl]=\"ngControl\"\r\n        [label]=\"hideLabelInErrors ? null : label\"\r\n      ></ui-validation-error>\r\n    </mat-hint>\r\n\r\n    @if (badgeVariant) {\r\n      <ui-badge class=\"field-badge\"\r\n                [variant]=\"badgeVariant\"></ui-badge>\r\n    }\r\n  </mat-form-field>\r\n</ng-container>\r\n"]}
544
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/field/field.component.ts","../../../../../projects/tgo-canopy-ui/components/field/field.component.html"],"names":[],"mappings":"AAEA,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EACT,QAAQ,EAGR,UAAU,EACV,YAAY,EACZ,WAAW,EACX,MAAM,EACN,KAAK,EACL,KAAK,EAGL,QAAQ,EACR,MAAM,EACN,IAAI,EACJ,MAAM,EACN,SAAS,EACT,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;;;;;;;;;;;;;;;;;AAUhE;;;;;;;GAOG;AACH,MAAM,CAAC,IAAI,OAAO,GAAG,CAAC,CAAC;AASvB,MAAM,OAAO,cAAc;IA+EzB;;;;;OAKG;IACH,IAAa,MAAM,CAAC,MAAgB;QAClC,IAAI,CAAC,OAAO,GAAG,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC,CAAC;QACtG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;IAC7C,CAAC;IAwPD,IAAI,eAAe;QACjB,IAAI,IAAI,CAAC,gBAAgB,KAAK,SAAS,EAAE,CAAC;YACxC,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC;QACrD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;gBAC/C,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,cAAc,CAAC;YAC7D,CAAC;iBAAM,CAAC;gBACN,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC;YAC3D,CAAC;QACH,CAAC;IACH,CAAC;IAmBD,YAC6E,eAAiC,EACpG,eAAgC,EAChC,YAA0B,EAC1B,GAAsB,EACH,SAAoB,EACvC,YAA0B,EAC1B,MAAc,EACd,UAAsB;QAP6C,oBAAe,GAAf,eAAe,CAAkB;QACpG,oBAAe,GAAf,eAAe,CAAiB;QAChC,iBAAY,GAAZ,YAAY,CAAc;QAC1B,QAAG,GAAH,GAAG,CAAmB;QACH,cAAS,GAAT,SAAS,CAAW;QACvC,iBAAY,GAAZ,YAAY,CAAc;QAC1B,WAAM,GAAN,MAAM,CAAQ;QACd,eAAU,GAAV,UAAU,CAAY;QApXjB,UAAK,GAAG,UAAU,CAAC;QAElC;;;;;WAKG;QAGH,cAAS,GAAG,IAAI,CAAC;QAEjB;;;;;WAKG;QACM,UAAK,GAAI,EAAE,CAAC;QAErB;;;;WAIG;QACH,cAAS,GAAG,KAAK,CAAC,IAAI,EAAE;YACtB,SAAS,EAAE,CAAC,KAAa,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAC,KAAK,CAAC;SAC/E,CAAC,CAAC;QAkBH;;;;;WAKG;QACM,gBAAW,GAAI,EAAE,CAAC;QAE3B;;;;;WAKG;QACH,OAAE,GAAG,KAAK,CAAC,SAAS,OAAO,EAAE,EAAE,CAAC,CAAC;QAEjC;;;;;WAKG;QACM,UAAK,GAAG,EAAE,CAAC;QAsCpB;;;;;WAKG;QACM,aAAQ,GAAG,KAAK,CAAC;QAE1B;;;;;WAKG;QACM,gBAAW,GAAG,EAAE,CAAC;QAE1B;;;;;WAKG;QAGH,SAAI,GAAc,MAAM,CAAC;QAEzB;;;;;WAKG;QACM,iBAAY,GAAG,KAAK,CAAC;QAE9B;;;;;WAKG;QACM,oBAAe,GAAG,KAAK,CAAC;QAEjC;;;;;WAKG;QACM,kBAAa,GAAG,IAAI,CAAC;QAE9B;;;;;WAKG;QACM,sBAAiB,GAAG,IAAI,CAAC;QAElC;;;;;;WAMG;QAGH,qBAAgB,GAAqB,OAAO,CAAC;QAU7C;;;;;WAKG;QACM,YAAO,GAAG,KAAK,CAAC;QAEzB;;;;;WAKG;QACM,YAAO,GAAG,KAAK,CAAC;QAEzB;;;;;WAKG;QACM,kBAAa,GAAG,GAAG,CAAC;QAE7B;;;;;WAKG;QACM,eAAU,GAAG,KAAK,CAAC;QAC5B;;;;;WAKG;QACM,iBAAY,GAAG,KAAK,CAAC;QAC9B;;;;;WAKG;QACM,YAAO,GAAG,CAAC,CAAC;QACrB;;;;;WAKG;QACM,uBAAkB,GAAG,IAAI,CAAC;QAEnC;;;;;WAKG;QACM,sBAAiB,GAAG,KAAK,CAAC;QAEnC;;;;;WAKG;QACM,sBAAiB,GAAG,KAAK,CAAC;QAkBnC;;;;;WAKG;QACM,mBAAc,GAAG,GAAG,CAAC;QAE9B;;;;;WAKG;QACM,eAAU,GAAG,KAAK,CAAC;QAE5B;;;;;WAKG;QACM,gBAAW,GAAG,KAAK,CAAC;QAE7B;;;;;WAKG;QACgB,qBAAgB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,EAAE,YAAY,CAAC,CAAC;QAE/E;;;;;WAKG;QACgB,mBAAc,GAAG,KAAK,CAAqB,SAAS,CAAC,CAAC;QACzE;;;;;WAKG;QACgB,sBAAiB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,EAAE,cAAc,CAAC,CAAC;QAElF;;;;;WAKG;QACgB,oBAAe,GAAG,KAAK,CAAqB,SAAS,CAAC,CAAC;QAE1E;;;;WAIG;QACM,aAAQ,GAAG,KAAK,CAAC;QAEhB,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC;QAC3C,cAAS,GAAG,IAAI,YAAY,EAAQ,CAAC;QAiB/C,kBAAa,GAAG,KAAK,CAAC;QACtB,kBAAa,GAAG,KAAK,CAAC;QAEtB,oBAAe,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAEb,uBAAkB,GAAG,QAAQ,CAAC;QAEjD;;WAEG;QACH,aAAQ,GAAG,CAAC,CAAM,EAAE,EAAE,GAAE,CAAC,CAAC;QAE1B;;WAEG;QACH,YAAO,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QA8KnB,cAAS,GAAG,CAAC,KAAa,EAAE,KAAU,EAAE,EAAE,CAAC,KAAK,CAAC,qCAAqC,CAAC;QAlKrF,IAAI,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,gBAAgB,GAAG,eAAe,CAAC;QAC1C,CAAC;QAED,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,EAAE,CAAC;YAC3B,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,IAAI,CAAC;QACtC,CAAC;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,YAAY;aACd,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC;aACnB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aACzC,SAAS,CAAC,MAAM,CAAC,EAAE,CAClB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;YACnB,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,KAAK,UAAU,CAAC,CAAC;QAClD,CAAC,CAAC,CACH,CAAC;QAEJ,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY,EAAE,CAAC;YAC/B,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,SAAS;QACP,IAAI,IAAI,CAAC,SAAS,EAAE,OAAO,IAAI,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,CAAC;YACtD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC;IACH,CAAC;IAOD,QAAQ;QACN,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;IACpC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAED,gCAAgC;IAChC,cAAc;QACZ,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,IAAI,KAAK,kBAAkB,EAAE,CAAC;YAC/D,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC,8BAA8B,CAAC,mBAAmB,CAAC,CAAC,CAAC;QACnH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC;IACH,CAAC;IAED,iCAAiC;IACjC,OAAO;QACL,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YAClD,OAAO,MAAM,CAAC;QAChB,CAAC;QACD,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,mBAAmB;IACnB,UAAU;QACR,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAChB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,qBAAqB;IACrB,iBAAiB;QACf,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC;QACvC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;IACpC,CAAC;IAED,8BAA8B;IAC9B,mBAAmB;QACjB,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,IAAI,KAAK,kBAAkB,EAAE,CAAC;YAC/D,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;gBAChB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACzB,CAAC;YACD,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;gBACf,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACxB,CAAC;QACH,CAAC;IACH,CAAC;IAED,mCAAmC;IACnC,uDAAuD;IACvD,eAAe;QACb,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QACrE,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,kBAAkB;IAClB,OAAO,CAAC,KAAU;QAChB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QAChC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QAC3C,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,IAAI,CAAC,OAAO,EAAE,CAAC;QACjB,CAAC;QACD,IAAI,IAAI,CAAC,eAAe,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC;YACnE,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;QACnB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxF,CAAC;IACH,CAAC;IAED,UAAU,CAAC,KAAW;QACpB,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YAC1C,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACrB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAClB,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,QAAQ,CAAC,KAAc,EAAE,MAAc;QACrC,IAAI,MAAM,KAAK,OAAO,EAAE,CAAC;YACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC7B,CAAC;aAAM,IAAI,MAAM,KAAK,OAAO,EAAE,CAAC;YAC9B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAE3B,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;gBAC9B,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,CAAC;QACH,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;IACH,CAAC;IAEO,UAAU;QAChB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;QAC/B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;IAID,KAAK;QACH,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACnC,CAAC;IAED,qBAAqB,CAAC,GAAQ;QAC5B,UAAU,CAAC,GAAG,EAAE;YACd,GAAG,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QACxB,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;+GAniBU,cAAc,kBA8WH,oCAAoC;mGA9W/C,cAAc,06KA6UU,UAAU,oHCjY/C,g9OAkMA;;4FD9Ia,cAAc;kBAP1B,SAAS;+BACE,UAAU,iBAGL,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;;0BAgX5C,QAAQ;;0BAAI,MAAM;2BAAC,oCAAoC;;0BAIvD,QAAQ;;0BAAI,IAAI;kHAjXJ,KAAK;sBAAnB,WAAW;gBAUZ,SAAS;sBAFR,WAAW;uBAAC,kBAAkB;;sBAC9B,KAAK;gBASG,KAAK;sBAAb,KAAK;gBAiBG,SAAS;sBAAjB,KAAK;gBAQG,SAAS;sBAAjB,KAAK;gBAQG,WAAW;sBAAnB,KAAK;gBAgBG,KAAK;sBAAb,KAAK;gBAQG,YAAY;sBAApB,KAAK;gBASO,MAAM;sBAAlB,KAAK;gBAWG,QAAQ;sBAAhB,KAAK;gBAQG,QAAQ;sBAAhB,KAAK;gBAQG,QAAQ;sBAAhB,KAAK;gBAQG,WAAW;sBAAnB,KAAK;gBAUN,IAAI;sBAFH,WAAW;uBAAC,kBAAkB;;sBAC9B,KAAK;gBASG,YAAY;sBAApB,KAAK;gBAQG,eAAe;sBAAvB,KAAK;gBAQG,aAAa;sBAArB,KAAK;gBAQG,iBAAiB;sBAAzB,KAAK;gBAWN,gBAAgB;sBAFf,WAAW;uBAAC,YAAY;;sBACxB,KAAK;gBASG,SAAS;sBAAjB,KAAK;gBAQG,OAAO;sBAAf,KAAK;gBAQG,OAAO;sBAAf,KAAK;gBAQG,aAAa;sBAArB,KAAK;gBAQG,UAAU;sBAAlB,KAAK;gBAOG,YAAY;sBAApB,KAAK;gBAOG,OAAO;sBAAf,KAAK;gBAOG,kBAAkB;sBAA1B,KAAK;gBAQG,iBAAiB;sBAAzB,KAAK;gBAQG,iBAAiB;sBAAzB,KAAK;gBAQG,GAAG;sBAAX,KAAK;gBAQG,GAAG;sBAAX,KAAK;gBAQG,cAAc;sBAAtB,KAAK;gBAQG,UAAU;sBAAlB,KAAK;gBAQG,WAAW;sBAAnB,KAAK;gBAsCG,QAAQ;sBAAhB,KAAK;gBAEI,aAAa;sBAAtB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBAE0C,KAAK;sBAArD,SAAS;uBAAC,cAAc,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBACxB,QAAQ;sBAA9B,SAAS;uBAAC,UAAU","sourcesContent":["/* eslint-disable no-underscore-dangle */\r\nimport { FocusMonitor } from '@angular/cdk/a11y';\r\nimport {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  computed,\r\n  DestroyRef,\r\n  DoCheck,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Inject,\r\n  input,\r\n  Input,\r\n  NgZone,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  Self,\r\n  signal,\r\n  ViewChild,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\r\nimport { MatIconRegistry } from '@angular/material/icon';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\nimport { CdkTextareaAutosize } from '@angular/cdk/text-field';\r\nimport { FieldType } from '../../components/field/field.model';\r\nimport { ApplicationTheme } from '../../models/application-theme.model';\r\nimport { BadgeVariant } from '../badge/badge.model';\r\nimport { IconName } from '../icon/icon.model';\r\n\r\n/**\r\n * A global counter used to generate unique field IDs.\r\n * This variable is incremented each time a new field ID is needed.\r\n *\r\n * @remarks\r\n * This is primarily used to ensure that each field component\r\n * has a unique identifier within the application / useful for their Aria Labels.\r\n */\r\nexport let fieldID = 0;\r\n\r\n@Component({\r\n  selector: 'ui-field',\r\n  templateUrl: './field.component.html',\r\n  styleUrls: ['./field.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class FieldComponent implements OnInit, ControlValueAccessor, DoCheck, AfterViewInit {\r\n  @HostBinding() class = 'ui-field';\r\n\r\n  /**\r\n   * Indicator of the autocomplete width\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @HostBinding('class.full-width')\r\n  @Input()\r\n  fullWidth = true;\r\n\r\n  /**\r\n   * Form field label\r\n   *\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() label? = '';\r\n\r\n  /**\r\n   * Form field label from html\r\n   *\r\n   * @memberof FieldComponent\r\n   */\r\n  labelHtml = input(null, {\r\n    transform: (value: string) => this.domSanitizer.bypassSecurityTrustHtml(value)\r\n  });\r\n\r\n  /**\r\n   * Icon to display alongside the label\r\n   *\r\n   * @type {IconName}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() labelIcon?: IconName;\r\n\r\n  /**\r\n   * Input name attribute\r\n   *\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() fieldName?: string;\r\n\r\n  /**\r\n   * Input placeholder\r\n   *\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() placeholder? = '';\r\n\r\n  /**\r\n   * Input id\r\n   *\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  id = input(`field-${fieldID++}`);\r\n\r\n  /**\r\n   * Input value\r\n   *\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() value = '';\r\n\r\n  /**\r\n   * Variant of badge to use\r\n   *\r\n   * @type {BadgeVariant}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() badgeVariant?: BadgeVariant | undefined;\r\n\r\n  _errors: SafeHtml[];\r\n  /**\r\n   * Input field errors\r\n   *\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() set errors(errors: string[]) {\r\n    this._errors = errors?.filter(Boolean).map(error => this.domSanitizer.bypassSecurityTrustHtml(error));\r\n    this.errorsLength = this.setErrorsLength();\r\n  }\r\n\r\n  /**\r\n   * Determines if input is disabled\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() disabled: boolean;\r\n\r\n  /**\r\n   * Input is required or not\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() required: boolean;\r\n\r\n  /**\r\n   * Input is readonly or not\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() readOnly = false;\r\n\r\n  /**\r\n   * Hint text\r\n   *\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() hintMessage = '';\r\n\r\n  /**\r\n   * Input type\r\n   *\r\n   * @type {FieldType}\r\n   * @memberof FieldComponent\r\n   */\r\n  @HostBinding('attr.field-class')\r\n  @Input()\r\n  type: FieldType = 'text';\r\n\r\n  /**\r\n   * Input is update only on blur\r\n   *\r\n   * @type {Boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() updateOnBlur = false;\r\n\r\n  /**\r\n   * allow only digits in input\r\n   *\r\n   * @type {Boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() allowOnlyDigits = false;\r\n\r\n  /**\r\n   * allow negative numbers\r\n   *\r\n   * @type {Boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() allowNegative = true;\r\n\r\n  /**\r\n   * Show reserved content below form field\r\n   * @property showBottomContent\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() showBottomContent = true;\r\n\r\n  /**\r\n   *\r\n   * Defines the application theme\r\n   *\r\n   * @type {ApplicationTheme}\r\n   * @memberof FieldComponent\r\n   */\r\n  @HostBinding('attr.theme')\r\n  @Input()\r\n  applicationTheme: ApplicationTheme = 'light';\r\n\r\n  /**\r\n   * A string representing the ARIA label for accessibility.\r\n   * This label is used to provide an accessible name for the input element.\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() ariaLabel: string;\r\n\r\n  /**\r\n   * Show loading button. Only for text\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() loading = false;\r\n\r\n  /**\r\n   * Show icon when field is valid\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() isValid = false;\r\n\r\n  /**\r\n   * Max characters number\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() maxCharacters = 255;\r\n\r\n  /**\r\n   * Trim text on blur\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() trimOnBlur = false;\r\n  /**\r\n   * Trim text on submit\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() trimOnSubmit = false;\r\n  /**\r\n   * Max rows for multi-line type\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() maxRows = 0;\r\n  /**\r\n   * has text area counter\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() hasTextAreaCounter = true;\r\n\r\n  /**\r\n   * Hide in build errors for Reactive Forms\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() hideBuiltInErrors = false;\r\n\r\n  /**\r\n   * Hide label in errors\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() hideLabelInErrors = false;\r\n\r\n  /**\r\n   * Set maximum number\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() max: number | undefined;\r\n\r\n  /**\r\n   * Set minimum number\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() min: number | undefined;\r\n\r\n  /**\r\n   * Sets textarea height. Default 110\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() textareaHeight = 110;\r\n\r\n  /**\r\n   * Sets textarea borderless. Default false\r\n   *\r\n   * @type {number}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() borderless = false;\r\n\r\n  /**\r\n   * Indicates if this field is filled by AI\r\n   *\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() isAIVariant = false;\r\n\r\n  /**\r\n   * A string representing the ARIA requirement for accessibility.\r\n   * This attribute is used for input field Aria Labeled By Element Id.\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  protected readonly ariaLabelledbyId = computed(() => `${this.id()}-labeledBy`);\r\n\r\n  /**\r\n   * A string representing the ARIA requirement for accessibility.\r\n   * This attribute is used for input field Aria LabeledBy Text.\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  protected readonly ariaLabelledby = input<string | undefined>(undefined);\r\n  /**\r\n   * A string representing the ARIA requirement for accessibility.\r\n   * This attribute is used for input field Aria Described By Element Id.\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  protected readonly ariaDescribedbyId = computed(() => `${this.id()}-describedBy`);\r\n\r\n  /**\r\n   * A string representing the ARIA requirement for accessibility.\r\n   * This attribute is used for input field Aria DescribedBy Text.\r\n   * @type {string}\r\n   * @memberof FieldComponent\r\n   */\r\n  protected readonly ariaDescribedby = input<string | undefined>(undefined);\r\n\r\n  /**\r\n   * Show state of error\r\n   * @type {boolean}\r\n   * @memberof FieldComponent\r\n   */\r\n  @Input() hasError = false;\r\n\r\n  @Output() validateEvent = new EventEmitter<string>();\r\n  @Output() fieldBlur = new EventEmitter<void>();\r\n\r\n  @ViewChild('inputElement', { read: ElementRef }) field: ElementRef<HTMLInputElement>;\r\n  @ViewChild('autosize') autosize: CdkTextareaAutosize;\r\n\r\n  get getPasswordIcon(): IconName {\r\n    if (this.applicationTheme === 'classic') {\r\n      return this.showPassword ? 'Eye-hide' : 'Eye-view';\r\n    } else {\r\n      if (!this.isActiveField && !this.isActiveHover) {\r\n        return this.showPassword ? 'View-in-line' : 'Hide-in-line';\r\n      } else {\r\n        return this.showPassword ? 'View-filled' : 'Hide-filled';\r\n      }\r\n    }\r\n  }\r\n\r\n  isActiveField = false;\r\n  isActiveHover = false;\r\n\r\n  keyboardFocused = signal(false);\r\n\r\n  protected readonly translationContext = 'FIELD.';\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  onChange = (_: any) => {};\r\n\r\n  /**\r\n   * @ignore\r\n   */\r\n  onTouch = () => {};\r\n\r\n  constructor(\r\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\r\n    private matIconRegistry: MatIconRegistry,\r\n    private domSanitizer: DomSanitizer,\r\n    private cdr: ChangeDetectorRef,\r\n    @Optional() @Self() public ngControl: NgControl,\r\n    private focusMonitor: FocusMonitor,\r\n    private ngZone: NgZone,\r\n    private destroyRef: DestroyRef\r\n  ) {\r\n    if (defaultAppTheme) {\r\n      this.applicationTheme = defaultAppTheme;\r\n    }\r\n\r\n    if (this.ngControl != null) {\r\n      this.ngControl.valueAccessor = this;\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.focusMonitor\r\n      .monitor(this.field)\r\n      .pipe(takeUntilDestroyed(this.destroyRef))\r\n      .subscribe(origin =>\r\n        this.ngZone.run(() => {\r\n          this.keyboardFocused.set(origin === 'keyboard');\r\n        })\r\n      );\r\n\r\n    if (this.type === 'multi-line') {\r\n      this.autosize.resizeToFitContent(true);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Used to mark component view as dirty when touched programmatically with markAsTouched/markAllAsTouched or errors\r\n   * to display validation errors that might happen (e.g. required)\r\n   */\r\n  ngDoCheck(): void {\r\n    if (this.ngControl?.touched || this.ngControl?.errors) {\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  showClose: boolean;\r\n  showPassword: boolean;\r\n  currentType: string;\r\n  errorsLength: boolean;\r\n\r\n  ngOnInit(): void {\r\n    this.setSearchInput();\r\n    this.currentType = this.getType();\r\n  }\r\n\r\n  validate(): void {\r\n    this.validateEvent.emit(this.value);\r\n  }\r\n\r\n  //set search input initial value\r\n  setSearchInput(): void {\r\n    if (this.type === 'search' || this.type === 'collapsed-search') {\r\n      this.matIconRegistry.addSvgIcon('Search', this.domSanitizer.bypassSecurityTrustResourceUrl('/icons/Search.svg'));\r\n    } else {\r\n      this.showClose = false;\r\n    }\r\n  }\r\n\r\n  //change type for reveal password\r\n  getType(): string {\r\n    if (this.type === 'password' && this.showPassword) {\r\n      return 'text';\r\n    }\r\n    return this.type;\r\n  }\r\n\r\n  //Clear input value\r\n  clearValue(): void {\r\n    this.value = '';\r\n    this.onChange(this.value);\r\n    this.onChangeInputSearch();\r\n  }\r\n\r\n  //toggle for password\r\n  showPasswordClick() {\r\n    this.showPassword = !this.showPassword;\r\n    this.currentType = this.getType();\r\n  }\r\n\r\n  //Set options for search input\r\n  onChangeInputSearch() {\r\n    if (this.type === 'search' || this.type === 'collapsed-search') {\r\n      if (!this.value) {\r\n        this.showClose = false;\r\n      }\r\n      if (this.value) {\r\n        this.showClose = true;\r\n      }\r\n    }\r\n  }\r\n\r\n  // Set errors length for validation\r\n  // Consider only those errors which which are not empty\r\n  setErrorsLength(): boolean {\r\n    if (!!this._errors) {\r\n      return this._errors.filter(err => !!err).length > 0 ? true : false;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  //Save input value\r\n  onInput(event: any) {\r\n    this.value = event.target.value;\r\n    this.errorsLength = this.setErrorsLength();\r\n    if (!this.updateOnBlur) {\r\n      this.onTouch();\r\n    }\r\n    if (this.allowOnlyDigits && !this.allowNegative && +this.value < 0) {\r\n      this.value = '0';\r\n    } else {\r\n      this.onChange(this.type === 'number' && this.value !== '' ? +this.value : this.value);\r\n    }\r\n  }\r\n\r\n  writeValue(value?: any): void {\r\n    if (value !== null && value !== undefined) {\r\n      this.value = value;\r\n    } else {\r\n      this.value = '';\r\n    }\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  onActive(state: boolean, action: string): void {\r\n    if (action === 'hover') {\r\n      this.isActiveHover = state;\r\n    } else if (action === 'focus') {\r\n      this.isActiveField = state;\r\n\r\n      if (!state && this.trimOnBlur) {\r\n        this.clearSpace();\r\n      }\r\n    }\r\n  }\r\n\r\n  onSubmit(): void {\r\n    if (this.trimOnSubmit) {\r\n      this.clearSpace();\r\n    }\r\n  }\r\n\r\n  private clearSpace(): void {\r\n    this.value = this.value.trim();\r\n    this.onChange(this.value);\r\n  }\r\n\r\n  onBlur(): void {\r\n    this.fieldBlur.emit();\r\n  }\r\n\r\n  trackByFn = (index: number, value: any) => value.changingThisBreaksApplicationSecurity;\r\n\r\n  focus(): void {\r\n    this.field.nativeElement.focus();\r\n  }\r\n\r\n  refocusPasswordButton(btn: any) {\r\n    setTimeout(() => {\r\n      btn.focus('keyboard');\r\n    }, 0);\r\n  }\r\n}\r\n","<ng-container>\r\n  <mat-form-field\r\n    [ngStyle]=\"{\r\n      '--textarea-height': textareaHeight - 10 + 'px',\r\n      '--textarea-height-container': textareaHeight + 'px',\r\n    }\"\r\n    #uiField\r\n    appearance=\"outline\"\r\n    hideRequiredMarker=\"true\"\r\n    [color]=\"errorsLength || (ngControl?.errors && ngControl?.touched) || hasError ? 'warn' : 'accent'\"\r\n    [ngClass]=\"{\r\n      'hide-bottom-content': !showBottomContent,\r\n      textarea: type === 'textarea',\r\n      'multi-line': type === 'multi-line',\r\n      'keyboard-focused': keyboardFocused(),\r\n      'has-label': !!label,\r\n      'has-value': !!value,\r\n      'text-area-borderless': type === 'textarea' && borderless,\r\n    }\"\r\n    (mouseenter)=\"onActive(true, 'hover')\"\r\n    (mouseleave)=\"onActive(false, 'hover')\"\r\n  >\r\n    <span [style.display]=\"'none'\" [id]=\"ariaDescribedbyId()\">\r\n      @if (required) {\r\n        <span>{{ 'ERRORS.REQUIRED' | uiTranslate | async }}</span>\r\n      }\r\n      {{ ariaDescribedby() }}\r\n    </span>\r\n    <span [style.display]=\"'none'\" [id]=\"ariaLabelledbyId()\">\r\n      {{ ariaLabelledby() ?? label }}\r\n    </span>\r\n    <mat-label\r\n      *ngIf=\"(label || labelHtml()) && ((type !== 'search' && applicationTheme === 'classic') || applicationTheme !== 'classic')\"\r\n      class=\"label-with-icon\"\r\n    >\r\n      @if(isAIVariant || labelIcon) {\r\n        <ui-icon\r\n          [name]=\"isAIVariant ? 'Sparkle-in-line' : labelIcon!\"\r\n          [size]=\"'16'\"\r\n          class=\"label-icon\"\r\n        ></ui-icon>\r\n      }\r\n      <span>\r\n        @if(labelHtml()) {\r\n          <span [innerHTML]=\"labelHtml()\"></span>\r\n        } @else {\r\n          {{ label }}\r\n        }@if(required) {<span>*</span>}\r\n      </span>\r\n    </mat-label>\r\n    <mat-icon\r\n      *ngIf=\"type === 'search' || type === 'collapsed-search'\"\r\n      matIconPrefix\r\n      class=\"search-icon\"\r\n      [svgIcon]=\"'Search'\"\r\n    ></mat-icon>\r\n    <input\r\n      [readonly]=\"readOnly\"\r\n      *ngIf=\"type !== 'textarea' && type !== 'multi-line'; else textarea\"\r\n      matInput\r\n      #inputElement\r\n      (blur)=\"onTouch(); onActive(false, 'focus'); onBlur()\"\r\n      (input)=\"onInput($event)\"\r\n      [id]=\"id()\"\r\n      (keyup)=\"onChangeInputSearch()\"\r\n      [placeholder]=\"placeholder!\"\r\n      [value]=\"value\"\r\n      [disabled]=\"disabled || loading\"\r\n      [type]=\"currentType\"\r\n      (keyup.enter)=\"onSubmit()\"\r\n      [max]=\"max\"\r\n      [min]=\"min\"\r\n      [name]=\"fieldName!\"\r\n      [required]=\"required\"\r\n      [attr.aria-label]=\"ariaLabel\"\r\n      [attr.aria-invalid]=\"errorsLength || (ngControl?.errors && ngControl?.touched) || hasError\"\r\n      [attr.aria-labelledby]=\"ariaLabelledbyId()\"\r\n      [attr.aria-describedby]=\"ariaDescribedbyId()\"\r\n      role=\"textbox\"\r\n      digitsOnly\r\n      [allowOnlyDigits]=\"allowOnlyDigits\"\r\n      [allowNegative]=\"allowNegative\"\r\n      (focusin)=\"onActive(true, 'focus')\"\r\n    />\r\n\r\n    <ng-template #textarea>\r\n      <textarea\r\n        matInput\r\n        #inputElement\r\n        #autosize=\"cdkTextareaAutosize\"\r\n        [readonly]=\"readOnly\"\r\n        (blur)=\"onTouch(); onActive(false, 'focus'); onBlur()\"\r\n        (input)=\"onInput($event)\"\r\n        [id]=\"id()\"\r\n        (keyup)=\"onChangeInputSearch()\"\r\n        (keyup.enter)=\"onSubmit()\"\r\n        [placeholder]=\"placeholder!\"\r\n        [value]=\"value\"\r\n        [disabled]=\"disabled\"\r\n        [type]=\"currentType\"\r\n        [name]=\"fieldName!\"\r\n        [required]=\"required\"\r\n        [attr.aria-label]=\"!label ? ariaLabel : ''\"\r\n        [attr.aria-invalid]=\"errorsLength || (ngControl?.errors && ngControl?.touched) || hasError\"\r\n        [attr.aria-labelledby]=\"ariaLabelledbyId()\"\r\n        [attr.aria-describedby]=\"ariaDescribedbyId()\"\r\n        role=\"textbox\"\r\n        [cdkTextareaAutosize]=\"type === 'multi-line'\"\r\n        [cdkAutosizeMinRows]=\"type === 'multi-line' ? 1 : 5\"\r\n        [cdkAutosizeMaxRows]=\"type === 'multi-line' ? maxRows : 5\"\r\n        (focusin)=\"onActive(true, 'focus')\"\r\n      ></textarea>\r\n    </ng-template>\r\n\r\n    <div class=\"options\" *ngIf=\"type === 'search' || type === 'collapsed-search' || type === 'password' || type === 'validation-text'\">\r\n      <div class=\"options-container\">\r\n        <ui-button\r\n          *ngIf=\"showClose\"\r\n          variant=\"secondary\"\r\n          [justIcon]=\"true\"\r\n          class=\"close\"\r\n          iconName=\"Close\"\r\n          [label]=\"('COMMON.CLEAR' | uiTranslate | async)!\"\r\n          (buttonClickEvent)=\"clearValue()\"\r\n          [ariaLabel]=\"ariaLabel + '--' + ('COMMON.CLEAR' | uiTranslate | async)\"\r\n        ></ui-button>\r\n        <ui-button\r\n          class=\"password\"\r\n          variant=\"secondary\"\r\n          [tooltip]=\"((showPassword ? 'FIELD.HIDE_PASSWORD' : 'FIELD.SHOW_PASSWORD') | uiTranslate | async)!\"\r\n          *ngIf=\"type === 'password'\"\r\n          [justIcon]=\"true\"\r\n          role=\"switch\"\r\n          [attr.aria-checked]=\"showPassword\"\r\n          [iconName]=\"getPasswordIcon\"\r\n          [applicationTheme]=\"applicationTheme\"\r\n          (click)=\"showPasswordClick()\"\r\n          #btn\r\n          (keydown.enter)=\"refocusPasswordButton(btn)\"\r\n          (keydown.space)=\"refocusPasswordButton(btn)\"\r\n        ></ui-button>\r\n\r\n        <ng-container\r\n          *ngIf=\"\r\n            type === 'validation-text' && (applicationTheme === 'dark' || applicationTheme === 'light') && value.length\r\n          \"\r\n        >\r\n          <ui-button\r\n            *ngIf=\"!isValid\"\r\n            class=\"validation\"\r\n            [variant]=\"'text'\"\r\n            [applicationTheme]=\"'light'\"\r\n            [label]=\"'Validate'\"\r\n            [loading]=\"loading\"\r\n            (click)=\"validate()\"\r\n            [disabled]=\"disabled\"\r\n            [size]=\"'small'\"\r\n          ></ui-button>\r\n          <ui-icon class=\"valid\" [color]=\"'white'\" applicationTheme=\"light\" [name]=\"'Check'\" *ngIf=\"isValid\"></ui-icon>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n    @if (hasTextAreaCounter) {\r\n      <mat-hint class=\"info\" *ngIf=\"type === 'textarea' && !errorsLength && !(ngControl?.errors | hasValidationError)\"\r\n        >{{ value.length }} / {{ maxCharacters }}</mat-hint\r\n      >\r\n    }\r\n\r\n    <mat-hint\r\n      class=\"info\"\r\n      *ngIf=\"hintMessage && !errorsLength && !(ngControl?.errors | hasValidationError) && type !== 'textarea'\"\r\n      >{{ hintMessage }}</mat-hint\r\n    >\r\n    <mat-hint class=\"error\" *ngIf=\"errorsLength || (ngControl?.errors | hasValidationError)\">\r\n      <ng-template [ngIf]=\"errorsLength\">\r\n        <div class=\"errors\" *ngFor=\"let error of _errors; trackBy: trackByFn\">\r\n          <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\r\n          <span [innerHTML]=\"error\"></span>\r\n        </div>\r\n      </ng-template>\r\n\r\n      <ui-validation-error\r\n        *ngIf=\"ngControl && !hideBuiltInErrors\"\r\n        [ngControl]=\"ngControl\"\r\n        [label]=\"hideLabelInErrors ? null : label\"\r\n      ></ui-validation-error>\r\n    </mat-hint>\r\n\r\n    @if (badgeVariant) {\r\n      <ui-badge class=\"field-badge\"\r\n                [variant]=\"badgeVariant\"></ui-badge>\r\n    }\r\n  </mat-form-field>\r\n</ng-container>\r\n"]}
@@ -7705,7 +7705,7 @@ class FieldComponent {
7705
7705
  this.value = '0';
7706
7706
  }
7707
7707
  else {
7708
- this.onChange(this.type === 'number' ? +this.value : this.value);
7708
+ this.onChange(this.type === 'number' && this.value !== '' ? +this.value : this.value);
7709
7709
  }
7710
7710
  }
7711
7711
  writeValue(value) {