Files
react-test/test/regressions/fixtures/CssVarsProvider/IndependentCssVarsProviders.js
how2ice 005cf56baf
Some checks failed
No response / noResponse (push) Has been cancelled
CI / Continuous releases (push) Has been cancelled
CI / test-dev (macos-latest) (push) Has been cancelled
CI / test-dev (ubuntu-latest) (push) Has been cancelled
CI / test-dev (windows-latest) (push) Has been cancelled
Maintenance / main (push) Has been cancelled
Scorecards supply-chain security / Scorecards analysis (push) Has been cancelled
CodeQL / Analyze (push) Has been cancelled
init project
2025-12-12 14:26:25 +09:00

82 lines
1.7 KiB
JavaScript

import * as React from 'react';
import {
unstable_createCssVarsProvider as createCssVarsProvider,
unstable_createCssVarsTheme as createCssVarsTheme,
} from '@mui/system';
const { CssVarsProvider, useColorScheme } = createCssVarsProvider({
theme: createCssVarsTheme({
colorSchemes: {
light: {
background: {
default: 'red',
},
},
dark: {
background: {
default: 'blue',
},
},
},
}),
defaultColorScheme: {
light: 'light',
dark: 'dark',
},
});
const nestedTheme = createCssVarsTheme({
cssVarPrefix: 'nested',
colorSchemeSelector: '[data-nested-color-scheme="%s"]',
colorSchemes: {
light: {
background: {
default: 'yellow',
},
},
dark: {
background: {
default: 'cyan',
},
},
},
});
function DarkMode() {
const { setMode } = useColorScheme();
React.useEffect(() => {
setMode('dark');
}, [setMode]);
return null;
}
export default function IndependentCssVarsProviders() {
return (
<CssVarsProvider>
<div
style={{
background: 'var(--background-default)',
color: 'white',
padding: '1rem',
}}
>
Background should be red.
{/* If `disableNestedContext` is true, the upper CssVarsProvider should be independent */}
<CssVarsProvider theme={nestedTheme} disableNestedContext>
<DarkMode />
<div
style={{
background: 'var(--nested-background-default)',
height: 40,
color: '#000',
padding: '1rem',
}}
>
Background should be cyan.
</div>
</CssVarsProvider>
</div>
</CssVarsProvider>
);
}