@mui/system 5.13.1 → 5.13.5
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.
- package/CHANGELOG.md +184 -4
- package/Container/createContainer.js +35 -41
- package/GlobalStyles/GlobalStyles.d.ts +2 -2
- package/Stack/createStack.js +26 -24
- package/ThemeProvider/ThemeProvider.js +5 -9
- package/Unstable_Grid/createGrid.js +23 -21
- package/Unstable_Grid/gridGenerator.d.ts +1 -6
- package/Unstable_Grid/gridGenerator.js +26 -71
- package/Unstable_Grid/index.d.ts +1 -0
- package/Unstable_Grid/index.js +9 -1
- package/Unstable_Grid/traverseBreakpoints.d.ts +7 -0
- package/Unstable_Grid/traverseBreakpoints.js +50 -0
- package/breakpoints.js +6 -7
- package/createBox.js +12 -9
- package/createStyled.js +32 -40
- package/createTheme/createBreakpoints.js +26 -24
- package/createTheme/createTheme.js +14 -18
- package/cssVars/createCssVarsProvider.js +26 -21
- package/cssVars/createCssVarsTheme.js +10 -10
- package/cssVars/getInitColorSchemeScript.d.ts +2 -2
- package/cssVars/prepareCssVars.js +12 -13
- package/cssVars/useCurrentColorScheme.js +11 -17
- package/esm/Container/createContainer.js +35 -41
- package/esm/Stack/createStack.js +26 -24
- package/esm/ThemeProvider/ThemeProvider.js +5 -9
- package/esm/Unstable_Grid/createGrid.js +23 -21
- package/esm/Unstable_Grid/gridGenerator.js +18 -62
- package/esm/Unstable_Grid/index.js +2 -1
- package/esm/Unstable_Grid/traverseBreakpoints.js +42 -0
- package/esm/breakpoints.js +6 -7
- package/esm/createBox.js +12 -9
- package/esm/createStyled.js +31 -38
- package/esm/createTheme/createBreakpoints.js +25 -24
- package/esm/createTheme/createTheme.js +14 -18
- package/esm/cssVars/createCssVarsProvider.js +26 -21
- package/esm/cssVars/createCssVarsTheme.js +10 -10
- package/esm/cssVars/prepareCssVars.js +12 -13
- package/esm/cssVars/useCurrentColorScheme.js +10 -17
- package/esm/propsToClassKey.js +5 -3
- package/esm/styleFunctionSx/extendSxProp.js +10 -14
- package/index.js +1 -1
- package/legacy/Container/createContainer.js +6 -7
- package/legacy/Stack/createStack.js +5 -6
- package/legacy/ThemeProvider/ThemeProvider.js +3 -4
- package/legacy/Unstable_Grid/createGrid.js +4 -6
- package/legacy/Unstable_Grid/gridGenerator.js +7 -54
- package/legacy/Unstable_Grid/index.js +2 -1
- package/legacy/Unstable_Grid/traverseBreakpoints.js +48 -0
- package/legacy/breakpoints.js +3 -5
- package/legacy/createBox.js +2 -4
- package/legacy/createStyled.js +11 -13
- package/legacy/createTheme/createBreakpoints.js +3 -4
- package/legacy/createTheme/createTheme.js +4 -6
- package/legacy/cssVars/createCssVarsProvider.js +5 -6
- package/legacy/cssVars/createCssVarsTheme.js +2 -4
- package/legacy/cssVars/prepareCssVars.js +3 -5
- package/legacy/cssVars/useCurrentColorScheme.js +7 -9
- package/legacy/index.js +1 -1
- package/legacy/styleFunctionSx/extendSxProp.js +4 -6
- package/modern/Container/createContainer.js +35 -41
- package/modern/Stack/createStack.js +26 -24
- package/modern/ThemeProvider/ThemeProvider.js +5 -9
- package/modern/Unstable_Grid/createGrid.js +23 -21
- package/modern/Unstable_Grid/gridGenerator.js +18 -62
- package/modern/Unstable_Grid/index.js +2 -1
- package/modern/Unstable_Grid/traverseBreakpoints.js +42 -0
- package/modern/breakpoints.js +6 -7
- package/modern/createBox.js +12 -9
- package/modern/createStyled.js +31 -38
- package/modern/createTheme/createBreakpoints.js +25 -24
- package/modern/createTheme/createTheme.js +14 -18
- package/modern/cssVars/createCssVarsProvider.js +26 -21
- package/modern/cssVars/createCssVarsTheme.js +10 -10
- package/modern/cssVars/prepareCssVars.js +12 -13
- package/modern/cssVars/useCurrentColorScheme.js +10 -17
- package/modern/index.js +1 -1
- package/modern/propsToClassKey.js +5 -3
- package/modern/styleFunctionSx/extendSxProp.js +10 -14
- package/package.json +2 -2
- package/propsToClassKey.js +6 -3
- package/styleFunctionSx/extendSxProp.js +10 -14
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
1
2
|
import * as React from 'react';
|
|
2
3
|
import { DEFAULT_MODE_STORAGE_KEY, DEFAULT_COLOR_SCHEME_STORAGE_KEY } from './getInitColorSchemeScript';
|
|
3
4
|
export function getSystemMode(mode) {
|
|
@@ -81,11 +82,10 @@ export default function useCurrentColorScheme(options) {
|
|
|
81
82
|
} catch (e) {
|
|
82
83
|
// Unsupported
|
|
83
84
|
}
|
|
84
|
-
return {
|
|
85
|
-
...currentState,
|
|
85
|
+
return _extends({}, currentState, {
|
|
86
86
|
mode: newMode,
|
|
87
87
|
systemMode: getSystemMode(newMode)
|
|
88
|
-
};
|
|
88
|
+
});
|
|
89
89
|
});
|
|
90
90
|
}, [modeStorageKey, defaultMode]);
|
|
91
91
|
const setColorScheme = React.useCallback(value => {
|
|
@@ -97,20 +97,17 @@ export default function useCurrentColorScheme(options) {
|
|
|
97
97
|
} catch (e) {
|
|
98
98
|
// Unsupported
|
|
99
99
|
}
|
|
100
|
-
return {
|
|
101
|
-
...currentState,
|
|
100
|
+
return _extends({}, currentState, {
|
|
102
101
|
lightColorScheme: defaultLightColorScheme,
|
|
103
102
|
darkColorScheme: defaultDarkColorScheme
|
|
104
|
-
};
|
|
103
|
+
});
|
|
105
104
|
});
|
|
106
105
|
} else if (typeof value === 'string') {
|
|
107
106
|
if (value && !joinedColorSchemes.includes(value)) {
|
|
108
107
|
console.error(`\`${value}\` does not exist in \`theme.colorSchemes\`.`);
|
|
109
108
|
} else {
|
|
110
109
|
setState(currentState => {
|
|
111
|
-
const newState = {
|
|
112
|
-
...currentState
|
|
113
|
-
};
|
|
110
|
+
const newState = _extends({}, currentState);
|
|
114
111
|
processState(currentState, mode => {
|
|
115
112
|
try {
|
|
116
113
|
localStorage.setItem(`${colorSchemeStorageKey}-${mode}`, value);
|
|
@@ -129,9 +126,7 @@ export default function useCurrentColorScheme(options) {
|
|
|
129
126
|
}
|
|
130
127
|
} else {
|
|
131
128
|
setState(currentState => {
|
|
132
|
-
const newState = {
|
|
133
|
-
...currentState
|
|
134
|
-
};
|
|
129
|
+
const newState = _extends({}, currentState);
|
|
135
130
|
const newLightColorScheme = value.light === null ? defaultLightColorScheme : value.light;
|
|
136
131
|
const newDarkColorScheme = value.dark === null ? defaultDarkColorScheme : value.dark;
|
|
137
132
|
if (newLightColorScheme) {
|
|
@@ -164,8 +159,7 @@ export default function useCurrentColorScheme(options) {
|
|
|
164
159
|
}, [joinedColorSchemes, colorSchemeStorageKey, defaultLightColorScheme, defaultDarkColorScheme]);
|
|
165
160
|
const handleMediaQuery = React.useCallback(e => {
|
|
166
161
|
if (state.mode === 'system') {
|
|
167
|
-
setState(currentState => ({
|
|
168
|
-
...currentState,
|
|
162
|
+
setState(currentState => _extends({}, currentState, {
|
|
169
163
|
systemMode: e != null && e.matches ? 'dark' : 'light'
|
|
170
164
|
}));
|
|
171
165
|
}
|
|
@@ -214,10 +208,9 @@ export default function useCurrentColorScheme(options) {
|
|
|
214
208
|
}
|
|
215
209
|
return undefined;
|
|
216
210
|
}, [setColorScheme, setMode, modeStorageKey, colorSchemeStorageKey, joinedColorSchemes, defaultMode, storageWindow]);
|
|
217
|
-
return {
|
|
218
|
-
...state,
|
|
211
|
+
return _extends({}, state, {
|
|
219
212
|
colorScheme,
|
|
220
213
|
setMode,
|
|
221
214
|
setColorScheme
|
|
222
|
-
};
|
|
215
|
+
});
|
|
223
216
|
}
|
package/esm/propsToClassKey.js
CHANGED
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
|
|
2
|
+
const _excluded = ["variant"];
|
|
1
3
|
import { unstable_capitalize as capitalize } from '@mui/utils';
|
|
2
4
|
function isEmpty(string) {
|
|
3
5
|
return string.length === 0;
|
|
@@ -10,9 +12,9 @@ function isEmpty(string) {
|
|
|
10
12
|
*/
|
|
11
13
|
export default function propsToClassKey(props) {
|
|
12
14
|
const {
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
15
|
+
variant
|
|
16
|
+
} = props,
|
|
17
|
+
other = _objectWithoutPropertiesLoose(props, _excluded);
|
|
16
18
|
let classKey = variant || '';
|
|
17
19
|
Object.keys(other).sort().forEach(key => {
|
|
18
20
|
if (key === 'color') {
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
|
+
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
|
|
3
|
+
const _excluded = ["sx"];
|
|
1
4
|
import { isPlainObject } from '@mui/utils';
|
|
2
5
|
import defaultSxConfig from './defaultSxConfig';
|
|
3
6
|
const splitProps = props => {
|
|
@@ -18,9 +21,9 @@ const splitProps = props => {
|
|
|
18
21
|
};
|
|
19
22
|
export default function extendSxProp(props) {
|
|
20
23
|
const {
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
+
sx: inSx
|
|
25
|
+
} = props,
|
|
26
|
+
other = _objectWithoutPropertiesLoose(props, _excluded);
|
|
24
27
|
const {
|
|
25
28
|
systemProps,
|
|
26
29
|
otherProps
|
|
@@ -34,19 +37,12 @@ export default function extendSxProp(props) {
|
|
|
34
37
|
if (!isPlainObject(result)) {
|
|
35
38
|
return systemProps;
|
|
36
39
|
}
|
|
37
|
-
return {
|
|
38
|
-
...systemProps,
|
|
39
|
-
...result
|
|
40
|
-
};
|
|
40
|
+
return _extends({}, systemProps, result);
|
|
41
41
|
};
|
|
42
42
|
} else {
|
|
43
|
-
finalSx = {
|
|
44
|
-
...systemProps,
|
|
45
|
-
...inSx
|
|
46
|
-
};
|
|
43
|
+
finalSx = _extends({}, systemProps, inSx);
|
|
47
44
|
}
|
|
48
|
-
return {
|
|
49
|
-
...otherProps,
|
|
45
|
+
return _extends({}, otherProps, {
|
|
50
46
|
sx: finalSx
|
|
51
|
-
};
|
|
47
|
+
});
|
|
52
48
|
}
|
package/index.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
|
|
2
2
|
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
|
3
|
-
|
|
4
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
3
|
+
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
5
4
|
import * as React from 'react';
|
|
6
5
|
import PropTypes from 'prop-types';
|
|
7
6
|
import clsx from 'clsx';
|
|
@@ -50,7 +49,7 @@ export default function createContainer() {
|
|
|
50
49
|
var ContainerRoot = createStyledComponent(function (_ref) {
|
|
51
50
|
var theme = _ref.theme,
|
|
52
51
|
ownerState = _ref.ownerState;
|
|
53
|
-
return
|
|
52
|
+
return _extends({
|
|
54
53
|
width: '100%',
|
|
55
54
|
marginLeft: 'auto',
|
|
56
55
|
boxSizing: 'border-box',
|
|
@@ -80,10 +79,10 @@ export default function createContainer() {
|
|
|
80
79
|
}, function (_ref4) {
|
|
81
80
|
var theme = _ref4.theme,
|
|
82
81
|
ownerState = _ref4.ownerState;
|
|
83
|
-
return
|
|
82
|
+
return _extends({}, ownerState.maxWidth === 'xs' && _defineProperty({}, theme.breakpoints.up('xs'), {
|
|
84
83
|
// @ts-ignore module augmentation fails if custom breakpoints are used
|
|
85
84
|
maxWidth: Math.max(theme.breakpoints.values.xs, 444)
|
|
86
|
-
})
|
|
85
|
+
}), ownerState.maxWidth &&
|
|
87
86
|
// @ts-ignore module augmentation fails if custom breakpoints are used
|
|
88
87
|
ownerState.maxWidth !== 'xs' && _defineProperty({}, theme.breakpoints.up(ownerState.maxWidth), {
|
|
89
88
|
// @ts-ignore module augmentation fails if custom breakpoints are used
|
|
@@ -103,7 +102,7 @@ export default function createContainer() {
|
|
|
103
102
|
maxWidth = _props$maxWidth === void 0 ? 'lg' : _props$maxWidth,
|
|
104
103
|
classesProp = props.classes,
|
|
105
104
|
other = _objectWithoutProperties(props, ["className", "component", "disableGutters", "fixed", "maxWidth", "classes"]);
|
|
106
|
-
var ownerState =
|
|
105
|
+
var ownerState = _extends({}, props, {
|
|
107
106
|
component: component,
|
|
108
107
|
disableGutters: disableGutters,
|
|
109
108
|
fixed: fixed,
|
|
@@ -115,7 +114,7 @@ export default function createContainer() {
|
|
|
115
114
|
return (
|
|
116
115
|
/*#__PURE__*/
|
|
117
116
|
// @ts-ignore theme is injected by the styled util
|
|
118
|
-
_jsx(ContainerRoot,
|
|
117
|
+
_jsx(ContainerRoot, _extends({
|
|
119
118
|
as: component
|
|
120
119
|
// @ts-ignore module augmentation fails if custom breakpoints are used
|
|
121
120
|
,
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
|
|
2
|
-
import _typeof from "@babel/runtime/helpers/esm/typeof";
|
|
3
2
|
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
import _typeof from "@babel/runtime/helpers/esm/typeof";
|
|
4
|
+
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
6
5
|
import * as React from 'react';
|
|
7
6
|
import PropTypes from 'prop-types';
|
|
8
7
|
import clsx from 'clsx';
|
|
@@ -61,7 +60,7 @@ var getSideFromDirection = function getSideFromDirection(direction) {
|
|
|
61
60
|
export var style = function style(_ref) {
|
|
62
61
|
var ownerState = _ref.ownerState,
|
|
63
62
|
theme = _ref.theme;
|
|
64
|
-
var styles =
|
|
63
|
+
var styles = _extends({
|
|
65
64
|
display: 'flex',
|
|
66
65
|
flexDirection: 'column'
|
|
67
66
|
}, handleBreakpoints({
|
|
@@ -156,12 +155,12 @@ export default function createStack() {
|
|
|
156
155
|
useFlexGap: useFlexGap
|
|
157
156
|
};
|
|
158
157
|
var classes = useUtilityClasses();
|
|
159
|
-
return /*#__PURE__*/_jsx(StackRoot,
|
|
158
|
+
return /*#__PURE__*/_jsx(StackRoot, _extends({
|
|
160
159
|
as: component,
|
|
161
160
|
ownerState: ownerState,
|
|
162
161
|
ref: ref,
|
|
163
162
|
className: clsx(classes.root, className)
|
|
164
|
-
}, other
|
|
163
|
+
}, other, {
|
|
165
164
|
children: divider ? joinChildren(children, divider) : children
|
|
166
165
|
}));
|
|
167
166
|
});
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
|
2
|
-
|
|
3
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
2
|
+
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,7 +14,7 @@ function useThemeScoping(themeId, upperTheme, localTheme) {
|
|
|
15
14
|
var resolvedTheme = themeId ? upperTheme[themeId] || upperTheme : upperTheme;
|
|
16
15
|
if (typeof localTheme === 'function') {
|
|
17
16
|
var mergedTheme = localTheme(resolvedTheme);
|
|
18
|
-
var result = themeId ?
|
|
17
|
+
var result = themeId ? _extends({}, upperTheme, _defineProperty({}, themeId, mergedTheme)) : mergedTheme;
|
|
19
18
|
// must return a function for the private theme to NOT merge with the upper theme.
|
|
20
19
|
// see the test case "use provided theme from a callback" in ThemeProvider.test.js
|
|
21
20
|
if (isPrivate) {
|
|
@@ -25,7 +24,7 @@ function useThemeScoping(themeId, upperTheme, localTheme) {
|
|
|
25
24
|
}
|
|
26
25
|
return result;
|
|
27
26
|
}
|
|
28
|
-
return themeId ?
|
|
27
|
+
return themeId ? _extends({}, upperTheme, _defineProperty({}, themeId, localTheme)) : _extends({}, upperTheme, localTheme);
|
|
29
28
|
}, [themeId, upperTheme, localTheme, isPrivate]);
|
|
30
29
|
}
|
|
31
30
|
|
|
@@ -1,9 +1,7 @@
|
|
|
1
|
-
import
|
|
1
|
+
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
2
|
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
|
3
3
|
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
|
|
4
4
|
import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
|
|
5
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
6
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
7
5
|
import * as React from 'react';
|
|
8
6
|
import PropTypes from 'prop-types';
|
|
9
7
|
import clsx from 'clsx';
|
|
@@ -107,7 +105,7 @@ export default function createGrid() {
|
|
|
107
105
|
var spacing = (_inProps$spacing = inProps.spacing) != null ? _inProps$spacing : level ? undefined : spacingProp;
|
|
108
106
|
var rowSpacing = (_ref3 = (_inProps$rowSpacing = inProps.rowSpacing) != null ? _inProps$rowSpacing : inProps.spacing) != null ? _ref3 : level ? undefined : rowSpacingProp;
|
|
109
107
|
var columnSpacing = (_ref4 = (_inProps$columnSpacin = inProps.columnSpacing) != null ? _inProps$columnSpacin : inProps.spacing) != null ? _ref4 : level ? undefined : columnSpacingProp;
|
|
110
|
-
var ownerState =
|
|
108
|
+
var ownerState = _extends({}, props, {
|
|
111
109
|
level: level,
|
|
112
110
|
columns: columns,
|
|
113
111
|
container: container,
|
|
@@ -124,12 +122,12 @@ export default function createGrid() {
|
|
|
124
122
|
});
|
|
125
123
|
|
|
126
124
|
var classes = useUtilityClasses(ownerState, theme);
|
|
127
|
-
var result = /*#__PURE__*/_jsx(GridRoot,
|
|
125
|
+
var result = /*#__PURE__*/_jsx(GridRoot, _extends({
|
|
128
126
|
ref: ref,
|
|
129
127
|
as: component,
|
|
130
128
|
ownerState: ownerState,
|
|
131
129
|
className: clsx(classes.root, className)
|
|
132
|
-
}, other
|
|
130
|
+
}, other, {
|
|
133
131
|
children: React.Children.map(children, function (child) {
|
|
134
132
|
if ( /*#__PURE__*/React.isValidElement(child) && isMuiElement(child, ['Grid'])) {
|
|
135
133
|
var _child$props$unstable;
|
|
@@ -1,9 +1,8 @@
|
|
|
1
|
-
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
|
2
|
-
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
|
3
1
|
import _typeof from "@babel/runtime/helpers/esm/typeof";
|
|
2
|
+
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
|
4
3
|
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
5
|
-
|
|
6
|
-
|
|
4
|
+
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
|
5
|
+
import { traverseBreakpoints } from './traverseBreakpoints';
|
|
7
6
|
function appendLevel(level) {
|
|
8
7
|
if (!level) {
|
|
9
8
|
return '';
|
|
@@ -32,52 +31,6 @@ function getParentColumns(ownerState) {
|
|
|
32
31
|
}
|
|
33
32
|
return "var(--Grid-columns".concat(appendLevel(ownerState.unstable_level - 1), ")");
|
|
34
33
|
}
|
|
35
|
-
export var filterBreakpointKeys = function filterBreakpointKeys(breakpointsKeys, responsiveKeys) {
|
|
36
|
-
return breakpointsKeys.filter(function (key) {
|
|
37
|
-
return responsiveKeys.includes(key);
|
|
38
|
-
});
|
|
39
|
-
};
|
|
40
|
-
export var traverseBreakpoints = function traverseBreakpoints(breakpoints, responsive, iterator) {
|
|
41
|
-
var smallestBreakpoint = breakpoints.keys[0]; // the keys is sorted from smallest to largest by `createBreakpoints`.
|
|
42
|
-
|
|
43
|
-
if (Array.isArray(responsive)) {
|
|
44
|
-
responsive.forEach(function (breakpointValue, index) {
|
|
45
|
-
iterator(function (responsiveStyles, style) {
|
|
46
|
-
if (index <= breakpoints.keys.length - 1) {
|
|
47
|
-
if (index === 0) {
|
|
48
|
-
_extends(responsiveStyles, style);
|
|
49
|
-
} else {
|
|
50
|
-
responsiveStyles[breakpoints.up(breakpoints.keys[index])] = style;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
}, breakpointValue);
|
|
54
|
-
});
|
|
55
|
-
} else if (responsive && _typeof(responsive) === 'object') {
|
|
56
|
-
// prevent null
|
|
57
|
-
// responsive could be a very big object, pick the smallest responsive values
|
|
58
|
-
|
|
59
|
-
var keys = Object.keys(responsive).length > breakpoints.keys.length ? breakpoints.keys : filterBreakpointKeys(breakpoints.keys, Object.keys(responsive));
|
|
60
|
-
keys.forEach(function (key) {
|
|
61
|
-
if (breakpoints.keys.indexOf(key) !== -1) {
|
|
62
|
-
// @ts-ignore already checked that responsive is an object
|
|
63
|
-
var breakpointValue = responsive[key];
|
|
64
|
-
if (breakpointValue !== undefined) {
|
|
65
|
-
iterator(function (responsiveStyles, style) {
|
|
66
|
-
if (smallestBreakpoint === key) {
|
|
67
|
-
_extends(responsiveStyles, style);
|
|
68
|
-
} else {
|
|
69
|
-
responsiveStyles[breakpoints.up(key)] = style;
|
|
70
|
-
}
|
|
71
|
-
}, breakpointValue);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
});
|
|
75
|
-
} else if (typeof responsive === 'number' || typeof responsive === 'string') {
|
|
76
|
-
iterator(function (responsiveStyles, style) {
|
|
77
|
-
_extends(responsiveStyles, style);
|
|
78
|
-
}, responsive);
|
|
79
|
-
}
|
|
80
|
-
};
|
|
81
34
|
export var generateGridSizeStyles = function generateGridSizeStyles(_ref) {
|
|
82
35
|
var theme = _ref.theme,
|
|
83
36
|
ownerState = _ref.ownerState;
|
|
@@ -192,19 +145,19 @@ export var generateGridStyles = function generateGridStyles(_ref10) {
|
|
|
192
145
|
var ownerState = _ref10.ownerState;
|
|
193
146
|
var getSelfSpacing = createGetSelfSpacing(ownerState);
|
|
194
147
|
var getParentSpacing = createGetParentSpacing(ownerState);
|
|
195
|
-
return
|
|
148
|
+
return _extends({
|
|
196
149
|
minWidth: 0,
|
|
197
150
|
boxSizing: 'border-box'
|
|
198
|
-
}, ownerState.container &&
|
|
151
|
+
}, ownerState.container && _extends({
|
|
199
152
|
display: 'flex',
|
|
200
153
|
flexWrap: 'wrap'
|
|
201
154
|
}, ownerState.wrap && ownerState.wrap !== 'wrap' && {
|
|
202
155
|
flexWrap: ownerState.wrap
|
|
203
|
-
}
|
|
156
|
+
}, {
|
|
204
157
|
margin: "calc(".concat(getSelfSpacing('row'), " / -2) calc(").concat(getSelfSpacing('column'), " / -2)")
|
|
205
158
|
}, ownerState.disableEqualOverflow && {
|
|
206
159
|
margin: "calc(".concat(getSelfSpacing('row'), " * -1) 0px 0px calc(").concat(getSelfSpacing('column'), " * -1)")
|
|
207
|
-
})
|
|
160
|
+
}), (!ownerState.container || isNestedContainer(ownerState)) && _extends({
|
|
208
161
|
padding: "calc(".concat(getParentSpacing('row'), " / 2) calc(").concat(getParentSpacing('column'), " / 2)")
|
|
209
162
|
}, (ownerState.disableEqualOverflow || ownerState.parentDisableEqualOverflow) && {
|
|
210
163
|
padding: "".concat(getParentSpacing('row'), " 0px 0px ").concat(getParentSpacing('column'))
|
|
@@ -2,4 +2,5 @@ export { default } from './Grid';
|
|
|
2
2
|
export { default as createGrid } from './createGrid';
|
|
3
3
|
export * from './GridProps';
|
|
4
4
|
export { default as gridClasses } from './gridClasses';
|
|
5
|
-
export * from './gridClasses';
|
|
5
|
+
export * from './gridClasses';
|
|
6
|
+
export { traverseBreakpoints as unstable_traverseBreakpoints } from './traverseBreakpoints';
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import _typeof from "@babel/runtime/helpers/esm/typeof";
|
|
2
|
+
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
3
|
+
export var filterBreakpointKeys = function filterBreakpointKeys(breakpointsKeys, responsiveKeys) {
|
|
4
|
+
return breakpointsKeys.filter(function (key) {
|
|
5
|
+
return responsiveKeys.includes(key);
|
|
6
|
+
});
|
|
7
|
+
};
|
|
8
|
+
export var traverseBreakpoints = function traverseBreakpoints(breakpoints, responsive, iterator) {
|
|
9
|
+
var smallestBreakpoint = breakpoints.keys[0]; // the keys is sorted from smallest to largest by `createBreakpoints`.
|
|
10
|
+
|
|
11
|
+
if (Array.isArray(responsive)) {
|
|
12
|
+
responsive.forEach(function (breakpointValue, index) {
|
|
13
|
+
iterator(function (responsiveStyles, style) {
|
|
14
|
+
if (index <= breakpoints.keys.length - 1) {
|
|
15
|
+
if (index === 0) {
|
|
16
|
+
_extends(responsiveStyles, style);
|
|
17
|
+
} else {
|
|
18
|
+
responsiveStyles[breakpoints.up(breakpoints.keys[index])] = style;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}, breakpointValue);
|
|
22
|
+
});
|
|
23
|
+
} else if (responsive && _typeof(responsive) === 'object') {
|
|
24
|
+
// prevent null
|
|
25
|
+
// responsive could be a very big object, pick the smallest responsive values
|
|
26
|
+
|
|
27
|
+
var keys = Object.keys(responsive).length > breakpoints.keys.length ? breakpoints.keys : filterBreakpointKeys(breakpoints.keys, Object.keys(responsive));
|
|
28
|
+
keys.forEach(function (key) {
|
|
29
|
+
if (breakpoints.keys.indexOf(key) !== -1) {
|
|
30
|
+
// @ts-ignore already checked that responsive is an object
|
|
31
|
+
var breakpointValue = responsive[key];
|
|
32
|
+
if (breakpointValue !== undefined) {
|
|
33
|
+
iterator(function (responsiveStyles, style) {
|
|
34
|
+
if (smallestBreakpoint === key) {
|
|
35
|
+
_extends(responsiveStyles, style);
|
|
36
|
+
} else {
|
|
37
|
+
responsiveStyles[breakpoints.up(key)] = style;
|
|
38
|
+
}
|
|
39
|
+
}, breakpointValue);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
} else if (typeof responsive === 'number' || typeof responsive === 'string') {
|
|
44
|
+
iterator(function (responsiveStyles, style) {
|
|
45
|
+
_extends(responsiveStyles, style);
|
|
46
|
+
}, responsive);
|
|
47
|
+
}
|
|
48
|
+
};
|
package/legacy/breakpoints.js
CHANGED
|
@@ -1,8 +1,6 @@
|
|
|
1
1
|
import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
|
|
2
|
-
import
|
|
2
|
+
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
3
3
|
import _typeof from "@babel/runtime/helpers/esm/typeof";
|
|
4
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
5
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
6
4
|
import PropTypes from 'prop-types';
|
|
7
5
|
import { deepmerge } from '@mui/utils';
|
|
8
6
|
import merge from './merge';
|
|
@@ -65,7 +63,7 @@ function breakpoints(styleFunction) {
|
|
|
65
63
|
var extended = themeBreakpoints.keys.reduce(function (acc, key) {
|
|
66
64
|
if (props[key]) {
|
|
67
65
|
acc = acc || {};
|
|
68
|
-
acc[themeBreakpoints.up(key)] = styleFunction(
|
|
66
|
+
acc[themeBreakpoints.up(key)] = styleFunction(_extends({
|
|
69
67
|
theme: theme
|
|
70
68
|
}, props[key]));
|
|
71
69
|
}
|
|
@@ -73,7 +71,7 @@ function breakpoints(styleFunction) {
|
|
|
73
71
|
}, null);
|
|
74
72
|
return merge(base, extended);
|
|
75
73
|
};
|
|
76
|
-
newStyleFunction.propTypes = process.env.NODE_ENV !== 'production' ?
|
|
74
|
+
newStyleFunction.propTypes = process.env.NODE_ENV !== 'production' ? _extends({}, styleFunction.propTypes, {
|
|
77
75
|
xs: PropTypes.object,
|
|
78
76
|
sm: PropTypes.object,
|
|
79
77
|
md: PropTypes.object,
|
package/legacy/createBox.js
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
|
-
import
|
|
1
|
+
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
2
|
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
|
|
3
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
4
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
5
3
|
import * as React from 'react';
|
|
6
4
|
import clsx from 'clsx';
|
|
7
5
|
import styled from '@mui/styled-engine';
|
|
@@ -27,7 +25,7 @@ export default function createBox() {
|
|
|
27
25
|
_extendSxProp$compone = _extendSxProp.component,
|
|
28
26
|
component = _extendSxProp$compone === void 0 ? 'div' : _extendSxProp$compone,
|
|
29
27
|
other = _objectWithoutProperties(_extendSxProp, ["className", "component"]);
|
|
30
|
-
return /*#__PURE__*/_jsx(BoxRoot,
|
|
28
|
+
return /*#__PURE__*/_jsx(BoxRoot, _extends({
|
|
31
29
|
as: component,
|
|
32
30
|
ref: ref,
|
|
33
31
|
className: clsx(className, generateClassName ? generateClassName(defaultClassName) : defaultClassName),
|
package/legacy/createStyled.js
CHANGED
|
@@ -1,9 +1,7 @@
|
|
|
1
1
|
import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
|
|
2
2
|
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
|
3
3
|
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
|
|
4
|
-
import
|
|
5
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
6
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
4
|
+
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
7
5
|
/* eslint-disable no-underscore-dangle */
|
|
8
6
|
import styledEngineStyled, { internal_processStyles as processStyles } from '@mui/styled-engine';
|
|
9
7
|
import { getDisplayName } from '@mui/utils';
|
|
@@ -86,8 +84,8 @@ export default function createStyled() {
|
|
|
86
84
|
_input$slotShouldForw = input.slotShouldForwardProp,
|
|
87
85
|
slotShouldForwardProp = _input$slotShouldForw === void 0 ? shouldForwardProp : _input$slotShouldForw;
|
|
88
86
|
var systemSx = function systemSx(props) {
|
|
89
|
-
return styleFunctionSx(
|
|
90
|
-
theme: resolveTheme(
|
|
87
|
+
return styleFunctionSx(_extends({}, props, {
|
|
88
|
+
theme: resolveTheme(_extends({}, props, {
|
|
91
89
|
defaultTheme: defaultTheme,
|
|
92
90
|
themeId: themeId
|
|
93
91
|
}))
|
|
@@ -126,7 +124,7 @@ export default function createStyled() {
|
|
|
126
124
|
// for string (html) tag, preserve the behavior in emotion & styled-components.
|
|
127
125
|
shouldForwardPropOption = undefined;
|
|
128
126
|
}
|
|
129
|
-
var defaultStyledResolver = styledEngineStyled(tag,
|
|
127
|
+
var defaultStyledResolver = styledEngineStyled(tag, _extends({
|
|
130
128
|
shouldForwardProp: shouldForwardPropOption,
|
|
131
129
|
label: label
|
|
132
130
|
}, options));
|
|
@@ -139,8 +137,8 @@ export default function createStyled() {
|
|
|
139
137
|
// component stays as a function. This condition makes sure that we do not interpolate functions
|
|
140
138
|
// which are basically components used as a selectors.
|
|
141
139
|
return typeof stylesArg === 'function' && stylesArg.__emotion_real !== stylesArg ? function (props) {
|
|
142
|
-
return stylesArg(
|
|
143
|
-
theme: resolveTheme(
|
|
140
|
+
return stylesArg(_extends({}, props, {
|
|
141
|
+
theme: resolveTheme(_extends({}, props, {
|
|
144
142
|
defaultTheme: defaultTheme,
|
|
145
143
|
themeId: themeId
|
|
146
144
|
}))
|
|
@@ -150,7 +148,7 @@ export default function createStyled() {
|
|
|
150
148
|
var transformedStyleArg = styleArg;
|
|
151
149
|
if (componentName && overridesResolver) {
|
|
152
150
|
expressionsWithDefaultTheme.push(function (props) {
|
|
153
|
-
var theme = resolveTheme(
|
|
151
|
+
var theme = resolveTheme(_extends({}, props, {
|
|
154
152
|
defaultTheme: defaultTheme,
|
|
155
153
|
themeId: themeId
|
|
156
154
|
}));
|
|
@@ -161,7 +159,7 @@ export default function createStyled() {
|
|
|
161
159
|
var _ref3 = _slicedToArray(_ref2, 2),
|
|
162
160
|
slotKey = _ref3[0],
|
|
163
161
|
slotStyle = _ref3[1];
|
|
164
|
-
resolvedStyleOverrides[slotKey] = typeof slotStyle === 'function' ? slotStyle(
|
|
162
|
+
resolvedStyleOverrides[slotKey] = typeof slotStyle === 'function' ? slotStyle(_extends({}, props, {
|
|
165
163
|
theme: theme
|
|
166
164
|
})) : slotStyle;
|
|
167
165
|
});
|
|
@@ -172,7 +170,7 @@ export default function createStyled() {
|
|
|
172
170
|
}
|
|
173
171
|
if (componentName && !skipVariantsResolver) {
|
|
174
172
|
expressionsWithDefaultTheme.push(function (props) {
|
|
175
|
-
var theme = resolveTheme(
|
|
173
|
+
var theme = resolveTheme(_extends({}, props, {
|
|
176
174
|
defaultTheme: defaultTheme,
|
|
177
175
|
themeId: themeId
|
|
178
176
|
}));
|
|
@@ -195,8 +193,8 @@ export default function createStyled() {
|
|
|
195
193
|
styleArg.__emotion_real !== styleArg) {
|
|
196
194
|
// If the type is function, we need to define the default theme.
|
|
197
195
|
transformedStyleArg = function transformedStyleArg(props) {
|
|
198
|
-
return styleArg(
|
|
199
|
-
theme: resolveTheme(
|
|
196
|
+
return styleArg(_extends({}, props, {
|
|
197
|
+
theme: resolveTheme(_extends({}, props, {
|
|
200
198
|
defaultTheme: defaultTheme,
|
|
201
199
|
themeId: themeId
|
|
202
200
|
}))
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
|
|
2
2
|
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
|
3
|
-
|
|
4
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
3
|
+
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
5
4
|
// Sorted ASC by size. That's important.
|
|
6
5
|
// It can't be configured as it's used statically for propTypes.
|
|
7
6
|
export var breakpointKeys = ['xs', 'sm', 'md', 'lg', 'xl'];
|
|
@@ -17,7 +16,7 @@ var sortBreakpointsValues = function sortBreakpointsValues(values) {
|
|
|
17
16
|
return breakpoint1.val - breakpoint2.val;
|
|
18
17
|
});
|
|
19
18
|
return breakpointsAsArray.reduce(function (acc, obj) {
|
|
20
|
-
return
|
|
19
|
+
return _extends({}, acc, _defineProperty({}, obj.key, obj.val));
|
|
21
20
|
}, {});
|
|
22
21
|
};
|
|
23
22
|
|
|
@@ -71,7 +70,7 @@ export default function createBreakpoints(breakpoints) {
|
|
|
71
70
|
}
|
|
72
71
|
return between(key, keys[keys.indexOf(key) + 1]).replace('@media', '@media not all and');
|
|
73
72
|
}
|
|
74
|
-
return
|
|
73
|
+
return _extends({
|
|
75
74
|
keys: keys,
|
|
76
75
|
values: sortedValues,
|
|
77
76
|
up: up,
|
|
@@ -1,7 +1,5 @@
|
|
|
1
|
-
import
|
|
1
|
+
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
2
|
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
|
|
3
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
4
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
5
3
|
import { deepmerge } from '@mui/utils';
|
|
6
4
|
import createBreakpoints from './createBreakpoints';
|
|
7
5
|
import shape from './shape';
|
|
@@ -25,11 +23,11 @@ function createTheme() {
|
|
|
25
23
|
direction: 'ltr',
|
|
26
24
|
components: {},
|
|
27
25
|
// Inject component definitions.
|
|
28
|
-
palette:
|
|
26
|
+
palette: _extends({
|
|
29
27
|
mode: 'light'
|
|
30
28
|
}, paletteInput),
|
|
31
29
|
spacing: spacing,
|
|
32
|
-
shape:
|
|
30
|
+
shape: _extends({}, shape, shapeInput)
|
|
33
31
|
}, other);
|
|
34
32
|
for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
|
|
35
33
|
args[_key - 1] = arguments[_key];
|
|
@@ -37,7 +35,7 @@ function createTheme() {
|
|
|
37
35
|
muiTheme = args.reduce(function (acc, argument) {
|
|
38
36
|
return deepmerge(acc, argument);
|
|
39
37
|
}, muiTheme);
|
|
40
|
-
muiTheme.unstable_sxConfig =
|
|
38
|
+
muiTheme.unstable_sxConfig = _extends({}, defaultSxConfig, other == null ? void 0 : other.unstable_sxConfig);
|
|
41
39
|
muiTheme.unstable_sx = function sx(props) {
|
|
42
40
|
return styleFunctionSx({
|
|
43
41
|
sx: props,
|