src/app/app.component.ts
selector | app-root |
styleUrls | ./app.component.scss |
templateUrl | ./app.component.html |
Properties |
constructor(router: Router, tokenStorage: TokenStorageService)
|
||||||||||||
Defined in src/app/app.component.ts:18
|
||||||||||||
Router import to show router-outlet.
Parameters :
|
isLoggedIn |
Default value : false
|
Defined in src/app/app.component.ts:18
|
showHeader |
Default value : false
|
Defined in src/app/app.component.ts:17
|
title |
Type : string
|
Default value : 'Aktienbot'
|
Defined in src/app/app.component.ts:15
|
Application title. |
import { Component } from '@angular/core';
import { NavigationEnd, Router } from '@angular/router';
import { TokenStorageService } from './Services/token.service';
import { filter } from 'rxjs/operators';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.scss'],
})
export class AppComponent {
/**
* Application title.
*/
title = 'Aktienbot';
showHeader = false;
isLoggedIn = false;
/**
* Router import to show router-outlet.
*
* @param router Router
*/
constructor(
private router: Router,
private tokenStorage: TokenStorageService
) {
//check if it is login or registration page, header should not show there
this.router.events
.pipe(filter((event) => event instanceof NavigationEnd))
.subscribe((event) => {
this.showHeader = !(
(event as NavigationEnd).url === '/login' ||
(event as NavigationEnd).url === '/register'
);
//check if token already exists from past login
if (this.tokenStorage.getToken()) {
this.isLoggedIn = true;
} else {
this.isLoggedIn = false;
}
//prevent user from accessing dashboard if not logged in
if (
this.isLoggedIn === false &&
(event as NavigationEnd).url != '/register'
) {
this.router.navigate(['/login']);
}
});
}
}
<app-header *ngIf="showHeader"></app-header>
<router-outlet></router-outlet>
./app.component.scss