@leanix/components 0.4.365 → 0.4.367

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,7 +1,8 @@
1
1
  import { AsyncPipe } from '@angular/common';
2
- import { Component, ContentChildren, HostBinding, HostListener, Input } from '@angular/core';
3
- import { BehaviorSubject, Subject, combineLatest, fromEvent, merge } from 'rxjs';
4
- import { delay, map, startWith, switchMap, takeUntil } from 'rxjs/operators';
2
+ import { Component, ContentChildren, DestroyRef, HostBinding, HostListener, inject, Input } from '@angular/core';
3
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
+ import { BehaviorSubject, combineLatest, fromEvent, merge, Subject } from 'rxjs';
5
+ import { debounceTime, delay, map, startWith, switchMap } from 'rxjs/operators';
5
6
  import { AutocloseDirective } from '../../../core-ui/directives/autoclose.directive';
6
7
  import { executeOnNextTick } from '../../../shared/misc-helpers';
7
8
  import { OptionComponent } from '../option/option.component';
@@ -14,6 +15,7 @@ export class OptionsSubDropdownComponent {
14
15
  this.mouseInside$ = new BehaviorSubject(false);
15
16
  this.destroyed$ = new Subject();
16
17
  this.maxHeight$ = new BehaviorSubject('none');
18
+ this.destroyRef = inject(DestroyRef);
17
19
  }
18
20
  mouseenter() {
19
21
  this.mouseInside$.next(true);
@@ -30,7 +32,7 @@ export class OptionsSubDropdownComponent {
30
32
  this.trigger.hasSubdropdown = true;
31
33
  });
32
34
  merge(this.showByKeyboard(), this.showByMouse())
33
- .pipe(takeUntil(this.destroyed$))
35
+ .pipe(debounceTime(150), takeUntilDestroyed(this.destroyRef))
34
36
  .subscribe((show) => {
35
37
  this.hidden = !show;
36
38
  this.changeDetection.markForCheck();
@@ -89,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
89
91
  type: HostListener,
90
92
  args: ['mouseleave']
91
93
  }] } });
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"options-sub-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAGL,SAAS,EACT,eAAe,EAEf,WAAW,EACX,YAAY,EACZ,KAAK,EAGN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AACjF,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC7E,OAAO,EAAE,kBAAkB,EAAE,MAAM,iDAAiD,CAAC;AACrF,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;;AAS7D,MAAM,OAAO,2BAA2B;IAatC,YAAoB,eAAkC;QAAlC,oBAAe,GAAf,eAAe,CAAmB;QAX7C,UAAK,GAAqB,OAAO,CAAC;QAI3C,WAAM,GAAG,IAAI,CAAC;QAEN,iBAAY,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAElD,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;QACjC,eAAU,GAAG,IAAI,eAAe,CAAS,MAAM,CAAC,CAAC;IAED,CAAC;IAG1D,UAAU;QACR,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAGD,UAAU;QACR,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,eAAe;QACb,yDAAyD;QACzD,iBAAiB,CAAC,GAAG,EAAE;YACrB,IAAI,CAAC,OAAO,CAAC,cAAc,GAAG,IAAI,CAAC;QACrC,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC;aAC7C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aAChC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YAClB,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC;YACpB,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;YACpC,IAAI,IAAI,EAAE,CAAC;gBACT,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;YAChD,CAAC;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,eAAe,CAAC,UAAsB;QAC5C,MAAM,YAAY,GAAG,CAAC,CAAC;QACvB,MAAM,iBAAiB,GAAG,UAAU,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,GAAG,CAAC;QAC/E,MAAM,YAAY,GAAG,MAAM,CAAC,WAAW,CAAC;QACxC,MAAM,SAAS,GAAG,GAAG,YAAY,GAAG,iBAAiB,GAAG,YAAY,IAAI,CAAC;QACzE,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,KAAK,SAAS,EAAE,CAAC;YAC7C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAEO,cAAc;QACpB,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAC7C,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EACvB,GAAG,CAAC,CAAC,OAAmC,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,EAC/D,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CACd,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;YACrB,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC;YAC1B,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CACH,CACF,CAAC;QAEF,OAAO,aAAa,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,YAAY,EAAE,EAAE,aAAa,CAAC,CAAC,CAAC,IAAI,CAC/E,KAAK,CAAC,CAAC,CAAC,EAAE,oEAAoE;QAC9E,GAAG,CAAC,CAAC,CAAC,aAAa,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CACnG,CAAC;IACJ,CAAC;IAEO,WAAW;QACjB,MAAM,kBAAkB,GAAG,SAAS,CAAa,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;QACtG,MAAM,kBAAkB,GAAG,SAAS,CAAa,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;QAEtG,MAAM,iBAAiB,GAAG,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;QACnE,MAAM,mBAAmB,GAAG,kBAAkB,CAAC,IAAI,CACjD,SAAS,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC,EACnC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,CACnC,CAAC;QAEF,OAAO,KAAK,CAAC,iBAAiB,EAAE,mBAAmB,CAAC,CAAC;IACvD,CAAC;IAED,aAAa;QACX,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;IACrB,CAAC;8GAzFU,2BAA2B;kGAA3B,2BAA2B,+RAGrB,eAAe,gDC7BlC,uWAYA,gtBDYY,kBAAkB,yGAAE,SAAS;;2FAE5B,2BAA2B;kBAPvC,SAAS;+BACE,yBAAyB,cAGvB,IAAI,WACP,CAAC,kBAAkB,EAAE,SAAS,CAAC;sFAG/B,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACmD,OAAO;sBAA/D,eAAe;uBAAC,eAAe,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAGvD,MAAM;sBADL,WAAW;uBAAC,cAAc;gBAW3B,UAAU;sBADT,YAAY;uBAAC,YAAY;gBAM1B,UAAU;sBADT,YAAY;uBAAC,YAAY","sourcesContent":["import { AsyncPipe } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  QueryList\n} from '@angular/core';\nimport { BehaviorSubject, Subject, combineLatest, fromEvent, merge } from 'rxjs';\nimport { delay, map, startWith, switchMap, takeUntil } from 'rxjs/operators';\nimport { AutocloseDirective } from '../../../core-ui/directives/autoclose.directive';\nimport { executeOnNextTick } from '../../../shared/misc-helpers';\nimport { OptionComponent } from '../option/option.component';\n\n@Component({\n  selector: 'lx-options-sub-dropdown',\n  templateUrl: 'options-sub-dropdown.component.html',\n  styleUrls: ['options-sub-dropdown.component.scss'],\n  standalone: true,\n  imports: [AutocloseDirective, AsyncPipe]\n})\nexport class OptionsSubDropdownComponent implements AfterViewInit, OnDestroy {\n  @Input() trigger!: OptionComponent;\n  @Input() align: 'right' | 'left' = 'right';\n  @ContentChildren(OptionComponent, { descendants: true }) options!: QueryList<OptionComponent>;\n\n  @HostBinding('class.hidden')\n  hidden = true;\n\n  private mouseInside$ = new BehaviorSubject<boolean>(false);\n\n  readonly destroyed$ = new Subject<void>();\n  readonly maxHeight$ = new BehaviorSubject<string>('none');\n\n  constructor(private changeDetection: ChangeDetectorRef) {}\n\n  @HostListener('mouseenter')\n  mouseenter() {\n    this.mouseInside$.next(true);\n  }\n\n  @HostListener('mouseleave')\n  mouseleave() {\n    this.mouseInside$.next(false);\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  ngAfterViewInit() {\n    // To avoid `Expression has changed after it was checked`\n    executeOnNextTick(() => {\n      this.trigger.hasSubdropdown = true;\n    });\n\n    merge(this.showByKeyboard(), this.showByMouse())\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe((show) => {\n        this.hidden = !show;\n        this.changeDetection.markForCheck();\n        if (show) {\n          this.updateMaxHeight(this.trigger.elementRef);\n        }\n      });\n  }\n\n  private updateMaxHeight(elementRef: ElementRef) {\n    const marginBottom = 8;\n    const optionTopPosition = elementRef.nativeElement.getBoundingClientRect().top;\n    const screenHeight = window.innerHeight;\n    const maxHeight = `${screenHeight - optionTopPosition - marginBottom}px`;\n    if (this.maxHeight$.getValue() !== maxHeight) {\n      this.maxHeight$.next(maxHeight);\n    }\n  }\n\n  private showByKeyboard() {\n    const optionChange$ = this.options.changes.pipe(\n      startWith(this.options),\n      map((options: QueryList<OptionComponent>) => options.toArray()),\n      map((options) =>\n        options.map((option) => {\n          option.isSuboption = true;\n          return option;\n        })\n      )\n    );\n\n    return combineLatest([this.trigger.highlight.asObservable(), optionChange$]).pipe(\n      delay(0), // Need tick delay to get option highlighted and filter it out after\n      map(([isHighlighted, options]) => isHighlighted || options.some((option) => option.isHighlighted))\n    );\n  }\n\n  private showByMouse() {\n    const mouseEnterTrigger$ = fromEvent<MouseEvent>(this.trigger.elementRef.nativeElement, 'mouseenter');\n    const mouseLeaveTrigger$ = fromEvent<MouseEvent>(this.trigger.elementRef.nativeElement, 'mouseleave');\n\n    const showOnEnterMouse$ = mouseEnterTrigger$.pipe(map(() => true));\n    const showOnEnterSubmenu$ = mouseEnterTrigger$.pipe(\n      switchMap(() => mouseLeaveTrigger$),\n      switchMap(() => this.mouseInside$)\n    );\n\n    return merge(showOnEnterMouse$, showOnEnterSubmenu$);\n  }\n\n  closeDropdown() {\n    this.hidden = true;\n  }\n}\n","<div #spacingContainer class=\"spacingContainer\" [class.left]=\"align === 'left'\">\n  <ul\n    #subDropdown\n    class=\"sub-dropdown\"\n    lxAutoclose\n    [class.showScrollbar]=\"(maxHeight$ | async) !== 'none'\"\n    [style.max-height]=\"(maxHeight$ | async) ?? 'none'\"\n    (autoclose)=\"closeDropdown()\"\n  >\n    <ng-content />\n  </ul>\n</div>\n"]}
94
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"options-sub-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAGL,SAAS,EACT,eAAe,EACf,UAAU,EAEV,WAAW,EACX,YAAY,EACZ,MAAM,EACN,KAAK,EAGN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACjF,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAChF,OAAO,EAAE,kBAAkB,EAAE,MAAM,iDAAiD,CAAC;AACrF,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;;AAS7D,MAAM,OAAO,2BAA2B;IAetC,YAAoB,eAAkC;QAAlC,oBAAe,GAAf,eAAe,CAAmB;QAb7C,UAAK,GAAqB,OAAO,CAAC;QAI3C,WAAM,GAAG,IAAI,CAAC;QAEN,iBAAY,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAElD,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;QACjC,eAAU,GAAG,IAAI,eAAe,CAAS,MAAM,CAAC,CAAC;QAE1D,eAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAEyB,CAAC;IAG1D,UAAU;QACR,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAGD,UAAU;QACR,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,eAAe;QACb,yDAAyD;QACzD,iBAAiB,CAAC,GAAG,EAAE;YACrB,IAAI,CAAC,OAAO,CAAC,cAAc,GAAG,IAAI,CAAC;QACrC,CAAC,CAAC,CAAC;QAEH,KAAK,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC;aAC7C,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aAC5D,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YAClB,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC;YACpB,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;YACpC,IAAI,IAAI,EAAE,CAAC;gBACT,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;YAChD,CAAC;QACH,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,eAAe,CAAC,UAAsB;QAC5C,MAAM,YAAY,GAAG,CAAC,CAAC;QACvB,MAAM,iBAAiB,GAAG,UAAU,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,GAAG,CAAC;QAC/E,MAAM,YAAY,GAAG,MAAM,CAAC,WAAW,CAAC;QACxC,MAAM,SAAS,GAAG,GAAG,YAAY,GAAG,iBAAiB,GAAG,YAAY,IAAI,CAAC;QACzE,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,KAAK,SAAS,EAAE,CAAC;YAC7C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAEO,cAAc;QACpB,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAC7C,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EACvB,GAAG,CAAC,CAAC,OAAmC,EAAE,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,EAC/D,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CACd,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;YACrB,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC;YAC1B,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CACH,CACF,CAAC;QAEF,OAAO,aAAa,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,YAAY,EAAE,EAAE,aAAa,CAAC,CAAC,CAAC,IAAI,CAC/E,KAAK,CAAC,CAAC,CAAC,EAAE,oEAAoE;QAC9E,GAAG,CAAC,CAAC,CAAC,aAAa,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CACnG,CAAC;IACJ,CAAC;IAEO,WAAW;QACjB,MAAM,kBAAkB,GAAG,SAAS,CAAa,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;QACtG,MAAM,kBAAkB,GAAG,SAAS,CAAa,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;QAEtG,MAAM,iBAAiB,GAAG,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;QACnE,MAAM,mBAAmB,GAAG,kBAAkB,CAAC,IAAI,CACjD,SAAS,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC,EACnC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,CACnC,CAAC;QAEF,OAAO,KAAK,CAAC,iBAAiB,EAAE,mBAAmB,CAAC,CAAC;IACvD,CAAC;IAED,aAAa;QACX,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;IACrB,CAAC;8GA3FU,2BAA2B;kGAA3B,2BAA2B,+RAGrB,eAAe,gDChClC,uWAYA,gtBDeY,kBAAkB,yGAAE,SAAS;;2FAE5B,2BAA2B;kBAPvC,SAAS;+BACE,yBAAyB,cAGvB,IAAI,WACP,CAAC,kBAAkB,EAAE,SAAS,CAAC;sFAG/B,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACmD,OAAO;sBAA/D,eAAe;uBAAC,eAAe,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAGvD,MAAM;sBADL,WAAW;uBAAC,cAAc;gBAa3B,UAAU;sBADT,YAAY;uBAAC,YAAY;gBAM1B,UAAU;sBADT,YAAY;uBAAC,YAAY","sourcesContent":["import { AsyncPipe } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  DestroyRef,\n  ElementRef,\n  HostBinding,\n  HostListener,\n  inject,\n  Input,\n  OnDestroy,\n  QueryList\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { BehaviorSubject, combineLatest, fromEvent, merge, Subject } from 'rxjs';\nimport { debounceTime, delay, map, startWith, switchMap } from 'rxjs/operators';\nimport { AutocloseDirective } from '../../../core-ui/directives/autoclose.directive';\nimport { executeOnNextTick } from '../../../shared/misc-helpers';\nimport { OptionComponent } from '../option/option.component';\n\n@Component({\n  selector: 'lx-options-sub-dropdown',\n  templateUrl: 'options-sub-dropdown.component.html',\n  styleUrls: ['options-sub-dropdown.component.scss'],\n  standalone: true,\n  imports: [AutocloseDirective, AsyncPipe]\n})\nexport class OptionsSubDropdownComponent implements AfterViewInit, OnDestroy {\n  @Input() trigger!: OptionComponent;\n  @Input() align: 'right' | 'left' = 'right';\n  @ContentChildren(OptionComponent, { descendants: true }) options!: QueryList<OptionComponent>;\n\n  @HostBinding('class.hidden')\n  hidden = true;\n\n  private mouseInside$ = new BehaviorSubject<boolean>(false);\n\n  readonly destroyed$ = new Subject<void>();\n  readonly maxHeight$ = new BehaviorSubject<string>('none');\n\n  destroyRef = inject(DestroyRef);\n\n  constructor(private changeDetection: ChangeDetectorRef) {}\n\n  @HostListener('mouseenter')\n  mouseenter() {\n    this.mouseInside$.next(true);\n  }\n\n  @HostListener('mouseleave')\n  mouseleave() {\n    this.mouseInside$.next(false);\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  ngAfterViewInit() {\n    // To avoid `Expression has changed after it was checked`\n    executeOnNextTick(() => {\n      this.trigger.hasSubdropdown = true;\n    });\n\n    merge(this.showByKeyboard(), this.showByMouse())\n      .pipe(debounceTime(150), takeUntilDestroyed(this.destroyRef))\n      .subscribe((show) => {\n        this.hidden = !show;\n        this.changeDetection.markForCheck();\n        if (show) {\n          this.updateMaxHeight(this.trigger.elementRef);\n        }\n      });\n  }\n\n  private updateMaxHeight(elementRef: ElementRef) {\n    const marginBottom = 8;\n    const optionTopPosition = elementRef.nativeElement.getBoundingClientRect().top;\n    const screenHeight = window.innerHeight;\n    const maxHeight = `${screenHeight - optionTopPosition - marginBottom}px`;\n    if (this.maxHeight$.getValue() !== maxHeight) {\n      this.maxHeight$.next(maxHeight);\n    }\n  }\n\n  private showByKeyboard() {\n    const optionChange$ = this.options.changes.pipe(\n      startWith(this.options),\n      map((options: QueryList<OptionComponent>) => options.toArray()),\n      map((options) =>\n        options.map((option) => {\n          option.isSuboption = true;\n          return option;\n        })\n      )\n    );\n\n    return combineLatest([this.trigger.highlight.asObservable(), optionChange$]).pipe(\n      delay(0), // Need tick delay to get option highlighted and filter it out after\n      map(([isHighlighted, options]) => isHighlighted || options.some((option) => option.isHighlighted))\n    );\n  }\n\n  private showByMouse() {\n    const mouseEnterTrigger$ = fromEvent<MouseEvent>(this.trigger.elementRef.nativeElement, 'mouseenter');\n    const mouseLeaveTrigger$ = fromEvent<MouseEvent>(this.trigger.elementRef.nativeElement, 'mouseleave');\n\n    const showOnEnterMouse$ = mouseEnterTrigger$.pipe(map(() => true));\n    const showOnEnterSubmenu$ = mouseEnterTrigger$.pipe(\n      switchMap(() => mouseLeaveTrigger$),\n      switchMap(() => this.mouseInside$)\n    );\n\n    return merge(showOnEnterMouse$, showOnEnterSubmenu$);\n  }\n\n  closeDropdown() {\n    this.hidden = true;\n  }\n}\n","<div #spacingContainer class=\"spacingContainer\" [class.left]=\"align === 'left'\">\n  <ul\n    #subDropdown\n    class=\"sub-dropdown\"\n    lxAutoclose\n    [class.showScrollbar]=\"(maxHeight$ | async) !== 'none'\"\n    [style.max-height]=\"(maxHeight$ | async) ?? 'none'\"\n    (autoclose)=\"closeDropdown()\"\n  >\n    <ng-content />\n  </ul>\n</div>\n"]}
@@ -1,5 +1,5 @@
1
1
  import * as i0 from '@angular/core';
2
- import { InjectionToken, Component, Input, signal, ChangeDetectionStrategy, HostBinding, EventEmitter, Output, HostListener, Directive, Injectable, ElementRef, Inject, ViewChild, input, computed, ContentChildren, Pipe, Optional, NgModule, effect, ContentChild, ViewChildren, forwardRef, TemplateRef, viewChild, booleanAttribute, SecurityContext, Self, Host } from '@angular/core';
2
+ import { InjectionToken, Component, Input, signal, ChangeDetectionStrategy, HostBinding, EventEmitter, Output, HostListener, Directive, Injectable, ElementRef, Inject, ViewChild, input, computed, ContentChildren, Pipe, Optional, NgModule, effect, ContentChild, ViewChildren, forwardRef, TemplateRef, viewChild, inject, DestroyRef, booleanAttribute, SecurityContext, Self, Host } from '@angular/core';
3
3
  import * as i1$2 from '@ngx-translate/core';
4
4
  import { TranslatePipe, TranslateModule } from '@ngx-translate/core';
5
5
  import * as i1 from '@angular/common';
@@ -6585,6 +6585,7 @@ class OptionsSubDropdownComponent {
6585
6585
  this.mouseInside$ = new BehaviorSubject(false);
6586
6586
  this.destroyed$ = new Subject();
6587
6587
  this.maxHeight$ = new BehaviorSubject('none');
6588
+ this.destroyRef = inject(DestroyRef);
6588
6589
  }
6589
6590
  mouseenter() {
6590
6591
  this.mouseInside$.next(true);
@@ -6601,7 +6602,7 @@ class OptionsSubDropdownComponent {
6601
6602
  this.trigger.hasSubdropdown = true;
6602
6603
  });
6603
6604
  merge(this.showByKeyboard(), this.showByMouse())
6604
- .pipe(takeUntil(this.destroyed$))
6605
+ .pipe(debounceTime(150), takeUntilDestroyed(this.destroyRef))
6605
6606
  .subscribe((show) => {
6606
6607
  this.hidden = !show;
6607
6608
  this.changeDetection.markForCheck();