@mui/system 6.0.0-alpha.0 → 6.0.0-alpha.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (199) hide show
  1. package/CHANGELOG.md +591 -6
  2. package/Container/Container.d.ts +1 -1
  3. package/Container/createContainer.js +39 -35
  4. package/RtlProvider/index.js +8 -11
  5. package/Stack/Stack.d.ts +1 -1
  6. package/Stack/createStack.d.ts +1 -1
  7. package/Stack/createStack.js +24 -26
  8. package/ThemeProvider/ThemeProvider.js +9 -5
  9. package/Unstable_Grid/Grid.d.ts +1 -1
  10. package/Unstable_Grid/createGrid.d.ts +1 -1
  11. package/Unstable_Grid/createGrid.js +21 -23
  12. package/Unstable_Grid/gridGenerator.js +20 -17
  13. package/breakpoints/breakpoints.js +26 -7
  14. package/createBox/createBox.js +9 -12
  15. package/createStyled/createStyled.js +56 -51
  16. package/createTheme/applyStyles.d.ts +1 -1
  17. package/createTheme/applyStyles.js +1 -1
  18. package/createTheme/createBreakpoints.js +24 -25
  19. package/createTheme/createSpacing.d.ts +2 -2
  20. package/createTheme/createSpacing.js +7 -8
  21. package/createTheme/createTheme.d.ts +2 -1
  22. package/createTheme/createTheme.js +20 -14
  23. package/cssContainerQueries/cssContainerQueries.d.ts +24 -0
  24. package/cssContainerQueries/cssContainerQueries.js +70 -0
  25. package/cssContainerQueries/index.d.ts +3 -0
  26. package/cssContainerQueries/index.js +2 -0
  27. package/cssContainerQueries/package.json +6 -0
  28. package/cssVars/createCssVarsProvider.d.ts +1 -1
  29. package/cssVars/createCssVarsProvider.js +20 -16
  30. package/cssVars/createCssVarsTheme.js +3 -3
  31. package/cssVars/cssVarsParser.d.ts +1 -1
  32. package/cssVars/cssVarsParser.js +3 -2
  33. package/cssVars/index.d.ts +2 -0
  34. package/cssVars/index.js +1 -0
  35. package/cssVars/prepareCssVars.js +30 -25
  36. package/cssVars/prepareTypographyVars.d.ts +8 -0
  37. package/cssVars/prepareTypographyVars.js +11 -0
  38. package/cssVars/useCurrentColorScheme.js +18 -11
  39. package/index.d.ts +2 -0
  40. package/index.js +2 -1
  41. package/modern/Container/createContainer.js +39 -35
  42. package/modern/RtlProvider/index.js +8 -11
  43. package/modern/Stack/createStack.js +24 -26
  44. package/modern/ThemeProvider/ThemeProvider.js +9 -5
  45. package/modern/Unstable_Grid/createGrid.js +21 -23
  46. package/modern/Unstable_Grid/gridGenerator.js +20 -17
  47. package/modern/breakpoints/breakpoints.js +26 -7
  48. package/modern/createBox/createBox.js +9 -12
  49. package/modern/createStyled/createStyled.js +56 -51
  50. package/modern/createTheme/applyStyles.js +1 -1
  51. package/modern/createTheme/createBreakpoints.js +24 -25
  52. package/modern/createTheme/createSpacing.js +7 -8
  53. package/modern/createTheme/createTheme.js +20 -14
  54. package/modern/cssContainerQueries/cssContainerQueries.js +70 -0
  55. package/modern/cssContainerQueries/index.js +2 -0
  56. package/modern/cssVars/createCssVarsProvider.js +20 -16
  57. package/modern/cssVars/createCssVarsTheme.js +3 -3
  58. package/modern/cssVars/cssVarsParser.js +3 -2
  59. package/modern/cssVars/index.js +1 -0
  60. package/modern/cssVars/prepareCssVars.js +30 -25
  61. package/modern/cssVars/prepareTypographyVars.js +11 -0
  62. package/modern/cssVars/useCurrentColorScheme.js +18 -11
  63. package/modern/index.js +2 -1
  64. package/modern/propsToClassKey/propsToClassKey.js +3 -5
  65. package/modern/spacing/spacing.js +24 -21
  66. package/modern/styleFunctionSx/defaultSxConfig.js +3 -0
  67. package/modern/styleFunctionSx/extendSxProp.js +14 -10
  68. package/modern/styleFunctionSx/styleFunctionSx.js +2 -1
  69. package/node/Container/createContainer.js +39 -35
  70. package/node/RtlProvider/index.js +8 -11
  71. package/node/Stack/createStack.js +24 -26
  72. package/node/ThemeProvider/ThemeProvider.js +9 -5
  73. package/node/Unstable_Grid/createGrid.js +23 -25
  74. package/node/Unstable_Grid/gridGenerator.js +20 -18
  75. package/node/breakpoints/breakpoints.js +26 -7
  76. package/node/createBox/createBox.js +9 -12
  77. package/node/createStyled/createStyled.js +58 -52
  78. package/node/createTheme/applyStyles.js +1 -1
  79. package/node/createTheme/createBreakpoints.js +24 -26
  80. package/node/createTheme/createSpacing.js +7 -8
  81. package/node/createTheme/createTheme.js +20 -14
  82. package/node/cssContainerQueries/cssContainerQueries.js +81 -0
  83. package/node/cssContainerQueries/index.js +32 -0
  84. package/node/cssVars/createCssVarsProvider.js +20 -16
  85. package/node/cssVars/createCssVarsTheme.js +3 -3
  86. package/node/cssVars/cssVarsParser.js +3 -2
  87. package/node/cssVars/index.js +7 -0
  88. package/node/cssVars/prepareCssVars.js +30 -25
  89. package/node/cssVars/prepareTypographyVars.js +17 -0
  90. package/node/cssVars/useCurrentColorScheme.js +18 -12
  91. package/node/index.js +9 -1
  92. package/node/propsToClassKey/propsToClassKey.js +3 -5
  93. package/node/spacing/spacing.js +24 -21
  94. package/node/styleFunctionSx/defaultSxConfig.js +3 -0
  95. package/node/styleFunctionSx/extendSxProp.js +14 -10
  96. package/node/styleFunctionSx/styleFunctionSx.js +2 -1
  97. package/package.json +6 -6
  98. package/propsToClassKey/propsToClassKey.js +3 -5
  99. package/spacing/spacing.js +24 -21
  100. package/styleFunctionSx/defaultSxConfig.js +3 -0
  101. package/styleFunctionSx/extendSxProp.js +14 -10
  102. package/styleFunctionSx/styleFunctionSx.js +2 -1
  103. package/legacy/Box/Box.js +0 -30
  104. package/legacy/Box/boxClasses.js +0 -3
  105. package/legacy/Box/index.js +0 -5
  106. package/legacy/Container/Container.js +0 -61
  107. package/legacy/Container/ContainerProps.js +0 -1
  108. package/legacy/Container/containerClasses.js +0 -7
  109. package/legacy/Container/createContainer.js +0 -140
  110. package/legacy/Container/index.js +0 -5
  111. package/legacy/GlobalStyles/GlobalStyles.js +0 -37
  112. package/legacy/GlobalStyles/index.js +0 -4
  113. package/legacy/RtlProvider/index.js +0 -22
  114. package/legacy/Stack/Stack.js +0 -62
  115. package/legacy/Stack/StackProps.js +0 -1
  116. package/legacy/Stack/createStack.js +0 -180
  117. package/legacy/Stack/index.js +0 -7
  118. package/legacy/Stack/stackClasses.js +0 -7
  119. package/legacy/ThemeProvider/ThemeProvider.js +0 -87
  120. package/legacy/ThemeProvider/index.js +0 -3
  121. package/legacy/Unstable_Grid/Grid.js +0 -177
  122. package/legacy/Unstable_Grid/GridProps.js +0 -1
  123. package/legacy/Unstable_Grid/createGrid.js +0 -184
  124. package/legacy/Unstable_Grid/gridClasses.js +0 -28
  125. package/legacy/Unstable_Grid/gridGenerator.js +0 -216
  126. package/legacy/Unstable_Grid/index.js +0 -8
  127. package/legacy/Unstable_Grid/traverseBreakpoints.js +0 -48
  128. package/legacy/borders/borders.js +0 -51
  129. package/legacy/borders/index.js +0 -4
  130. package/legacy/breakpoints/breakpoints.js +0 -162
  131. package/legacy/breakpoints/index.js +0 -4
  132. package/legacy/colorManipulator/colorManipulator.js +0 -356
  133. package/legacy/colorManipulator/index.js +0 -3
  134. package/legacy/compose/compose.js +0 -32
  135. package/legacy/compose/index.js +0 -3
  136. package/legacy/createBox/createBox.js +0 -38
  137. package/legacy/createBox/index.js +0 -3
  138. package/legacy/createStyled/createStyled.js +0 -250
  139. package/legacy/createStyled/index.js +0 -4
  140. package/legacy/createTheme/applyStyles.js +0 -73
  141. package/legacy/createTheme/createBreakpoints.js +0 -83
  142. package/legacy/createTheme/createSpacing.js +0 -36
  143. package/legacy/createTheme/createTheme.js +0 -49
  144. package/legacy/createTheme/index.js +0 -3
  145. package/legacy/createTheme/shape.js +0 -4
  146. package/legacy/cssGrid/cssGrid.js +0 -91
  147. package/legacy/cssGrid/index.js +0 -4
  148. package/legacy/cssVars/createCssVarsProvider.js +0 -335
  149. package/legacy/cssVars/createCssVarsTheme.js +0 -13
  150. package/legacy/cssVars/createGetCssVar.js +0 -30
  151. package/legacy/cssVars/cssVarsParser.js +0 -140
  152. package/legacy/cssVars/getInitColorSchemeScript.js +0 -28
  153. package/legacy/cssVars/index.js +0 -6
  154. package/legacy/cssVars/prepareCssVars.js +0 -92
  155. package/legacy/cssVars/useCurrentColorScheme.js +0 -237
  156. package/legacy/display/display.js +0 -29
  157. package/legacy/display/index.js +0 -4
  158. package/legacy/flexbox/flexbox.js +0 -43
  159. package/legacy/flexbox/index.js +0 -4
  160. package/legacy/getThemeValue/getThemeValue.js +0 -47
  161. package/legacy/getThemeValue/index.js +0 -4
  162. package/legacy/index.js +0 -72
  163. package/legacy/memoize/index.js +0 -3
  164. package/legacy/memoize/memoize.js +0 -9
  165. package/legacy/merge/index.js +0 -3
  166. package/legacy/merge/merge.js +0 -10
  167. package/legacy/palette/index.js +0 -4
  168. package/legacy/palette/palette.js +0 -26
  169. package/legacy/positions/index.js +0 -4
  170. package/legacy/positions/positions.js +0 -22
  171. package/legacy/propsToClassKey/index.js +0 -3
  172. package/legacy/propsToClassKey/propsToClassKey.js +0 -24
  173. package/legacy/responsivePropType/index.js +0 -3
  174. package/legacy/responsivePropType/responsivePropType.js +0 -3
  175. package/legacy/shadows/index.js +0 -3
  176. package/legacy/shadows/shadows.js +0 -6
  177. package/legacy/sizing/index.js +0 -4
  178. package/legacy/sizing/sizing.js +0 -65
  179. package/legacy/spacing/index.js +0 -4
  180. package/legacy/spacing/spacing.js +0 -158
  181. package/legacy/style/index.js +0 -4
  182. package/legacy/style/style.js +0 -73
  183. package/legacy/styleFunctionSx/defaultSxConfig.js +0 -293
  184. package/legacy/styleFunctionSx/extendSxProp.js +0 -45
  185. package/legacy/styleFunctionSx/index.js +0 -4
  186. package/legacy/styleFunctionSx/styleFunctionSx.js +0 -126
  187. package/legacy/styled/index.js +0 -3
  188. package/legacy/styled/styled.js +0 -3
  189. package/legacy/typography/index.js +0 -4
  190. package/legacy/typography/typography.js +0 -37
  191. package/legacy/useMediaQuery/index.js +0 -2
  192. package/legacy/useMediaQuery/useMediaQuery.js +0 -145
  193. package/legacy/useTheme/index.js +0 -4
  194. package/legacy/useTheme/useTheme.js +0 -10
  195. package/legacy/useThemeProps/getThemeProps.js +0 -10
  196. package/legacy/useThemeProps/index.js +0 -4
  197. package/legacy/useThemeProps/useThemeProps.js +0 -20
  198. package/legacy/useThemeWithoutDefault/index.js +0 -3
  199. package/legacy/useThemeWithoutDefault/useThemeWithoutDefault.js +0 -13
@@ -1,6 +1,3 @@
1
- import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
2
- import _extends from "@babel/runtime/helpers/esm/extends";
3
- const _excluded = ["className", "component", "disableGutters", "fixed", "maxWidth", "classes"];
4
1
  import * as React from 'react';
5
2
  import PropTypes from 'prop-types';
6
3
  import clsx from 'clsx';
@@ -52,20 +49,20 @@ export default function createContainer(options = {}) {
52
49
  const ContainerRoot = createStyledComponent(({
53
50
  theme,
54
51
  ownerState
55
- }) => _extends({
52
+ }) => ({
56
53
  width: '100%',
57
54
  marginLeft: 'auto',
58
55
  boxSizing: 'border-box',
59
56
  marginRight: 'auto',
60
- display: 'block'
61
- }, !ownerState.disableGutters && {
62
- paddingLeft: theme.spacing(2),
63
- paddingRight: theme.spacing(2),
64
- // @ts-ignore module augmentation fails if custom breakpoints are used
65
- [theme.breakpoints.up('sm')]: {
66
- paddingLeft: theme.spacing(3),
67
- paddingRight: theme.spacing(3)
68
- }
57
+ ...(!ownerState.disableGutters && {
58
+ paddingLeft: theme.spacing(2),
59
+ paddingRight: theme.spacing(2),
60
+ // @ts-ignore module augmentation fails if custom breakpoints are used
61
+ [theme.breakpoints.up('sm')]: {
62
+ paddingLeft: theme.spacing(3),
63
+ paddingRight: theme.spacing(3)
64
+ }
65
+ })
69
66
  }), ({
70
67
  theme,
71
68
  ownerState
@@ -82,51 +79,58 @@ export default function createContainer(options = {}) {
82
79
  }, {}), ({
83
80
  theme,
84
81
  ownerState
85
- }) => _extends({}, ownerState.maxWidth === 'xs' && {
82
+ }) => ({
86
83
  // @ts-ignore module augmentation fails if custom breakpoints are used
87
- [theme.breakpoints.up('xs')]: {
84
+ ...(ownerState.maxWidth === 'xs' && {
88
85
  // @ts-ignore module augmentation fails if custom breakpoints are used
89
- maxWidth: Math.max(theme.breakpoints.values.xs, 444)
90
- }
91
- }, ownerState.maxWidth &&
92
- // @ts-ignore module augmentation fails if custom breakpoints are used
93
- ownerState.maxWidth !== 'xs' && {
86
+ [theme.breakpoints.up('xs')]: {
87
+ // @ts-ignore module augmentation fails if custom breakpoints are used
88
+ maxWidth: Math.max(theme.breakpoints.values.xs, 444)
89
+ }
90
+ }),
91
+ ...(ownerState.maxWidth &&
94
92
  // @ts-ignore module augmentation fails if custom breakpoints are used
95
- [theme.breakpoints.up(ownerState.maxWidth)]: {
93
+ ownerState.maxWidth !== 'xs' && {
96
94
  // @ts-ignore module augmentation fails if custom breakpoints are used
97
- maxWidth: `${theme.breakpoints.values[ownerState.maxWidth]}${theme.breakpoints.unit}`
98
- }
95
+ [theme.breakpoints.up(ownerState.maxWidth)]: {
96
+ // @ts-ignore module augmentation fails if custom breakpoints are used
97
+ maxWidth: `${theme.breakpoints.values[ownerState.maxWidth]}${theme.breakpoints.unit}`
98
+ }
99
+ })
99
100
  }));
100
101
  const Container = /*#__PURE__*/React.forwardRef(function Container(inProps, ref) {
101
102
  const props = useThemeProps(inProps);
102
103
  const {
103
- className,
104
- component = 'div',
105
- disableGutters = false,
106
- fixed = false,
107
- maxWidth = 'lg'
108
- } = props,
109
- other = _objectWithoutPropertiesLoose(props, _excluded);
110
- const ownerState = _extends({}, props, {
104
+ className,
105
+ component = 'div',
106
+ disableGutters = false,
107
+ fixed = false,
108
+ maxWidth = 'lg',
109
+ classes: classesProp,
110
+ ...other
111
+ } = props;
112
+ const ownerState = {
113
+ ...props,
111
114
  component,
112
115
  disableGutters,
113
116
  fixed,
114
117
  maxWidth
115
- });
118
+ };
116
119
 
117
120
  // @ts-ignore module augmentation fails if custom breakpoints are used
118
121
  const classes = useUtilityClasses(ownerState, componentName);
119
122
  return (
120
123
  /*#__PURE__*/
121
124
  // @ts-ignore theme is injected by the styled util
122
- _jsx(ContainerRoot, _extends({
125
+ _jsx(ContainerRoot, {
123
126
  as: component
124
127
  // @ts-ignore module augmentation fails if custom breakpoints are used
125
128
  ,
126
129
  ownerState: ownerState,
127
130
  className: clsx(classes.root, className),
128
- ref: ref
129
- }, other))
131
+ ref: ref,
132
+ ...other
133
+ })
130
134
  );
131
135
  });
132
136
  process.env.NODE_ENV !== "production" ? Container.propTypes /* remove-proptypes */ = {
@@ -1,18 +1,15 @@
1
- import _extends from "@babel/runtime/helpers/esm/extends";
2
- import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
3
- const _excluded = ["value"];
4
1
  import * as React from 'react';
5
2
  import PropTypes from 'prop-types';
6
3
  import { jsx as _jsx } from "react/jsx-runtime";
7
4
  const RtlContext = /*#__PURE__*/React.createContext();
8
- function RtlProvider(_ref) {
9
- let {
10
- value
11
- } = _ref,
12
- props = _objectWithoutPropertiesLoose(_ref, _excluded);
13
- return /*#__PURE__*/_jsx(RtlContext.Provider, _extends({
14
- value: value ?? true
15
- }, props));
5
+ function RtlProvider({
6
+ value,
7
+ ...props
8
+ }) {
9
+ return /*#__PURE__*/_jsx(RtlContext.Provider, {
10
+ value: value ?? true,
11
+ ...props
12
+ });
16
13
  }
17
14
  process.env.NODE_ENV !== "production" ? RtlProvider.propTypes = {
18
15
  children: PropTypes.node,
package/Stack/Stack.d.ts CHANGED
@@ -10,5 +10,5 @@
10
10
  *
11
11
  * - [Stack API](https://mui.com/system/api/stack/)
12
12
  */
13
- declare const Stack: import("@mui/types").OverridableComponent<import("@mui/system").StackTypeMap<{}, "div">>;
13
+ declare const Stack: import("@mui/types").OverridableComponent<import("./StackProps").StackTypeMap<{}, "div">>;
14
14
  export default Stack;
@@ -10,7 +10,7 @@ interface StyleFunctionProps {
10
10
  };
11
11
  ownerState: StackOwnerState;
12
12
  }
13
- declare const defaultCreateStyledComponent: import("@mui/styled-engine").CreateStyledComponent<import("@mui/system/createStyled/createStyled").MUIStyledCommonProps<any>, Pick<React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, keyof React.ClassAttributes<HTMLDivElement> | keyof React.HTMLAttributes<HTMLDivElement>>, {}, any>;
13
+ declare const defaultCreateStyledComponent: import("@mui/styled-engine").CreateStyledComponent<import("../createStyled").MUIStyledCommonProps<any>, Pick<React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, keyof React.ClassAttributes<HTMLDivElement> | keyof React.HTMLAttributes<HTMLDivElement>>, {}, any>;
14
14
  declare function useThemePropsDefault<T extends {}>(props: T): T;
15
15
  export declare const style: ({ ownerState, theme }: StyleFunctionProps) => any;
16
16
  export default function createStack(options?: {
@@ -1,6 +1,3 @@
1
- import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
2
- import _extends from "@babel/runtime/helpers/esm/extends";
3
- const _excluded = ["component", "direction", "spacing", "divider", "children", "className", "useFlexGap"];
4
1
  import * as React from 'react';
5
2
  import PropTypes from 'prop-types';
6
3
  import clsx from 'clsx';
@@ -60,17 +57,18 @@ export const style = ({
60
57
  ownerState,
61
58
  theme
62
59
  }) => {
63
- let styles = _extends({
60
+ let styles = {
64
61
  display: 'flex',
65
- flexDirection: 'column'
66
- }, handleBreakpoints({
67
- theme
68
- }, resolveBreakpointValues({
69
- values: ownerState.direction,
70
- breakpoints: theme.breakpoints.values
71
- }), propValue => ({
72
- flexDirection: propValue
73
- })));
62
+ flexDirection: 'column',
63
+ ...handleBreakpoints({
64
+ theme
65
+ }, resolveBreakpointValues({
66
+ values: ownerState.direction,
67
+ breakpoints: theme.breakpoints.values
68
+ }), propValue => ({
69
+ flexDirection: propValue
70
+ }))
71
+ };
74
72
  if (ownerState.spacing) {
75
73
  const transformer = createUnarySpacing(theme);
76
74
  const base = Object.keys(theme.breakpoints.values).reduce((acc, breakpoint) => {
@@ -138,29 +136,29 @@ export default function createStack(options = {}) {
138
136
  const themeProps = useThemeProps(inProps);
139
137
  const props = extendSxProp(themeProps); // `color` type conflicts with html color attribute.
140
138
  const {
141
- component = 'div',
142
- direction = 'column',
143
- spacing = 0,
144
- divider,
145
- children,
146
- className,
147
- useFlexGap = false
148
- } = props,
149
- other = _objectWithoutPropertiesLoose(props, _excluded);
139
+ component = 'div',
140
+ direction = 'column',
141
+ spacing = 0,
142
+ divider,
143
+ children,
144
+ className,
145
+ useFlexGap = false,
146
+ ...other
147
+ } = props;
150
148
  const ownerState = {
151
149
  direction,
152
150
  spacing,
153
151
  useFlexGap
154
152
  };
155
153
  const classes = useUtilityClasses();
156
- return /*#__PURE__*/_jsx(StackRoot, _extends({
154
+ return /*#__PURE__*/_jsx(StackRoot, {
157
155
  as: component,
158
156
  ownerState: ownerState,
159
157
  ref: ref,
160
- className: clsx(classes.root, className)
161
- }, other, {
158
+ className: clsx(classes.root, className),
159
+ ...other,
162
160
  children: divider ? joinChildren(children, divider) : children
163
- }));
161
+ });
164
162
  });
165
163
  process.env.NODE_ENV !== "production" ? Stack.propTypes /* remove-proptypes */ = {
166
164
  children: PropTypes.node,
@@ -1,6 +1,5 @@
1
1
  'use client';
2
2
 
3
- import _extends from "@babel/runtime/helpers/esm/extends";
4
3
  import * as React from 'react';
5
4
  import PropTypes from 'prop-types';
6
5
  import { ThemeProvider as MuiThemeProvider, useTheme as usePrivateTheme } from '@mui/private-theming';
@@ -15,9 +14,10 @@ function useThemeScoping(themeId, upperTheme, localTheme, isPrivate = false) {
15
14
  const resolvedTheme = themeId ? upperTheme[themeId] || upperTheme : upperTheme;
16
15
  if (typeof localTheme === 'function') {
17
16
  const mergedTheme = localTheme(resolvedTheme);
18
- const result = themeId ? _extends({}, upperTheme, {
17
+ const result = themeId ? {
18
+ ...upperTheme,
19
19
  [themeId]: mergedTheme
20
- }) : mergedTheme;
20
+ } : mergedTheme;
21
21
  // must return a function for the private theme to NOT merge with the upper theme.
22
22
  // see the test case "use provided theme from a callback" in ThemeProvider.test.js
23
23
  if (isPrivate) {
@@ -25,9 +25,13 @@ function useThemeScoping(themeId, upperTheme, localTheme, isPrivate = false) {
25
25
  }
26
26
  return result;
27
27
  }
28
- return themeId ? _extends({}, upperTheme, {
28
+ return themeId ? {
29
+ ...upperTheme,
29
30
  [themeId]: localTheme
30
- }) : _extends({}, upperTheme, localTheme);
31
+ } : {
32
+ ...upperTheme,
33
+ ...localTheme
34
+ };
31
35
  }, [themeId, upperTheme, localTheme, isPrivate]);
32
36
  }
33
37
 
@@ -9,5 +9,5 @@
9
9
  *
10
10
  * - [Grid API](https://mui.com/system/api/grid/)
11
11
  */
12
- declare const Grid: import("@mui/types").OverridableComponent<import("@mui/system").GridTypeMap<{}, "div">>;
12
+ declare const Grid: import("@mui/types").OverridableComponent<import("./GridProps").GridTypeMap<{}, "div">>;
13
13
  export default Grid;
@@ -1,7 +1,7 @@
1
1
  import * as React from 'react';
2
2
  import { OverridableComponent } from '@mui/types';
3
3
  import { GridTypeMap } from './GridProps';
4
- declare const defaultCreateStyledComponent: import("@mui/styled-engine").CreateStyledComponent<import("@mui/system/createStyled/createStyled").MUIStyledCommonProps<any>, Pick<React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, keyof React.ClassAttributes<HTMLDivElement> | keyof React.HTMLAttributes<HTMLDivElement>>, {}, any>;
4
+ declare const defaultCreateStyledComponent: import("@mui/styled-engine").CreateStyledComponent<import("../createStyled").MUIStyledCommonProps<any>, Pick<React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, keyof React.ClassAttributes<HTMLDivElement> | keyof React.HTMLAttributes<HTMLDivElement>>, {}, any>;
5
5
  declare function useThemePropsDefault<T extends {}>(props: T): T;
6
6
  export default function createGrid(options?: {
7
7
  createStyledComponent?: typeof defaultCreateStyledComponent;
@@ -1,6 +1,3 @@
1
- import _extends from "@babel/runtime/helpers/esm/extends";
2
- import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
3
- const _excluded = ["className", "children", "columns", "container", "component", "direction", "wrap", "spacing", "rowSpacing", "columnSpacing", "disableEqualOverflow", "unstable_level"];
4
1
  import * as React from 'react';
5
2
  import PropTypes from 'prop-types';
6
3
  import clsx from 'clsx';
@@ -60,20 +57,20 @@ export default function createGrid(options = {}) {
60
57
  const props = extendSxProp(themeProps); // `color` type conflicts with html color attribute.
61
58
  const overflow = React.useContext(GridOverflowContext);
62
59
  const {
63
- className,
64
- children,
65
- columns: columnsProp = 12,
66
- container = false,
67
- component = 'div',
68
- direction = 'row',
69
- wrap = 'wrap',
70
- spacing: spacingProp = 0,
71
- rowSpacing: rowSpacingProp = spacingProp,
72
- columnSpacing: columnSpacingProp = spacingProp,
73
- disableEqualOverflow: themeDisableEqualOverflow,
74
- unstable_level: level = 0
75
- } = props,
76
- rest = _objectWithoutPropertiesLoose(props, _excluded);
60
+ className,
61
+ children,
62
+ columns: columnsProp = 12,
63
+ container = false,
64
+ component = 'div',
65
+ direction = 'row',
66
+ wrap = 'wrap',
67
+ spacing: spacingProp = 0,
68
+ rowSpacing: rowSpacingProp = spacingProp,
69
+ columnSpacing: columnSpacingProp = spacingProp,
70
+ disableEqualOverflow: themeDisableEqualOverflow,
71
+ unstable_level: level = 0,
72
+ ...rest
73
+ } = props;
77
74
  // Because `disableEqualOverflow` can be set from the theme's defaultProps, the **nested** grid should look at the instance props instead.
78
75
  let disableEqualOverflow = themeDisableEqualOverflow;
79
76
  if (level && themeDisableEqualOverflow !== undefined) {
@@ -96,7 +93,8 @@ export default function createGrid(options = {}) {
96
93
  const spacing = inProps.spacing ?? (level ? undefined : spacingProp);
97
94
  const rowSpacing = inProps.rowSpacing ?? inProps.spacing ?? (level ? undefined : rowSpacingProp);
98
95
  const columnSpacing = inProps.columnSpacing ?? inProps.spacing ?? (level ? undefined : columnSpacingProp);
99
- const ownerState = _extends({}, props, {
96
+ const ownerState = {
97
+ ...props,
100
98
  level,
101
99
  columns,
102
100
  container,
@@ -110,14 +108,14 @@ export default function createGrid(options = {}) {
110
108
  disableEqualOverflow: disableEqualOverflow ?? overflow ?? false,
111
109
  // use context value if exists.
112
110
  parentDisableEqualOverflow: overflow // for nested grid
113
- });
111
+ };
114
112
  const classes = useUtilityClasses(ownerState, theme);
115
- let result = /*#__PURE__*/_jsx(GridRoot, _extends({
113
+ let result = /*#__PURE__*/_jsx(GridRoot, {
116
114
  ref: ref,
117
115
  as: component,
118
116
  ownerState: ownerState,
119
- className: clsx(classes.root, className)
120
- }, other, {
117
+ className: clsx(classes.root, className),
118
+ ...other,
121
119
  children: React.Children.map(children, child => {
122
120
  if ( /*#__PURE__*/React.isValidElement(child) && isMuiElement(child, ['Grid'])) {
123
121
  return /*#__PURE__*/React.cloneElement(child, {
@@ -126,7 +124,7 @@ export default function createGrid(options = {}) {
126
124
  }
127
125
  return child;
128
126
  })
129
- }));
127
+ });
130
128
  if (disableEqualOverflow !== undefined && disableEqualOverflow !== (overflow ?? false)) {
131
129
  // There are 2 possibilities that should wrap with the GridOverflowContext to communicate with the nested grids:
132
130
  // 1. It is the root grid with `disableEqualOverflow`.
@@ -1,4 +1,3 @@
1
- import _extends from "@babel/runtime/helpers/esm/extends";
2
1
  import { traverseBreakpoints } from './traverseBreakpoints';
3
2
  function appendLevel(level) {
4
3
  if (!level) {
@@ -163,23 +162,27 @@ export const generateGridStyles = ({
163
162
  }) => {
164
163
  const getSelfSpacing = createGetSelfSpacing(ownerState);
165
164
  const getParentSpacing = createGetParentSpacing(ownerState);
166
- return _extends({
165
+ return {
167
166
  minWidth: 0,
168
- boxSizing: 'border-box'
169
- }, ownerState.container && _extends({
170
- display: 'flex',
171
- flexWrap: 'wrap'
172
- }, ownerState.wrap && ownerState.wrap !== 'wrap' && {
173
- flexWrap: ownerState.wrap
174
- }, {
175
- margin: `calc(${getSelfSpacing('row')} / -2) calc(${getSelfSpacing('column')} / -2)`
176
- }, ownerState.disableEqualOverflow && {
177
- margin: `calc(${getSelfSpacing('row')} * -1) 0px 0px calc(${getSelfSpacing('column')} * -1)`
178
- }), (!ownerState.container || isNestedContainer(ownerState)) && _extends({
179
- padding: `calc(${getParentSpacing('row')} / 2) calc(${getParentSpacing('column')} / 2)`
180
- }, (ownerState.disableEqualOverflow || ownerState.parentDisableEqualOverflow) && {
181
- padding: `${getParentSpacing('row')} 0px 0px ${getParentSpacing('column')}`
182
- }));
167
+ boxSizing: 'border-box',
168
+ ...(ownerState.container && {
169
+ display: 'flex',
170
+ flexWrap: 'wrap',
171
+ ...(ownerState.wrap && ownerState.wrap !== 'wrap' && {
172
+ flexWrap: ownerState.wrap
173
+ }),
174
+ margin: `calc(${getSelfSpacing('row')} / -2) calc(${getSelfSpacing('column')} / -2)`,
175
+ ...(ownerState.disableEqualOverflow && {
176
+ margin: `calc(${getSelfSpacing('row')} * -1) 0px 0px calc(${getSelfSpacing('column')} * -1)`
177
+ })
178
+ }),
179
+ ...((!ownerState.container || isNestedContainer(ownerState)) && {
180
+ padding: `calc(${getParentSpacing('row')} / 2) calc(${getParentSpacing('column')} / 2)`,
181
+ ...((ownerState.disableEqualOverflow || ownerState.parentDisableEqualOverflow) && {
182
+ padding: `${getParentSpacing('row')} 0px 0px ${getParentSpacing('column')}`
183
+ })
184
+ })
185
+ };
183
186
  };
184
187
  export const generateSizeClassNames = gridSize => {
185
188
  const classNames = [];
@@ -1,7 +1,7 @@
1
- import _extends from "@babel/runtime/helpers/esm/extends";
2
1
  import PropTypes from 'prop-types';
3
2
  import deepmerge from '@mui/utils/deepmerge';
4
3
  import merge from '../merge';
4
+ import { isCqShorthand, getContainerQuery } from '../cssContainerQueries';
5
5
 
6
6
  // The breakpoint **start** at this value.
7
7
  // For instance with the first breakpoint xs: [xs, sm[.
@@ -22,6 +22,17 @@ const defaultBreakpoints = {
22
22
  keys: ['xs', 'sm', 'md', 'lg', 'xl'],
23
23
  up: key => `@media (min-width:${values[key]}px)`
24
24
  };
25
+ const defaultContainerQueries = {
26
+ containerQueries: containerName => ({
27
+ up: key => {
28
+ let result = typeof key === 'number' ? key : values[key] || key;
29
+ if (typeof result === 'number') {
30
+ result = `${result}px`;
31
+ }
32
+ return containerName ? `@container ${containerName} (min-width:${result})` : `@container (min-width:${result})`;
33
+ }
34
+ })
35
+ };
25
36
  export function handleBreakpoints(props, propValue, styleFromPropValue) {
26
37
  const theme = props.theme || {};
27
38
  if (Array.isArray(propValue)) {
@@ -34,8 +45,14 @@ export function handleBreakpoints(props, propValue, styleFromPropValue) {
34
45
  if (typeof propValue === 'object') {
35
46
  const themeBreakpoints = theme.breakpoints || defaultBreakpoints;
36
47
  return Object.keys(propValue).reduce((acc, breakpoint) => {
48
+ if (isCqShorthand(themeBreakpoints.keys, breakpoint)) {
49
+ const containerKey = getContainerQuery(theme.containerQueries ? theme : defaultContainerQueries, breakpoint);
50
+ if (containerKey) {
51
+ acc[containerKey] = styleFromPropValue(propValue[breakpoint], breakpoint);
52
+ }
53
+ }
37
54
  // key is breakpoint
38
- if (Object.keys(themeBreakpoints.values || values).indexOf(breakpoint) !== -1) {
55
+ else if (Object.keys(themeBreakpoints.values || values).indexOf(breakpoint) !== -1) {
39
56
  const mediaKey = themeBreakpoints.up(breakpoint);
40
57
  acc[mediaKey] = styleFromPropValue(propValue[breakpoint], breakpoint);
41
58
  } else {
@@ -58,21 +75,23 @@ function breakpoints(styleFunction) {
58
75
  const extended = themeBreakpoints.keys.reduce((acc, key) => {
59
76
  if (props[key]) {
60
77
  acc = acc || {};
61
- acc[themeBreakpoints.up(key)] = styleFunction(_extends({
62
- theme
63
- }, props[key]));
78
+ acc[themeBreakpoints.up(key)] = styleFunction({
79
+ theme,
80
+ ...props[key]
81
+ });
64
82
  }
65
83
  return acc;
66
84
  }, null);
67
85
  return merge(base, extended);
68
86
  };
69
- newStyleFunction.propTypes = process.env.NODE_ENV !== 'production' ? _extends({}, styleFunction.propTypes, {
87
+ newStyleFunction.propTypes = process.env.NODE_ENV !== 'production' ? {
88
+ ...styleFunction.propTypes,
70
89
  xs: PropTypes.object,
71
90
  sm: PropTypes.object,
72
91
  md: PropTypes.object,
73
92
  lg: PropTypes.object,
74
93
  xl: PropTypes.object
75
- }) : {};
94
+ } : {};
76
95
  newStyleFunction.filterProps = ['xs', 'sm', 'md', 'lg', 'xl', ...styleFunction.filterProps];
77
96
  return newStyleFunction;
78
97
  }
@@ -1,8 +1,5 @@
1
1
  'use client';
2
2
 
3
- import _extends from "@babel/runtime/helpers/esm/extends";
4
- import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
5
- const _excluded = ["className", "component"];
6
3
  import * as React from 'react';
7
4
  import clsx from 'clsx';
8
5
  import styled from '@mui/styled-engine';
@@ -21,18 +18,18 @@ export default function createBox(options = {}) {
21
18
  })(styleFunctionSx);
22
19
  const Box = /*#__PURE__*/React.forwardRef(function Box(inProps, ref) {
23
20
  const theme = useTheme(defaultTheme);
24
- const _extendSxProp = extendSxProp(inProps),
25
- {
26
- className,
27
- component = 'div'
28
- } = _extendSxProp,
29
- other = _objectWithoutPropertiesLoose(_extendSxProp, _excluded);
30
- return /*#__PURE__*/_jsx(BoxRoot, _extends({
21
+ const {
22
+ className,
23
+ component = 'div',
24
+ ...other
25
+ } = extendSxProp(inProps);
26
+ return /*#__PURE__*/_jsx(BoxRoot, {
31
27
  as: component,
32
28
  ref: ref,
33
29
  className: clsx(className, generateClassName ? generateClassName(defaultClassName) : defaultClassName),
34
- theme: themeId ? theme[themeId] || theme : theme
35
- }, other));
30
+ theme: themeId ? theme[themeId] || theme : theme,
31
+ ...other
32
+ });
36
33
  });
37
34
  return Box;
38
35
  }