Files
n8n-enterprise-unlocked/packages/frontend/editor-ui/src/stores/ui.utils.ts
2025-06-16 14:50:57 +02:00

26 lines
991 B
TypeScript

import { LOCAL_STORAGE_THEME } from '@/constants';
import type { AppliedThemeOption, ThemeOption } from '@/Interface';
export function applyThemeToBody(theme: ThemeOption, window_?: Window) {
if (theme === 'system') {
(window_ ?? window).document.body.removeAttribute('data-theme');
} else {
(window_ ?? window).document.body.setAttribute?.('data-theme', theme); // setAttribute can be missing in jsdom environment
}
}
export function isValidTheme(theme: string | null): theme is AppliedThemeOption {
return !!theme && ['light', 'dark'].includes(theme);
}
// query param allows overriding theme for demo view in preview iframe without flickering
export function getThemeOverride(): AppliedThemeOption | null {
const override = getQueryParam('theme') ?? localStorage.getItem(LOCAL_STORAGE_THEME);
return isValidTheme(override) ? override : null;
}
function getQueryParam(paramName: string): string | null {
return new URLSearchParams(window.location.search).get(paramName);
}