You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
session-desktop/ts/session/utils/Theme.tsx

29 lines
823 B
TypeScript

import { Dispatch } from '@reduxjs/toolkit';
import { switchHtmlToDarkTheme, switchHtmlToLightTheme } from '../../state/ducks/SessionTheme';
import { applyTheme, ThemeStateType } from '../../state/ducks/theme';
export async function switchThemeTo(theme: ThemeStateType, dispatch: Dispatch | null) {
await window.setTheme(theme);
// for now, do not switch to ocean light nor dark theme as the SessionTheme associated with them is not complete
let newTheme: ThemeStateType | null = null;
switch (theme) {
case 'dark':
switchHtmlToDarkTheme();
newTheme = 'dark';
break;
case 'light':
switchHtmlToLightTheme();
newTheme = 'light';
break;
default:
window.log.warn('Unsupported theme: ', theme);
}
if (newTheme) {
dispatch?.(applyTheme(newTheme));
}
}