@coreui/angular
Version:
CoreUI Components Library for Angular
230 lines • 41.6 kB
JavaScript
import { animate, state, style, transition, trigger } from '@angular/animations';
import { NgClass, NgStyle, NgTemplateOutlet } from '@angular/common';
import { booleanAttribute, Component, ElementRef, forwardRef, HostBinding, Input, Optional, ViewChild } from '@angular/core';
import { NavigationEnd, RouterModule } from '@angular/router';
import { filter } from 'rxjs/operators';
import { SidebarNavHelper } from './sidebar-nav.service';
import { SidebarNavGroupService } from './sidebar-nav-group.service';
import { HtmlAttributesDirective } from '../../shared';
import { SidebarNavIconPipe } from './sidebar-nav-icon.pipe';
import { SidebarNavBadgePipe } from './sidebar-nav-badge.pipe';
import { SidebarNavLinkComponent } from './sidebar-nav-link.component';
import { SidebarNavLabelComponent } from './sidebar-nav-label.component';
import { SidebarNavTitleComponent } from './sidebar-nav-title.component';
import { SidebarNavDividerComponent } from './sidebar-nav-divider.component';
import { SidebarNavItemClassPipe } from './sidebar-nav-item-class.pipe';
import { IconDirective } from '@coreui/icons-angular';
import * as i0 from "@angular/core";
import * as i1 from "@angular/router";
import * as i2 from "./sidebar-nav.service";
import * as i3 from "./sidebar-nav-group.service";
import * as i4 from "../sidebar/sidebar.component";
import * as i5 from "../sidebar.service";
export class SidebarNavGroupComponent {
constructor(router, renderer, hostElement, helper, sidebarNavGroupService) {
this.router = router;
this.renderer = renderer;
this.hostElement = hostElement;
this.helper = helper;
this.sidebarNavGroupService = sidebarNavGroupService;
this.dropdownMode = 'path';
this.navItems = [];
this.display = { display: 'block' };
this.navigationEndObservable = router.events.pipe(filter((event) => event instanceof NavigationEnd));
}
get hostClasses() {
return {
'nav-group': true,
show: this.open
};
}
ngOnInit() {
this.navItems = [...this.item.children];
this.navSubscription = this.navigationEndObservable.subscribe((event) => {
if (this.dropdownMode !== 'none') {
const samePath = this.samePath(event.url);
this.openGroup(samePath);
}
});
if (this.samePath(this.router.routerState.snapshot.url)) {
this.openGroup(true);
}
this.navGroupSubscription = this.sidebarNavGroupService.sidebarNavGroupState$.subscribe((next) => {
if (this.dropdownMode === 'close' && next.sidebarNavGroup && next.sidebarNavGroup !== this) {
if (next.sidebarNavGroup.item.url.startsWith(this.item.url)) {
return;
}
if (this.samePath(this.router.routerState.snapshot.url)) {
this.openGroup(true);
return;
}
this.openGroup(false);
}
});
}
samePath(url) {
// console.log('item:', this.item.name, this.item.url, 'url:', url);
const itemArray = this.item.url?.split('/');
const urlArray = url.split('/');
return itemArray?.every((value, index) => {
// console.log(value === urlArray[index], 'value:', value, 'index:', index, urlArray[index], url);
return value === urlArray[index];
});
}
openGroup(open) {
this.open = open;
}
toggleGroup($event) {
$event.preventDefault();
this.openGroup(!this.open);
if (this.open) {
this.sidebarNavGroupService.toggle({ open: this.open, sidebarNavGroup: this });
}
}
ngOnDestroy() {
this.navSubscription?.unsubscribe();
}
onAnimationStart($event) {
this.display = { display: 'block' };
setTimeout(() => {
const host = this.sidebarNav?.nativeElement;
if ($event.toState === 'open' && host) {
this.renderer.setStyle(host, 'height', `${host['scrollHeight']}px`);
}
});
}
onAnimationDone($event) {
setTimeout(() => {
const host = this.sidebarNav?.nativeElement;
if ($event.toState === 'open' && host) {
this.renderer.setStyle(host, 'height', 'auto');
}
if ($event.toState === 'closed') {
setTimeout(() => {
this.display = null;
});
}
});
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SidebarNavGroupComponent, deps: [{ token: i1.Router }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i2.SidebarNavHelper }, { token: i3.SidebarNavGroupService }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.12", type: SidebarNavGroupComponent, isStandalone: true, selector: "c-sidebar-nav-group", inputs: { item: "item", dropdownMode: "dropdownMode", show: "show", compact: ["compact", "compact", booleanAttribute] }, host: { properties: { "class": "this.hostClasses" } }, providers: [SidebarNavHelper, SidebarNavGroupService], viewQueries: [{ propertyName: "sidebarNav", first: true, predicate: i0.forwardRef(() => SidebarNavComponent), descendants: true, read: ElementRef }], ngImport: i0, template: "<a (click)=\"toggleGroup($event)\"\n [cHtmlAttr]=\"item.attributes\"\n class=\"nav-link nav-group-toggle\"\n href>\n <ng-container *ngTemplateOutlet=\"iconTemplate ; context: {$implicit: item}\" />\n <ng-container>{{ item.name }}</ng-container>\n @if (helper.hasBadge(item)) {\n <span [ngClass]=\"item | cSidebarNavBadge\">{{ item.badge.text }}</span>\n }\n</a>\n<c-sidebar-nav\n (@openClose.done)=\"onAnimationDone($event)\"\n (@openClose.start)=\"onAnimationStart($event)\"\n [@openClose]=\"open ? 'open' : 'closed'\"\n [compact]=\"compact\"\n [dropdownMode]=\"dropdownMode\"\n [groupItems]=\"true\"\n [navItems]=\"navItems\"\n [ngStyle]=\"display\"\n/>\n\n<ng-template #iconTemplate let-item>\n <!-- <i *ngIf=\"item?.icon\" [ngClass]=\"item | cSidebarNavIcon\"></i>-->\n @if (item?.icon) {\n <span class=\"nav-icon\">\n <span [ngClass]=\"item.icon ?? ''\"></span>\n </span>\n }\n @if (item?.iconComponent) {\n <svg\n [cIcon]=\"item.iconComponent?.content\"\n [customClasses]=\"item | cSidebarNavIcon\"\n [name]=\"item.iconComponent?.name\"\n />\n }\n @if (!item?.icon && !item?.iconComponent) {\n <span [ngClass]=\"item | cSidebarNavIcon\"></span>\n }\n</ng-template>\n", styles: [".nav-group-toggle{cursor:pointer}.nav-group-items{display:block}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(() => HtmlAttributesDirective), selector: "[cHtmlAttr]", inputs: ["cHtmlAttr"], exportAs: ["cHtmlAttr"] }, { kind: "directive", type: i0.forwardRef(() => IconDirective), selector: "svg[cIcon]", inputs: ["cIcon", "customClasses", "size", "title", "height", "width", "name", "viewBox", "xmlns", "pointer-events", "role"], exportAs: ["cIcon"] }, { kind: "directive", type: i0.forwardRef(() => NgTemplateOutlet), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(() => NgClass), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: i0.forwardRef(() => SidebarNavIconPipe), name: "cSidebarNavIcon" }, { kind: "pipe", type: i0.forwardRef(() => SidebarNavBadgePipe), name: "cSidebarNavBadge" }, { kind: "component", type: i0.forwardRef(() => SidebarNavComponent), selector: "c-sidebar-nav", inputs: ["navItems", "dropdownMode", "groupItems", "compact", "role"] }, { kind: "directive", type: i0.forwardRef(() => NgStyle), selector: "[ngStyle]", inputs: ["ngStyle"] }], animations: [
trigger('openClose', [
state('open', style({
height: '*'
})),
state('closed', style({
height: '0px'
})),
transition('open <=> closed', [animate('.15s ease')])
])
] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SidebarNavGroupComponent, decorators: [{
type: Component,
args: [{ selector: 'c-sidebar-nav-group', providers: [SidebarNavHelper, SidebarNavGroupService], standalone: true, imports: [
HtmlAttributesDirective,
IconDirective,
NgTemplateOutlet,
NgClass,
SidebarNavIconPipe,
SidebarNavBadgePipe,
forwardRef(() => SidebarNavComponent),
NgStyle
], animations: [
trigger('openClose', [
state('open', style({
height: '*'
})),
state('closed', style({
height: '0px'
})),
transition('open <=> closed', [animate('.15s ease')])
])
], template: "<a (click)=\"toggleGroup($event)\"\n [cHtmlAttr]=\"item.attributes\"\n class=\"nav-link nav-group-toggle\"\n href>\n <ng-container *ngTemplateOutlet=\"iconTemplate ; context: {$implicit: item}\" />\n <ng-container>{{ item.name }}</ng-container>\n @if (helper.hasBadge(item)) {\n <span [ngClass]=\"item | cSidebarNavBadge\">{{ item.badge.text }}</span>\n }\n</a>\n<c-sidebar-nav\n (@openClose.done)=\"onAnimationDone($event)\"\n (@openClose.start)=\"onAnimationStart($event)\"\n [@openClose]=\"open ? 'open' : 'closed'\"\n [compact]=\"compact\"\n [dropdownMode]=\"dropdownMode\"\n [groupItems]=\"true\"\n [navItems]=\"navItems\"\n [ngStyle]=\"display\"\n/>\n\n<ng-template #iconTemplate let-item>\n <!-- <i *ngIf=\"item?.icon\" [ngClass]=\"item | cSidebarNavIcon\"></i>-->\n @if (item?.icon) {\n <span class=\"nav-icon\">\n <span [ngClass]=\"item.icon ?? ''\"></span>\n </span>\n }\n @if (item?.iconComponent) {\n <svg\n [cIcon]=\"item.iconComponent?.content\"\n [customClasses]=\"item | cSidebarNavIcon\"\n [name]=\"item.iconComponent?.name\"\n />\n }\n @if (!item?.icon && !item?.iconComponent) {\n <span [ngClass]=\"item | cSidebarNavIcon\"></span>\n }\n</ng-template>\n", styles: [".nav-group-toggle{cursor:pointer}.nav-group-items{display:block}\n"] }]
}], ctorParameters: () => [{ type: i1.Router }, { type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i2.SidebarNavHelper }, { type: i3.SidebarNavGroupService }], propDecorators: { item: [{
type: Input
}], dropdownMode: [{
type: Input
}], show: [{
type: Input
}], compact: [{
type: Input,
args: [{ transform: booleanAttribute }]
}], hostClasses: [{
type: HostBinding,
args: ['class']
}], sidebarNav: [{
type: ViewChild,
args: [forwardRef(() => SidebarNavComponent), { read: ElementRef }]
}] } });
export class SidebarNavComponent {
constructor(sidebar, helper, router, renderer, hostElement, sidebarService) {
this.sidebar = sidebar;
this.helper = helper;
this.router = router;
this.renderer = renderer;
this.hostElement = hostElement;
this.sidebarService = sidebarService;
this.navItems = [];
this.dropdownMode = 'path';
// @HostBinding('class.nav-group-items')
// get sidebarNavGroupItemsClass(): boolean {
// return !!this.groupItems;
// }
this.role = 'navigation';
this.navItemsArray = [];
}
get hostClasses() {
return {
'sidebar-nav': !this.groupItems,
'nav-group-items': this.groupItems,
compact: this.groupItems && this.compact
};
}
ngOnChanges(changes) {
this.navItemsArray = Array.isArray(this.navItems) ? this.navItems.slice() : [];
}
hideMobile() {
// todo: proper scrollIntoView() after NavigationEnd
if (this.sidebar && this.sidebar.sidebarState.mobile) {
this.sidebarService.toggle({ toggle: 'visible', sidebar: this.sidebar });
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SidebarNavComponent, deps: [{ token: i4.SidebarComponent, optional: true }, { token: i2.SidebarNavHelper }, { token: i1.Router }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i5.SidebarService }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.12", type: SidebarNavComponent, isStandalone: true, selector: "c-sidebar-nav", inputs: { navItems: "navItems", dropdownMode: "dropdownMode", groupItems: ["groupItems", "groupItems", booleanAttribute], compact: ["compact", "compact", booleanAttribute], role: "role" }, host: { properties: { "class": "this.hostClasses", "attr.role": "this.role" } }, usesOnChanges: true, ngImport: i0, template: "@for (item of navItemsArray; track item) {\n @switch (helper.itemType(item)) {\n @case ('group') {\n <c-sidebar-nav-group\n #rla=\"routerLinkActive\"\n [dropdownMode]=\"dropdownMode\"\n [item]=\"item\"\n [ngClass]=\"item | cSidebarNavItemClass\"\n [routerLinkActiveOptions]=\"{exact: true}\"\n routerLinkActive=\"show\"\n [compact]=\"compact\"\n />\n }\n @case ('divider') {\n <c-sidebar-nav-divider\n [cHtmlAttr]=\"item.attributes ?? {}\"\n [item]=\"item\"\n [ngClass]=\"item | cSidebarNavItemClass\"\n />\n }\n @case ('title') {\n <c-sidebar-nav-title\n [cHtmlAttr]=\"item.attributes ?? {}\"\n [item]=\"item\"\n [ngClass]=\"item | cSidebarNavItemClass\"\n />\n }\n @case ('label') {\n <c-sidebar-nav-label\n [item]=\"item\"\n [ngClass]=\"item | cSidebarNavItemClass\"\n />\n }\n @case ('empty') {\n <ng-container />\n }\n @default {\n <c-sidebar-nav-link\n (linkClick)=\"hideMobile()\"\n [item]=\"item\"\n [ngClass]=\"item | cSidebarNavItemClass\"\n />\n }\n }\n}\n<ng-content />\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: HtmlAttributesDirective, selector: "[cHtmlAttr]", inputs: ["cHtmlAttr"], exportAs: ["cHtmlAttr"] }, { kind: "component", type: SidebarNavLinkComponent, selector: "c-sidebar-nav-link", inputs: ["item"], outputs: ["linkClick"] }, { kind: "component", type: SidebarNavLabelComponent, selector: "c-sidebar-nav-label", inputs: ["item"] }, { kind: "component", type: SidebarNavTitleComponent, selector: "c-sidebar-nav-title", inputs: ["item"] }, { kind: "component", type: SidebarNavDividerComponent, selector: "c-sidebar-nav-divider", inputs: ["item"] }, { kind: "component", type: SidebarNavGroupComponent, selector: "c-sidebar-nav-group", inputs: ["item", "dropdownMode", "show", "compact"] }, { kind: "pipe", type: SidebarNavItemClassPipe, name: "cSidebarNavItemClass" }, { kind: "ngmodule", type: RouterModule }, { kind: "directive", type: i1.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SidebarNavComponent, decorators: [{
type: Component,
args: [{ selector: 'c-sidebar-nav', standalone: true, imports: [
NgClass,
HtmlAttributesDirective,
SidebarNavLinkComponent,
SidebarNavLabelComponent,
SidebarNavTitleComponent,
SidebarNavDividerComponent,
SidebarNavGroupComponent,
SidebarNavItemClassPipe,
RouterModule
], template: "@for (item of navItemsArray; track item) {\n @switch (helper.itemType(item)) {\n @case ('group') {\n <c-sidebar-nav-group\n #rla=\"routerLinkActive\"\n [dropdownMode]=\"dropdownMode\"\n [item]=\"item\"\n [ngClass]=\"item | cSidebarNavItemClass\"\n [routerLinkActiveOptions]=\"{exact: true}\"\n routerLinkActive=\"show\"\n [compact]=\"compact\"\n />\n }\n @case ('divider') {\n <c-sidebar-nav-divider\n [cHtmlAttr]=\"item.attributes ?? {}\"\n [item]=\"item\"\n [ngClass]=\"item | cSidebarNavItemClass\"\n />\n }\n @case ('title') {\n <c-sidebar-nav-title\n [cHtmlAttr]=\"item.attributes ?? {}\"\n [item]=\"item\"\n [ngClass]=\"item | cSidebarNavItemClass\"\n />\n }\n @case ('label') {\n <c-sidebar-nav-label\n [item]=\"item\"\n [ngClass]=\"item | cSidebarNavItemClass\"\n />\n }\n @case ('empty') {\n <ng-container />\n }\n @default {\n <c-sidebar-nav-link\n (linkClick)=\"hideMobile()\"\n [item]=\"item\"\n [ngClass]=\"item | cSidebarNavItemClass\"\n />\n }\n }\n}\n<ng-content />\n" }]
}], ctorParameters: () => [{ type: i4.SidebarComponent, decorators: [{
type: Optional
}] }, { type: i2.SidebarNavHelper }, { type: i1.Router }, { type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i5.SidebarService }], propDecorators: { navItems: [{
type: Input
}], dropdownMode: [{
type: Input
}], groupItems: [{
type: Input,
args: [{ transform: booleanAttribute }]
}], compact: [{
type: Input,
args: [{ transform: booleanAttribute }]
}], hostClasses: [{
type: HostBinding,
args: ['class']
}], role: [{
type: HostBinding,
args: ['attr.role']
}, {
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-nav.component.js","sourceRoot":"","sources":["../../../../../../projects/coreui-angular/src/lib/sidebar/sidebar-nav/sidebar-nav.component.ts","../../../../../../projects/coreui-angular/src/lib/sidebar/sidebar-nav/sidebar-nav-group.component.html","../../../../../../projects/coreui-angular/src/lib/sidebar/sidebar-nav/sidebar-nav.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, AnimationEvent, state, style, transition, trigger } from '@angular/animations';\nimport { NgClass, NgStyle, NgTemplateOutlet } from '@angular/common';\nimport {\n  booleanAttribute,\n  Component,\n  ElementRef,\n  forwardRef,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Renderer2,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { NavigationEnd, Router, RouterModule } from '@angular/router';\nimport { Observable, Subscription } from 'rxjs';\nimport { filter } from 'rxjs/operators';\n\nimport { SidebarService } from '../sidebar.service';\nimport { SidebarComponent } from '../sidebar/sidebar.component';\nimport { INavData } from './sidebar-nav';\nimport { SidebarNavHelper } from './sidebar-nav.service';\nimport { SidebarNavGroupService } from './sidebar-nav-group.service';\nimport { HtmlAttributesDirective } from '../../shared';\nimport { SidebarNavIconPipe } from './sidebar-nav-icon.pipe';\nimport { SidebarNavBadgePipe } from './sidebar-nav-badge.pipe';\nimport { SidebarNavLinkComponent } from './sidebar-nav-link.component';\nimport { SidebarNavLabelComponent } from './sidebar-nav-label.component';\nimport { SidebarNavTitleComponent } from './sidebar-nav-title.component';\nimport { SidebarNavDividerComponent } from './sidebar-nav-divider.component';\nimport { SidebarNavItemClassPipe } from './sidebar-nav-item-class.pipe';\nimport { IconDirective } from '@coreui/icons-angular';\n\n@Component({\n  selector: 'c-sidebar-nav-group',\n  templateUrl: './sidebar-nav-group.component.html',\n  styleUrls: ['./sidebar-nav-group.component.scss'],\n  providers: [SidebarNavHelper, SidebarNavGroupService],\n  standalone: true,\n  imports: [\n    HtmlAttributesDirective,\n    IconDirective,\n    NgTemplateOutlet,\n    NgClass,\n    SidebarNavIconPipe,\n    SidebarNavBadgePipe,\n    forwardRef(() => SidebarNavComponent),\n    NgStyle\n  ],\n  animations: [\n    trigger('openClose', [\n      state(\n        'open',\n        style({\n          height: '*'\n        })\n      ),\n      state(\n        'closed',\n        style({\n          height: '0px'\n        })\n      ),\n      transition('open <=> closed', [animate('.15s ease')])\n    ])\n  ]\n})\nexport class SidebarNavGroupComponent implements OnInit, OnDestroy {\n  constructor(\n    private router: Router,\n    private renderer: Renderer2,\n    private hostElement: ElementRef,\n    public helper: SidebarNavHelper,\n    private sidebarNavGroupService: SidebarNavGroupService\n  ) {\n    this.navigationEndObservable = router.events.pipe(\n      filter((event: any) => event instanceof NavigationEnd)\n    ) as Observable<NavigationEnd>;\n  }\n\n  @Input() item: any;\n  @Input() dropdownMode: 'path' | 'none' | 'close' = 'path';\n  @Input() show?: boolean;\n  @Input({ transform: booleanAttribute }) compact?: boolean;\n\n  @HostBinding('class')\n  get hostClasses(): any {\n    return {\n      'nav-group': true,\n      show: this.open\n    };\n  }\n\n  @ViewChild(forwardRef(() => SidebarNavComponent), { read: ElementRef }) sidebarNav!: ElementRef;\n\n  navigationEndObservable: Observable<NavigationEnd>;\n  navSubscription!: Subscription;\n  navGroupSubscription!: Subscription;\n\n  public open!: boolean;\n  public navItems: INavData[] = [];\n  public display: any = { display: 'block' };\n\n  ngOnInit(): void {\n    this.navItems = [...this.item.children];\n\n    this.navSubscription = this.navigationEndObservable.subscribe((event: NavigationEnd) => {\n      if (this.dropdownMode !== 'none') {\n        const samePath = this.samePath(event.url);\n        this.openGroup(samePath);\n      }\n    });\n\n    if (this.samePath(this.router.routerState.snapshot.url)) {\n      this.openGroup(true);\n    }\n\n    this.navGroupSubscription = this.sidebarNavGroupService.sidebarNavGroupState$.subscribe((next) => {\n      if (this.dropdownMode === 'close' && next.sidebarNavGroup && next.sidebarNavGroup !== this) {\n        if (next.sidebarNavGroup.item.url.startsWith(this.item.url)) {\n          return;\n        }\n        if (this.samePath(this.router.routerState.snapshot.url)) {\n          this.openGroup(true);\n          return;\n        }\n        this.openGroup(false);\n      }\n    });\n  }\n\n  samePath(url: string): boolean {\n    // console.log('item:', this.item.name, this.item.url, 'url:', url);\n    const itemArray = this.item.url?.split('/');\n    const urlArray = url.split('/');\n    return itemArray?.every((value: string, index: number) => {\n      // console.log(value === urlArray[index], 'value:', value, 'index:', index, urlArray[index], url);\n      return value === urlArray[index];\n    });\n  }\n\n  openGroup(open: boolean): void {\n    this.open = open;\n  }\n\n  toggleGroup($event: any): void {\n    $event.preventDefault();\n    this.openGroup(!this.open);\n    if (this.open) {\n      this.sidebarNavGroupService.toggle({ open: this.open, sidebarNavGroup: this });\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.navSubscription?.unsubscribe();\n  }\n\n  onAnimationStart($event: AnimationEvent) {\n    this.display = { display: 'block' };\n    setTimeout(() => {\n      const host = this.sidebarNav?.nativeElement;\n      if ($event.toState === 'open' && host) {\n        this.renderer.setStyle(host, 'height', `${host['scrollHeight']}px`);\n      }\n    });\n  }\n\n  onAnimationDone($event: AnimationEvent) {\n    setTimeout(() => {\n      const host = this.sidebarNav?.nativeElement;\n      if ($event.toState === 'open' && host) {\n        this.renderer.setStyle(host, 'height', 'auto');\n      }\n      if ($event.toState === 'closed') {\n        setTimeout(() => {\n          this.display = null;\n        });\n      }\n    });\n  }\n}\n\n@Component({\n  selector: 'c-sidebar-nav',\n  templateUrl: './sidebar-nav.component.html',\n  standalone: true,\n  imports: [\n    NgClass,\n    HtmlAttributesDirective,\n    SidebarNavLinkComponent,\n    SidebarNavLabelComponent,\n    SidebarNavTitleComponent,\n    SidebarNavDividerComponent,\n    SidebarNavGroupComponent,\n    SidebarNavItemClassPipe,\n    RouterModule\n  ]\n})\nexport class SidebarNavComponent implements OnChanges {\n  constructor(\n    @Optional() public sidebar: SidebarComponent,\n    public helper: SidebarNavHelper,\n    public router: Router,\n    private renderer: Renderer2,\n    private hostElement: ElementRef,\n    private sidebarService: SidebarService\n  ) {}\n\n  @Input() navItems?: INavData[] = [];\n  @Input() dropdownMode: 'path' | 'none' | 'close' = 'path';\n  @Input({ transform: booleanAttribute }) groupItems?: boolean;\n  @Input({ transform: booleanAttribute }) compact?: boolean;\n\n  @HostBinding('class')\n  get hostClasses(): any {\n    return {\n      'sidebar-nav': !this.groupItems,\n      'nav-group-items': this.groupItems,\n      compact: this.groupItems && this.compact\n    };\n  }\n\n  // @HostBinding('class.nav-group-items')\n  // get sidebarNavGroupItemsClass(): boolean {\n  //   return !!this.groupItems;\n  // }\n\n  @HostBinding('attr.role')\n  @Input()\n  role = 'navigation';\n\n  public navItemsArray: INavData[] = [];\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    this.navItemsArray = Array.isArray(this.navItems) ? this.navItems.slice() : [];\n  }\n\n  public hideMobile(): void {\n    // todo: proper scrollIntoView() after NavigationEnd\n    if (this.sidebar && this.sidebar.sidebarState.mobile) {\n      this.sidebarService.toggle({ toggle: 'visible', sidebar: this.sidebar });\n    }\n  }\n}\n","<a (click)=\"toggleGroup($event)\"\n   [cHtmlAttr]=\"item.attributes\"\n   class=\"nav-link nav-group-toggle\"\n   href>\n  <ng-container *ngTemplateOutlet=\"iconTemplate ; context: {$implicit: item}\" />\n  <ng-container>{{ item.name }}</ng-container>\n  @if (helper.hasBadge(item)) {\n    <span [ngClass]=\"item | cSidebarNavBadge\">{{ item.badge.text }}</span>\n  }\n</a>\n<c-sidebar-nav\n  (@openClose.done)=\"onAnimationDone($event)\"\n  (@openClose.start)=\"onAnimationStart($event)\"\n  [@openClose]=\"open ? 'open' : 'closed'\"\n  [compact]=\"compact\"\n  [dropdownMode]=\"dropdownMode\"\n  [groupItems]=\"true\"\n  [navItems]=\"navItems\"\n  [ngStyle]=\"display\"\n/>\n\n<ng-template #iconTemplate let-item>\n  <!--  <i *ngIf=\"item?.icon\" [ngClass]=\"item | cSidebarNavIcon\"></i>-->\n  @if (item?.icon) {\n    <span class=\"nav-icon\">\n    <span [ngClass]=\"item.icon ?? ''\"></span>\n  </span>\n  }\n  @if (item?.iconComponent) {\n    <svg\n      [cIcon]=\"item.iconComponent?.content\"\n      [customClasses]=\"item | cSidebarNavIcon\"\n      [name]=\"item.iconComponent?.name\"\n    />\n  }\n  @if (!item?.icon && !item?.iconComponent) {\n    <span [ngClass]=\"item | cSidebarNavIcon\"></span>\n  }\n</ng-template>\n","@for (item of navItemsArray; track item) {\n  @switch (helper.itemType(item)) {\n    @case ('group') {\n      <c-sidebar-nav-group\n        #rla=\"routerLinkActive\"\n        [dropdownMode]=\"dropdownMode\"\n        [item]=\"item\"\n        [ngClass]=\"item | cSidebarNavItemClass\"\n        [routerLinkActiveOptions]=\"{exact: true}\"\n        routerLinkActive=\"show\"\n        [compact]=\"compact\"\n      />\n    }\n    @case ('divider') {\n      <c-sidebar-nav-divider\n        [cHtmlAttr]=\"item.attributes ?? {}\"\n        [item]=\"item\"\n        [ngClass]=\"item | cSidebarNavItemClass\"\n      />\n    }\n    @case ('title') {\n      <c-sidebar-nav-title\n        [cHtmlAttr]=\"item.attributes ?? {}\"\n        [item]=\"item\"\n        [ngClass]=\"item | cSidebarNavItemClass\"\n      />\n    }\n    @case ('label') {\n      <c-sidebar-nav-label\n        [item]=\"item\"\n        [ngClass]=\"item | cSidebarNavItemClass\"\n      />\n    }\n    @case ('empty') {\n      <ng-container />\n    }\n    @default {\n      <c-sidebar-nav-link\n        (linkClick)=\"hideMobile()\"\n        [item]=\"item\"\n        [ngClass]=\"item | cSidebarNavItemClass\"\n      />\n    }\n  }\n}\n<ng-content />\n"]}