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/util/theme.ts

19 lines
736 B
TypeScript

import { ThemeStateType } from '../themes/constants/colors';
export function getOppositeTheme(themeName: string): ThemeStateType {
if (themeName.includes('dark')) {
return themeName.replace('dark', 'light') as ThemeStateType;
}
if (themeName.includes('light')) {
return themeName.replace('light', 'dark') as ThemeStateType;
}
// If neither 'dark' nor 'light' is in the theme name, return the original theme name.
return themeName as ThemeStateType;
}
export function isThemeMismatched(themeName: string, prefersDark: boolean): boolean {
const isLightTheme = themeName.includes('light');
const isDarkTheme = themeName.includes('dark');
return (prefersDark && isLightTheme) || (!prefersDark && isDarkTheme);
}