From 7ff1d2aed0be20effca61c5eb79a1758b4ac2652 Mon Sep 17 00:00:00 2001 From: Sercan Yemen Date: Mon, 2 Jul 2018 15:58:07 +0300 Subject: [PATCH] (Navbar) Scroll the active menu item into the view --- .../components/navbar/navbar.component.ts | 25 ++++++++++++++++++- 1 file changed, 24 insertions(+), 1 deletion(-) diff --git a/src/app/layout/components/navbar/navbar.component.ts b/src/app/layout/components/navbar/navbar.component.ts index c611f7c9..4809bb61 100644 --- a/src/app/layout/components/navbar/navbar.component.ts +++ b/src/app/layout/components/navbar/navbar.component.ts @@ -1,7 +1,7 @@ import { Component, Input, OnDestroy, OnInit, ViewChild, ViewEncapsulation } from '@angular/core'; import { NavigationEnd, Router } from '@angular/router'; import { Subject } from 'rxjs'; -import { filter, takeUntil } from 'rxjs/operators'; +import { filter, take, takeUntil } from 'rxjs/operators'; import { FuseNavigationService } from '@fuse/components/navigation/navigation.service'; import { FusePerfectScrollbarDirective } from '@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive'; @@ -61,6 +61,7 @@ export class NavbarComponent implements OnInit, OnDestroy this._fusePerfectScrollbar = theDirective; + // Update the scrollbar on collapsable item toggle this._fuseNavigationService.onItemCollapseToggled .pipe(takeUntil(this._unsubscribeAll)) .subscribe(() => { @@ -68,6 +69,28 @@ export class NavbarComponent implements OnInit, OnDestroy this._fusePerfectScrollbar.update(); }, 310); }); + + // Scroll to the active item position + this._router.events + .pipe( + filter((event) => event instanceof NavigationEnd), + take(1) + ) + .subscribe(() => { + setTimeout(() => { + const activeNavItem = document.querySelector('navbar .nav-link.active'); + + if ( activeNavItem ) + { + const activeItemOffsetTop = activeNavItem.offsetTop, + activeItemOffsetParentTop = activeNavItem.offsetParent.offsetTop, + scrollDistance = activeItemOffsetTop - activeItemOffsetParentTop - (48 * 3); + + this._fusePerfectScrollbar.scrollToTop(scrollDistance); + } + }); + } + ); } // -----------------------------------------------------------------------------------------------------