2016-07-08 18:03:48 +03:00
|
|
|
import {Component, ViewEncapsulation, Input, Output, EventEmitter} from '@angular/core';
|
2016-08-26 17:37:59 +03:00
|
|
|
import {Router, Routes, NavigationEnd} from '@angular/router';
|
2016-07-08 18:03:48 +03:00
|
|
|
import {Subscription} from 'rxjs/Rx';
|
|
|
|
|
|
|
|
|
|
import {BaMenuService} from './baMenu.service';
|
2016-08-26 17:37:59 +03:00
|
|
|
import {GlobalState} from '../../../global.state';
|
2016-07-08 18:03:48 +03:00
|
|
|
|
|
|
|
|
@Component({
|
|
|
|
|
selector: 'ba-menu',
|
|
|
|
|
encapsulation: ViewEncapsulation.None,
|
|
|
|
|
styles: [require('./baMenu.scss')],
|
|
|
|
|
template: require('./baMenu.html'),
|
2016-09-19 14:30:30 +03:00
|
|
|
providers: [BaMenuService]
|
2016-07-08 18:03:48 +03:00
|
|
|
})
|
|
|
|
|
export class BaMenu {
|
|
|
|
|
|
2016-08-26 17:37:59 +03:00
|
|
|
@Input() menuRoutes:Routes = [];
|
2016-07-08 18:03:48 +03:00
|
|
|
@Input() sidebarCollapsed:boolean = false;
|
|
|
|
|
@Input() menuHeight:number;
|
|
|
|
|
|
|
|
|
|
@Output() expandMenu = new EventEmitter<any>();
|
|
|
|
|
|
|
|
|
|
public menuItems:any[];
|
|
|
|
|
public showHoverElem:boolean;
|
|
|
|
|
public hoverElemHeight:number;
|
|
|
|
|
public hoverElemTop:number;
|
|
|
|
|
protected _onRouteChange:Subscription;
|
2016-07-11 11:09:35 +03:00
|
|
|
public outOfArea:number = -200;
|
2016-07-08 18:03:48 +03:00
|
|
|
|
2016-08-26 17:37:59 +03:00
|
|
|
constructor(private _router:Router, private _service:BaMenuService, private _state:GlobalState) {
|
2016-07-08 18:03:48 +03:00
|
|
|
this._onRouteChange = this._router.events.subscribe((event) => {
|
2016-07-14 12:05:05 +03:00
|
|
|
|
|
|
|
|
if (event instanceof NavigationEnd) {
|
|
|
|
|
if (this.menuItems) {
|
|
|
|
|
this.selectMenuAndNotify();
|
|
|
|
|
} else {
|
|
|
|
|
// on page load we have to wait as event is fired before menu elements are prepared
|
|
|
|
|
setTimeout(() => this.selectMenuAndNotify());
|
|
|
|
|
}
|
2016-07-08 18:03:48 +03:00
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-14 12:05:05 +03:00
|
|
|
public selectMenuAndNotify():void {
|
|
|
|
|
if (this.menuItems) {
|
|
|
|
|
this.menuItems = this._service.selectMenuItem(this.menuItems);
|
|
|
|
|
this._state.notifyDataChanged('menu.activeLink', this._service.getCurrentItem());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-08 18:03:48 +03:00
|
|
|
public ngOnInit():void {
|
|
|
|
|
this.menuItems = this._service.convertRoutesToMenus(this.menuRoutes);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public ngOnDestroy():void {
|
|
|
|
|
this._onRouteChange.unsubscribe();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public hoverItem($event):void {
|
|
|
|
|
this.showHoverElem = true;
|
|
|
|
|
this.hoverElemHeight = $event.currentTarget.clientHeight;
|
|
|
|
|
// TODO: get rid of magic 66 constant
|
|
|
|
|
this.hoverElemTop = $event.currentTarget.getBoundingClientRect().top - 66;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public toggleSubMenu($event):boolean {
|
|
|
|
|
var submenu = jQuery($event.currentTarget).next();
|
|
|
|
|
|
|
|
|
|
if (this.sidebarCollapsed) {
|
|
|
|
|
this.expandMenu.emit(null);
|
|
|
|
|
if (!$event.item.expanded) {
|
|
|
|
|
$event.item.expanded = true;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
$event.item.expanded = !$event.item.expanded;
|
|
|
|
|
submenu.slideToggle();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|