49 lines
1.5 KiB
JavaScript
49 lines
1.5 KiB
JavaScript
'use strict';
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
|
|
var _extends2 = require('babel-runtime/helpers/extends');
|
|
|
|
var _extends3 = _interopRequireDefault(_extends2);
|
|
|
|
var _react = require('react');
|
|
|
|
var _react2 = _interopRequireDefault(_react);
|
|
|
|
var _propTypes = require('prop-types');
|
|
|
|
var _propTypes2 = _interopRequireDefault(_propTypes);
|
|
|
|
var _withWidth = require('../utils/withWidth');
|
|
|
|
var _withWidth2 = _interopRequireDefault(_withWidth);
|
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
|
|
/**
|
|
* 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.
|
|
*/
|
|
var withMobileDialog = function withMobileDialog() {
|
|
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
return function (Component) {
|
|
var _options$breakpoint = options.breakpoint,
|
|
breakpoint = _options$breakpoint === undefined ? 'sm' : _options$breakpoint;
|
|
|
|
|
|
function WithMobileDialog(props) {
|
|
return _react2.default.createElement(Component, (0, _extends3.default)({ fullScreen: (0, _withWidth.isWidthDown)(breakpoint, props.width) }, props));
|
|
}
|
|
|
|
WithMobileDialog.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
width: _propTypes2.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl']).isRequired
|
|
} : {};
|
|
|
|
return (0, _withWidth2.default)()(WithMobileDialog);
|
|
};
|
|
};
|
|
|
|
exports.default = withMobileDialog; |