implement custom clientstore add new Password page if password is set force entering password to successfully receive the token add a new unsafe api call for init call only
62 lines
1.5 KiB
TypeScript
62 lines
1.5 KiB
TypeScript
import darktheme from '../AppDarkTheme.module.css';
|
|
import lighttheme from '../AppLightTheme.module.css';
|
|
|
|
/**
|
|
* This class is available for all components in project
|
|
* it contains general infos about app - like theme
|
|
*/
|
|
class StaticInfos {
|
|
private darktheme: boolean = true;
|
|
private videopath: string = ""
|
|
|
|
/**
|
|
* check if the current theme is the dark theme
|
|
* @returns {boolean} is dark theme?
|
|
*/
|
|
isDarkTheme(): boolean {
|
|
return this.darktheme;
|
|
};
|
|
|
|
/**
|
|
* setter to enable or disable the dark or light theme
|
|
* @param enable enable the dark theme?
|
|
*/
|
|
enableDarkTheme(enable = true): void {
|
|
this.darktheme = enable;
|
|
this.handlers.map(func => {
|
|
return func();
|
|
})
|
|
}
|
|
|
|
/**
|
|
* get the currently selected theme stylesheet
|
|
* @returns {*} the style object of the current active theme
|
|
*/
|
|
getThemeStyle(): { [_: string]: string } {
|
|
return this.isDarkTheme() ? darktheme : lighttheme;
|
|
}
|
|
|
|
handlers: (() => void)[] = [];
|
|
onThemeChange(func: () => void): void {
|
|
this.handlers.push(func);
|
|
}
|
|
|
|
/**
|
|
* set the current videopath
|
|
* @param vidpath videopath with beginning and ending slash
|
|
*/
|
|
setVideoPath(vidpath: string): void {
|
|
this.videopath = vidpath;
|
|
}
|
|
|
|
/**
|
|
* return the current videopath
|
|
*/
|
|
getVideoPath(): string {
|
|
return this.videopath;
|
|
}
|
|
}
|
|
|
|
const GlobalInfos = new StaticInfos();
|
|
export default GlobalInfos;
|