Files
cinny/src/app/pages/ThemeManager.tsx
T

61 lines
2.1 KiB
TypeScript
Raw Normal View History

import React, { ReactNode, useEffect } from 'react';
import { configClass, varsClass } from 'folds';
import {
DarkTheme,
LightTheme,
LotusTerminalTheme,
ThemeContextProvider,
ThemeKind,
useActiveTheme,
useSystemThemeKind,
} from '../hooks/useTheme';
import { lotusTerminalBodyClass } from '../../lotus-terminal.css';
2025-08-25 18:49:14 +05:30
import { useSetting } from '../state/hooks/settings';
import { settingsAtom } from '../state/settings';
2026-05-13 22:36:48 -04:00
import { runLotusBootSequence } from '../../lotus-boot';
export function UnAuthRouteThemeManager() {
const systemThemeKind = useSystemThemeKind();
2026-05-13 22:36:48 -04:00
const [lotusTerminal] = useSetting(settingsAtom, 'lotusTerminal');
useEffect(() => {
document.body.className = '';
document.body.classList.add(configClass, varsClass);
2026-05-13 22:36:48 -04:00
if (lotusTerminal) {
document.body.classList.add(...LotusTerminalTheme.classNames);
document.body.classList.add(lotusTerminalBodyClass);
} else if (systemThemeKind === ThemeKind.Dark) {
document.body.classList.add(...DarkTheme.classNames);
2026-05-13 22:36:48 -04:00
} else {
document.body.classList.add(...LightTheme.classNames);
}
2026-05-13 22:36:48 -04:00
}, [systemThemeKind, lotusTerminal]);
return null;
}
export function AuthRouteThemeManager({ children }: { children: ReactNode }) {
const activeTheme = useActiveTheme();
2025-08-25 18:49:14 +05:30
const [monochromeMode] = useSetting(settingsAtom, 'monochromeMode');
const [lotusTerminal] = useSetting(settingsAtom, 'lotusTerminal');
const effectiveTheme = lotusTerminal ? LotusTerminalTheme : activeTheme;
useEffect(() => {
document.body.className = '';
document.body.classList.add(configClass, varsClass);
document.body.classList.add(...effectiveTheme.classNames);
if (lotusTerminal) {
document.body.classList.add(lotusTerminalBodyClass);
2026-05-13 22:36:48 -04:00
runLotusBootSequence();
}
if (monochromeMode && !lotusTerminal) {
2025-08-25 18:49:14 +05:30
document.body.style.filter = 'grayscale(1)';
} else {
document.body.style.filter = '';
}
}, [effectiveTheme, monochromeMode, lotusTerminal]);
return <ThemeContextProvider value={effectiveTheme}>{children}</ThemeContextProvider>;
}