mirror of
https://github.com/bpatrik/pigallery2.git
synced 2025-01-18 04:58:59 +02:00
44 lines
1.2 KiB
TypeScript
44 lines
1.2 KiB
TypeScript
import {Component, ViewEncapsulation} from '@angular/core';
|
|
import {RouterLink} from '@angular/router';
|
|
import {AuthenticationService} from '../model/network/authentication.service';
|
|
import {UserDTO, UserRoles} from '../../../common/entities/UserDTO';
|
|
import {Config} from '../../../common/config/public/Config';
|
|
import {BehaviorSubject} from 'rxjs/BehaviorSubject';
|
|
import {NotificationService} from '../model/notification.service';
|
|
|
|
@Component({
|
|
selector: 'app-frame',
|
|
templateUrl: './frame.component.html',
|
|
styleUrls: ['./frame.component.css'],
|
|
providers: [RouterLink],
|
|
encapsulation: ViewEncapsulation.Emulated
|
|
})
|
|
export class FrameComponent {
|
|
|
|
user: BehaviorSubject<UserDTO>;
|
|
authenticationRequired = false;
|
|
public title: string;
|
|
isIn = false;
|
|
|
|
constructor(private _authService: AuthenticationService,
|
|
public notificationService: NotificationService) {
|
|
this.user = this._authService.user;
|
|
this.authenticationRequired = Config.Client.authenticationRequired;
|
|
this.title = Config.Client.applicationTitle;
|
|
}
|
|
|
|
toggleState() { // click handler
|
|
this.isIn = !this.isIn;
|
|
}
|
|
|
|
isAdmin() {
|
|
return this.user.value && this.user.value.role >= UserRoles.Admin;
|
|
}
|
|
|
|
|
|
logout() {
|
|
this._authService.logout();
|
|
}
|
|
}
|
|
|