paradiego
This commit is contained in:
145
node_modules/@mui/material/node/Hidden/Hidden.js
generated
vendored
Normal file
145
node_modules/@mui/material/node/Hidden/Hidden.js
generated
vendored
Normal file
@@ -0,0 +1,145 @@
|
||||
"use strict";
|
||||
'use client';
|
||||
|
||||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
||||
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.default = void 0;
|
||||
var React = _interopRequireWildcard(require("react"));
|
||||
var _propTypes = _interopRequireDefault(require("prop-types"));
|
||||
var _HiddenJs = _interopRequireDefault(require("./HiddenJs"));
|
||||
var _HiddenCss = _interopRequireDefault(require("./HiddenCss"));
|
||||
var _jsxRuntime = require("react/jsx-runtime");
|
||||
/**
|
||||
* Responsively hides children based on the selected implementation.
|
||||
*
|
||||
* @deprecated The Hidden component was deprecated in Material UI v5. To learn more, see [the Hidden section](https://mui.com/material-ui/migration/v5-component-changes/#hidden) of the migration docs.
|
||||
*/function Hidden(props) {
|
||||
const {
|
||||
implementation = 'js',
|
||||
lgDown = false,
|
||||
lgUp = false,
|
||||
mdDown = false,
|
||||
mdUp = false,
|
||||
smDown = false,
|
||||
smUp = false,
|
||||
xlDown = false,
|
||||
xlUp = false,
|
||||
xsDown = false,
|
||||
xsUp = false,
|
||||
...other
|
||||
} = props;
|
||||
if (implementation === 'js') {
|
||||
return /*#__PURE__*/(0, _jsxRuntime.jsx)(_HiddenJs.default, {
|
||||
lgDown: lgDown,
|
||||
lgUp: lgUp,
|
||||
mdDown: mdDown,
|
||||
mdUp: mdUp,
|
||||
smDown: smDown,
|
||||
smUp: smUp,
|
||||
xlDown: xlDown,
|
||||
xlUp: xlUp,
|
||||
xsDown: xsDown,
|
||||
xsUp: xsUp,
|
||||
...other
|
||||
});
|
||||
}
|
||||
return /*#__PURE__*/(0, _jsxRuntime.jsx)(_HiddenCss.default, {
|
||||
lgDown: lgDown,
|
||||
lgUp: lgUp,
|
||||
mdDown: mdDown,
|
||||
mdUp: mdUp,
|
||||
smDown: smDown,
|
||||
smUp: smUp,
|
||||
xlDown: xlDown,
|
||||
xlUp: xlUp,
|
||||
xsDown: xsDown,
|
||||
xsUp: xsUp,
|
||||
...other
|
||||
});
|
||||
}
|
||||
process.env.NODE_ENV !== "production" ? Hidden.propTypes /* remove-proptypes */ = {
|
||||
// ┌────────────────────────────── Warning ──────────────────────────────┐
|
||||
// │ These PropTypes are generated from the TypeScript type definitions. │
|
||||
// │ To update them, edit the d.ts file and run `pnpm proptypes`. │
|
||||
// └─────────────────────────────────────────────────────────────────────┘
|
||||
/**
|
||||
* The content of the component.
|
||||
*/
|
||||
children: _propTypes.default.node,
|
||||
/**
|
||||
* Specify which implementation to use. 'js' is the default, 'css' works better for
|
||||
* server-side rendering.
|
||||
* @default 'js'
|
||||
*/
|
||||
implementation: _propTypes.default.oneOf(['css', 'js']),
|
||||
/**
|
||||
* You can use this prop when choosing the `js` implementation with server-side rendering.
|
||||
*
|
||||
* As `window.innerWidth` is unavailable on the server,
|
||||
* we default to rendering an empty component during the first mount.
|
||||
* You might want to use a heuristic to approximate
|
||||
* the screen width of the client browser screen width.
|
||||
*
|
||||
* For instance, you could be using the user-agent or the client-hints.
|
||||
* https://caniuse.com/#search=client%20hint
|
||||
*/
|
||||
initialWidth: _propTypes.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl']),
|
||||
/**
|
||||
* If `true`, component is hidden on screens below (but not including) this size.
|
||||
* @default false
|
||||
*/
|
||||
lgDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, component is hidden on screens this size and above.
|
||||
* @default false
|
||||
*/
|
||||
lgUp: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, component is hidden on screens below (but not including) this size.
|
||||
* @default false
|
||||
*/
|
||||
mdDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, component is hidden on screens this size and above.
|
||||
* @default false
|
||||
*/
|
||||
mdUp: _propTypes.default.bool,
|
||||
/**
|
||||
* Hide the given breakpoint(s).
|
||||
*/
|
||||
only: _propTypes.default.oneOfType([_propTypes.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl']), _propTypes.default.arrayOf(_propTypes.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl']).isRequired)]),
|
||||
/**
|
||||
* If `true`, component is hidden on screens below (but not including) this size.
|
||||
* @default false
|
||||
*/
|
||||
smDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, component is hidden on screens this size and above.
|
||||
* @default false
|
||||
*/
|
||||
smUp: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, component is hidden on screens below (but not including) this size.
|
||||
* @default false
|
||||
*/
|
||||
xlDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, component is hidden on screens this size and above.
|
||||
* @default false
|
||||
*/
|
||||
xlUp: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, component is hidden on screens below (but not including) this size.
|
||||
* @default false
|
||||
*/
|
||||
xsDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, component is hidden on screens this size and above.
|
||||
* @default false
|
||||
*/
|
||||
xsUp: _propTypes.default.bool
|
||||
} : void 0;
|
||||
var _default = exports.default = Hidden;
|
||||
189
node_modules/@mui/material/node/Hidden/HiddenCss.js
generated
vendored
Normal file
189
node_modules/@mui/material/node/Hidden/HiddenCss.js
generated
vendored
Normal file
@@ -0,0 +1,189 @@
|
||||
"use strict";
|
||||
'use client';
|
||||
|
||||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
||||
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.default = void 0;
|
||||
var React = _interopRequireWildcard(require("react"));
|
||||
var _clsx = _interopRequireDefault(require("clsx"));
|
||||
var _propTypes = _interopRequireDefault(require("prop-types"));
|
||||
var _composeClasses = _interopRequireDefault(require("@mui/utils/composeClasses"));
|
||||
var _capitalize = _interopRequireDefault(require("../utils/capitalize"));
|
||||
var _styled = _interopRequireDefault(require("../styles/styled"));
|
||||
var _useTheme = _interopRequireDefault(require("../styles/useTheme"));
|
||||
var _hiddenCssClasses = require("./hiddenCssClasses");
|
||||
var _jsxRuntime = require("react/jsx-runtime");
|
||||
const useUtilityClasses = ownerState => {
|
||||
const {
|
||||
classes,
|
||||
breakpoints
|
||||
} = ownerState;
|
||||
const slots = {
|
||||
root: ['root', ...breakpoints.map(({
|
||||
breakpoint,
|
||||
dir
|
||||
}) => {
|
||||
return dir === 'only' ? `${dir}${(0, _capitalize.default)(breakpoint)}` : `${breakpoint}${(0, _capitalize.default)(dir)}`;
|
||||
})]
|
||||
};
|
||||
return (0, _composeClasses.default)(slots, _hiddenCssClasses.getHiddenCssUtilityClass, classes);
|
||||
};
|
||||
|
||||
// FIXME(romgrk): Can't use memoTheme here, should we memo also on ownerState?
|
||||
const HiddenCssRoot = (0, _styled.default)('div', {
|
||||
name: 'PrivateHiddenCss',
|
||||
slot: 'Root'
|
||||
})(({
|
||||
theme,
|
||||
ownerState
|
||||
}) => {
|
||||
const hidden = {
|
||||
display: 'none'
|
||||
};
|
||||
return {
|
||||
...ownerState.breakpoints.map(({
|
||||
breakpoint,
|
||||
dir
|
||||
}) => {
|
||||
if (dir === 'only') {
|
||||
return {
|
||||
[theme.breakpoints.only(breakpoint)]: hidden
|
||||
};
|
||||
}
|
||||
return dir === 'up' ? {
|
||||
[theme.breakpoints.up(breakpoint)]: hidden
|
||||
} : {
|
||||
[theme.breakpoints.down(breakpoint)]: hidden
|
||||
};
|
||||
}).reduce((r, o) => {
|
||||
Object.keys(o).forEach(k => {
|
||||
r[k] = o[k];
|
||||
});
|
||||
return r;
|
||||
}, {})
|
||||
};
|
||||
});
|
||||
|
||||
/**
|
||||
* @ignore - internal component.
|
||||
*/
|
||||
function HiddenCss(props) {
|
||||
const {
|
||||
children,
|
||||
className,
|
||||
only,
|
||||
...other
|
||||
} = props;
|
||||
const theme = (0, _useTheme.default)();
|
||||
if (process.env.NODE_ENV !== 'production') {
|
||||
const unknownProps = Object.keys(other).filter(propName => {
|
||||
const isUndeclaredBreakpoint = !theme.breakpoints.keys.some(breakpoint => {
|
||||
return `${breakpoint}Up` === propName || `${breakpoint}Down` === propName;
|
||||
});
|
||||
return !['classes', 'theme', 'isRtl', 'sx'].includes(propName) && isUndeclaredBreakpoint;
|
||||
});
|
||||
if (unknownProps.length > 0) {
|
||||
console.error(`MUI: Unsupported props received by \`<Hidden implementation="css" />\`: ${unknownProps.join(', ')}. Did you forget to wrap this component in a ThemeProvider declaring these breakpoints?`);
|
||||
}
|
||||
}
|
||||
const breakpoints = [];
|
||||
for (let i = 0; i < theme.breakpoints.keys.length; i += 1) {
|
||||
const breakpoint = theme.breakpoints.keys[i];
|
||||
const breakpointUp = other[`${breakpoint}Up`];
|
||||
const breakpointDown = other[`${breakpoint}Down`];
|
||||
if (breakpointUp) {
|
||||
breakpoints.push({
|
||||
breakpoint,
|
||||
dir: 'up'
|
||||
});
|
||||
}
|
||||
if (breakpointDown) {
|
||||
breakpoints.push({
|
||||
breakpoint,
|
||||
dir: 'down'
|
||||
});
|
||||
}
|
||||
}
|
||||
if (only) {
|
||||
const onlyBreakpoints = Array.isArray(only) ? only : [only];
|
||||
onlyBreakpoints.forEach(breakpoint => {
|
||||
breakpoints.push({
|
||||
breakpoint,
|
||||
dir: 'only'
|
||||
});
|
||||
});
|
||||
}
|
||||
const ownerState = {
|
||||
...props,
|
||||
breakpoints
|
||||
};
|
||||
const classes = useUtilityClasses(ownerState);
|
||||
return /*#__PURE__*/(0, _jsxRuntime.jsx)(HiddenCssRoot, {
|
||||
className: (0, _clsx.default)(classes.root, className),
|
||||
ownerState: ownerState,
|
||||
children: children
|
||||
});
|
||||
}
|
||||
process.env.NODE_ENV !== "production" ? HiddenCss.propTypes = {
|
||||
/**
|
||||
* The content of the component.
|
||||
*/
|
||||
children: _propTypes.default.node,
|
||||
/**
|
||||
* @ignore
|
||||
*/
|
||||
className: _propTypes.default.string,
|
||||
/**
|
||||
* Specify which implementation to use. 'js' is the default, 'css' works better for
|
||||
* server-side rendering.
|
||||
*/
|
||||
implementation: _propTypes.default.oneOf(['js', 'css']),
|
||||
/**
|
||||
* If `true`, screens this size and down are hidden.
|
||||
*/
|
||||
lgDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and up are hidden.
|
||||
*/
|
||||
lgUp: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and down are hidden.
|
||||
*/
|
||||
mdDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and up are hidden.
|
||||
*/
|
||||
mdUp: _propTypes.default.bool,
|
||||
/**
|
||||
* Hide the given breakpoint(s).
|
||||
*/
|
||||
only: _propTypes.default.oneOfType([_propTypes.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl']), _propTypes.default.arrayOf(_propTypes.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl']))]),
|
||||
/**
|
||||
* If `true`, screens this size and down are hidden.
|
||||
*/
|
||||
smDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and up are hidden.
|
||||
*/
|
||||
smUp: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and down are hidden.
|
||||
*/
|
||||
xlDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and up are hidden.
|
||||
*/
|
||||
xlUp: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and down are hidden.
|
||||
*/
|
||||
xsDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and up are hidden.
|
||||
*/
|
||||
xsUp: _propTypes.default.bool
|
||||
} : void 0;
|
||||
var _default = exports.default = HiddenCss;
|
||||
130
node_modules/@mui/material/node/Hidden/HiddenJs.js
generated
vendored
Normal file
130
node_modules/@mui/material/node/Hidden/HiddenJs.js
generated
vendored
Normal file
@@ -0,0 +1,130 @@
|
||||
"use strict";
|
||||
'use client';
|
||||
|
||||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
||||
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.default = void 0;
|
||||
var React = _interopRequireWildcard(require("react"));
|
||||
var _propTypes = _interopRequireDefault(require("prop-types"));
|
||||
var _exactProp = _interopRequireDefault(require("@mui/utils/exactProp"));
|
||||
var _withWidth = _interopRequireWildcard(require("./withWidth"));
|
||||
var _useTheme = _interopRequireDefault(require("../styles/useTheme"));
|
||||
var _jsxRuntime = require("react/jsx-runtime");
|
||||
/**
|
||||
* @ignore - internal component.
|
||||
*/function HiddenJs(props) {
|
||||
const {
|
||||
children,
|
||||
only,
|
||||
width
|
||||
} = props;
|
||||
const theme = (0, _useTheme.default)();
|
||||
let visible = true;
|
||||
|
||||
// `only` check is faster to get out sooner if used.
|
||||
if (only) {
|
||||
if (Array.isArray(only)) {
|
||||
for (let i = 0; i < only.length; i += 1) {
|
||||
const breakpoint = only[i];
|
||||
if (width === breakpoint) {
|
||||
visible = false;
|
||||
break;
|
||||
}
|
||||
}
|
||||
} else if (only && width === only) {
|
||||
visible = false;
|
||||
}
|
||||
}
|
||||
|
||||
// Allow `only` to be combined with other props. If already hidden, no need to check others.
|
||||
if (visible) {
|
||||
// determine visibility based on the smallest size up
|
||||
for (let i = 0; i < theme.breakpoints.keys.length; i += 1) {
|
||||
const breakpoint = theme.breakpoints.keys[i];
|
||||
const breakpointUp = props[`${breakpoint}Up`];
|
||||
const breakpointDown = props[`${breakpoint}Down`];
|
||||
if (breakpointUp && (0, _withWidth.isWidthUp)(breakpoint, width) || breakpointDown && (0, _withWidth.isWidthDown)(breakpoint, width)) {
|
||||
visible = false;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (!visible) {
|
||||
return null;
|
||||
}
|
||||
return /*#__PURE__*/(0, _jsxRuntime.jsx)(React.Fragment, {
|
||||
children: children
|
||||
});
|
||||
}
|
||||
process.env.NODE_ENV !== "production" ? HiddenJs.propTypes = {
|
||||
/**
|
||||
* The content of the component.
|
||||
*/
|
||||
children: _propTypes.default.node,
|
||||
/**
|
||||
* If `true`, screens this size and down are hidden.
|
||||
*/
|
||||
// eslint-disable-next-line react/no-unused-prop-types
|
||||
lgDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and up are hidden.
|
||||
*/
|
||||
// eslint-disable-next-line react/no-unused-prop-types
|
||||
lgUp: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and down are hidden.
|
||||
*/
|
||||
// eslint-disable-next-line react/no-unused-prop-types
|
||||
mdDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and up are hidden.
|
||||
*/
|
||||
// eslint-disable-next-line react/no-unused-prop-types
|
||||
mdUp: _propTypes.default.bool,
|
||||
/**
|
||||
* Hide the given breakpoint(s).
|
||||
*/
|
||||
only: _propTypes.default.oneOfType([_propTypes.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl']), _propTypes.default.arrayOf(_propTypes.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl']))]),
|
||||
/**
|
||||
* If `true`, screens this size and down are hidden.
|
||||
*/
|
||||
// eslint-disable-next-line react/no-unused-prop-types
|
||||
smDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and up are hidden.
|
||||
*/
|
||||
// eslint-disable-next-line react/no-unused-prop-types
|
||||
smUp: _propTypes.default.bool,
|
||||
/**
|
||||
* @ignore
|
||||
* width prop provided by withWidth decorator.
|
||||
*/
|
||||
width: _propTypes.default.string.isRequired,
|
||||
/**
|
||||
* If `true`, screens this size and down are hidden.
|
||||
*/
|
||||
// eslint-disable-next-line react/no-unused-prop-types
|
||||
xlDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and up are hidden.
|
||||
*/
|
||||
// eslint-disable-next-line react/no-unused-prop-types
|
||||
xlUp: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and down are hidden.
|
||||
*/
|
||||
// eslint-disable-next-line react/no-unused-prop-types
|
||||
xsDown: _propTypes.default.bool,
|
||||
/**
|
||||
* If `true`, screens this size and up are hidden.
|
||||
*/
|
||||
// eslint-disable-next-line react/no-unused-prop-types
|
||||
xsUp: _propTypes.default.bool
|
||||
} : void 0;
|
||||
if (process.env.NODE_ENV !== 'production') {
|
||||
process.env.NODE_ENV !== "production" ? HiddenJs.propTypes = (0, _exactProp.default)(HiddenJs.propTypes) : void 0;
|
||||
}
|
||||
var _default = exports.default = (0, _withWidth.default)()(HiddenJs);
|
||||
15
node_modules/@mui/material/node/Hidden/hiddenCssClasses.js
generated
vendored
Normal file
15
node_modules/@mui/material/node/Hidden/hiddenCssClasses.js
generated
vendored
Normal file
@@ -0,0 +1,15 @@
|
||||
"use strict";
|
||||
|
||||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.default = void 0;
|
||||
exports.getHiddenCssUtilityClass = getHiddenCssUtilityClass;
|
||||
var _generateUtilityClasses = _interopRequireDefault(require("@mui/utils/generateUtilityClasses"));
|
||||
var _generateUtilityClass = _interopRequireDefault(require("@mui/utils/generateUtilityClass"));
|
||||
function getHiddenCssUtilityClass(slot) {
|
||||
return (0, _generateUtilityClass.default)('PrivateHiddenCss', slot);
|
||||
}
|
||||
const hiddenCssClasses = (0, _generateUtilityClasses.default)('PrivateHiddenCss', ['root', 'xlDown', 'xlUp', 'onlyXl', 'lgDown', 'lgUp', 'onlyLg', 'mdDown', 'mdUp', 'onlyMd', 'smDown', 'smUp', 'onlySm', 'xsDown', 'xsUp', 'onlyXs']);
|
||||
var _default = exports.default = hiddenCssClasses;
|
||||
13
node_modules/@mui/material/node/Hidden/index.js
generated
vendored
Normal file
13
node_modules/@mui/material/node/Hidden/index.js
generated
vendored
Normal file
@@ -0,0 +1,13 @@
|
||||
"use strict";
|
||||
|
||||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
Object.defineProperty(exports, "default", {
|
||||
enumerable: true,
|
||||
get: function () {
|
||||
return _Hidden.default;
|
||||
}
|
||||
});
|
||||
var _Hidden = _interopRequireDefault(require("./Hidden"));
|
||||
116
node_modules/@mui/material/node/Hidden/withWidth.js
generated
vendored
Normal file
116
node_modules/@mui/material/node/Hidden/withWidth.js
generated
vendored
Normal file
@@ -0,0 +1,116 @@
|
||||
"use strict";
|
||||
|
||||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
||||
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.isWidthUp = exports.isWidthDown = exports.default = void 0;
|
||||
var React = _interopRequireWildcard(require("react"));
|
||||
var _propTypes = _interopRequireDefault(require("prop-types"));
|
||||
var _getDisplayName = _interopRequireDefault(require("@mui/utils/getDisplayName"));
|
||||
var _useThemeProps = require("@mui/system/useThemeProps");
|
||||
var _useTheme = _interopRequireDefault(require("../styles/useTheme"));
|
||||
var _useEnhancedEffect = _interopRequireDefault(require("../utils/useEnhancedEffect"));
|
||||
var _useMediaQuery = _interopRequireDefault(require("../useMediaQuery"));
|
||||
var _jsxRuntime = require("react/jsx-runtime");
|
||||
const breakpointKeys = ['xs', 'sm', 'md', 'lg', 'xl'];
|
||||
|
||||
// By default, returns true if screen width is the same or greater than the given breakpoint.
|
||||
const isWidthUp = (breakpoint, width, inclusive = true) => {
|
||||
if (inclusive) {
|
||||
return breakpointKeys.indexOf(breakpoint) <= breakpointKeys.indexOf(width);
|
||||
}
|
||||
return breakpointKeys.indexOf(breakpoint) < breakpointKeys.indexOf(width);
|
||||
};
|
||||
|
||||
// By default, returns true if screen width is less than the given breakpoint.
|
||||
exports.isWidthUp = isWidthUp;
|
||||
const isWidthDown = (breakpoint, width, inclusive = false) => {
|
||||
if (inclusive) {
|
||||
return breakpointKeys.indexOf(width) <= breakpointKeys.indexOf(breakpoint);
|
||||
}
|
||||
return breakpointKeys.indexOf(width) < breakpointKeys.indexOf(breakpoint);
|
||||
};
|
||||
exports.isWidthDown = isWidthDown;
|
||||
const withWidth = (options = {}) => Component => {
|
||||
const {
|
||||
withTheme: withThemeOption = false,
|
||||
noSSR = false,
|
||||
initialWidth: initialWidthOption
|
||||
} = options;
|
||||
function WithWidth(props) {
|
||||
const contextTheme = (0, _useTheme.default)();
|
||||
const theme = props.theme || contextTheme;
|
||||
const {
|
||||
initialWidth,
|
||||
width,
|
||||
...other
|
||||
} = (0, _useThemeProps.getThemeProps)({
|
||||
theme,
|
||||
name: 'MuiWithWidth',
|
||||
props
|
||||
});
|
||||
const [mountedState, setMountedState] = React.useState(false);
|
||||
(0, _useEnhancedEffect.default)(() => {
|
||||
setMountedState(true);
|
||||
}, []);
|
||||
|
||||
/**
|
||||
* innerWidth |xs sm md lg xl
|
||||
* |-------|-------|-------|-------|------>
|
||||
* width | xs | sm | md | lg | xl
|
||||
*/
|
||||
const keys = theme.breakpoints.keys.slice().reverse();
|
||||
const widthComputed = keys.reduce((output, key) => {
|
||||
// eslint-disable-next-line react-hooks/rules-of-hooks
|
||||
const matches = (0, _useMediaQuery.default)(theme.breakpoints.up(key));
|
||||
return !output && matches ? key : output;
|
||||
}, null);
|
||||
const more = {
|
||||
width: width || (mountedState || noSSR ? widthComputed : undefined) || initialWidth || initialWidthOption,
|
||||
...(withThemeOption ? {
|
||||
theme
|
||||
} : {}),
|
||||
...other
|
||||
};
|
||||
|
||||
// When rendering the component on the server,
|
||||
// we have no idea about the client browser screen width.
|
||||
// In order to prevent blinks and help the reconciliation of the React tree
|
||||
// we are not rendering the child component.
|
||||
//
|
||||
// An alternative is to use the `initialWidth` property.
|
||||
if (more.width === undefined) {
|
||||
return null;
|
||||
}
|
||||
return /*#__PURE__*/(0, _jsxRuntime.jsx)(Component, {
|
||||
...more
|
||||
});
|
||||
}
|
||||
process.env.NODE_ENV !== "production" ? WithWidth.propTypes = {
|
||||
/**
|
||||
* As `window.innerWidth` is unavailable on the server,
|
||||
* we default to rendering an empty component during the first mount.
|
||||
* You might want to use a heuristic to approximate
|
||||
* the screen width of the client browser screen width.
|
||||
*
|
||||
* For instance, you could be using the user-agent or the client-hints.
|
||||
* https://caniuse.com/#search=client%20hint
|
||||
*/
|
||||
initialWidth: _propTypes.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl']),
|
||||
/**
|
||||
* @ignore
|
||||
*/
|
||||
theme: _propTypes.default.object,
|
||||
/**
|
||||
* Bypass the width calculation logic.
|
||||
*/
|
||||
width: _propTypes.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl'])
|
||||
} : void 0;
|
||||
if (process.env.NODE_ENV !== 'production') {
|
||||
WithWidth.displayName = `WithWidth(${(0, _getDisplayName.default)(Component)})`;
|
||||
}
|
||||
return WithWidth;
|
||||
};
|
||||
var _default = exports.default = withWidth;
|
||||
Reference in New Issue
Block a user