108 lines
3.2 KiB
TypeScript
108 lines
3.2 KiB
TypeScript
|
import {
|
||
|
ChangeDetectionStrategy,
|
||
|
ChangeDetectorRef,
|
||
|
Component,
|
||
|
OnDestroy,
|
||
|
OnInit
|
||
|
} from '@angular/core';
|
||
|
import { NavigationEnd, Router } from '@angular/router';
|
||
|
import { MaterialCssVarsService } from 'angular-material-css-vars';
|
||
|
import { User } from 'apps/api/src/app/user/interfaces/user.interface';
|
||
|
import { formatDistanceToNow } from 'date-fns';
|
||
|
import { primaryColorHex, secondaryColorHex } from 'libs/helper/src';
|
||
|
import { hasPermission, permissions } from 'libs/helper/src';
|
||
|
import { Subject } from 'rxjs';
|
||
|
import { filter, takeUntil } from 'rxjs/operators';
|
||
|
|
||
|
import { environment } from '../environments/environment';
|
||
|
import { DataService } from './services/data.service';
|
||
|
import { TokenStorageService } from './services/token-storage.service';
|
||
|
|
||
|
@Component({
|
||
|
selector: 'gf-root',
|
||
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
||
|
templateUrl: './app.component.html',
|
||
|
styleUrls: ['./app.component.scss']
|
||
|
})
|
||
|
export class AppComponent implements OnDestroy, OnInit {
|
||
|
public canCreateAccount: boolean;
|
||
|
public currentRoute: string;
|
||
|
public isLoggedIn = false;
|
||
|
public lastDataGathering: string;
|
||
|
public user: User;
|
||
|
public version = environment.version;
|
||
|
|
||
|
private unsubscribeSubject = new Subject<void>();
|
||
|
|
||
|
public constructor(
|
||
|
private cd: ChangeDetectorRef,
|
||
|
private dataService: DataService,
|
||
|
private materialCssVarsService: MaterialCssVarsService,
|
||
|
private router: Router,
|
||
|
private tokenStorageService: TokenStorageService
|
||
|
) {
|
||
|
this.initializeTheme();
|
||
|
this.user = undefined;
|
||
|
}
|
||
|
|
||
|
public ngOnInit() {
|
||
|
this.dataService.fetchInfo().subscribe(({ lastDataGathering }) => {
|
||
|
this.lastDataGathering = lastDataGathering
|
||
|
? formatDistanceToNow(new Date(lastDataGathering), { addSuffix: true })
|
||
|
: '';
|
||
|
});
|
||
|
|
||
|
this.router.events
|
||
|
.pipe(filter((event) => event instanceof NavigationEnd))
|
||
|
.subscribe((test) => {
|
||
|
this.currentRoute = this.router.url.toString().substring(1);
|
||
|
// this.initializeTheme();
|
||
|
});
|
||
|
|
||
|
this.tokenStorageService
|
||
|
.onChangeHasToken()
|
||
|
.pipe(takeUntil(this.unsubscribeSubject))
|
||
|
.subscribe(() => {
|
||
|
this.isLoggedIn = !!this.tokenStorageService.getToken();
|
||
|
|
||
|
if (this.isLoggedIn) {
|
||
|
this.dataService.fetchUser().subscribe((user) => {
|
||
|
this.user = user;
|
||
|
|
||
|
this.canCreateAccount = hasPermission(
|
||
|
this.user.permissions,
|
||
|
permissions.createAccount
|
||
|
);
|
||
|
|
||
|
this.cd.markForCheck();
|
||
|
});
|
||
|
} else {
|
||
|
this.user = null;
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
|
||
|
private initializeTheme() {
|
||
|
this.materialCssVarsService.setDarkTheme(
|
||
|
window.matchMedia('(prefers-color-scheme: dark)').matches
|
||
|
);
|
||
|
|
||
|
window.matchMedia('(prefers-color-scheme: dark)').addListener((event) => {
|
||
|
this.materialCssVarsService.setDarkTheme(event.matches);
|
||
|
});
|
||
|
|
||
|
this.materialCssVarsService.setPrimaryColor(primaryColorHex);
|
||
|
this.materialCssVarsService.setAccentColor(secondaryColorHex);
|
||
|
}
|
||
|
|
||
|
public onCreateAccount() {
|
||
|
this.tokenStorageService.signOut();
|
||
|
window.location.reload();
|
||
|
}
|
||
|
|
||
|
public ngOnDestroy() {
|
||
|
this.unsubscribeSubject.next();
|
||
|
this.unsubscribeSubject.complete();
|
||
|
}
|
||
|
}
|