12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- import {Fragment, useEffect} from 'react';
- import {createPortal} from 'react-dom';
- import createCache from '@emotion/cache';
- import {CacheProvider, ThemeProvider} from '@emotion/react';
- import {loadPreferencesState} from 'sentry/actionCreators/preferences';
- import ConfigStore from 'sentry/stores/configStore';
- import {useLegacyStore} from 'sentry/stores/useLegacyStore';
- import GlobalStyles from 'sentry/styles/global';
- import {darkTheme, lightTheme} from 'sentry/utils/theme';
- type Props = {
- children: React.ReactNode;
- };
- const cache = createCache({key: 'app', stylisPlugins: []});
- cache.compat = true;
- export function ThemeAndStyleProvider({children}: Props) {
- useEffect(() => void loadPreferencesState(), []);
- const config = useLegacyStore(ConfigStore);
- const theme = config.theme === 'dark' ? darkTheme : lightTheme;
- return (
- <ThemeProvider theme={theme}>
- <GlobalStyles isDark={config.theme === 'dark'} theme={theme} />
- <CacheProvider value={cache}>{children}</CacheProvider>
- {createPortal(
- <Fragment>
- <meta name="color-scheme" content={config.theme} />
- <meta name="theme-color" content={theme.sidebar.background} />
- </Fragment>,
- document.head
- )}
- </ThemeProvider>
- );
- }
|