@leanix/components 0.4.503 → 0.4.505

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.
Files changed (31) hide show
  1. package/esm2022/lib/core-ui/components/badge/badge.component.mjs +1 -9
  2. package/esm2022/lib/core-ui/components/banner/banner.component.mjs +1 -11
  3. package/esm2022/lib/core-ui/components/button/button.component.mjs +1 -9
  4. package/esm2022/lib/core-ui/components/card/card.component.mjs +1 -9
  5. package/esm2022/lib/core-ui/components/counter/counter.component.mjs +1 -9
  6. package/esm2022/lib/core-ui/components/skeleton/skeleton.component.mjs +1 -12
  7. package/esm2022/lib/core-ui/components/tiny-spinner/tiny-spinner.component.mjs +1 -9
  8. package/esm2022/lib/core-ui/tooltip/tooltip.directive.mjs +1 -9
  9. package/esm2022/lib/forms-ui/components/breadcrumb/breadcrumb.component.mjs +1 -9
  10. package/esm2022/lib/forms-ui/components/date-input/date-input.component.mjs +1 -9
  11. package/esm2022/lib/forms-ui/components/single-select/single-select.component.mjs +1 -12
  12. package/esm2022/lib/forms-ui/components/switch/switch.component.mjs +1 -9
  13. package/esm2022/lib/popover-ui/components/popover/popover.component.mjs +3 -9
  14. package/esm2022/lib/tab-ui/components/tab-group/tab-group.component.mjs +8 -24
  15. package/fesm2022/leanix-components.mjs +9 -135
  16. package/fesm2022/leanix-components.mjs.map +1 -1
  17. package/lib/core-ui/components/badge/badge.component.d.ts +0 -8
  18. package/lib/core-ui/components/banner/banner.component.d.ts +0 -10
  19. package/lib/core-ui/components/button/button.component.d.ts +0 -8
  20. package/lib/core-ui/components/card/card.component.d.ts +0 -8
  21. package/lib/core-ui/components/counter/counter.component.d.ts +0 -8
  22. package/lib/core-ui/components/skeleton/skeleton.component.d.ts +0 -11
  23. package/lib/core-ui/components/tiny-spinner/tiny-spinner.component.d.ts +0 -8
  24. package/lib/core-ui/tooltip/tooltip.directive.d.ts +0 -8
  25. package/lib/forms-ui/components/breadcrumb/breadcrumb.component.d.ts +0 -8
  26. package/lib/forms-ui/components/date-input/date-input.component.d.ts +0 -8
  27. package/lib/forms-ui/components/single-select/single-select.component.d.ts +0 -11
  28. package/lib/forms-ui/components/switch/switch.component.d.ts +0 -8
  29. package/lib/popover-ui/components/popover/popover.component.d.ts +2 -8
  30. package/lib/tab-ui/components/tab-group/tab-group.component.d.ts +10 -23
  31. package/package.json +1 -1
@@ -14,17 +14,6 @@ import { BasicDropdownComponent } from '../basic-dropdown/basic-dropdown.compone
14
14
  import { KeyboardSelectAction } from '../keyboard-select.directive';
15
15
  import * as i0 from "@angular/core";
16
16
  import * as i1 from "@angular/forms";
17
- /**
18
- * ## Usage
19
- *
20
- * 1. Import the `LxFormsModule` module from `@leanix/components` in your module where you want to use the component.
21
- *
22
- * ```ts
23
- * import { LxFormsModule } from '@leanix/components';
24
- * ```
25
- *
26
- * 2. Use the component in your template.
27
- */
28
17
  export class SingleSelectComponent extends BaseSelectDirective {
29
18
  /** @internal */
30
19
  static calculateNewCursorPostionOnKeyboardNavigation(cursorPosition, keyCode) {
@@ -298,4 +287,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
298
287
  type: ViewChild,
299
288
  args: ['queryInput', { static: true }]
300
289
  }] } });
301
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"single-select.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/single-select/single-select.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/single-select/single-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe, NgIf, NgTemplateOutlet } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  TemplateRef,\n  ViewChild,\n  booleanAttribute,\n  forwardRef\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\nimport { get, includes, isEqual } from 'lodash/fp';\nimport { Subject, fromEvent } from 'rxjs';\nimport { distinctUntilChanged, filter, map, takeUntil, tap } from 'rxjs/operators';\nimport { MarkInvalidDirective } from '../../directives/mark-invalid.directive';\nimport { SelectDropdownDirective } from '../../directives/select-dropdown.directive';\nimport { SelectedOptionDirective } from '../../directives/selected-option.directive';\nimport { ARROW_LEFT, ARROW_RIGHT, BACKSPACE, ESCAPE, TAB } from '../../helpers/key-codes.constants';\nimport { getKeyboardNavigationEvents } from '../../helpers/keyboard-navigation.helpers';\nimport { BaseSelectDirective } from '../../models/base-select.directive';\nimport { SingleSelectPadding } from '../../models/single-select-padding.interface';\nimport { BasicDropdownComponent } from '../basic-dropdown/basic-dropdown.component';\nimport { KeyboardSelectAction } from '../keyboard-select.directive';\n\nexport type SingleSelectSize = 'default' | 'small' | 'select2' | 'large';\n\n/**\n * ## Usage\n *\n * 1. Import the `LxFormsModule` module from `@leanix/components` in your module where you want to use the component.\n *\n * ```ts\n * import { LxFormsModule } from '@leanix/components';\n * ```\n *\n * 2. Use the component in your template.\n */\n@Component({\n  selector: 'lx-single-select',\n  templateUrl: 'single-select.component.html',\n  styleUrls: ['single-select.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      multi: true,\n      useExisting: forwardRef(() => SingleSelectComponent)\n    }\n  ],\n  standalone: true,\n  imports: [NgIf, MarkInvalidDirective, NgTemplateOutlet, FormsModule, ReactiveFormsModule, AsyncPipe]\n})\nexport class SingleSelectComponent extends BaseSelectDirective implements OnDestroy, AfterViewInit, ControlValueAccessor {\n  /** @internal */\n  public static calculateNewCursorPostionOnKeyboardNavigation(cursorPosition: number, keyCode: number) {\n    switch (keyCode) {\n      case ARROW_LEFT:\n        cursorPosition--;\n        break;\n      case ARROW_RIGHT:\n        cursorPosition++;\n        break;\n    }\n    return cursorPosition;\n  }\n\n  /** @internal */\n  public static getKeyboardSelectAction(cursorPosition: number, keyCode: number): KeyboardSelectAction | null {\n    if (cursorPosition <= -1 && keyCode === ARROW_RIGHT) {\n      return KeyboardSelectAction.NEXT;\n    }\n    if (cursorPosition === -1 && keyCode === ARROW_LEFT) {\n      return KeyboardSelectAction.LAST;\n    }\n    if (cursorPosition < -1 && keyCode === ARROW_LEFT) {\n      return KeyboardSelectAction.PREV;\n    }\n    if (cursorPosition <= -1 && keyCode === BACKSPACE) {\n      return KeyboardSelectAction.EXECUTE;\n    }\n    return null;\n  }\n\n  @Input() selection: any;\n  @Input() selectionBackground: 'white' | 'gray' = 'white';\n  @Input() size: SingleSelectSize = 'default';\n  @Input() padding?: SingleSelectPadding = 'default';\n  @Input() inputId?: string;\n  @Input({ transform: booleanAttribute }) required: boolean = false;\n\n  @Output() selectionChange = new EventEmitter<any>();\n  @Output() blur = new EventEmitter<FocusEvent>();\n\n  /** @internal */\n  @ContentChild(SelectDropdownDirective, { read: TemplateRef, static: true }) explicitDropdown?: TemplateRef<any>;\n  /** @internal */\n  @ContentChild(SelectedOptionDirective, { read: TemplateRef, static: true }) explicitSelectedOption?: TemplateRef<any>;\n  /** @internal */\n  @ContentChild(BasicDropdownComponent, { static: false }) private dropdownComponent?: BasicDropdownComponent;\n\n  /** @internal */\n  @ViewChild('selectedOption', { static: true }) implicitSelectedOption!: TemplateRef<any>;\n  /** @internal */\n  @ViewChild('dropdown', { static: true }) implicitDropdown!: TemplateRef<any>;\n\n  /** @internal */\n  get selectedOptionTmpl() {\n    return this.explicitSelectedOption || this.implicitSelectedOption;\n  }\n\n  /** @internal */\n  get dropdownTmpl() {\n    return this.explicitDropdown || this.implicitDropdown;\n  }\n\n  @Input() allowClear = true;\n  @Input() tabIndex: number = 0;\n  @Input() markInvalid: boolean = false;\n\n  /** @internal */\n  @ViewChild('queryInput', { static: true }) queryInput!: ElementRef<HTMLInputElement>;\n\n  /** @internal */\n  override readonly destroyed$ = new Subject<void>();\n  /** @internal */\n  isInputFocusedViaTab = false;\n\n  constructor(private cd: ChangeDetectorRef) {\n    super();\n  }\n\n  /** @internal */\n  get cursorStyle() {\n    if (this.disabled) {\n      return 'default';\n    } else if (this.allowQuery) {\n      return 'text';\n    } else {\n      return 'pointer';\n    }\n  }\n\n  /** @internal */\n  resetInput() {\n    this.queryControl.reset('', { emitEvent: false });\n  }\n\n  /** @internal */\n  focus() {\n    this.queryInput.nativeElement.focus();\n  }\n\n  /** @internal */\n  focusAndOpen() {\n    this.queryInput.nativeElement.focus();\n    this.open.next(true);\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n    this.destroyed$.next();\n  }\n\n  override ngAfterViewInit() {\n    super.ngAfterViewInit();\n    this.open\n      .pipe(\n        distinctUntilChanged(),\n        filter((open) => open && !!this.dropdownComponent),\n        map(() => this.selection),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((selection) => {\n        if (selection) {\n          const index = this.determineHighlightIndex(this.dropdownComponent!.options, selection, this.dropdownComponent!.itemKey);\n          if (index > -1) {\n            this.dropdownComponent!.select(index);\n          } else {\n            this.selectFirstOption();\n          }\n        } else {\n          this.selectFirstOption();\n        }\n      });\n\n    // keyboard event handling\n    const sourceElement = this.queryInput.nativeElement;\n    // handle keyboard navigation for the selection\n    fromEvent<KeyboardEvent>(sourceElement, 'keydown')\n      .pipe(\n        map((event) => this.mapToEventSet(event, sourceElement, this.virtualCursorPosition)),\n        tap((eventSet) => {\n          if (!this.allowQuery && eventSet.event.keyCode !== BACKSPACE) {\n            // additional check for even.code for userEvent API compatibility\n            if (eventSet.event.keyCode !== TAB && eventSet.event.code !== 'Tab') {\n              // if querying is disabled, only the tab key press event will be propagated, so that you can still defocus.\n              eventSet.event.preventDefault();\n            }\n            return;\n          }\n          if (\n            eventSet.virtualCursorPosition === 0 &&\n            eventSet.inputCursorPosition === 0 &&\n            eventSet.event.keyCode === BACKSPACE &&\n            this.selection &&\n            this.allowClear\n          ) {\n            this.removeSelection();\n            eventSet.inputCursorPosition = undefined; // set to null to prevent continuing in the stream\n          }\n          if (typeof eventSet.inputCursorPosition === 'number' && eventSet.inputCursorPosition > 0) {\n            this.virtualCursorPosition = 0;\n          } else if (eventSet.virtualCursorPosition === -1 && eventSet.event.keyCode === ARROW_RIGHT) {\n            eventSet.event.preventDefault();\n            this.selectionKeyboardSelectAction$.next(KeyboardSelectAction.UNSELECT);\n            this.virtualCursorPosition = 0;\n            eventSet.inputCursorPosition = undefined; // set to null to prevent continuing in the stream\n          }\n        }),\n        filter((eventSet) => this.allowQuery && eventSet.inputCursorPosition === 0),\n        map((eventSet) => eventSet.event),\n        filter((event) => includes(event.keyCode, [ARROW_RIGHT, ARROW_LEFT, BACKSPACE])),\n        map((event) => {\n          this.virtualCursorPosition = SingleSelectComponent.calculateNewCursorPostionOnKeyboardNavigation(\n            this.virtualCursorPosition,\n            event.keyCode\n          );\n          return {\n            cursorPosition: this.virtualCursorPosition,\n            event\n          };\n        }),\n        map((positionSet) => {\n          const action = SingleSelectComponent.getKeyboardSelectAction(positionSet.cursorPosition, positionSet.event.keyCode);\n          if (action === KeyboardSelectAction.NEXT) {\n            // prevent cursor from moving in the input field, while we are still in the selection items\n            positionSet.event.preventDefault();\n          }\n          return action;\n        }),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe(this.selectionKeyboardSelectAction$);\n\n    const keyboardEvents = getKeyboardNavigationEvents(sourceElement, this.destroyed$);\n\n    keyboardEvents.verticalNavigation$.subscribe((event) => {\n      event.preventDefault();\n    });\n\n    keyboardEvents.close$.subscribe((event) => {\n      if (event.keyCode === ESCAPE && this.dropdownOpen) {\n        event.preventDefault();\n        event.stopImmediatePropagation();\n      }\n      this.open.next(false);\n    });\n\n    keyboardEvents.dropdownKeyboardEvent$.subscribe(this.optionsKeyboardSelectAction$);\n\n    keyboardEvents.enter$.subscribe(() => this.open.next(!this.dropdownOpen));\n    keyboardEvents.space$.pipe(filter(() => !this.allowQuery)).subscribe(() => {\n      if (this.dropdownOpen) {\n        this.optionsKeyboardSelectAction$.next(KeyboardSelectAction.EXECUTE);\n      }\n      this.open.next(!this.dropdownOpen);\n    });\n\n    keyboardEvents.openOnArrowDown$.subscribe(() => this.open.next(true));\n  }\n\n  /** @internal */\n  selectOption(option: any) {\n    this.selection = option;\n\n    this.selectionChange.emit(option);\n    this.propagateChange(option);\n\n    this.resetSelectState();\n\n    // This timeout makes sure that the dropdown will be closed at the end\n    // of all the callbacks in the open subscriptions.\n    setTimeout(() => {\n      this.open.next(false);\n    });\n  }\n\n  /** @internal */\n  removeSelection() {\n    this.selection = null;\n    this.cd.markForCheck();\n    this.cd.detectChanges();\n\n    this.selectionChange.emit(this.selection);\n    this.propagateChange(this.selection);\n\n    this.resetSelectState();\n  }\n\n  /** @internal */\n  propagateChange(_value: any) {}\n\n  /** @internal */\n  writeValue(newSelection: any) {\n    this.selection = newSelection;\n  }\n\n  /** @internal */\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  /** @internal */\n  registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  /** @internal */\n  registerOnTouched(_fn: any) {}\n\n  /** @internal */\n  focusedViaTab() {\n    this.isInputFocusedViaTab = true;\n  }\n\n  private determineHighlightIndex(options: any[], selection: any, itemKey?: string) {\n    return itemKey\n      ? options.findIndex((option) => isEqual(get(itemKey, selection), get(itemKey, option)) || isEqual(selection, get(itemKey, option)))\n      : options.findIndex((option) => isEqual(selection, option));\n  }\n}\n","<div *ngIf=\"dropdownOpen\" class=\"backdrop\" (click)=\"handleBackdropClick($event)\"></div>\n<div\n  [lxMarkInvalid]=\"markInvalid\"\n  class=\"selectContainer {{ padding }}Padding\"\n  [class.open]=\"dropdownOpen\"\n  [class.top]=\"(dropdownDirection$ | async) === 'TOP'\"\n  [class.bottom]=\"(dropdownDirection$ | async) === 'BOTTOM'\"\n  [class.disabled]=\"disabled\"\n  [class.grayBackground]=\"selectionBackground === 'gray'\"\n  [class.defaultSize]=\"size === 'default'\"\n  [class.smallSize]=\"size === 'small'\"\n  [class.select2Size]=\"size === 'select2'\"\n  [class.largeSize]=\"size === 'large'\"\n  [style.cursor]=\"cursorStyle\"\n  [class.focused]=\"isInputFocused\"\n  [class.focusedVisible]=\"isInputFocusedViaTab\"\n  (click)=\"handleClick($event.target === toggle)\"\n>\n  <div class=\"selectionContainer\">\n    <div class=\"inputContainer\">\n      <div *ngIf=\"!selection && selection !== 0 && !queryInput?.value\" class=\"placeholder\" [attr.title]=\"placeholder\">\n        {{ placeholder }}\n      </div>\n      <div\n        *ngIf=\"!allowQuery || !queryInput?.value\"\n        class=\"selection\"\n        [class.lowerOpacity]=\"allowQuery && !queryInput?.value && dropdownOpen\"\n        [class.lightgrayColor]=\"!allowQuery && dropdownOpen\"\n        (click)=\"$event.stopPropagation(); focus()\"\n      >\n        <ng-container *ngTemplateOutlet=\"selectedOptionTmpl\" />\n      </div>\n      <input\n        #queryInput\n        class=\"queryInput\"\n        type=\"text\"\n        [attr.id]=\"inputId\"\n        [attr.required]=\"required ? 'true' : null\"\n        [class.isHidden]=\"!allowQuery\"\n        (keydown.enter)=\"$event.preventDefault()\"\n        (focus)=\"isInputFocused = true\"\n        (blur)=\"isInputFocused = false; isInputFocusedViaTab = false; blur.emit($event)\"\n        (keyup.tab)=\"focusedViaTab()\"\n        (keyup.shift.tab)=\"focusedViaTab()\"\n        [tabIndex]=\"disabled ? -1 : tabIndex\"\n        [formControl]=\"queryControl\"\n        [readOnly]=\"!allowQuery\"\n      />\n    </div>\n    <div class=\"iconContainer\">\n      <i *ngIf=\"(selection || selection === 0) && allowClear && !disabled\" class=\"far fa-times\" (click)=\"removeSelection()\"></i>\n      <i #toggle class=\"fas fa-angle-down\" aria-hidden=\"true\"></i>\n    </div>\n  </div>\n  <div class=\"optionsContainer\" #optionsContainer>\n    <ng-container *ngIf=\"dropdownOpen\">\n      <ng-container *ngTemplateOutlet=\"dropdownTmpl\" />\n    </ng-container>\n  </div>\n</div>\n\n<ng-template #selectedOption>\n  <ng-content select=\".selectedOption\" />\n</ng-template>\n<ng-template #dropdown>\n  <ng-content select=\".dropdownComponent\" />\n</ng-template>\n"]}
290
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"single-select.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/single-select/single-select.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/single-select/single-select.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACpE,OAAO,EAGL,SAAS,EACT,YAAY,EAEZ,YAAY,EACZ,KAAK,EAEL,MAAM,EACN,WAAW,EACX,SAAS,EACT,gBAAgB,EAChB,UAAU,EACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,WAAW,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC3G,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAC1C,OAAO,EAAE,oBAAoB,EAAE,MAAM,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACnF,OAAO,EAAE,oBAAoB,EAAE,MAAM,yCAAyC,CAAC;AAC/E,OAAO,EAAE,uBAAuB,EAAE,MAAM,4CAA4C,CAAC;AACrF,OAAO,EAAE,uBAAuB,EAAE,MAAM,4CAA4C,CAAC;AACrF,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,mCAAmC,CAAC;AACpG,OAAO,EAAE,2BAA2B,EAAE,MAAM,2CAA2C,CAAC;AACxF,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AAEzE,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AACpF,OAAO,EAAE,oBAAoB,EAAE,MAAM,8BAA8B,CAAC;;;AAkBpE,MAAM,OAAO,qBAAsB,SAAQ,mBAAmB;IAC5D,gBAAgB;IACT,MAAM,CAAC,6CAA6C,CAAC,cAAsB,EAAE,OAAe;QACjG,QAAQ,OAAO,EAAE,CAAC;YAChB,KAAK,UAAU;gBACb,cAAc,EAAE,CAAC;gBACjB,MAAM;YACR,KAAK,WAAW;gBACd,cAAc,EAAE,CAAC;gBACjB,MAAM;QACV,CAAC;QACD,OAAO,cAAc,CAAC;IACxB,CAAC;IAED,gBAAgB;IACT,MAAM,CAAC,uBAAuB,CAAC,cAAsB,EAAE,OAAe;QAC3E,IAAI,cAAc,IAAI,CAAC,CAAC,IAAI,OAAO,KAAK,WAAW,EAAE,CAAC;YACpD,OAAO,oBAAoB,CAAC,IAAI,CAAC;QACnC,CAAC;QACD,IAAI,cAAc,KAAK,CAAC,CAAC,IAAI,OAAO,KAAK,UAAU,EAAE,CAAC;YACpD,OAAO,oBAAoB,CAAC,IAAI,CAAC;QACnC,CAAC;QACD,IAAI,cAAc,GAAG,CAAC,CAAC,IAAI,OAAO,KAAK,UAAU,EAAE,CAAC;YAClD,OAAO,oBAAoB,CAAC,IAAI,CAAC;QACnC,CAAC;QACD,IAAI,cAAc,IAAI,CAAC,CAAC,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;YAClD,OAAO,oBAAoB,CAAC,OAAO,CAAC;QACtC,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAwBD,gBAAgB;IAChB,IAAI,kBAAkB;QACpB,OAAO,IAAI,CAAC,sBAAsB,IAAI,IAAI,CAAC,sBAAsB,CAAC;IACpE,CAAC;IAED,gBAAgB;IAChB,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,gBAAgB,CAAC;IACxD,CAAC;IAcD,YAAoB,EAAqB;QACvC,KAAK,EAAE,CAAC;QADU,OAAE,GAAF,EAAE,CAAmB;QA3ChC,wBAAmB,GAAqB,OAAO,CAAC;QAChD,SAAI,GAAqB,SAAS,CAAC;QACnC,YAAO,GAAyB,SAAS,CAAC;QAEX,aAAQ,GAAY,KAAK,CAAC;QAExD,oBAAe,GAAG,IAAI,YAAY,EAAO,CAAC;QAC1C,SAAI,GAAG,IAAI,YAAY,EAAc,CAAC;QAwBvC,eAAU,GAAG,IAAI,CAAC;QAClB,aAAQ,GAAW,CAAC,CAAC;QACrB,gBAAW,GAAY,KAAK,CAAC;QAKtC,gBAAgB;QACE,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;QACnD,gBAAgB;QAChB,yBAAoB,GAAG,KAAK,CAAC;IAI7B,CAAC;IAED,gBAAgB;IAChB,IAAI,WAAW;QACb,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,OAAO,SAAS,CAAC;QACnB,CAAC;aAAM,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAC3B,OAAO,MAAM,CAAC;QAChB,CAAC;aAAM,CAAC;YACN,OAAO,SAAS,CAAC;QACnB,CAAC;IACH,CAAC;IAED,gBAAgB;IAChB,UAAU;QACR,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;IACpD,CAAC;IAED,gBAAgB;IAChB,KAAK;QACH,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACxC,CAAC;IAED,gBAAgB;IAChB,YAAY;QACV,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QACtC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACvB,CAAC;IAEQ,WAAW;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAEQ,eAAe;QACtB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI;aACN,IAAI,CACH,oBAAoB,EAAE,EACtB,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAClD,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAC3B;aACA,SAAS,CAAC,CAAC,SAAS,EAAE,EAAE;YACvB,IAAI,SAAS,EAAE,CAAC;gBACd,MAAM,KAAK,GAAG,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,iBAAkB,CAAC,OAAO,EAAE,SAAS,EAAE,IAAI,CAAC,iBAAkB,CAAC,OAAO,CAAC,CAAC;gBACxH,IAAI,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC;oBACf,IAAI,CAAC,iBAAkB,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBACxC,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBAC3B,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,CAAC;QACH,CAAC,CAAC,CAAC;QAEL,0BAA0B;QAC1B,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QACpD,+CAA+C;QAC/C,SAAS,CAAgB,aAAa,EAAE,SAAS,CAAC;aAC/C,IAAI,CACH,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,aAAa,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC,EACpF,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;YACf,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,QAAQ,CAAC,KAAK,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;gBAC7D,iEAAiE;gBACjE,IAAI,QAAQ,CAAC,KAAK,CAAC,OAAO,KAAK,GAAG,IAAI,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;oBACpE,2GAA2G;oBAC3G,QAAQ,CAAC,KAAK,CAAC,cAAc,EAAE,CAAC;gBAClC,CAAC;gBACD,OAAO;YACT,CAAC;YACD,IACE,QAAQ,CAAC,qBAAqB,KAAK,CAAC;gBACpC,QAAQ,CAAC,mBAAmB,KAAK,CAAC;gBAClC,QAAQ,CAAC,KAAK,CAAC,OAAO,KAAK,SAAS;gBACpC,IAAI,CAAC,SAAS;gBACd,IAAI,CAAC,UAAU,EACf,CAAC;gBACD,IAAI,CAAC,eAAe,EAAE,CAAC;gBACvB,QAAQ,CAAC,mBAAmB,GAAG,SAAS,CAAC,CAAC,kDAAkD;YAC9F,CAAC;YACD,IAAI,OAAO,QAAQ,CAAC,mBAAmB,KAAK,QAAQ,IAAI,QAAQ,CAAC,mBAAmB,GAAG,CAAC,EAAE,CAAC;gBACzF,IAAI,CAAC,qBAAqB,GAAG,CAAC,CAAC;YACjC,CAAC;iBAAM,IAAI,QAAQ,CAAC,qBAAqB,KAAK,CAAC,CAAC,IAAI,QAAQ,CAAC,KAAK,CAAC,OAAO,KAAK,WAAW,EAAE,CAAC;gBAC3F,QAAQ,CAAC,KAAK,CAAC,cAAc,EAAE,CAAC;gBAChC,IAAI,CAAC,8BAA8B,CAAC,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAC;gBACxE,IAAI,CAAC,qBAAqB,GAAG,CAAC,CAAC;gBAC/B,QAAQ,CAAC,mBAAmB,GAAG,SAAS,CAAC,CAAC,kDAAkD;YAC9F,CAAC;QACH,CAAC,CAAC,EACF,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,IAAI,QAAQ,CAAC,mBAAmB,KAAK,CAAC,CAAC,EAC3E,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,EACjC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,WAAW,EAAE,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC,EAChF,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YACZ,IAAI,CAAC,qBAAqB,GAAG,qBAAqB,CAAC,6CAA6C,CAC9F,IAAI,CAAC,qBAAqB,EAC1B,KAAK,CAAC,OAAO,CACd,CAAC;YACF,OAAO;gBACL,cAAc,EAAE,IAAI,CAAC,qBAAqB;gBAC1C,KAAK;aACN,CAAC;QACJ,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE;YAClB,MAAM,MAAM,GAAG,qBAAqB,CAAC,uBAAuB,CAAC,WAAW,CAAC,cAAc,EAAE,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACpH,IAAI,MAAM,KAAK,oBAAoB,CAAC,IAAI,EAAE,CAAC;gBACzC,2FAA2F;gBAC3F,WAAW,CAAC,KAAK,CAAC,cAAc,EAAE,CAAC;YACrC,CAAC;YACD,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAC3B;aACA,SAAS,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;QAElD,MAAM,cAAc,GAAG,2BAA2B,CAAC,aAAa,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QAEnF,cAAc,CAAC,mBAAmB,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACrD,KAAK,CAAC,cAAc,EAAE,CAAC;QACzB,CAAC,CAAC,CAAC;QAEH,cAAc,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACxC,IAAI,KAAK,CAAC,OAAO,KAAK,MAAM,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;gBAClD,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,KAAK,CAAC,wBAAwB,EAAE,CAAC;YACnC,CAAC;YACD,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;QAEH,cAAc,CAAC,sBAAsB,CAAC,SAAS,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;QAEnF,cAAc,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;QAC1E,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACxE,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;gBACtB,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;YACvE,CAAC;YACD,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;QAEH,cAAc,CAAC,gBAAgB,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACxE,CAAC;IAED,gBAAgB;IAChB,YAAY,CAAC,MAAW;QACtB,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC;QAExB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAClC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;QAE7B,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAExB,sEAAsE;QACtE,kDAAkD;QAClD,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB;IAChB,eAAe;QACb,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;QACvB,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QAExB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC1C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAErC,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,gBAAgB;IAChB,eAAe,CAAC,MAAW,IAAG,CAAC;IAE/B,gBAAgB;IAChB,UAAU,CAAC,YAAiB;QAC1B,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC;IAChC,CAAC;IAED,gBAAgB;IAChB,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IAED,gBAAgB;IAChB,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC5B,CAAC;IAED,gBAAgB;IAChB,iBAAiB,CAAC,GAAQ,IAAG,CAAC;IAE9B,gBAAgB;IAChB,aAAa;QACX,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;IACnC,CAAC;IAEO,uBAAuB,CAAC,OAAc,EAAE,SAAc,EAAE,OAAgB;QAC9E,OAAO,OAAO;YACZ,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,SAAS,CAAC,EAAE,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,IAAI,OAAO,CAAC,SAAS,EAAE,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC;YACnI,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,CAAC;IAChE,CAAC;8GArRU,qBAAqB;kGAArB,qBAAqB,2NAoCZ,gBAAgB,2JA9CzB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,KAAK,EAAE,IAAI;gBACX,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC;aACrD;SACF,wEA8Ca,uBAAuB,2BAAU,WAAW,oFAE5C,uBAAuB,2BAAU,WAAW,+EAE5C,sBAAsB,qaC5FtC,4oFAmEA,2+GDvBY,IAAI,6FAAE,oBAAoB,uFAAE,gBAAgB,mJAAE,WAAW,sZAAE,mBAAmB,6MAAE,SAAS;;2FAExF,qBAAqB;kBAdjC,SAAS;+BACE,kBAAkB,aAGjB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,KAAK,EAAE,IAAI;4BACX,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,sBAAsB,CAAC;yBACrD;qBACF,cACW,IAAI,WACP,CAAC,IAAI,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,WAAW,EAAE,mBAAmB,EAAE,SAAS,CAAC;sFAiC3F,SAAS;sBAAjB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACkC,QAAQ;sBAA/C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAE5B,eAAe;sBAAxB,MAAM;gBACG,IAAI;sBAAb,MAAM;gBAGqE,gBAAgB;sBAA3F,YAAY;uBAAC,uBAAuB,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE;gBAEE,sBAAsB;sBAAjG,YAAY;uBAAC,uBAAuB,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE;gBAET,iBAAiB;sBAAjF,YAAY;uBAAC,sBAAsB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAGR,sBAAsB;sBAApE,SAAS;uBAAC,gBAAgB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAEJ,gBAAgB;sBAAxD,SAAS;uBAAC,UAAU,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAY9B,UAAU;sBAAlB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAGqC,UAAU;sBAApD,SAAS;uBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { AsyncPipe, NgIf, NgTemplateOutlet } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  TemplateRef,\n  ViewChild,\n  booleanAttribute,\n  forwardRef\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\nimport { get, includes, isEqual } from 'lodash/fp';\nimport { Subject, fromEvent } from 'rxjs';\nimport { distinctUntilChanged, filter, map, takeUntil, tap } from 'rxjs/operators';\nimport { MarkInvalidDirective } from '../../directives/mark-invalid.directive';\nimport { SelectDropdownDirective } from '../../directives/select-dropdown.directive';\nimport { SelectedOptionDirective } from '../../directives/selected-option.directive';\nimport { ARROW_LEFT, ARROW_RIGHT, BACKSPACE, ESCAPE, TAB } from '../../helpers/key-codes.constants';\nimport { getKeyboardNavigationEvents } from '../../helpers/keyboard-navigation.helpers';\nimport { BaseSelectDirective } from '../../models/base-select.directive';\nimport { SingleSelectPadding } from '../../models/single-select-padding.interface';\nimport { BasicDropdownComponent } from '../basic-dropdown/basic-dropdown.component';\nimport { KeyboardSelectAction } from '../keyboard-select.directive';\n\nexport type SingleSelectSize = 'default' | 'small' | 'select2' | 'large';\n\n@Component({\n  selector: 'lx-single-select',\n  templateUrl: 'single-select.component.html',\n  styleUrls: ['single-select.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      multi: true,\n      useExisting: forwardRef(() => SingleSelectComponent)\n    }\n  ],\n  standalone: true,\n  imports: [NgIf, MarkInvalidDirective, NgTemplateOutlet, FormsModule, ReactiveFormsModule, AsyncPipe]\n})\nexport class SingleSelectComponent extends BaseSelectDirective implements OnDestroy, AfterViewInit, ControlValueAccessor {\n  /** @internal */\n  public static calculateNewCursorPostionOnKeyboardNavigation(cursorPosition: number, keyCode: number) {\n    switch (keyCode) {\n      case ARROW_LEFT:\n        cursorPosition--;\n        break;\n      case ARROW_RIGHT:\n        cursorPosition++;\n        break;\n    }\n    return cursorPosition;\n  }\n\n  /** @internal */\n  public static getKeyboardSelectAction(cursorPosition: number, keyCode: number): KeyboardSelectAction | null {\n    if (cursorPosition <= -1 && keyCode === ARROW_RIGHT) {\n      return KeyboardSelectAction.NEXT;\n    }\n    if (cursorPosition === -1 && keyCode === ARROW_LEFT) {\n      return KeyboardSelectAction.LAST;\n    }\n    if (cursorPosition < -1 && keyCode === ARROW_LEFT) {\n      return KeyboardSelectAction.PREV;\n    }\n    if (cursorPosition <= -1 && keyCode === BACKSPACE) {\n      return KeyboardSelectAction.EXECUTE;\n    }\n    return null;\n  }\n\n  @Input() selection: any;\n  @Input() selectionBackground: 'white' | 'gray' = 'white';\n  @Input() size: SingleSelectSize = 'default';\n  @Input() padding?: SingleSelectPadding = 'default';\n  @Input() inputId?: string;\n  @Input({ transform: booleanAttribute }) required: boolean = false;\n\n  @Output() selectionChange = new EventEmitter<any>();\n  @Output() blur = new EventEmitter<FocusEvent>();\n\n  /** @internal */\n  @ContentChild(SelectDropdownDirective, { read: TemplateRef, static: true }) explicitDropdown?: TemplateRef<any>;\n  /** @internal */\n  @ContentChild(SelectedOptionDirective, { read: TemplateRef, static: true }) explicitSelectedOption?: TemplateRef<any>;\n  /** @internal */\n  @ContentChild(BasicDropdownComponent, { static: false }) private dropdownComponent?: BasicDropdownComponent;\n\n  /** @internal */\n  @ViewChild('selectedOption', { static: true }) implicitSelectedOption!: TemplateRef<any>;\n  /** @internal */\n  @ViewChild('dropdown', { static: true }) implicitDropdown!: TemplateRef<any>;\n\n  /** @internal */\n  get selectedOptionTmpl() {\n    return this.explicitSelectedOption || this.implicitSelectedOption;\n  }\n\n  /** @internal */\n  get dropdownTmpl() {\n    return this.explicitDropdown || this.implicitDropdown;\n  }\n\n  @Input() allowClear = true;\n  @Input() tabIndex: number = 0;\n  @Input() markInvalid: boolean = false;\n\n  /** @internal */\n  @ViewChild('queryInput', { static: true }) queryInput!: ElementRef<HTMLInputElement>;\n\n  /** @internal */\n  override readonly destroyed$ = new Subject<void>();\n  /** @internal */\n  isInputFocusedViaTab = false;\n\n  constructor(private cd: ChangeDetectorRef) {\n    super();\n  }\n\n  /** @internal */\n  get cursorStyle() {\n    if (this.disabled) {\n      return 'default';\n    } else if (this.allowQuery) {\n      return 'text';\n    } else {\n      return 'pointer';\n    }\n  }\n\n  /** @internal */\n  resetInput() {\n    this.queryControl.reset('', { emitEvent: false });\n  }\n\n  /** @internal */\n  focus() {\n    this.queryInput.nativeElement.focus();\n  }\n\n  /** @internal */\n  focusAndOpen() {\n    this.queryInput.nativeElement.focus();\n    this.open.next(true);\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n    this.destroyed$.next();\n  }\n\n  override ngAfterViewInit() {\n    super.ngAfterViewInit();\n    this.open\n      .pipe(\n        distinctUntilChanged(),\n        filter((open) => open && !!this.dropdownComponent),\n        map(() => this.selection),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((selection) => {\n        if (selection) {\n          const index = this.determineHighlightIndex(this.dropdownComponent!.options, selection, this.dropdownComponent!.itemKey);\n          if (index > -1) {\n            this.dropdownComponent!.select(index);\n          } else {\n            this.selectFirstOption();\n          }\n        } else {\n          this.selectFirstOption();\n        }\n      });\n\n    // keyboard event handling\n    const sourceElement = this.queryInput.nativeElement;\n    // handle keyboard navigation for the selection\n    fromEvent<KeyboardEvent>(sourceElement, 'keydown')\n      .pipe(\n        map((event) => this.mapToEventSet(event, sourceElement, this.virtualCursorPosition)),\n        tap((eventSet) => {\n          if (!this.allowQuery && eventSet.event.keyCode !== BACKSPACE) {\n            // additional check for even.code for userEvent API compatibility\n            if (eventSet.event.keyCode !== TAB && eventSet.event.code !== 'Tab') {\n              // if querying is disabled, only the tab key press event will be propagated, so that you can still defocus.\n              eventSet.event.preventDefault();\n            }\n            return;\n          }\n          if (\n            eventSet.virtualCursorPosition === 0 &&\n            eventSet.inputCursorPosition === 0 &&\n            eventSet.event.keyCode === BACKSPACE &&\n            this.selection &&\n            this.allowClear\n          ) {\n            this.removeSelection();\n            eventSet.inputCursorPosition = undefined; // set to null to prevent continuing in the stream\n          }\n          if (typeof eventSet.inputCursorPosition === 'number' && eventSet.inputCursorPosition > 0) {\n            this.virtualCursorPosition = 0;\n          } else if (eventSet.virtualCursorPosition === -1 && eventSet.event.keyCode === ARROW_RIGHT) {\n            eventSet.event.preventDefault();\n            this.selectionKeyboardSelectAction$.next(KeyboardSelectAction.UNSELECT);\n            this.virtualCursorPosition = 0;\n            eventSet.inputCursorPosition = undefined; // set to null to prevent continuing in the stream\n          }\n        }),\n        filter((eventSet) => this.allowQuery && eventSet.inputCursorPosition === 0),\n        map((eventSet) => eventSet.event),\n        filter((event) => includes(event.keyCode, [ARROW_RIGHT, ARROW_LEFT, BACKSPACE])),\n        map((event) => {\n          this.virtualCursorPosition = SingleSelectComponent.calculateNewCursorPostionOnKeyboardNavigation(\n            this.virtualCursorPosition,\n            event.keyCode\n          );\n          return {\n            cursorPosition: this.virtualCursorPosition,\n            event\n          };\n        }),\n        map((positionSet) => {\n          const action = SingleSelectComponent.getKeyboardSelectAction(positionSet.cursorPosition, positionSet.event.keyCode);\n          if (action === KeyboardSelectAction.NEXT) {\n            // prevent cursor from moving in the input field, while we are still in the selection items\n            positionSet.event.preventDefault();\n          }\n          return action;\n        }),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe(this.selectionKeyboardSelectAction$);\n\n    const keyboardEvents = getKeyboardNavigationEvents(sourceElement, this.destroyed$);\n\n    keyboardEvents.verticalNavigation$.subscribe((event) => {\n      event.preventDefault();\n    });\n\n    keyboardEvents.close$.subscribe((event) => {\n      if (event.keyCode === ESCAPE && this.dropdownOpen) {\n        event.preventDefault();\n        event.stopImmediatePropagation();\n      }\n      this.open.next(false);\n    });\n\n    keyboardEvents.dropdownKeyboardEvent$.subscribe(this.optionsKeyboardSelectAction$);\n\n    keyboardEvents.enter$.subscribe(() => this.open.next(!this.dropdownOpen));\n    keyboardEvents.space$.pipe(filter(() => !this.allowQuery)).subscribe(() => {\n      if (this.dropdownOpen) {\n        this.optionsKeyboardSelectAction$.next(KeyboardSelectAction.EXECUTE);\n      }\n      this.open.next(!this.dropdownOpen);\n    });\n\n    keyboardEvents.openOnArrowDown$.subscribe(() => this.open.next(true));\n  }\n\n  /** @internal */\n  selectOption(option: any) {\n    this.selection = option;\n\n    this.selectionChange.emit(option);\n    this.propagateChange(option);\n\n    this.resetSelectState();\n\n    // This timeout makes sure that the dropdown will be closed at the end\n    // of all the callbacks in the open subscriptions.\n    setTimeout(() => {\n      this.open.next(false);\n    });\n  }\n\n  /** @internal */\n  removeSelection() {\n    this.selection = null;\n    this.cd.markForCheck();\n    this.cd.detectChanges();\n\n    this.selectionChange.emit(this.selection);\n    this.propagateChange(this.selection);\n\n    this.resetSelectState();\n  }\n\n  /** @internal */\n  propagateChange(_value: any) {}\n\n  /** @internal */\n  writeValue(newSelection: any) {\n    this.selection = newSelection;\n  }\n\n  /** @internal */\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  /** @internal */\n  registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  /** @internal */\n  registerOnTouched(_fn: any) {}\n\n  /** @internal */\n  focusedViaTab() {\n    this.isInputFocusedViaTab = true;\n  }\n\n  private determineHighlightIndex(options: any[], selection: any, itemKey?: string) {\n    return itemKey\n      ? options.findIndex((option) => isEqual(get(itemKey, selection), get(itemKey, option)) || isEqual(selection, get(itemKey, option)))\n      : options.findIndex((option) => isEqual(selection, option));\n  }\n}\n","<div *ngIf=\"dropdownOpen\" class=\"backdrop\" (click)=\"handleBackdropClick($event)\"></div>\n<div\n  [lxMarkInvalid]=\"markInvalid\"\n  class=\"selectContainer {{ padding }}Padding\"\n  [class.open]=\"dropdownOpen\"\n  [class.top]=\"(dropdownDirection$ | async) === 'TOP'\"\n  [class.bottom]=\"(dropdownDirection$ | async) === 'BOTTOM'\"\n  [class.disabled]=\"disabled\"\n  [class.grayBackground]=\"selectionBackground === 'gray'\"\n  [class.defaultSize]=\"size === 'default'\"\n  [class.smallSize]=\"size === 'small'\"\n  [class.select2Size]=\"size === 'select2'\"\n  [class.largeSize]=\"size === 'large'\"\n  [style.cursor]=\"cursorStyle\"\n  [class.focused]=\"isInputFocused\"\n  [class.focusedVisible]=\"isInputFocusedViaTab\"\n  (click)=\"handleClick($event.target === toggle)\"\n>\n  <div class=\"selectionContainer\">\n    <div class=\"inputContainer\">\n      <div *ngIf=\"!selection && selection !== 0 && !queryInput?.value\" class=\"placeholder\" [attr.title]=\"placeholder\">\n        {{ placeholder }}\n      </div>\n      <div\n        *ngIf=\"!allowQuery || !queryInput?.value\"\n        class=\"selection\"\n        [class.lowerOpacity]=\"allowQuery && !queryInput?.value && dropdownOpen\"\n        [class.lightgrayColor]=\"!allowQuery && dropdownOpen\"\n        (click)=\"$event.stopPropagation(); focus()\"\n      >\n        <ng-container *ngTemplateOutlet=\"selectedOptionTmpl\" />\n      </div>\n      <input\n        #queryInput\n        class=\"queryInput\"\n        type=\"text\"\n        [attr.id]=\"inputId\"\n        [attr.required]=\"required ? 'true' : null\"\n        [class.isHidden]=\"!allowQuery\"\n        (keydown.enter)=\"$event.preventDefault()\"\n        (focus)=\"isInputFocused = true\"\n        (blur)=\"isInputFocused = false; isInputFocusedViaTab = false; blur.emit($event)\"\n        (keyup.tab)=\"focusedViaTab()\"\n        (keyup.shift.tab)=\"focusedViaTab()\"\n        [tabIndex]=\"disabled ? -1 : tabIndex\"\n        [formControl]=\"queryControl\"\n        [readOnly]=\"!allowQuery\"\n      />\n    </div>\n    <div class=\"iconContainer\">\n      <i *ngIf=\"(selection || selection === 0) && allowClear && !disabled\" class=\"far fa-times\" (click)=\"removeSelection()\"></i>\n      <i #toggle class=\"fas fa-angle-down\" aria-hidden=\"true\"></i>\n    </div>\n  </div>\n  <div class=\"optionsContainer\" #optionsContainer>\n    <ng-container *ngIf=\"dropdownOpen\">\n      <ng-container *ngTemplateOutlet=\"dropdownTmpl\" />\n    </ng-container>\n  </div>\n</div>\n\n<ng-template #selectedOption>\n  <ng-content select=\".selectedOption\" />\n</ng-template>\n<ng-template #dropdown>\n  <ng-content select=\".dropdownComponent\" />\n</ng-template>\n"]}
@@ -3,14 +3,6 @@ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from
3
3
  import * as i0 from "@angular/core";
4
4
  /**
5
5
  * Switch component is a toggle switch that can be used to switch between two states.
6
- *
7
- * ## Usage
8
- *
9
- * 1. Import the `SwitchComponent` component from `@leanix/components` in your module or standalone copmonent where you want to use the component.
10
- *
11
- * ```ts
12
- * import { SwitchComponent } from '@leanix/components';
13
- * ```
14
6
  */
15
7
  export class SwitchComponent {
16
8
  constructor() {
@@ -56,4 +48,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
56
48
  }], toggle: [{
57
49
  type: Output
58
50
  }] } });
59
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2Zvcm1zLXVpL2NvbXBvbmVudHMvc3dpdGNoL3N3aXRjaC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL3N3aXRjaC9zd2l0Y2guY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3ZDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRWhHOzs7Ozs7Ozs7O0dBVUc7QUFTSCxNQUFNLE9BQU8sZUFBZTtJQVI1QjtRQVdFLHlCQUF5QjtRQUNULFNBQUksR0FBWSxPQUFPLENBQUM7UUFDeEMscUNBQXFDO1FBQ3JCLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFHakMsa0RBQWtEO1FBQ2xDLGlCQUFZLEdBQUcsSUFBSSxDQUFDO1FBSXBDLHVEQUF1RDtRQUN0QyxXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztLQWdCdkQ7SUFkQyxnQkFBZ0I7SUFDaEIsUUFBUTtRQUNOLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFFRCxJQUFJLEVBQUU7UUFDSixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLE9BQU8sSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDekQsQ0FBQztJQUVELGdCQUFnQjtJQUNoQixLQUFLLENBQUMsUUFBMEI7UUFDOUIseURBQXlEO1FBQ3pELFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDMUMsQ0FBQzs4R0E5QlUsZUFBZTtrR0FBZixlQUFlLDBPQ3RCNUIsMnFCQXVCQSw4a0NESFksSUFBSTs7MkZBRUgsZUFBZTtrQkFSM0IsU0FBUzsrQkFDRSxXQUFXLG1CQUdKLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSxXQUNQLENBQUMsSUFBSSxDQUFDOzhCQUlDLEtBQUs7c0JBQXBCLEtBQUs7Z0JBRVUsSUFBSTtzQkFBbkIsS0FBSztnQkFFVSxRQUFRO3NCQUF2QixLQUFLO2dCQUVVLEtBQUs7c0JBQXBCLEtBQUs7Z0JBRVUsWUFBWTtzQkFBM0IsS0FBSztnQkFFVSxTQUFTO3NCQUF4QixLQUFLO2dCQUdXLE1BQU07c0JBQXRCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ0lmIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIFN3aXRjaCBjb21wb25lbnQgaXMgYSB0b2dnbGUgc3dpdGNoIHRoYXQgY2FuIGJlIHVzZWQgdG8gc3dpdGNoIGJldHdlZW4gdHdvIHN0YXRlcy5cbiAqXG4gKiAjIyBVc2FnZVxuICpcbiAqIDEuIEltcG9ydCB0aGUgYFN3aXRjaENvbXBvbmVudGAgY29tcG9uZW50IGZyb20gYEBsZWFuaXgvY29tcG9uZW50c2AgaW4geW91ciBtb2R1bGUgb3Igc3RhbmRhbG9uZSBjb3Btb25lbnQgd2hlcmUgeW91IHdhbnQgdG8gdXNlIHRoZSBjb21wb25lbnQuXG4gKlxuICogYGBgdHNcbiAqIGltcG9ydCB7IFN3aXRjaENvbXBvbmVudCB9IGZyb20gJ0BsZWFuaXgvY29tcG9uZW50cyc7XG4gKiBgYGBcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbHgtc3dpdGNoJyxcbiAgdGVtcGxhdGVVcmw6ICdzd2l0Y2guY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vc3dpdGNoLmNvbXBvbmVudC5zY3NzJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtOZ0lmXVxufSlcbmV4cG9ydCBjbGFzcyBTd2l0Y2hDb21wb25lbnQge1xuICAvKiogVmFsdWUgb2YgdGhlIHN3aXRjaCAqL1xuICBASW5wdXQoKSBwdWJsaWMgdmFsdWUhOiBib29sZWFuO1xuICAvKiogU2l6ZSBvZiB0aGUgc3dpdGNoICovXG4gIEBJbnB1dCgpIHB1YmxpYyBzaXplOiAnc21hbGwnID0gJ3NtYWxsJztcbiAgLyoqIFdoZXRoZXIgdGhlIHN3aXRjaCBpcyBkaXNhYmxlZCAqL1xuICBASW5wdXQoKSBwdWJsaWMgZGlzYWJsZWQgPSBmYWxzZTtcbiAgLyoqIExhYmVsIG9mIHRoZSBzd2l0Y2ggKi9cbiAgQElucHV0KCkgcHVibGljIGxhYmVsITogc3RyaW5nO1xuICAvKiogV2hldGhlciB0aGUgbGFiZWwgaXMgaW4gZnJvbnQgb2YgdGhlIHN3aXRjaCAqL1xuICBASW5wdXQoKSBwdWJsaWMgbGFiZWxJbkZyb250ID0gdHJ1ZTtcbiAgLyoqIElkIG9mIHRoZSBzd2l0Y2ggKi9cbiAgQElucHV0KCkgcHVibGljIGVsZW1lbnRJZD86IHN0cmluZztcblxuICAvKiogRXZlbnQgdGhhdCBpcyBlbWl0dGVkIHdoZW4gdGhlIHN3aXRjaCBpcyB0b2dnbGVkICovXG4gIEBPdXRwdXQoKSBwdWJsaWMgdG9nZ2xlID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xuXG4gIC8qKiBAaW50ZXJuYWwgKi9cbiAgb25Ub2dnbGUoKSB7XG4gICAgdGhpcy50b2dnbGUuZW1pdCghdGhpcy52YWx1ZSk7XG4gIH1cblxuICBnZXQgaWQoKSB7XG4gICAgcmV0dXJuIHRoaXMuZWxlbWVudElkID8gYHRvdXIke3RoaXMuZWxlbWVudElkfWAgOiBudWxsO1xuICB9XG5cbiAgLyoqIEBpbnRlcm5hbCAqL1xuICBmb2N1cyhjaGVja2JveDogSFRNTElucHV0RWxlbWVudCkge1xuICAgIC8vIHdpdGhvdXQgYSBkZWxheSB0aGUgY2hlY2tib3ggd2lsbCBub3QgYmUgZm9jdXNlZCBhZ2FpblxuICAgIHNldFRpbWVvdXQoKCkgPT4gY2hlY2tib3guZm9jdXMoKSwgMTUwKTtcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cIndyYXBwZXJcIlxuICBbY2xhc3Mud2l0aExhYmVsXT1cImxhYmVsXCJcbiAgW2NsYXNzLndpdGhMYWJlbEJlaGluZF09XCJsYWJlbCAmJiAhbGFiZWxJbkZyb250XCJcbiAgW2NsYXNzLmRpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgW2F0dHIuaWRdPVwiaWRcIlxuICBbY2xhc3Muc21hbGxdPVwic2l6ZSA9PT0gJ3NtYWxsJ1wiXG4+XG4gIDxzcGFuICpuZ0lmPVwibGFiZWxcIiBjbGFzcz1cImxhYmVsVGV4dFwiIFtjbGFzcy5vZmZdPVwiIXZhbHVlXCI+e3sgbGFiZWwgfX08L3NwYW4+XG4gIDxsYWJlbCBjbGFzcz1cImNoZWNrYm94XCIgW2NsYXNzLnNtYWxsXT1cInNpemUgPT09ICdzbWFsbCdcIj5cbiAgICA8aW5wdXRcbiAgICAgICNpbnB1dFJlZlxuICAgICAgdHlwZT1cImNoZWNrYm94XCJcbiAgICAgIFtjaGVja2VkXT1cInZhbHVlXCJcbiAgICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXG4gICAgICAoY2xpY2spPVwiaW5wdXRSZWYuYmx1cigpXCJcbiAgICAgIChjaGFuZ2UpPVwib25Ub2dnbGUoKVwiXG4gICAgICAoa2V5ZG93bi5zcGFjZSk9XCJmb2N1cyhpbnB1dFJlZilcIlxuICAgICAgKGtleWRvd24uZW50ZXIpPVwib25Ub2dnbGUoKVwiXG4gICAgLz5cbiAgICA8c3BhbiBjbGFzcz1cInNsaWRlclwiPjwvc3Bhbj5cbiAgPC9sYWJlbD5cbjwvZGl2PlxuIl19
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2Zvcm1zLXVpL2NvbXBvbmVudHMvc3dpdGNoL3N3aXRjaC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL3N3aXRjaC9zd2l0Y2guY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3ZDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRWhHOztHQUVHO0FBU0gsTUFBTSxPQUFPLGVBQWU7SUFSNUI7UUFXRSx5QkFBeUI7UUFDVCxTQUFJLEdBQVksT0FBTyxDQUFDO1FBQ3hDLHFDQUFxQztRQUNyQixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBR2pDLGtEQUFrRDtRQUNsQyxpQkFBWSxHQUFHLElBQUksQ0FBQztRQUlwQyx1REFBdUQ7UUFDdEMsV0FBTSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7S0FnQnZEO0lBZEMsZ0JBQWdCO0lBQ2hCLFFBQVE7UUFDTixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNoQyxDQUFDO0lBRUQsSUFBSSxFQUFFO1FBQ0osT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxPQUFPLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBQ3pELENBQUM7SUFFRCxnQkFBZ0I7SUFDaEIsS0FBSyxDQUFDLFFBQTBCO1FBQzlCLHlEQUF5RDtRQUN6RCxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQzFDLENBQUM7OEdBOUJVLGVBQWU7a0dBQWYsZUFBZSwwT0NkNUIsMnFCQXVCQSw4a0NEWFksSUFBSTs7MkZBRUgsZUFBZTtrQkFSM0IsU0FBUzsrQkFDRSxXQUFXLG1CQUdKLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSxXQUNQLENBQUMsSUFBSSxDQUFDOzhCQUlDLEtBQUs7c0JBQXBCLEtBQUs7Z0JBRVUsSUFBSTtzQkFBbkIsS0FBSztnQkFFVSxRQUFRO3NCQUF2QixLQUFLO2dCQUVVLEtBQUs7c0JBQXBCLEtBQUs7Z0JBRVUsWUFBWTtzQkFBM0IsS0FBSztnQkFFVSxTQUFTO3NCQUF4QixLQUFLO2dCQUdXLE1BQU07c0JBQXRCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ0lmIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIFN3aXRjaCBjb21wb25lbnQgaXMgYSB0b2dnbGUgc3dpdGNoIHRoYXQgY2FuIGJlIHVzZWQgdG8gc3dpdGNoIGJldHdlZW4gdHdvIHN0YXRlcy5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbHgtc3dpdGNoJyxcbiAgdGVtcGxhdGVVcmw6ICdzd2l0Y2guY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vc3dpdGNoLmNvbXBvbmVudC5zY3NzJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtOZ0lmXVxufSlcbmV4cG9ydCBjbGFzcyBTd2l0Y2hDb21wb25lbnQge1xuICAvKiogVmFsdWUgb2YgdGhlIHN3aXRjaCAqL1xuICBASW5wdXQoKSBwdWJsaWMgdmFsdWUhOiBib29sZWFuO1xuICAvKiogU2l6ZSBvZiB0aGUgc3dpdGNoICovXG4gIEBJbnB1dCgpIHB1YmxpYyBzaXplOiAnc21hbGwnID0gJ3NtYWxsJztcbiAgLyoqIFdoZXRoZXIgdGhlIHN3aXRjaCBpcyBkaXNhYmxlZCAqL1xuICBASW5wdXQoKSBwdWJsaWMgZGlzYWJsZWQgPSBmYWxzZTtcbiAgLyoqIExhYmVsIG9mIHRoZSBzd2l0Y2ggKi9cbiAgQElucHV0KCkgcHVibGljIGxhYmVsITogc3RyaW5nO1xuICAvKiogV2hldGhlciB0aGUgbGFiZWwgaXMgaW4gZnJvbnQgb2YgdGhlIHN3aXRjaCAqL1xuICBASW5wdXQoKSBwdWJsaWMgbGFiZWxJbkZyb250ID0gdHJ1ZTtcbiAgLyoqIElkIG9mIHRoZSBzd2l0Y2ggKi9cbiAgQElucHV0KCkgcHVibGljIGVsZW1lbnRJZD86IHN0cmluZztcblxuICAvKiogRXZlbnQgdGhhdCBpcyBlbWl0dGVkIHdoZW4gdGhlIHN3aXRjaCBpcyB0b2dnbGVkICovXG4gIEBPdXRwdXQoKSBwdWJsaWMgdG9nZ2xlID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xuXG4gIC8qKiBAaW50ZXJuYWwgKi9cbiAgb25Ub2dnbGUoKSB7XG4gICAgdGhpcy50b2dnbGUuZW1pdCghdGhpcy52YWx1ZSk7XG4gIH1cblxuICBnZXQgaWQoKSB7XG4gICAgcmV0dXJuIHRoaXMuZWxlbWVudElkID8gYHRvdXIke3RoaXMuZWxlbWVudElkfWAgOiBudWxsO1xuICB9XG5cbiAgLyoqIEBpbnRlcm5hbCAqL1xuICBmb2N1cyhjaGVja2JveDogSFRNTElucHV0RWxlbWVudCkge1xuICAgIC8vIHdpdGhvdXQgYSBkZWxheSB0aGUgY2hlY2tib3ggd2lsbCBub3QgYmUgZm9jdXNlZCBhZ2FpblxuICAgIHNldFRpbWVvdXQoKCkgPT4gY2hlY2tib3guZm9jdXMoKSwgMTUwKTtcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cIndyYXBwZXJcIlxuICBbY2xhc3Mud2l0aExhYmVsXT1cImxhYmVsXCJcbiAgW2NsYXNzLndpdGhMYWJlbEJlaGluZF09XCJsYWJlbCAmJiAhbGFiZWxJbkZyb250XCJcbiAgW2NsYXNzLmRpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgW2F0dHIuaWRdPVwiaWRcIlxuICBbY2xhc3Muc21hbGxdPVwic2l6ZSA9PT0gJ3NtYWxsJ1wiXG4+XG4gIDxzcGFuICpuZ0lmPVwibGFiZWxcIiBjbGFzcz1cImxhYmVsVGV4dFwiIFtjbGFzcy5vZmZdPVwiIXZhbHVlXCI+e3sgbGFiZWwgfX08L3NwYW4+XG4gIDxsYWJlbCBjbGFzcz1cImNoZWNrYm94XCIgW2NsYXNzLnNtYWxsXT1cInNpemUgPT09ICdzbWFsbCdcIj5cbiAgICA8aW5wdXRcbiAgICAgICNpbnB1dFJlZlxuICAgICAgdHlwZT1cImNoZWNrYm94XCJcbiAgICAgIFtjaGVja2VkXT1cInZhbHVlXCJcbiAgICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXG4gICAgICAoY2xpY2spPVwiaW5wdXRSZWYuYmx1cigpXCJcbiAgICAgIChjaGFuZ2UpPVwib25Ub2dnbGUoKVwiXG4gICAgICAoa2V5ZG93bi5zcGFjZSk9XCJmb2N1cyhpbnB1dFJlZilcIlxuICAgICAgKGtleWRvd24uZW50ZXIpPVwib25Ub2dnbGUoKVwiXG4gICAgLz5cbiAgICA8c3BhbiBjbGFzcz1cInNsaWRlclwiPjwvc3Bhbj5cbiAgPC9sYWJlbD5cbjwvZGl2PlxuIl19
@@ -7,14 +7,8 @@ import * as i1 from "@ncstate/sat-popover";
7
7
  /**
8
8
  * The Popover component is based on the [ncstate-sat/popover](https://github.com/ncstate-sat/popover) library.
9
9
  *
10
- * ## Usage
11
- *
12
- * 1. Import `LxPopoverUiModule` and `LxCoreUiModule` module from `@leanix/components` in your module where you want to use the component.
13
- *
14
- * ```ts
15
- * import { LxPopoverUiModule, LxCoreUiModule } from '@leanix/components';
16
- * ```
17
- *
10
+ * ## Examples
11
+
18
12
  * This popover encapsulates this open source library: https://github.com/ncstate-sat/popover,
19
13
  * make sure to also check out the docs over there.
20
14
  *
@@ -231,4 +225,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
231
225
  type: ContentChild,
232
226
  args: [PopoverContentDirective, { read: TemplateRef, static: true }]
233
227
  }] } });
234
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/popover-ui/components/popover/popover.component.ts","../../../../../../../../libs/components/src/lib/popover-ui/components/popover/popover.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAClE,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,EAAiB,WAAW,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACvI,OAAO,EAAE,mBAAmB,EAA6B,gBAAgB,EAA2B,MAAM,sBAAsB,CAAC;AACjI,OAAO,EAAE,uBAAuB,EAAE,MAAM,4CAA4C,CAAC;;;AAGrF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+DG;AAQH,MAAM,OAAO,gBAAgB;IAP7B;QAcE,gCAAgC;QACvB,aAAQ,GAAG,KAAK,CAAC;QAC1B,6DAA6D;QACpD,kBAAa,GAAG,KAAK,CAAC;QAC/B,qFAAqF;QAC5E,cAAS,GAAG,KAAK,CAAC;QAC3B,6FAA6F;QACpF,iBAAY,GAAG,IAAI,CAAC;QAC7B,0CAA0C;QACjC,gBAAW,GAAG,KAAK,CAAC;QAC7B;;;;;;;WAOG;QACM,uCAAkC,GAAG,KAAK,CAAC;QAEpD,gDAAgD;QACtC,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAC;QAC5C,gDAAgD;QACtC,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAC;QAoBpC,YAAO,GAAG,KAAK,CAAC;KAwGzB;IA/GC,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC;IACtD,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAGD,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,iBAAiB,CAAC,IAAI,OAAO,CAAC,eAAe,CAAC,EAAE,CAAC;YAC3D,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAC9F,CAAC;IACH,CAAC;IAED,gBAAgB;IAChB,IAAI;QACF,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,gBAAgB;IAChB,KAAK;QACH,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;IAC1B,CAAC;IAED,gBAAgB;IAChB,MAAM;QACJ,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACrB,CAAC;IAED,gBAAgB;IAChB,WAAW;QACT,IAAI,IAAI,CAAC,kCAAkC,EAAE,CAAC;YAC5C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;QACrF,CAAC;IACH,CAAC;IAED,gBAAgB;IAChB,OAAO;QACL,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACrB,CAAC;IAED;;;;;OAKG;IACK,4BAA4B,CAAC,mBAAqD;QACxF,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,mBAAmB,CAAC,mBAAmB,CAAC,EAAE,CAAC;YAC7C,OAAO,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,KAAK,CAAC;QACzE,CAAC;QAED,IAAI,mBAAmB,CAAC,mBAAmB,CAAC,EAAE,CAAC;YAC7C,OAAO,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC;QAC/E,CAAC;QAED,IAAI,mBAAmB,CAAC,oBAAoB,CAAC,EAAE,CAAC;YAC9C,OAAO,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC;QAC3E,CAAC;QAED,IAAI,mBAAmB,CAAC,mBAAmB,CAAC,EAAE,CAAC;YAC7C,OAAO,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC;QAC7E,CAAC;QAED,IAAI,mBAAmB,CAAC,oBAAoB,CAAC,EAAE,CAAC;YAC9C,OAAO,EAAE,CAAC;QACZ,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAEO,uBAAuB,CAAC,eAA0C,EAAE,aAAsC;QAChH,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,eAAe,KAAK,OAAO,EAAE,CAAC;YAChC,IAAI,aAAa,KAAK,QAAQ,IAAI,aAAa,KAAK,OAAO,IAAI,aAAa,KAAK,KAAK,EAAE,CAAC;gBACvF,OAAO,OAAO,CAAC;YACjB,CAAC;iBAAM,IAAI,aAAa,KAAK,OAAO,EAAE,CAAC;gBACrC,OAAO,WAAW,CAAC;YACrB,CAAC;iBAAM,IAAI,aAAa,KAAK,OAAO,EAAE,CAAC;gBACrC,OAAO,cAAc,CAAC;YACxB,CAAC;QACH,CAAC;QAED,IAAI,eAAe,KAAK,QAAQ,EAAE,CAAC;YACjC,IAAI,aAAa,KAAK,QAAQ,IAAI,aAAa,KAAK,OAAO,IAAI,aAAa,KAAK,KAAK,EAAE,CAAC;gBACvF,OAAO,MAAM,CAAC;YAChB,CAAC;iBAAM,IAAI,aAAa,KAAK,OAAO,EAAE,CAAC;gBACrC,OAAO,UAAU,CAAC;YACpB,CAAC;iBAAM,IAAI,aAAa,KAAK,OAAO,EAAE,CAAC;gBACrC,OAAO,aAAa,CAAC;YACvB,CAAC;QACH,CAAC;QAED,IAAI,eAAe,KAAK,QAAQ,IAAI,eAAe,KAAK,OAAO,IAAI,eAAe,KAAK,KAAK,EAAE,CAAC;YAC7F,IAAI,aAAa,KAAK,OAAO,EAAE,CAAC;gBAC9B,OAAO,KAAK,CAAC;YACf,CAAC;iBAAM,IAAI,aAAa,KAAK,OAAO,EAAE,CAAC;gBACrC,OAAO,QAAQ,CAAC;YAClB,CAAC;QACH,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;8GAzJU,gBAAgB;kGAAhB,gBAAgB,0dAsCb,uBAAuB,2BAAU,WAAW,uFAL/C,mBAAmB,sMC9GhC,+4BA8BA,wdD6CY,gBAAgB,0gBAAE,OAAO,oFAAE,IAAI,6FAAE,gBAAgB;;2FAEhD,gBAAgB;kBAP5B,SAAS;+BACE,YAAY,cAGV,IAAI,WACP,CAAC,gBAAgB,EAAE,OAAO,EAAE,IAAI,EAAE,gBAAgB,CAAC;8BAInD,OAAO;sBAAf,KAAK;gBAEG,eAAe;sBAAvB,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBASG,kCAAkC;sBAA1C,KAAK;gBAGI,MAAM;sBAAf,MAAM;gBAEG,MAAM;sBAAf,MAAM;gBAG2C,UAAU;sBAA3D,SAAS;uBAAC,mBAAmB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAEA,eAAe;sBAA9D,SAAS;uBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAG8B,eAAe;sBAA1F,YAAY;uBAAC,uBAAuB,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { NgClass, NgIf, NgTemplateOutlet } from '@angular/common';\nimport { Component, ContentChild, EventEmitter, Input, OnChanges, Output, SimpleChanges, TemplateRef, ViewChild } from '@angular/core';\nimport { SatPopoverComponent, SatPopoverHorizontalAlign, SatPopoverModule, SatPopoverVerticalAlign } from '@ncstate/sat-popover';\nimport { PopoverContentDirective } from '../../directives/popover-content.directive';\nimport { PopoverTriggerDirective } from '../../directives/popover-hover.directive';\n\n/**\n * The Popover component is based on the [ncstate-sat/popover](https://github.com/ncstate-sat/popover) library.\n *\n * ## Usage\n *\n * 1. Import `LxPopoverUiModule` and `LxCoreUiModule` module from `@leanix/components` in your module where you want to use the component.\n *\n * ```ts\n * import { LxPopoverUiModule, LxCoreUiModule } from '@leanix/components';\n * ```\n *\n * This popover encapsulates this open source library: https://github.com/ncstate-sat/popover,\n * make sure to also check out the docs over there.\n *\n * As of today they are two trigger strategies to display a popover.\n * 1. Show on hovering the anchor and while hovering the popover body.\n * 2. Show on click and while hovering the popover body.\n *\n * For use case 1. you would use the lxPopoverHover directive, which exports as hoverAnchor.\n *\n * ### Example:\n * ```html\n * <div lxPopoverHover\n *      hoverAnchor\n *      satPopoverAnchor\n *      #anchor=\"hoverAnchor\"></div>\n * <lx-popover [trigger]=\"anchor\"\n *             horizontalAlign=\"after\"\n *             verticalAlign=\"center\">\n *    <p>Popover content</p>\n * </lx-popover>\n * ```\n *\n * For use case 2. you would use the lxPopoverClick directive, which exports as clickAnchor.\n * Note: Since the only component where we use the lxPopoverClick directive (ReportComponent)\n * needs to fetch some data before opening it, we do not register a click EventListener in this directive,\n * but require the developer to implement that in the component, where the popover is used.\n *\n * ### Example:\n * ```html\n * <div lxPopoverClick\n *      clickAnchor\n *      satPopoverAnchor\n *      #anchor=\"clickAnchor\"\n *      (click)=\"popover.open()\">Click Me!</div>\n * <lx-popover [trigger]=\"anchor\"\n *             horizontalAlign=\"after\"\n *             verticalAlign=\"center\"\n *             #popover>\n *    <p>Popover content</p>\n * </lx-popover>\n * ```\n *\n * If this component is used with angularCompilerOptions strictTemplates=true,\n * satPopoverAnchor must be set to the reference to the SatPopover inside lx-popover.\n *\n * ### Example:\n * ```html\n * <div [satPopoverAnchor]=\"popover.satPopover\"></div>\n * <lx-popover #popover>\n *    <p>Popover content</p>\n * </lx-popover>\n * ```\n */\n@Component({\n  selector: 'lx-popover',\n  templateUrl: 'popover.component.html',\n  styleUrls: ['popover.component.scss'],\n  standalone: true,\n  imports: [SatPopoverModule, NgClass, NgIf, NgTemplateOutlet]\n})\nexport class PopoverComponent implements OnChanges {\n  /** The trigger directive that will open the popover. This is also the anchor for the popover. */\n  @Input() trigger!: PopoverTriggerDirective;\n  /** The horizontal alignment of the popover (`center` by default). */\n  @Input() horizontalAlign!: SatPopoverHorizontalAlign;\n  /** The vertical alignment of the popover (`above` by default). */\n  @Input() verticalAlign!: SatPopoverVerticalAlign;\n  /** Whether to apply margins. */\n  @Input() noMargin = false;\n  /** Whether to allow the popover to overflow the viewport. */\n  @Input() allowOverflow = false;\n  /** Whether to focus the first focusable element in the popover when it is opened. */\n  @Input() autoFocus = false;\n  /** Whether to restore focus to the previously-focused element when the popover is closed. */\n  @Input() restoreFocus = true;\n  /** Whether the popover has a backdrop. */\n  @Input() hasBackdrop = false;\n  /**\n   * If you have a popover, that should usually be displayed above or below its anchor,\n   * and this anchor is in a scrollable container, you should set this to true.\n   * SatPopover will open this popover in the direction where there is enough space,\n   * so its position might differ from the horizontalAlign and verticalAlign values.\n   * In this case we rely on the SatPopover::_classList property to get the computed\n   * position of the popover after opening.\n   */\n  @Input() adaptMarginsForViewportAlignChange = false;\n\n  /** Event emitted when the popover is opened. */\n  @Output() opened = new EventEmitter<void>();\n  /** Event emitted when the popover is closed. */\n  @Output() closed = new EventEmitter<void>();\n\n  /** @internal */\n  @ViewChild(SatPopoverComponent, { static: true }) satPopover!: SatPopoverComponent;\n  /** @internal */\n  @ViewChild('implicitContent', { static: true }) implicitContent!: TemplateRef<any>;\n\n  /** @internal */\n  @ContentChild(PopoverContentDirective, { read: TemplateRef, static: true }) explicitContent?: TemplateRef<any>;\n\n  /** @internal */\n  marginClasses!: string;\n\n  get content() {\n    return this.explicitContent || this.implicitContent;\n  }\n\n  get isOpen() {\n    return this._isOpen;\n  }\n  private _isOpen = false;\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['horizontalAlign'] && changes['verticalAlign']) {\n      this.marginClasses = this.getDefaultMarginClasses(this.horizontalAlign, this.verticalAlign);\n    }\n  }\n\n  /** @internal */\n  open() {\n    this.satPopover.open();\n  }\n\n  /** @internal */\n  close() {\n    this.satPopover.close();\n  }\n\n  /** @internal */\n  onOpen() {\n    this._isOpen = true;\n    this.opened.emit();\n  }\n\n  /** @internal */\n  onAfterOpen() {\n    if (this.adaptMarginsForViewportAlignChange) {\n      this.marginClasses = this.getMarginClassesForClassList(this.satPopover._classList);\n    }\n  }\n\n  /** @internal */\n  onClose() {\n    this._isOpen = false;\n    this.closed.emit();\n  }\n\n  /**\n   * SatPopover::_classList will contain a map of alignment CSS classes, once the popover was opened.\n   * These alignment classes can be different from what you would expect from the horizontal- and verticalAlign inputs,\n   * because there might not be enough space above the anchor to meet the verticalAlign='above' criteria,\n   * so it will be displayed below the anchor instead.\n   */\n  private getMarginClassesForClassList(satPopoverClassList: { [className: string]: boolean }): string {\n    if (this.noMargin) {\n      return '';\n    }\n\n    if (satPopoverClassList['sat-popover-above']) {\n      return this.marginClasses.includes('top') ? this.marginClasses : 'top';\n    }\n\n    if (satPopoverClassList['sat-popover-below']) {\n      return this.marginClasses.includes('bottom') ? this.marginClasses : 'bottom';\n    }\n\n    if (satPopoverClassList['sat-popover-before']) {\n      return this.marginClasses.includes('left') ? this.marginClasses : 'left';\n    }\n\n    if (satPopoverClassList['sat-popover-after']) {\n      return this.marginClasses.includes('right') ? this.marginClasses : 'right';\n    }\n\n    if (satPopoverClassList['sat-popover-center']) {\n      return '';\n    }\n    return '';\n  }\n\n  private getDefaultMarginClasses(horizontalAlign: SatPopoverHorizontalAlign, verticalAlign: SatPopoverVerticalAlign): string {\n    if (this.noMargin) {\n      return '';\n    }\n\n    if (horizontalAlign === 'after') {\n      if (verticalAlign === 'center' || verticalAlign === 'start' || verticalAlign === 'end') {\n        return 'right';\n      } else if (verticalAlign === 'above') {\n        return 'right top';\n      } else if (verticalAlign === 'below') {\n        return 'right bottom';\n      }\n    }\n\n    if (horizontalAlign === 'before') {\n      if (verticalAlign === 'center' || verticalAlign === 'start' || verticalAlign === 'end') {\n        return 'left';\n      } else if (verticalAlign === 'above') {\n        return 'left top';\n      } else if (verticalAlign === 'below') {\n        return 'left bottom';\n      }\n    }\n\n    if (horizontalAlign === 'center' || horizontalAlign === 'start' || horizontalAlign === 'end') {\n      if (verticalAlign === 'above') {\n        return 'top';\n      } else if (verticalAlign === 'below') {\n        return 'bottom';\n      }\n    }\n    return '';\n  }\n}\n","<sat-popover\n  [anchor]=\"trigger.anchor\"\n  [horizontalAlign]=\"horizontalAlign\"\n  [verticalAlign]=\"verticalAlign\"\n  [restoreFocus]=\"restoreFocus\"\n  [lockAlignment]=\"true\"\n  [autoFocus]=\"autoFocus\"\n  [hasBackdrop]=\"hasBackdrop\"\n  openTransition=\"0ms\"\n  closeTransition=\"0ms\"\n  (opened)=\"onOpen()\"\n  (afterOpen)=\"onAfterOpen()\"\n  (closed)=\"onClose()\"\n>\n  <div\n    class=\"popoverContainer\"\n    [ngClass]=\"marginClasses\"\n    [class.overflowHidden]=\"!allowOverflow\"\n    (mouseenter)=\"trigger.showPopover(true)\"\n    (mouseleave)=\"!hasBackdrop && trigger.closePopover(true)\"\n    (keydown.escape)=\"$event.stopPropagation(); trigger.closePopover(true)\"\n  >\n    <ng-container *ngIf=\"isOpen\">\n      <ng-container *ngTemplateOutlet=\"content\" />\n    </ng-container>\n  </div>\n</sat-popover>\n<ng-template #implicitContent>\n  <ng-content />\n</ng-template>\n"]}
228
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/popover-ui/components/popover/popover.component.ts","../../../../../../../../libs/components/src/lib/popover-ui/components/popover/popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgIf, NgTemplateOutlet } from '@angular/common';\nimport { Component, ContentChild, EventEmitter, Input, OnChanges, Output, SimpleChanges, TemplateRef, ViewChild } from '@angular/core';\nimport { SatPopoverComponent, SatPopoverHorizontalAlign, SatPopoverModule, SatPopoverVerticalAlign } from '@ncstate/sat-popover';\nimport { PopoverContentDirective } from '../../directives/popover-content.directive';\nimport { PopoverTriggerDirective } from '../../directives/popover-hover.directive';\n\n/**\n * The Popover component is based on the [ncstate-sat/popover](https://github.com/ncstate-sat/popover) library.\n *\n * ## Examples\n\n * This popover encapsulates this open source library: https://github.com/ncstate-sat/popover,\n * make sure to also check out the docs over there.\n *\n * As of today they are two trigger strategies to display a popover.\n * 1. Show on hovering the anchor and while hovering the popover body.\n * 2. Show on click and while hovering the popover body.\n *\n * For use case 1. you would use the lxPopoverHover directive, which exports as hoverAnchor.\n *\n * ### Example:\n * ```html\n * <div lxPopoverHover\n *      hoverAnchor\n *      satPopoverAnchor\n *      #anchor=\"hoverAnchor\"></div>\n * <lx-popover [trigger]=\"anchor\"\n *             horizontalAlign=\"after\"\n *             verticalAlign=\"center\">\n *    <p>Popover content</p>\n * </lx-popover>\n * ```\n *\n * For use case 2. you would use the lxPopoverClick directive, which exports as clickAnchor.\n * Note: Since the only component where we use the lxPopoverClick directive (ReportComponent)\n * needs to fetch some data before opening it, we do not register a click EventListener in this directive,\n * but require the developer to implement that in the component, where the popover is used.\n *\n * ### Example:\n * ```html\n * <div lxPopoverClick\n *      clickAnchor\n *      satPopoverAnchor\n *      #anchor=\"clickAnchor\"\n *      (click)=\"popover.open()\">Click Me!</div>\n * <lx-popover [trigger]=\"anchor\"\n *             horizontalAlign=\"after\"\n *             verticalAlign=\"center\"\n *             #popover>\n *    <p>Popover content</p>\n * </lx-popover>\n * ```\n *\n * If this component is used with angularCompilerOptions strictTemplates=true,\n * satPopoverAnchor must be set to the reference to the SatPopover inside lx-popover.\n *\n * ### Example:\n * ```html\n * <div [satPopoverAnchor]=\"popover.satPopover\"></div>\n * <lx-popover #popover>\n *    <p>Popover content</p>\n * </lx-popover>\n * ```\n */\n@Component({\n  selector: 'lx-popover',\n  templateUrl: 'popover.component.html',\n  styleUrls: ['popover.component.scss'],\n  standalone: true,\n  imports: [SatPopoverModule, NgClass, NgIf, NgTemplateOutlet]\n})\nexport class PopoverComponent implements OnChanges {\n  /** The trigger directive that will open the popover. This is also the anchor for the popover. */\n  @Input() trigger!: PopoverTriggerDirective;\n  /** The horizontal alignment of the popover (`center` by default). */\n  @Input() horizontalAlign!: SatPopoverHorizontalAlign;\n  /** The vertical alignment of the popover (`above` by default). */\n  @Input() verticalAlign!: SatPopoverVerticalAlign;\n  /** Whether to apply margins. */\n  @Input() noMargin = false;\n  /** Whether to allow the popover to overflow the viewport. */\n  @Input() allowOverflow = false;\n  /** Whether to focus the first focusable element in the popover when it is opened. */\n  @Input() autoFocus = false;\n  /** Whether to restore focus to the previously-focused element when the popover is closed. */\n  @Input() restoreFocus = true;\n  /** Whether the popover has a backdrop. */\n  @Input() hasBackdrop = false;\n  /**\n   * If you have a popover, that should usually be displayed above or below its anchor,\n   * and this anchor is in a scrollable container, you should set this to true.\n   * SatPopover will open this popover in the direction where there is enough space,\n   * so its position might differ from the horizontalAlign and verticalAlign values.\n   * In this case we rely on the SatPopover::_classList property to get the computed\n   * position of the popover after opening.\n   */\n  @Input() adaptMarginsForViewportAlignChange = false;\n\n  /** Event emitted when the popover is opened. */\n  @Output() opened = new EventEmitter<void>();\n  /** Event emitted when the popover is closed. */\n  @Output() closed = new EventEmitter<void>();\n\n  /** @internal */\n  @ViewChild(SatPopoverComponent, { static: true }) satPopover!: SatPopoverComponent;\n  /** @internal */\n  @ViewChild('implicitContent', { static: true }) implicitContent!: TemplateRef<any>;\n\n  /** @internal */\n  @ContentChild(PopoverContentDirective, { read: TemplateRef, static: true }) explicitContent?: TemplateRef<any>;\n\n  /** @internal */\n  marginClasses!: string;\n\n  get content() {\n    return this.explicitContent || this.implicitContent;\n  }\n\n  get isOpen() {\n    return this._isOpen;\n  }\n  private _isOpen = false;\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['horizontalAlign'] && changes['verticalAlign']) {\n      this.marginClasses = this.getDefaultMarginClasses(this.horizontalAlign, this.verticalAlign);\n    }\n  }\n\n  /** @internal */\n  open() {\n    this.satPopover.open();\n  }\n\n  /** @internal */\n  close() {\n    this.satPopover.close();\n  }\n\n  /** @internal */\n  onOpen() {\n    this._isOpen = true;\n    this.opened.emit();\n  }\n\n  /** @internal */\n  onAfterOpen() {\n    if (this.adaptMarginsForViewportAlignChange) {\n      this.marginClasses = this.getMarginClassesForClassList(this.satPopover._classList);\n    }\n  }\n\n  /** @internal */\n  onClose() {\n    this._isOpen = false;\n    this.closed.emit();\n  }\n\n  /**\n   * SatPopover::_classList will contain a map of alignment CSS classes, once the popover was opened.\n   * These alignment classes can be different from what you would expect from the horizontal- and verticalAlign inputs,\n   * because there might not be enough space above the anchor to meet the verticalAlign='above' criteria,\n   * so it will be displayed below the anchor instead.\n   */\n  private getMarginClassesForClassList(satPopoverClassList: { [className: string]: boolean }): string {\n    if (this.noMargin) {\n      return '';\n    }\n\n    if (satPopoverClassList['sat-popover-above']) {\n      return this.marginClasses.includes('top') ? this.marginClasses : 'top';\n    }\n\n    if (satPopoverClassList['sat-popover-below']) {\n      return this.marginClasses.includes('bottom') ? this.marginClasses : 'bottom';\n    }\n\n    if (satPopoverClassList['sat-popover-before']) {\n      return this.marginClasses.includes('left') ? this.marginClasses : 'left';\n    }\n\n    if (satPopoverClassList['sat-popover-after']) {\n      return this.marginClasses.includes('right') ? this.marginClasses : 'right';\n    }\n\n    if (satPopoverClassList['sat-popover-center']) {\n      return '';\n    }\n    return '';\n  }\n\n  private getDefaultMarginClasses(horizontalAlign: SatPopoverHorizontalAlign, verticalAlign: SatPopoverVerticalAlign): string {\n    if (this.noMargin) {\n      return '';\n    }\n\n    if (horizontalAlign === 'after') {\n      if (verticalAlign === 'center' || verticalAlign === 'start' || verticalAlign === 'end') {\n        return 'right';\n      } else if (verticalAlign === 'above') {\n        return 'right top';\n      } else if (verticalAlign === 'below') {\n        return 'right bottom';\n      }\n    }\n\n    if (horizontalAlign === 'before') {\n      if (verticalAlign === 'center' || verticalAlign === 'start' || verticalAlign === 'end') {\n        return 'left';\n      } else if (verticalAlign === 'above') {\n        return 'left top';\n      } else if (verticalAlign === 'below') {\n        return 'left bottom';\n      }\n    }\n\n    if (horizontalAlign === 'center' || horizontalAlign === 'start' || horizontalAlign === 'end') {\n      if (verticalAlign === 'above') {\n        return 'top';\n      } else if (verticalAlign === 'below') {\n        return 'bottom';\n      }\n    }\n    return '';\n  }\n}\n","<sat-popover\n  [anchor]=\"trigger.anchor\"\n  [horizontalAlign]=\"horizontalAlign\"\n  [verticalAlign]=\"verticalAlign\"\n  [restoreFocus]=\"restoreFocus\"\n  [lockAlignment]=\"true\"\n  [autoFocus]=\"autoFocus\"\n  [hasBackdrop]=\"hasBackdrop\"\n  openTransition=\"0ms\"\n  closeTransition=\"0ms\"\n  (opened)=\"onOpen()\"\n  (afterOpen)=\"onAfterOpen()\"\n  (closed)=\"onClose()\"\n>\n  <div\n    class=\"popoverContainer\"\n    [ngClass]=\"marginClasses\"\n    [class.overflowHidden]=\"!allowOverflow\"\n    (mouseenter)=\"trigger.showPopover(true)\"\n    (mouseleave)=\"!hasBackdrop && trigger.closePopover(true)\"\n    (keydown.escape)=\"$event.stopPropagation(); trigger.closePopover(true)\"\n  >\n    <ng-container *ngIf=\"isOpen\">\n      <ng-container *ngTemplateOutlet=\"content\" />\n    </ng-container>\n  </div>\n</sat-popover>\n<ng-template #implicitContent>\n  <ng-content />\n</ng-template>\n"]}
@@ -9,36 +9,15 @@ import { TabComponent } from '../tab/tab.component';
9
9
  import { LxTabGroupKeyCode } from './tab-group-key-codes.enum';
10
10
  import * as i0 from "@angular/core";
11
11
  import * as i1 from "@angular/cdk/portal";
12
- /**
13
- * ## Usage
14
- *
15
- * 1. Import the `LxTabUiModule` module from `@leanix/components` in your module where you want to use the component.
16
- *
17
- * ```ts
18
- * import { LxTabUiModule } from '@leanix/components';
19
- *
20
- * // ...
21
- *
22
- * @NgModule({
23
- * // ...
24
- * imports: [
25
- * // ...
26
- * LxTabUiModule
27
- * // ...
28
- * ]
29
- * })
30
- * export class MyModule {}
31
- * ```
32
- *
33
- * 2. Use the component in your template.
34
- */
35
12
  export class TabGroupComponent {
13
+ /** @internal */
36
14
  get tabIds() {
37
15
  return this.tabs.map((t) => t.tabId);
38
16
  }
39
17
  get tabs() {
40
18
  return this.tabsQueryList?.toArray() || [];
41
19
  }
20
+ /** @internal */
42
21
  get activeTabPortal() {
43
22
  return this.tabs[this.selectedIndex]?.content;
44
23
  }
@@ -52,8 +31,10 @@ export class TabGroupComponent {
52
31
  this.indexChange = new EventEmitter();
53
32
  /**
54
33
  * The tab that is currently focused via keyboard.
34
+ * @internal
55
35
  */
56
36
  this.focusedIndex = 0;
37
+ /** @internal */
57
38
  this.destroyed$ = new Subject();
58
39
  this.listenToFirstTabSelectByAngularRouterForTabLinks().subscribe((tab) => {
59
40
  // synchonize the focusedIndex and selectedIndex state with the tab that is active through the current route.
@@ -89,12 +70,14 @@ export class TabGroupComponent {
89
70
  ngOnDestroy() {
90
71
  this.destroyed$.next();
91
72
  }
73
+ /** @internal */
92
74
  onFocusOut(event) {
93
75
  if (!this.tabListElement?.nativeElement?.contains(event.relatedTarget)) {
94
76
  // resync focused index on selected index when leaving tabs
95
77
  this.focusedIndex = this.selectedIndex;
96
78
  }
97
79
  }
80
+ /** @internal */
98
81
  switchTo(tab) {
99
82
  this.tabsQueryList?.forEach((t, index) => {
100
83
  t.isActive = t === tab;
@@ -106,6 +89,7 @@ export class TabGroupComponent {
106
89
  });
107
90
  this.cd.markForCheck();
108
91
  }
92
+ /** @internal */
109
93
  handleKeyDown(event) {
110
94
  switch (event.code) {
111
95
  case LxTabGroupKeyCode.ArrowRight:
@@ -163,4 +147,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
163
147
  type: ViewChild,
164
148
  args: ['tabListElement']
165
149
  }] } });
166
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-group.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/tab-ui/components/tab-group/tab-group.component.ts","../../../../../../../../libs/components/src/lib/tab-ui/components/tab-group/tab-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { PortalModule } from '@angular/cdk/portal';\nimport { NgTemplateOutlet } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { Observable, Subject, merge } from 'rxjs';\nimport { first, map, startWith, switchMap, takeUntil } from 'rxjs/operators';\nimport { Observe } from '../../../shared/observe';\nimport { TabComponent } from '../tab/tab.component';\nimport { LxTabGroupKeyCode } from './tab-group-key-codes.enum';\n\n/**\n * ## Usage\n *\n * 1. Import the `LxTabUiModule` module from `@leanix/components` in your module where you want to use the component.\n *\n * ```ts\n * import { LxTabUiModule } from '@leanix/components';\n *\n * // ...\n *\n * @NgModule({\n *   // ...\n *   imports: [\n *     // ...\n *     LxTabUiModule\n *     // ...\n *   ]\n * })\n * export class MyModule {}\n * ```\n *\n * 2. Use the component in your template.\n */\n@Component({\n  selector: 'lx-tab-group',\n  templateUrl: 'tab-group.component.html',\n  styleUrls: ['tab-group.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [PortalModule, NgTemplateOutlet]\n})\nexport class TabGroupComponent implements OnChanges, AfterContentInit, OnDestroy {\n  @Input() isCentered: boolean = false;\n  /**\n   * The tab whose content should be displayed.\n   */\n  @Input() selectedIndex: number = 0;\n  @Output() indexChange = new EventEmitter<number>();\n\n  @Observe('tabsQueryList') tabsQueryList$!: Observable<QueryList<TabComponent>>;\n  @ContentChildren(TabComponent) tabsQueryList?: QueryList<TabComponent>;\n  @ViewChild('tabListElement') tabListElement?: ElementRef<HTMLElement>;\n\n  /**\n   * The tab that is currently focused via keyboard.\n   */\n  focusedIndex: number = 0;\n\n  get tabIds(): string[] {\n    return this.tabs.map((t) => t.tabId);\n  }\n  private get tabs(): TabComponent[] {\n    return this.tabsQueryList?.toArray() || [];\n  }\n\n  get activeTabPortal() {\n    return this.tabs[this.selectedIndex]?.content;\n  }\n\n  readonly destroyed$ = new Subject<void>();\n\n  constructor(private cd: ChangeDetectorRef) {\n    this.listenToFirstTabSelectByAngularRouterForTabLinks().subscribe((tab) => {\n      // synchonize the focusedIndex and selectedIndex state with the tab that is active through the current route.\n      this.switchTo(tab);\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const tab = this.tabs[this.selectedIndex];\n    if (changes['selectedIndex'] && !changes['selectedIndex'].isFirstChange() && tab) {\n      this.switchTo(tab);\n    }\n  }\n\n  ngAfterContentInit() {\n    if (this.tabs[0]) {\n      this.tabs[0].noLeftMarginForFirstTab = true;\n    }\n    const tab = this.tabs[this.selectedIndex];\n    if (tab && !tab.tabLink) {\n      this.switchTo(tab);\n    }\n\n    const listenToTabsSwitch = (tabs: TabComponent[]) => merge(...tabs.map((tab) => tab.switch.asObservable().pipe(map(() => tab))));\n\n    this.tabsQueryList?.changes\n      .pipe(\n        startWith(null),\n        switchMap(() => listenToTabsSwitch(this.tabs)),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((tab) => {\n        this.switchTo(tab);\n      });\n\n    this.tabsQueryList?.changes\n      .pipe(\n        startWith(null),\n        switchMap(() => merge(...this.tabs.map((tab) => tab.keyDownAction))),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((event) => {\n        this.handleKeyDown(event);\n      });\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  onFocusOut(event: any) {\n    if (!this.tabListElement?.nativeElement?.contains(event.relatedTarget)) {\n      // resync focused index on selected index when leaving tabs\n      this.focusedIndex = this.selectedIndex;\n    }\n  }\n\n  switchTo(tab: TabComponent) {\n    this.tabsQueryList?.forEach((t, index) => {\n      t.isActive = t === tab;\n      if (t.isActive) {\n        this.selectedIndex = index;\n        this.focusedIndex = index;\n        this.indexChange.emit(index);\n      }\n    });\n    this.cd.markForCheck();\n  }\n\n  handleKeyDown(event: KeyboardEvent) {\n    switch (event.code) {\n      case LxTabGroupKeyCode.ArrowRight:\n        const newTabIndex = (this.focusedIndex + 1) % this.tabs.length;\n        this.focusTab(newTabIndex);\n        break;\n      case LxTabGroupKeyCode.ArrowLeft:\n        const previousTabIndex = this.focusedIndex === 0 ? this.tabs.length - 1 : this.focusedIndex - 1;\n        this.focusTab(previousTabIndex);\n        break;\n      case LxTabGroupKeyCode.Home:\n        event.preventDefault();\n        this.focusTab(0);\n        break;\n      case LxTabGroupKeyCode.End:\n        event.preventDefault();\n        this.focusTab(this.tabs.length - 1);\n        break;\n    }\n  }\n\n  private focusTab(tabIndex: number): void {\n    const tab = this.tabs[tabIndex];\n    if (!tab) {\n      return;\n    }\n\n    tab.setFocus();\n    this.focusedIndex = tabIndex;\n  }\n\n  private listenToFirstTabSelectByAngularRouterForTabLinks() {\n    return this.tabsQueryList$.pipe(\n      switchMap(() => {\n        const tabLinks = this.tabs.filter((tab) => !!tab.tabLink);\n        return merge(...tabLinks.map((tab) => tab.routerLinkActiveChange$.pipe(map(() => tab))));\n      }),\n      first(),\n      takeUntil(this.destroyed$) // added in addition to first() here since for tab groups without links no single value will ever be emit.\n    );\n  }\n}\n","<ul\n  #tabListElement\n  class=\"tabs\"\n  role=\"tablist\"\n  (focusout)=\"onFocusOut($event)\"\n  [attr.aria-owns]=\"tabIds.join(' ')\"\n  [class.centered]=\"isCentered\"\n>\n  <ng-content />\n</ul>\n\n<ng-template [cdkPortalOutlet]=\"activeTabPortal\" />\n"]}
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-group.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/tab-ui/components/tab-group/tab-group.component.ts","../../../../../../../../libs/components/src/lib/tab-ui/components/tab-group/tab-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { PortalModule } from '@angular/cdk/portal';\nimport { NgTemplateOutlet } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { Observable, Subject, merge } from 'rxjs';\nimport { first, map, startWith, switchMap, takeUntil } from 'rxjs/operators';\nimport { Observe } from '../../../shared/observe';\nimport { TabComponent } from '../tab/tab.component';\nimport { LxTabGroupKeyCode } from './tab-group-key-codes.enum';\n\n@Component({\n  selector: 'lx-tab-group',\n  templateUrl: 'tab-group.component.html',\n  styleUrls: ['tab-group.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [PortalModule, NgTemplateOutlet]\n})\nexport class TabGroupComponent implements OnChanges, AfterContentInit, OnDestroy {\n  @Input() isCentered: boolean = false;\n  /**\n   * The tab whose content should be displayed.\n   */\n  @Input() selectedIndex: number = 0;\n  @Output() indexChange = new EventEmitter<number>();\n\n  /** @internal */\n  @Observe('tabsQueryList') tabsQueryList$!: Observable<QueryList<TabComponent>>;\n  /** @internal */\n  @ContentChildren(TabComponent) tabsQueryList?: QueryList<TabComponent>;\n  /** @internal */\n  @ViewChild('tabListElement') tabListElement?: ElementRef<HTMLElement>;\n\n  /**\n   * The tab that is currently focused via keyboard.\n   * @internal\n   */\n  focusedIndex: number = 0;\n\n  /** @internal */\n  get tabIds(): string[] {\n    return this.tabs.map((t) => t.tabId);\n  }\n  private get tabs(): TabComponent[] {\n    return this.tabsQueryList?.toArray() || [];\n  }\n\n  /** @internal */\n  get activeTabPortal() {\n    return this.tabs[this.selectedIndex]?.content;\n  }\n\n  /** @internal */\n  readonly destroyed$ = new Subject<void>();\n\n  constructor(private cd: ChangeDetectorRef) {\n    this.listenToFirstTabSelectByAngularRouterForTabLinks().subscribe((tab) => {\n      // synchonize the focusedIndex and selectedIndex state with the tab that is active through the current route.\n      this.switchTo(tab);\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    const tab = this.tabs[this.selectedIndex];\n    if (changes['selectedIndex'] && !changes['selectedIndex'].isFirstChange() && tab) {\n      this.switchTo(tab);\n    }\n  }\n\n  ngAfterContentInit() {\n    if (this.tabs[0]) {\n      this.tabs[0].noLeftMarginForFirstTab = true;\n    }\n    const tab = this.tabs[this.selectedIndex];\n    if (tab && !tab.tabLink) {\n      this.switchTo(tab);\n    }\n\n    const listenToTabsSwitch = (tabs: TabComponent[]) => merge(...tabs.map((tab) => tab.switch.asObservable().pipe(map(() => tab))));\n\n    this.tabsQueryList?.changes\n      .pipe(\n        startWith(null),\n        switchMap(() => listenToTabsSwitch(this.tabs)),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((tab) => {\n        this.switchTo(tab);\n      });\n\n    this.tabsQueryList?.changes\n      .pipe(\n        startWith(null),\n        switchMap(() => merge(...this.tabs.map((tab) => tab.keyDownAction))),\n        takeUntil(this.destroyed$)\n      )\n      .subscribe((event) => {\n        this.handleKeyDown(event);\n      });\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  /** @internal */\n  onFocusOut(event: any) {\n    if (!this.tabListElement?.nativeElement?.contains(event.relatedTarget)) {\n      // resync focused index on selected index when leaving tabs\n      this.focusedIndex = this.selectedIndex;\n    }\n  }\n\n  /** @internal */\n  switchTo(tab: TabComponent) {\n    this.tabsQueryList?.forEach((t, index) => {\n      t.isActive = t === tab;\n      if (t.isActive) {\n        this.selectedIndex = index;\n        this.focusedIndex = index;\n        this.indexChange.emit(index);\n      }\n    });\n    this.cd.markForCheck();\n  }\n\n  /** @internal */\n  handleKeyDown(event: KeyboardEvent) {\n    switch (event.code) {\n      case LxTabGroupKeyCode.ArrowRight:\n        const newTabIndex = (this.focusedIndex + 1) % this.tabs.length;\n        this.focusTab(newTabIndex);\n        break;\n      case LxTabGroupKeyCode.ArrowLeft:\n        const previousTabIndex = this.focusedIndex === 0 ? this.tabs.length - 1 : this.focusedIndex - 1;\n        this.focusTab(previousTabIndex);\n        break;\n      case LxTabGroupKeyCode.Home:\n        event.preventDefault();\n        this.focusTab(0);\n        break;\n      case LxTabGroupKeyCode.End:\n        event.preventDefault();\n        this.focusTab(this.tabs.length - 1);\n        break;\n    }\n  }\n\n  private focusTab(tabIndex: number): void {\n    const tab = this.tabs[tabIndex];\n    if (!tab) {\n      return;\n    }\n\n    tab.setFocus();\n    this.focusedIndex = tabIndex;\n  }\n\n  private listenToFirstTabSelectByAngularRouterForTabLinks() {\n    return this.tabsQueryList$.pipe(\n      switchMap(() => {\n        const tabLinks = this.tabs.filter((tab) => !!tab.tabLink);\n        return merge(...tabLinks.map((tab) => tab.routerLinkActiveChange$.pipe(map(() => tab))));\n      }),\n      first(),\n      takeUntil(this.destroyed$) // added in addition to first() here since for tab groups without links no single value will ever be emit.\n    );\n  }\n}\n","<ul\n  #tabListElement\n  class=\"tabs\"\n  role=\"tablist\"\n  (focusout)=\"onFocusOut($event)\"\n  [attr.aria-owns]=\"tabIds.join(' ')\"\n  [class.centered]=\"isCentered\"\n>\n  <ng-content />\n</ul>\n\n<ng-template [cdkPortalOutlet]=\"activeTabPortal\" />\n"]}