paradiego
This commit is contained in:
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