mirror of
https://github.com/akveo/ngx-admin.git
synced 2025-12-17 07:50:12 +01:00
feat(sidebar): add menu sidebar updating (#548)
* feat(sidebar): add menu sidebar updating Relates to issue #236 * refactor(sidebar): move menu initialization into app component Also fix BaMenuService provider (move it into module providers from component providers) * refactor(sidebar): move baMenuService to services directory
This commit is contained in:
parent
b78e72dde9
commit
05e17d24df
9 changed files with 42 additions and 19 deletions
|
|
@ -1,10 +1,14 @@
|
||||||
|
import { Routes } from '@angular/router';
|
||||||
import './app.loader.ts';
|
import './app.loader.ts';
|
||||||
import { Component, ViewEncapsulation, ViewContainerRef } from '@angular/core';
|
import { Component, ViewEncapsulation, ViewContainerRef } from '@angular/core';
|
||||||
import { GlobalState } from './global.state';
|
import { GlobalState } from './global.state';
|
||||||
import { BaImageLoaderService, BaThemePreloader, BaThemeSpinner } from './theme/services';
|
import { BaImageLoaderService, BaThemePreloader, BaThemeSpinner } from './theme/services';
|
||||||
import { layoutPaths } from './theme/theme.constants';
|
import { layoutPaths } from './theme/theme.constants';
|
||||||
import { BaThemeConfig } from './theme/theme.config';
|
import { BaThemeConfig } from './theme/theme.config';
|
||||||
|
import { BaMenuService } from './theme';
|
||||||
import {ComponentsHelper } from 'ng2-bootstrap';
|
import {ComponentsHelper } from 'ng2-bootstrap';
|
||||||
|
|
||||||
|
import { MENU } from './app.menu';
|
||||||
/*
|
/*
|
||||||
* App Component
|
* App Component
|
||||||
* Top Level Component
|
* Top Level Component
|
||||||
|
|
@ -28,8 +32,11 @@ export class App {
|
||||||
private _imageLoader: BaImageLoaderService,
|
private _imageLoader: BaImageLoaderService,
|
||||||
private _spinner: BaThemeSpinner,
|
private _spinner: BaThemeSpinner,
|
||||||
private _config: BaThemeConfig,
|
private _config: BaThemeConfig,
|
||||||
|
private _menuService: BaMenuService,
|
||||||
private viewContainerRef: ViewContainerRef) {
|
private viewContainerRef: ViewContainerRef) {
|
||||||
|
|
||||||
|
this._menuService.updateMenuByRoutes(<Routes>MENU);
|
||||||
|
|
||||||
this._fixModals();
|
this._fixModals();
|
||||||
|
|
||||||
this._loadImages();
|
this._loadImages();
|
||||||
|
|
|
||||||
|
|
@ -2,25 +2,24 @@ import {Component, ViewEncapsulation, Input, Output, EventEmitter} from '@angula
|
||||||
import {Router, Routes, NavigationEnd} from '@angular/router';
|
import {Router, Routes, NavigationEnd} from '@angular/router';
|
||||||
import {Subscription} from 'rxjs/Rx';
|
import {Subscription} from 'rxjs/Rx';
|
||||||
|
|
||||||
import {BaMenuService} from './baMenu.service';
|
import { BaMenuService } from '../../services';
|
||||||
import {GlobalState} from '../../../global.state';
|
import {GlobalState} from '../../../global.state';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'ba-menu',
|
selector: 'ba-menu',
|
||||||
encapsulation: ViewEncapsulation.None,
|
encapsulation: ViewEncapsulation.None,
|
||||||
styles: [require('./baMenu.scss')],
|
styles: [require('./baMenu.scss')],
|
||||||
template: require('./baMenu.html'),
|
template: require('./baMenu.html')
|
||||||
providers: [BaMenuService]
|
|
||||||
})
|
})
|
||||||
export class BaMenu {
|
export class BaMenu {
|
||||||
|
|
||||||
@Input() menuRoutes:Routes = [];
|
|
||||||
@Input() sidebarCollapsed:boolean = false;
|
@Input() sidebarCollapsed:boolean = false;
|
||||||
@Input() menuHeight:number;
|
@Input() menuHeight:number;
|
||||||
|
|
||||||
@Output() expandMenu = new EventEmitter<any>();
|
@Output() expandMenu = new EventEmitter<any>();
|
||||||
|
|
||||||
public menuItems:any[];
|
public menuItems: any[];
|
||||||
|
protected _menuItemsSub: Subscription;
|
||||||
public showHoverElem:boolean;
|
public showHoverElem:boolean;
|
||||||
public hoverElemHeight:number;
|
public hoverElemHeight:number;
|
||||||
public hoverElemTop:number;
|
public hoverElemTop:number;
|
||||||
|
|
@ -39,6 +38,13 @@ export class BaMenu {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
this._menuItemsSub = this._service.menuItems.subscribe(this.updateMenu.bind(this));
|
||||||
|
}
|
||||||
|
|
||||||
|
public updateMenu(newMenuItems) {
|
||||||
|
this.menuItems = newMenuItems;
|
||||||
|
this.selectMenuAndNotify();
|
||||||
}
|
}
|
||||||
|
|
||||||
public selectMenuAndNotify():void {
|
public selectMenuAndNotify():void {
|
||||||
|
|
@ -49,11 +55,11 @@ export class BaMenu {
|
||||||
}
|
}
|
||||||
|
|
||||||
public ngOnInit():void {
|
public ngOnInit():void {
|
||||||
this.menuItems = this._service.convertRoutesToMenus(this.menuRoutes);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public ngOnDestroy():void {
|
public ngOnDestroy():void {
|
||||||
this._onRouteChange.unsubscribe();
|
this._onRouteChange.unsubscribe();
|
||||||
|
this._menuItemsSub.unsubscribe();
|
||||||
}
|
}
|
||||||
|
|
||||||
public hoverItem($event):void {
|
public hoverItem($event):void {
|
||||||
|
|
|
||||||
|
|
@ -1,8 +1,6 @@
|
||||||
import {Component, ElementRef, HostListener, ViewEncapsulation} from '@angular/core';
|
import {Component, ElementRef, HostListener, ViewEncapsulation} from '@angular/core';
|
||||||
import {GlobalState} from '../../../global.state';
|
import {GlobalState} from '../../../global.state';
|
||||||
import {layoutSizes} from '../../../theme';
|
import {layoutSizes} from '../../../theme';
|
||||||
import {MENU} from '../../../../app/app.menu';
|
|
||||||
import * as _ from 'lodash';
|
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'ba-sidebar',
|
selector: 'ba-sidebar',
|
||||||
|
|
@ -11,10 +9,6 @@ import * as _ from 'lodash';
|
||||||
template: require('./baSidebar.html')
|
template: require('./baSidebar.html')
|
||||||
})
|
})
|
||||||
export class BaSidebar {
|
export class BaSidebar {
|
||||||
|
|
||||||
// here we declare which routes we want to use as a menu in our sidebar
|
|
||||||
public routes = _.cloneDeep(MENU); // we're creating a deep copy since we are going to change that object
|
|
||||||
|
|
||||||
public menuHeight:number;
|
public menuHeight:number;
|
||||||
public isMenuCollapsed:boolean = false;
|
public isMenuCollapsed:boolean = false;
|
||||||
public isMenuShouldCollapsed:boolean = false;
|
public isMenuShouldCollapsed:boolean = false;
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,5 @@
|
||||||
<aside class="al-sidebar" (mouseleave)="hoverElemTop=outOfArea" sidebarResize>
|
<aside class="al-sidebar" (mouseleave)="hoverElemTop=outOfArea" sidebarResize>
|
||||||
<ba-menu [menuRoutes]="routes"
|
<ba-menu [menuHeight]="menuHeight"
|
||||||
[menuHeight]="menuHeight"
|
|
||||||
[sidebarCollapsed]="isMenuCollapsed"
|
[sidebarCollapsed]="isMenuCollapsed"
|
||||||
(expandMenu)="menuExpand()"></ba-menu>
|
(expandMenu)="menuExpand()"></ba-menu>
|
||||||
</aside>
|
</aside>
|
||||||
|
|
|
||||||
|
|
@ -1,3 +1,4 @@
|
||||||
export * from './theme.constants'
|
export { BaMenuService } from './services';
|
||||||
export * from './theme.configProvider'
|
export * from './theme.constants';
|
||||||
export * from './theme.config'
|
export * from './theme.configProvider';
|
||||||
|
export * from './theme.config';
|
||||||
|
|
|
||||||
|
|
@ -44,6 +44,7 @@ import {
|
||||||
|
|
||||||
import {
|
import {
|
||||||
BaImageLoaderService,
|
BaImageLoaderService,
|
||||||
|
BaMenuService,
|
||||||
BaThemePreloader,
|
BaThemePreloader,
|
||||||
BaThemeSpinner
|
BaThemeSpinner
|
||||||
} from './services';
|
} from './services';
|
||||||
|
|
@ -86,7 +87,8 @@ const NGA_PIPES = [
|
||||||
const NGA_SERVICES = [
|
const NGA_SERVICES = [
|
||||||
BaImageLoaderService,
|
BaImageLoaderService,
|
||||||
BaThemePreloader,
|
BaThemePreloader,
|
||||||
BaThemeSpinner
|
BaThemeSpinner,
|
||||||
|
BaMenuService
|
||||||
];
|
];
|
||||||
|
|
||||||
const NGA_VALIDATORS = [
|
const NGA_VALIDATORS = [
|
||||||
|
|
|
||||||
|
|
@ -1,12 +1,24 @@
|
||||||
import {Injectable} from '@angular/core';
|
import {Injectable} from '@angular/core';
|
||||||
import {Router, Routes} from '@angular/router';
|
import {Router, Routes} from '@angular/router';
|
||||||
|
|
||||||
|
import { BehaviorSubject } from 'rxjs/BehaviorSubject';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class BaMenuService {
|
export class BaMenuService {
|
||||||
|
menuItems = new BehaviorSubject<any[]>([]);
|
||||||
|
|
||||||
protected _currentMenuItem = {};
|
protected _currentMenuItem = {};
|
||||||
|
|
||||||
constructor(private _router:Router) {
|
constructor(private _router:Router) { }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Updates the routes in the menu
|
||||||
|
*
|
||||||
|
* @param {Routes} routes Type compatible with app.menu.ts
|
||||||
|
*/
|
||||||
|
public updateMenuByRoutes(routes: Routes) {
|
||||||
|
let convertedRoutes = this.convertRoutesToMenus(_.cloneDeep(routes));
|
||||||
|
this.menuItems.next(convertedRoutes);
|
||||||
}
|
}
|
||||||
|
|
||||||
public convertRoutesToMenus(routes:Routes):any[] {
|
public convertRoutesToMenus(routes:Routes):any[] {
|
||||||
1
src/app/theme/services/baMenu/index.ts
Normal file
1
src/app/theme/services/baMenu/index.ts
Normal file
|
|
@ -0,0 +1 @@
|
||||||
|
export * from './baMenu.service';
|
||||||
|
|
@ -1,3 +1,4 @@
|
||||||
export * from './baImageLoader';
|
export * from './baImageLoader';
|
||||||
|
export * from './baMenu';
|
||||||
export * from './baThemePreloader';
|
export * from './baThemePreloader';
|
||||||
export * from './baThemeSpinner';
|
export * from './baThemeSpinner';
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue