@coreui/angular
Version:
CoreUI for Angular UI components library
137 lines • 28.2 kB
JavaScript
import { Component, HostBinding, Input, Optional } from '@angular/core';
import { NavigationEnd } from '@angular/router';
import { SidebarNavHelper } from './sidebar-nav.service';
import { filter } from 'rxjs/operators';
import * as i0 from "@angular/core";
import * as i1 from "../sidebar/sidebar.component";
import * as i2 from "./sidebar-nav.service";
import * as i3 from "@angular/router";
import * as i4 from "../sidebar.service";
import * as i5 from "./sidebar-nav-divider.component";
import * as i6 from "./sidebar-nav-title.component";
import * as i7 from "./sidebar-nav-label.component";
import * as i8 from "./sidebar-nav-link.component";
import * as i9 from "@angular/common";
import * as i10 from "../../shared/html-attr.directive";
import * as i11 from "./sidebar-nav-item-class.pipe";
import * as i12 from "@coreui/icons-angular";
import * as i13 from "./sidebar-nav-badge.pipe";
import * as i14 from "./sidebar-nav-icon.pipe";
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 = 'closeInactive';
this.role = 'nav';
this.navItemsArray = [];
}
get hostClasses() {
return {
'sidebar-nav': !this.groupItems,
compact: !this.groupItems && !!this.compact
};
}
get sidebarNavGroupItemsClass() {
return !!this.groupItems;
}
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 });
}
}
}
SidebarNavComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: SidebarNavComponent, deps: [{ token: i1.SidebarComponent, optional: true }, { token: i2.SidebarNavHelper }, { token: i3.Router }, { token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i4.SidebarService }], target: i0.ɵɵFactoryTarget.Component });
SidebarNavComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.4", type: SidebarNavComponent, selector: "c-sidebar-nav", inputs: { navItems: "navItems", dropdownMode: "dropdownMode", groupItems: "groupItems", compact: "compact" }, host: { properties: { "class": "this.hostClasses", "class.nav-group-items": "this.sidebarNavGroupItemsClass", "attr.role": "this.role" } }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngFor=\"let item of navItemsArray\">\r\n <ng-container [ngSwitch]=\"helper.itemType(item)\">\r\n <c-sidebar-nav-group\r\n *ngSwitchCase=\"'group'\"\r\n [item]=\"item\"\r\n [ngClass]=\"item | cSidebarNavItemClass\"\r\n routerLinkActive=\"show\"\r\n #rla=\"routerLinkActive\"\r\n [routerLinkActiveOptions]=\"{exact: true}\"\r\n >\r\n </c-sidebar-nav-group>\r\n <c-sidebar-nav-divider\r\n *ngSwitchCase=\"'divider'\"\r\n [item]=\"item\"\r\n [ngClass]=\"item | cSidebarNavItemClass\"\r\n [cHtmlAttr]=\"item.attributes ?? {}\">\r\n </c-sidebar-nav-divider>\r\n <c-sidebar-nav-title\r\n *ngSwitchCase=\"'title'\"\r\n [item]=\"item\"\r\n [ngClass]=\"item | cSidebarNavItemClass\"\r\n [cHtmlAttr]=\"item.attributes ?? {}\">\r\n </c-sidebar-nav-title>\r\n <c-sidebar-nav-label\r\n *ngSwitchCase=\"'label'\"\r\n [item]=\"item\"\r\n [ngClass]=\"item | cSidebarNavItemClass\">\r\n </c-sidebar-nav-label>\r\n <ng-container\r\n *ngSwitchCase=\"'empty'\">\r\n </ng-container>\r\n <c-sidebar-nav-link\r\n *ngSwitchDefault\r\n [item]=\"item\"\r\n [ngClass]=\"item | cSidebarNavItemClass\"\r\n (linkClick)=\"hideMobile()\"\r\n >\r\n </c-sidebar-nav-link>\r\n </ng-container>\r\n</ng-container>\r\n<ng-content></ng-content>\r\n", styles: [""], components: [{ type: i0.forwardRef(function () { return SidebarNavGroupComponent; }), selector: "c-sidebar-nav-group", inputs: ["item", "dropdownMode", "show"] }, { type: i0.forwardRef(function () { return i5.SidebarNavDividerComponent; }), selector: "c-sidebar-nav-divider", inputs: ["item"] }, { type: i0.forwardRef(function () { return i6.SidebarNavTitleComponent; }), selector: "c-sidebar-nav-title", inputs: ["item"] }, { type: i0.forwardRef(function () { return i7.SidebarNavLabelComponent; }), selector: "c-sidebar-nav-label", inputs: ["item"] }, { type: i0.forwardRef(function () { return i8.SidebarNavLinkComponent; }), selector: "c-sidebar-nav-link", inputs: ["item"], outputs: ["linkClick"] }], directives: [{ type: i0.forwardRef(function () { return i9.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i0.forwardRef(function () { return i9.NgSwitch; }), selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i0.forwardRef(function () { return i9.NgSwitchCase; }), selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i0.forwardRef(function () { return i3.RouterLinkActive; }), selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { type: i0.forwardRef(function () { return i9.NgClass; }), selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i0.forwardRef(function () { return i10.HtmlAttributesDirective; }), selector: "[cHtmlAttr]", inputs: ["cHtmlAttr"], exportAs: ["cHtmlAttr"] }, { type: i0.forwardRef(function () { return i9.NgSwitchDefault; }), selector: "[ngSwitchDefault]" }], pipes: { "cSidebarNavItemClass": i0.forwardRef(function () { return i11.SidebarNavItemClassPipe; }) } });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: SidebarNavComponent, decorators: [{
type: Component,
args: [{ selector: 'c-sidebar-nav', template: "<ng-container *ngFor=\"let item of navItemsArray\">\r\n <ng-container [ngSwitch]=\"helper.itemType(item)\">\r\n <c-sidebar-nav-group\r\n *ngSwitchCase=\"'group'\"\r\n [item]=\"item\"\r\n [ngClass]=\"item | cSidebarNavItemClass\"\r\n routerLinkActive=\"show\"\r\n #rla=\"routerLinkActive\"\r\n [routerLinkActiveOptions]=\"{exact: true}\"\r\n >\r\n </c-sidebar-nav-group>\r\n <c-sidebar-nav-divider\r\n *ngSwitchCase=\"'divider'\"\r\n [item]=\"item\"\r\n [ngClass]=\"item | cSidebarNavItemClass\"\r\n [cHtmlAttr]=\"item.attributes ?? {}\">\r\n </c-sidebar-nav-divider>\r\n <c-sidebar-nav-title\r\n *ngSwitchCase=\"'title'\"\r\n [item]=\"item\"\r\n [ngClass]=\"item | cSidebarNavItemClass\"\r\n [cHtmlAttr]=\"item.attributes ?? {}\">\r\n </c-sidebar-nav-title>\r\n <c-sidebar-nav-label\r\n *ngSwitchCase=\"'label'\"\r\n [item]=\"item\"\r\n [ngClass]=\"item | cSidebarNavItemClass\">\r\n </c-sidebar-nav-label>\r\n <ng-container\r\n *ngSwitchCase=\"'empty'\">\r\n </ng-container>\r\n <c-sidebar-nav-link\r\n *ngSwitchDefault\r\n [item]=\"item\"\r\n [ngClass]=\"item | cSidebarNavItemClass\"\r\n (linkClick)=\"hideMobile()\"\r\n >\r\n </c-sidebar-nav-link>\r\n </ng-container>\r\n</ng-container>\r\n<ng-content></ng-content>\r\n", styles: [""] }]
}], ctorParameters: function () { return [{ type: i1.SidebarComponent, decorators: [{
type: Optional
}] }, { type: i2.SidebarNavHelper }, { type: i3.Router }, { type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i4.SidebarService }]; }, propDecorators: { navItems: [{
type: Input
}], dropdownMode: [{
type: Input
}], groupItems: [{
type: Input
}], compact: [{
type: Input
}], hostClasses: [{
type: HostBinding,
args: ['class']
}], sidebarNavGroupItemsClass: [{
type: HostBinding,
args: ['class.nav-group-items']
}], role: [{
type: HostBinding,
args: ['attr.role']
}] } });
export class SidebarNavGroupComponent {
constructor(router, helper, hostElement) {
this.router = router;
this.helper = helper;
this.hostElement = hostElement;
this.dropdownMode = 'closeInactive';
this.navItems = [];
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) => {
const samePath = this.samePath(event.url);
this.openGroup(samePath);
});
if (this.samePath(this.router.routerState.snapshot.url)) {
this.openGroup(true);
}
}
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.open = !this.open;
}
ngOnDestroy() {
this.navSubscription.unsubscribe();
}
}
SidebarNavGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: SidebarNavGroupComponent, deps: [{ token: i3.Router }, { token: i2.SidebarNavHelper }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
SidebarNavGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.4", type: SidebarNavGroupComponent, selector: "c-sidebar-nav-group", inputs: { item: "item", dropdownMode: "dropdownMode", show: "show" }, host: { properties: { "class": "this.hostClasses" } }, providers: [SidebarNavHelper], ngImport: i0, template: "<a class=\"nav-link nav-group-toggle\"\r\n (click)=\"toggleGroup($event)\"\r\n [cHtmlAttr]=\"item.attributes\">\r\n <ng-container *ngTemplateOutlet=\"iconTemplate ; context: {$implicit: item}\"></ng-container>\r\n <ng-container>{{ item.name }}</ng-container>\r\n <span *ngIf=\"helper.hasBadge(item)\" [ngClass]=\"item | cSidebarNavBadge\">{{ item.badge.text }}</span>\r\n</a>\r\n<c-sidebar-nav\r\n [groupItems]=\"true\"\r\n [navItems]=\"navItems\">\r\n</c-sidebar-nav>\r\n\r\n<ng-template #iconTemplate let-item>\r\n <i *ngIf=\"item?.icon\" [ngClass]=\"item | cSidebarNavIcon\"></i>\r\n <ng-template [ngIf]=\"item?.iconComponent\">\r\n <svg\r\n [cIcon]=\"item.iconComponent?.content\"\r\n [name]=\"item.iconComponent?.name\"\r\n [customClasses]=\"item | cSidebarNavIcon\"\r\n ></svg>\r\n </ng-template>\r\n <span *ngIf=\"!item?.icon && !item?.iconComponent\" [ngClass]=\"item | cSidebarNavIcon\"></span>\r\n</ng-template>\r\n", styles: [".nav-group-toggle{cursor:pointer}.nav-group-items{display:block}\n"], components: [{ type: SidebarNavComponent, selector: "c-sidebar-nav", inputs: ["navItems", "dropdownMode", "groupItems", "compact"] }], directives: [{ type: i10.HtmlAttributesDirective, selector: "[cHtmlAttr]", inputs: ["cHtmlAttr"], exportAs: ["cHtmlAttr"] }, { type: i9.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i12.IconDirective, selector: "svg[cIcon]", inputs: ["cIcon", "size", "title", "customClasses", "width", "height", "name", "viewBox", "xmlns", "pointer-events", "role"], exportAs: ["cIcon"] }], pipes: { "cSidebarNavBadge": i13.SidebarNavBadgePipe, "cSidebarNavIcon": i14.SidebarNavIconPipe } });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.4", ngImport: i0, type: SidebarNavGroupComponent, decorators: [{
type: Component,
args: [{ selector: 'c-sidebar-nav-group', providers: [SidebarNavHelper], template: "<a class=\"nav-link nav-group-toggle\"\r\n (click)=\"toggleGroup($event)\"\r\n [cHtmlAttr]=\"item.attributes\">\r\n <ng-container *ngTemplateOutlet=\"iconTemplate ; context: {$implicit: item}\"></ng-container>\r\n <ng-container>{{ item.name }}</ng-container>\r\n <span *ngIf=\"helper.hasBadge(item)\" [ngClass]=\"item | cSidebarNavBadge\">{{ item.badge.text }}</span>\r\n</a>\r\n<c-sidebar-nav\r\n [groupItems]=\"true\"\r\n [navItems]=\"navItems\">\r\n</c-sidebar-nav>\r\n\r\n<ng-template #iconTemplate let-item>\r\n <i *ngIf=\"item?.icon\" [ngClass]=\"item | cSidebarNavIcon\"></i>\r\n <ng-template [ngIf]=\"item?.iconComponent\">\r\n <svg\r\n [cIcon]=\"item.iconComponent?.content\"\r\n [name]=\"item.iconComponent?.name\"\r\n [customClasses]=\"item | cSidebarNavIcon\"\r\n ></svg>\r\n </ng-template>\r\n <span *ngIf=\"!item?.icon && !item?.iconComponent\" [ngClass]=\"item | cSidebarNavIcon\"></span>\r\n</ng-template>\r\n", styles: [".nav-group-toggle{cursor:pointer}.nav-group-items{display:block}\n"] }]
}], ctorParameters: function () { return [{ type: i3.Router }, { type: i2.SidebarNavHelper }, { type: i0.ElementRef }]; }, propDecorators: { item: [{
type: Input
}], dropdownMode: [{
type: Input
}], show: [{
type: Input
}], hostClasses: [{
type: HostBinding,
args: ['class']
}] } });
//# 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.component.html","../../../../../../projects/coreui-angular/src/lib/sidebar/sidebar-nav/sidebar-nav-group.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,WAAW,EACX,KAAK,EAIL,QAAQ,EAGT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAU,MAAM,iBAAiB,CAAC;AAGxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAIzD,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;;;;;;;AAOxC,MAAM,OAAO,mBAAmB;IAuB9B,YACqB,OAAyB,EACrC,MAAwB,EACxB,MAAc,EACb,QAAmB,EACnB,WAAuB,EACvB,cAA8B;QALnB,YAAO,GAAP,OAAO,CAAkB;QACrC,WAAM,GAAN,MAAM,CAAkB;QACxB,WAAM,GAAN,MAAM,CAAQ;QACb,aAAQ,GAAR,QAAQ,CAAW;QACnB,gBAAW,GAAX,WAAW,CAAY;QACvB,mBAAc,GAAd,cAAc,CAAgB;QA5B/B,aAAQ,GAAgB,EAAE,CAAC;QAC3B,iBAAY,GAAiD,eAAe,CAAC;QAiB5D,SAAI,GAAG,KAAK,CAAC;QAEhC,kBAAa,GAAe,EAAE,CAAC;IASlC,CAAC;IAxBL,IACI,WAAW;QACb,OAAO;YACL,aAAa,EAAE,CAAC,IAAI,CAAC,UAAU;YAC/B,OAAO,EAAE,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO;SAC5C,CAAC;IACJ,CAAC;IAED,IACI,yBAAyB;QAC3B,OAAO,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAeM,WAAW,CAAC,OAAsB;QACvC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IACjF,CAAC;IAEM,UAAU;QACf,oDAAoD;QACpD,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,EAAE;YACpD,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,EAAC,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAC,CAAC,CAAC;SACxE;IACH,CAAC;;gHAzCU,mBAAmB;oGAAnB,mBAAmB,oUC1BhC,m2CAyCA,wEDmCa,wBAAwB;2FAlDxB,mBAAmB;kBAL/B,SAAS;+BACE,eAAe;;0BA4BtB,QAAQ;8KAvBF,QAAQ;sBAAhB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBAGF,WAAW;sBADd,WAAW;uBAAC,OAAO;gBAShB,yBAAyB;sBAD5B,WAAW;uBAAC,uBAAuB;gBAKV,IAAI;sBAA7B,WAAW;uBAAC,WAAW;;AA+B1B,MAAM,OAAO,wBAAwB;IAyBnC,YACU,MAAc,EACf,MAAwB,EACvB,WAAuB;QAFvB,WAAM,GAAN,MAAM,CAAQ;QACf,WAAM,GAAN,MAAM,CAAkB;QACvB,gBAAW,GAAX,WAAW,CAAY;QA1BxB,iBAAY,GAAgD,eAAe,CAAC;QAqB9E,aAAQ,GAAe,EAAE,CAAC;QAO/B,IAAI,CAAC,uBAAuB,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAC/C,MAAM,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,YAAY,aAAa,CAAC,CAC1B,CAAC;IACjC,CAAC;IA3BD,IAEI,WAAW;QACb,OAAO;YACL,WAAW,EAAE,IAAI;YACjB,IAAI,EAAE,IAAI,CAAC,IAAI;SAChB,CAAC;IACJ,CAAC;IAsBD,QAAQ;QAEN,IAAI,CAAC,QAAQ,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAExC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,uBAAuB,CAAC,SAAS,CAAC,CAAC,KAAoB,EAAE,EAAE;YACrF,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAC1C,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QAC3B,CAAC,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;YACvD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;SACtB;IACH,CAAC;IAED,QAAQ,CAAC,GAAW;QAClB,oEAAoE;QACpE,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;QAC5C,MAAM,QAAQ,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAChC,OAAO,SAAS,EAAE,KAAK,CAAC,CAAC,KAAa,EAAE,KAAa,EAAE,EAAE;YACvD,kGAAkG;YAClG,OAAO,KAAK,KAAK,QAAQ,CAAC,KAAK,CAAC,CAAC;QACnC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,SAAS,CAAC,IAAa;QACrB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IAED,WAAW,CAAC,MAAW;QACrB,MAAM,CAAC,cAAc,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;IACzB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,CAAC;IACrC,CAAC;;qHAtEU,wBAAwB;yGAAxB,wBAAwB,2KAFxB,CAAE,gBAAgB,CAAE,0BE1EjC,i8BAuBA,uGFGa,mBAAmB;2FAkDnB,wBAAwB;kBANpC,SAAS;+BACE,qBAAqB,aAGpB,CAAE,gBAAgB,CAAE;qJAGtB,IAAI;sBAAZ,KAAK;gBACG,YAAY;sBAApB,KAAK;gBAEG,IAAI;sBAAZ,KAAK;gBAIF,WAAW;sBAFd,WAAW;uBAAC,OAAO","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  HostBinding,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Optional,\r\n  Renderer2,\r\n  SimpleChanges\r\n} from '@angular/core';\r\nimport { NavigationEnd, Router } from '@angular/router';\r\n\r\nimport { INavData } from './sidebar-nav';\r\nimport { SidebarNavHelper } from './sidebar-nav.service';\r\nimport { SidebarService } from '../sidebar.service';\r\nimport { SidebarComponent } from '../sidebar/sidebar.component';\r\nimport { Observable, Subscription } from 'rxjs';\r\nimport { filter } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: 'c-sidebar-nav',\r\n  templateUrl: './sidebar-nav.component.html',\r\n  styleUrls: ['./sidebar-nav.component.scss']\r\n  })\r\nexport class SidebarNavComponent implements OnChanges {\r\n  @Input() navItems?: INavData[] = [];\r\n  @Input() dropdownMode?: 'closeInactive' | 'noAction' | 'openActive' = 'closeInactive';\r\n  @Input() groupItems?: boolean;\r\n  @Input() compact?: boolean;\r\n\r\n  @HostBinding('class')\r\n  get hostClasses(): any {\r\n    return {\r\n      'sidebar-nav': !this.groupItems,\r\n      compact: !this.groupItems && !!this.compact\r\n    };\r\n  }\r\n\r\n  @HostBinding('class.nav-group-items')\r\n  get sidebarNavGroupItemsClass(): boolean {\r\n    return !!this.groupItems;\r\n  }\r\n\r\n  @HostBinding('attr.role') role = 'nav';\r\n\r\n  public navItemsArray: INavData[] = [];\r\n\r\n  constructor(\r\n    @Optional() public sidebar: SidebarComponent,\r\n    public helper: SidebarNavHelper,\r\n    public router: Router,\r\n    private renderer: Renderer2,\r\n    private hostElement: ElementRef,\r\n    private sidebarService: SidebarService\r\n  ) { }\r\n\r\n  public ngOnChanges(changes: SimpleChanges): void {\r\n    this.navItemsArray = Array.isArray(this.navItems) ? this.navItems.slice() : [];\r\n  }\r\n\r\n  public hideMobile(): void {\r\n    // todo: proper scrollIntoView() after NavigationEnd\r\n    if (this.sidebar && this.sidebar.sidebarState.mobile) {\r\n      this.sidebarService.toggle({toggle: 'visible', sidebar: this.sidebar});\r\n    }\r\n  }\r\n}\r\n\r\n@Component({\r\n  selector: 'c-sidebar-nav-group',\r\n  templateUrl: './sidebar-nav-group.component.html',\r\n  styleUrls: ['./sidebar-nav-group.component.scss'],\r\n  providers: [ SidebarNavHelper ]\r\n})\r\nexport class SidebarNavGroupComponent implements OnInit, OnDestroy {\r\n  @Input() item: any;\r\n  @Input() dropdownMode: 'closeInactive' | 'noAction' | 'openActive' = 'closeInactive';\r\n  // @ts-ignore\r\n  @Input() show: boolean;\r\n\r\n  @HostBinding('class')\r\n  // tslint:disable-next-line:typedef\r\n  get hostClasses(): any {\r\n    return {\r\n      'nav-group': true,\r\n      show: this.open,\r\n    };\r\n  }\r\n\r\n  // todo: dropdownMode\r\n\r\n  navigationEndObservable: Observable<NavigationEnd>;\r\n  // @ts-ignore\r\n  navSubscription: Subscription;\r\n\r\n  // @ts-ignore\r\n  private open: boolean;\r\n  public navItems: INavData[] = [];\r\n\r\n  constructor(\r\n    private router: Router,\r\n    public helper: SidebarNavHelper,\r\n    private hostElement: ElementRef\r\n  ) {\r\n    this.navigationEndObservable = router.events.pipe(\r\n      filter((event: any) => event instanceof NavigationEnd)\r\n    ) as Observable<NavigationEnd>;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    this.navItems = [...this.item.children];\r\n\r\n    this.navSubscription = this.navigationEndObservable.subscribe((event: NavigationEnd) => {\r\n      const samePath = this.samePath(event.url);\r\n      this.openGroup(samePath);\r\n    });\r\n\r\n    if (this.samePath(this.router.routerState.snapshot.url)) {\r\n      this.openGroup(true);\r\n    }\r\n  }\r\n\r\n  samePath(url: string): boolean {\r\n    // console.log('item:', this.item.name, this.item.url, 'url:', url);\r\n    const itemArray = this.item.url?.split('/');\r\n    const urlArray = url.split('/');\r\n    return itemArray?.every((value: string, index: number) => {\r\n      // console.log(value === urlArray[index], 'value:', value, 'index:', index, urlArray[index], url);\r\n      return value === urlArray[index];\r\n    });\r\n  }\r\n\r\n  openGroup(open: boolean): void {\r\n    this.open = open;\r\n  }\r\n\r\n  toggleGroup($event: any): void {\r\n    $event.preventDefault();\r\n    this.open = !this.open;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.navSubscription.unsubscribe();\r\n  }\r\n}\r\n","<ng-container *ngFor=\"let item of navItemsArray\">\r\n  <ng-container [ngSwitch]=\"helper.itemType(item)\">\r\n    <c-sidebar-nav-group\r\n      *ngSwitchCase=\"'group'\"\r\n      [item]=\"item\"\r\n      [ngClass]=\"item | cSidebarNavItemClass\"\r\n      routerLinkActive=\"show\"\r\n      #rla=\"routerLinkActive\"\r\n      [routerLinkActiveOptions]=\"{exact: true}\"\r\n    >\r\n    </c-sidebar-nav-group>\r\n    <c-sidebar-nav-divider\r\n      *ngSwitchCase=\"'divider'\"\r\n      [item]=\"item\"\r\n      [ngClass]=\"item | cSidebarNavItemClass\"\r\n      [cHtmlAttr]=\"item.attributes ?? {}\">\r\n    </c-sidebar-nav-divider>\r\n    <c-sidebar-nav-title\r\n      *ngSwitchCase=\"'title'\"\r\n      [item]=\"item\"\r\n      [ngClass]=\"item | cSidebarNavItemClass\"\r\n      [cHtmlAttr]=\"item.attributes ?? {}\">\r\n    </c-sidebar-nav-title>\r\n    <c-sidebar-nav-label\r\n      *ngSwitchCase=\"'label'\"\r\n      [item]=\"item\"\r\n      [ngClass]=\"item | cSidebarNavItemClass\">\r\n    </c-sidebar-nav-label>\r\n    <ng-container\r\n      *ngSwitchCase=\"'empty'\">\r\n    </ng-container>\r\n    <c-sidebar-nav-link\r\n      *ngSwitchDefault\r\n      [item]=\"item\"\r\n      [ngClass]=\"item | cSidebarNavItemClass\"\r\n      (linkClick)=\"hideMobile()\"\r\n    >\r\n    </c-sidebar-nav-link>\r\n  </ng-container>\r\n</ng-container>\r\n<ng-content></ng-content>\r\n","<a class=\"nav-link nav-group-toggle\"\r\n   (click)=\"toggleGroup($event)\"\r\n   [cHtmlAttr]=\"item.attributes\">\r\n  <ng-container *ngTemplateOutlet=\"iconTemplate ; context: {$implicit: item}\"></ng-container>\r\n  <ng-container>{{ item.name }}</ng-container>\r\n  <span *ngIf=\"helper.hasBadge(item)\" [ngClass]=\"item | cSidebarNavBadge\">{{ item.badge.text }}</span>\r\n</a>\r\n<c-sidebar-nav\r\n  [groupItems]=\"true\"\r\n  [navItems]=\"navItems\">\r\n</c-sidebar-nav>\r\n\r\n<ng-template #iconTemplate let-item>\r\n  <i *ngIf=\"item?.icon\" [ngClass]=\"item | cSidebarNavIcon\"></i>\r\n  <ng-template [ngIf]=\"item?.iconComponent\">\r\n    <svg\r\n      [cIcon]=\"item.iconComponent?.content\"\r\n      [name]=\"item.iconComponent?.name\"\r\n      [customClasses]=\"item | cSidebarNavIcon\"\r\n    ></svg>\r\n  </ng-template>\r\n  <span *ngIf=\"!item?.icon && !item?.iconComponent\" [ngClass]=\"item | cSidebarNavIcon\"></span>\r\n</ng-template>\r\n"]}