Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[CssVarsProvider] Add CssVarsProvider in @mui/material #31138

Merged
merged 56 commits into from
Mar 30, 2022
Merged
Show file tree
Hide file tree
Changes from 19 commits
Commits
Show all changes
56 commits
Select commit Hold shift + click to select a range
cc346b6
fix typings
siriwatknp Feb 17, 2022
2a3e286
add comment
siriwatknp Feb 17, 2022
3876b19
fix comment
siriwatknp Feb 17, 2022
2e4688e
move variants out
siriwatknp Feb 17, 2022
278b596
change to interface
siriwatknp Feb 17, 2022
9489792
remove unused type
siriwatknp Feb 17, 2022
c670070
test theme types
siriwatknp Feb 17, 2022
79ffa20
refactor types
siriwatknp Feb 17, 2022
5fff83a
wip
siriwatknp Feb 17, 2022
cd8bc7e
add spec
siriwatknp Feb 17, 2022
6e35910
revert the name to PaletteRange
siriwatknp Feb 17, 2022
95d7580
bring back vars for default them
siriwatknp Feb 17, 2022
3465d41
add spec for createCssVarsProvider
siriwatknp Feb 17, 2022
918aa37
fix lint
siriwatknp Feb 17, 2022
7614e32
revert type util change
siriwatknp Feb 17, 2022
0d6279e
fix Typography types
siriwatknp Feb 17, 2022
64eb5fe
wip
mnajdova Feb 18, 2022
ddcdd20
prettier & lint
mnajdova Feb 18, 2022
8a31db8
Merge branch 'master' into feat/css-vars-provider-mui-material
mnajdova Feb 18, 2022
3c228cd
Add custom design system page
mnajdova Feb 21, 2022
1f6b439
Fix CI
mnajdova Feb 21, 2022
27aee41
Merge branch 'master' into feat/css-vars-provider-mui-material
siriwatknp Mar 3, 2022
be88d5a
rename folder to material-ui
siriwatknp Mar 3, 2022
0ef6c17
fix double generated vars
siriwatknp Mar 3, 2022
b62d8d8
use channel token for js color manipulation
siriwatknp Mar 3, 2022
79a1b67
fix custom theme page
siriwatknp Mar 3, 2022
d8f7306
[material] Add an unstable createTheme for creating a theme using col…
mnajdova Mar 8, 2022
37bda7f
Small fixes, create the typography in the CssVarsProvider
mnajdova Mar 8, 2022
b159c33
Improve the createTheme func, fix some channels generation, fix some …
mnajdova Mar 9, 2022
3ea304e
Some fixes
mnajdova Mar 9, 2022
86d9665
Fix TS issue
mnajdova Mar 9, 2022
3e10415
Fix the types
mnajdova Mar 9, 2022
cff193f
Some TS fixes
mnajdova Mar 15, 2022
91d9995
Types improvements
mnajdova Mar 15, 2022
46f6610
Merge branch 'master' into feat/css-vars-provider-mui-material
mnajdova Mar 15, 2022
f502102
Fix build API script
mnajdova Mar 15, 2022
75fd833
More fixes
mnajdova Mar 15, 2022
7181088
Fix CI
mnajdova Mar 15, 2022
8733e6c
Try demos using CSS Variables (to be reverted)
mnajdova Mar 15, 2022
11fe020
Fix netlify build
mnajdova Mar 15, 2022
9d8e060
Some comments addressed
mnajdova Mar 16, 2022
990c453
Move colorChannel to colorManipulator
mnajdova Mar 16, 2022
d25444f
[tests] Added tests and fixed some bugs
mnajdova Mar 16, 2022
22abf9a
prettier
mnajdova Mar 16, 2022
51c95c1
Fix CssVarsProvider to use correct defaul theme
mnajdova Mar 17, 2022
6f9653a
Add the experimental prefix, remove comments
mnajdova Mar 17, 2022
661bee3
Fix lint issue
mnajdova Mar 17, 2022
71def97
Merge branch 'master' into feat/css-vars-provider-mui-material
mnajdova Mar 17, 2022
062c4f5
Fix the DemoSandboxed
mnajdova Mar 18, 2022
6e11cc7
Merge branch 'master' into feat/css-vars-provider-mui-material
mnajdova Mar 30, 2022
5b8ebdf
Revert DemoSandboxed changes
mnajdova Mar 30, 2022
78ab74c
Update docs/data/material/customization/palette/palette.md
mnajdova Mar 30, 2022
59f08e5
Update docs/data/material/customization/palette/palette.md
mnajdova Mar 30, 2022
6d05333
final fixes
mnajdova Mar 30, 2022
a2bbc33
Merge branch 'feat/css-vars-provider-mui-material' of https://github.…
mnajdova Mar 30, 2022
fe370af
Remove unused border color
mnajdova Mar 30, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
95 changes: 95 additions & 0 deletions docs/pages/experiments/mui/css-variables.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,95 @@
import * as React from 'react';
import { CssVarsProvider, useColorScheme } from '@mui/material/styles';
import Moon from '@mui/icons-material/DarkMode';
import Sun from '@mui/icons-material/LightMode';
import Button from '@mui/material/Button';
import Box from '@mui/material/Box';

const ColorSchemePicker = () => {
const { mode, setMode } = useColorScheme();
const [mounted, setMounted] = React.useState(false);
React.useEffect(() => {
setMounted(true);
}, []);
if (!mounted) {
return null;
}

return (
<Button
variant="outlined"
onClick={() => {
if (mode === 'light') {
setMode('dark');
} else {
setMode('light');
}
}}
sx={{ '--Button-gutter': '0.25rem', minWidth: 'var(--Button-minHeight)' }}
>
{mode === 'light' ? <Moon /> : <Sun />}
</Button>
);
};

export default function Page() {
return (
<CssVarsProvider>
<Box sx={{ py: 5, maxWidth: { md: 1152, xl: 1536 }, mx: 'auto' }}>
<Box sx={{ pb: 4 }}>
<ColorSchemePicker />
</Box>
<Box sx={{ display: 'flex', flexWrap: 'wrap', gap: 4, mb: 1 }}>
<Button variant="contained">Text</Button>
<Button variant="outlined">Text</Button>
<Button>Text</Button>
</Box>
<Box sx={{ display: 'flex', flexWrap: 'wrap', gap: 4, mb: 1 }}>
<Button color="secondary" variant="contained">
Text
</Button>
<Button color="secondary" variant="outlined">
Text
</Button>
<Button color="secondary">Text</Button>
</Box>
<Box sx={{ display: 'flex', flexWrap: 'wrap', gap: 4, mb: 1 }}>
<Button color="error" variant="contained">
Text
</Button>
<Button color="error" variant="outlined">
Text
</Button>
<Button color="error">Text</Button>
</Box>
<Box sx={{ display: 'flex', flexWrap: 'wrap', gap: 4, mb: 1 }}>
<Button color="info" variant="contained">
Text
</Button>
<Button color="info" variant="outlined">
Text
</Button>
<Button color="info">Text</Button>
</Box>
<Box sx={{ display: 'flex', flexWrap: 'wrap', gap: 4, mb: 1 }}>
<Button color="warning" variant="contained">
Text
</Button>
<Button color="warning" variant="outlined">
Text
</Button>
<Button color="warning">Text</Button>
</Box>
<Box sx={{ display: 'flex', flexWrap: 'wrap', gap: 4, mb: 1 }}>
<Button color="success" variant="contained">
Text
</Button>
<Button color="success" variant="outlined">
Text
</Button>
<Button color="success">Text</Button>
</Box>
</Box>
</CssVarsProvider>
);
}
46 changes: 23 additions & 23 deletions packages/mui-material/src/Button/Button.js
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,7 @@ const ButtonRoot = styled(ButtonBase, {
...theme.typography.button,
minWidth: 64,
padding: '6px 16px',
borderRadius: theme.shape.borderRadius,
borderRadius: (theme.vars || theme).shape.borderRadius,
transition: theme.transitions.create(
['background-color', 'box-shadow', 'border-color', 'color'],
{
Expand All @@ -106,7 +106,7 @@ const ButtonRoot = styled(ButtonBase, {
}),
...(ownerState.variant === 'outlined' &&
ownerState.color !== 'inherit' && {
border: `1px solid ${theme.palette[ownerState.color].main}`,
border: `1px solid ${(theme.vars || theme).palette[ownerState.color].main}`,
backgroundColor: alpha(
theme.palette[ownerState.color].main,
theme.palette.action.hoverOpacity,
Expand All @@ -117,54 +117,54 @@ const ButtonRoot = styled(ButtonBase, {
},
}),
...(ownerState.variant === 'contained' && {
backgroundColor: theme.palette.grey.A100,
boxShadow: theme.shadows[4],
backgroundColor: (theme.vars || theme).palette.grey.A100,
boxShadow: (theme.vars || theme).shadows[4],
// Reset on touch devices, it doesn't add specificity
'@media (hover: none)': {
boxShadow: theme.shadows[2],
backgroundColor: theme.palette.grey[300],
boxShadow: (theme.vars || theme).shadows[2],
backgroundColor: (theme.vars || theme).palette.grey[300],
},
}),
...(ownerState.variant === 'contained' &&
ownerState.color !== 'inherit' && {
backgroundColor: theme.palette[ownerState.color].dark,
backgroundColor: (theme.vars || theme).palette[ownerState.color].dark,
// Reset on touch devices, it doesn't add specificity
'@media (hover: none)': {
backgroundColor: theme.palette[ownerState.color].main,
backgroundColor: (theme.vars || theme).palette[ownerState.color].main,
},
}),
},
'&:active': {
...(ownerState.variant === 'contained' && {
boxShadow: theme.shadows[8],
boxShadow: (theme.vars || theme).shadows[8],
}),
},
[`&.${buttonClasses.focusVisible}`]: {
...(ownerState.variant === 'contained' && {
boxShadow: theme.shadows[6],
boxShadow: (theme.vars || theme).shadows[6],
}),
},
[`&.${buttonClasses.disabled}`]: {
color: theme.palette.action.disabled,
color: (theme.vars || theme).palette.action.disabled,
...(ownerState.variant === 'outlined' && {
border: `1px solid ${theme.palette.action.disabledBackground}`,
border: `1px solid ${(theme.vars || theme).palette.action.disabledBackground}`,
}),
...(ownerState.variant === 'outlined' &&
ownerState.color === 'secondary' && {
border: `1px solid ${theme.palette.action.disabled}`,
border: `1px solid ${(theme.vars || theme).palette.action.disabled}`,
}),
...(ownerState.variant === 'contained' && {
color: theme.palette.action.disabled,
boxShadow: theme.shadows[0],
backgroundColor: theme.palette.action.disabledBackground,
color: (theme.vars || theme).palette.action.disabled,
boxShadow: (theme.vars || theme).shadows[0],
backgroundColor: (theme.vars || theme).palette.action.disabledBackground,
}),
},
...(ownerState.variant === 'text' && {
padding: '6px 8px',
}),
...(ownerState.variant === 'text' &&
ownerState.color !== 'inherit' && {
color: theme.palette[ownerState.color].main,
color: (theme.vars || theme).palette[ownerState.color].main,
}),
...(ownerState.variant === 'outlined' && {
padding: '5px 15px',
Expand All @@ -174,18 +174,18 @@ const ButtonRoot = styled(ButtonBase, {
}),
...(ownerState.variant === 'outlined' &&
ownerState.color !== 'inherit' && {
color: theme.palette[ownerState.color].main,
color: (theme.vars || theme).palette[ownerState.color].main,
border: `1px solid ${alpha(theme.palette[ownerState.color].main, 0.5)}`,
}),
...(ownerState.variant === 'contained' && {
color: theme.palette.getContrastText(theme.palette.grey[300]),
backgroundColor: theme.palette.grey[300],
boxShadow: theme.shadows[2],
color: theme.palette.getContrastText?.(theme.palette.grey[300]),
backgroundColor: (theme.vars || theme).palette.grey[300],
boxShadow: (theme.vars || theme).shadows[2],
}),
...(ownerState.variant === 'contained' &&
ownerState.color !== 'inherit' && {
color: theme.palette[ownerState.color].contrastText,
backgroundColor: theme.palette[ownerState.color].main,
color: (theme.vars || theme).palette[ownerState.color].contrastText,
backgroundColor: (theme.vars || theme).palette[ownerState.color].main,
}),
...(ownerState.color === 'inherit' && {
color: 'inherit',
Expand Down
37 changes: 37 additions & 0 deletions packages/mui-material/src/styles/CssVarsProvider.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
import { unstable_createCssVarsProvider as createCssVarsProvider } from '@mui/system';
import createTheme, { ThemeOptions, Theme } from './createTheme';
import { PaletteOptions } from './createPalette';

interface ThemeInput extends ThemeOptions {
colorSchemes?: Partial<
Record<
'light' | 'dark',
Omit<PaletteOptions, 'getContrastText' | 'contrastThreshold' | 'tonalOffset' | 'mode'>
>
>;
}

const defaultTheme = createTheme();
const darkTheme = createTheme({ palette: { mode: 'dark' } });

const { CssVarsProvider, useColorScheme, getInitColorSchemeScript } = createCssVarsProvider<
'light' | 'dark',
ThemeInput
>({
theme: {
...defaultTheme,
colorSchemes: {
// TODO: Shuold we remove the non color scheme values from here, like getContrastText, contrastThreshold etc.
light: { palette: defaultTheme.palette },
dark: { palette: darkTheme.palette },
},
},
defaultColorScheme: {
light: 'light',
dark: 'dark',
},
shouldSkipGeneratingVar: (keys) =>
keys[0] === 'typography' || keys[0] === 'mixins' || keys[0] === 'breakpoints',
});

export { useColorScheme, getInitColorSchemeScript, CssVarsProvider };
2 changes: 2 additions & 0 deletions packages/mui-material/src/styles/index.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -89,3 +89,5 @@ export interface StyledComponentProps<ClassKey extends string = string> {
export { default as makeStyles } from './makeStyles';
export { default as withStyles } from './withStyles';
export { default as withTheme } from './withTheme';

export * from './CssVarsProvider';
2 changes: 2 additions & 0 deletions packages/mui-material/src/styles/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -32,3 +32,5 @@ export { StyledEngineProvider } from '@mui/system';
export { default as makeStyles } from './makeStyles';
export { default as withStyles } from './withStyles';
export { default as withTheme } from './withTheme';

export * from './CssVarsProvider';
5 changes: 4 additions & 1 deletion packages/mui-system/src/cssVars/createCssVarsProvider.js
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,10 @@ export default function createCssVarsProvider(options) {
}) {
// make sure that baseTheme is always independent of each <CssVarsProvider /> call.
// JSON.parse(JSON.stringify(...)) is okay to be used as long as the baseTheme is a plain object.
const clonedBaseTheme = React.useMemo(() => JSON.parse(JSON.stringify(baseTheme)), []);
// const clonedBaseTheme = React.useMemo(() => JSON.parse(JSON.stringify(baseTheme)), []);
// TODO: this is not working for MD theme where there are functions, like
// transitions.create, palette.getContrastText etc.
const clonedBaseTheme = React.useMemo(() => ({ ...baseTheme }), []);
mnajdova marked this conversation as resolved.
Show resolved Hide resolved

const { colorSchemes: baseColorSchemes = {}, ...restBaseTheme } = clonedBaseTheme;
const { colorSchemes: colorSchemesProp = {}, ...restThemeProp } = themeProp;
Expand Down