Commit 03668d01 by Ali Arshad

Added routing and layouts modules

parent 00046558
// The content below is only a placeholder and can be replaced.
div(style='text-align:center')
h1 Welcome to {{ title }}!
img(width='300', alt='Angular Logo', src='')
h2 Here are some links to help you start:
ul
li
h2
a(target='_blank', rel='noopener', href='https://angular.io/tutorial') Tour of Heroes
li
h2
a(target='_blank', rel='noopener', href='https://github.com/angular/angular-cli/wiki') CLI Documentation
li
h2
a(target='_blank', rel='noopener', href='https://blog.angular.io/') Angular blog
\ No newline at end of file
router-outlet
\ No newline at end of file
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import {BrowserModule} from '@angular/platform-browser';
import {NgModule} from '@angular/core';
import {LayoutsModule} from './layouts/layouts.module';
import {RoutesModule} from './routes/routes.module';
import { AppComponent } from './app.component';
import {AppComponent} from './app.component';
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule
],
providers: [],
bootstrap: [AppComponent]
declarations: [
AppComponent
],
imports: [
BrowserModule,
LayoutsModule,
RoutesModule
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
export class AppModule {
}
import {NgModule} from '@angular/core';
import {CommonModule} from '@angular/common';
import {RoutesModule} from '../routes/routes.module';
import {PublicComponent} from './public/public.component';
import {ProtectedComponent} from './protected/protected.component';
@NgModule({
imports: [
CommonModule,
RoutesModule
],
declarations: [PublicComponent, ProtectedComponent]
})
export class LayoutsModule {
}
//below line will be removed with actual layout
p protected works!
router-outlet
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { ProtectedComponent } from './protected.component';
describe('ProtectedComponent', () => {
let component: ProtectedComponent;
let fixture: ComponentFixture<ProtectedComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ ProtectedComponent ]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(ProtectedComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'app-protected',
templateUrl: './protected.component.pug',
styleUrls: ['./protected.component.less']
})
export class ProtectedComponent implements OnInit {
constructor() { }
ngOnInit() {
}
}
//below line will be removed with actual layout
p public works!
router-outlet
\ No newline at end of file
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { PublicComponent } from './public.component';
describe('PublicComponent', () => {
let component: PublicComponent;
let fixture: ComponentFixture<PublicComponent>;
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ PublicComponent ]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(PublicComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});
import { Component, OnInit } from '@angular/core';
import { Router } from '@angular/router';
@Component({
selector: 'app-public',
templateUrl: './public.component.pug',
styleUrls: ['./public.component.less']
})
export class PublicComponent implements OnInit {
constructor(
private router: Router,
) { }
ngOnInit() {
}
}
import {Injectable} from '@angular/core';
import {ActivatedRoute, ActivatedRouteSnapshot, CanActivate, Router, RouterStateSnapshot} from '@angular/router';
@Injectable()
export class AppGuard implements CanActivate {
constructor(private router: Router,
public activatedRoute: ActivatedRoute) {
// nothing in constructor
}
canActivate(next: ActivatedRouteSnapshot,
state: RouterStateSnapshot) {
let roles = next.data['roles'];
let user: any = {};
// specify route protection logic below
if (1) {
// logged in so return true
return true;
} else {
// not logged in so redirect to login page with the return url
return false;
}
}
}
import {NgModule} from '@angular/core';
import {RouterModule, Routes} from '@angular/router';
import {AppGuard} from './app.guard';
import {PublicComponent} from '../layouts/public/public.component';
import {ProtectedComponent} from '../layouts/protected/protected.component';
const routes: Routes = [
{
path: 'admin',
canActivate: [AppGuard],
data: {roles: ['admin']},
component: ProtectedComponent,
children: []
},
{
path: '',
component: PublicComponent,
children: []
},
];
@NgModule({
imports: [
RouterModule.forRoot(routes)
],
exports: [
RouterModule
],
declarations: [],
providers: [
AppGuard
]
})
export class RoutesModule {
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment