mirror of
https://github.com/richard-loafle/fuse-angular.git
synced 2025-01-10 12:35:07 +00:00
Navigation service added, basic collapse functionality added to navigation, expand navigated item..
This commit is contained in:
parent
b5cc591ccc
commit
e98e37402a
|
@ -11,6 +11,8 @@ import {ChatModule} from './main/apps/chat/chat.module';
|
||||||
import {NavigationModule} from './navigation/navigation.module';
|
import {NavigationModule} from './navigation/navigation.module';
|
||||||
import {ProjectModule} from './main/apps/dashboards/project/project.module';
|
import {ProjectModule} from './main/apps/dashboards/project/project.module';
|
||||||
import {SharedModule} from './core/shared.module';
|
import {SharedModule} from './core/shared.module';
|
||||||
|
import {NavigationService} from './navigation/navigation.service';
|
||||||
|
import {CardedFullWidthModule} from './main/ui/page-layouts/carded/fullwidth/fullwidth.module';
|
||||||
|
|
||||||
const appRoutes: Routes = [
|
const appRoutes: Routes = [
|
||||||
{path: '**', redirectTo: 'apps/dashboards/project'}
|
{path: '**', redirectTo: 'apps/dashboards/project'}
|
||||||
|
@ -20,7 +22,7 @@ const appRoutes: Routes = [
|
||||||
declarations: [
|
declarations: [
|
||||||
AppComponent,
|
AppComponent,
|
||||||
LayoutComponent,
|
LayoutComponent,
|
||||||
ToolbarComponent
|
ToolbarComponent,
|
||||||
],
|
],
|
||||||
imports : [
|
imports : [
|
||||||
SharedModule,
|
SharedModule,
|
||||||
|
@ -33,9 +35,10 @@ const appRoutes: Routes = [
|
||||||
NavigationModule,
|
NavigationModule,
|
||||||
MailModule,
|
MailModule,
|
||||||
ChatModule,
|
ChatModule,
|
||||||
ProjectModule
|
ProjectModule,
|
||||||
|
CardedFullWidthModule
|
||||||
],
|
],
|
||||||
providers : [],
|
providers : [NavigationService],
|
||||||
bootstrap : [AppComponent]
|
bootstrap : [AppComponent]
|
||||||
})
|
})
|
||||||
export class AppModule
|
export class AppModule
|
||||||
|
|
|
@ -53,6 +53,6 @@ export class LayoutService
|
||||||
{
|
{
|
||||||
Object.assign(this.settings, newSettings);
|
Object.assign(this.settings, newSettings);
|
||||||
this.settingsChanged.emit(this.settings);
|
this.settingsChanged.emit(this.settings);
|
||||||
console.log('settings changed');
|
// console.log('settings changed');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,3 @@
|
||||||
|
<p>
|
||||||
|
FullWidth works!
|
||||||
|
</p>
|
|
@ -0,0 +1,25 @@
|
||||||
|
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
||||||
|
|
||||||
|
import { ChatComponent } from './fullwidth.component';
|
||||||
|
|
||||||
|
describe('ChatComponent', () => {
|
||||||
|
let component: ChatComponent;
|
||||||
|
let fixture: ComponentFixture<ChatComponent>;
|
||||||
|
|
||||||
|
beforeEach(async(() => {
|
||||||
|
TestBed.configureTestingModule({
|
||||||
|
declarations: [ ChatComponent ]
|
||||||
|
})
|
||||||
|
.compileComponents();
|
||||||
|
}));
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
fixture = TestBed.createComponent(ChatComponent);
|
||||||
|
component = fixture.componentInstance;
|
||||||
|
fixture.detectChanges();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be created', () => {
|
||||||
|
expect(component).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
|
@ -0,0 +1,19 @@
|
||||||
|
import {Component, OnInit} from '@angular/core';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector : 'fuse-chat',
|
||||||
|
templateUrl: './fullwidth.component.html',
|
||||||
|
styleUrls : ['./fullwidth.component.scss']
|
||||||
|
})
|
||||||
|
export class CardedFullWidthComponent implements OnInit
|
||||||
|
{
|
||||||
|
|
||||||
|
constructor()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
ngOnInit()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,23 @@
|
||||||
|
import {NgModule} from '@angular/core';
|
||||||
|
import {RouterModule, Routes} from '@angular/router';
|
||||||
|
import {CardedFullWidthComponent} from './fullwidth.component';
|
||||||
|
import {SharedModule} from '../../../../../core/shared.module';
|
||||||
|
|
||||||
|
const routes: Routes = [
|
||||||
|
{
|
||||||
|
path: 'user-interface/page-layouts/carded/full-width', component: CardedFullWidthComponent, children: []
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
@NgModule({
|
||||||
|
imports : [
|
||||||
|
SharedModule,
|
||||||
|
RouterModule.forChild(routes)
|
||||||
|
],
|
||||||
|
declarations: [
|
||||||
|
CardedFullWidthComponent
|
||||||
|
]
|
||||||
|
})
|
||||||
|
export class CardedFullWidthModule
|
||||||
|
{
|
||||||
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
<a class="nav-link" [routerLink]="[item.url]" md-ripple>
|
<a class="nav-link" md-ripple (click)="toggleOpen($event)">
|
||||||
<md-icon *ngIf="item.icon">{{item.icon}}</md-icon>
|
<md-icon *ngIf="item.icon">{{item.icon}}</md-icon>
|
||||||
<span>{{item.title}}</span>
|
<span>{{item.title}}</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
:host {
|
||||||
|
|
||||||
|
> .children {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
&.open {
|
||||||
|
> .children {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,19 +1,46 @@
|
||||||
import {Component, HostBinding, Input, OnInit} from '@angular/core';
|
import {Component, HostBinding, HostListener, Input, OnInit} from '@angular/core';
|
||||||
|
import {NavigationService} from '../navigation.service';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector : 'fuse-nav-collapse',
|
selector : 'fuse-nav-collapse',
|
||||||
templateUrl: './nav-collapse.component.html',
|
templateUrl: './nav-collapse.component.html',
|
||||||
styleUrls : ['./nav-collapse.component.scss']
|
styleUrls : ['./nav-collapse.component.scss'],
|
||||||
})
|
})
|
||||||
export class NavCollapseComponent implements OnInit
|
export class NavCollapseComponent implements OnInit
|
||||||
{
|
{
|
||||||
@HostBinding('class') classes = 'nav-collapse nav-item';
|
|
||||||
@Input() item: any;
|
@Input() item: any;
|
||||||
|
@HostBinding('class') classes = 'nav-collapse nav-item';
|
||||||
|
@HostBinding('class.open') public isOpen = false;
|
||||||
|
|
||||||
constructor()
|
constructor(private navigationService: NavigationService)
|
||||||
{
|
{
|
||||||
|
this.navigationService.navItemClicked.subscribe(
|
||||||
|
(instance) =>
|
||||||
|
{
|
||||||
|
// console.warn('navItemClicked', instance);
|
||||||
|
|
||||||
|
if ( !instance.includes(this.item.url) && this.isOpen )
|
||||||
|
{
|
||||||
|
this.isOpen = !this.isOpen;
|
||||||
|
}
|
||||||
|
console.warn(this.item.url, instance);
|
||||||
|
if ( instance.includes(this.item.url) && !this.isOpen )
|
||||||
|
{
|
||||||
|
this.isOpen = !this.isOpen;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
toggleOpen(event)
|
||||||
|
{
|
||||||
|
event.preventDefault();
|
||||||
|
this.isOpen = !this.isOpen;
|
||||||
|
this.navigationService.navItemClicked.emit(this.item.url);
|
||||||
|
console.log('toggleOpen');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
ngOnInit()
|
ngOnInit()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
<a class="nav-link" [routerLink]="[item.url]" routerLinkActive="active" md-ripple>
|
<a class="nav-link" md-ripple
|
||||||
|
[routerLink]="[item.url]" routerLinkActive="active"
|
||||||
|
(click)="onClick()">
|
||||||
<md-icon *ngIf="item.icon">{{item.icon}}</md-icon>
|
<md-icon *ngIf="item.icon">{{item.icon}}</md-icon>
|
||||||
<span>{{item.title}}</span>
|
<span>{{item.title}}</span>
|
||||||
</a>
|
</a>
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
import {Component, HostBinding, Input, OnInit, ViewEncapsulation} from '@angular/core';
|
import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';
|
||||||
|
import {NavigationService} from '../navigation.service';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector : 'fuse-nav-item',
|
selector : 'fuse-nav-item',
|
||||||
|
@ -10,7 +11,7 @@ export class NavItemComponent implements OnInit
|
||||||
@HostBinding('class') classes = 'nav-item';
|
@HostBinding('class') classes = 'nav-item';
|
||||||
@Input() item: any;
|
@Input() item: any;
|
||||||
|
|
||||||
constructor()
|
constructor(private navigationService: NavigationService)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -18,4 +19,9 @@ export class NavItemComponent implements OnInit
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onClick()
|
||||||
|
{
|
||||||
|
console.log('clicked');
|
||||||
|
this.navigationService.navItemClicked.emit(this.item.url);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
background-color: map-get($background, raised-button);
|
background-color: map-get($background, raised-button);
|
||||||
color: map_get($foreground, text);
|
color: map_get($foreground, text);
|
||||||
|
cursor: pointer;
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
background-color: map-get($background, hover);
|
background-color: map-get($background, hover);
|
||||||
|
|
|
@ -1,21 +1,19 @@
|
||||||
import {Component, OnInit, ViewEncapsulation} from '@angular/core';
|
import {Component, EventEmitter, OnInit, ViewEncapsulation} from '@angular/core';
|
||||||
import {FuseNavigation} from './navigation.model';
|
import {NavigationService} from './navigation.service';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector : 'fuse-navigation',
|
selector : 'fuse-navigation',
|
||||||
templateUrl: './navigation.component.html',
|
templateUrl : './navigation.component.html',
|
||||||
styleUrls : ['./navigation.component.scss'],
|
styleUrls : ['./navigation.component.scss'],
|
||||||
providers : [FuseNavigation],
|
encapsulation: ViewEncapsulation.None,
|
||||||
encapsulation: ViewEncapsulation.None
|
|
||||||
|
|
||||||
})
|
})
|
||||||
export class NavigationComponent implements OnInit
|
export class NavigationComponent implements OnInit
|
||||||
{
|
{
|
||||||
navigation: object[];
|
navigation: object[];
|
||||||
|
|
||||||
constructor(fuseNavigation: FuseNavigation)
|
constructor(private navigationService: NavigationService)
|
||||||
{
|
{
|
||||||
this.navigation = fuseNavigation.array;
|
this.navigation = navigationService.getNavigation();
|
||||||
}
|
}
|
||||||
|
|
||||||
ngOnInit()
|
ngOnInit()
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
export class FuseNavigation
|
export class FuseNavigation
|
||||||
{
|
{
|
||||||
array = [
|
items = [
|
||||||
{
|
{
|
||||||
'title': 'APPS',
|
'title': 'APPS',
|
||||||
'type' : 'subheader'
|
'type' : 'subheader'
|
||||||
|
@ -9,17 +9,17 @@ export class FuseNavigation
|
||||||
'title' : 'Dashboards',
|
'title' : 'Dashboards',
|
||||||
'type' : 'nav-collapse',
|
'type' : 'nav-collapse',
|
||||||
'icon' : 'dashboard',
|
'icon' : 'dashboard',
|
||||||
'url' : 'apps/dashboards',
|
'url' : '/apps/dashboards',
|
||||||
'children': [
|
'children': [
|
||||||
{
|
{
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'title': 'Project',
|
'title': 'Project',
|
||||||
'url' : 'apps/dashboards/project'
|
'url' : '/apps/dashboards/project'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'title': 'Server',
|
'title': 'Server',
|
||||||
'url' : 'apps-dashboards-server'
|
'url' : '/apps/dashboards/server'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -27,28 +27,28 @@ export class FuseNavigation
|
||||||
'title': 'Calendar',
|
'title': 'Calendar',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'today',
|
'icon' : 'today',
|
||||||
'url' : 'apps-calendar'
|
'url' : '/apps/calendar'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title' : 'Ecommerce',
|
'title' : 'Ecommerce',
|
||||||
'type' : 'nav-collapse',
|
'type' : 'nav-collapse',
|
||||||
'icon' : 'shopping_cart',
|
'icon' : 'shopping_cart',
|
||||||
'url' : 'apps-e-commerce-',
|
'url' : '/apps/e-commerce',
|
||||||
'children': [
|
'children': [
|
||||||
{
|
{
|
||||||
'title': 'Products',
|
'title': 'Products',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'apps-e-commerce-products'
|
'url' : '/apps/e-commerce/products'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Product',
|
'title': 'Product',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'apps-e-commerce-product'
|
'url' : '/apps/e-commerce/product'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Orders',
|
'title': 'Orders',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'apps-e-commerce-orders'
|
'url' : '/apps/e-commerce/orders'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -56,31 +56,31 @@ export class FuseNavigation
|
||||||
'title': 'Mail',
|
'title': 'Mail',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'email',
|
'icon' : 'email',
|
||||||
'url' : 'apps/mail'
|
'url' : '/apps/mail'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Chat',
|
'title': 'Chat',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'chat',
|
'icon' : 'chat',
|
||||||
'url' : 'apps/chat'
|
'url' : '/apps/chat'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'File Manager',
|
'title': 'File Manager',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'folder',
|
'icon' : 'folder',
|
||||||
'url' : 'apps-file-manager'
|
'url' : '/apps/file-manager'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Contacts',
|
'title': 'Contacts',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'account_box',
|
'icon' : 'account_box',
|
||||||
'url' : 'apps-contacts'
|
'url' : '/apps/contacts'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'To-Do',
|
'title': 'To-Do',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'checkbox_cricle',
|
'icon' : 'checkbox_cricle',
|
||||||
'url' : 'apps-todo'
|
'url' : '/apps/todo'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'PAGES',
|
'title': 'PAGES',
|
||||||
|
@ -90,42 +90,42 @@ export class FuseNavigation
|
||||||
'title' : 'Authentication',
|
'title' : 'Authentication',
|
||||||
'type' : 'nav-collapse',
|
'type' : 'nav-collapse',
|
||||||
'icon' : 'lock',
|
'icon' : 'lock',
|
||||||
'url' : 'pages-auth-',
|
'url' : '/pages/auth',
|
||||||
'children': [
|
'children': [
|
||||||
{
|
{
|
||||||
'title': 'Login',
|
'title': 'Login',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'pages-auth-login'
|
'url' : '/pages/auth/login'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Login v2',
|
'title': 'Login v2',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'pages-auth-login-v2'
|
'url' : '/pages/auth/login-v2'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Register',
|
'title': 'Register',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'pages-auth-register'
|
'url' : '/pages/auth/register'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Register v2',
|
'title': 'Register v2',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'pages-auth-register-v2'
|
'url' : '/pages/auth/register-v2'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Forgot Password',
|
'title': 'Forgot Password',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'pages-auth-forgot-password'
|
'url' : '/pages/auth/forgot-password'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Reset Password',
|
'title': 'Reset Password',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'pages-auth-reset-password'
|
'url' : '/pages/auth/reset-password'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Lock Screen',
|
'title': 'Lock Screen',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'pages-auth-lock-screen'
|
'url' : '/pages/auth/lock-screen'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -133,23 +133,23 @@ export class FuseNavigation
|
||||||
'title': 'Coming Soon',
|
'title': 'Coming Soon',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'alarm',
|
'icon' : 'alarm',
|
||||||
'url' : 'pages-coming-soon'
|
'url' : '/pages/coming-soon'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title' : 'Errors',
|
'title' : 'Errors',
|
||||||
'type' : 'nav-collapse',
|
'type' : 'nav-collapse',
|
||||||
'icon' : 'error',
|
'icon' : 'error',
|
||||||
'url' : 'pages-errors-',
|
'url' : '/pages/errors',
|
||||||
'children': [
|
'children': [
|
||||||
{
|
{
|
||||||
'title': '404',
|
'title': '404',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'pages-errors-404'
|
'url' : '/pages/errors/404'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': '500',
|
'title': '500',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'pages-errors-500'
|
'url' : '/pages/errors/500'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -157,19 +157,19 @@ export class FuseNavigation
|
||||||
'title': 'Maintenance',
|
'title': 'Maintenance',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'build',
|
'icon' : 'build',
|
||||||
'url' : 'pages-maintenance'
|
'url' : '/pages/maintenance'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Profile',
|
'title': 'Profile',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'account',
|
'icon' : 'account',
|
||||||
'url' : 'pages-profile'
|
'url' : '/pages/profile'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Search',
|
'title': 'Search',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'search',
|
'icon' : 'search',
|
||||||
'url' : 'pages-search'
|
'url' : '/pages/search'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'USER INTERFACE',
|
'title': 'USER INTERFACE',
|
||||||
|
@ -179,82 +179,82 @@ export class FuseNavigation
|
||||||
'title' : 'Elements',
|
'title' : 'Elements',
|
||||||
'type' : 'nav-collapse',
|
'type' : 'nav-collapse',
|
||||||
'icon' : 'layers',
|
'icon' : 'layers',
|
||||||
'url' : 'user-interface-elements-',
|
'url' : '/user-interface/elements',
|
||||||
'children': [
|
'children': [
|
||||||
{
|
{
|
||||||
'title': 'Alerts',
|
'title': 'Alerts',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-alerts'
|
'url' : '/user-interface/elements/alerts'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Badges',
|
'title': 'Badges',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-badges'
|
'url' : '/user-interface/elements/badges'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Breadcrumb',
|
'title': 'Breadcrumb',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-breadcrumb'
|
'url' : '/user-interface/elements/breadcrumb'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Buttons',
|
'title': 'Buttons',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-buttons'
|
'url' : '/user-interface/elements/buttons'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Button Group',
|
'title': 'Button Group',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-button-group'
|
'url' : '/user-interface/elements/button-group'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Cards',
|
'title': 'Cards',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-cards'
|
'url' : '/user-interface/elements/cards'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Dropdowns',
|
'title': 'Dropdowns',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-dropdowns'
|
'url' : '/user-interface/elements/dropdowns'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Forms',
|
'title': 'Forms',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-forms'
|
'url' : '/user-interface/elements/forms'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Input Group',
|
'title': 'Input Group',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-input-group'
|
'url' : '/user-interface/elements/input-group'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Jumbotron',
|
'title': 'Jumbotron',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-jumbotron'
|
'url' : '/user-interface/elements/jumbotron'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'List Group',
|
'title': 'List Group',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-list-group'
|
'url' : '/user-interface/elements/list-group'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Navs',
|
'title': 'Navs',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-navs'
|
'url' : '/user-interface/elements/navs'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Navbar',
|
'title': 'Navbar',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-navbar'
|
'url' : '/user-interface/elements/navbar'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Pagination',
|
'title': 'Pagination',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-pagination'
|
'url' : '/user-interface/elements/pagination'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Progress',
|
'title': 'Progress',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-elements-progress'
|
'url' : '/user-interface/elements/progress'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -262,17 +262,17 @@ export class FuseNavigation
|
||||||
'title' : 'Tables',
|
'title' : 'Tables',
|
||||||
'type' : 'nav-collapse',
|
'type' : 'nav-collapse',
|
||||||
'icon' : 'border_all',
|
'icon' : 'border_all',
|
||||||
'url' : 'user-interface-tables-',
|
'url' : '/user-interface/tables',
|
||||||
'children': [
|
'children': [
|
||||||
{
|
{
|
||||||
'title': 'Simple Table',
|
'title': 'Simple Table',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-tables-simple-table'
|
'url' : '/user-interface/tables/simple-table'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Data Table',
|
'title': 'Data Table',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-tables-data-table'
|
'url' : '/user-interface/tables/data-table'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -280,81 +280,81 @@ export class FuseNavigation
|
||||||
'title' : 'Page Layouts',
|
'title' : 'Page Layouts',
|
||||||
'type' : 'nav-collapse',
|
'type' : 'nav-collapse',
|
||||||
'icon' : 'view_quilt',
|
'icon' : 'view_quilt',
|
||||||
'url' : 'user-interface-page-layouts-',
|
'url' : 'page-layouts',
|
||||||
'children': [
|
'children': [
|
||||||
{
|
{
|
||||||
'title' : 'Carded',
|
'title' : 'Carded',
|
||||||
'type' : 'nav-collapse',
|
'type' : 'nav-collapse',
|
||||||
'url' : 'user-interface-page-layouts-carded-',
|
'url' : '/user-interface/page-layouts/carded',
|
||||||
'children': [
|
'children': [
|
||||||
{
|
{
|
||||||
'title': 'Full Width',
|
'title': 'Full Width',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-page-layouts-carded-full-width'
|
'url' : '/user-interface/page-layouts/carded/full-width'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Left Sidebar',
|
'title': 'Left Sidebar',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-page-layouts-carded-left-sidebar'
|
'url' : '/user-interface/page-layouts/carded/left-sidebar'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Right Sidebar',
|
'title': 'Right Sidebar',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-page-layouts-carded-right-sidebar'
|
'url' : '/user-interface/page-layouts/carded/right-sidebar'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title' : 'Simple',
|
'title' : 'Simple',
|
||||||
'type' : 'nav-collapse',
|
'type' : 'nav-collapse',
|
||||||
'url' : 'user-interface-page-layouts-simple-',
|
'url' : '/user-interface/page-layouts/simple',
|
||||||
'children': [
|
'children': [
|
||||||
{
|
{
|
||||||
'title': 'Full Width',
|
'title': 'Full Width',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-page-layouts-simple-full-width'
|
'url' : '/user-interface/page-layouts/simple/full-width'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Left Sidebar',
|
'title': 'Left Sidebar',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-page-layouts-simple-left-sidebar'
|
'url' : '/user-interface/page-layouts/simple/left-sidebar'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Left Sidebar Inner',
|
'title': 'Left Sidebar Inner',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-page-layouts-simple-left-sidebar-inner'
|
'url' : '/user-interface/page-layouts/simple/left-sidebar-inner'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Left Sidebar Floating',
|
'title': 'Left Sidebar Floating',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-page-layouts-simple-left-sidebar-floating'
|
'url' : '/user-interface/page-layouts/simple/left-sidebar-floating'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Right Sidebar',
|
'title': 'Right Sidebar',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-page-layouts-simple-right-sidebar'
|
'url' : '/user-interface/page-layouts/simple/right-sidebar'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Right Sidebar Inner',
|
'title': 'Right Sidebar Inner',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-page-layouts-simple-right-sidebar-inner'
|
'url' : '/user-interface/page-layouts/simple/sidebar-inner'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Right Sidebar Floating',
|
'title': 'Right Sidebar Floating',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-page-layouts-simple-right-sidebar-floating'
|
'url' : '/user-interface/page-layouts/simple/right-sidebar-floating'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Tabbed',
|
'title': 'Tabbed',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-page-layouts-simple-tabbed'
|
'url' : '/user-interface/page-layouts/simple/tabbed'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Blank',
|
'title': 'Blank',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'user-interface-page-layouts-blank'
|
'url' : '/user-interface/page-layouts/blank'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -362,7 +362,7 @@ export class FuseNavigation
|
||||||
'title': 'Colors',
|
'title': 'Colors',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'color_lens',
|
'icon' : 'color_lens',
|
||||||
'url' : 'user-interface-colors'
|
'url' : '/user-interface/colors'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'COMPONENTS',
|
'title': 'COMPONENTS',
|
||||||
|
@ -371,13 +371,13 @@ export class FuseNavigation
|
||||||
{
|
{
|
||||||
'title' : 'Charts',
|
'title' : 'Charts',
|
||||||
'type' : 'nav-collapse',
|
'type' : 'nav-collapse',
|
||||||
'url' : 'components-charts-',
|
'url' : '/components/charts',
|
||||||
'icon' : 'poll',
|
'icon' : 'poll',
|
||||||
'children': [
|
'children': [
|
||||||
{
|
{
|
||||||
'title': 'nvD3',
|
'title': 'nvD3',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'url' : 'components-charts-nvd3'
|
'url' : '/components/charts/nvd3'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -385,31 +385,31 @@ export class FuseNavigation
|
||||||
'title': 'Collapse',
|
'title': 'Collapse',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'add_box',
|
'icon' : 'add_box',
|
||||||
'url' : 'components-collapse'
|
'url' : '/components/collapse'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Modal',
|
'title': 'Modal',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'picture_in_picture',
|
'icon' : 'picture_in_picture',
|
||||||
'url' : 'components-modal'
|
'url' : '/components/modal'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Popovers',
|
'title': 'Popovers',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'chat_buble',
|
'icon' : 'chat_buble',
|
||||||
'url' : 'components-popovers'
|
'url' : '/components/popovers'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Snackbar',
|
'title': 'Snackbar',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'call_to_action',
|
'icon' : 'call_to_action',
|
||||||
'url' : 'components-snackbar'
|
'url' : '/components/snackbar'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'title': 'Tooltips',
|
'title': 'Tooltips',
|
||||||
'type' : 'nav-item',
|
'type' : 'nav-item',
|
||||||
'icon' : 'live_help',
|
'icon' : 'live_help',
|
||||||
'url' : 'components-tooltips'
|
'url' : '/components/tooltips'
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,7 @@ import {NavCollapseComponent} from './nav-collapse/nav-collapse.component';
|
||||||
NavSubheaderComponent,
|
NavSubheaderComponent,
|
||||||
NavItemComponent,
|
NavItemComponent,
|
||||||
NavCollapseComponent
|
NavCollapseComponent
|
||||||
]
|
],
|
||||||
})
|
})
|
||||||
export class NavigationModule
|
export class NavigationModule
|
||||||
{
|
{
|
||||||
|
|
38
src/app/navigation/navigation.service.ts
Normal file
38
src/app/navigation/navigation.service.ts
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
import {EventEmitter, Injectable} from '@angular/core';
|
||||||
|
import {NavigationEnd, NavigationStart, Router} from '@angular/router';
|
||||||
|
import {FuseNavigation} from './navigation.model';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class NavigationService
|
||||||
|
{
|
||||||
|
navItemClicked = new EventEmitter<any>();
|
||||||
|
clickedItemUrl: string;
|
||||||
|
navigation: object[];
|
||||||
|
|
||||||
|
constructor(private router: Router)
|
||||||
|
{
|
||||||
|
this.navigation = new FuseNavigation().items;
|
||||||
|
router.events.subscribe(
|
||||||
|
(event) =>
|
||||||
|
{
|
||||||
|
if ( event instanceof NavigationEnd )
|
||||||
|
{
|
||||||
|
console.warn('event', event);
|
||||||
|
this.navItemClicked.emit(event.urlAfterRedirects);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
this.navItemClicked.subscribe(
|
||||||
|
(instance) =>
|
||||||
|
{
|
||||||
|
console.log('instance', instance);
|
||||||
|
this.clickedItemUrl = instance;
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
getNavigation()
|
||||||
|
{
|
||||||
|
return this.navigation;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user