@material-ui/core
Version:
React components that implement Google's Material Design.
423 lines (346 loc) • 13.5 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.styles = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _utils = require("@material-ui/utils");
var _withStyles = _interopRequireDefault(require("../styles/withStyles"));
var _helpers = require("../utils/helpers");
var _Modal = _interopRequireDefault(require("../Modal"));
var _Fade = _interopRequireDefault(require("../Fade"));
var _transitions = require("../styles/transitions");
var _Paper = _interopRequireDefault(require("../Paper"));
/* eslint-disable jsx-a11y/click-events-have-key-events */
/* eslint-disable jsx-a11y/no-noninteractive-element-interactions */
// @inheritedComponent Modal
var styles = function styles(theme) {
return {
/* Styles applied to the root element. */
root: {},
/* Styles applied to the root element if `scroll="paper"`. */
scrollPaper: {
display: 'flex',
justifyContent: 'center',
alignItems: 'center'
},
/* Styles applied to the root element if `scroll="body"`. */
scrollBody: {
overflowY: 'auto',
overflowX: 'hidden'
},
/* Styles applied to the container element. */
container: {
height: '100%',
// We disable the focus ring for mouse, touch and keyboard users.
outline: 'none'
},
/* Styles applied to the `Paper` component. */
paper: {
display: 'flex',
flexDirection: 'column',
margin: 48,
position: 'relative',
overflowY: 'auto' // Fix IE 11 issue, to remove at some point.
},
/* Styles applied to the `Paper` component if `scroll="paper"`. */
paperScrollPaper: {
flex: '0 1 auto',
maxHeight: 'calc(100% - 96px)'
},
/* Styles applied to the `Paper` component if `scroll="body"`. */
paperScrollBody: {
margin: '48px auto'
},
/* Styles applied to the `Paper` component if `maxWidth="xs"`. */
paperWidthXs: {
maxWidth: Math.max(theme.breakpoints.values.xs, 360),
'&$paperScrollBody': (0, _defineProperty2.default)({}, theme.breakpoints.down(Math.max(theme.breakpoints.values.xs, 360) + 48 * 2), {
margin: 48
})
},
/* Styles applied to the `Paper` component if `maxWidth="sm"`. */
paperWidthSm: {
maxWidth: theme.breakpoints.values.sm,
'&$paperScrollBody': (0, _defineProperty2.default)({}, theme.breakpoints.down(theme.breakpoints.values.sm + 48 * 2), {
margin: 48
})
},
/* Styles applied to the `Paper` component if `maxWidth="md"`. */
paperWidthMd: {
maxWidth: theme.breakpoints.values.md,
'&$paperScrollBody': (0, _defineProperty2.default)({}, theme.breakpoints.down(theme.breakpoints.values.md + 48 * 2), {
margin: 48
})
},
/* Styles applied to the `Paper` component if `maxWidth="lg"`. */
paperWidthLg: {
maxWidth: theme.breakpoints.values.lg,
'&$paperScrollBody': (0, _defineProperty2.default)({}, theme.breakpoints.down(theme.breakpoints.values.lg + 48 * 2), {
margin: 48
})
},
/* Styles applied to the `Paper` component if `maxWidth="xl"`. */
paperWidthXl: {
maxWidth: theme.breakpoints.values.xl,
'&$paperScrollBody': (0, _defineProperty2.default)({}, theme.breakpoints.down(theme.breakpoints.values.xl + 48 * 2), {
margin: 48
})
},
/* Styles applied to the `Paper` component if `fullWidth={true}`. */
paperFullWidth: {
width: '100%'
},
/* Styles applied to the `Paper` component if `fullScreen={true}`. */
paperFullScreen: {
margin: 0,
width: '100%',
maxWidth: '100%',
height: '100%',
maxHeight: 'none',
borderRadius: 0,
'&$paperScrollBody': {
margin: 0
}
}
};
};
/**
* Dialogs are overlaid modal paper based components with a backdrop.
*/
exports.styles = styles;
var Dialog =
/*#__PURE__*/
function (_React$Component) {
(0, _inherits2.default)(Dialog, _React$Component);
function Dialog() {
var _getPrototypeOf2;
var _this;
(0, _classCallCheck2.default)(this, Dialog);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = (0, _possibleConstructorReturn2.default)(this, (_getPrototypeOf2 = (0, _getPrototypeOf3.default)(Dialog)).call.apply(_getPrototypeOf2, [this].concat(args)));
_this.handleBackdropClick = function (event) {
if (event.target !== event.currentTarget) {
return;
}
if (_this.props.onBackdropClick) {
_this.props.onBackdropClick(event);
}
if (!_this.props.disableBackdropClick && _this.props.onClose) {
_this.props.onClose(event, 'backdropClick');
}
};
return _this;
}
(0, _createClass2.default)(Dialog, [{
key: "render",
value: function render() {
var _classNames;
var _this$props = this.props,
BackdropProps = _this$props.BackdropProps,
children = _this$props.children,
classes = _this$props.classes,
className = _this$props.className,
disableBackdropClick = _this$props.disableBackdropClick,
disableEscapeKeyDown = _this$props.disableEscapeKeyDown,
fullScreen = _this$props.fullScreen,
fullWidth = _this$props.fullWidth,
maxWidth = _this$props.maxWidth,
onBackdropClick = _this$props.onBackdropClick,
onClose = _this$props.onClose,
onEnter = _this$props.onEnter,
onEntered = _this$props.onEntered,
onEntering = _this$props.onEntering,
onEscapeKeyDown = _this$props.onEscapeKeyDown,
onExit = _this$props.onExit,
onExited = _this$props.onExited,
onExiting = _this$props.onExiting,
open = _this$props.open,
PaperComponent = _this$props.PaperComponent,
_this$props$PaperProp = _this$props.PaperProps,
PaperProps = _this$props$PaperProp === void 0 ? {} : _this$props$PaperProp,
scroll = _this$props.scroll,
TransitionComponent = _this$props.TransitionComponent,
transitionDuration = _this$props.transitionDuration,
TransitionProps = _this$props.TransitionProps,
other = (0, _objectWithoutProperties2.default)(_this$props, ["BackdropProps", "children", "classes", "className", "disableBackdropClick", "disableEscapeKeyDown", "fullScreen", "fullWidth", "maxWidth", "onBackdropClick", "onClose", "onEnter", "onEntered", "onEntering", "onEscapeKeyDown", "onExit", "onExited", "onExiting", "open", "PaperComponent", "PaperProps", "scroll", "TransitionComponent", "transitionDuration", "TransitionProps"]);
return _react.default.createElement(_Modal.default, (0, _extends2.default)({
className: (0, _classnames.default)(classes.root, className),
BackdropProps: (0, _extends2.default)({
transitionDuration: transitionDuration
}, BackdropProps),
disableBackdropClick: disableBackdropClick,
disableEscapeKeyDown: disableEscapeKeyDown,
onBackdropClick: onBackdropClick,
onEscapeKeyDown: onEscapeKeyDown,
onClose: onClose,
open: open,
role: "dialog"
}, other), _react.default.createElement(TransitionComponent, (0, _extends2.default)({
appear: true,
in: open,
timeout: transitionDuration,
onEnter: onEnter,
onEntering: onEntering,
onEntered: onEntered,
onExit: onExit,
onExiting: onExiting,
onExited: onExited
}, TransitionProps), _react.default.createElement("div", {
className: (0, _classnames.default)(classes.container, classes["scroll".concat((0, _helpers.capitalize)(scroll))]),
onClick: this.handleBackdropClick,
role: "document"
}, _react.default.createElement(PaperComponent, (0, _extends2.default)({
elevation: 24
}, PaperProps, {
className: (0, _classnames.default)(classes.paper, classes["paperScroll".concat((0, _helpers.capitalize)(scroll))], (_classNames = {}, (0, _defineProperty2.default)(_classNames, classes["paperWidth".concat(maxWidth ? (0, _helpers.capitalize)(maxWidth) : '')], maxWidth), (0, _defineProperty2.default)(_classNames, classes.paperFullScreen, fullScreen), (0, _defineProperty2.default)(_classNames, classes.paperFullWidth, fullWidth), _classNames), PaperProps.className)
}), children))));
}
}]);
return Dialog;
}(_react.default.Component);
process.env.NODE_ENV !== "production" ? Dialog.propTypes = {
/**
* @ignore
*/
BackdropProps: _propTypes.default.object,
/**
* Dialog children, usually the included sub-components.
*/
children: _propTypes.default.node.isRequired,
/**
* Override or extend the styles applied to the component.
* See [CSS API](#css-api) below for more details.
*/
classes: _propTypes.default.object.isRequired,
/**
* @ignore
*/
className: _propTypes.default.string,
/**
* If `true`, clicking the backdrop will not fire the `onClose` callback.
*/
disableBackdropClick: _propTypes.default.bool,
/**
* If `true`, hitting escape will not fire the `onClose` callback.
*/
disableEscapeKeyDown: _propTypes.default.bool,
/**
* If `true`, the dialog will be full-screen
*/
fullScreen: _propTypes.default.bool,
/**
* If `true`, the dialog stretches to `maxWidth`.
*/
fullWidth: _propTypes.default.bool,
/**
* Determine the max width of the dialog.
* The dialog width grows with the size of the screen, this property is useful
* on the desktop where you might need some coherent different width size across your
* application. Set to `false` to disable `maxWidth`.
*/
maxWidth: _propTypes.default.oneOf(['xs', 'sm', 'md', 'lg', 'xl', false]),
/**
* Callback fired when the backdrop is clicked.
*/
onBackdropClick: _propTypes.default.func,
/**
* Callback fired when the component requests to be closed.
*
* @param {object} event The event source of the callback
* @param {string} reason Can be:`"escapeKeyDown"`, `"backdropClick"`
*/
onClose: _propTypes.default.func,
/**
* Callback fired before the dialog enters.
*/
onEnter: _propTypes.default.func,
/**
* Callback fired when the dialog has entered.
*/
onEntered: _propTypes.default.func,
/**
* Callback fired when the dialog is entering.
*/
onEntering: _propTypes.default.func,
/**
* Callback fired when the escape key is pressed,
* `disableKeyboard` is false and the modal is in focus.
*/
onEscapeKeyDown: _propTypes.default.func,
/**
* Callback fired before the dialog exits.
*/
onExit: _propTypes.default.func,
/**
* Callback fired when the dialog has exited.
*/
onExited: _propTypes.default.func,
/**
* Callback fired when the dialog is exiting.
*/
onExiting: _propTypes.default.func,
/**
* If `true`, the Dialog is open.
*/
open: _propTypes.default.bool.isRequired,
/**
* The component used to render the body of the dialog.
*/
PaperComponent: _utils.componentPropType,
/**
* Properties applied to the [`Paper`](/api/paper/) element.
*/
PaperProps: _propTypes.default.object,
/**
* Determine the container for scrolling the dialog.
*/
scroll: _propTypes.default.oneOf(['body', 'paper']),
/**
* The component used for the transition.
*/
TransitionComponent: _utils.componentPropType,
/**
* The duration for the transition, in milliseconds.
* You may specify a single timeout for all transitions, or individually with an object.
*/
transitionDuration: _propTypes.default.oneOfType([_propTypes.default.number, _propTypes.default.shape({
enter: _propTypes.default.number,
exit: _propTypes.default.number
})]),
/**
* Properties applied to the `Transition` element.
*/
TransitionProps: _propTypes.default.object
} : void 0;
Dialog.defaultProps = {
disableBackdropClick: false,
disableEscapeKeyDown: false,
fullScreen: false,
fullWidth: false,
maxWidth: 'sm',
PaperComponent: _Paper.default,
scroll: 'paper',
TransitionComponent: _Fade.default,
transitionDuration: {
enter: _transitions.duration.enteringScreen,
exit: _transitions.duration.leavingScreen
}
};
var _default = (0, _withStyles.default)(styles, {
name: 'MuiDialog'
})(Dialog);
exports.default = _default;