OpenMediaCenter/src/utils/GlobalInfos.ts

66 lines
1.6 KiB
TypeScript
Raw Normal View History

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 = '';
2020-07-27 21:14:56 +02:00
/**
* check if the current theme is the dark theme
* @returns {boolean} is dark theme?
*/
isDarkTheme(): boolean {
return this.darktheme;
}
2020-07-27 21:14:56 +02:00
/**
* 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();
});
2020-07-27 21:14:56 +02:00
}
/**
* 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;
}
/**
* load the Password page manually
*/
loadPasswordPage: ((callback?: () => void) => void) | undefined = undefined;
}
export default new StaticInfos();