1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2025-01-14 14:43:17 +08:00
pigallery2/frontend/app/app.component.ts

71 lines
2.0 KiB
TypeScript
Raw Normal View History

2018-03-30 15:30:30 -04:00
import {Component, OnDestroy, OnInit, ViewContainerRef} from '@angular/core';
import {AuthenticationService} from './model/network/authentication.service';
import {UserDTO} from '../../common/entities/UserDTO';
import {Router} from '@angular/router';
import {Config} from '../../common/config/public/Config';
import {Title} from '@angular/platform-browser';
import {NotificationService} from './model/notification.service';
import {ShareService} from './gallery/share.service';
import 'hammerjs';
import {QueryService} from './model/query.service';
2017-07-19 22:40:27 +02:00
2016-03-12 14:57:22 +01:00
@Component({
2018-03-30 15:30:30 -04:00
selector: 'app-pi-gallery2',
template: `<router-outlet></router-outlet>`,
2016-12-26 23:36:38 +01:00
2016-03-12 14:57:22 +01:00
})
2017-07-19 22:40:27 +02:00
export class AppComponent implements OnInit, OnDestroy {
private subscription = null;
2016-03-13 11:28:29 +01:00
2017-07-08 12:43:42 +02:00
constructor(private _router: Router,
private _authenticationService: AuthenticationService,
2017-07-09 12:03:17 +02:00
private _shareService: ShareService,
2018-05-22 20:27:07 -04:00
private _title: Title) {
}
2016-03-12 18:11:19 +01:00
2017-07-09 12:03:17 +02:00
async ngOnInit() {
2017-07-08 00:18:24 +02:00
this._title.setTitle(Config.Client.applicationTitle);
2017-07-09 12:03:17 +02:00
await this._shareService.wait();
2017-07-19 22:40:27 +02:00
this.subscription = this._authenticationService.user.subscribe((user: UserDTO) => {
2017-07-09 12:03:17 +02:00
if (this._authenticationService.isAuthenticated()) {
if (this.isLoginPage()) {
return this.toGallery();
}
} else {
2017-07-09 12:03:17 +02:00
if (!this.isLoginPage()) {
return this.toLogin();
}
}
2016-05-16 23:15:03 +02:00
});
2016-05-09 17:04:56 +02:00
2017-07-19 22:40:27 +02:00
}
2017-07-19 22:40:27 +02:00
ngOnDestroy() {
if (this.subscription != null) {
this.subscription.unsubscribe();
}
}
2017-06-21 21:16:04 +02:00
2017-07-09 12:03:17 +02:00
private isLoginPage() {
return this._router.isActive('login', true) || this._router.isActive('shareLogin', false);
}
private toLogin() {
if (this._shareService.isSharing()) {
2018-03-30 15:30:30 -04:00
return this._router.navigate(['shareLogin'], {queryParams: {sk: this._shareService.getSharingKey()}});
2017-07-09 12:03:17 +02:00
} else {
2018-03-30 15:30:30 -04:00
return this._router.navigate(['login']);
2017-07-09 12:03:17 +02:00
}
}
2017-06-21 21:16:04 +02:00
2017-07-09 12:03:17 +02:00
private toGallery() {
if (this._shareService.isSharing()) {
2018-03-30 15:30:30 -04:00
return this._router.navigate(['share', this._shareService.getSharingKey()]);
2017-07-09 12:03:17 +02:00
} else {
2018-03-30 15:30:30 -04:00
return this._router.navigate(['gallery', '']);
2017-07-09 12:03:17 +02:00
}
}
}