@material-ui/core
Version:
React components that implement Google's Material Design.
286 lines (226 loc) • 8.57 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 _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _reactDom = _interopRequireDefault(require("react-dom"));
var _scrollbarSize = _interopRequireDefault(require("dom-helpers/util/scrollbarSize"));
var _withStyles = _interopRequireDefault(require("../styles/withStyles"));
var _Popover = _interopRequireDefault(require("../Popover"));
var _MenuList = _interopRequireDefault(require("../MenuList"));
// @inheritedComponent Popover
var RTL_ORIGIN = {
vertical: 'top',
horizontal: 'right'
};
var LTR_ORIGIN = {
vertical: 'top',
horizontal: 'left'
};
var styles = {
/* Styles applied to the `Paper` component. */
paper: {
// specZ: The maximum height of a simple menu should be one or more rows less than the view
// height. This ensures a tapable area outside of the simple menu with which to dismiss
// the menu.
maxHeight: 'calc(100% - 96px)',
// Add iOS momentum scrolling.
WebkitOverflowScrolling: 'touch'
}
};
exports.styles = styles;
var Menu =
/*#__PURE__*/
function (_React$Component) {
(0, _inherits2.default)(Menu, _React$Component);
function Menu() {
var _getPrototypeOf2;
var _this;
(0, _classCallCheck2.default)(this, Menu);
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)(Menu)).call.apply(_getPrototypeOf2, [this].concat(args)));
_this.getContentAnchorEl = function () {
if (!_this.menuListRef || !_this.menuListRef.selectedItemRef) {
return _reactDom.default.findDOMNode(_this.menuListRef).firstChild;
}
return _reactDom.default.findDOMNode(_this.menuListRef.selectedItemRef);
};
_this.focus = function () {
if (_this.menuListRef && _this.menuListRef.selectedItemRef) {
_reactDom.default.findDOMNode(_this.menuListRef.selectedItemRef).focus();
return;
}
var menuList = _reactDom.default.findDOMNode(_this.menuListRef);
if (menuList && menuList.firstChild) {
menuList.firstChild.focus();
}
};
_this.handleEnter = function (element) {
var _this$props = _this.props,
disableAutoFocusItem = _this$props.disableAutoFocusItem,
theme = _this$props.theme;
var menuList = _reactDom.default.findDOMNode(_this.menuListRef); // Focus so the scroll computation of the Popover works as expected.
if (disableAutoFocusItem !== true) {
_this.focus();
} // Let's ignore that piece of logic if users are already overriding the width
// of the menu.
if (menuList && element.clientHeight < menuList.clientHeight && !menuList.style.width) {
var size = "".concat((0, _scrollbarSize.default)(), "px");
menuList.style[theme.direction === 'rtl' ? 'paddingLeft' : 'paddingRight'] = size;
menuList.style.width = "calc(100% + ".concat(size, ")");
}
if (_this.props.onEnter) {
_this.props.onEnter(element);
}
};
_this.handleListKeyDown = function (event, key) {
if (key === 'tab') {
event.preventDefault();
if (_this.props.onClose) {
_this.props.onClose(event);
}
}
};
return _this;
}
(0, _createClass2.default)(Menu, [{
key: "componentDidMount",
value: function componentDidMount() {
if (this.props.open && this.props.disableAutoFocusItem !== true) {
this.focus();
}
}
}, {
key: "render",
value: function render() {
var _this2 = this;
var _this$props2 = this.props,
children = _this$props2.children,
classes = _this$props2.classes,
disableAutoFocusItem = _this$props2.disableAutoFocusItem,
MenuListProps = _this$props2.MenuListProps,
onEnter = _this$props2.onEnter,
_this$props2$PaperPro = _this$props2.PaperProps,
PaperProps = _this$props2$PaperPro === void 0 ? {} : _this$props2$PaperPro,
PopoverClasses = _this$props2.PopoverClasses,
theme = _this$props2.theme,
other = (0, _objectWithoutProperties2.default)(_this$props2, ["children", "classes", "disableAutoFocusItem", "MenuListProps", "onEnter", "PaperProps", "PopoverClasses", "theme"]);
return _react.default.createElement(_Popover.default, (0, _extends2.default)({
getContentAnchorEl: this.getContentAnchorEl,
classes: PopoverClasses,
onEnter: this.handleEnter,
anchorOrigin: theme.direction === 'rtl' ? RTL_ORIGIN : LTR_ORIGIN,
transformOrigin: theme.direction === 'rtl' ? RTL_ORIGIN : LTR_ORIGIN,
PaperProps: (0, _extends2.default)({}, PaperProps, {
classes: (0, _extends2.default)({}, PaperProps.classes, {
root: classes.paper
})
})
}, other), _react.default.createElement(_MenuList.default, (0, _extends2.default)({
onKeyDown: this.handleListKeyDown
}, MenuListProps, {
ref: function ref(_ref) {
_this2.menuListRef = _ref;
}
}), children));
}
}]);
return Menu;
}(_react.default.Component);
Menu.propTypes = process.env.NODE_ENV !== "production" ? {
/**
* The DOM element used to set the position of the menu.
*/
anchorEl: _propTypes.default.oneOfType([_propTypes.default.object, _propTypes.default.func]),
/**
* Menu contents, normally `MenuItem`s.
*/
children: _propTypes.default.node,
/**
* Override or extend the styles applied to the component.
* See [CSS API](#css-api) below for more details.
*/
classes: _propTypes.default.object.isRequired,
/**
* If `true`, the selected / first menu item will not be auto focused.
*/
disableAutoFocusItem: _propTypes.default.bool,
/**
* Properties applied to the [`MenuList`](/api/menu-list/) element.
*/
MenuListProps: _propTypes.default.object,
/**
* Callback fired when the component requests to be closed.
*
* @param {object} event The event source of the callback
*/
onClose: _propTypes.default.func,
/**
* Callback fired before the Menu enters.
*/
onEnter: _propTypes.default.func,
/**
* Callback fired when the Menu has entered.
*/
onEntered: _propTypes.default.func,
/**
* Callback fired when the Menu is entering.
*/
onEntering: _propTypes.default.func,
/**
* Callback fired before the Menu exits.
*/
onExit: _propTypes.default.func,
/**
* Callback fired when the Menu has exited.
*/
onExited: _propTypes.default.func,
/**
* Callback fired when the Menu is exiting.
*/
onExiting: _propTypes.default.func,
/**
* If `true`, the menu is visible.
*/
open: _propTypes.default.bool.isRequired,
/**
* @ignore
*/
PaperProps: _propTypes.default.object,
/**
* `classes` property applied to the [`Popover`](/api/popover/) element.
*/
PopoverClasses: _propTypes.default.object,
/**
* @ignore
*/
theme: _propTypes.default.object.isRequired,
/**
* The length of the transition in `ms`, or 'auto'
*/
transitionDuration: _propTypes.default.oneOfType([_propTypes.default.number, _propTypes.default.shape({
enter: _propTypes.default.number,
exit: _propTypes.default.number
}), _propTypes.default.oneOf(['auto'])])
} : {};
Menu.defaultProps = {
disableAutoFocusItem: false,
transitionDuration: 'auto'
};
var _default = (0, _withStyles.default)(styles, {
name: 'MuiMenu',
withTheme: true
})(Menu);
exports.default = _default;