Files
goTorrent/goTorrentWebUI/node_modules/material-ui/Dialog/withMobileDialog.js.flow

25 lines
756 B
Plaintext

import React from 'react';
import PropTypes from 'prop-types';
import withWidth, { isWidthDown } from '../utils/withWidth';
/**
* Dialog will responsively be full screen *at or below* the given breakpoint
* (defaults to 'sm' for mobile devices).
* Notice that this Higher-order Component is incompatible with server side rendering.
*/
const withMobileDialog = (options = {}) => Component => {
const { breakpoint = 'sm' } = options;
function WithMobileDialog(props) {
return <Component fullScreen={isWidthDown(breakpoint, props.width)} {...props} />;
}
WithMobileDialog.propTypes = {
width: PropTypes.oneOf(['xs', 'sm', 'md', 'lg', 'xl']).isRequired,
};
return withWidth()(WithMobileDialog);
};
export default withMobileDialog;