@testgorilla/tgo-ui 2.3.8 → 2.3.9

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.
@@ -320,7 +320,6 @@ export class AutocompleteComponent {
320
320
  onUpdate() {
321
321
  this.inputValueSearch$.next('');
322
322
  this.userInput$.next('');
323
- this.selectionChange.emit(this.value);
324
323
  if (!this.valuePrimitive) {
325
324
  this.onChange(this.value);
326
325
  }
@@ -332,6 +331,7 @@ export class AutocompleteComponent {
332
331
  this.onChange(this.value.map((v) => v[this.valueField]));
333
332
  }
334
333
  }
334
+ this.selectionChange.emit(this.value);
335
335
  }
336
336
  initValue() {
337
337
  if (this.type === this.autocompleteType.SINGLE && this.variant !== DropdownVariation.DROPDOWN) {
@@ -447,4 +447,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
447
447
  type: ViewChild,
448
448
  args: ['trigger']
449
449
  }] } });
450
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../src/components/autocomplete/autocomplete.component.ts","../../../../../src/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  Self,\n  ViewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { MatAutocomplete, MatAutocompleteSelectedEvent, MatAutocompleteTrigger } from '@angular/material/autocomplete';\nimport { map, ReplaySubject, startWith } from 'rxjs';\nimport { AutocompleteUtils } from '../../utils/autocomplete-utils';\nimport { Autocomplete, AutocompleteType, DropdownVariation, Padding, Timeout } from './autocomplete.model';\nimport { LanguageService } from '../../utils/localization/language.service';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\n@Component({\n  selector: 'ui-autocomplete',\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['./autocomplete.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\n// eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\nexport class AutocompleteComponent implements ControlValueAccessor, OnChanges, AfterViewInit, DoCheck {\n  /**\n   * @property itemsList\n   * @description The list of items to display in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() itemsList: any[] = [];\n\n  /**\n   * @property suggestionsList\n   * @description The list of suggestions to display in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() suggestionsList: any[] = [];\n\n  /**\n   * @property disabled\n   * @description If `true`, the autocomplete is disabled.\n   * @memberof AutocompleteComponent\n   */\n  @Input() disabled = false;\n\n  /**\n   * @property allowAdd\n   * @description If `true`, allows adding new values to the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() allowAdd = true;\n\n  /**\n   * @property textField\n   * @description The field to be used as the display text in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() textField = '';\n\n  /**\n   * @property valueField\n   * @description The field to be used as the value in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() valueField = '';\n\n  /**\n   * @property label\n   * @description The label for the autocomplete input.\n   * @memberof AutocompleteComponent\n   */\n  @Input() label = '';\n\n  /**\n   * @property value\n   * @description The selected value(s) in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() set itemValue(v: any) {\n    this.value = AutocompleteUtils.isArray(v) ? v : [v];\n  }\n\n  /**\n   * @property type\n   * @description The type of the autocomplete ('single', 'multi', etc.).\n   * @memberof AutocompleteComponent\n   */\n  @Input() type: AutocompleteType = 'multi';\n\n  /**\n   * @property minCharactersSearch\n   * @description The minimum characters to trigger search.\n   * @memberof AutocompleteComponent\n   */\n  @Input() minCharactersSearch = 3;\n\n  /**\n   * @property variant\n   * @description The variant of Autocomplete\n   * @memberof AutocompleteComponent\n   */\n  @Input({ required: true }) variant = DropdownVariation.AUTOCOMPLETE;\n\n  /**\n   * The language to be used\n   * @property language\n   * @type {Language}\n   * @memberof AutocompleteComponent\n   */\n  @Input() language = LanguageService.defaultLanguage;\n\n  /**\n   * Show reserved content below form field\n   * @property showBottomContent\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() showBottomContent = true;\n\n  /**\n   * Return full object if true\n   * @property valuePrimitive\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() valuePrimitive = false;\n\n  /**\n   * Indicator of the autocomplete width\n   * @property fullWidth\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() fullWidth = false;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof AutocompleteComponent\n   */\n  @HostBinding('attr.theme')\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Autocomplete is required or not\n   *\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() required: boolean;\n\n  /**\n   * Input field errors\n   *\n   * @type {string[]}\n   * @memberof AutocompleteComponent\n   */\n  @Input() set errors(errors: string[]) {\n    this.safeErrors = errors.filter(Boolean).map(error => this.domSanitizer.bypassSecurityTrustHtml(error));\n  }\n\n  @Output() selectionChange = new EventEmitter<any>();\n  @Output() searchTextChange = new EventEmitter<string>();\n\n  @ViewChild('formField') formFieldElement: ElementRef<HTMLElement>;\n  @ViewChild('tagContainer') tagContainer: ElementRef<HTMLElement>;\n  @ViewChild('trigger') autocomplete: MatAutocompleteTrigger;\n\n  protected safeErrors: SafeHtml[] = [];\n  protected value: any;\n  protected inputValue: any = '';\n  protected isInputFocus = false;\n  protected autocompleteType = Autocomplete;\n  protected isOverLapping = false;\n  protected isOverlapChecking = true;\n  protected overlapIndex = 0;\n  protected inputValueSearch$ = new ReplaySubject<string>(1);\n  protected userInput$ = new ReplaySubject<string>(1);\n  protected filteredItemsList$ = this.inputValueSearch$.pipe(\n    startWith(''),\n    map(inputValue =>\n      inputValue.length ? AutocompleteUtils.filterItems(this.itemsList, inputValue, this.textField) : null\n    )\n  );\n  protected filteredSuggestionList$ = this.inputValueSearch$.pipe(\n    map(inputValue =>\n      inputValue.length ? AutocompleteUtils.filterItems(this.suggestionsList, inputValue, this.textField) : null\n    )\n  );\n  protected searchResult$ = this.inputValueSearch$.pipe(map(inputValue => !!inputValue.trim()));\n  protected translationContext = 'AUTOCOMPLETE.';\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly domSanitizer: DomSanitizer,\n    @Optional() @Self() public ngControl: NgControl\n  ) {\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  /**\n   * Used to mark component view as dirty when touched programmatically with markAsTouched/markAllAsTouched\n   * to display validation errors that might happen (e.g. required)\n   */\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngDoCheck(): void {\n    if (this.ngControl?.touched) {\n      this.cdr.markForCheck();\n    }\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnChanges(): void {\n    this.itemsList = AutocompleteUtils.excludeSuggestions(this.itemsList, this.suggestionsList, this.valueField);\n    this.initValue();\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngAfterViewInit(): void {\n    if (this.type !== Autocomplete.LARGE) {\n      this.checkOverlap(Timeout.VIEW_INITIALIZED_COMPONENT_LOAD, true);\n    }\n  }\n\n  onChange = (_: any) => {};\n  onTouch = () => {};\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  writeValue(value: any): void {\n    if (this.valuePrimitive && this.textField && this.valueField) {\n      if (this.type === Autocomplete.SINGLE) {\n        this.value = this.itemsList.find(item => item[this.valueField] === value);\n      } else {\n        this.value = [this.itemsList.find(item => item[this.valueField] === value)];\n      }\n    } else {\n      this.value = value;\n    }\n    this.initValue();\n  }\n\n  protected onOptionSelected(event: MatAutocompleteSelectedEvent): void {\n    const inputValue = event.option.value;\n    const itemValue = AutocompleteUtils.createValueItem(inputValue, this.textField, this.valueField);\n    this.addNewValue(itemValue);\n\n    if (this.type === this.autocompleteType.MULTI) {\n      this.checkOverlap();\n    }\n\n    queueMicrotask(() => {\n      if (this.type !== this.autocompleteType.SINGLE) {\n        this.inputValue = '';\n      } else {\n        this.inputValue = AutocompleteUtils.transformDisplayValue(this.value, this.textField);\n      }\n      this.cdr.markForCheck();\n    });\n\n    this.onUpdate();\n  }\n\n  protected onOptionRemoved(option: any): void {\n    setTimeout(() => this.autocomplete.closePanel(), 0);\n    const foundValue = this.value.find((v: any) => v === option);\n\n    if (foundValue) {\n      this.value = this.value.filter((v: any) => v !== option);\n    }\n\n    if (this.type === this.autocompleteType.MULTI) {\n      this.checkOverlap();\n    }\n\n    if (!this.value.length) {\n      this.inputValue = '';\n    }\n\n    this.onUpdate();\n  }\n\n  protected onInputChange(event: Event): void {\n    const inputValue = (event.target as HTMLInputElement).value;\n    this.userInput$.next(inputValue);\n    if (inputValue.length >= this.minCharactersSearch) {\n      this.inputValueSearch$.next(inputValue);\n      this.searchTextChange.emit(inputValue);\n    } else {\n      this.inputValueSearch$.next('');\n    }\n  }\n\n  protected onClear(): void {\n    this.inputValue = '';\n    this.value = AutocompleteUtils.isArray(this.value) ? [] : '';\n    this.isOverLapping = false;\n    this.overlapIndex = 0;\n    this.onUpdate();\n  }\n\n  protected refillInput(): void {\n    if (this.value && this.type === this.autocompleteType.SINGLE && !this.inputValue) {\n      this.inputValue = AutocompleteUtils.transformDisplayValue(this.value, this.textField);\n      this.inputValueSearch$.next('');\n    }\n\n    if (!this.inputValue && this.value?.length) {\n      this.inputValue = ' ';\n    }\n\n    this.isInputFocus = false;\n  }\n\n  protected onFocus(): void {\n    this.isInputFocus = true;\n\n    const inputValue = AutocompleteUtils.isArray(this.inputValue) ? this.inputValue[0] : this.inputValue;\n\n    if (AutocompleteUtils.isPrimitive(inputValue)) {\n      if (inputValue?.match(/^\\s+/gm)) {\n        this.inputValue = inputValue.trimStart();\n      }\n    } else {\n      if (inputValue[this.textField]?.match(/^\\s+/gm)) {\n        this.inputValue = inputValue[this.textField].trimStart();\n      }\n    }\n  }\n\n  private checkOverlap(delay = Timeout.VIEW_INITIALIZED_AFTER_ACTION, init = false): void {\n    this.isOverLapping = false;\n    this.isOverlapChecking = true;\n\n    setTimeout(() => {\n      const inputWidth = this.inputWidth;\n      const tags = this.tagContainer?.nativeElement.querySelectorAll('.value-tag');\n      if (tags) {\n        let width = 0;\n        let firstTagWidth = 0;\n\n        tags.forEach((tag: any, index: number) => {\n          width += tag.getBoundingClientRect().width;\n\n          if (!index) {\n            firstTagWidth = width;\n          }\n\n          if (!this.isOverLapping && width > inputWidth) {\n            this.isOverLapping = true;\n            this.overlapIndex = index;\n          }\n\n          if (firstTagWidth > inputWidth) {\n            this.overlapIndex = 0;\n          }\n        });\n        this.isOverlapChecking = false;\n        if (init) {\n          if (this.type === this.autocompleteType.SINGLE) {\n            this.inputValue = AutocompleteUtils.transformDisplayValue(this.value[0], this.textField);\n          } else {\n            this.inputValue = ' ';\n          }\n        }\n        this.cdr.markForCheck();\n      }\n    }, delay);\n  }\n\n  private onUpdate(): void {\n    this.inputValueSearch$.next('');\n    this.userInput$.next('');\n    this.selectionChange.emit(this.value);\n    if (!this.valuePrimitive) {\n      this.onChange(this.value);\n    } else {\n      if (this.type === Autocomplete.SINGLE) {\n        this.onChange(this.value[this.valueField]);\n      } else {\n        this.onChange(this.value.map((v: any) => v[this.valueField]));\n      }\n    }\n  }\n\n  private initValue(): void {\n    if (this.type === this.autocompleteType.SINGLE && this.variant !== DropdownVariation.DROPDOWN) {\n      if (AutocompleteUtils.isArray(this.value)) {\n        this.inputValue = AutocompleteUtils.transformDisplayValue(this.value[0], this.textField);\n      } else {\n        this.inputValue = this.value ? AutocompleteUtils.transformDisplayValue(this.value, this.textField) : '';\n      }\n    } else if (this.variant === DropdownVariation.DROPDOWN) {\n      this.inputValue = this.value ? AutocompleteUtils.transformDisplayValue(this.value, this.textField) : '';\n    } else {\n      this.inputValue = this.value?.length ? '' : ' ';\n    }\n    if (this.type === this.autocompleteType.MULTI) {\n      this.checkOverlap();\n    }\n  }\n\n  private addNewValue(newValue: any): void {\n    if (this.type !== this.autocompleteType.SINGLE && !this.value) {\n      this.value = [];\n    }\n\n    const foundDuplicate = AutocompleteUtils.findDuplicate(this.value, newValue, this.textField);\n\n    if (this.type !== this.autocompleteType.SINGLE) {\n      this.value = foundDuplicate ? this.value.filter((v: any) => v !== foundDuplicate) : [...this.value, newValue];\n    } else {\n      this.value = newValue;\n    }\n  }\n\n  protected get isDropdown(): boolean {\n    return this.variant === DropdownVariation.DROPDOWN;\n  }\n\n  protected onChevronClick(autocomplete: MatAutocomplete): void {\n    if (autocomplete.isOpen) {\n      setTimeout(() => {\n        this.autocomplete.closePanel();\n      }, 0);\n    }\n  }\n\n  protected get inputWidth(): number {\n    return (\n      this.formFieldElement?.nativeElement.getBoundingClientRect().width -\n      (this.isDropdown ? Padding.DROPDOWN_CONTAINER : Padding.AUTOCOMPLETE_CONTAINER)\n    );\n  }\n\n  protected trackByFn = (index: number, value: any) => value.changingThisBreaksApplicationSecurity;\n}\n","<ng-container>\n  <div class=\"autocomplete-wrapper\" [ngClass]=\"{ 'full-width': fullWidth, disabled: disabled }\">\n    <mat-form-field\n      [color]=\"(safeErrors.length || (ngControl?.errors && ngControl?.touched )) ? 'warn' : 'accent'\"\n      [appearance]=\"'outline'\"\n      [ngClass]=\"{ 'large-size': type === autocompleteType.LARGE, 'hide-bottom-content': !showBottomContent }\"\n    >\n      <mat-label *ngIf=\"label\">{{ label }} <span *ngIf=\"required\">*</span></mat-label>\n      <div #formField class=\"input-container\">\n        <div\n          class=\"selected-items\"\n          #tagContainer\n          *ngIf=\"\n            (type === autocompleteType.LARGE && this.value) ||\n            (!(inputValue && this.isInputFocus) && this.value && type !== autocompleteType.SINGLE)\n          \"\n        >\n          <ui-tag\n            class=\"value-tag\"\n            [id]=\"'ui-tag-' + i\"\n            *ngFor=\"let valueItem of value; let i = index\"\n            [label]=\"valueItem | transformItem: textField\"\n            [allowClose]=\"true\"\n            [applicationTheme]=\"applicationTheme\"\n            [style.display]=\"isOverLapping && i >= overlapIndex ? 'none' : 'block'\"\n            [ngClass]=\"{\n              'overlap-tag': isOverlapChecking && overlapIndex && i >= overlapIndex && type === autocompleteType.MULTI\n            }\"\n            (close)=\"onOptionRemoved(valueItem)\"\n          ></ui-tag>\n          <ng-container *ngIf=\"isOverLapping\">\n            <div *ngIf=\"!overlapIndex; else overlapTag\" class=\"overlap-count\">\n              {{ (translationContext + 'SELECTED_AMOUNT') | uiTranslate : language : { numberSelected: (value | slice: overlapIndex).length } }}\n            </div>\n            <ng-template #overlapTag>\n              <ui-tag [applicationTheme]=\"applicationTheme\" [readOnly]=\"true\" [label]=\"'+' + (value | slice: overlapIndex).length\"></ui-tag>\n            </ng-template>\n          </ng-container>\n        </div>\n        <input\n          #trigger=\"matAutocompleteTrigger\"\n          [disabled]=\"disabled\"\n          [ngClass]=\"{ 'unset-margin': this.value && type === autocompleteType.LARGE }\"\n          (blur)=\"refillInput()\"\n          (focusin)=\"onFocus()\"\n          matInput\n          [type]=\"'text'\"\n          [matAutocomplete]=\"autocomplete\"\n          (input)=\"onInputChange($event)\"\n          [(ngModel)]=\"inputValue\"\n        />\n      </div>\n\n      <ui-icon\n        class=\"remove-selected\"\n        [ngClass]=\"{ 'large-input-icon': type === autocompleteType.LARGE }\"\n        (click)=\"onClear()\"\n        [size]=\"'24'\"\n        [color]=\"applicationTheme === 'classic' ? 'inherit' : 'rebrand-black'\"\n        [name]=\"applicationTheme === 'classic' ? 'Close' : 'Close-in-line'\"\n      ></ui-icon>\n\n      <ui-icon\n        class=\"arrow-state\"\n        [ngClass]=\"{ opened: autocomplete.isOpen, 'large-input-icon': type === autocompleteType.LARGE }\"\n        *ngIf=\"isDropdown\"\n        [size]=\"'24'\"\n        [name]=\"'Arrow_down'\"\n        (click)=\"onChevronClick(autocomplete)\"\n      ></ui-icon>\n\n      <mat-autocomplete\n        #autocomplete\n        [class]=\"applicationTheme\"\n        (optionSelected)=\"onOptionSelected($event)\"\n        [disableRipple]=\"applicationTheme !== 'classic'\"\n        [hideSingleSelectionIndicator]=\"false\"\n      >\n        <ng-container *ngIf=\"!(searchResult$ | async)\">\n          <ng-container *ngIf=\"!isDropdown; else dropdownList\">\n            <mat-optgroup [label]=\"(translationContext + 'SUGGESTED') | uiTranslate : language | uppercase\" *ngIf=\"suggestionsList.length\">\n              <mat-option\n                [ngClass]=\"{ 'selected-option': suggested | includes: value }\"\n                *ngFor=\"let suggested of suggestionsList\"\n                [value]=\"suggested\"\n              >\n                <span [selectText]=\"userInput$ | async\">{{ suggested | transformItem: textField }}</span>\n                <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n              </mat-option>\n            </mat-optgroup>\n\n            <mat-optgroup [label]=\"(translationContext + 'SELECTED') | uiTranslate : language | uppercase\" *ngIf=\"value?.length && type !== autocompleteType.SINGLE\">\n              <mat-option\n                [ngClass]=\"{ 'selected-option': item | includes: value }\"\n                *ngFor=\"let item of value\"\n                [value]=\"item\"\n              >\n                <span>{{ item | transformItem: textField }}</span>\n                <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n              </mat-option>\n            </mat-optgroup>\n\n            <mat-optgroup [label]=\"(translationContext + 'SELECTED') | uiTranslate : language | uppercase\" *ngIf=\"value?.length && type === autocompleteType.SINGLE\">\n              <mat-option\n                [class]=\"'selected-option'\"\n                [value]=\"value\"\n              >\n                <span [selectText]=\"userInput$ | async\">{{ value | transformItem: textField }}</span>\n                <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n              </mat-option>\n            </mat-optgroup>\n          </ng-container>\n\n          <ng-template #dropdownList>\n            <mat-option\n              [ngClass]=\"{ 'selected-option': item | includes: value }\"\n              *ngFor=\"let item of itemsList\"\n              [value]=\"item\"\n            >\n              <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n              <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n            </mat-option>\n          </ng-template>\n\n        </ng-container>\n\n        <ng-container *ngIf=\"filteredSuggestionList$ | async as filteredSuggestionList\">\n          <ng-container *ngIf=\"filteredItemsList$ | async as filteredItemsList\">\n            <mat-optgroup [label]=\"(translationContext + 'SUGGESTED') | uiTranslate : language | uppercase\" *ngIf=\"filteredSuggestionList.length\">\n              <mat-option\n                [ngClass]=\"{ 'selected-option': item | includes: value }\"\n                *ngFor=\"let item of filteredSuggestionList\"\n                [value]=\"item\"\n              >\n                <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n              </mat-option>\n            </mat-optgroup>\n\n            <ng-container *ngIf=\"!filteredSuggestionList.length; else showItemListWithGroup\">\n              <mat-option\n                [ngClass]=\"{ 'selected-option': item | includes: value }\"\n                *ngFor=\"let item of filteredItemsList\"\n                [value]=\"item\"\n              >\n                <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n              </mat-option>\n            </ng-container>\n\n            <ng-template #showItemListWithGroup>\n              <mat-optgroup [label]=\"(translationContext + 'ALL_ITEMS') | uiTranslate : language | uppercase\" *ngIf=\"filteredItemsList.length\">\n                <mat-option\n                  [ngClass]=\"{ 'selected-option': item | includes: value }\"\n                  *ngFor=\"let item of filteredItemsList\"\n                  [value]=\"item\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n                </mat-option>\n              </mat-optgroup>\n            </ng-template>\n\n            <ng-container *ngIf=\"!filteredItemsList.length && !filteredSuggestionList.length && inputValue\">\n              <ng-container *ngIf=\"allowAdd && !isDropdown; else notFound\">\n                <mat-option [value]=\"inputValue\">\n                  <span>{{ ('COMMON.ADD') | uiTranslate : language }}</span>\n                  <span class=\"add-suggestion\">\"{{ inputValue }}\"</span>\n                </mat-option>\n              </ng-container>\n\n              <ng-template #notFound>\n                <mat-option [style.pointer-events]=\"'none'\">\n                  <span>{{ (translationContext + 'NO_RESULTS_FOUND') | uiTranslate : language }}</span>\n                </mat-option>\n              </ng-template>\n            </ng-container>\n          </ng-container>\n        </ng-container>\n      </mat-autocomplete>\n      <mat-hint class=\"error\" *ngIf=\"safeErrors.length || ngControl?.errors\">\n        <ng-container *ngIf=\"safeErrors.length\">\n          <div class=\"errors\" *ngFor=\"let error of safeErrors; trackBy: trackByFn\">\n            <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\n            <span [innerHTML]=\"error\"></span>\n          </div>\n        </ng-container>\n\n        <ui-validation-error *ngIf=\"ngControl\" [ngControl]=\"ngControl\" [label]=\"label\" [language]=\"language\"></ui-validation-error>\n\n      </mat-hint>\n    </mat-form-field>\n  </div>\n</ng-container>\n"]}
450
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../src/components/autocomplete/autocomplete.component.ts","../../../../../src/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  Self,\n  ViewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { MatAutocomplete, MatAutocompleteSelectedEvent, MatAutocompleteTrigger } from '@angular/material/autocomplete';\nimport { map, ReplaySubject, startWith } from 'rxjs';\nimport { AutocompleteUtils } from '../../utils/autocomplete-utils';\nimport { Autocomplete, AutocompleteType, DropdownVariation, Padding, Timeout } from './autocomplete.model';\nimport { LanguageService } from '../../utils/localization/language.service';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\n@Component({\n  selector: 'ui-autocomplete',\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['./autocomplete.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\n// eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\nexport class AutocompleteComponent implements ControlValueAccessor, OnChanges, AfterViewInit, DoCheck {\n  /**\n   * @property itemsList\n   * @description The list of items to display in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() itemsList: any[] = [];\n\n  /**\n   * @property suggestionsList\n   * @description The list of suggestions to display in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() suggestionsList: any[] = [];\n\n  /**\n   * @property disabled\n   * @description If `true`, the autocomplete is disabled.\n   * @memberof AutocompleteComponent\n   */\n  @Input() disabled = false;\n\n  /**\n   * @property allowAdd\n   * @description If `true`, allows adding new values to the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() allowAdd = true;\n\n  /**\n   * @property textField\n   * @description The field to be used as the display text in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() textField = '';\n\n  /**\n   * @property valueField\n   * @description The field to be used as the value in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() valueField = '';\n\n  /**\n   * @property label\n   * @description The label for the autocomplete input.\n   * @memberof AutocompleteComponent\n   */\n  @Input() label = '';\n\n  /**\n   * @property value\n   * @description The selected value(s) in the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() set itemValue(v: any) {\n    this.value = AutocompleteUtils.isArray(v) ? v : [v];\n  }\n\n  /**\n   * @property type\n   * @description The type of the autocomplete ('single', 'multi', etc.).\n   * @memberof AutocompleteComponent\n   */\n  @Input() type: AutocompleteType = 'multi';\n\n  /**\n   * @property minCharactersSearch\n   * @description The minimum characters to trigger search.\n   * @memberof AutocompleteComponent\n   */\n  @Input() minCharactersSearch = 3;\n\n  /**\n   * @property variant\n   * @description The variant of Autocomplete\n   * @memberof AutocompleteComponent\n   */\n  @Input({ required: true }) variant = DropdownVariation.AUTOCOMPLETE;\n\n  /**\n   * The language to be used\n   * @property language\n   * @type {Language}\n   * @memberof AutocompleteComponent\n   */\n  @Input() language = LanguageService.defaultLanguage;\n\n  /**\n   * Show reserved content below form field\n   * @property showBottomContent\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() showBottomContent = true;\n\n  /**\n   * Return full object if true\n   * @property valuePrimitive\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() valuePrimitive = false;\n\n  /**\n   * Indicator of the autocomplete width\n   * @property fullWidth\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() fullWidth = false;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof AutocompleteComponent\n   */\n  @HostBinding('attr.theme')\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Autocomplete is required or not\n   *\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() required: boolean;\n\n  /**\n   * Input field errors\n   *\n   * @type {string[]}\n   * @memberof AutocompleteComponent\n   */\n  @Input() set errors(errors: string[]) {\n    this.safeErrors = errors.filter(Boolean).map(error => this.domSanitizer.bypassSecurityTrustHtml(error));\n  }\n\n  @Output() selectionChange = new EventEmitter<any>();\n  @Output() searchTextChange = new EventEmitter<string>();\n\n  @ViewChild('formField') formFieldElement: ElementRef<HTMLElement>;\n  @ViewChild('tagContainer') tagContainer: ElementRef<HTMLElement>;\n  @ViewChild('trigger') autocomplete: MatAutocompleteTrigger;\n\n  protected safeErrors: SafeHtml[] = [];\n  protected value: any;\n  protected inputValue: any = '';\n  protected isInputFocus = false;\n  protected autocompleteType = Autocomplete;\n  protected isOverLapping = false;\n  protected isOverlapChecking = true;\n  protected overlapIndex = 0;\n  protected inputValueSearch$ = new ReplaySubject<string>(1);\n  protected userInput$ = new ReplaySubject<string>(1);\n  protected filteredItemsList$ = this.inputValueSearch$.pipe(\n    startWith(''),\n    map(inputValue =>\n      inputValue.length ? AutocompleteUtils.filterItems(this.itemsList, inputValue, this.textField) : null\n    )\n  );\n  protected filteredSuggestionList$ = this.inputValueSearch$.pipe(\n    map(inputValue =>\n      inputValue.length ? AutocompleteUtils.filterItems(this.suggestionsList, inputValue, this.textField) : null\n    )\n  );\n  protected searchResult$ = this.inputValueSearch$.pipe(map(inputValue => !!inputValue.trim()));\n  protected translationContext = 'AUTOCOMPLETE.';\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly domSanitizer: DomSanitizer,\n    @Optional() @Self() public ngControl: NgControl\n  ) {\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  /**\n   * Used to mark component view as dirty when touched programmatically with markAsTouched/markAllAsTouched\n   * to display validation errors that might happen (e.g. required)\n   */\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngDoCheck(): void {\n    if (this.ngControl?.touched) {\n      this.cdr.markForCheck();\n    }\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnChanges(): void {\n    this.itemsList = AutocompleteUtils.excludeSuggestions(this.itemsList, this.suggestionsList, this.valueField);\n    this.initValue();\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngAfterViewInit(): void {\n    if (this.type !== Autocomplete.LARGE) {\n      this.checkOverlap(Timeout.VIEW_INITIALIZED_COMPONENT_LOAD, true);\n    }\n  }\n\n  onChange = (_: any) => {};\n  onTouch = () => {};\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  writeValue(value: any): void {\n    if (this.valuePrimitive && this.textField && this.valueField) {\n      if (this.type === Autocomplete.SINGLE) {\n        this.value = this.itemsList.find(item => item[this.valueField] === value);\n      } else {\n        this.value = [this.itemsList.find(item => item[this.valueField] === value)];\n      }\n    } else {\n      this.value = value;\n    }\n    this.initValue();\n  }\n\n  protected onOptionSelected(event: MatAutocompleteSelectedEvent): void {\n    const inputValue = event.option.value;\n    const itemValue = AutocompleteUtils.createValueItem(inputValue, this.textField, this.valueField);\n    this.addNewValue(itemValue);\n\n    if (this.type === this.autocompleteType.MULTI) {\n      this.checkOverlap();\n    }\n\n    queueMicrotask(() => {\n      if (this.type !== this.autocompleteType.SINGLE) {\n        this.inputValue = '';\n      } else {\n        this.inputValue = AutocompleteUtils.transformDisplayValue(this.value, this.textField);\n      }\n      this.cdr.markForCheck();\n    });\n\n    this.onUpdate();\n  }\n\n  protected onOptionRemoved(option: any): void {\n    setTimeout(() => this.autocomplete.closePanel(), 0);\n    const foundValue = this.value.find((v: any) => v === option);\n\n    if (foundValue) {\n      this.value = this.value.filter((v: any) => v !== option);\n    }\n\n    if (this.type === this.autocompleteType.MULTI) {\n      this.checkOverlap();\n    }\n\n    if (!this.value.length) {\n      this.inputValue = '';\n    }\n\n    this.onUpdate();\n  }\n\n  protected onInputChange(event: Event): void {\n    const inputValue = (event.target as HTMLInputElement).value;\n    this.userInput$.next(inputValue);\n    if (inputValue.length >= this.minCharactersSearch) {\n      this.inputValueSearch$.next(inputValue);\n      this.searchTextChange.emit(inputValue);\n    } else {\n      this.inputValueSearch$.next('');\n    }\n  }\n\n  protected onClear(): void {\n    this.inputValue = '';\n    this.value = AutocompleteUtils.isArray(this.value) ? [] : '';\n    this.isOverLapping = false;\n    this.overlapIndex = 0;\n    this.onUpdate();\n  }\n\n  protected refillInput(): void {\n    if (this.value && this.type === this.autocompleteType.SINGLE && !this.inputValue) {\n      this.inputValue = AutocompleteUtils.transformDisplayValue(this.value, this.textField);\n      this.inputValueSearch$.next('');\n    }\n\n    if (!this.inputValue && this.value?.length) {\n      this.inputValue = ' ';\n    }\n\n    this.isInputFocus = false;\n  }\n\n  protected onFocus(): void {\n    this.isInputFocus = true;\n\n    const inputValue = AutocompleteUtils.isArray(this.inputValue) ? this.inputValue[0] : this.inputValue;\n\n    if (AutocompleteUtils.isPrimitive(inputValue)) {\n      if (inputValue?.match(/^\\s+/gm)) {\n        this.inputValue = inputValue.trimStart();\n      }\n    } else {\n      if (inputValue[this.textField]?.match(/^\\s+/gm)) {\n        this.inputValue = inputValue[this.textField].trimStart();\n      }\n    }\n  }\n\n  private checkOverlap(delay = Timeout.VIEW_INITIALIZED_AFTER_ACTION, init = false): void {\n    this.isOverLapping = false;\n    this.isOverlapChecking = true;\n\n    setTimeout(() => {\n      const inputWidth = this.inputWidth;\n      const tags = this.tagContainer?.nativeElement.querySelectorAll('.value-tag');\n      if (tags) {\n        let width = 0;\n        let firstTagWidth = 0;\n\n        tags.forEach((tag: any, index: number) => {\n          width += tag.getBoundingClientRect().width;\n\n          if (!index) {\n            firstTagWidth = width;\n          }\n\n          if (!this.isOverLapping && width > inputWidth) {\n            this.isOverLapping = true;\n            this.overlapIndex = index;\n          }\n\n          if (firstTagWidth > inputWidth) {\n            this.overlapIndex = 0;\n          }\n        });\n        this.isOverlapChecking = false;\n        if (init) {\n          if (this.type === this.autocompleteType.SINGLE) {\n            this.inputValue = AutocompleteUtils.transformDisplayValue(this.value[0], this.textField);\n          } else {\n            this.inputValue = ' ';\n          }\n        }\n        this.cdr.markForCheck();\n      }\n    }, delay);\n  }\n\n  private onUpdate(): void {\n    this.inputValueSearch$.next('');\n    this.userInput$.next('');\n    if (!this.valuePrimitive) {\n      this.onChange(this.value);\n    } else {\n      if (this.type === Autocomplete.SINGLE) {\n        this.onChange(this.value[this.valueField]);\n      } else {\n        this.onChange(this.value.map((v: any) => v[this.valueField]));\n      }\n    }\n    this.selectionChange.emit(this.value);\n  }\n\n  private initValue(): void {\n    if (this.type === this.autocompleteType.SINGLE && this.variant !== DropdownVariation.DROPDOWN) {\n      if (AutocompleteUtils.isArray(this.value)) {\n        this.inputValue = AutocompleteUtils.transformDisplayValue(this.value[0], this.textField);\n      } else {\n        this.inputValue = this.value ? AutocompleteUtils.transformDisplayValue(this.value, this.textField) : '';\n      }\n    } else if (this.variant === DropdownVariation.DROPDOWN) {\n      this.inputValue = this.value ? AutocompleteUtils.transformDisplayValue(this.value, this.textField) : '';\n    } else {\n      this.inputValue = this.value?.length ? '' : ' ';\n    }\n    if (this.type === this.autocompleteType.MULTI) {\n      this.checkOverlap();\n    }\n  }\n\n  private addNewValue(newValue: any): void {\n    if (this.type !== this.autocompleteType.SINGLE && !this.value) {\n      this.value = [];\n    }\n\n    const foundDuplicate = AutocompleteUtils.findDuplicate(this.value, newValue, this.textField);\n\n    if (this.type !== this.autocompleteType.SINGLE) {\n      this.value = foundDuplicate ? this.value.filter((v: any) => v !== foundDuplicate) : [...this.value, newValue];\n    } else {\n      this.value = newValue;\n    }\n  }\n\n  protected get isDropdown(): boolean {\n    return this.variant === DropdownVariation.DROPDOWN;\n  }\n\n  protected onChevronClick(autocomplete: MatAutocomplete): void {\n    if (autocomplete.isOpen) {\n      setTimeout(() => {\n        this.autocomplete.closePanel();\n      }, 0);\n    }\n  }\n\n  protected get inputWidth(): number {\n    return (\n      this.formFieldElement?.nativeElement.getBoundingClientRect().width -\n      (this.isDropdown ? Padding.DROPDOWN_CONTAINER : Padding.AUTOCOMPLETE_CONTAINER)\n    );\n  }\n\n  protected trackByFn = (index: number, value: any) => value.changingThisBreaksApplicationSecurity;\n}\n","<ng-container>\n  <div class=\"autocomplete-wrapper\" [ngClass]=\"{ 'full-width': fullWidth, disabled: disabled }\">\n    <mat-form-field\n      [color]=\"(safeErrors.length || (ngControl?.errors && ngControl?.touched )) ? 'warn' : 'accent'\"\n      [appearance]=\"'outline'\"\n      [ngClass]=\"{ 'large-size': type === autocompleteType.LARGE, 'hide-bottom-content': !showBottomContent }\"\n    >\n      <mat-label *ngIf=\"label\">{{ label }} <span *ngIf=\"required\">*</span></mat-label>\n      <div #formField class=\"input-container\">\n        <div\n          class=\"selected-items\"\n          #tagContainer\n          *ngIf=\"\n            (type === autocompleteType.LARGE && this.value) ||\n            (!(inputValue && this.isInputFocus) && this.value && type !== autocompleteType.SINGLE)\n          \"\n        >\n          <ui-tag\n            class=\"value-tag\"\n            [id]=\"'ui-tag-' + i\"\n            *ngFor=\"let valueItem of value; let i = index\"\n            [label]=\"valueItem | transformItem: textField\"\n            [allowClose]=\"true\"\n            [applicationTheme]=\"applicationTheme\"\n            [style.display]=\"isOverLapping && i >= overlapIndex ? 'none' : 'block'\"\n            [ngClass]=\"{\n              'overlap-tag': isOverlapChecking && overlapIndex && i >= overlapIndex && type === autocompleteType.MULTI\n            }\"\n            (close)=\"onOptionRemoved(valueItem)\"\n          ></ui-tag>\n          <ng-container *ngIf=\"isOverLapping\">\n            <div *ngIf=\"!overlapIndex; else overlapTag\" class=\"overlap-count\">\n              {{ (translationContext + 'SELECTED_AMOUNT') | uiTranslate : language : { numberSelected: (value | slice: overlapIndex).length } }}\n            </div>\n            <ng-template #overlapTag>\n              <ui-tag [applicationTheme]=\"applicationTheme\" [readOnly]=\"true\" [label]=\"'+' + (value | slice: overlapIndex).length\"></ui-tag>\n            </ng-template>\n          </ng-container>\n        </div>\n        <input\n          #trigger=\"matAutocompleteTrigger\"\n          [disabled]=\"disabled\"\n          [ngClass]=\"{ 'unset-margin': this.value && type === autocompleteType.LARGE }\"\n          (blur)=\"refillInput()\"\n          (focusin)=\"onFocus()\"\n          matInput\n          [type]=\"'text'\"\n          [matAutocomplete]=\"autocomplete\"\n          (input)=\"onInputChange($event)\"\n          [(ngModel)]=\"inputValue\"\n        />\n      </div>\n\n      <ui-icon\n        class=\"remove-selected\"\n        [ngClass]=\"{ 'large-input-icon': type === autocompleteType.LARGE }\"\n        (click)=\"onClear()\"\n        [size]=\"'24'\"\n        [color]=\"applicationTheme === 'classic' ? 'inherit' : 'rebrand-black'\"\n        [name]=\"applicationTheme === 'classic' ? 'Close' : 'Close-in-line'\"\n      ></ui-icon>\n\n      <ui-icon\n        class=\"arrow-state\"\n        [ngClass]=\"{ opened: autocomplete.isOpen, 'large-input-icon': type === autocompleteType.LARGE }\"\n        *ngIf=\"isDropdown\"\n        [size]=\"'24'\"\n        [name]=\"'Arrow_down'\"\n        (click)=\"onChevronClick(autocomplete)\"\n      ></ui-icon>\n\n      <mat-autocomplete\n        #autocomplete\n        [class]=\"applicationTheme\"\n        (optionSelected)=\"onOptionSelected($event)\"\n        [disableRipple]=\"applicationTheme !== 'classic'\"\n        [hideSingleSelectionIndicator]=\"false\"\n      >\n        <ng-container *ngIf=\"!(searchResult$ | async)\">\n          <ng-container *ngIf=\"!isDropdown; else dropdownList\">\n            <mat-optgroup [label]=\"(translationContext + 'SUGGESTED') | uiTranslate : language | uppercase\" *ngIf=\"suggestionsList.length\">\n              <mat-option\n                [ngClass]=\"{ 'selected-option': suggested | includes: value }\"\n                *ngFor=\"let suggested of suggestionsList\"\n                [value]=\"suggested\"\n              >\n                <span [selectText]=\"userInput$ | async\">{{ suggested | transformItem: textField }}</span>\n                <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n              </mat-option>\n            </mat-optgroup>\n\n            <mat-optgroup [label]=\"(translationContext + 'SELECTED') | uiTranslate : language | uppercase\" *ngIf=\"value?.length && type !== autocompleteType.SINGLE\">\n              <mat-option\n                [ngClass]=\"{ 'selected-option': item | includes: value }\"\n                *ngFor=\"let item of value\"\n                [value]=\"item\"\n              >\n                <span>{{ item | transformItem: textField }}</span>\n                <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n              </mat-option>\n            </mat-optgroup>\n\n            <mat-optgroup [label]=\"(translationContext + 'SELECTED') | uiTranslate : language | uppercase\" *ngIf=\"value?.length && type === autocompleteType.SINGLE\">\n              <mat-option\n                [class]=\"'selected-option'\"\n                [value]=\"value\"\n              >\n                <span [selectText]=\"userInput$ | async\">{{ value | transformItem: textField }}</span>\n                <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n              </mat-option>\n            </mat-optgroup>\n          </ng-container>\n\n          <ng-template #dropdownList>\n            <mat-option\n              [ngClass]=\"{ 'selected-option': item | includes: value }\"\n              *ngFor=\"let item of itemsList\"\n              [value]=\"item\"\n            >\n              <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n              <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n            </mat-option>\n          </ng-template>\n\n        </ng-container>\n\n        <ng-container *ngIf=\"filteredSuggestionList$ | async as filteredSuggestionList\">\n          <ng-container *ngIf=\"filteredItemsList$ | async as filteredItemsList\">\n            <mat-optgroup [label]=\"(translationContext + 'SUGGESTED') | uiTranslate : language | uppercase\" *ngIf=\"filteredSuggestionList.length\">\n              <mat-option\n                [ngClass]=\"{ 'selected-option': item | includes: value }\"\n                *ngFor=\"let item of filteredSuggestionList\"\n                [value]=\"item\"\n              >\n                <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n              </mat-option>\n            </mat-optgroup>\n\n            <ng-container *ngIf=\"!filteredSuggestionList.length; else showItemListWithGroup\">\n              <mat-option\n                [ngClass]=\"{ 'selected-option': item | includes: value }\"\n                *ngFor=\"let item of filteredItemsList\"\n                [value]=\"item\"\n              >\n                <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n              </mat-option>\n            </ng-container>\n\n            <ng-template #showItemListWithGroup>\n              <mat-optgroup [label]=\"(translationContext + 'ALL_ITEMS') | uiTranslate : language | uppercase\" *ngIf=\"filteredItemsList.length\">\n                <mat-option\n                  [ngClass]=\"{ 'selected-option': item | includes: value }\"\n                  *ngFor=\"let item of filteredItemsList\"\n                  [value]=\"item\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n                </mat-option>\n              </mat-optgroup>\n            </ng-template>\n\n            <ng-container *ngIf=\"!filteredItemsList.length && !filteredSuggestionList.length && inputValue\">\n              <ng-container *ngIf=\"allowAdd && !isDropdown; else notFound\">\n                <mat-option [value]=\"inputValue\">\n                  <span>{{ ('COMMON.ADD') | uiTranslate : language }}</span>\n                  <span class=\"add-suggestion\">\"{{ inputValue }}\"</span>\n                </mat-option>\n              </ng-container>\n\n              <ng-template #notFound>\n                <mat-option [style.pointer-events]=\"'none'\">\n                  <span>{{ (translationContext + 'NO_RESULTS_FOUND') | uiTranslate : language }}</span>\n                </mat-option>\n              </ng-template>\n            </ng-container>\n          </ng-container>\n        </ng-container>\n      </mat-autocomplete>\n      <mat-hint class=\"error\" *ngIf=\"safeErrors.length || ngControl?.errors\">\n        <ng-container *ngIf=\"safeErrors.length\">\n          <div class=\"errors\" *ngFor=\"let error of safeErrors; trackBy: trackByFn\">\n            <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\n            <span [innerHTML]=\"error\"></span>\n          </div>\n        </ng-container>\n\n        <ui-validation-error *ngIf=\"ngControl\" [ngControl]=\"ngControl\" [label]=\"label\" [language]=\"language\"></ui-validation-error>\n\n      </mat-hint>\n    </mat-form-field>\n  </div>\n</ng-container>\n"]}
@@ -8633,7 +8633,6 @@ class AutocompleteComponent {
8633
8633
  onUpdate() {
8634
8634
  this.inputValueSearch$.next('');
8635
8635
  this.userInput$.next('');
8636
- this.selectionChange.emit(this.value);
8637
8636
  if (!this.valuePrimitive) {
8638
8637
  this.onChange(this.value);
8639
8638
  }
@@ -8645,6 +8644,7 @@ class AutocompleteComponent {
8645
8644
  this.onChange(this.value.map((v) => v[this.valueField]));
8646
8645
  }
8647
8646
  }
8647
+ this.selectionChange.emit(this.value);
8648
8648
  }
8649
8649
  initValue() {
8650
8650
  if (this.type === this.autocompleteType.SINGLE && this.variant !== DropdownVariation.DROPDOWN) {