@testgorilla/tgo-ui 2.24.13 → 2.24.14
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.
|
@@ -559,7 +559,7 @@ export class AutocompleteComponent {
|
|
|
559
559
|
* Adding company color variable to the body to style overlay container that's out of the component scope.
|
|
560
560
|
*/
|
|
561
561
|
setCompanyColorVariable() {
|
|
562
|
-
this.renderer2.
|
|
562
|
+
this.renderer2.setStyle(document.body, '--ui-autocomplete-option-color', `${this.companyColor}`);
|
|
563
563
|
}
|
|
564
564
|
subscriberDisplayChange() {
|
|
565
565
|
const autocompleteHostElement = this.el.nativeElement;
|
|
@@ -714,4 +714,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
714
714
|
type: ViewChild,
|
|
715
715
|
args: ['matInput']
|
|
716
716
|
}] } });
|
|
717
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/autocomplete/autocomplete.component.ts","../../../../../projects/tgo-canopy-ui/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\nimport { isPlatformBrowser } from '@angular/common';\nimport {\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DestroyRef,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  Optional,\n  Output,\n  PLATFORM_ID,\n  Renderer2,\n  Self,\n  signal,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { MatAutocomplete, MatAutocompleteSelectedEvent, MatAutocompleteTrigger } from '@angular/material/autocomplete';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { map, ReplaySubject, startWith } from 'rxjs';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { AutocompleteUtils } from '../../utils/autocomplete-utils';\nimport {\n  Autocomplete,\n  AutocompleteSize,\n  AutocompleteType,\n  DropdownVariation,\n  Padding,\n  Timeout,\n} from './autocomplete.model';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { FocusMonitor } from '@angular/cdk/a11y';\nimport { IKeyboardEvent } from '../../models/keyboard-events.model';\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, OnDestroy {\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 placeholder\n   * @description The placeholder for the autocomplete input.\n   * @memberof AutocompleteComponent\n   */\n  @Input() placeholder = '';\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 ? [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   * 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  @HostBinding('class.full-width')\n  @Input()\n  fullWidth = false;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof AutocompleteComponent\n   */\n  @HostBinding('attr.theme')\n  @Input()\n  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  /**\n   * Color of the option hover.\n   * Defaults to Test Gorilla primary color.\n   *\n   * @type {string}\n   * @memberof AutocompleteComponent\n   */\n  @Input() companyColor: string | null = '#FFF2FC';\n\n  /**\n   * Hide in-build errors for Reactive Forms\n   *\n   * @type {number}\n   * @memberof AutocompleteComponent\n   */\n  @Input() hideBuiltInErrors = false;\n\n  /**\n   * Hide label in errors\n   *\n   * @type {number}\n   * @memberof AutocompleteComponent\n   */\n  @Input() hideLabelInErrors = false;\n\n  /**\n   * Sets dropdown list to virtual scroll mode\n   *\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input({ transform: booleanAttribute }) virtualScroll = false;\n\n  /**\n   * @property compareWith\n   * @description Custom comparison logic for the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() compareWith: (a: any, b: any) => boolean;\n\n  /**\n   * @property dropdownPanelClass\n   * @description Sets class on autocomplete dropdown\n   * @memberof AutocompleteComponent\n   */\n  @Input() dropdownPanelClass = '';\n\n  /**\n   * @property closeOnScroll\n   * @description Defines if dropdown should be closed on page scroll\n   * @memberof AutocompleteComponent\n   */\n  @Input() closeOnScroll = false;\n\n  /**\n   * @property AutocompleteSize\n   * @description Defines the size of the autocomplete. Small changes the tags to counter; medium is default.\n   * @memberof AutocompleteComponent\n   */\n  @Input() size: AutocompleteSize = 'medium';\n\n  /**\n   * @property allowUserInput\n   * @description If `true`, allows the user to input custom values in the autocomplete.\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() allowUserInput = true;\n\n  /**\n   * @property clearable\n   * @description If `true`, allows the user to clear the input values\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() clearable = true;\n\n  /**\n   * @property exactMatchSelect\n   * @description If `true`, allows to select the exact match from the suggestions list\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() exactMatchSelect = true;\n\n  /**\n   * @property maxItemSelected\n   * @description Sets the maximum number of items that can be selected in the autocomplete\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() maxItemSelected = Infinity;\n\n  @Output() selectionChange = new EventEmitter<any>();\n  @Output() searchTextChange = new EventEmitter<string>();\n  @Output() blur = new EventEmitter<void>();\n  @Output() focus = new EventEmitter<void>();\n\n  @ViewChild('formField') formFieldElement: ElementRef<HTMLElement>;\n  @ViewChild('tagContainer') tagContainer: ElementRef<HTMLElement>;\n  @ViewChild('trigger') autocomplete: MatAutocompleteTrigger;\n  @ViewChild(CdkVirtualScrollViewport, { static: false }) cdkVirtualScrollViewPort: CdkVirtualScrollViewport;\n  @ViewChild('autocomplete') matAutocomplete: MatAutocomplete;\n  @ViewChild('matInput') matInput: ElementRef<HTMLInputElement>;\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 inputOpacity = 1;\n  protected firstTagMaxWidth: number = 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\n  scrollEvent = (event: any): void => {\n    const isNotAutocompleteScroll =\n      !event.target?.id?.includes('mat-autocomplete-') &&\n      !event.target?.parentElement?.id?.includes('mat-autocomplete-') &&\n      !event.target?.classList?.contains('mat-mdc-autocomplete-trigger');\n\n    if (this.autocomplete.panelOpen && isNotAutocompleteScroll) {\n      this.autocomplete.closePanel();\n    }\n  };\n\n  protected searchResult$ = this.inputValueSearch$.pipe(map(inputValue => !!inputValue.trim()));\n  protected translationContext = 'AUTOCOMPLETE.';\n  protected readonly AutocompleteUtils = AutocompleteUtils;\n  private readonly isPlatform = isPlatformBrowser(this.platformId);\n  private observer: MutationObserver;\n  protected keyboardFocused = signal<boolean>(false);\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    private readonly renderer2: Renderer2,\n    @Inject(PLATFORM_ID) private readonly platformId: any,\n    private readonly el: ElementRef,\n    private readonly focusMonitor: FocusMonitor,\n    private readonly destroyRef: DestroyRef,\n    private readonly ngZone: NgZone\n  ) {\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    this.subscriberDisplayChange();\n  }\n\n  /**\n   * Used to mark component view as dirty when touched programmatically with markAsTouched/markAllAsTouched or errors\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 || this.ngControl?.errors) {\n      this.cdr.markForCheck();\n    }\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnChanges(changes: SimpleChanges): void {\n    this.itemsList = AutocompleteUtils.excludeSuggestions(this.itemsList, this.suggestionsList, this.valueField);\n    this.initValue();\n\n    if (this.isPlatform && changes['companyColor']) {\n      this.setCompanyColorVariable();\n    }\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    this.isPlatform && this.setCompanyColorVariable();\n    if (this.closeOnScroll) {\n      window.addEventListener('scroll', this.scrollEvent, true);\n    }\n\n    this.focusMonitor\n      .monitor(this.matInput)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(origin =>\n        this.ngZone.run(() => {\n          this.keyboardFocused.set(origin === 'keyboard');\n        })\n      );\n\n    this.matInput.nativeElement.onkeydown = this.onKeydown.bind(this);\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnDestroy(): void {\n    window.removeEventListener('scroll', this.scrollEvent, true);\n\n    if (this.observer) {\n      this.observer.disconnect();\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 = AutocompleteUtils.isArray(value)\n          ? this.itemsList.filter(item => value.find((v: any) => v === item[this.valueField]))\n          : [this.itemsList.find(item => item[this.valueField] === value)];\n        this.value = this.value.filter(Boolean).length ? this.value : null;\n      }\n    } else {\n      this.value = value;\n    }\n    this.initValue();\n    this.cdr.markForCheck();\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) => (this.compareWith ? this.compareWith(v, option) : v === option));\n\n    if (foundValue) {\n      this.value = this.value.filter((v: any) => (this.compareWith ? !this.compareWith(v, option) : v !== option));\n      this.matAutocomplete.options.forEach(option => {\n        if (option.value.value === foundValue.value) {\n          option.deselect();\n        }\n      });\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      const findValue = [...this.suggestionsList, ...this.itemsList].find(\n        v => inputValue === (this.textField ? v[this.textField] : v)\n      );\n      const count = AutocompleteUtils.countMatchingWords(\n        [...this.suggestionsList, ...this.itemsList],\n        this.inputValue,\n        this.textField\n      );\n      if (findValue && count === 1 && this.exactMatchSelect) {\n        this.onOptionSelected({ option: { value: findValue } } as MatAutocompleteSelectedEvent);\n      }\n    } else {\n      this.inputValueSearch$.next('');\n      this.userInput$.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    this.matAutocomplete?.options.forEach(option => option.deselect());\n    this.onTouch();\n  }\n\n  protected refillInput(): void {\n    setTimeout(() => {\n      if (this.value && this.type === this.autocompleteType.SINGLE && !this.inputValue) {\n        this.inputValue = AutocompleteUtils.transformDisplayValue(this.value, this.textField);\n      } else if (!this.inputValue && this.value?.length) {\n        this.inputValue = ' ';\n      } else if (this.inputValue && this.type === Autocomplete.SINGLE && this.value && Object.keys(this.value).length) {\n        this.inputValue = AutocompleteUtils.transformDisplayValue(\n          AutocompleteUtils.isArray(this.value) ? this.value[0] : this.value,\n          this.textField\n        );\n      } else if (this.inputValue) {\n        this.inputValue = ' ';\n      }\n\n      this.inputValueSearch$.next('');\n      this.userInput$.next('');\n      this.isInputFocus = false;\n      this.onTouch();\n      this.blur.emit();\n    }, 0);\n  }\n\n  protected gotoUp() {\n    if (this.cdkVirtualScrollViewPort) {\n      this.cdkVirtualScrollViewPort.scrollToIndex(0);\n      this.cdkVirtualScrollViewPort.checkViewportSize();\n    }\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 (typeof inputValue !== 'number' && 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    this.focus.emit();\n  }\n\n  private checkOverlap(delay = Timeout.VIEW_INITIALIZED_AFTER_ACTION, init = false): void {\n    this.isOverLapping = false;\n    this.isOverlapChecking = true;\n    this.inputOpacity = 0;\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          const inpWidth = this.formFieldElement?.nativeElement.getBoundingClientRect().width - 20;\n          this.firstTagMaxWidth =\n            tags.length > 1\n              ? inpWidth -\n                (this.variant === DropdownVariation.DROPDOWN\n                  ? Padding.DROPDOWN_SPACE_CONTAINER\n                  : Padding.AUTOCOMPLETE_SPACE_CONTAINER)\n              : inpWidth;\n\n          if (!this.isOverLapping && width > inputWidth && index > 0) {\n            this.isOverLapping = true;\n            this.overlapIndex = index;\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 if (this.value?.length) {\n            this.inputValue = ' ';\n          }\n        }\n        const tagContainerWidth = this.tagContainer.nativeElement.getBoundingClientRect().width;\n        this.tagContainer.nativeElement.style.maxWidth = tagContainerWidth / 100 ? '100%' : tagContainerWidth + 'px';\n        this.cdr.markForCheck();\n      }\n      this.inputOpacity = 1;\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 =\n        (AutocompleteUtils.isArray(this.value) && !this.value?.length) || !this.value\n          ? ''\n          : this.type === Autocomplete.SINGLE\n          ? AutocompleteUtils.transformDisplayValue(\n              AutocompleteUtils.isArray(this.value) ? this.value[0] : this.value,\n              this.textField\n            )\n          : ' ';\n    } else {\n      this.inputValue = this.value && 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 = this.compareWith\n      ? this.value.find((v: any) => this.compareWith(v, newValue))\n      : AutocompleteUtils.findDuplicate(this.value, newValue, this.textField);\n\n    if (this.type !== this.autocompleteType.SINGLE) {\n      this.value = foundDuplicate\n        ? this.value.filter((v: any) =>\n            this.compareWith ? !this.compareWith(v, foundDuplicate) : v !== foundDuplicate\n          )\n        : [...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  /**\n   * Adding company color variable to the body to style overlay container that's out of the component scope.\n   */\n  private setCompanyColorVariable(): void {\n    this.renderer2.setAttribute(document.body, 'style', `--ui-autocomplete-option-color: ${this.companyColor};`);\n  }\n\n  private subscriberDisplayChange(): void {\n    const autocompleteHostElement = this.el.nativeElement;\n\n    this.observer = new MutationObserver(mutations => {\n      mutations.forEach(mutation => {\n        if (mutation.attributeName === 'style') {\n          const displayStyle = getComputedStyle(autocompleteHostElement).display;\n          if (displayStyle !== 'none') {\n            this.checkOverlap();\n          }\n        }\n      });\n    });\n\n    this.observer.observe(autocompleteHostElement, {\n      attributes: true,\n      attributeFilter: ['style'],\n    });\n  }\n\n  protected get hasObjectValue(): boolean {\n    return this.value ? !!Object.keys(this.value).length : false;\n  }\n\n  onKeydown($event: KeyboardEvent) {\n    const optionHeight = 48;\n\n    if ($event.key === IKeyboardEvent.HOME) {\n      this.matAutocomplete._keyManager.setFirstItemActive();\n    } else if ($event.key === IKeyboardEvent.END) {\n      this.matAutocomplete._keyManager.setLastItemActive();\n    } else if ($event.key === IKeyboardEvent.PAGE_DOWN) {\n      this.matAutocomplete._keyManager.setNextItemActive();\n      this.matAutocomplete._keyManager.setNextItemActive();\n      this.matAutocomplete._keyManager.setNextItemActive();\n    } else if ($event.key === IKeyboardEvent.PAGE_UP) {\n      this.matAutocomplete._keyManager.setPreviousItemActive();\n      this.matAutocomplete._keyManager.setPreviousItemActive();\n      this.matAutocomplete._keyManager.setPreviousItemActive();\n    }\n\n    this.matAutocomplete._setScrollTop(this.matAutocomplete._keyManager.activeItemIndex! * optionHeight);\n  }\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 ) || (AutocompleteUtils.isArray(value) && value.length) > maxItemSelected || ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue) ) ? 'warn' : 'accent'\"\n      [appearance]=\"'outline'\"\n      [ngClass]=\"{ 'large-size': type === autocompleteType.LARGE, 'hide-bottom-content': !showBottomContent, 'keyboard-focused': keyboardFocused(), 'has-label': !!label }\"\n    >\n      <mat-label *ngIf=\"label\">{{ label }} <span *ngIf=\"required\">*</span></mat-label>\n      <div #formField class=\"input-container\">\n        <span style=\"position: absolute; left: -9999px\" *ngIf=\"textField ? value?.[textField] : value === inputValue\" aria-live=\"polite\">{{ (('SELECTED') | uiTranslate | async) + ' ' + inputValue }}</span>\n\n        <input\n          #trigger=\"matAutocompleteTrigger\"\n          #matInput\n          [uiPreventInput]=\"!allowUserInput\"\n          [disabled]=\"disabled\"\n          [ngClass]=\"{ 'unset-margin': this.value && type === autocompleteType.LARGE, 'no-caret': !allowUserInput }\"\n          (blur)=\"refillInput()\"\n          (focusin)=\"onFocus()\"\n          [attr.aria-label]=\"((translationContext + 'SELECTED') | uiTranslate | async) + ' ' + (value | transformItem: textField : true)\"\n          [style.opacity]=\"type === autocompleteType.MULTI ? inputOpacity : 1\"\n          matInput\n          [placeholder]=\"value && value.length ? '': placeholder\"\n          [type]=\"'text'\"\n          [matAutocomplete]=\"autocomplete\"\n          (input)=\"onInputChange($event)\"\n          [(ngModel)]=\"inputValue\"\n        />\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.opacity]=\"type === autocompleteType.MULTI ? inputOpacity : 1\"\n            [style.display]=\"(isOverLapping && i > 0 && i >= overlapIndex) || (size === 'small' && value.length > 1)  ? 'none' : 'block'\"\n            [ngStyle]=\"{ '--tag-max-width': type === autocompleteType.LARGE ? 'fit-content' : firstTagMaxWidth + 'px' }\"\n            [ngClass]=\"{\n              'overlap-tag': isOverlapChecking && overlapIndex && i >= overlapIndex && type === autocompleteType.MULTI\n            }\"\n            (close)=\"onOptionRemoved(valueItem)\"\n          ></ui-tag>\n          @if (size === 'small') {\n            <div class=\"selected-count\" *ngIf=\"value.length > 1\">\n              {{ (translationContext + 'SELECTED_AMOUNT' | uiTranslate : { numberSelected: (value | slice: overlapIndex).length }) | async }}\n            </div>\n          } @else {\n            <div *ngIf=\"value.length > 1 && isOverLapping\" class=\"overlap-count\">\n              <ui-tag [applicationTheme]=\"applicationTheme\"\n                      [label]=\"'+' + (value.length - overlapIndex)\"></ui-tag>\n            </div>\n          }\n        </div>\n      </div>\n\n      <ui-icon\n        *ngIf=\"clearable && (type === autocompleteType.SINGLE && (value?.length || hasObjectValue)) || (type !== autocompleteType.SINGLE && value && value.length > 1 && ((AutocompleteUtils.isPrimitive(value) && value.length) || (!AutocompleteUtils.isPrimitive(value) && (AutocompleteUtils.isArray(value) && value.length || !AutocompleteUtils.isArray(value) && !value.length))))\"\n        class=\"remove-selected\"\n        [tabIndex]=\"disabled ? -1 : 0\"\n        (keydown.enter)=\"onClear();$event.preventDefault();$event.stopPropagation()\"\n        (keydown.space)=\"onClear();$event.preventDefault();$event.stopPropagation()\"\n        [ngClass]=\"{ 'large-input-icon': type === autocompleteType.LARGE }\"\n        (click)=\"onClear();$event.preventDefault();$event.stopPropagation()\"\n        [size]=\"'24'\"\n        [color]=\"applicationTheme === 'classic' ? 'inherit' : 'rebrand-black'\"\n        [attr.aria-label]=\"('COMMON.CLEAR') | uiTranslate | async\"\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]=\"applicationTheme !== 'classic' ? 'Arrow-chevron-down-in-line' : 'Arrow_down'\"\n        (click)=\"onChevronClick(autocomplete)\"\n      ></ui-icon>\n\n\n      <mat-autocomplete\n        #autocomplete\n        [class]=\"applicationTheme + ' ' + dropdownPanelClass\"\n        (optionSelected)=\"onOptionSelected($event)\"\n        [disableRipple]=\"applicationTheme !== 'classic'\"\n        [hideSingleSelectionIndicator]=\"false\"\n        (opened)=\"gotoUp()\"\n      >\n        @if (type !== autocompleteType.MULTI || value?.length < maxItemSelected) {\n          <ng-container *ngIf=\"!(searchResult$ | async)\">\n            <ng-container *ngIf=\"!isDropdown; else dropdownList\">\n              <mat-optgroup [label]=\"((translationContext + 'SUGGESTED') | uiTranslate | async)! | uppercase\"\n                            *ngIf=\"suggestionsList.length\">\n                <mat-option\n                  (mousedown)=$event.preventDefault()\n                  [ngClass]=\"{ 'selected-option': suggested | includes: value : valueField }\"\n                  *ngFor=\"let suggested of suggestionsList\"\n                  [value]=\"suggested\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ suggested | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\"\n                           [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n                </mat-option>\n              </mat-optgroup>\n\n              <mat-optgroup [label]=\"((translationContext + 'SELECTED') | uiTranslate | async)! | uppercase\"\n                            *ngIf=\"value?.length && type !== autocompleteType.SINGLE\">\n                <mat-option\n                  (mousedown)=$event.preventDefault()\n                  [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                  *ngFor=\"let item of value\"\n                  [value]=\"item\"\n                >\n                  <span>{{ item | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\"\n                           [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n                </mat-option>\n              </mat-optgroup>\n\n              <mat-optgroup [label]=\"((translationContext + 'SELECTED') | uiTranslate | async)! | uppercase\"\n                            *ngIf=\"value?.length && type === autocompleteType.SINGLE\">\n                <mat-option\n                  (mousedown)=$event.preventDefault()\n                  [class]=\"'selected-option'\"\n                  [value]=\"value\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ value | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\"\n                           [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n                </mat-option>\n              </mat-optgroup>\n            </ng-container>\n\n            <ng-template #dropdownList>\n              <cdk-virtual-scroll-viewport *ngIf=\"virtualScroll; else defaultViewPort\" [itemSize]=\"48\"\n                                           [style.height]=\"'200px'\" class=\"virtual-scroll\">\n                <mat-option\n                  (mousedown)=$event.preventDefault()\n                  [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                  *cdkVirtualFor=\"let item of itemsList\"\n                  [value]=\"item\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\"\n                           [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n                </mat-option>\n              </cdk-virtual-scroll-viewport>\n\n              <ng-template #defaultViewPort>\n                <mat-option\n                  (mousedown)=$event.preventDefault()\n                  [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                  *ngFor=\"let item of itemsList\"\n                  [value]=\"item\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\"\n                           [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n                </mat-option>\n              </ng-template>\n\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 | async)! | uppercase\"\n                            *ngIf=\"filteredSuggestionList.length\">\n                <mat-option\n                  (mousedown)=$event.preventDefault()\n                  [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                  *ngFor=\"let item of filteredSuggestionList\"\n                  [value]=\"item\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\"\n                           [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                  (mousedown)=$event.preventDefault()\n                  [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                  *ngFor=\"let item of filteredItemsList\"\n                  [value]=\"item\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\"\n                           [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 | async)! | uppercase\"\n                              *ngIf=\"filteredItemsList.length\">\n                  <mat-option\n                    (mousedown)=$event.preventDefault()\n                    [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                    *ngFor=\"let item of filteredItemsList\"\n                    [value]=\"item\"\n                  >\n                    <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                    <ui-icon [applicationTheme]=\"applicationTheme\"\n                             [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; else notFound\">\n                  <mat-option (mousedown)=$event.preventDefault() [value]=\"inputValue\">\n                    <span>{{ ('COMMON.ADD') | uiTranslate | async }}</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 | async }}</span>\n                  </mat-option>\n                </ng-template>\n              </ng-container>\n            </ng-container>\n          </ng-container>\n        }\n      </mat-autocomplete>\n      <mat-hint class=\"error\" *ngIf=\"safeErrors.length || (ngControl?.errors | hasValidationError) || (AutocompleteUtils.isArray(value) && value.length) > maxItemSelected || ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue)\">\n        <div class=\"errors\" *ngIf=\"(AutocompleteUtils.isArray(value) && value.length) > maxItemSelected || ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue)\">\n          <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\n          <span>{{ (translationContext + 'MAX_SELECTED_ERROR') | uiTranslate : { max: maxItemSelected } | async }}</span>\n        </div>\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        <ui-validation-error *ngIf=\"ngControl && !hideBuiltInErrors\" [ngControl]=\"ngControl\"\n                             [label]=\"hideLabelInErrors ? null : label\"></ui-validation-error>\n\n      </mat-hint>\n    </mat-form-field>\n  </div>\n</ng-container>\n"]}
|
|
717
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/autocomplete/autocomplete.component.ts","../../../../../projects/tgo-canopy-ui/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\nimport { isPlatformBrowser } from '@angular/common';\nimport {\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DestroyRef,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  Optional,\n  Output,\n  PLATFORM_ID,\n  Renderer2,\n  Self,\n  signal,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { MatAutocomplete, MatAutocompleteSelectedEvent, MatAutocompleteTrigger } from '@angular/material/autocomplete';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { map, ReplaySubject, startWith } from 'rxjs';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { AutocompleteUtils } from '../../utils/autocomplete-utils';\nimport {\n  Autocomplete,\n  AutocompleteSize,\n  AutocompleteType,\n  DropdownVariation,\n  Padding,\n  Timeout,\n} from './autocomplete.model';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { FocusMonitor } from '@angular/cdk/a11y';\nimport { IKeyboardEvent } from '../../models/keyboard-events.model';\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, OnDestroy {\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 placeholder\n   * @description The placeholder for the autocomplete input.\n   * @memberof AutocompleteComponent\n   */\n  @Input() placeholder = '';\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 ? [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   * 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  @HostBinding('class.full-width')\n  @Input()\n  fullWidth = false;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof AutocompleteComponent\n   */\n  @HostBinding('attr.theme')\n  @Input()\n  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  /**\n   * Color of the option hover.\n   * Defaults to Test Gorilla primary color.\n   *\n   * @type {string}\n   * @memberof AutocompleteComponent\n   */\n  @Input() companyColor: string | null = '#FFF2FC';\n\n  /**\n   * Hide in-build errors for Reactive Forms\n   *\n   * @type {number}\n   * @memberof AutocompleteComponent\n   */\n  @Input() hideBuiltInErrors = false;\n\n  /**\n   * Hide label in errors\n   *\n   * @type {number}\n   * @memberof AutocompleteComponent\n   */\n  @Input() hideLabelInErrors = false;\n\n  /**\n   * Sets dropdown list to virtual scroll mode\n   *\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input({ transform: booleanAttribute }) virtualScroll = false;\n\n  /**\n   * @property compareWith\n   * @description Custom comparison logic for the autocomplete.\n   * @memberof AutocompleteComponent\n   */\n  @Input() compareWith: (a: any, b: any) => boolean;\n\n  /**\n   * @property dropdownPanelClass\n   * @description Sets class on autocomplete dropdown\n   * @memberof AutocompleteComponent\n   */\n  @Input() dropdownPanelClass = '';\n\n  /**\n   * @property closeOnScroll\n   * @description Defines if dropdown should be closed on page scroll\n   * @memberof AutocompleteComponent\n   */\n  @Input() closeOnScroll = false;\n\n  /**\n   * @property AutocompleteSize\n   * @description Defines the size of the autocomplete. Small changes the tags to counter; medium is default.\n   * @memberof AutocompleteComponent\n   */\n  @Input() size: AutocompleteSize = 'medium';\n\n  /**\n   * @property allowUserInput\n   * @description If `true`, allows the user to input custom values in the autocomplete.\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() allowUserInput = true;\n\n  /**\n   * @property clearable\n   * @description If `true`, allows the user to clear the input values\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() clearable = true;\n\n  /**\n   * @property exactMatchSelect\n   * @description If `true`, allows to select the exact match from the suggestions list\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() exactMatchSelect = true;\n\n  /**\n   * @property maxItemSelected\n   * @description Sets the maximum number of items that can be selected in the autocomplete\n   * @type {boolean}\n   * @memberof AutocompleteComponent\n   */\n  @Input() maxItemSelected = Infinity;\n\n  @Output() selectionChange = new EventEmitter<any>();\n  @Output() searchTextChange = new EventEmitter<string>();\n  @Output() blur = new EventEmitter<void>();\n  @Output() focus = new EventEmitter<void>();\n\n  @ViewChild('formField') formFieldElement: ElementRef<HTMLElement>;\n  @ViewChild('tagContainer') tagContainer: ElementRef<HTMLElement>;\n  @ViewChild('trigger') autocomplete: MatAutocompleteTrigger;\n  @ViewChild(CdkVirtualScrollViewport, { static: false }) cdkVirtualScrollViewPort: CdkVirtualScrollViewport;\n  @ViewChild('autocomplete') matAutocomplete: MatAutocomplete;\n  @ViewChild('matInput') matInput: ElementRef<HTMLInputElement>;\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 inputOpacity = 1;\n  protected firstTagMaxWidth: number = 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\n  scrollEvent = (event: any): void => {\n    const isNotAutocompleteScroll =\n      !event.target?.id?.includes('mat-autocomplete-') &&\n      !event.target?.parentElement?.id?.includes('mat-autocomplete-') &&\n      !event.target?.classList?.contains('mat-mdc-autocomplete-trigger');\n\n    if (this.autocomplete.panelOpen && isNotAutocompleteScroll) {\n      this.autocomplete.closePanel();\n    }\n  };\n\n  protected searchResult$ = this.inputValueSearch$.pipe(map(inputValue => !!inputValue.trim()));\n  protected translationContext = 'AUTOCOMPLETE.';\n  protected readonly AutocompleteUtils = AutocompleteUtils;\n  private readonly isPlatform = isPlatformBrowser(this.platformId);\n  private observer: MutationObserver;\n  protected keyboardFocused = signal<boolean>(false);\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    private readonly renderer2: Renderer2,\n    @Inject(PLATFORM_ID) private readonly platformId: any,\n    private readonly el: ElementRef,\n    private readonly focusMonitor: FocusMonitor,\n    private readonly destroyRef: DestroyRef,\n    private readonly ngZone: NgZone\n  ) {\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    this.subscriberDisplayChange();\n  }\n\n  /**\n   * Used to mark component view as dirty when touched programmatically with markAsTouched/markAllAsTouched or errors\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 || this.ngControl?.errors) {\n      this.cdr.markForCheck();\n    }\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnChanges(changes: SimpleChanges): void {\n    this.itemsList = AutocompleteUtils.excludeSuggestions(this.itemsList, this.suggestionsList, this.valueField);\n    this.initValue();\n\n    if (this.isPlatform && changes['companyColor']) {\n      this.setCompanyColorVariable();\n    }\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    this.isPlatform && this.setCompanyColorVariable();\n    if (this.closeOnScroll) {\n      window.addEventListener('scroll', this.scrollEvent, true);\n    }\n\n    this.focusMonitor\n      .monitor(this.matInput)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(origin =>\n        this.ngZone.run(() => {\n          this.keyboardFocused.set(origin === 'keyboard');\n        })\n      );\n\n    this.matInput.nativeElement.onkeydown = this.onKeydown.bind(this);\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnDestroy(): void {\n    window.removeEventListener('scroll', this.scrollEvent, true);\n\n    if (this.observer) {\n      this.observer.disconnect();\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 = AutocompleteUtils.isArray(value)\n          ? this.itemsList.filter(item => value.find((v: any) => v === item[this.valueField]))\n          : [this.itemsList.find(item => item[this.valueField] === value)];\n        this.value = this.value.filter(Boolean).length ? this.value : null;\n      }\n    } else {\n      this.value = value;\n    }\n    this.initValue();\n    this.cdr.markForCheck();\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) => (this.compareWith ? this.compareWith(v, option) : v === option));\n\n    if (foundValue) {\n      this.value = this.value.filter((v: any) => (this.compareWith ? !this.compareWith(v, option) : v !== option));\n      this.matAutocomplete.options.forEach(option => {\n        if (option.value.value === foundValue.value) {\n          option.deselect();\n        }\n      });\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      const findValue = [...this.suggestionsList, ...this.itemsList].find(\n        v => inputValue === (this.textField ? v[this.textField] : v)\n      );\n      const count = AutocompleteUtils.countMatchingWords(\n        [...this.suggestionsList, ...this.itemsList],\n        this.inputValue,\n        this.textField\n      );\n      if (findValue && count === 1 && this.exactMatchSelect) {\n        this.onOptionSelected({ option: { value: findValue } } as MatAutocompleteSelectedEvent);\n      }\n    } else {\n      this.inputValueSearch$.next('');\n      this.userInput$.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    this.matAutocomplete?.options.forEach(option => option.deselect());\n    this.onTouch();\n  }\n\n  protected refillInput(): void {\n    setTimeout(() => {\n      if (this.value && this.type === this.autocompleteType.SINGLE && !this.inputValue) {\n        this.inputValue = AutocompleteUtils.transformDisplayValue(this.value, this.textField);\n      } else if (!this.inputValue && this.value?.length) {\n        this.inputValue = ' ';\n      } else if (this.inputValue && this.type === Autocomplete.SINGLE && this.value && Object.keys(this.value).length) {\n        this.inputValue = AutocompleteUtils.transformDisplayValue(\n          AutocompleteUtils.isArray(this.value) ? this.value[0] : this.value,\n          this.textField\n        );\n      } else if (this.inputValue) {\n        this.inputValue = ' ';\n      }\n\n      this.inputValueSearch$.next('');\n      this.userInput$.next('');\n      this.isInputFocus = false;\n      this.onTouch();\n      this.blur.emit();\n    }, 0);\n  }\n\n  protected gotoUp() {\n    if (this.cdkVirtualScrollViewPort) {\n      this.cdkVirtualScrollViewPort.scrollToIndex(0);\n      this.cdkVirtualScrollViewPort.checkViewportSize();\n    }\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 (typeof inputValue !== 'number' && 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    this.focus.emit();\n  }\n\n  private checkOverlap(delay = Timeout.VIEW_INITIALIZED_AFTER_ACTION, init = false): void {\n    this.isOverLapping = false;\n    this.isOverlapChecking = true;\n    this.inputOpacity = 0;\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          const inpWidth = this.formFieldElement?.nativeElement.getBoundingClientRect().width - 20;\n          this.firstTagMaxWidth =\n            tags.length > 1\n              ? inpWidth -\n                (this.variant === DropdownVariation.DROPDOWN\n                  ? Padding.DROPDOWN_SPACE_CONTAINER\n                  : Padding.AUTOCOMPLETE_SPACE_CONTAINER)\n              : inpWidth;\n\n          if (!this.isOverLapping && width > inputWidth && index > 0) {\n            this.isOverLapping = true;\n            this.overlapIndex = index;\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 if (this.value?.length) {\n            this.inputValue = ' ';\n          }\n        }\n        const tagContainerWidth = this.tagContainer.nativeElement.getBoundingClientRect().width;\n        this.tagContainer.nativeElement.style.maxWidth = tagContainerWidth / 100 ? '100%' : tagContainerWidth + 'px';\n        this.cdr.markForCheck();\n      }\n      this.inputOpacity = 1;\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 =\n        (AutocompleteUtils.isArray(this.value) && !this.value?.length) || !this.value\n          ? ''\n          : this.type === Autocomplete.SINGLE\n          ? AutocompleteUtils.transformDisplayValue(\n              AutocompleteUtils.isArray(this.value) ? this.value[0] : this.value,\n              this.textField\n            )\n          : ' ';\n    } else {\n      this.inputValue = this.value && 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 = this.compareWith\n      ? this.value.find((v: any) => this.compareWith(v, newValue))\n      : AutocompleteUtils.findDuplicate(this.value, newValue, this.textField);\n\n    if (this.type !== this.autocompleteType.SINGLE) {\n      this.value = foundDuplicate\n        ? this.value.filter((v: any) =>\n            this.compareWith ? !this.compareWith(v, foundDuplicate) : v !== foundDuplicate\n          )\n        : [...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  /**\n   * Adding company color variable to the body to style overlay container that's out of the component scope.\n   */\n  private setCompanyColorVariable(): void {\n    this.renderer2.setStyle(document.body, '--ui-autocomplete-option-color', `${this.companyColor}`);\n  }\n\n  private subscriberDisplayChange(): void {\n    const autocompleteHostElement = this.el.nativeElement;\n\n    this.observer = new MutationObserver(mutations => {\n      mutations.forEach(mutation => {\n        if (mutation.attributeName === 'style') {\n          const displayStyle = getComputedStyle(autocompleteHostElement).display;\n          if (displayStyle !== 'none') {\n            this.checkOverlap();\n          }\n        }\n      });\n    });\n\n    this.observer.observe(autocompleteHostElement, {\n      attributes: true,\n      attributeFilter: ['style'],\n    });\n  }\n\n  protected get hasObjectValue(): boolean {\n    return this.value ? !!Object.keys(this.value).length : false;\n  }\n\n  onKeydown($event: KeyboardEvent) {\n    const optionHeight = 48;\n\n    if ($event.key === IKeyboardEvent.HOME) {\n      this.matAutocomplete._keyManager.setFirstItemActive();\n    } else if ($event.key === IKeyboardEvent.END) {\n      this.matAutocomplete._keyManager.setLastItemActive();\n    } else if ($event.key === IKeyboardEvent.PAGE_DOWN) {\n      this.matAutocomplete._keyManager.setNextItemActive();\n      this.matAutocomplete._keyManager.setNextItemActive();\n      this.matAutocomplete._keyManager.setNextItemActive();\n    } else if ($event.key === IKeyboardEvent.PAGE_UP) {\n      this.matAutocomplete._keyManager.setPreviousItemActive();\n      this.matAutocomplete._keyManager.setPreviousItemActive();\n      this.matAutocomplete._keyManager.setPreviousItemActive();\n    }\n\n    this.matAutocomplete._setScrollTop(this.matAutocomplete._keyManager.activeItemIndex! * optionHeight);\n  }\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 ) || (AutocompleteUtils.isArray(value) && value.length) > maxItemSelected || ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue) ) ? 'warn' : 'accent'\"\n      [appearance]=\"'outline'\"\n      [ngClass]=\"{ 'large-size': type === autocompleteType.LARGE, 'hide-bottom-content': !showBottomContent, 'keyboard-focused': keyboardFocused(), 'has-label': !!label }\"\n    >\n      <mat-label *ngIf=\"label\">{{ label }} <span *ngIf=\"required\">*</span></mat-label>\n      <div #formField class=\"input-container\">\n        <span style=\"position: absolute; left: -9999px\" *ngIf=\"textField ? value?.[textField] : value === inputValue\" aria-live=\"polite\">{{ (('SELECTED') | uiTranslate | async) + ' ' + inputValue }}</span>\n\n        <input\n          #trigger=\"matAutocompleteTrigger\"\n          #matInput\n          [uiPreventInput]=\"!allowUserInput\"\n          [disabled]=\"disabled\"\n          [ngClass]=\"{ 'unset-margin': this.value && type === autocompleteType.LARGE, 'no-caret': !allowUserInput }\"\n          (blur)=\"refillInput()\"\n          (focusin)=\"onFocus()\"\n          [attr.aria-label]=\"((translationContext + 'SELECTED') | uiTranslate | async) + ' ' + (value | transformItem: textField : true)\"\n          [style.opacity]=\"type === autocompleteType.MULTI ? inputOpacity : 1\"\n          matInput\n          [placeholder]=\"value && value.length ? '': placeholder\"\n          [type]=\"'text'\"\n          [matAutocomplete]=\"autocomplete\"\n          (input)=\"onInputChange($event)\"\n          [(ngModel)]=\"inputValue\"\n        />\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.opacity]=\"type === autocompleteType.MULTI ? inputOpacity : 1\"\n            [style.display]=\"(isOverLapping && i > 0 && i >= overlapIndex) || (size === 'small' && value.length > 1)  ? 'none' : 'block'\"\n            [ngStyle]=\"{ '--tag-max-width': type === autocompleteType.LARGE ? 'fit-content' : firstTagMaxWidth + 'px' }\"\n            [ngClass]=\"{\n              'overlap-tag': isOverlapChecking && overlapIndex && i >= overlapIndex && type === autocompleteType.MULTI\n            }\"\n            (close)=\"onOptionRemoved(valueItem)\"\n          ></ui-tag>\n          @if (size === 'small') {\n            <div class=\"selected-count\" *ngIf=\"value.length > 1\">\n              {{ (translationContext + 'SELECTED_AMOUNT' | uiTranslate : { numberSelected: (value | slice: overlapIndex).length }) | async }}\n            </div>\n          } @else {\n            <div *ngIf=\"value.length > 1 && isOverLapping\" class=\"overlap-count\">\n              <ui-tag [applicationTheme]=\"applicationTheme\"\n                      [label]=\"'+' + (value.length - overlapIndex)\"></ui-tag>\n            </div>\n          }\n        </div>\n      </div>\n\n      <ui-icon\n        *ngIf=\"clearable && (type === autocompleteType.SINGLE && (value?.length || hasObjectValue)) || (type !== autocompleteType.SINGLE && value && value.length > 1 && ((AutocompleteUtils.isPrimitive(value) && value.length) || (!AutocompleteUtils.isPrimitive(value) && (AutocompleteUtils.isArray(value) && value.length || !AutocompleteUtils.isArray(value) && !value.length))))\"\n        class=\"remove-selected\"\n        [tabIndex]=\"disabled ? -1 : 0\"\n        (keydown.enter)=\"onClear();$event.preventDefault();$event.stopPropagation()\"\n        (keydown.space)=\"onClear();$event.preventDefault();$event.stopPropagation()\"\n        [ngClass]=\"{ 'large-input-icon': type === autocompleteType.LARGE }\"\n        (click)=\"onClear();$event.preventDefault();$event.stopPropagation()\"\n        [size]=\"'24'\"\n        [color]=\"applicationTheme === 'classic' ? 'inherit' : 'rebrand-black'\"\n        [attr.aria-label]=\"('COMMON.CLEAR') | uiTranslate | async\"\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]=\"applicationTheme !== 'classic' ? 'Arrow-chevron-down-in-line' : 'Arrow_down'\"\n        (click)=\"onChevronClick(autocomplete)\"\n      ></ui-icon>\n\n\n      <mat-autocomplete\n        #autocomplete\n        [class]=\"applicationTheme + ' ' + dropdownPanelClass\"\n        (optionSelected)=\"onOptionSelected($event)\"\n        [disableRipple]=\"applicationTheme !== 'classic'\"\n        [hideSingleSelectionIndicator]=\"false\"\n        (opened)=\"gotoUp()\"\n      >\n        @if (type !== autocompleteType.MULTI || value?.length < maxItemSelected) {\n          <ng-container *ngIf=\"!(searchResult$ | async)\">\n            <ng-container *ngIf=\"!isDropdown; else dropdownList\">\n              <mat-optgroup [label]=\"((translationContext + 'SUGGESTED') | uiTranslate | async)! | uppercase\"\n                            *ngIf=\"suggestionsList.length\">\n                <mat-option\n                  (mousedown)=$event.preventDefault()\n                  [ngClass]=\"{ 'selected-option': suggested | includes: value : valueField }\"\n                  *ngFor=\"let suggested of suggestionsList\"\n                  [value]=\"suggested\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ suggested | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\"\n                           [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n                </mat-option>\n              </mat-optgroup>\n\n              <mat-optgroup [label]=\"((translationContext + 'SELECTED') | uiTranslate | async)! | uppercase\"\n                            *ngIf=\"value?.length && type !== autocompleteType.SINGLE\">\n                <mat-option\n                  (mousedown)=$event.preventDefault()\n                  [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                  *ngFor=\"let item of value\"\n                  [value]=\"item\"\n                >\n                  <span>{{ item | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\"\n                           [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n                </mat-option>\n              </mat-optgroup>\n\n              <mat-optgroup [label]=\"((translationContext + 'SELECTED') | uiTranslate | async)! | uppercase\"\n                            *ngIf=\"value?.length && type === autocompleteType.SINGLE\">\n                <mat-option\n                  (mousedown)=$event.preventDefault()\n                  [class]=\"'selected-option'\"\n                  [value]=\"value\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ value | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\"\n                           [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n                </mat-option>\n              </mat-optgroup>\n            </ng-container>\n\n            <ng-template #dropdownList>\n              <cdk-virtual-scroll-viewport *ngIf=\"virtualScroll; else defaultViewPort\" [itemSize]=\"48\"\n                                           [style.height]=\"'200px'\" class=\"virtual-scroll\">\n                <mat-option\n                  (mousedown)=$event.preventDefault()\n                  [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                  *cdkVirtualFor=\"let item of itemsList\"\n                  [value]=\"item\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\"\n                           [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n                </mat-option>\n              </cdk-virtual-scroll-viewport>\n\n              <ng-template #defaultViewPort>\n                <mat-option\n                  (mousedown)=$event.preventDefault()\n                  [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                  *ngFor=\"let item of itemsList\"\n                  [value]=\"item\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\"\n                           [name]=\"applicationTheme === 'classic' ? 'Check' : 'Check-in-line'\"></ui-icon>\n                </mat-option>\n              </ng-template>\n\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 | async)! | uppercase\"\n                            *ngIf=\"filteredSuggestionList.length\">\n                <mat-option\n                  (mousedown)=$event.preventDefault()\n                  [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                  *ngFor=\"let item of filteredSuggestionList\"\n                  [value]=\"item\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\"\n                           [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                  (mousedown)=$event.preventDefault()\n                  [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                  *ngFor=\"let item of filteredItemsList\"\n                  [value]=\"item\"\n                >\n                  <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                  <ui-icon [applicationTheme]=\"applicationTheme\"\n                           [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 | async)! | uppercase\"\n                              *ngIf=\"filteredItemsList.length\">\n                  <mat-option\n                    (mousedown)=$event.preventDefault()\n                    [ngClass]=\"{ 'selected-option': item | includes: value : valueField }\"\n                    *ngFor=\"let item of filteredItemsList\"\n                    [value]=\"item\"\n                  >\n                    <span [selectText]=\"userInput$ | async\">{{ item | transformItem: textField }}</span>\n                    <ui-icon [applicationTheme]=\"applicationTheme\"\n                             [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; else notFound\">\n                  <mat-option (mousedown)=$event.preventDefault() [value]=\"inputValue\">\n                    <span>{{ ('COMMON.ADD') | uiTranslate | async }}</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 | async }}</span>\n                  </mat-option>\n                </ng-template>\n              </ng-container>\n            </ng-container>\n          </ng-container>\n        }\n      </mat-autocomplete>\n      <mat-hint class=\"error\" *ngIf=\"safeErrors.length || (ngControl?.errors | hasValidationError) || (AutocompleteUtils.isArray(value) && value.length) > maxItemSelected || ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue)\">\n        <div class=\"errors\" *ngIf=\"(AutocompleteUtils.isArray(value) && value.length) > maxItemSelected || ((AutocompleteUtils.isArray(value) && value.length) >= maxItemSelected && inputValue)\">\n          <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\n          <span>{{ (translationContext + 'MAX_SELECTED_ERROR') | uiTranslate : { max: maxItemSelected } | async }}</span>\n        </div>\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        <ui-validation-error *ngIf=\"ngControl && !hideBuiltInErrors\" [ngControl]=\"ngControl\"\n                             [label]=\"hideLabelInErrors ? null : label\"></ui-validation-error>\n\n      </mat-hint>\n    </mat-form-field>\n  </div>\n</ng-container>\n"]}
|
|
@@ -260,9 +260,8 @@ export class DatepickerComponent {
|
|
|
260
260
|
}
|
|
261
261
|
setStyleVariable() {
|
|
262
262
|
const hover = this.companyColor ? adjustLightness(this.companyColor, 'hover') : '#FFF2FC';
|
|
263
|
-
this.renderer2.
|
|
264
|
-
|
|
265
|
-
--datepicker-selected-color: ${this.companyColor || '#D410AA'}`);
|
|
263
|
+
this.renderer2.setStyle(document.body, '--datepicker-hover-color', hover);
|
|
264
|
+
this.renderer2.setStyle(document.body, '--datepicker-selected-color', `${this.companyColor || '#D410AA'}`);
|
|
266
265
|
}
|
|
267
266
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: DatepickerComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: i0.ChangeDetectorRef }, { token: i1.DomSanitizer }, { token: i2.NgControl, optional: true, self: true }, { token: i0.Renderer2 }, { token: i3.DatepickerService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
268
267
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.7", type: DatepickerComponent, selector: "ui-datepicker", inputs: { label: "label", fieldName: "fieldName", placeholder: "placeholder", id: "id", value: "value", errors: "errors", isRange: "isRange", disabled: "disabled", required: "required", hintMessage: "hintMessage", updateOnBlur: "updateOnBlur", showBottomContent: "showBottomContent", fullWidth: "fullWidth", minDate: "minDate", maxDate: "maxDate", monthPicker: "monthPicker", applicationTheme: "applicationTheme", hideBuiltInErrors: "hideBuiltInErrors", hideLabelInErrors: "hideLabelInErrors", preventUserInput: "preventUserInput", companyColor: "companyColor", browserTimezone: "browserTimezone" }, outputs: { changed: "changed" }, host: { properties: { "class": "this.class" } }, providers: [
|
|
@@ -334,4 +333,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
334
333
|
}], changed: [{
|
|
335
334
|
type: Output
|
|
336
335
|
}] } });
|
|
337
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/datepicker/datepicker.component.ts","../../../../../projects/tgo-canopy-ui/components/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-underscore-dangle */\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  Renderer2,\n  Self,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, FormControl, FormGroup, NgControl } from '@angular/forms';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { MatDatepicker } from '@angular/material/datepicker';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { adjustLightness } from \"../../utils/color-contrast\";\nimport { DateAdapter, MAT_DATE_FORMATS } from \"@angular/material/core\";\nimport { UI_DATE_FORMATS, UiDateAdapter } from \"./DateAdapter\";\nimport { DatepickerService } from \"./datepicker.service\";\n\n@Component({\n  selector: 'ui-datepicker',\n  templateUrl: './datepicker.component.html',\n  styleUrls: ['./datepicker.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    { provide: DateAdapter, useClass: UiDateAdapter },\n    { provide: MAT_DATE_FORMATS, useValue: UI_DATE_FORMATS }\n  ]\n})\n// eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\nexport class DatepickerComponent implements OnChanges, ControlValueAccessor, DoCheck {\n  @HostBinding() class = 'ui-datepicker';\n\n  /**\n   * Form field label\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() label? = '';\n\n  /**\n   * Input name attribute\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() fieldName?: string;\n\n  /**\n   * Input placeholder\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() placeholder? = '';\n\n  /**\n   * Input id\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() id? = '';\n\n  /**\n   * Input value\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() value?: Date[] | Date;\n\n  _errors: SafeHtml[];\n  /**\n   * Input field errors\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() set errors(errors: string[]) {\n    this._errors = errors?.filter(Boolean).map(error => this.sanitizer.bypassSecurityTrustHtml(error));\n    this.errorsLength = this.setErrorsLength();\n  }\n\n  /**\n   * Determines if input is date range\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() isRange: boolean;\n\n  /**\n   * Determines if input is disabled\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() disabled: boolean;\n\n  /**\n   * Input is required or not\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() required: boolean;\n\n  /**\n   * Hint text\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() hintMessage: string;\n\n  /**\n   * Input is update only on blur\n   *\n   * @type {Boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() updateOnBlur = false;\n\n  /**\n   * Show reserved content below form field\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() showBottomContent = true;\n\n  /**\n   * Set full width DatepickerComponent\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() fullWidth = false;\n\n  /**\n   * Set min date for Datepicker\n   *\n   * @type {Date}\n   * @memberof DatepickerComponent\n   */\n  @Input() minDate: Date | undefined;\n\n  /**\n   * Set max date for Datepicker\n   *\n   * @type {Date}\n   * @memberof DatepickerComponent\n   */\n  @Input() maxDate: Date | undefined;\n\n  /**\n   * Show and pick date without day\n   * @default false\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() monthPicker = false;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof DatepickerComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Hide in-build errors for Reactive Forms\n   *\n   * @type {number}\n   * @memberof DatepickerComponent\n   */\n  @Input() hideBuiltInErrors = false;\n\n  /**\n   * Hide label in errors\n   *\n   * @type {number}\n   * @memberof DatepickerComponent\n   */\n  @Input() hideLabelInErrors = false;\n\n  /**\n   * Prevent user input\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() preventUserInput = false;\n\n  /**\n   * Color of the option hover.\n   * Defaults to Test Gorilla primary color.\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() companyColor: string = ''\n\n  /**\n   * Use browser timezone\n   * @type boolean\n   * @memberof DatepickerComponent\n   */\n  @Input() set browserTimezone(value: boolean) {\n    this.datepickerService.useBrowserTimezone = value;\n  }\n\n  /**\n   * @ignore\n   */\n  onChange = (_: any) => {};\n\n  /**\n   * @ignore\n   */\n  onTouch = () => {};\n\n  /**\n   * Event emitted when the value is change - when used outside of form\n   *\n   * @type {Date}\n   * @memberof DatepickerComponent\n   */\n  @Output() changed = new EventEmitter<Date | Date[]>();\n\n  range = new FormGroup({\n    start: new FormControl<Date | null>(null),\n    end: new FormControl<Date | null>(null),\n  });\n\n  errorsLength: boolean;\n  protected translationContext = 'DATEPICKER.';\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private cdr: ChangeDetectorRef,\n    private sanitizer: DomSanitizer,\n    @Optional() @Self() public ngControl: NgControl,\n    private renderer2: Renderer2,\n    private datepickerService: DatepickerService\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  get hint(): string {\n    if (this.hintMessage === undefined) {\n      return this.isRange ?  'MM/DD/YYYY - MM/DD/YYYY' : this.monthPicker ? 'MM/YYYY' :  'MM/DD/YYYY';\n    }\n\n    return this.hintMessage;\n  }\n\n  /**\n   * Used to mark component view as dirty when touched programmatically with markAsTouched/markAllAsTouched or errors\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 || this.ngControl?.errors) {\n      this.cdr.markForCheck();\n    }\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnInit() {\n    document.body.setAttribute('theme', this.applicationTheme);\n    this.setStyleVariable();\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.isRange) {\n      this.setRange();\n    }\n    if (changes['companyColor']) {\n      this.setStyleVariable();\n    }\n  }\n\n  // Set errors length for validation\n  // Consider only those errors which which are not empty\n  setErrorsLength(): boolean {\n    if (!!this._errors) {\n      return this._errors.filter(err => !!err).length > 0 ? true : false;\n    }\n    return false;\n  }\n\n  onValueChange(value: Date | Date[]) {\n    this.writeValue(value);\n    this.errorsLength = this.setErrorsLength();\n    if (!this.updateOnBlur) {\n      this.onTouch();\n    }\n    this.onChange(value);\n    this.changed.emit(value);\n  }\n\n  writeValue(value?: Date | Date[]): void {\n    this.value = value;\n    if (this.isRange) {\n      this.setRange();\n    }\n  }\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  dateRangeChange() {\n    const start = this.range.controls.start.value!;\n    const end = this.range.controls.end.value!;\n    this.onValueChange([new Date(start), new Date(end)]);\n  }\n\n  setMonthAndYear(normalizedMonthAndYear: any, datepicker: MatDatepicker<Date>) {\n    const ctrlValue = (this.value) as Date || new Date();\n\n    ctrlValue.setMonth(normalizedMonthAndYear.getMonth());\n    ctrlValue.setFullYear(normalizedMonthAndYear.getFullYear());\n\n    datepicker.close();\n\n    this.onValueChange(new Date(ctrlValue));\n  }\n\n  private setRange() {\n    if (Array.isArray(this.value)) {\n      const [start, end] = this.value;\n      const startDate = this.range.controls.start.value;\n      const endDate = this.range.controls.end.value;\n\n      if (startDate) {\n        this.range.controls.start.setValue(new Date(start));\n      }\n\n      if (endDate) {\n        this.range.controls.end.setValue(new Date(end));\n      }\n    }\n\n    if (!this.value) {\n      this.range.controls.start.setValue(null);\n      this.range.controls.end.setValue(null);\n    }\n  }\n\n  onInput(event: Event) {\n    const target = event.target as EventTarget & { value: string };\n    const [month, year] = target.value.split('/');\n    const date = new Date().getDate();\n    const fullDateString = `${month}/${date}/${year}`;\n    const fullDate = new Date(fullDateString);\n    this.onValueChange(fullDate);\n  }\n\n  private setStyleVariable() {\n    const hover = this.companyColor ? adjustLightness(this.companyColor, 'hover') : '#FFF2FC';\n    this.renderer2.setAttribute(document.body, 'style', `\n    --datepicker-hover-color: ${hover};\n    --datepicker-selected-color: ${this.companyColor || '#D410AA'}`);\n  }\n}\n","<ng-container>\n  <mat-form-field\n    *ngIf=\"!monthPicker; else dateYearPicker\"\n    #uiDatepicker\n    appearance=\"outline\"\n    [color]=\"(errorsLength || (ngControl?.errors && ngControl?.touched ))  ? 'warn' : 'accent'\"\n    [ngClass]=\"{ 'hide-bottom-content': !showBottomContent, 'full-width': fullWidth }\"\n  >\n    <mat-label *ngIf=\"label\">{{ label }}<span *ngIf=\"required\"> *</span></mat-label>\n    <ng-container *ngIf=\"!isRange\">\n      <input *ngIf=\"!isRange\" matInput\n             [matDatepicker]=\"picker\"\n             (blur)=\"onTouch()\"\n             (dateChange)=\"onValueChange($event.value)\"\n             [id]=\"id!\"\n             [placeholder]=\"placeholder!\"\n             [value]=\"value\"\n             [disabled]=\"disabled\"\n             [name]=\"fieldName!\"\n             [readonly]=\"preventUserInput\"\n             [min]=\"minDate\"\n             [max]=\"maxDate\"\n      />\n      <mat-datepicker-toggle matIconSuffix [for]=\"picker\">\n        <ui-icon matDatepickerToggleIcon [applicationTheme]=\"applicationTheme\" name=\"Calendar\" size=\"24\" color=\"inherit\"></ui-icon>\n      </mat-datepicker-toggle>\n      <mat-datepicker #picker></mat-datepicker>\n    </ng-container>\n\n    <ng-container *ngIf=\"isRange\">\n      <mat-date-range-input *ngIf=\"isRange\" [formGroup]=\"range\" [rangePicker]=\"rangePicker\" [min]=\"minDate\" [max]=\"maxDate\" >\n        <input matStartDate formControlName=\"start\" [placeholder]=\"(translationContext + 'START_DATE') | uiTranslate | async\" (dateChange)=\"dateRangeChange()\">\n        <input matEndDate formControlName=\"end\" [placeholder]=\"(translationContext + 'END_DATE') | uiTranslate | async\" (dateChange)=\"dateRangeChange()\">\n      </mat-date-range-input>\n      <mat-datepicker-toggle matIconSuffix [for]=\"rangePicker\">\n        <ui-icon matDatepickerToggleIcon [applicationTheme]=\"applicationTheme\" name=\"Calendar\" size=\"24\" color=\"inherit\"></ui-icon>\n      </mat-datepicker-toggle>\n      <mat-date-range-picker #rangePicker></mat-date-range-picker>\n    </ng-container>\n\n    <mat-hint class=\"info\" *ngIf=\"hint && !_errors && !(ngControl?.touched && (ngControl?.errors | hasValidationError))\">{{ hint }}</mat-hint>\n    <mat-hint class=\"error\" *ngIf=\"errorsLength || (ngControl?.touched && (ngControl?.errors | hasValidationError))\">\n      <ng-container *ngIf=\"errorsLength\">\n        <div class=\"errors\" *ngFor=\"let error of _errors\">\n          <ui-icon [applicationTheme]=\"applicationTheme\" name=\"Error\"></ui-icon>\n          <span [innerHTML]=\"error\"></span>\n        </div>\n      </ng-container>\n      <ui-validation-error *ngIf=\"ngControl && !hideBuiltInErrors\" [ngControl]=\"ngControl\" [label]=\"hideLabelInErrors ? null : label\"></ui-validation-error>\n    </mat-hint>\n  </mat-form-field>\n\n  <ng-template #dateYearPicker>\n    <mat-form-field\n      appNoDateFormat\n      #uiDatepicker\n      appearance=\"outline\"\n      [color]=\"(errorsLength || (ngControl?.errors && ngControl?.touched ))  ? 'warn' : 'accent'\"\n      [ngClass]=\"{ 'hide-bottom-content': !showBottomContent, 'full-width': fullWidth }\"\n    >\n      <mat-label *ngIf=\"label\">{{ label }}<span *ngIf=\"required\"> *</span></mat-label>\n\n      <ng-container >\n        <input matInput\n               [id]=\"id!\"\n               (blur)=\"onTouch()\"\n               [placeholder]=\"placeholder!\"\n               [matDatepicker]=\"dp\"\n               [value]=\"value\"\n               [disabled]=\"disabled\"\n               [name]=\"fieldName!\"\n               [min]=\"minDate\"\n               [max]=\"maxDate\"\n               [readonly]=\"preventUserInput\"\n               (change)=\"onInput($event)\"\n               (dateChange)=\"onValueChange($event.value)\"\n        >\n        <mat-datepicker-toggle matIconSuffix [for]=\"dp\">\n          <ui-icon *ngIf=\"applicationTheme !== 'classic'\" matDatepickerToggleIcon [applicationTheme]=\"applicationTheme\" name=\"Calendar\" size=\"24\" color=\"inherit\"></ui-icon>\n        </mat-datepicker-toggle>\n        <mat-datepicker panelClass=\"month-picker\" #dp startView=\"multi-year\" (monthSelected)=\"setMonthAndYear($event, dp)\"></mat-datepicker>\n      </ng-container>\n\n      <mat-hint class=\"info\" *ngIf=\"hint && !_errors && !(ngControl?.touched && (ngControl?.errors | hasValidationError))\">{{ hint }}</mat-hint>\n      <mat-hint class=\"error\" *ngIf=\"errorsLength || (ngControl?.touched && (ngControl?.errors | hasValidationError))\">\n        <ng-container *ngIf=\"errorsLength\">\n          <div class=\"errors\" *ngFor=\"let error of _errors\">\n            <ui-icon [applicationTheme]=\"applicationTheme\" name=\"Error\"></ui-icon>\n            <span [innerHTML]=\"error\"></span>\n          </div>\n        </ng-container>\n        <ui-validation-error *ngIf=\"ngControl && !hideBuiltInErrors\" [ngControl]=\"ngControl\" [label]=\"hideLabelInErrors ? null : label\"></ui-validation-error>\n      </mat-hint>\n\n    </mat-form-field>\n  </ng-template>\n\n</ng-container>\n"]}
|
|
336
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/datepicker/datepicker.component.ts","../../../../../projects/tgo-canopy-ui/components/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-underscore-dangle */\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  Renderer2,\n  Self,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, FormControl, FormGroup, NgControl } from '@angular/forms';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { MatDatepicker } from '@angular/material/datepicker';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { adjustLightness } from \"../../utils/color-contrast\";\nimport { DateAdapter, MAT_DATE_FORMATS } from \"@angular/material/core\";\nimport { UI_DATE_FORMATS, UiDateAdapter } from \"./DateAdapter\";\nimport { DatepickerService } from \"./datepicker.service\";\n\n@Component({\n  selector: 'ui-datepicker',\n  templateUrl: './datepicker.component.html',\n  styleUrls: ['./datepicker.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    { provide: DateAdapter, useClass: UiDateAdapter },\n    { provide: MAT_DATE_FORMATS, useValue: UI_DATE_FORMATS }\n  ]\n})\n// eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\nexport class DatepickerComponent implements OnChanges, ControlValueAccessor, DoCheck {\n  @HostBinding() class = 'ui-datepicker';\n\n  /**\n   * Form field label\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() label? = '';\n\n  /**\n   * Input name attribute\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() fieldName?: string;\n\n  /**\n   * Input placeholder\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() placeholder? = '';\n\n  /**\n   * Input id\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() id? = '';\n\n  /**\n   * Input value\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() value?: Date[] | Date;\n\n  _errors: SafeHtml[];\n  /**\n   * Input field errors\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() set errors(errors: string[]) {\n    this._errors = errors?.filter(Boolean).map(error => this.sanitizer.bypassSecurityTrustHtml(error));\n    this.errorsLength = this.setErrorsLength();\n  }\n\n  /**\n   * Determines if input is date range\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() isRange: boolean;\n\n  /**\n   * Determines if input is disabled\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() disabled: boolean;\n\n  /**\n   * Input is required or not\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() required: boolean;\n\n  /**\n   * Hint text\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() hintMessage: string;\n\n  /**\n   * Input is update only on blur\n   *\n   * @type {Boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() updateOnBlur = false;\n\n  /**\n   * Show reserved content below form field\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() showBottomContent = true;\n\n  /**\n   * Set full width DatepickerComponent\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() fullWidth = false;\n\n  /**\n   * Set min date for Datepicker\n   *\n   * @type {Date}\n   * @memberof DatepickerComponent\n   */\n  @Input() minDate: Date | undefined;\n\n  /**\n   * Set max date for Datepicker\n   *\n   * @type {Date}\n   * @memberof DatepickerComponent\n   */\n  @Input() maxDate: Date | undefined;\n\n  /**\n   * Show and pick date without day\n   * @default false\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() monthPicker = false;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof DatepickerComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Hide in-build errors for Reactive Forms\n   *\n   * @type {number}\n   * @memberof DatepickerComponent\n   */\n  @Input() hideBuiltInErrors = false;\n\n  /**\n   * Hide label in errors\n   *\n   * @type {number}\n   * @memberof DatepickerComponent\n   */\n  @Input() hideLabelInErrors = false;\n\n  /**\n   * Prevent user input\n   *\n   * @type {boolean}\n   * @memberof DatepickerComponent\n   */\n  @Input() preventUserInput = false;\n\n  /**\n   * Color of the option hover.\n   * Defaults to Test Gorilla primary color.\n   *\n   * @type {string}\n   * @memberof DatepickerComponent\n   */\n  @Input() companyColor: string = ''\n\n  /**\n   * Use browser timezone\n   * @type boolean\n   * @memberof DatepickerComponent\n   */\n  @Input() set browserTimezone(value: boolean) {\n    this.datepickerService.useBrowserTimezone = value;\n  }\n\n  /**\n   * @ignore\n   */\n  onChange = (_: any) => {};\n\n  /**\n   * @ignore\n   */\n  onTouch = () => {};\n\n  /**\n   * Event emitted when the value is change - when used outside of form\n   *\n   * @type {Date}\n   * @memberof DatepickerComponent\n   */\n  @Output() changed = new EventEmitter<Date | Date[]>();\n\n  range = new FormGroup({\n    start: new FormControl<Date | null>(null),\n    end: new FormControl<Date | null>(null),\n  });\n\n  errorsLength: boolean;\n  protected translationContext = 'DATEPICKER.';\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private cdr: ChangeDetectorRef,\n    private sanitizer: DomSanitizer,\n    @Optional() @Self() public ngControl: NgControl,\n    private renderer2: Renderer2,\n    private datepickerService: DatepickerService\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  get hint(): string {\n    if (this.hintMessage === undefined) {\n      return this.isRange ?  'MM/DD/YYYY - MM/DD/YYYY' : this.monthPicker ? 'MM/YYYY' :  'MM/DD/YYYY';\n    }\n\n    return this.hintMessage;\n  }\n\n  /**\n   * Used to mark component view as dirty when touched programmatically with markAsTouched/markAllAsTouched or errors\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 || this.ngControl?.errors) {\n      this.cdr.markForCheck();\n    }\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnInit() {\n    document.body.setAttribute('theme', this.applicationTheme);\n    this.setStyleVariable();\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.isRange) {\n      this.setRange();\n    }\n    if (changes['companyColor']) {\n      this.setStyleVariable();\n    }\n  }\n\n  // Set errors length for validation\n  // Consider only those errors which which are not empty\n  setErrorsLength(): boolean {\n    if (!!this._errors) {\n      return this._errors.filter(err => !!err).length > 0 ? true : false;\n    }\n    return false;\n  }\n\n  onValueChange(value: Date | Date[]) {\n    this.writeValue(value);\n    this.errorsLength = this.setErrorsLength();\n    if (!this.updateOnBlur) {\n      this.onTouch();\n    }\n    this.onChange(value);\n    this.changed.emit(value);\n  }\n\n  writeValue(value?: Date | Date[]): void {\n    this.value = value;\n    if (this.isRange) {\n      this.setRange();\n    }\n  }\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  dateRangeChange() {\n    const start = this.range.controls.start.value!;\n    const end = this.range.controls.end.value!;\n    this.onValueChange([new Date(start), new Date(end)]);\n  }\n\n  setMonthAndYear(normalizedMonthAndYear: any, datepicker: MatDatepicker<Date>) {\n    const ctrlValue = (this.value) as Date || new Date();\n\n    ctrlValue.setMonth(normalizedMonthAndYear.getMonth());\n    ctrlValue.setFullYear(normalizedMonthAndYear.getFullYear());\n\n    datepicker.close();\n\n    this.onValueChange(new Date(ctrlValue));\n  }\n\n  private setRange() {\n    if (Array.isArray(this.value)) {\n      const [start, end] = this.value;\n      const startDate = this.range.controls.start.value;\n      const endDate = this.range.controls.end.value;\n\n      if (startDate) {\n        this.range.controls.start.setValue(new Date(start));\n      }\n\n      if (endDate) {\n        this.range.controls.end.setValue(new Date(end));\n      }\n    }\n\n    if (!this.value) {\n      this.range.controls.start.setValue(null);\n      this.range.controls.end.setValue(null);\n    }\n  }\n\n  onInput(event: Event) {\n    const target = event.target as EventTarget & { value: string };\n    const [month, year] = target.value.split('/');\n    const date = new Date().getDate();\n    const fullDateString = `${month}/${date}/${year}`;\n    const fullDate = new Date(fullDateString);\n    this.onValueChange(fullDate);\n  }\n\n  private setStyleVariable() {\n    const hover = this.companyColor ? adjustLightness(this.companyColor, 'hover') : '#FFF2FC';\n    this.renderer2.setStyle(document.body, '--datepicker-hover-color', hover);\n    this.renderer2.setStyle(document.body,'--datepicker-selected-color', `${this.companyColor || '#D410AA'}`);\n  }\n}\n","<ng-container>\n  <mat-form-field\n    *ngIf=\"!monthPicker; else dateYearPicker\"\n    #uiDatepicker\n    appearance=\"outline\"\n    [color]=\"(errorsLength || (ngControl?.errors && ngControl?.touched ))  ? 'warn' : 'accent'\"\n    [ngClass]=\"{ 'hide-bottom-content': !showBottomContent, 'full-width': fullWidth }\"\n  >\n    <mat-label *ngIf=\"label\">{{ label }}<span *ngIf=\"required\"> *</span></mat-label>\n    <ng-container *ngIf=\"!isRange\">\n      <input *ngIf=\"!isRange\" matInput\n             [matDatepicker]=\"picker\"\n             (blur)=\"onTouch()\"\n             (dateChange)=\"onValueChange($event.value)\"\n             [id]=\"id!\"\n             [placeholder]=\"placeholder!\"\n             [value]=\"value\"\n             [disabled]=\"disabled\"\n             [name]=\"fieldName!\"\n             [readonly]=\"preventUserInput\"\n             [min]=\"minDate\"\n             [max]=\"maxDate\"\n      />\n      <mat-datepicker-toggle matIconSuffix [for]=\"picker\">\n        <ui-icon matDatepickerToggleIcon [applicationTheme]=\"applicationTheme\" name=\"Calendar\" size=\"24\" color=\"inherit\"></ui-icon>\n      </mat-datepicker-toggle>\n      <mat-datepicker #picker></mat-datepicker>\n    </ng-container>\n\n    <ng-container *ngIf=\"isRange\">\n      <mat-date-range-input *ngIf=\"isRange\" [formGroup]=\"range\" [rangePicker]=\"rangePicker\" [min]=\"minDate\" [max]=\"maxDate\" >\n        <input matStartDate formControlName=\"start\" [placeholder]=\"(translationContext + 'START_DATE') | uiTranslate | async\" (dateChange)=\"dateRangeChange()\">\n        <input matEndDate formControlName=\"end\" [placeholder]=\"(translationContext + 'END_DATE') | uiTranslate | async\" (dateChange)=\"dateRangeChange()\">\n      </mat-date-range-input>\n      <mat-datepicker-toggle matIconSuffix [for]=\"rangePicker\">\n        <ui-icon matDatepickerToggleIcon [applicationTheme]=\"applicationTheme\" name=\"Calendar\" size=\"24\" color=\"inherit\"></ui-icon>\n      </mat-datepicker-toggle>\n      <mat-date-range-picker #rangePicker></mat-date-range-picker>\n    </ng-container>\n\n    <mat-hint class=\"info\" *ngIf=\"hint && !_errors && !(ngControl?.touched && (ngControl?.errors | hasValidationError))\">{{ hint }}</mat-hint>\n    <mat-hint class=\"error\" *ngIf=\"errorsLength || (ngControl?.touched && (ngControl?.errors | hasValidationError))\">\n      <ng-container *ngIf=\"errorsLength\">\n        <div class=\"errors\" *ngFor=\"let error of _errors\">\n          <ui-icon [applicationTheme]=\"applicationTheme\" name=\"Error\"></ui-icon>\n          <span [innerHTML]=\"error\"></span>\n        </div>\n      </ng-container>\n      <ui-validation-error *ngIf=\"ngControl && !hideBuiltInErrors\" [ngControl]=\"ngControl\" [label]=\"hideLabelInErrors ? null : label\"></ui-validation-error>\n    </mat-hint>\n  </mat-form-field>\n\n  <ng-template #dateYearPicker>\n    <mat-form-field\n      appNoDateFormat\n      #uiDatepicker\n      appearance=\"outline\"\n      [color]=\"(errorsLength || (ngControl?.errors && ngControl?.touched ))  ? 'warn' : 'accent'\"\n      [ngClass]=\"{ 'hide-bottom-content': !showBottomContent, 'full-width': fullWidth }\"\n    >\n      <mat-label *ngIf=\"label\">{{ label }}<span *ngIf=\"required\"> *</span></mat-label>\n\n      <ng-container >\n        <input matInput\n               [id]=\"id!\"\n               (blur)=\"onTouch()\"\n               [placeholder]=\"placeholder!\"\n               [matDatepicker]=\"dp\"\n               [value]=\"value\"\n               [disabled]=\"disabled\"\n               [name]=\"fieldName!\"\n               [min]=\"minDate\"\n               [max]=\"maxDate\"\n               [readonly]=\"preventUserInput\"\n               (change)=\"onInput($event)\"\n               (dateChange)=\"onValueChange($event.value)\"\n        >\n        <mat-datepicker-toggle matIconSuffix [for]=\"dp\">\n          <ui-icon *ngIf=\"applicationTheme !== 'classic'\" matDatepickerToggleIcon [applicationTheme]=\"applicationTheme\" name=\"Calendar\" size=\"24\" color=\"inherit\"></ui-icon>\n        </mat-datepicker-toggle>\n        <mat-datepicker panelClass=\"month-picker\" #dp startView=\"multi-year\" (monthSelected)=\"setMonthAndYear($event, dp)\"></mat-datepicker>\n      </ng-container>\n\n      <mat-hint class=\"info\" *ngIf=\"hint && !_errors && !(ngControl?.touched && (ngControl?.errors | hasValidationError))\">{{ hint }}</mat-hint>\n      <mat-hint class=\"error\" *ngIf=\"errorsLength || (ngControl?.touched && (ngControl?.errors | hasValidationError))\">\n        <ng-container *ngIf=\"errorsLength\">\n          <div class=\"errors\" *ngFor=\"let error of _errors\">\n            <ui-icon [applicationTheme]=\"applicationTheme\" name=\"Error\"></ui-icon>\n            <span [innerHTML]=\"error\"></span>\n          </div>\n        </ng-container>\n        <ui-validation-error *ngIf=\"ngControl && !hideBuiltInErrors\" [ngControl]=\"ngControl\" [label]=\"hideLabelInErrors ? null : label\"></ui-validation-error>\n      </mat-hint>\n\n    </mat-form-field>\n  </ng-template>\n\n</ng-container>\n"]}
|
|
@@ -9352,9 +9352,8 @@ class DatepickerComponent {
|
|
|
9352
9352
|
}
|
|
9353
9353
|
setStyleVariable() {
|
|
9354
9354
|
const hover = this.companyColor ? adjustLightness(this.companyColor, 'hover') : '#FFF2FC';
|
|
9355
|
-
this.renderer2.
|
|
9356
|
-
|
|
9357
|
-
--datepicker-selected-color: ${this.companyColor || '#D410AA'}`);
|
|
9355
|
+
this.renderer2.setStyle(document.body, '--datepicker-hover-color', hover);
|
|
9356
|
+
this.renderer2.setStyle(document.body, '--datepicker-selected-color', `${this.companyColor || '#D410AA'}`);
|
|
9358
9357
|
}
|
|
9359
9358
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: DatepickerComponent, deps: [{ token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: i0.ChangeDetectorRef }, { token: i2.DomSanitizer }, { token: i1$2.NgControl, optional: true, self: true }, { token: i0.Renderer2 }, { token: DatepickerService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
9360
9359
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.7", type: DatepickerComponent, selector: "ui-datepicker", inputs: { label: "label", fieldName: "fieldName", placeholder: "placeholder", id: "id", value: "value", errors: "errors", isRange: "isRange", disabled: "disabled", required: "required", hintMessage: "hintMessage", updateOnBlur: "updateOnBlur", showBottomContent: "showBottomContent", fullWidth: "fullWidth", minDate: "minDate", maxDate: "maxDate", monthPicker: "monthPicker", applicationTheme: "applicationTheme", hideBuiltInErrors: "hideBuiltInErrors", hideLabelInErrors: "hideLabelInErrors", preventUserInput: "preventUserInput", companyColor: "companyColor", browserTimezone: "browserTimezone" }, outputs: { changed: "changed" }, host: { properties: { "class": "this.class" } }, providers: [
|
|
@@ -11186,7 +11185,7 @@ class AutocompleteComponent {
|
|
|
11186
11185
|
* Adding company color variable to the body to style overlay container that's out of the component scope.
|
|
11187
11186
|
*/
|
|
11188
11187
|
setCompanyColorVariable() {
|
|
11189
|
-
this.renderer2.
|
|
11188
|
+
this.renderer2.setStyle(document.body, '--ui-autocomplete-option-color', `${this.companyColor}`);
|
|
11190
11189
|
}
|
|
11191
11190
|
subscriberDisplayChange() {
|
|
11192
11191
|
const autocompleteHostElement = this.el.nativeElement;
|