@leanix/components 0.4.504 → 0.4.506

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 (32) 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/core-ui.constants.mjs +12 -9
  9. package/esm2022/lib/core-ui/tooltip/tooltip.directive.mjs +1 -9
  10. package/esm2022/lib/forms-ui/components/breadcrumb/breadcrumb.component.mjs +1 -9
  11. package/esm2022/lib/forms-ui/components/date-input/date-input.component.mjs +1 -9
  12. package/esm2022/lib/forms-ui/components/single-select/single-select.component.mjs +1 -12
  13. package/esm2022/lib/forms-ui/components/switch/switch.component.mjs +1 -9
  14. package/esm2022/lib/popover-ui/components/popover/popover.component.mjs +3 -9
  15. package/esm2022/lib/tab-ui/components/tab-group/tab-group.component.mjs +8 -24
  16. package/fesm2022/leanix-components.mjs +20 -143
  17. package/fesm2022/leanix-components.mjs.map +1 -1
  18. package/lib/core-ui/components/badge/badge.component.d.ts +0 -8
  19. package/lib/core-ui/components/banner/banner.component.d.ts +0 -10
  20. package/lib/core-ui/components/button/button.component.d.ts +0 -8
  21. package/lib/core-ui/components/card/card.component.d.ts +0 -8
  22. package/lib/core-ui/components/counter/counter.component.d.ts +0 -8
  23. package/lib/core-ui/components/skeleton/skeleton.component.d.ts +0 -11
  24. package/lib/core-ui/components/tiny-spinner/tiny-spinner.component.d.ts +0 -8
  25. package/lib/core-ui/tooltip/tooltip.directive.d.ts +0 -8
  26. package/lib/forms-ui/components/breadcrumb/breadcrumb.component.d.ts +0 -8
  27. package/lib/forms-ui/components/date-input/date-input.component.d.ts +0 -8
  28. package/lib/forms-ui/components/single-select/single-select.component.d.ts +0 -11
  29. package/lib/forms-ui/components/switch/switch.component.d.ts +0 -8
  30. package/lib/popover-ui/components/popover/popover.component.d.ts +2 -8
  31. package/lib/tab-ui/components/tab-group/tab-group.component.d.ts +10 -23
  32. package/package.json +1 -1
@@ -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":";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;;;AAE/D;;;;;;;;;;;;;;;;;;;;;;GAsBG;AASH,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,oKChE/B,sQAYA,+QDyCY,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/**\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"]}
@@ -72,6 +72,7 @@ const ICON_MAP = {
72
72
  'fa-sync': ['synchronize'],
73
73
  'fa-plus-circle': ['sys-add'],
74
74
  'fa-exclamation-triangle': ['warning'],
75
+ 'fa-exclamation-circle': ['lx-icons/exclamation-circle'],
75
76
  'fa-arrow-right': ['arrow-right'],
76
77
  'fa-arrow-left': ['arrow-left'],
77
78
  'fa-link': ['chain-link'],
@@ -184,7 +185,7 @@ const ICON_MAP = {
184
185
  'fa-lightbulb': ['lightbulb'],
185
186
  'fa-list-ol': ['business-suite/icon-bulleting-with-numbers'],
186
187
  'fa-map': ['map-3'],
187
- 'fa-map-pin': [],
188
+ 'fa-map-pin': ['lx-icons/map-pin'],
188
189
  'fa-map-signs': ['lx-icons/map-signs'],
189
190
  'fa-pen': ['edit'],
190
191
  'fa-people-arrows': ['citizen-connect'],
@@ -247,41 +248,35 @@ const ICON_MAP = {
247
248
  'fa-confluence': ['lx-icons/confluence'],
248
249
  'fa-cloud': ['cloud'],
249
250
  'fa-euro-sign': ['lx-icons/euro-sign'],
250
- 'fa-exchange': [],
251
+ 'fa-exchange': ['lx-icons/exchange'],
251
252
  'fa-folder-open': ['open-folder'],
252
253
  'fa-folder-tree': ['lx-icons/folder-tree'],
253
254
  'fa-gavel': ['lx-icons/gavel'],
254
255
  'fa-keyboard': ['keyboard-and-mouse'],
255
256
  'fa-hammer': ['lx-icons/hammer'],
256
- 'fa-hat-wizard': [],
257
- 'fa-hourglass-end': [],
257
+ 'fa-hat-wizard': ['lx-icons/hat-wizard'],
258
+ 'fa-hourglass-end': ['lx-icons/hourglass-end'],
258
259
  'fa-lemon': [],
259
260
  'fa-pound-sign': ['lx-icons/pound-sign'],
260
261
  'fa-project-diagram': ['lx-icons/project-diagram'],
261
262
  'fa-shield': ['lx-icons/shield'],
262
- 'fa-signal': [],
263
+ 'fa-signal': ['lx-icons/signal'],
263
264
  'fa-tasks-alt': ['lx-icons/tasks'],
264
265
  'fa-toolbox': ['lx-icons/toolbox'],
265
266
  'fa-tools': ['wrench'],
266
- 'fa-tshirt': [],
267
+ 'fa-tshirt': ['lx-icons/tshirt'],
267
268
  'fa-underline': ['underline-text'],
268
269
  'fa-unicorn': [],
269
270
  'fa-user-hard-hat': [],
270
- 'fa-window': ['tnt/subject'],
271
+ 'fa-window': ['lx-icons/window'], // ['tnt/subject'],
271
272
  'fa-quote-right': ['lx-icons/quote-right'],
272
- 'fa-yen-sign': ['lx-icons/yen-sign']
273
+ 'fa-yen-sign': ['lx-icons/yen-sign'],
274
+ 'fa-feather': ['lx-icons/feather'],
275
+ 'fa-road': ['lx-icons/road']
273
276
  };
274
277
 
275
278
  /**
276
279
  * Badge component is used to show a small piece of information in a colored badge.
277
- *
278
- * ## Usage
279
- *
280
- * 1. Import the `LxCoreUiModule` module from `@leanix/components` in your module where you want to use the component.
281
- *
282
- * ```ts
283
- * import { LxCoreUiModule } from '@leanix/components';
284
- * ```
285
280
  */
286
281
  class BadgeComponent {
287
282
  constructor() {
@@ -350,16 +345,6 @@ const BANNER_SIZE = {
350
345
 
351
346
  /**
352
347
  * Banner can be used to display important information to the user. It allows for any type of content to be displayed in a banner.
353
- *
354
- * ## Usage
355
- *
356
- * 1. Import the `LxCoreUiModule` module from `@leanix/components` in your module where you want to use the component.
357
- *
358
- * ```ts
359
- * import { LxCoreUiModule } from '@leanix/components';
360
- * ```
361
- *
362
- * 2. Use the component in your template.
363
348
  */
364
349
  class BannerComponent {
365
350
  constructor() {
@@ -451,14 +436,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
451
436
 
452
437
  /**
453
438
  * Tiny spinner component is used to show a small spinner.
454
- *
455
- * ## Usage
456
- *
457
- * 1. Import the `TinySpinnerComponent` component from `@leanix/components` in your module or standalone copmonent where you want to use the component.
458
- *
459
- * ```ts
460
- * import { TinySpinnerComponent } from '@leanix/components';
461
- * ```
462
439
  */
463
440
  class TinySpinnerComponent {
464
441
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: TinySpinnerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
@@ -482,14 +459,6 @@ const LX_BUTTON_USE_SAP_ICONS = new InjectionToken('LX_BUTTON_USE_SAP_ICONS', {
482
459
  /**
483
460
  * Button component is used to create a button with different styles and sizes. This uses native button element and
484
461
  * only provides styling and some additional features like loading spinner.
485
- *
486
- * ## Usage
487
- *
488
- * 1. Import the `ButtonComponent` from `@leanix/components` where you want to use the component.
489
- *
490
- * ```ts
491
- * import { ButtonComponent } from '@leanix/components';
492
- * ```
493
462
  */
494
463
  class ButtonComponent {
495
464
  constructor() {
@@ -650,14 +619,6 @@ function removeFontAwesomeVariant(iconName) {
650
619
  /**
651
620
  * Card component is a container component that can be used to display content in a card-like style.
652
621
  * This documentation provides details on the usage and configuration of the Card Component.
653
- *
654
- * ## Usage
655
- *
656
- * 1. Import the `LxCoreUiModule` module from `@leanix/components` in your module where you want to use the component.
657
- *
658
- * ```ts
659
- * import { LxCoreUiModule } from '@leanix/components';
660
- * ```
661
622
  */
662
623
  class CardComponent {
663
624
  constructor() {
@@ -730,14 +691,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
730
691
 
731
692
  /**
732
693
  * Counter component is used to create a counter with different styles and sizes.
733
- *
734
- * ## Usage
735
- *
736
- * 1. Import the `CounterComponent` component from `@leanix/components` in your module or standalone copmonent where you want to use the component.
737
- *
738
- * ```ts
739
- * import { CounterComponent } from '@leanix/components';
740
- * ```
741
694
  */
742
695
  class CounterComponent {
743
696
  constructor() {
@@ -2365,14 +2318,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
2365
2318
 
2366
2319
  /**
2367
2320
  * Tooltip directive is used to show a tooltip on hover or focus on an element.
2368
- *
2369
- * ## Usage
2370
- *
2371
- * 1. Import the `TooltipDirective` component from `@leanix/components` in your module or standalone copmonent where you want to use the component.
2372
- *
2373
- * ```ts
2374
- * import { TooltipDirective } from '@leanix/components';
2375
- * ```
2376
2321
  */
2377
2322
  class TooltipDirective {
2378
2323
  /** The position of the tooltip. */
@@ -2651,20 +2596,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
2651
2596
  /**
2652
2597
  * Skeleton is a component that can be used to show a loading state of a component.
2653
2598
  *
2654
- * ## Usage
2655
- *
2656
- * 1. Import the `SkeletonComponent` component from `@leanix/components` in your module or standalone copmonent where you want to use the component.
2657
- *
2658
- * ```ts
2659
- * import { SkeletonComponent } from '@leanix/components';
2660
- * ```
2661
- *
2662
2599
  * Use skeleton loaders for pages or sections that load content progressively, like text and images. The component can
2663
2600
  * be used to compose various scenarios like placeholders for thumbnails, lists, and avatars. See the example
2664
2601
  * [patterns](?path=/docs/skeleton-patterns--docs) for more details.
2665
- *
2666
- * To get started, import the `SkeletonComponent` in your Angular module or standalone component and use it in the
2667
- * template using the `<lx-skeleton />` selector with the desired width, height, and border radius.
2668
2602
  */
2669
2603
  class SkeletonComponent {
2670
2604
  constructor() {
@@ -3706,14 +3640,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
3706
3640
 
3707
3641
  /**
3708
3642
  * Breadcrumb component is used to show a list of labels, usually to show the path of user's navigation.
3709
- *
3710
- * ## Usage
3711
- *
3712
- * 1. Import the LxFormsModule module from @leanix/components in your module where you want to use the component.
3713
- *
3714
- * ```ts
3715
- * import { LxFormsModule } from '@leanix/components';
3716
- * ```
3717
3643
  */
3718
3644
  class BreadcrumbComponent {
3719
3645
  constructor() {
@@ -5370,14 +5296,6 @@ const DEFAULT_MIN_DATE = new Date('0000-01-01');
5370
5296
  const DEFAULT_MAX_DATE = new Date('9999-12-31');
5371
5297
  /**
5372
5298
  * This is a date input component that can be used to select a date.
5373
- *
5374
- * ## Usage
5375
- *
5376
- * 1. Import the `LxFormsUiModule` module from `@leanix/components` in your module where you want to use the component.
5377
- *
5378
- * ```ts
5379
- * import { LxFormsUiModule } from '@leanix/components';
5380
- * ```
5381
5299
  */
5382
5300
  class DateInputComponent {
5383
5301
  constructor(cd, dateFormatsProvider, getDateFnLocale) {
@@ -8007,17 +7925,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
8007
7925
  }]
8008
7926
  }] });
8009
7927
 
8010
- /**
8011
- * ## Usage
8012
- *
8013
- * 1. Import the `LxFormsModule` module from `@leanix/components` in your module where you want to use the component.
8014
- *
8015
- * ```ts
8016
- * import { LxFormsModule } from '@leanix/components';
8017
- * ```
8018
- *
8019
- * 2. Use the component in your template.
8020
- */
8021
7928
  class SingleSelectComponent extends BaseSelectDirective {
8022
7929
  /** @internal */
8023
7930
  static calculateNewCursorPostionOnKeyboardNavigation(cursorPosition, keyCode) {
@@ -8373,14 +8280,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
8373
8280
 
8374
8281
  /**
8375
8282
  * Switch component is a toggle switch that can be used to switch between two states.
8376
- *
8377
- * ## Usage
8378
- *
8379
- * 1. Import the `SwitchComponent` component from `@leanix/components` in your module or standalone copmonent where you want to use the component.
8380
- *
8381
- * ```ts
8382
- * import { SwitchComponent } from '@leanix/components';
8383
- * ```
8384
8283
  */
8385
8284
  class SwitchComponent {
8386
8285
  constructor() {
@@ -9601,14 +9500,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
9601
9500
  /**
9602
9501
  * The Popover component is based on the [ncstate-sat/popover](https://github.com/ncstate-sat/popover) library.
9603
9502
  *
9604
- * ## Usage
9605
- *
9606
- * 1. Import `LxPopoverUiModule` and `LxCoreUiModule` module from `@leanix/components` in your module where you want to use the component.
9607
- *
9608
- * ```ts
9609
- * import { LxPopoverUiModule, LxCoreUiModule } from '@leanix/components';
9610
- * ```
9611
- *
9503
+ * ## Examples
9504
+
9612
9505
  * This popover encapsulates this open source library: https://github.com/ncstate-sat/popover,
9613
9506
  * make sure to also check out the docs over there.
9614
9507
  *
@@ -10083,36 +9976,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
10083
9976
  args: [RouterLinkActive]
10084
9977
  }] } });
10085
9978
 
10086
- /**
10087
- * ## Usage
10088
- *
10089
- * 1. Import the `LxTabUiModule` module from `@leanix/components` in your module where you want to use the component.
10090
- *
10091
- * ```ts
10092
- * import { LxTabUiModule } from '@leanix/components';
10093
- *
10094
- * // ...
10095
- *
10096
- * @NgModule({
10097
- * // ...
10098
- * imports: [
10099
- * // ...
10100
- * LxTabUiModule
10101
- * // ...
10102
- * ]
10103
- * })
10104
- * export class MyModule {}
10105
- * ```
10106
- *
10107
- * 2. Use the component in your template.
10108
- */
10109
9979
  class TabGroupComponent {
9980
+ /** @internal */
10110
9981
  get tabIds() {
10111
9982
  return this.tabs.map((t) => t.tabId);
10112
9983
  }
10113
9984
  get tabs() {
10114
9985
  return this.tabsQueryList?.toArray() || [];
10115
9986
  }
9987
+ /** @internal */
10116
9988
  get activeTabPortal() {
10117
9989
  return this.tabs[this.selectedIndex]?.content;
10118
9990
  }
@@ -10126,8 +9998,10 @@ class TabGroupComponent {
10126
9998
  this.indexChange = new EventEmitter();
10127
9999
  /**
10128
10000
  * The tab that is currently focused via keyboard.
10001
+ * @internal
10129
10002
  */
10130
10003
  this.focusedIndex = 0;
10004
+ /** @internal */
10131
10005
  this.destroyed$ = new Subject();
10132
10006
  this.listenToFirstTabSelectByAngularRouterForTabLinks().subscribe((tab) => {
10133
10007
  // synchonize the focusedIndex and selectedIndex state with the tab that is active through the current route.
@@ -10163,12 +10037,14 @@ class TabGroupComponent {
10163
10037
  ngOnDestroy() {
10164
10038
  this.destroyed$.next();
10165
10039
  }
10040
+ /** @internal */
10166
10041
  onFocusOut(event) {
10167
10042
  if (!this.tabListElement?.nativeElement?.contains(event.relatedTarget)) {
10168
10043
  // resync focused index on selected index when leaving tabs
10169
10044
  this.focusedIndex = this.selectedIndex;
10170
10045
  }
10171
10046
  }
10047
+ /** @internal */
10172
10048
  switchTo(tab) {
10173
10049
  this.tabsQueryList?.forEach((t, index) => {
10174
10050
  t.isActive = t === tab;
@@ -10180,6 +10056,7 @@ class TabGroupComponent {
10180
10056
  });
10181
10057
  this.cd.markForCheck();
10182
10058
  }
10059
+ /** @internal */
10183
10060
  handleKeyDown(event) {
10184
10061
  switch (event.code) {
10185
10062
  case LxTabGroupKeyCode.ArrowRight: