@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.
- package/esm2022/lib/core-ui/components/collapsible/collapsible.component.mjs +3 -3
- package/esm2022/lib/core-ui/components/spinner/spinner.component.mjs +4 -4
- package/esm2022/lib/core-ui/components/tokenizer/tokenizer.component.mjs +40 -1
- package/esm2022/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.mjs +4 -2
- package/esm2022/lib/forms-ui/components/picker/picker.component.mjs +4 -2
- package/esm2022/lib/forms-ui/components/single-select/single-select.component.mjs +12 -1
- package/esm2022/lib/tab-ui/components/tab-group/tab-group.component.mjs +24 -1
- package/fesm2022/leanix-components.mjs +84 -7
- package/fesm2022/leanix-components.mjs.map +1 -1
- package/lib/core-ui/components/spinner/spinner.component.d.ts +3 -3
- package/lib/core-ui/components/tokenizer/tokenizer.component.d.ts +39 -0
- package/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.d.ts +3 -1
- package/lib/forms-ui/components/picker/picker.component.d.ts +3 -1
- package/lib/forms-ui/components/single-select/single-select.component.d.ts +11 -0
- package/lib/tab-ui/components/tab-group/tab-group.component.d.ts +23 -0
- package/package.json +1 -1
@@ -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":"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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  @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
|
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
|
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
|
1105
|
-
* - fullSpaceFixed
|
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
|
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
|
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);
|