openvidu/openvidu-components-angular/projects/openvidu-angular/src/lib/services/caption/caption.service.ts

62 lines
1.8 KiB
TypeScript
Raw Normal View History

2022-10-24 17:08:32 +02:00
import { Injectable } from '@angular/core';
import { Observable, Subject } from 'rxjs';
import { StorageService } from '../storage/storage.service';
/**
* @internal
*/
@Injectable({
providedIn: 'root'
})
export class CaptionService {
2022-10-24 17:08:32 +02:00
private langTitles = [
{ name: 'English', ISO: 'en-US' },
{ name: 'Español', ISO: 'es-ES' },
{ name: 'Deutsch', ISO: 'de-DE' },
{ name: 'Français', ISO: 'fr-FR' },
{ name: '中国', ISO: 'zh-CN' },
{ name: 'हिन्दी', ISO: 'hi-IN' },
{ name: 'Italiano', ISO: 'it-IT' },
{ name: 'やまと', ISO: 'jp-JP' },
{ name: 'Português', ISO: 'pt-PT' }
];
captionLangSelected: { name: string; ISO: string };
captionLangObs: Observable<{ name: string; ISO: string }>;
private _captionLangObs: Subject<{ name: string; ISO: string }> = new Subject();
private captionsEnabled: boolean = false;
2022-10-24 17:08:32 +02:00
constructor(private storageService: StorageService) {
const iso = this.storageService.getCaptionsLang();
if (iso) {
this.captionLangSelected = this.langTitles.find((lang) => lang.ISO === iso) || this.langTitles[0];
}
2022-10-24 17:08:32 +02:00
this.captionLangObs = this._captionLangObs.asObservable();
}
setCaptionsEnabled(value: boolean) {
this.captionsEnabled = value;
}
areCaptionsEnabled(): boolean {
return this.captionsEnabled;
}
2022-10-24 17:08:32 +02:00
setLanguage(lang: string) {
const newLang = this.langTitles.find((l) => l.ISO === lang);
if(!!newLang && newLang.ISO !== this.captionLangSelected.ISO){
this.captionLangSelected = newLang;
2022-10-24 17:08:32 +02:00
this.storageService.setCaptionLang(lang);
this._captionLangObs.next(this.captionLangSelected);
2022-10-24 17:08:32 +02:00
}
}
getLangSelected(): { name: string; ISO: string } {
return this.captionLangSelected || this.langTitles[0];
}
getCaptionLanguages(): { name: string; ISO: string }[] {
return this.langTitles;
}
}