@leanix/components 0.4.527 → 0.4.529

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.
@@ -1,5 +1,5 @@
1
1
  import { __decorate } from "tslib";
2
- import { AsyncPipe, NgIf } from '@angular/common';
2
+ import { AsyncPipe } from '@angular/common';
3
3
  import { ChangeDetectionStrategy, Component, ElementRef, Inject, InjectionToken, Input, ViewChild } from '@angular/core';
4
4
  import { escape } from 'lodash/fp';
5
5
  import { BehaviorSubject, Subject, combineLatest, concat, merge } from 'rxjs';
@@ -112,7 +112,7 @@ export class EllipsisComponent {
112
112
  return offsetWidth < scrollWidth;
113
113
  }
114
114
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: EllipsisComponent, deps: [{ token: LX_ELLIPSIS_DEBOUNCE_ON_RESIZE }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i1.ResizeObserverService }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
115
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: EllipsisComponent, isStandalone: true, selector: "lx-ellipsis", inputs: { content: "content", escapeHtmlInContent: "escapeHtmlInContent" }, viewQueries: [{ propertyName: "contentSpanEl", first: true, predicate: ["contentEl"], descendants: true }, { propertyName: "showMoreButtonEl", first: true, predicate: ["showMoreButton"], descendants: true, read: ElementRef }], ngImport: i0, template: "<span\n #contentEl\n [class.showMore]=\"isShowingMore$ | async\"\n class=\"content truncate lx-margin-right\"\n [innerHtml]=\"sanitizedContent$ | async\"\n></span>\n<button *ngIf=\"showButton$ | async\" (click)=\"onShowMoreToggle()\" lx-button #showMoreButton size=\"auto\" mode=\"link\" color=\"primary\">\n {{ showMoreButtonLabel$ | async }}\n</button>\n", styles: [":host{display:block;white-space:pre-line;overflow-wrap:break-word}.content{display:inline-block;word-break:break-word}.truncate:not(.showMore){width:calc(100% - 140px);white-space:nowrap;overflow-wrap:normal;overflow:hidden;text-overflow:ellipsis}.content.showMore+button{margin-top:4px;display:block}button{white-space:nowrap;vertical-align:top}\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"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
115
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: EllipsisComponent, isStandalone: true, selector: "lx-ellipsis", inputs: { content: "content", escapeHtmlInContent: "escapeHtmlInContent" }, viewQueries: [{ propertyName: "contentSpanEl", first: true, predicate: ["contentEl"], descendants: true }, { propertyName: "showMoreButtonEl", first: true, predicate: ["showMoreButton"], descendants: true, read: ElementRef }], ngImport: i0, template: "<span\n #contentEl\n [class.showMore]=\"isShowingMore$ | async\"\n class=\"content truncate lx-margin-right\"\n [innerHtml]=\"sanitizedContent$ | async\"\n></span>\n@let showButton = showButton$ | async;\n@if (showButton) {\n <button (click)=\"onShowMoreToggle()\" lx-button #showmorebutton size=\"auto\" mode=\"link\" color=\"primary\">\n {{ showMoreButtonLabel$ | async }}\n </button>\n}\n", styles: [":host{display:block;white-space:pre-line;overflow-wrap:break-word}.content{display:inline-block;word-break:break-word}.truncate:not(.showMore){width:calc(100% - 140px);white-space:nowrap;overflow-wrap:normal;overflow:hidden;text-overflow:ellipsis}.content.showMore+button{margin-top:4px;display:block}button{white-space:nowrap;vertical-align:top}\n"], dependencies: [{ kind: "component", type: ButtonComponent, selector: "button[lx-button]", inputs: ["size", "color", "mode", "pressed", "selected", "square", "circle", "disabled", "icon", "endIcon", "showSpinner"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
116
116
  }
117
117
  __decorate([
118
118
  Observe('contentSpanEl')
@@ -125,7 +125,7 @@ __decorate([
125
125
  ], EllipsisComponent.prototype, "content$", void 0);
126
126
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: EllipsisComponent, decorators: [{
127
127
  type: Component,
128
- args: [{ selector: 'lx-ellipsis', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgIf, ButtonComponent, AsyncPipe], template: "<span\n #contentEl\n [class.showMore]=\"isShowingMore$ | async\"\n class=\"content truncate lx-margin-right\"\n [innerHtml]=\"sanitizedContent$ | async\"\n></span>\n<button *ngIf=\"showButton$ | async\" (click)=\"onShowMoreToggle()\" lx-button #showMoreButton size=\"auto\" mode=\"link\" color=\"primary\">\n {{ showMoreButtonLabel$ | async }}\n</button>\n", styles: [":host{display:block;white-space:pre-line;overflow-wrap:break-word}.content{display:inline-block;word-break:break-word}.truncate:not(.showMore){width:calc(100% - 140px);white-space:nowrap;overflow-wrap:normal;overflow:hidden;text-overflow:ellipsis}.content.showMore+button{margin-top:4px;display:block}button{white-space:nowrap;vertical-align:top}\n"] }]
128
+ args: [{ selector: 'lx-ellipsis', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ButtonComponent, AsyncPipe], template: "<span\n #contentEl\n [class.showMore]=\"isShowingMore$ | async\"\n class=\"content truncate lx-margin-right\"\n [innerHtml]=\"sanitizedContent$ | async\"\n></span>\n@let showButton = showButton$ | async;\n@if (showButton) {\n <button (click)=\"onShowMoreToggle()\" lx-button #showmorebutton size=\"auto\" mode=\"link\" color=\"primary\">\n {{ showMoreButtonLabel$ | async }}\n </button>\n}\n", styles: [":host{display:block;white-space:pre-line;overflow-wrap:break-word}.content{display:inline-block;word-break:break-word}.truncate:not(.showMore){width:calc(100% - 140px);white-space:nowrap;overflow-wrap:normal;overflow:hidden;text-overflow:ellipsis}.content.showMore+button{margin-top:4px;display:block}button{white-space:nowrap;vertical-align:top}\n"] }]
129
129
  }], ctorParameters: () => [{ type: undefined, decorators: [{
130
130
  type: Inject,
131
131
  args: [LX_ELLIPSIS_DEBOUNCE_ON_RESIZE]
@@ -140,4 +140,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
140
140
  type: ViewChild,
141
141
  args: ['showMoreButton', { read: ElementRef }]
142
142
  }], content$: [] } });
143
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ellipsis.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/core-ui/components/ellipsis/ellipsis.component.ts","../../../../../../../../libs/components/src/lib/core-ui/components/ellipsis/ellipsis.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe, NgIf } from '@angular/common';\nimport {\n  AfterViewChecked,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  InjectionToken,\n  Input,\n  OnDestroy,\n  OnInit,\n  ViewChild\n} from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { escape } from 'lodash/fp';\nimport { BehaviorSubject, Observable, Subject, combineLatest, concat, merge } from 'rxjs';\nimport {\n  debounceTime,\n  distinctUntilChanged,\n  filter,\n  map,\n  pairwise,\n  skip,\n  startWith,\n  switchMap,\n  take,\n  takeUntil,\n  withLatestFrom\n} from 'rxjs/operators';\nimport { Observe } from '../../../shared/observe';\nimport { ResizeObserverService } from '../../services/resize-observer.service';\nimport { ButtonComponent } from '../button/button.component';\n\nexport const LX_ELLIPSIS_DEBOUNCE_ON_RESIZE = new InjectionToken<number>('LX_ELLIPSIS_DEBOUNCE_ON_RESIZE', {\n  providedIn: 'root',\n  factory: () => EllipsisComponent.DEFAULT_RESIZE_DEBOUNCE_MS\n});\n\n/**\n * You can set `max-width` CSS property on your `lx-ellipsis` host element or the parent element if you want its content to never exceed a specific width.\n */\n@Component({\n  selector: 'lx-ellipsis',\n  templateUrl: 'ellipsis.component.html',\n  styleUrls: [`ellipsis.component.scss`],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [NgIf, ButtonComponent, AsyncPipe]\n})\nexport class EllipsisComponent implements OnInit, OnDestroy, AfterViewChecked {\n  /** @internal */\n  static DEFAULT_RESIZE_DEBOUNCE_MS = 500;\n\n  @Input() content: string = '';\n  /**\n   * Only set this to false if the content is not a user provided string\n   * or if you sanitize the provided content yourself.\n   */\n  @Input() escapeHtmlInContent = true;\n\n  @Observe('contentSpanEl') private contentSpanEl$!: Observable<ElementRef<HTMLSpanElement>>;\n  /** @internal */\n  @ViewChild('contentEl') contentSpanEl!: ElementRef<HTMLSpanElement>;\n  @Observe('showMoreButtonEl') private showMoreButtonEl$!: Observable<ElementRef<HTMLButtonElement>>;\n  /** @internal */\n  @ViewChild('showMoreButton', { read: ElementRef }) showMoreButtonEl!: ElementRef<HTMLButtonElement>;\n\n  /** @internal */\n  isShowingMore$ = new BehaviorSubject(false);\n\n  /** @internal */\n  showButton$!: Observable<boolean>;\n  /** @internal */\n  showMoreButtonLabel$!: Observable<string>;\n\n  /** @internal */\n  sanitizedContent$!: Observable<string>;\n  @Observe('content')\n  private content$!: Observable<string>;\n\n  private destroyed$ = new Subject<void>();\n\n  private viewChecked$ = new Subject<void>();\n\n  constructor(\n    @Inject(LX_ELLIPSIS_DEBOUNCE_ON_RESIZE)\n    private debounceMsAfterResize: number,\n    private cdRef: ChangeDetectorRef,\n    private hostEl: ElementRef,\n    private resizeObserverService: ResizeObserverService,\n    private translateService: TranslateService\n  ) {}\n\n  ngOnInit(): void {\n    this.sanitizedContent$ = this.content$.pipe(\n      map((content) => {\n        if (this.escapeHtmlInContent && typeof content === 'string') {\n          return escape(content);\n        }\n        return content;\n      })\n    );\n\n    this.showMoreButtonLabel$ = this.isShowingMore$.pipe(\n      switchMap((isShowingMore) => {\n        const translationKey = isShowingMore ? 'common.showLess' : 'common.showMore';\n        return this.translateService.get(translationKey);\n      })\n    );\n    const newWidthOnResize$ = new Subject<number>();\n    const newHeightOnResize$ = new Subject<number>();\n    this.resizeObserverService.observe(this.hostEl.nativeElement, (resizedElement) => {\n      newWidthOnResize$.next(resizedElement.contentRect.width);\n      newHeightOnResize$.next(resizedElement.contentRect.height);\n    });\n    const containerWidthChangedSignificantlyAfterResize$ = newWidthOnResize$.pipe(\n      startWith(0),\n      pairwise(),\n      filter(([previousWidth, newWidth]) => Math.abs(newWidth - previousWidth) > 1),\n      map(([, newWidth]) => newWidth)\n    );\n    const userTriggeredTriggeredShowLess$ = this.isShowingMore$.pipe(filter((isShowingMore) => !isShowingMore));\n\n    const reevaluateIfContentIsOverflowing$ = combineLatest([\n      this.contentSpanEl$,\n      userTriggeredTriggeredShowLess$,\n      containerWidthChangedSignificantlyAfterResize$\n    ]);\n\n    const isContentOverflowing$ = merge(\n      concat(\n        reevaluateIfContentIsOverflowing$.pipe(take(1)), // debounce all but the first output\n        reevaluateIfContentIsOverflowing$.pipe(debounceTime(this.debounceMsAfterResize))\n      ),\n      this.content$.pipe(\n        skip(1),\n        switchMap(() => this.viewChecked$)\n      )\n    ).pipe(\n      withLatestFrom(this.contentSpanEl$),\n      map(([, contentSpanRef]) => this.isContentOverflowing(contentSpanRef))\n    );\n\n    const userTriggeredTriggeredShowMore$ = this.isShowingMore$.pipe(filter((isShowingMore) => isShowingMore));\n\n    const buttonHeight$ = this.showMoreButtonEl$.pipe(\n      filter((showMoreButtonEl) => !!showMoreButtonEl),\n      map((showMoreButtonEl) => showMoreButtonEl.nativeElement.offsetHeight),\n      distinctUntilChanged()\n    );\n    const userIncreasedBrowserWindowSizeToThePointOfNoTruncationNecessary$ = combineLatest([\n      buttonHeight$,\n      newHeightOnResize$.pipe(distinctUntilChanged())\n    ]).pipe(\n      withLatestFrom(this.isShowingMore$),\n      filter(([, isShowingMore]) => isShowingMore),\n      map(([[buttonHeight, newHeight]]) => {\n        const heightOfOneLine = buttonHeight;\n        const showLessButtonMarginTop = 4;\n        const heightOfSpanInShowMoreMode = newHeight - buttonHeight - showLessButtonMarginTop;\n        const thresholdToDetectContentInSingleLine = 4;\n        const differenceBetweenContentSpanAndButtonHeight = Math.abs(heightOfOneLine - heightOfSpanInShowMoreMode);\n        const isSpanContentDisplayedInOneLineAgain = differenceBetweenContentSpanAndButtonHeight < thresholdToDetectContentInSingleLine;\n        return isSpanContentDisplayedInOneLineAgain;\n      })\n    );\n    const contentFitsInOneLineAgainWhileShowMoreIsEnabled$ = userIncreasedBrowserWindowSizeToThePointOfNoTruncationNecessary$.pipe(\n      startWith(false),\n      pairwise(),\n      filter(([previousTextIsNowInOneLineAgain]) => !previousTextIsNowInOneLineAgain),\n      map(([, textIsNowInOneLineAgain]) => !textIsNowInOneLineAgain)\n    );\n    const contentIsOverflowingAndShowMoreIsNotEnabled$ = isContentOverflowing$.pipe(\n      withLatestFrom(this.isShowingMore$),\n      filter(([, isShowingMore]) => !isShowingMore),\n      map(([isContentLongerThanContainerWidth]) => {\n        return isContentLongerThanContainerWidth;\n      })\n    );\n    this.showButton$ = merge(\n      userTriggeredTriggeredShowMore$,\n      contentFitsInOneLineAgainWhileShowMoreIsEnabled$,\n      contentIsOverflowingAndShowMoreIsNotEnabled$\n    );\n\n    // As long as no parent component is listening on resize events,\n    // the ChangeDetectorRef.markForCheck() call done by the async pipe\n    // will not result in a change detection cycle in this component when its size changes.\n    // This is the least amount of ChangeDetectorRef.detectChanges() calls\n    // I was able to come up with. The Angular profiler shows acceptable numbers of change detection.\n    this.detectChangesWhenObservableEmits(isContentOverflowing$);\n    this.detectChangesWhenObservableEmits(this.showButton$);\n    this.detectChangesWhenObservableEmits(this.content$);\n    this.detectChangesWhenObservableEmits(contentIsOverflowingAndShowMoreIsNotEnabled$);\n    this.detectChangesWhenObservableEmits(isContentOverflowing$);\n  }\n\n  ngAfterViewChecked() {\n    this.viewChecked$.next();\n  }\n\n  /** @internal */\n  onShowMoreToggle() {\n    this.isShowingMore$.next(!this.isShowingMore$.getValue());\n    this.cdRef.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n    this.resizeObserverService.unobserve(this.hostEl.nativeElement);\n  }\n\n  private detectChangesWhenObservableEmits(observable$: Observable<any>) {\n    observable$.pipe(takeUntil(this.destroyed$)).subscribe(() => this.cdRef.detectChanges());\n  }\n\n  private isContentOverflowing(contentSpanElRef: ElementRef<HTMLSpanElement>) {\n    const scrollWidth = contentSpanElRef.nativeElement.scrollWidth;\n    const offsetWidth = contentSpanElRef.nativeElement.clientWidth;\n    return offsetWidth < scrollWidth;\n  }\n}\n","<span\n  #contentEl\n  [class.showMore]=\"isShowingMore$ | async\"\n  class=\"content truncate lx-margin-right\"\n  [innerHtml]=\"sanitizedContent$ | async\"\n></span>\n<button *ngIf=\"showButton$ | async\" (click)=\"onShowMoreToggle()\" lx-button #showMoreButton size=\"auto\" mode=\"link\" color=\"primary\">\n  {{ showMoreButtonLabel$ | async }}\n</button>\n"]}
143
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ellipsis.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/core-ui/components/ellipsis/ellipsis.component.ts","../../../../../../../../libs/components/src/lib/core-ui/components/ellipsis/ellipsis.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe } from '@angular/common';\nimport {\n  AfterViewChecked,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  InjectionToken,\n  Input,\n  OnDestroy,\n  OnInit,\n  ViewChild\n} from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { escape } from 'lodash/fp';\nimport { BehaviorSubject, Observable, Subject, combineLatest, concat, merge } from 'rxjs';\nimport {\n  debounceTime,\n  distinctUntilChanged,\n  filter,\n  map,\n  pairwise,\n  skip,\n  startWith,\n  switchMap,\n  take,\n  takeUntil,\n  withLatestFrom\n} from 'rxjs/operators';\nimport { Observe } from '../../../shared/observe';\nimport { ResizeObserverService } from '../../services/resize-observer.service';\nimport { ButtonComponent } from '../button/button.component';\n\nexport const LX_ELLIPSIS_DEBOUNCE_ON_RESIZE = new InjectionToken<number>('LX_ELLIPSIS_DEBOUNCE_ON_RESIZE', {\n  providedIn: 'root',\n  factory: () => EllipsisComponent.DEFAULT_RESIZE_DEBOUNCE_MS\n});\n\n/**\n * You can set `max-width` CSS property on your `lx-ellipsis` host element or the parent element if you want its content to never exceed a specific width.\n */\n@Component({\n  selector: 'lx-ellipsis',\n  templateUrl: 'ellipsis.component.html',\n  styleUrls: [`ellipsis.component.scss`],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [ButtonComponent, AsyncPipe]\n})\nexport class EllipsisComponent implements OnInit, OnDestroy, AfterViewChecked {\n  /** @internal */\n  static DEFAULT_RESIZE_DEBOUNCE_MS = 500;\n\n  @Input() content: string = '';\n  /**\n   * Only set this to false if the content is not a user provided string\n   * or if you sanitize the provided content yourself.\n   */\n  @Input() escapeHtmlInContent = true;\n\n  @Observe('contentSpanEl') private contentSpanEl$!: Observable<ElementRef<HTMLSpanElement>>;\n  /** @internal */\n  @ViewChild('contentEl') contentSpanEl!: ElementRef<HTMLSpanElement>;\n  @Observe('showMoreButtonEl') private showMoreButtonEl$!: Observable<ElementRef<HTMLButtonElement>>;\n  /** @internal */\n  @ViewChild('showMoreButton', { read: ElementRef }) showMoreButtonEl!: ElementRef<HTMLButtonElement>;\n\n  /** @internal */\n  isShowingMore$ = new BehaviorSubject(false);\n\n  /** @internal */\n  showButton$!: Observable<boolean>;\n  /** @internal */\n  showMoreButtonLabel$!: Observable<string>;\n\n  /** @internal */\n  sanitizedContent$!: Observable<string>;\n  @Observe('content')\n  private content$!: Observable<string>;\n\n  private destroyed$ = new Subject<void>();\n\n  private viewChecked$ = new Subject<void>();\n\n  constructor(\n    @Inject(LX_ELLIPSIS_DEBOUNCE_ON_RESIZE)\n    private debounceMsAfterResize: number,\n    private cdRef: ChangeDetectorRef,\n    private hostEl: ElementRef,\n    private resizeObserverService: ResizeObserverService,\n    private translateService: TranslateService\n  ) {}\n\n  ngOnInit(): void {\n    this.sanitizedContent$ = this.content$.pipe(\n      map((content) => {\n        if (this.escapeHtmlInContent && typeof content === 'string') {\n          return escape(content);\n        }\n        return content;\n      })\n    );\n\n    this.showMoreButtonLabel$ = this.isShowingMore$.pipe(\n      switchMap((isShowingMore) => {\n        const translationKey = isShowingMore ? 'common.showLess' : 'common.showMore';\n        return this.translateService.get(translationKey);\n      })\n    );\n    const newWidthOnResize$ = new Subject<number>();\n    const newHeightOnResize$ = new Subject<number>();\n    this.resizeObserverService.observe(this.hostEl.nativeElement, (resizedElement) => {\n      newWidthOnResize$.next(resizedElement.contentRect.width);\n      newHeightOnResize$.next(resizedElement.contentRect.height);\n    });\n    const containerWidthChangedSignificantlyAfterResize$ = newWidthOnResize$.pipe(\n      startWith(0),\n      pairwise(),\n      filter(([previousWidth, newWidth]) => Math.abs(newWidth - previousWidth) > 1),\n      map(([, newWidth]) => newWidth)\n    );\n    const userTriggeredTriggeredShowLess$ = this.isShowingMore$.pipe(filter((isShowingMore) => !isShowingMore));\n\n    const reevaluateIfContentIsOverflowing$ = combineLatest([\n      this.contentSpanEl$,\n      userTriggeredTriggeredShowLess$,\n      containerWidthChangedSignificantlyAfterResize$\n    ]);\n\n    const isContentOverflowing$ = merge(\n      concat(\n        reevaluateIfContentIsOverflowing$.pipe(take(1)), // debounce all but the first output\n        reevaluateIfContentIsOverflowing$.pipe(debounceTime(this.debounceMsAfterResize))\n      ),\n      this.content$.pipe(\n        skip(1),\n        switchMap(() => this.viewChecked$)\n      )\n    ).pipe(\n      withLatestFrom(this.contentSpanEl$),\n      map(([, contentSpanRef]) => this.isContentOverflowing(contentSpanRef))\n    );\n\n    const userTriggeredTriggeredShowMore$ = this.isShowingMore$.pipe(filter((isShowingMore) => isShowingMore));\n\n    const buttonHeight$ = this.showMoreButtonEl$.pipe(\n      filter((showMoreButtonEl) => !!showMoreButtonEl),\n      map((showMoreButtonEl) => showMoreButtonEl.nativeElement.offsetHeight),\n      distinctUntilChanged()\n    );\n    const userIncreasedBrowserWindowSizeToThePointOfNoTruncationNecessary$ = combineLatest([\n      buttonHeight$,\n      newHeightOnResize$.pipe(distinctUntilChanged())\n    ]).pipe(\n      withLatestFrom(this.isShowingMore$),\n      filter(([, isShowingMore]) => isShowingMore),\n      map(([[buttonHeight, newHeight]]) => {\n        const heightOfOneLine = buttonHeight;\n        const showLessButtonMarginTop = 4;\n        const heightOfSpanInShowMoreMode = newHeight - buttonHeight - showLessButtonMarginTop;\n        const thresholdToDetectContentInSingleLine = 4;\n        const differenceBetweenContentSpanAndButtonHeight = Math.abs(heightOfOneLine - heightOfSpanInShowMoreMode);\n        const isSpanContentDisplayedInOneLineAgain = differenceBetweenContentSpanAndButtonHeight < thresholdToDetectContentInSingleLine;\n        return isSpanContentDisplayedInOneLineAgain;\n      })\n    );\n    const contentFitsInOneLineAgainWhileShowMoreIsEnabled$ = userIncreasedBrowserWindowSizeToThePointOfNoTruncationNecessary$.pipe(\n      startWith(false),\n      pairwise(),\n      filter(([previousTextIsNowInOneLineAgain]) => !previousTextIsNowInOneLineAgain),\n      map(([, textIsNowInOneLineAgain]) => !textIsNowInOneLineAgain)\n    );\n    const contentIsOverflowingAndShowMoreIsNotEnabled$ = isContentOverflowing$.pipe(\n      withLatestFrom(this.isShowingMore$),\n      filter(([, isShowingMore]) => !isShowingMore),\n      map(([isContentLongerThanContainerWidth]) => {\n        return isContentLongerThanContainerWidth;\n      })\n    );\n    this.showButton$ = merge(\n      userTriggeredTriggeredShowMore$,\n      contentFitsInOneLineAgainWhileShowMoreIsEnabled$,\n      contentIsOverflowingAndShowMoreIsNotEnabled$\n    );\n\n    // As long as no parent component is listening on resize events,\n    // the ChangeDetectorRef.markForCheck() call done by the async pipe\n    // will not result in a change detection cycle in this component when its size changes.\n    // This is the least amount of ChangeDetectorRef.detectChanges() calls\n    // I was able to come up with. The Angular profiler shows acceptable numbers of change detection.\n    this.detectChangesWhenObservableEmits(isContentOverflowing$);\n    this.detectChangesWhenObservableEmits(this.showButton$);\n    this.detectChangesWhenObservableEmits(this.content$);\n    this.detectChangesWhenObservableEmits(contentIsOverflowingAndShowMoreIsNotEnabled$);\n    this.detectChangesWhenObservableEmits(isContentOverflowing$);\n  }\n\n  ngAfterViewChecked() {\n    this.viewChecked$.next();\n  }\n\n  /** @internal */\n  onShowMoreToggle() {\n    this.isShowingMore$.next(!this.isShowingMore$.getValue());\n    this.cdRef.detectChanges();\n  }\n\n  ngOnDestroy(): void {\n    this.resizeObserverService.unobserve(this.hostEl.nativeElement);\n  }\n\n  private detectChangesWhenObservableEmits(observable$: Observable<any>) {\n    observable$.pipe(takeUntil(this.destroyed$)).subscribe(() => this.cdRef.detectChanges());\n  }\n\n  private isContentOverflowing(contentSpanElRef: ElementRef<HTMLSpanElement>) {\n    const scrollWidth = contentSpanElRef.nativeElement.scrollWidth;\n    const offsetWidth = contentSpanElRef.nativeElement.clientWidth;\n    return offsetWidth < scrollWidth;\n  }\n}\n","<span\n  #contentEl\n  [class.showMore]=\"isShowingMore$ | async\"\n  class=\"content truncate lx-margin-right\"\n  [innerHtml]=\"sanitizedContent$ | async\"\n></span>\n@let showButton = showButton$ | async;\n@if (showButton) {\n  <button (click)=\"onShowMoreToggle()\" lx-button #showmorebutton size=\"auto\" mode=\"link\" color=\"primary\">\n    {{ showMoreButtonLabel$ | async }}\n  </button>\n}\n"]}
@@ -1,4 +1,3 @@
1
- import { CommonModule } from '@angular/common';
2
1
  import { Component, EventEmitter, HostBinding, Output, computed, input } from '@angular/core';
3
2
  import { RouterLink } from '@angular/router';
4
3
  import { ButtonComponent } from '../button/button.component';
@@ -23,11 +22,11 @@ export class EmptyStateComponent {
23
22
  return this.size();
24
23
  }
25
24
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: EmptyStateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
26
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: EmptyStateComponent, isStandalone: true, selector: "lx-empty-state", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: true, transformFunction: null }, icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, buttonLabel: { classPropertyName: "buttonLabel", publicName: "buttonLabel", isSignal: true, isRequired: false, transformFunction: null }, secondaryButtonLabel: { classPropertyName: "secondaryButtonLabel", publicName: "secondaryButtonLabel", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, moreLinkLabel: { classPropertyName: "moreLinkLabel", publicName: "moreLinkLabel", isSignal: true, isRequired: false, transformFunction: null }, moreLink: { classPropertyName: "moreLink", publicName: "moreLink", isSignal: true, isRequired: false, transformFunction: null }, openMoreLinkInNewTab: { classPropertyName: "openMoreLinkInNewTab", publicName: "openMoreLinkInNewTab", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { buttonClicked: "buttonClicked", secondaryButtonClicked: "secondaryButtonClicked", moreLinkClicked: "moreLinkClicked" }, host: { properties: { "attr.size": "this._size" } }, ngImport: i0, template: "<div class=\"tw-max-w-[434px] tw-text-center\">\n @if (icon()) {\n <i class=\"emptyStateIcon fas tw-text-primary\" [class]=\"'fa-' + icon()\" aria-hidden=\"true\"></i>\n }\n\n <h3 class=\"empty-state-title tw-mb-m tw-mt-xl tw-text-black\" [innerHTML]=\"title()\"></h3>\n\n <div class=\"empty-state-content tw-leading-[16px] tw-text-gray-50\">\n <ng-content />\n </div>\n\n <div class=\"tw-flex tw-justify-center tw-gap-m\">\n @if (secondaryButtonLabel()) {\n <div class=\"secondaryButton tw-my-xl\">\n <button lx-button size=\"large\" [showSpinner]=\"loading()\" (click)=\"secondaryButtonClicked.emit($event)\">\n {{ secondaryButtonLabel() }}\n </button>\n </div>\n }\n\n @if (buttonLabel()) {\n <div class=\"actionButton tw-my-xl\">\n <button lx-button size=\"large\" color=\"primary\" [showSpinner]=\"loading()\" (click)=\"buttonClicked.emit($event)\">\n {{ buttonLabel() }}\n </button>\n </div>\n }\n </div>\n\n @if (moreLinkLabel() && moreLink()) {\n <div>\n @if (useRouterLink()) {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [routerLink]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n } @else {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [href]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n }\n </div>\n }\n</div>\n", styles: [":host{display:flex;justify-content:center}:host .emptyStateIcon{font-size:var(--lxFontHeader1Size, 32px)}:host[size=small] .empty-state-title{font-size:var(--lxFontSize, 14px)}:host[size=small] .empty-state-content{font-size:var(--lxFontSmallSize, 12px)}:host[size=medium] .empty-state-title{font-size:var(--lxFontHeader2Size, 24px)}:host[size=medium] .empty-state-content{font-size:var(--lxFontSize, 14px)}i{position:relative}i:after{content:\"\";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);height:6px;width:44px;background-color:#f0f2f5;border-radius:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: ButtonComponent, selector: "button[lx-button]", inputs: ["size", "color", "mode", "pressed", "selected", "square", "circle", "disabled", "icon", "endIcon", "showSpinner"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] }); }
25
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: EmptyStateComponent, isStandalone: true, selector: "lx-empty-state", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: true, transformFunction: null }, icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, buttonLabel: { classPropertyName: "buttonLabel", publicName: "buttonLabel", isSignal: true, isRequired: false, transformFunction: null }, secondaryButtonLabel: { classPropertyName: "secondaryButtonLabel", publicName: "secondaryButtonLabel", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, moreLinkLabel: { classPropertyName: "moreLinkLabel", publicName: "moreLinkLabel", isSignal: true, isRequired: false, transformFunction: null }, moreLink: { classPropertyName: "moreLink", publicName: "moreLink", isSignal: true, isRequired: false, transformFunction: null }, openMoreLinkInNewTab: { classPropertyName: "openMoreLinkInNewTab", publicName: "openMoreLinkInNewTab", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { buttonClicked: "buttonClicked", secondaryButtonClicked: "secondaryButtonClicked", moreLinkClicked: "moreLinkClicked" }, host: { properties: { "attr.size": "this._size" } }, ngImport: i0, template: "<div class=\"tw-max-w-[434px] tw-text-center\">\n @if (icon()) {\n <i class=\"emptyStateIcon fas tw-text-primary\" [class]=\"'fa-' + icon()\" aria-hidden=\"true\"></i>\n }\n\n <h3 class=\"empty-state-title tw-mb-m tw-mt-xl tw-text-black\" [innerHTML]=\"title()\"></h3>\n\n <div class=\"empty-state-content tw-leading-[16px] tw-text-gray-50\">\n <ng-content />\n </div>\n\n <div class=\"tw-flex tw-justify-center tw-gap-m\">\n @if (secondaryButtonLabel()) {\n <div class=\"secondaryButton tw-my-xl\">\n <button lx-button size=\"large\" [showSpinner]=\"loading()\" (click)=\"secondaryButtonClicked.emit($event)\">\n {{ secondaryButtonLabel() }}\n </button>\n </div>\n }\n\n @if (buttonLabel()) {\n <div class=\"actionButton tw-my-xl\">\n <button lx-button size=\"large\" color=\"primary\" [showSpinner]=\"loading()\" (click)=\"buttonClicked.emit($event)\">\n {{ buttonLabel() }}\n </button>\n </div>\n }\n </div>\n\n @if (moreLinkLabel() && moreLink()) {\n <div>\n @if (useRouterLink()) {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [routerLink]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n } @else {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [href]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n }\n </div>\n }\n</div>\n", styles: [":host{display:flex;justify-content:center}:host .emptyStateIcon{font-size:var(--lxFontHeader1Size, 32px)}:host[size=small] .empty-state-title{font-size:var(--lxFontSize, 14px)}:host[size=small] .empty-state-content{font-size:var(--lxFontSmallSize, 12px)}:host[size=medium] .empty-state-title{font-size:var(--lxFontHeader2Size, 24px)}:host[size=medium] .empty-state-content{font-size:var(--lxFontSize, 14px)}i{position:relative}i:after{content:\"\";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);height:6px;width:44px;background-color:#f0f2f5;border-radius:100%}\n"], dependencies: [{ kind: "component", type: ButtonComponent, selector: "button[lx-button]", inputs: ["size", "color", "mode", "pressed", "selected", "square", "circle", "disabled", "icon", "endIcon", "showSpinner"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] }); }
27
26
  }
28
27
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: EmptyStateComponent, decorators: [{
29
28
  type: Component,
30
- args: [{ selector: 'lx-empty-state', standalone: true, imports: [CommonModule, ButtonComponent, RouterLink], template: "<div class=\"tw-max-w-[434px] tw-text-center\">\n @if (icon()) {\n <i class=\"emptyStateIcon fas tw-text-primary\" [class]=\"'fa-' + icon()\" aria-hidden=\"true\"></i>\n }\n\n <h3 class=\"empty-state-title tw-mb-m tw-mt-xl tw-text-black\" [innerHTML]=\"title()\"></h3>\n\n <div class=\"empty-state-content tw-leading-[16px] tw-text-gray-50\">\n <ng-content />\n </div>\n\n <div class=\"tw-flex tw-justify-center tw-gap-m\">\n @if (secondaryButtonLabel()) {\n <div class=\"secondaryButton tw-my-xl\">\n <button lx-button size=\"large\" [showSpinner]=\"loading()\" (click)=\"secondaryButtonClicked.emit($event)\">\n {{ secondaryButtonLabel() }}\n </button>\n </div>\n }\n\n @if (buttonLabel()) {\n <div class=\"actionButton tw-my-xl\">\n <button lx-button size=\"large\" color=\"primary\" [showSpinner]=\"loading()\" (click)=\"buttonClicked.emit($event)\">\n {{ buttonLabel() }}\n </button>\n </div>\n }\n </div>\n\n @if (moreLinkLabel() && moreLink()) {\n <div>\n @if (useRouterLink()) {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [routerLink]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n } @else {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [href]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n }\n </div>\n }\n</div>\n", styles: [":host{display:flex;justify-content:center}:host .emptyStateIcon{font-size:var(--lxFontHeader1Size, 32px)}:host[size=small] .empty-state-title{font-size:var(--lxFontSize, 14px)}:host[size=small] .empty-state-content{font-size:var(--lxFontSmallSize, 12px)}:host[size=medium] .empty-state-title{font-size:var(--lxFontHeader2Size, 24px)}:host[size=medium] .empty-state-content{font-size:var(--lxFontSize, 14px)}i{position:relative}i:after{content:\"\";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);height:6px;width:44px;background-color:#f0f2f5;border-radius:100%}\n"] }]
29
+ args: [{ selector: 'lx-empty-state', standalone: true, imports: [ButtonComponent, RouterLink], template: "<div class=\"tw-max-w-[434px] tw-text-center\">\n @if (icon()) {\n <i class=\"emptyStateIcon fas tw-text-primary\" [class]=\"'fa-' + icon()\" aria-hidden=\"true\"></i>\n }\n\n <h3 class=\"empty-state-title tw-mb-m tw-mt-xl tw-text-black\" [innerHTML]=\"title()\"></h3>\n\n <div class=\"empty-state-content tw-leading-[16px] tw-text-gray-50\">\n <ng-content />\n </div>\n\n <div class=\"tw-flex tw-justify-center tw-gap-m\">\n @if (secondaryButtonLabel()) {\n <div class=\"secondaryButton tw-my-xl\">\n <button lx-button size=\"large\" [showSpinner]=\"loading()\" (click)=\"secondaryButtonClicked.emit($event)\">\n {{ secondaryButtonLabel() }}\n </button>\n </div>\n }\n\n @if (buttonLabel()) {\n <div class=\"actionButton tw-my-xl\">\n <button lx-button size=\"large\" color=\"primary\" [showSpinner]=\"loading()\" (click)=\"buttonClicked.emit($event)\">\n {{ buttonLabel() }}\n </button>\n </div>\n }\n </div>\n\n @if (moreLinkLabel() && moreLink()) {\n <div>\n @if (useRouterLink()) {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [routerLink]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n } @else {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [href]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n }\n </div>\n }\n</div>\n", styles: [":host{display:flex;justify-content:center}:host .emptyStateIcon{font-size:var(--lxFontHeader1Size, 32px)}:host[size=small] .empty-state-title{font-size:var(--lxFontSize, 14px)}:host[size=small] .empty-state-content{font-size:var(--lxFontSmallSize, 12px)}:host[size=medium] .empty-state-title{font-size:var(--lxFontHeader2Size, 24px)}:host[size=medium] .empty-state-content{font-size:var(--lxFontSize, 14px)}i{position:relative}i:after{content:\"\";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);height:6px;width:44px;background-color:#f0f2f5;border-radius:100%}\n"] }]
31
30
  }], propDecorators: { _size: [{
32
31
  type: HostBinding,
33
32
  args: ['attr.size']
@@ -38,4 +37,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
38
37
  }], moreLinkClicked: [{
39
38
  type: Output
40
39
  }] } });
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1wdHktc3RhdGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvY29yZS11aS9jb21wb25lbnRzL2VtcHR5LXN0YXRlL2VtcHR5LXN0YXRlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2NvcmUtdWkvY29tcG9uZW50cy9lbXB0eS1zdGF0ZS9lbXB0eS1zdGF0ZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBVSxRQUFRLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3RHLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7O0FBUzdELE1BQU0sT0FBTyxtQkFBbUI7SUFQaEM7UUFRRSxVQUFLLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBRWpDLFNBQUksR0FBRyxLQUFLLEVBQVUsQ0FBQztRQUN2QixnQkFBVyxHQUFHLEtBQUssRUFBVSxDQUFDO1FBQzlCLHlCQUFvQixHQUFHLEtBQUssRUFBVSxDQUFDO1FBQ3ZDLFlBQU8sR0FBRyxLQUFLLENBQVUsS0FBSyxDQUFDLENBQUM7UUFDaEMsa0JBQWEsR0FBRyxLQUFLLEVBQVUsQ0FBQztRQUNoQyxhQUFRLEdBQUcsS0FBSyxFQUFxQixDQUFDO1FBQ3RDLHlCQUFvQixHQUFHLEtBQUssQ0FBVSxJQUFJLENBQUMsQ0FBQztRQUM1QyxTQUFJLEdBQUcsS0FBSyxDQUFxQixRQUFRLENBQUMsQ0FBQztRQUVwQyxrQkFBYSxHQUFvQixRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBTzdFLGtCQUFhLEdBQUcsSUFBSSxZQUFZLEVBQWMsQ0FBQztRQUMvQywyQkFBc0IsR0FBRyxJQUFJLFlBQVksRUFBYyxDQUFDO1FBQ3hELG9CQUFlLEdBQUcsSUFBSSxZQUFZLEVBQWMsQ0FBQztLQUM1RDtJQVJDLElBQ0ksS0FBSztRQUNQLE9BQU8sSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3JCLENBQUM7OEdBakJVLG1CQUFtQjtrR0FBbkIsbUJBQW1CLGs5Q0NaaEMsNnREQXFEQSw4bkJEN0NZLFlBQVksK0JBQUUsZUFBZSwwTEFBRSxVQUFVOzsyRkFJeEMsbUJBQW1CO2tCQVAvQixTQUFTOytCQUNFLGdCQUFnQixjQUNkLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxlQUFlLEVBQUUsVUFBVSxDQUFDOzhCQW1CaEQsS0FBSztzQkFEUixXQUFXO3VCQUFDLFdBQVc7Z0JBS2QsYUFBYTtzQkFBdEIsTUFBTTtnQkFDRyxzQkFBc0I7c0JBQS9CLE1BQU07Z0JBQ0csZUFBZTtzQkFBeEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSG9zdEJpbmRpbmcsIE91dHB1dCwgU2lnbmFsLCBjb21wdXRlZCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJvdXRlckxpbmsgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi4vYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdseC1lbXB0eS1zdGF0ZScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEJ1dHRvbkNvbXBvbmVudCwgUm91dGVyTGlua10sXG4gIHRlbXBsYXRlVXJsOiAnLi9lbXB0eS1zdGF0ZS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9lbXB0eS1zdGF0ZS5jb21wb25lbnQuc2Nzcydcbn0pXG5leHBvcnQgY2xhc3MgRW1wdHlTdGF0ZUNvbXBvbmVudCB7XG4gIHRpdGxlID0gaW5wdXQucmVxdWlyZWQ8c3RyaW5nPigpO1xuXG4gIGljb24gPSBpbnB1dDxzdHJpbmc+KCk7XG4gIGJ1dHRvbkxhYmVsID0gaW5wdXQ8c3RyaW5nPigpO1xuICBzZWNvbmRhcnlCdXR0b25MYWJlbCA9IGlucHV0PHN0cmluZz4oKTtcbiAgbG9hZGluZyA9IGlucHV0PGJvb2xlYW4+KGZhbHNlKTtcbiAgbW9yZUxpbmtMYWJlbCA9IGlucHV0PHN0cmluZz4oKTtcbiAgbW9yZUxpbmsgPSBpbnB1dDxzdHJpbmcgfCBzdHJpbmdbXT4oKTtcbiAgb3Blbk1vcmVMaW5rSW5OZXdUYWIgPSBpbnB1dDxib29sZWFuPih0cnVlKTtcbiAgc2l6ZSA9IGlucHV0PCdzbWFsbCcgfCAnbWVkaXVtJz4oJ21lZGl1bScpO1xuXG4gIHB1YmxpYyB1c2VSb3V0ZXJMaW5rOiBTaWduYWw8Ym9vbGVhbj4gPSBjb21wdXRlZCgoKSA9PiBBcnJheS5pc0FycmF5KHRoaXMubW9yZUxpbmsoKSkpO1xuXG4gIEBIb3N0QmluZGluZygnYXR0ci5zaXplJylcbiAgZ2V0IF9zaXplKCkge1xuICAgIHJldHVybiB0aGlzLnNpemUoKTtcbiAgfVxuXG4gIEBPdXRwdXQoKSBidXR0b25DbGlja2VkID0gbmV3IEV2ZW50RW1pdHRlcjxNb3VzZUV2ZW50PigpO1xuICBAT3V0cHV0KCkgc2Vjb25kYXJ5QnV0dG9uQ2xpY2tlZCA9IG5ldyBFdmVudEVtaXR0ZXI8TW91c2VFdmVudD4oKTtcbiAgQE91dHB1dCgpIG1vcmVMaW5rQ2xpY2tlZCA9IG5ldyBFdmVudEVtaXR0ZXI8TW91c2VFdmVudD4oKTtcbn1cbiIsIjxkaXYgY2xhc3M9XCJ0dy1tYXgtdy1bNDM0cHhdIHR3LXRleHQtY2VudGVyXCI+XG4gIEBpZiAoaWNvbigpKSB7XG4gICAgPGkgY2xhc3M9XCJlbXB0eVN0YXRlSWNvbiBmYXMgdHctdGV4dC1wcmltYXJ5XCIgW2NsYXNzXT1cIidmYS0nICsgaWNvbigpXCIgYXJpYS1oaWRkZW49XCJ0cnVlXCI+PC9pPlxuICB9XG5cbiAgPGgzIGNsYXNzPVwiZW1wdHktc3RhdGUtdGl0bGUgdHctbWItbSB0dy1tdC14bCB0dy10ZXh0LWJsYWNrXCIgW2lubmVySFRNTF09XCJ0aXRsZSgpXCI+PC9oMz5cblxuICA8ZGl2IGNsYXNzPVwiZW1wdHktc3RhdGUtY29udGVudCB0dy1sZWFkaW5nLVsxNnB4XSB0dy10ZXh0LWdyYXktNTBcIj5cbiAgICA8bmctY29udGVudCAvPlxuICA8L2Rpdj5cblxuICA8ZGl2IGNsYXNzPVwidHctZmxleCB0dy1qdXN0aWZ5LWNlbnRlciB0dy1nYXAtbVwiPlxuICAgIEBpZiAoc2Vjb25kYXJ5QnV0dG9uTGFiZWwoKSkge1xuICAgICAgPGRpdiBjbGFzcz1cInNlY29uZGFyeUJ1dHRvbiB0dy1teS14bFwiPlxuICAgICAgICA8YnV0dG9uIGx4LWJ1dHRvbiBzaXplPVwibGFyZ2VcIiBbc2hvd1NwaW5uZXJdPVwibG9hZGluZygpXCIgKGNsaWNrKT1cInNlY29uZGFyeUJ1dHRvbkNsaWNrZWQuZW1pdCgkZXZlbnQpXCI+XG4gICAgICAgICAge3sgc2Vjb25kYXJ5QnV0dG9uTGFiZWwoKSB9fVxuICAgICAgICA8L2J1dHRvbj5cbiAgICAgIDwvZGl2PlxuICAgIH1cblxuICAgIEBpZiAoYnV0dG9uTGFiZWwoKSkge1xuICAgICAgPGRpdiBjbGFzcz1cImFjdGlvbkJ1dHRvbiB0dy1teS14bFwiPlxuICAgICAgICA8YnV0dG9uIGx4LWJ1dHRvbiBzaXplPVwibGFyZ2VcIiBjb2xvcj1cInByaW1hcnlcIiBbc2hvd1NwaW5uZXJdPVwibG9hZGluZygpXCIgKGNsaWNrKT1cImJ1dHRvbkNsaWNrZWQuZW1pdCgkZXZlbnQpXCI+XG4gICAgICAgICAge3sgYnV0dG9uTGFiZWwoKSB9fVxuICAgICAgICA8L2J1dHRvbj5cbiAgICAgIDwvZGl2PlxuICAgIH1cbiAgPC9kaXY+XG5cbiAgQGlmIChtb3JlTGlua0xhYmVsKCkgJiYgbW9yZUxpbmsoKSkge1xuICAgIDxkaXY+XG4gICAgICBAaWYgKHVzZVJvdXRlckxpbmsoKSkge1xuICAgICAgICA8YVxuICAgICAgICAgIHJlbD1cIm5vb3BlbmVyIG5vcmVmZXJyZXJcIlxuICAgICAgICAgIGNsYXNzPVwidHctdGV4dC1zaXplLW1kIHR3LXRleHQtcHJpbWFyeVwiXG4gICAgICAgICAgW3JvdXRlckxpbmtdPVwibW9yZUxpbmsoKVwiXG4gICAgICAgICAgKGNsaWNrKT1cIm1vcmVMaW5rQ2xpY2tlZC5lbWl0KCRldmVudClcIlxuICAgICAgICAgIFt0YXJnZXRdPVwib3Blbk1vcmVMaW5rSW5OZXdUYWIoKSA/ICdfYmxhbmsnIDogJ19zZWxmJ1wiXG4gICAgICAgICAgPnt7IG1vcmVMaW5rTGFiZWwoKSB9fTwvYVxuICAgICAgICA+XG4gICAgICB9IEBlbHNlIHtcbiAgICAgICAgPGFcbiAgICAgICAgICByZWw9XCJub29wZW5lciBub3JlZmVycmVyXCJcbiAgICAgICAgICBjbGFzcz1cInR3LXRleHQtc2l6ZS1tZCB0dy10ZXh0LXByaW1hcnlcIlxuICAgICAgICAgIFtocmVmXT1cIm1vcmVMaW5rKClcIlxuICAgICAgICAgIChjbGljayk9XCJtb3JlTGlua0NsaWNrZWQuZW1pdCgkZXZlbnQpXCJcbiAgICAgICAgICBbdGFyZ2V0XT1cIm9wZW5Nb3JlTGlua0luTmV3VGFiKCkgPyAnX2JsYW5rJyA6ICdfc2VsZidcIlxuICAgICAgICAgID57eyBtb3JlTGlua0xhYmVsKCkgfX08L2FcbiAgICAgICAgPlxuICAgICAgfVxuICAgIDwvZGl2PlxuICB9XG48L2Rpdj5cbiJdfQ==
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1wdHktc3RhdGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvY29yZS11aS9jb21wb25lbnRzL2VtcHR5LXN0YXRlL2VtcHR5LXN0YXRlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2NvcmUtdWkvY29tcG9uZW50cy9lbXB0eS1zdGF0ZS9lbXB0eS1zdGF0ZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFVLFFBQVEsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdEcsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7QUFTN0QsTUFBTSxPQUFPLG1CQUFtQjtJQVBoQztRQVFFLFVBQUssR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFVLENBQUM7UUFFakMsU0FBSSxHQUFHLEtBQUssRUFBVSxDQUFDO1FBQ3ZCLGdCQUFXLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFDOUIseUJBQW9CLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFDdkMsWUFBTyxHQUFHLEtBQUssQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUNoQyxrQkFBYSxHQUFHLEtBQUssRUFBVSxDQUFDO1FBQ2hDLGFBQVEsR0FBRyxLQUFLLEVBQXFCLENBQUM7UUFDdEMseUJBQW9CLEdBQUcsS0FBSyxDQUFVLElBQUksQ0FBQyxDQUFDO1FBQzVDLFNBQUksR0FBRyxLQUFLLENBQXFCLFFBQVEsQ0FBQyxDQUFDO1FBRXBDLGtCQUFhLEdBQW9CLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFPN0Usa0JBQWEsR0FBRyxJQUFJLFlBQVksRUFBYyxDQUFDO1FBQy9DLDJCQUFzQixHQUFHLElBQUksWUFBWSxFQUFjLENBQUM7UUFDeEQsb0JBQWUsR0FBRyxJQUFJLFlBQVksRUFBYyxDQUFDO0tBQzVEO0lBUkMsSUFDSSxLQUFLO1FBQ1AsT0FBTyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDckIsQ0FBQzs4R0FqQlUsbUJBQW1CO2tHQUFuQixtQkFBbUIsazlDQ1hoQyw2dERBcURBLCtuQkQ5Q1ksZUFBZSwwTEFBRSxVQUFVOzsyRkFJMUIsbUJBQW1CO2tCQVAvQixTQUFTOytCQUNFLGdCQUFnQixjQUNkLElBQUksV0FDUCxDQUFDLGVBQWUsRUFBRSxVQUFVLENBQUM7OEJBbUJsQyxLQUFLO3NCQURSLFdBQVc7dUJBQUMsV0FBVztnQkFLZCxhQUFhO3NCQUF0QixNQUFNO2dCQUNHLHNCQUFzQjtzQkFBL0IsTUFBTTtnQkFDRyxlQUFlO3NCQUF4QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIEhvc3RCaW5kaW5nLCBPdXRwdXQsIFNpZ25hbCwgY29tcHV0ZWQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBSb3V0ZXJMaW5rIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4uL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbHgtZW1wdHktc3RhdGUnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQnV0dG9uQ29tcG9uZW50LCBSb3V0ZXJMaW5rXSxcbiAgdGVtcGxhdGVVcmw6ICcuL2VtcHR5LXN0YXRlLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL2VtcHR5LXN0YXRlLmNvbXBvbmVudC5zY3NzJ1xufSlcbmV4cG9ydCBjbGFzcyBFbXB0eVN0YXRlQ29tcG9uZW50IHtcbiAgdGl0bGUgPSBpbnB1dC5yZXF1aXJlZDxzdHJpbmc+KCk7XG5cbiAgaWNvbiA9IGlucHV0PHN0cmluZz4oKTtcbiAgYnV0dG9uTGFiZWwgPSBpbnB1dDxzdHJpbmc+KCk7XG4gIHNlY29uZGFyeUJ1dHRvbkxhYmVsID0gaW5wdXQ8c3RyaW5nPigpO1xuICBsb2FkaW5nID0gaW5wdXQ8Ym9vbGVhbj4oZmFsc2UpO1xuICBtb3JlTGlua0xhYmVsID0gaW5wdXQ8c3RyaW5nPigpO1xuICBtb3JlTGluayA9IGlucHV0PHN0cmluZyB8IHN0cmluZ1tdPigpO1xuICBvcGVuTW9yZUxpbmtJbk5ld1RhYiA9IGlucHV0PGJvb2xlYW4+KHRydWUpO1xuICBzaXplID0gaW5wdXQ8J3NtYWxsJyB8ICdtZWRpdW0nPignbWVkaXVtJyk7XG5cbiAgcHVibGljIHVzZVJvdXRlckxpbms6IFNpZ25hbDxib29sZWFuPiA9IGNvbXB1dGVkKCgpID0+IEFycmF5LmlzQXJyYXkodGhpcy5tb3JlTGluaygpKSk7XG5cbiAgQEhvc3RCaW5kaW5nKCdhdHRyLnNpemUnKVxuICBnZXQgX3NpemUoKSB7XG4gICAgcmV0dXJuIHRoaXMuc2l6ZSgpO1xuICB9XG5cbiAgQE91dHB1dCgpIGJ1dHRvbkNsaWNrZWQgPSBuZXcgRXZlbnRFbWl0dGVyPE1vdXNlRXZlbnQ+KCk7XG4gIEBPdXRwdXQoKSBzZWNvbmRhcnlCdXR0b25DbGlja2VkID0gbmV3IEV2ZW50RW1pdHRlcjxNb3VzZUV2ZW50PigpO1xuICBAT3V0cHV0KCkgbW9yZUxpbmtDbGlja2VkID0gbmV3IEV2ZW50RW1pdHRlcjxNb3VzZUV2ZW50PigpO1xufVxuIiwiPGRpdiBjbGFzcz1cInR3LW1heC13LVs0MzRweF0gdHctdGV4dC1jZW50ZXJcIj5cbiAgQGlmIChpY29uKCkpIHtcbiAgICA8aSBjbGFzcz1cImVtcHR5U3RhdGVJY29uIGZhcyB0dy10ZXh0LXByaW1hcnlcIiBbY2xhc3NdPVwiJ2ZhLScgKyBpY29uKClcIiBhcmlhLWhpZGRlbj1cInRydWVcIj48L2k+XG4gIH1cblxuICA8aDMgY2xhc3M9XCJlbXB0eS1zdGF0ZS10aXRsZSB0dy1tYi1tIHR3LW10LXhsIHR3LXRleHQtYmxhY2tcIiBbaW5uZXJIVE1MXT1cInRpdGxlKClcIj48L2gzPlxuXG4gIDxkaXYgY2xhc3M9XCJlbXB0eS1zdGF0ZS1jb250ZW50IHR3LWxlYWRpbmctWzE2cHhdIHR3LXRleHQtZ3JheS01MFwiPlxuICAgIDxuZy1jb250ZW50IC8+XG4gIDwvZGl2PlxuXG4gIDxkaXYgY2xhc3M9XCJ0dy1mbGV4IHR3LWp1c3RpZnktY2VudGVyIHR3LWdhcC1tXCI+XG4gICAgQGlmIChzZWNvbmRhcnlCdXR0b25MYWJlbCgpKSB7XG4gICAgICA8ZGl2IGNsYXNzPVwic2Vjb25kYXJ5QnV0dG9uIHR3LW15LXhsXCI+XG4gICAgICAgIDxidXR0b24gbHgtYnV0dG9uIHNpemU9XCJsYXJnZVwiIFtzaG93U3Bpbm5lcl09XCJsb2FkaW5nKClcIiAoY2xpY2spPVwic2Vjb25kYXJ5QnV0dG9uQ2xpY2tlZC5lbWl0KCRldmVudClcIj5cbiAgICAgICAgICB7eyBzZWNvbmRhcnlCdXR0b25MYWJlbCgpIH19XG4gICAgICAgIDwvYnV0dG9uPlxuICAgICAgPC9kaXY+XG4gICAgfVxuXG4gICAgQGlmIChidXR0b25MYWJlbCgpKSB7XG4gICAgICA8ZGl2IGNsYXNzPVwiYWN0aW9uQnV0dG9uIHR3LW15LXhsXCI+XG4gICAgICAgIDxidXR0b24gbHgtYnV0dG9uIHNpemU9XCJsYXJnZVwiIGNvbG9yPVwicHJpbWFyeVwiIFtzaG93U3Bpbm5lcl09XCJsb2FkaW5nKClcIiAoY2xpY2spPVwiYnV0dG9uQ2xpY2tlZC5lbWl0KCRldmVudClcIj5cbiAgICAgICAgICB7eyBidXR0b25MYWJlbCgpIH19XG4gICAgICAgIDwvYnV0dG9uPlxuICAgICAgPC9kaXY+XG4gICAgfVxuICA8L2Rpdj5cblxuICBAaWYgKG1vcmVMaW5rTGFiZWwoKSAmJiBtb3JlTGluaygpKSB7XG4gICAgPGRpdj5cbiAgICAgIEBpZiAodXNlUm91dGVyTGluaygpKSB7XG4gICAgICAgIDxhXG4gICAgICAgICAgcmVsPVwibm9vcGVuZXIgbm9yZWZlcnJlclwiXG4gICAgICAgICAgY2xhc3M9XCJ0dy10ZXh0LXNpemUtbWQgdHctdGV4dC1wcmltYXJ5XCJcbiAgICAgICAgICBbcm91dGVyTGlua109XCJtb3JlTGluaygpXCJcbiAgICAgICAgICAoY2xpY2spPVwibW9yZUxpbmtDbGlja2VkLmVtaXQoJGV2ZW50KVwiXG4gICAgICAgICAgW3RhcmdldF09XCJvcGVuTW9yZUxpbmtJbk5ld1RhYigpID8gJ19ibGFuaycgOiAnX3NlbGYnXCJcbiAgICAgICAgICA+e3sgbW9yZUxpbmtMYWJlbCgpIH19PC9hXG4gICAgICAgID5cbiAgICAgIH0gQGVsc2Uge1xuICAgICAgICA8YVxuICAgICAgICAgIHJlbD1cIm5vb3BlbmVyIG5vcmVmZXJyZXJcIlxuICAgICAgICAgIGNsYXNzPVwidHctdGV4dC1zaXplLW1kIHR3LXRleHQtcHJpbWFyeVwiXG4gICAgICAgICAgW2hyZWZdPVwibW9yZUxpbmsoKVwiXG4gICAgICAgICAgKGNsaWNrKT1cIm1vcmVMaW5rQ2xpY2tlZC5lbWl0KCRldmVudClcIlxuICAgICAgICAgIFt0YXJnZXRdPVwib3Blbk1vcmVMaW5rSW5OZXdUYWIoKSA/ICdfYmxhbmsnIDogJ19zZWxmJ1wiXG4gICAgICAgICAgPnt7IG1vcmVMaW5rTGFiZWwoKSB9fTwvYVxuICAgICAgICA+XG4gICAgICB9XG4gICAgPC9kaXY+XG4gIH1cbjwvZGl2PlxuIl19
@@ -13,24 +13,9 @@ import * as i0 from "@angular/core";
13
13
  import * as i1 from "ngx-infinite-scroll";
14
14
  import * as i2 from "@ngx-translate/core";
15
15
  /**
16
- * Usage:
17
- *
18
- * ```
19
- * <lx-single-select
20
- * #singleSelect
21
- * [selection]="value"
22
- * (selectionChange)="onSelectionChange($event)">
23
- * <span class="selectedOption">
24
- * {{ value.label }}
25
- * </span>
26
- * <lx-option-group-dropdown
27
- * class="dropdownComponent"
28
- * [keyboardSelectAction]="singleSelect.optionsKeyboardSelectAction$"
29
- * [optionGroups]="optionGroups"
30
- * (onItemSelected)="singleSelect.selectOption($event)">
31
- * </lx-option-group-dropdown>
32
- * </lx-single-select>
33
- * ```
16
+ * `OptionGroupDropdownComponent` is a dropdown component that displays a list of options grouped by categories.
17
+ * By itself it is only used to display a list of options, to be used in an input dropdown it can be used in
18
+ * combination with the `SingleSelectComponent` or `MultiSelectComponent`.
34
19
  */
35
20
  export class OptionGroupDropdownComponent extends KeyboardSelectDirective {
36
21
  constructor() {
@@ -135,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
135
120
  type: ViewChild,
136
121
  args: ['selectOrigin', { static: false }]
137
122
  }] } });
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option-group-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, CdkOverlayOrigin, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\nimport { AsyncPipe, NgClass, NgFor, NgIf, NgTemplateOutlet, UpperCasePipe } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { InfiniteScrollModule } from 'ngx-infinite-scroll';\nimport { CounterComponent } from '../../../core-ui/components/counter/counter.component';\nimport { SpinnerComponent } from '../../../core-ui/components/spinner/spinner.component';\nimport { SelectableItemDirective } from '../../directives/selectable-item.directive';\nimport { BasicDropdownItemComponent } from '../basic-dropdown-item/basic-dropdown-item.component';\nimport { BasicDropdownComponent } from '../basic-dropdown/basic-dropdown.component';\nimport { KeyboardSelectDirective } from '../keyboard-select.directive';\n\nexport type OptionGroupOption = { value: string; label: string };\n/**\n * TODO: rename to something unspecific for single selects because multiselects are also supported\n */\nexport type SingleSelectOptionGroup<T = any> = {\n  label: string;\n  options: (OptionGroupOption | T)[];\n};\n\n/**\n * Usage:\n *\n * ```\n * <lx-single-select\n *    #singleSelect\n *    [selection]=\"value\"\n *    (selectionChange)=\"onSelectionChange($event)\">\n *   <span class=\"selectedOption\">\n *     {{ value.label }}\n *   </span>\n *   <lx-option-group-dropdown\n *     class=\"dropdownComponent\"\n *     [keyboardSelectAction]=\"singleSelect.optionsKeyboardSelectAction$\"\n *     [optionGroups]=\"optionGroups\"\n *     (onItemSelected)=\"singleSelect.selectOption($event)\">\n *    </lx-option-group-dropdown>\n * </lx-single-select>\n * ```\n */\n@Component({\n  selector: 'lx-option-group-dropdown',\n  templateUrl: 'option-group-dropdown.component.html',\n  styleUrls: ['option-group-dropdown.component.scss'],\n  providers: [{ provide: KeyboardSelectDirective, useExisting: forwardRef(() => OptionGroupDropdownComponent) }],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgIf,\n    CdkOverlayOrigin,\n    CdkConnectedOverlay,\n    NgClass,\n    NgTemplateOutlet,\n    InfiniteScrollModule,\n    SelectableItemDirective,\n    CounterComponent,\n    NgFor,\n    BasicDropdownItemComponent,\n    SpinnerComponent,\n    AsyncPipe,\n    UpperCasePipe,\n    TranslateModule\n  ]\n})\nexport class OptionGroupDropdownComponent extends KeyboardSelectDirective {\n  /** @internal */\n  readonly NAME = 'OptionGroupDropdownComponent';\n  @Input() optionGroups: SingleSelectOptionGroup[] = [];\n  /**\n   * Usually a stream of the current input value of the parent select.\n   */\n  @Input() newOptionLabel?: string;\n  @Input() highlightTerm?: string;\n  @Input() showCreateNewOption: boolean = false;\n  @Input() labelKey: string = 'label';\n  @Input() loading: boolean = false;\n  @Input() trackByProperty?: string;\n  @Input() showNoResultsIfGroupIsEmpty: boolean = false;\n  @Input() override overlayPositioning: boolean = false;\n\n  @Output() onItemSelected = new EventEmitter<OptionGroupOption | any>();\n  @Output() containerScrolled = new EventEmitter();\n  @Output() createNewOption = new EventEmitter<string>();\n\n  /** @internal */\n  @ContentChild('optionTemplate') optionTemplateRef?: TemplateRef<any>;\n  /**\n   * If you provide a <ng-template #noResultsOptionTemplateRef></ng-template> inside the <lx-option-group-dropdown>\n   * it will be used to display the \"no results\" option instead of the default \"No results\" text.\n   * This way you can easily define different \"No results\" texts for different groups too.\n   * @internal\n   */\n  @ContentChild('noResultsOptionTemplateRef') noResultsOptionTemplateRef?: TemplateRef<any>;\n  /** @internal */\n  @ViewChild('selectOrigin', { static: false }) selectOrigin!: CdkOverlayOrigin;\n  /** @internal */\n  isTopDropdown = false;\n\n  /** @internal */\n  public get isNewItem() {\n    const options =\n      this.optionGroups?.reduce<(OptionGroupOption | any)[]>((flatOptions, optionGroup) => flatOptions.concat(optionGroup.options), []) ??\n      [];\n    return BasicDropdownComponent.isNewItem(options, this.newOptionLabel ?? '', this.labelKey);\n  }\n\n  /** @internal */\n  selectOption(option: OptionGroupOption | any) {\n    this.onItemSelected.emit(option);\n  }\n\n  /** @internal */\n  trackByLabel(index: number, optionGroup: SingleSelectOptionGroup) {\n    return optionGroup.label + index;\n  }\n\n  /** @internal */\n  public onCreateNewOption() {\n    if (!this.loading && this.newOptionLabel) {\n      this.createNewOption.emit(this.newOptionLabel);\n    }\n  }\n\n  /** @internal */\n  trackByValue(_index: number, option: OptionGroupOption | any) {\n    if (this.trackByProperty) {\n      return option[this.trackByProperty];\n    }\n    return option.value;\n  }\n\n  /** @internal */\n  onPositionChange(event: ConnectedOverlayPositionChange) {\n    this.isTopDropdown = event.connectionPair.originY === 'top';\n  }\n}\n","<ng-container *ngIf=\"overlayPositioning; else dropdown\">\n  <div class=\"overlayOrigin\" cdkOverlayOrigin #selectOrigin=\"cdkOverlayOrigin\"></div>\n  <ng-template\n    cdkConnectedOverlay\n    [cdkConnectedOverlayOrigin]=\"selectOrigin\"\n    [cdkConnectedOverlayOpen]=\"!!(cdkOverlayOpen$ | async)\"\n    [cdkConnectedOverlayWidth]=\"selectOrigin.elementRef.nativeElement.offsetWidth\"\n    (positionChange)=\"onPositionChange($event)\"\n  >\n    <div class=\"overlayDropdown\" [ngClass]=\"{ top: isTopDropdown }\">\n      <ng-container [ngTemplateOutlet]=\"dropdown\" />\n    </div>\n  </ng-template>\n</ng-container>\n\n<ng-template #dropdown>\n  <div\n    #keyboardSelectContainer\n    class=\"scrollingPanel lxThinScrollbar\"\n    infinite-scroll\n    [scrollWindow]=\"false\"\n    [fromRoot]=\"true\"\n    (scrolled)=\"containerScrolled.emit()\"\n  >\n    <ul class=\"options\">\n      <li\n        *ngIf=\"showCreateNewOption && newOptionLabel && isNewItem\"\n        lxSelectableItem\n        [scrollInContainer]=\"keyboardSelectContainer\"\n        #item\n        (click)=\"onCreateNewOption()\"\n        (select)=\"onCreateNewOption()\"\n        [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n        class=\"option\"\n      >\n        <span class=\"newEntryContent\">\n          {{ newOptionLabel }}\n        </span>\n        <lx-counter class=\"lx-margin-left\" size=\"small\" [content]=\"'common.new' | translate | uppercase\" />\n      </li>\n      <ng-container *ngFor=\"let optionGroup of optionGroups; let groupIndex = index; trackBy: trackByLabel\">\n        <li>\n          <div class=\"groupLabel\" *ngIf=\"optionGroup.label\">\n            <span>{{ optionGroup.label | uppercase }}</span>\n          </div>\n          <ul>\n            <ng-container *ngIf=\"showNoResultsIfGroupIsEmpty && optionGroup.options.length === 0; else options\">\n              <li class=\"noResult\">\n                <ng-container *ngIf=\"noResultsOptionTemplateRef; else defaultText\">\n                  <ng-container *ngTemplateOutlet=\"noResultsOptionTemplateRef; context: { group: optionGroup, groupIndex: groupIndex }\" />\n                </ng-container>\n                <ng-template #defaultText>\n                  <span>{{ NAME + '.noResults' | translate }}</span>\n                </ng-template>\n              </li>\n            </ng-container>\n            <ng-template #options>\n              <li\n                *ngFor=\"let option of optionGroup.options; let index = index; trackBy: trackByValue\"\n                lxSelectableItem\n                [scrollInContainer]=\"keyboardSelectContainer\"\n                #item\n                class=\"option\"\n                (click)=\"selectOption(option)\"\n                (select)=\"selectOption(option)\"\n                [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n              >\n                <ng-container *ngIf=\"optionTemplateRef; else basicDropdownOption\">\n                  <ng-container\n                    *ngTemplateOutlet=\"optionTemplateRef; context: { $implicit: option, index: index, groupIndex: groupIndex }\"\n                  />\n                </ng-container>\n                <ng-template #basicDropdownOption>\n                  <lx-basic-dropdown-item [label]=\"option.label\" labelFontWeight=\"normal\" [highlightTerm]=\"highlightTerm\" />\n                </ng-template>\n              </li>\n            </ng-template>\n          </ul>\n        </li>\n      </ng-container>\n      <lx-spinner *ngIf=\"loading\" [fadeBackground]=\"true\" />\n    </ul>\n  </div>\n</ng-template>\n"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option-group-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, CdkOverlayOrigin, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\nimport { AsyncPipe, NgClass, NgFor, NgIf, NgTemplateOutlet, UpperCasePipe } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { InfiniteScrollModule } from 'ngx-infinite-scroll';\nimport { CounterComponent } from '../../../core-ui/components/counter/counter.component';\nimport { SpinnerComponent } from '../../../core-ui/components/spinner/spinner.component';\nimport { SelectableItemDirective } from '../../directives/selectable-item.directive';\nimport { BasicDropdownItemComponent } from '../basic-dropdown-item/basic-dropdown-item.component';\nimport { BasicDropdownComponent } from '../basic-dropdown/basic-dropdown.component';\nimport { KeyboardSelectDirective } from '../keyboard-select.directive';\n\nexport type OptionGroupOption = { value: string; label: string };\n/**\n * TODO: rename to something unspecific for single selects because multiselects are also supported\n */\nexport type SingleSelectOptionGroup<T = any> = {\n  label: string;\n  options: (OptionGroupOption | T)[];\n};\n\n/**\n * `OptionGroupDropdownComponent` is a dropdown component that displays a list of options grouped by categories.\n * By itself it is only used to display a list of options, to be used in an input dropdown it can be used in\n * combination with the `SingleSelectComponent` or `MultiSelectComponent`.\n */\n@Component({\n  selector: 'lx-option-group-dropdown',\n  templateUrl: 'option-group-dropdown.component.html',\n  styleUrls: ['option-group-dropdown.component.scss'],\n  providers: [{ provide: KeyboardSelectDirective, useExisting: forwardRef(() => OptionGroupDropdownComponent) }],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgIf,\n    CdkOverlayOrigin,\n    CdkConnectedOverlay,\n    NgClass,\n    NgTemplateOutlet,\n    InfiniteScrollModule,\n    SelectableItemDirective,\n    CounterComponent,\n    NgFor,\n    BasicDropdownItemComponent,\n    SpinnerComponent,\n    AsyncPipe,\n    UpperCasePipe,\n    TranslateModule\n  ]\n})\nexport class OptionGroupDropdownComponent extends KeyboardSelectDirective {\n  /** @internal */\n  readonly NAME = 'OptionGroupDropdownComponent';\n  @Input() optionGroups: SingleSelectOptionGroup[] = [];\n  /**\n   * Usually a stream of the current input value of the parent select.\n   */\n  @Input() newOptionLabel?: string;\n  @Input() highlightTerm?: string;\n  @Input() showCreateNewOption: boolean = false;\n  @Input() labelKey: string = 'label';\n  @Input() loading: boolean = false;\n  @Input() trackByProperty?: string;\n  @Input() showNoResultsIfGroupIsEmpty: boolean = false;\n  @Input() override overlayPositioning: boolean = false;\n\n  @Output() onItemSelected = new EventEmitter<OptionGroupOption | any>();\n  @Output() containerScrolled = new EventEmitter();\n  @Output() createNewOption = new EventEmitter<string>();\n\n  /** @internal */\n  @ContentChild('optionTemplate') optionTemplateRef?: TemplateRef<any>;\n  /**\n   * If you provide a <ng-template #noResultsOptionTemplateRef></ng-template> inside the <lx-option-group-dropdown>\n   * it will be used to display the \"no results\" option instead of the default \"No results\" text.\n   * This way you can easily define different \"No results\" texts for different groups too.\n   * @internal\n   */\n  @ContentChild('noResultsOptionTemplateRef') noResultsOptionTemplateRef?: TemplateRef<any>;\n  /** @internal */\n  @ViewChild('selectOrigin', { static: false }) selectOrigin!: CdkOverlayOrigin;\n  /** @internal */\n  isTopDropdown = false;\n\n  /** @internal */\n  public get isNewItem() {\n    const options =\n      this.optionGroups?.reduce<(OptionGroupOption | any)[]>((flatOptions, optionGroup) => flatOptions.concat(optionGroup.options), []) ??\n      [];\n    return BasicDropdownComponent.isNewItem(options, this.newOptionLabel ?? '', this.labelKey);\n  }\n\n  /** @internal */\n  selectOption(option: OptionGroupOption | any) {\n    this.onItemSelected.emit(option);\n  }\n\n  /** @internal */\n  trackByLabel(index: number, optionGroup: SingleSelectOptionGroup) {\n    return optionGroup.label + index;\n  }\n\n  /** @internal */\n  public onCreateNewOption() {\n    if (!this.loading && this.newOptionLabel) {\n      this.createNewOption.emit(this.newOptionLabel);\n    }\n  }\n\n  /** @internal */\n  trackByValue(_index: number, option: OptionGroupOption | any) {\n    if (this.trackByProperty) {\n      return option[this.trackByProperty];\n    }\n    return option.value;\n  }\n\n  /** @internal */\n  onPositionChange(event: ConnectedOverlayPositionChange) {\n    this.isTopDropdown = event.connectionPair.originY === 'top';\n  }\n}\n","<ng-container *ngIf=\"overlayPositioning; else dropdown\">\n  <div class=\"overlayOrigin\" cdkOverlayOrigin #selectOrigin=\"cdkOverlayOrigin\"></div>\n  <ng-template\n    cdkConnectedOverlay\n    [cdkConnectedOverlayOrigin]=\"selectOrigin\"\n    [cdkConnectedOverlayOpen]=\"!!(cdkOverlayOpen$ | async)\"\n    [cdkConnectedOverlayWidth]=\"selectOrigin.elementRef.nativeElement.offsetWidth\"\n    (positionChange)=\"onPositionChange($event)\"\n  >\n    <div class=\"overlayDropdown\" [ngClass]=\"{ top: isTopDropdown }\">\n      <ng-container [ngTemplateOutlet]=\"dropdown\" />\n    </div>\n  </ng-template>\n</ng-container>\n\n<ng-template #dropdown>\n  <div\n    #keyboardSelectContainer\n    class=\"scrollingPanel lxThinScrollbar\"\n    infinite-scroll\n    [scrollWindow]=\"false\"\n    [fromRoot]=\"true\"\n    (scrolled)=\"containerScrolled.emit()\"\n  >\n    <ul class=\"options\">\n      <li\n        *ngIf=\"showCreateNewOption && newOptionLabel && isNewItem\"\n        lxSelectableItem\n        [scrollInContainer]=\"keyboardSelectContainer\"\n        #item\n        (click)=\"onCreateNewOption()\"\n        (select)=\"onCreateNewOption()\"\n        [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n        class=\"option\"\n      >\n        <span class=\"newEntryContent\">\n          {{ newOptionLabel }}\n        </span>\n        <lx-counter class=\"lx-margin-left\" size=\"small\" [content]=\"'common.new' | translate | uppercase\" />\n      </li>\n      <ng-container *ngFor=\"let optionGroup of optionGroups; let groupIndex = index; trackBy: trackByLabel\">\n        <li>\n          <div class=\"groupLabel\" *ngIf=\"optionGroup.label\">\n            <span>{{ optionGroup.label | uppercase }}</span>\n          </div>\n          <ul>\n            <ng-container *ngIf=\"showNoResultsIfGroupIsEmpty && optionGroup.options.length === 0; else options\">\n              <li class=\"noResult\">\n                <ng-container *ngIf=\"noResultsOptionTemplateRef; else defaultText\">\n                  <ng-container *ngTemplateOutlet=\"noResultsOptionTemplateRef; context: { group: optionGroup, groupIndex: groupIndex }\" />\n                </ng-container>\n                <ng-template #defaultText>\n                  <span>{{ NAME + '.noResults' | translate }}</span>\n                </ng-template>\n              </li>\n            </ng-container>\n            <ng-template #options>\n              <li\n                *ngFor=\"let option of optionGroup.options; let index = index; trackBy: trackByValue\"\n                lxSelectableItem\n                [scrollInContainer]=\"keyboardSelectContainer\"\n                #item\n                class=\"option\"\n                (click)=\"selectOption(option)\"\n                (select)=\"selectOption(option)\"\n                [class.highlighted]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n              >\n                <ng-container *ngIf=\"optionTemplateRef; else basicDropdownOption\">\n                  <ng-container\n                    *ngTemplateOutlet=\"optionTemplateRef; context: { $implicit: option, index: index, groupIndex: groupIndex }\"\n                  />\n                </ng-container>\n                <ng-template #basicDropdownOption>\n                  <lx-basic-dropdown-item [label]=\"option.label\" labelFontWeight=\"normal\" [highlightTerm]=\"highlightTerm\" />\n                </ng-template>\n              </li>\n            </ng-template>\n          </ul>\n        </li>\n      </ng-container>\n      <lx-spinner *ngIf=\"loading\" [fadeBackground]=\"true\" />\n    </ul>\n  </div>\n</ng-template>\n"]}
@@ -3,7 +3,7 @@ import { InjectionToken, Input, Component, signal, ChangeDetectionStrategy, Host
3
3
  import * as i1 from '@ngx-translate/core';
4
4
  import { TranslatePipe, TranslateModule } from '@ngx-translate/core';
5
5
  import * as i2 from '@angular/common';
6
- import { NgTemplateOutlet, NgClass, NgIf, AsyncPipe, CommonModule, NgFor, NgStyle, UpperCasePipe, NgSwitch, NgSwitchCase, DecimalPipe, formatDate } from '@angular/common';
6
+ import { NgTemplateOutlet, NgClass, AsyncPipe, NgFor, NgStyle, CommonModule, NgIf, UpperCasePipe, NgSwitch, NgSwitchCase, DecimalPipe, formatDate } from '@angular/common';
7
7
  import { toSignal, toObservable, takeUntilDestroyed } from '@angular/core/rxjs-interop';
8
8
  import { IconComponent as IconComponent$1 } from '@ui5/webcomponents-ngx/main/icon';
9
9
  import * as i5 from 'rxjs';
@@ -970,7 +970,7 @@ class EllipsisComponent {
970
970
  return offsetWidth < scrollWidth;
971
971
  }
972
972
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: EllipsisComponent, deps: [{ token: LX_ELLIPSIS_DEBOUNCE_ON_RESIZE }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: ResizeObserverService }, { token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
973
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: EllipsisComponent, isStandalone: true, selector: "lx-ellipsis", inputs: { content: "content", escapeHtmlInContent: "escapeHtmlInContent" }, viewQueries: [{ propertyName: "contentSpanEl", first: true, predicate: ["contentEl"], descendants: true }, { propertyName: "showMoreButtonEl", first: true, predicate: ["showMoreButton"], descendants: true, read: ElementRef }], ngImport: i0, template: "<span\n #contentEl\n [class.showMore]=\"isShowingMore$ | async\"\n class=\"content truncate lx-margin-right\"\n [innerHtml]=\"sanitizedContent$ | async\"\n></span>\n<button *ngIf=\"showButton$ | async\" (click)=\"onShowMoreToggle()\" lx-button #showMoreButton size=\"auto\" mode=\"link\" color=\"primary\">\n {{ showMoreButtonLabel$ | async }}\n</button>\n", styles: [":host{display:block;white-space:pre-line;overflow-wrap:break-word}.content{display:inline-block;word-break:break-word}.truncate:not(.showMore){width:calc(100% - 140px);white-space:nowrap;overflow-wrap:normal;overflow:hidden;text-overflow:ellipsis}.content.showMore+button{margin-top:4px;display:block}button{white-space:nowrap;vertical-align:top}\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"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
973
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: EllipsisComponent, isStandalone: true, selector: "lx-ellipsis", inputs: { content: "content", escapeHtmlInContent: "escapeHtmlInContent" }, viewQueries: [{ propertyName: "contentSpanEl", first: true, predicate: ["contentEl"], descendants: true }, { propertyName: "showMoreButtonEl", first: true, predicate: ["showMoreButton"], descendants: true, read: ElementRef }], ngImport: i0, template: "<span\n #contentEl\n [class.showMore]=\"isShowingMore$ | async\"\n class=\"content truncate lx-margin-right\"\n [innerHtml]=\"sanitizedContent$ | async\"\n></span>\n@let showButton = showButton$ | async;\n@if (showButton) {\n <button (click)=\"onShowMoreToggle()\" lx-button #showmorebutton size=\"auto\" mode=\"link\" color=\"primary\">\n {{ showMoreButtonLabel$ | async }}\n </button>\n}\n", styles: [":host{display:block;white-space:pre-line;overflow-wrap:break-word}.content{display:inline-block;word-break:break-word}.truncate:not(.showMore){width:calc(100% - 140px);white-space:nowrap;overflow-wrap:normal;overflow:hidden;text-overflow:ellipsis}.content.showMore+button{margin-top:4px;display:block}button{white-space:nowrap;vertical-align:top}\n"], dependencies: [{ kind: "component", type: ButtonComponent, selector: "button[lx-button]", inputs: ["size", "color", "mode", "pressed", "selected", "square", "circle", "disabled", "icon", "endIcon", "showSpinner"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
974
974
  }
975
975
  __decorate([
976
976
  Observe('contentSpanEl')
@@ -983,7 +983,7 @@ __decorate([
983
983
  ], EllipsisComponent.prototype, "content$", void 0);
984
984
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: EllipsisComponent, decorators: [{
985
985
  type: Component,
986
- args: [{ selector: 'lx-ellipsis', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgIf, ButtonComponent, AsyncPipe], template: "<span\n #contentEl\n [class.showMore]=\"isShowingMore$ | async\"\n class=\"content truncate lx-margin-right\"\n [innerHtml]=\"sanitizedContent$ | async\"\n></span>\n<button *ngIf=\"showButton$ | async\" (click)=\"onShowMoreToggle()\" lx-button #showMoreButton size=\"auto\" mode=\"link\" color=\"primary\">\n {{ showMoreButtonLabel$ | async }}\n</button>\n", styles: [":host{display:block;white-space:pre-line;overflow-wrap:break-word}.content{display:inline-block;word-break:break-word}.truncate:not(.showMore){width:calc(100% - 140px);white-space:nowrap;overflow-wrap:normal;overflow:hidden;text-overflow:ellipsis}.content.showMore+button{margin-top:4px;display:block}button{white-space:nowrap;vertical-align:top}\n"] }]
986
+ args: [{ selector: 'lx-ellipsis', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ButtonComponent, AsyncPipe], template: "<span\n #contentEl\n [class.showMore]=\"isShowingMore$ | async\"\n class=\"content truncate lx-margin-right\"\n [innerHtml]=\"sanitizedContent$ | async\"\n></span>\n@let showButton = showButton$ | async;\n@if (showButton) {\n <button (click)=\"onShowMoreToggle()\" lx-button #showmorebutton size=\"auto\" mode=\"link\" color=\"primary\">\n {{ showMoreButtonLabel$ | async }}\n </button>\n}\n", styles: [":host{display:block;white-space:pre-line;overflow-wrap:break-word}.content{display:inline-block;word-break:break-word}.truncate:not(.showMore){width:calc(100% - 140px);white-space:nowrap;overflow-wrap:normal;overflow:hidden;text-overflow:ellipsis}.content.showMore+button{margin-top:4px;display:block}button{white-space:nowrap;vertical-align:top}\n"] }]
987
987
  }], ctorParameters: () => [{ type: undefined, decorators: [{
988
988
  type: Inject,
989
989
  args: [LX_ELLIPSIS_DEBOUNCE_ON_RESIZE]
@@ -1019,11 +1019,11 @@ class EmptyStateComponent {
1019
1019
  return this.size();
1020
1020
  }
1021
1021
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: EmptyStateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
1022
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: EmptyStateComponent, isStandalone: true, selector: "lx-empty-state", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: true, transformFunction: null }, icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, buttonLabel: { classPropertyName: "buttonLabel", publicName: "buttonLabel", isSignal: true, isRequired: false, transformFunction: null }, secondaryButtonLabel: { classPropertyName: "secondaryButtonLabel", publicName: "secondaryButtonLabel", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, moreLinkLabel: { classPropertyName: "moreLinkLabel", publicName: "moreLinkLabel", isSignal: true, isRequired: false, transformFunction: null }, moreLink: { classPropertyName: "moreLink", publicName: "moreLink", isSignal: true, isRequired: false, transformFunction: null }, openMoreLinkInNewTab: { classPropertyName: "openMoreLinkInNewTab", publicName: "openMoreLinkInNewTab", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { buttonClicked: "buttonClicked", secondaryButtonClicked: "secondaryButtonClicked", moreLinkClicked: "moreLinkClicked" }, host: { properties: { "attr.size": "this._size" } }, ngImport: i0, template: "<div class=\"tw-max-w-[434px] tw-text-center\">\n @if (icon()) {\n <i class=\"emptyStateIcon fas tw-text-primary\" [class]=\"'fa-' + icon()\" aria-hidden=\"true\"></i>\n }\n\n <h3 class=\"empty-state-title tw-mb-m tw-mt-xl tw-text-black\" [innerHTML]=\"title()\"></h3>\n\n <div class=\"empty-state-content tw-leading-[16px] tw-text-gray-50\">\n <ng-content />\n </div>\n\n <div class=\"tw-flex tw-justify-center tw-gap-m\">\n @if (secondaryButtonLabel()) {\n <div class=\"secondaryButton tw-my-xl\">\n <button lx-button size=\"large\" [showSpinner]=\"loading()\" (click)=\"secondaryButtonClicked.emit($event)\">\n {{ secondaryButtonLabel() }}\n </button>\n </div>\n }\n\n @if (buttonLabel()) {\n <div class=\"actionButton tw-my-xl\">\n <button lx-button size=\"large\" color=\"primary\" [showSpinner]=\"loading()\" (click)=\"buttonClicked.emit($event)\">\n {{ buttonLabel() }}\n </button>\n </div>\n }\n </div>\n\n @if (moreLinkLabel() && moreLink()) {\n <div>\n @if (useRouterLink()) {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [routerLink]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n } @else {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [href]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n }\n </div>\n }\n</div>\n", styles: [":host{display:flex;justify-content:center}:host .emptyStateIcon{font-size:var(--lxFontHeader1Size, 32px)}:host[size=small] .empty-state-title{font-size:var(--lxFontSize, 14px)}:host[size=small] .empty-state-content{font-size:var(--lxFontSmallSize, 12px)}:host[size=medium] .empty-state-title{font-size:var(--lxFontHeader2Size, 24px)}:host[size=medium] .empty-state-content{font-size:var(--lxFontSize, 14px)}i{position:relative}i:after{content:\"\";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);height:6px;width:44px;background-color:#f0f2f5;border-radius:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: ButtonComponent, selector: "button[lx-button]", inputs: ["size", "color", "mode", "pressed", "selected", "square", "circle", "disabled", "icon", "endIcon", "showSpinner"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] }); }
1022
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: EmptyStateComponent, isStandalone: true, selector: "lx-empty-state", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: true, transformFunction: null }, icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, buttonLabel: { classPropertyName: "buttonLabel", publicName: "buttonLabel", isSignal: true, isRequired: false, transformFunction: null }, secondaryButtonLabel: { classPropertyName: "secondaryButtonLabel", publicName: "secondaryButtonLabel", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, moreLinkLabel: { classPropertyName: "moreLinkLabel", publicName: "moreLinkLabel", isSignal: true, isRequired: false, transformFunction: null }, moreLink: { classPropertyName: "moreLink", publicName: "moreLink", isSignal: true, isRequired: false, transformFunction: null }, openMoreLinkInNewTab: { classPropertyName: "openMoreLinkInNewTab", publicName: "openMoreLinkInNewTab", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { buttonClicked: "buttonClicked", secondaryButtonClicked: "secondaryButtonClicked", moreLinkClicked: "moreLinkClicked" }, host: { properties: { "attr.size": "this._size" } }, ngImport: i0, template: "<div class=\"tw-max-w-[434px] tw-text-center\">\n @if (icon()) {\n <i class=\"emptyStateIcon fas tw-text-primary\" [class]=\"'fa-' + icon()\" aria-hidden=\"true\"></i>\n }\n\n <h3 class=\"empty-state-title tw-mb-m tw-mt-xl tw-text-black\" [innerHTML]=\"title()\"></h3>\n\n <div class=\"empty-state-content tw-leading-[16px] tw-text-gray-50\">\n <ng-content />\n </div>\n\n <div class=\"tw-flex tw-justify-center tw-gap-m\">\n @if (secondaryButtonLabel()) {\n <div class=\"secondaryButton tw-my-xl\">\n <button lx-button size=\"large\" [showSpinner]=\"loading()\" (click)=\"secondaryButtonClicked.emit($event)\">\n {{ secondaryButtonLabel() }}\n </button>\n </div>\n }\n\n @if (buttonLabel()) {\n <div class=\"actionButton tw-my-xl\">\n <button lx-button size=\"large\" color=\"primary\" [showSpinner]=\"loading()\" (click)=\"buttonClicked.emit($event)\">\n {{ buttonLabel() }}\n </button>\n </div>\n }\n </div>\n\n @if (moreLinkLabel() && moreLink()) {\n <div>\n @if (useRouterLink()) {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [routerLink]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n } @else {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [href]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n }\n </div>\n }\n</div>\n", styles: [":host{display:flex;justify-content:center}:host .emptyStateIcon{font-size:var(--lxFontHeader1Size, 32px)}:host[size=small] .empty-state-title{font-size:var(--lxFontSize, 14px)}:host[size=small] .empty-state-content{font-size:var(--lxFontSmallSize, 12px)}:host[size=medium] .empty-state-title{font-size:var(--lxFontHeader2Size, 24px)}:host[size=medium] .empty-state-content{font-size:var(--lxFontSize, 14px)}i{position:relative}i:after{content:\"\";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);height:6px;width:44px;background-color:#f0f2f5;border-radius:100%}\n"], dependencies: [{ kind: "component", type: ButtonComponent, selector: "button[lx-button]", inputs: ["size", "color", "mode", "pressed", "selected", "square", "circle", "disabled", "icon", "endIcon", "showSpinner"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] }); }
1023
1023
  }
1024
1024
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: EmptyStateComponent, decorators: [{
1025
1025
  type: Component,
1026
- args: [{ selector: 'lx-empty-state', standalone: true, imports: [CommonModule, ButtonComponent, RouterLink], template: "<div class=\"tw-max-w-[434px] tw-text-center\">\n @if (icon()) {\n <i class=\"emptyStateIcon fas tw-text-primary\" [class]=\"'fa-' + icon()\" aria-hidden=\"true\"></i>\n }\n\n <h3 class=\"empty-state-title tw-mb-m tw-mt-xl tw-text-black\" [innerHTML]=\"title()\"></h3>\n\n <div class=\"empty-state-content tw-leading-[16px] tw-text-gray-50\">\n <ng-content />\n </div>\n\n <div class=\"tw-flex tw-justify-center tw-gap-m\">\n @if (secondaryButtonLabel()) {\n <div class=\"secondaryButton tw-my-xl\">\n <button lx-button size=\"large\" [showSpinner]=\"loading()\" (click)=\"secondaryButtonClicked.emit($event)\">\n {{ secondaryButtonLabel() }}\n </button>\n </div>\n }\n\n @if (buttonLabel()) {\n <div class=\"actionButton tw-my-xl\">\n <button lx-button size=\"large\" color=\"primary\" [showSpinner]=\"loading()\" (click)=\"buttonClicked.emit($event)\">\n {{ buttonLabel() }}\n </button>\n </div>\n }\n </div>\n\n @if (moreLinkLabel() && moreLink()) {\n <div>\n @if (useRouterLink()) {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [routerLink]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n } @else {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [href]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n }\n </div>\n }\n</div>\n", styles: [":host{display:flex;justify-content:center}:host .emptyStateIcon{font-size:var(--lxFontHeader1Size, 32px)}:host[size=small] .empty-state-title{font-size:var(--lxFontSize, 14px)}:host[size=small] .empty-state-content{font-size:var(--lxFontSmallSize, 12px)}:host[size=medium] .empty-state-title{font-size:var(--lxFontHeader2Size, 24px)}:host[size=medium] .empty-state-content{font-size:var(--lxFontSize, 14px)}i{position:relative}i:after{content:\"\";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);height:6px;width:44px;background-color:#f0f2f5;border-radius:100%}\n"] }]
1026
+ args: [{ selector: 'lx-empty-state', standalone: true, imports: [ButtonComponent, RouterLink], template: "<div class=\"tw-max-w-[434px] tw-text-center\">\n @if (icon()) {\n <i class=\"emptyStateIcon fas tw-text-primary\" [class]=\"'fa-' + icon()\" aria-hidden=\"true\"></i>\n }\n\n <h3 class=\"empty-state-title tw-mb-m tw-mt-xl tw-text-black\" [innerHTML]=\"title()\"></h3>\n\n <div class=\"empty-state-content tw-leading-[16px] tw-text-gray-50\">\n <ng-content />\n </div>\n\n <div class=\"tw-flex tw-justify-center tw-gap-m\">\n @if (secondaryButtonLabel()) {\n <div class=\"secondaryButton tw-my-xl\">\n <button lx-button size=\"large\" [showSpinner]=\"loading()\" (click)=\"secondaryButtonClicked.emit($event)\">\n {{ secondaryButtonLabel() }}\n </button>\n </div>\n }\n\n @if (buttonLabel()) {\n <div class=\"actionButton tw-my-xl\">\n <button lx-button size=\"large\" color=\"primary\" [showSpinner]=\"loading()\" (click)=\"buttonClicked.emit($event)\">\n {{ buttonLabel() }}\n </button>\n </div>\n }\n </div>\n\n @if (moreLinkLabel() && moreLink()) {\n <div>\n @if (useRouterLink()) {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [routerLink]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n } @else {\n <a\n rel=\"noopener noreferrer\"\n class=\"tw-text-size-md tw-text-primary\"\n [href]=\"moreLink()\"\n (click)=\"moreLinkClicked.emit($event)\"\n [target]=\"openMoreLinkInNewTab() ? '_blank' : '_self'\"\n >{{ moreLinkLabel() }}</a\n >\n }\n </div>\n }\n</div>\n", styles: [":host{display:flex;justify-content:center}:host .emptyStateIcon{font-size:var(--lxFontHeader1Size, 32px)}:host[size=small] .empty-state-title{font-size:var(--lxFontSize, 14px)}:host[size=small] .empty-state-content{font-size:var(--lxFontSmallSize, 12px)}:host[size=medium] .empty-state-title{font-size:var(--lxFontHeader2Size, 24px)}:host[size=medium] .empty-state-content{font-size:var(--lxFontSize, 14px)}i{position:relative}i:after{content:\"\";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);height:6px;width:44px;background-color:#f0f2f5;border-radius:100%}\n"] }]
1027
1027
  }], propDecorators: { _size: [{
1028
1028
  type: HostBinding,
1029
1029
  args: ['attr.size']
@@ -6987,24 +6987,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
6987
6987
  }] } });
6988
6988
 
6989
6989
  /**
6990
- * Usage:
6991
- *
6992
- * ```
6993
- * <lx-single-select
6994
- * #singleSelect
6995
- * [selection]="value"
6996
- * (selectionChange)="onSelectionChange($event)">
6997
- * <span class="selectedOption">
6998
- * {{ value.label }}
6999
- * </span>
7000
- * <lx-option-group-dropdown
7001
- * class="dropdownComponent"
7002
- * [keyboardSelectAction]="singleSelect.optionsKeyboardSelectAction$"
7003
- * [optionGroups]="optionGroups"
7004
- * (onItemSelected)="singleSelect.selectOption($event)">
7005
- * </lx-option-group-dropdown>
7006
- * </lx-single-select>
7007
- * ```
6990
+ * `OptionGroupDropdownComponent` is a dropdown component that displays a list of options grouped by categories.
6991
+ * By itself it is only used to display a list of options, to be used in an input dropdown it can be used in
6992
+ * combination with the `SingleSelectComponent` or `MultiSelectComponent`.
7008
6993
  */
7009
6994
  class OptionGroupDropdownComponent extends KeyboardSelectDirective {
7010
6995
  constructor() {