49 lines
1.4 KiB
TypeScript
49 lines
1.4 KiB
TypeScript
import { NotificationService } from '@ghostfolio/client/core/notification/notification.service';
|
|
import { DataService } from '@ghostfolio/client/services/data.service';
|
|
import { TokenStorageService } from '@ghostfolio/client/services/token-storage.service';
|
|
import { InfoItem } from '@ghostfolio/common/interfaces';
|
|
|
|
import { Component, OnDestroy } from '@angular/core';
|
|
import { Router } from '@angular/router';
|
|
import { Subject } from 'rxjs';
|
|
|
|
@Component({
|
|
host: { class: 'page' },
|
|
selector: 'gf-demo-page',
|
|
standalone: true,
|
|
templateUrl: './demo-page.html'
|
|
})
|
|
export class GfDemoPageComponent implements OnDestroy {
|
|
public info: InfoItem;
|
|
|
|
private unsubscribeSubject = new Subject<void>();
|
|
|
|
public constructor(
|
|
private dataService: DataService,
|
|
private notificationService: NotificationService,
|
|
private router: Router,
|
|
private tokenStorageService: TokenStorageService
|
|
) {
|
|
this.info = this.dataService.fetchInfo();
|
|
}
|
|
|
|
public ngOnInit() {
|
|
const hasToken = this.tokenStorageService.getToken()?.length > 0;
|
|
|
|
if (hasToken) {
|
|
this.notificationService.alert({
|
|
title: $localize`As you are already logged in, you cannot access the demo account.`
|
|
});
|
|
} else {
|
|
this.tokenStorageService.saveToken(this.info.demoAuthToken, true);
|
|
}
|
|
|
|
this.router.navigate(['/']);
|
|
}
|
|
|
|
public ngOnDestroy() {
|
|
this.unsubscribeSubject.next();
|
|
this.unsubscribeSubject.complete();
|
|
}
|
|
}
|