aboutsummaryrefslogtreecommitdiff
path: root/src/app
diff options
context:
space:
mode:
authorSyndamia <kamen.d.mladenov@protonmail.com>2021-03-19 16:15:53 +0200
committerSyndamia <kamen.d.mladenov@protonmail.com>2021-03-19 16:15:53 +0200
commit90003ad1e0342fc6e87b844fbbb05870ac128308 (patch)
tree5cc64dab126ec64449f0e21a6818656d7a11f7b4 /src/app
parent5916079f20c5cd36e4092fd717c1bcc8814670f7 (diff)
downloadDevHive-Angular-90003ad1e0342fc6e87b844fbbb05870ac128308.tar
DevHive-Angular-90003ad1e0342fc6e87b844fbbb05870ac128308.tar.gz
DevHive-Angular-90003ad1e0342fc6e87b844fbbb05870ac128308.zip
Fixed navbar component not handling logged out user properly
Diffstat (limited to 'src/app')
-rw-r--r--src/app/components/navbar/navbar.component.html17
-rw-r--r--src/app/components/navbar/navbar.component.ts17
2 files changed, 25 insertions, 9 deletions
diff --git a/src/app/components/navbar/navbar.component.html b/src/app/components/navbar/navbar.component.html
index 2d386aa..6bd3e66 100644
--- a/src/app/components/navbar/navbar.component.html
+++ b/src/app/components/navbar/navbar.component.html
@@ -1,9 +1,12 @@
<nav id="navbar">
<div id="nav-contents" class="flex-row padding-smaller flex-center-align-items">
- <div id="nav-profile-picture" class="nav-item flex-col border-radius-small light-hover hover-half-opacity click-effect" (click)="goToProfile()">
+ <div class="flexible" *ngIf="!loggedIn">
+ <!-- This element serves as a spacer -->
+ </div>
+ <div id="nav-profile-picture" class="nav-item flex-col border-radius-small light-hover hover-half-opacity click-effect" (click)="goToProfile()" *ngIf="loggedIn">
<img class="round-image" [src]="user.profilePictureURL">
</div>
- <div id="nav-username" class="font-size-dot9 nav-item flex-col border-radius-small light-hover hover-half-opacity click-effect" (click)="goToProfile()">
+ <div id="nav-username" class="font-size-dot9 nav-item flex-col border-radius-small light-hover hover-half-opacity click-effect" (click)="goToProfile()" *ngIf="loggedIn">
<div class="padding-small">
Konstantin
</div>
@@ -26,11 +29,17 @@
<div class="flexible">
<!-- This element serves as a spacer -->
</div>
- <div class="nav-item flex-col border-radius-small light-hover hover-half-opacity click-effect" (click)="goToSettings()">
+ <div class="nav-item flex-col border-radius-small light-hover hover-half-opacity click-effect" (click)="goToSettings()" *ngIf="loggedIn">
<img src="/assets/icons/tabler-icon-settings.svg">
</div>
- <div class="nav-item flex-col border-radius-small light-hover hover-half-opacity click-effect" (click)="logout()">
+ <div class="nav-item flex-col border-radius-small light-hover hover-half-opacity click-effect" (click)="logout()" *ngIf="loggedIn">
<img src="/assets/icons/tabler-icon-logout.svg">
</div>
+ <div class="nav-item flex-col border-radius-small light-hover hover-half-opacity click-effect" (click)="goToLogin()" *ngIf="!loggedIn">
+ <img src="/assets/icons/tabler-icon-login.svg">
+ </div>
+ <div class="flexible" *ngIf="!loggedIn">
+ <!-- This element serves as a spacer -->
+ </div>
</div>
</nav>
diff --git a/src/app/components/navbar/navbar.component.ts b/src/app/components/navbar/navbar.component.ts
index 4af7a8a..d10a49d 100644
--- a/src/app/components/navbar/navbar.component.ts
+++ b/src/app/components/navbar/navbar.component.ts
@@ -11,15 +11,13 @@ import { User } from 'src/models/identity/user.model';
})
export class NavbarComponent implements OnInit {
public user: User;
+ public loggedIn: Boolean;
constructor(private _router: Router, private _userService: UserService, private _tokenService: TokenService)
{ }
ngOnInit(): void {
- if (!this._tokenService.getTokenFromSessionStorage()) {
- this._router.navigate(['/login']);
- return;
- }
+ this.loggedIn = this._tokenService.getTokenFromSessionStorage() !== '';
this.user = this._userService.getDefaultUser();
@@ -35,7 +33,12 @@ export class NavbarComponent implements OnInit {
}
goToFeed(): void {
- this._router.navigate(['/']);
+ if (this.loggedIn) {
+ this._router.navigate(['/']);
+ }
+ else {
+ this.goToLogin();
+ }
}
goToSettings(): void {
@@ -44,6 +47,10 @@ export class NavbarComponent implements OnInit {
logout(): void {
this._tokenService.logoutUserFromSessionStorage();
+ this.goToLogin();
+ }
+
+ goToLogin(): void {
this._router.navigate(['/login']);
}
}