@leanix/components 0.4.472 → 0.4.474

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.
@@ -9,6 +9,29 @@ 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
+ */
12
35
  export class TabGroupComponent {
13
36
  get tabIds() {
14
37
  return this.tabs.map((t) => t.tabId);
@@ -140,4 +163,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
140
163
  type: ViewChild,
141
164
  args: ['tabListElement']
142
165
  }] } });
143
- //# 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":";AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EACT,eAAe,EAEf,YAAY,EACZ,KAAK,EAGL,MAAM,EAGN,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAc,OAAO,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AAClD,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC7E,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;;;AAU/D,MAAM,OAAO,iBAAiB;IAiB5B,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IACvC,CAAC;IACD,IAAY,IAAI;QACd,OAAO,IAAI,CAAC,aAAa,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IAC7C,CAAC;IAED,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,OAAO,CAAC;IAChD,CAAC;IAID,YAAoB,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;QA7BhC,eAAU,GAAY,KAAK,CAAC;QACrC;;WAEG;QACM,kBAAa,GAAW,CAAC,CAAC;QACzB,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QAMnD;;WAEG;QACH,iBAAY,GAAW,CAAC,CAAC;QAahB,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;QAGxC,IAAI,CAAC,gDAAgD,EAAE,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YACxE,6GAA6G;YAC7G,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QACrB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC1C,IAAI,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,aAAa,EAAE,IAAI,GAAG,EAAE,CAAC;YACjF,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QACrB,CAAC;IACH,CAAC;IAED,kBAAkB;QAChB,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;YACjB,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,uBAAuB,GAAG,IAAI,CAAC;QAC9C,CAAC;QACD,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC1C,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;YACxB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QACrB,CAAC;QAED,MAAM,kBAAkB,GAAG,CAAC,IAAoB,EAAE,EAAE,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAEjI,IAAI,CAAC,aAAa,EAAE,OAAO;aACxB,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,EACf,SAAS,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,EAC9C,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAC3B;aACA,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YACjB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QACrB,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,aAAa,EAAE,OAAO;aACxB,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,EACf,SAAS,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC,EACpE,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAC3B;aACA,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACnB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC5B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,aAAa,EAAE,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,EAAE,CAAC;YACvE,2DAA2D;YAC3D,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC;QACzC,CAAC;IACH,CAAC;IAED,QAAQ,CAAC,GAAiB;QACxB,IAAI,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE;YACvC,CAAC,CAAC,QAAQ,GAAG,CAAC,KAAK,GAAG,CAAC;YACvB,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC;gBACf,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;gBAC3B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;gBAC1B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC/B,CAAC;QACH,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;IACzB,CAAC;IAED,aAAa,CAAC,KAAoB;QAChC,QAAQ,KAAK,CAAC,IAAI,EAAE,CAAC;YACnB,KAAK,iBAAiB,CAAC,UAAU;gBAC/B,MAAM,WAAW,GAAG,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;gBAC/D,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;gBAC3B,MAAM;YACR,KAAK,iBAAiB,CAAC,SAAS;gBAC9B,MAAM,gBAAgB,GAAG,IAAI,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;gBAChG,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAC;gBAChC,MAAM;YACR,KAAK,iBAAiB,CAAC,IAAI;gBACzB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;gBACjB,MAAM;YACR,KAAK,iBAAiB,CAAC,GAAG;gBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;gBACpC,MAAM;QACV,CAAC;IACH,CAAC;IAEO,QAAQ,CAAC,QAAgB;QAC/B,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAChC,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,OAAO;QACT,CAAC;QAED,GAAG,CAAC,QAAQ,EAAE,CAAC;QACf,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;IAC/B,CAAC;IAEO,gDAAgD;QACtD,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAC7B,SAAS,CAAC,GAAG,EAAE;YACb,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;YAC1D,OAAO,KAAK,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,uBAAuB,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3F,CAAC,CAAC,EACF,KAAK,EAAE,EACP,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,0GAA0G;SACtI,CAAC;IACJ,CAAC;8GA3IU,iBAAiB;kGAAjB,iBAAiB,qNASX,YAAY,oKCzC/B,sQAYA,+QDkBY,YAAY;;AAUI;IAAzB,OAAO,CAAC,eAAe,CAAC;yDAAsD;2FARpE,iBAAiB;kBAR7B,SAAS;+BACE,cAAc,mBAGP,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP,CAAC,YAAY,EAAE,gBAAgB,CAAC;sFAGhC,UAAU;sBAAlB,KAAK;gBAIG,aAAa;sBAArB,KAAK;gBACI,WAAW;sBAApB,MAAM;gBAEmB,cAAc,MACT,aAAa;sBAA3C,eAAe;uBAAC,YAAY;gBACA,cAAc;sBAA1C,SAAS;uBAAC,gBAAgB","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  @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"]}
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"]}
@@ -694,11 +694,11 @@ class CollapsibleComponent {
694
694
  }
695
695
  }
696
696
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: CollapsibleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
697
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: CollapsibleComponent, isStandalone: true, selector: "lx-collapsible", inputs: { disableSectionToggle: "disableSectionToggle", hideSectionToggle: "hideSectionToggle", toggleSize: "toggleSize", toggleTitle: "toggleTitle", collapsed: "collapsed" }, outputs: { collapsedChange: "collapsedChange" }, host: { listeners: { "click": "onClick($event)" }, properties: { "class.notClickable": "this.notClickable" } }, ngImport: i0, template: "<button\n *ngIf=\"!hideSectionToggle\"\n lx-button\n mode=\"link\"\n [title]=\"toggleTitle\"\n [size]=\"toggleSize\"\n class=\"sectionToggle\"\n type=\"button\"\n [disabled]=\"disableSectionToggle\"\n [square]=\"true\"\n (click)=\"onToggleSection($event)\"\n>\n <i class=\"far fa-angle-down\" [class.collapsed]=\"collapsed\"></i>\n</button>\n<div class=\"collapsible-title\">\n <ng-content />\n</div>\n", styles: [":host{position:relative;cursor:pointer;display:flex;border-bottom:1px solid #e1e5eb;margin-bottom:4px}:host.notClickable{cursor:default}.sectionToggle{font-size:18px;width:32px;align-self:center}.sectionToggle .fa-angle-down{transition:transform .2s linear}.sectionToggle .fa-angle-down.collapsed{transform:rotate(-90deg)}.collapsible-title{width:100%;align-self:center}:host(.align-left) .sectionToggle{text-align:left;width:24px}:host-context(lx-fact-sheet-section.transformationsRedesign){border-bottom-color:#c2c9d6;padding-bottom:8px}:host-context(lx-fact-sheet-section.transformationsRedesign) .sectionToggle{font-size:var(--lxFontLargeSize, 16px);width:20px;height:20px;min-width:20px;text-align:left}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ButtonComponent, selector: "button[lx-button]", inputs: ["size", "color", "mode", "pressed", "selected", "square", "circle", "disabled", "icon", "endIcon", "showSpinner"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
697
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: CollapsibleComponent, isStandalone: true, selector: "lx-collapsible", inputs: { disableSectionToggle: "disableSectionToggle", hideSectionToggle: "hideSectionToggle", toggleSize: "toggleSize", toggleTitle: "toggleTitle", collapsed: "collapsed" }, outputs: { collapsedChange: "collapsedChange" }, host: { listeners: { "click": "onClick($event)" }, properties: { "class.notClickable": "this.notClickable" } }, ngImport: i0, template: "<button\n *ngIf=\"!hideSectionToggle\"\n lx-button\n mode=\"link\"\n [title]=\"toggleTitle\"\n [size]=\"toggleSize\"\n class=\"sectionToggle\"\n [class.collapsed]=\"collapsed\"\n type=\"button\"\n [disabled]=\"disableSectionToggle\"\n [square]=\"true\"\n icon=\"fa-angle-down\"\n (click)=\"onToggleSection($event)\"\n></button>\n<div class=\"collapsible-title\">\n <ng-content />\n</div>\n", styles: [":host{position:relative;cursor:pointer;display:flex;border-bottom:1px solid #e1e5eb;margin-bottom:4px}:host.notClickable{cursor:default}.sectionToggle{font-size:18px;width:32px;align-self:center;transition:transform .2s linear}.sectionToggle.collapsed{transform:rotate(-90deg)}.collapsible-title{width:100%;align-self:center}:host(.align-left) .sectionToggle{text-align:left;width:24px}:host-context(lx-fact-sheet-section.transformationsRedesign){border-bottom-color:#c2c9d6;padding-bottom:8px}:host-context(lx-fact-sheet-section.transformationsRedesign) .sectionToggle{font-size:var(--lxFontLargeSize, 16px);width:20px;height:20px;min-width:20px;text-align:left}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ButtonComponent, selector: "button[lx-button]", inputs: ["size", "color", "mode", "pressed", "selected", "square", "circle", "disabled", "icon", "endIcon", "showSpinner"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
698
698
  }
699
699
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: CollapsibleComponent, decorators: [{
700
700
  type: Component,
701
- args: [{ selector: 'lx-collapsible', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgIf, ButtonComponent], template: "<button\n *ngIf=\"!hideSectionToggle\"\n lx-button\n mode=\"link\"\n [title]=\"toggleTitle\"\n [size]=\"toggleSize\"\n class=\"sectionToggle\"\n type=\"button\"\n [disabled]=\"disableSectionToggle\"\n [square]=\"true\"\n (click)=\"onToggleSection($event)\"\n>\n <i class=\"far fa-angle-down\" [class.collapsed]=\"collapsed\"></i>\n</button>\n<div class=\"collapsible-title\">\n <ng-content />\n</div>\n", styles: [":host{position:relative;cursor:pointer;display:flex;border-bottom:1px solid #e1e5eb;margin-bottom:4px}:host.notClickable{cursor:default}.sectionToggle{font-size:18px;width:32px;align-self:center}.sectionToggle .fa-angle-down{transition:transform .2s linear}.sectionToggle .fa-angle-down.collapsed{transform:rotate(-90deg)}.collapsible-title{width:100%;align-self:center}:host(.align-left) .sectionToggle{text-align:left;width:24px}:host-context(lx-fact-sheet-section.transformationsRedesign){border-bottom-color:#c2c9d6;padding-bottom:8px}:host-context(lx-fact-sheet-section.transformationsRedesign) .sectionToggle{font-size:var(--lxFontLargeSize, 16px);width:20px;height:20px;min-width:20px;text-align:left}\n"] }]
701
+ args: [{ selector: 'lx-collapsible', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgIf, ButtonComponent], template: "<button\n *ngIf=\"!hideSectionToggle\"\n lx-button\n mode=\"link\"\n [title]=\"toggleTitle\"\n [size]=\"toggleSize\"\n class=\"sectionToggle\"\n [class.collapsed]=\"collapsed\"\n type=\"button\"\n [disabled]=\"disableSectionToggle\"\n [square]=\"true\"\n icon=\"fa-angle-down\"\n (click)=\"onToggleSection($event)\"\n></button>\n<div class=\"collapsible-title\">\n <ng-content />\n</div>\n", styles: [":host{position:relative;cursor:pointer;display:flex;border-bottom:1px solid #e1e5eb;margin-bottom:4px}:host.notClickable{cursor:default}.sectionToggle{font-size:18px;width:32px;align-self:center;transition:transform .2s linear}.sectionToggle.collapsed{transform:rotate(-90deg)}.collapsible-title{width:100%;align-self:center}:host(.align-left) .sectionToggle{text-align:left;width:24px}:host-context(lx-fact-sheet-section.transformationsRedesign){border-bottom-color:#c2c9d6;padding-bottom:8px}:host-context(lx-fact-sheet-section.transformationsRedesign) .sectionToggle{font-size:var(--lxFontLargeSize, 16px);width:20px;height:20px;min-width:20px;text-align:left}\n"] }]
702
702
  }], propDecorators: { disableSectionToggle: [{
703
703
  type: Input
704
704
  }], hideSectionToggle: [{
@@ -1101,10 +1101,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
1101
1101
 
1102
1102
  /**
1103
1103
  * The following CSS classes should be used to style this component. The use of the inputs is deprecated.
1104
- * - fullSpace: Sets position to absolute with full height and width => fills ancestor with position set.
1105
- * - fullSpaceFixed: Sets position to fixed with full height and width => fills window
1104
+ * - `fullSpace`: Sets position to absolute with full height and width => fills ancestor with position set.
1105
+ * - `fullSpaceFixed`: Sets position to fixed with full height and width => fills window
1106
1106
  * (or ancestor with new rendering context, created, for example, with `transform: translate(0, 0)`
1107
- * - fadeBackground: Sets background to 60% transparent white. TODO: Always use for fullSpace* classes and remove.
1107
+ * - `fadeBackground`: Sets background to 60% transparent white. TODO: Always use for fullSpace* classes and remove.
1108
1108
  */
1109
1109
  class SpinnerComponent {
1110
1110
  constructor() {
@@ -2630,6 +2630,45 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
2630
2630
  args: [{ selector: 'lx-token', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content />\n" }]
2631
2631
  }], ctorParameters: () => [{ type: i0.ElementRef }] });
2632
2632
 
2633
+ /**
2634
+ * The tokenizer component (`lx-tokenizer`) is responsible for rendering a list of items into a container and hiding those that do not fit behind a placeholder. The items are represented as `lx-token`. Each `lx-token` allows to project any content into it, so anything can become a token. The tokenizer calculates how many items fit into the container (based on width), hiding those items that are overflowing and showing a overflow placeholder instead (e.g. "+4").
2635
+ *
2636
+ * ## Usage
2637
+ *
2638
+ * 1. Import `TokenizerComponent` & `TokenComponent` into your module or component.
2639
+ * 2. Use the component in your template. All items should be wrapped in a `lx-token` element for the tokenizer to identify the individual tokens.
2640
+ *
2641
+ * ```ts
2642
+ * import { TokenizerComponent } from '@leanix/components';
2643
+ *
2644
+ * @Component({
2645
+ * selector: 'lx-my-component',
2646
+ * standalone: true,
2647
+ * imports: [TokenizerComponent, TokenComponent],
2648
+ * template: `
2649
+ * <lx-tokenizer>
2650
+ * <lx-token>Token One</lx-token>
2651
+ * <lx-token>Token Two</lx-token>
2652
+ * </lx-tokenizer>
2653
+ * `
2654
+ * })
2655
+ * export class MyComponent {}
2656
+ * ```
2657
+ *
2658
+ * ## API
2659
+ *
2660
+ * ### Inputs
2661
+ *
2662
+ * - `active`: Can be used to activate & deactivate tokenization
2663
+ *
2664
+ * ### Outputs
2665
+ *
2666
+ * - `overflowPlaceholderClick`: Fires when the user clicks on the overflow placeholder
2667
+ *
2668
+ * ### Content projection
2669
+ *
2670
+ * - `lx-token`: All `lx-tokens` will be projected into the tokenizer
2671
+ */
2633
2672
  class TokenizerComponent {
2634
2673
  constructor(elementRef, destroyRef, changeDetectorRef, resizeObserverService) {
2635
2674
  this.elementRef = elementRef;
@@ -6664,6 +6703,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
6664
6703
 
6665
6704
  /**
6666
6705
  * Usage:
6706
+ *
6707
+ * ```
6667
6708
  * <lx-single-select
6668
6709
  * #singleSelect
6669
6710
  * [selection]="value"
@@ -6678,7 +6719,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
6678
6719
  * (onItemSelected)="singleSelect.selectOption($event)">
6679
6720
  * </lx-option-group-dropdown>
6680
6721
  * </lx-single-select>
6681
- *
6722
+ * ```
6682
6723
  */
6683
6724
  class OptionGroupDropdownComponent extends KeyboardSelectDirective {
6684
6725
  constructor() {
@@ -7291,11 +7332,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
7291
7332
  * How to use:
7292
7333
  * Provide the lx-picker with two kinds of ContentChildren:
7293
7334
  * 1. A lxPickerTrigger, preferably a button element, which we use to open the dropdown on click or enter.
7294
- * 2. A list of <li> elements with an lx-picker-option attribute that own the option template as content children.
7335
+ * 2. A list of `<li>` elements with an lx-picker-option attribute that own the option template as content children.
7295
7336
  *
7296
7337
  * You can use this component as part of a FormGroup or wire it up yourself by listening on the (select) output of the options.
7297
7338
  *
7298
7339
  * Example usage (non FormGroup style):
7340
+ * ```
7299
7341
  * <lx-picker listBoxAriaLabel="Awesome picker">
7300
7342
  * <button lxPickerTrigger lx-button mode="outline" size="large" [square]="true" aria-label="Awesome picker" title="Awesome picker">
7301
7343
  * <lx-icon [name]="selection.label" [color]="selection.value" fontAwsomeStyle="solid"></lx-icon>
@@ -7304,6 +7346,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
7304
7346
  * <lx-icon lx-picker-option [name]="option.label" [color]="option.value" fontAwsomeStyle="solid"></lx-icon>
7305
7347
  * </li>
7306
7348
  * </lx-picker>
7349
+ * ```
7307
7350
  */
7308
7351
  class PickerComponent {
7309
7352
  get activeDescendantsId() {
@@ -7773,6 +7816,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
7773
7816
  }]
7774
7817
  }] });
7775
7818
 
7819
+ /**
7820
+ * ## Usage
7821
+ *
7822
+ * 1. Import the `LxFormsModule` module from `@leanix/components` in your module where you want to use the component.
7823
+ *
7824
+ * ```ts
7825
+ * import { LxFormsModule } from '@leanix/components';
7826
+ * ```
7827
+ *
7828
+ * 2. Use the component in your template.
7829
+ */
7776
7830
  class SingleSelectComponent extends BaseSelectDirective {
7777
7831
  static calculateNewCursorPostionOnKeyboardNavigation(cursorPosition, keyCode) {
7778
7832
  switch (keyCode) {
@@ -9827,6 +9881,29 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
9827
9881
  args: [RouterLinkActive]
9828
9882
  }] } });
9829
9883
 
9884
+ /**
9885
+ * ## Usage
9886
+ *
9887
+ * 1. Import the `LxTabUiModule` module from `@leanix/components` in your module where you want to use the component.
9888
+ *
9889
+ * ```ts
9890
+ * import { LxTabUiModule } from '@leanix/components';
9891
+ *
9892
+ * // ...
9893
+ *
9894
+ * @NgModule({
9895
+ * // ...
9896
+ * imports: [
9897
+ * // ...
9898
+ * LxTabUiModule
9899
+ * // ...
9900
+ * ]
9901
+ * })
9902
+ * export class MyModule {}
9903
+ * ```
9904
+ *
9905
+ * 2. Use the component in your template.
9906
+ */
9830
9907
  class TabGroupComponent {
9831
9908
  get tabIds() {
9832
9909
  return this.tabs.map((t) => t.tabId);