argos/dmp-frontend/src/app/ui/language/language-content/language.component.ts

68 lines
2.3 KiB
TypeScript

import { Component, EventEmitter, OnInit, Output } from '@angular/core';
import { MatButtonToggleChange } from '@angular/material/button-toggle';
import { Router } from '@angular/router';
import { AuthService } from '@app/core/services/auth/auth.service';
import { LanguageService } from '@app/core/services/language/language.service';
import { UserService } from '@app/core/services/user/user.service';
import { BaseComponent } from '@common/base/base.component';
@Component({
selector: 'app-language',
templateUrl: './language.component.html',
styleUrls: ['./language.component.scss']
})
export class LanguageComponent extends BaseComponent implements OnInit {
@Output() languageChange: EventEmitter<any> = new EventEmitter();
languages: string[] = [];
constructor(
private router: Router,
private authentication: AuthService,
private userService: UserService,
private languageService: LanguageService
) {
super();
this.languages = this.languageService.getAvailableLanguagesCodes();
}
ngOnInit() {
this.languageChange.emit(this.getCurrentLanguage())
}
public isAuthenticated(): boolean {
return this.authentication.currentAccountIsAuthenticated();
}
public getCurrentLanguage(): string {
const lang = this.languages.find(lang => lang === this.languageService.getCurrentLanguage());
return lang;
}
onLanguageSelected(selectedLanguage: MatButtonToggleChange) {
if (this.isAuthenticated()) {
const langMap = new Map<string, string>();
langMap.set('language', selectedLanguage.value);
//TODO: refactor - save language selection to user profile
// this.userService.updateUserSettings({ language: this.languages.find(lang => lang === selectedLanguage.value) })
// .pipe(takeUntil(this._destroyed))
// .subscribe((response) => {
// this.languageService.changeLanguage(selectedLanguage.value);
// this.authentication.refresh()
// .pipe(takeUntil(this._destroyed))
// .subscribe(innerResponse => { this.router.navigateByUrl(this.router.url); });
// },
// error => {
// console.log(error);
// });
this.languageService.changeLanguage(selectedLanguage.value);
this.router.navigateByUrl(this.router.url);
} else {
this.languageService.changeLanguage(selectedLanguage.value);
this.router.navigateByUrl(this.router.url);
}
this.languageChange.emit(selectedLanguage.value);
}
}