grommet
Version:
focus on the essential experience
166 lines (126 loc) • 5.72 kB
JavaScript
;
exports.__esModule = true;
exports.DropButton = void 0;
var _react = _interopRequireWildcard(require("react"));
var _recompose = require("recompose");
var _Button = require("../Button");
var _Drop = require("../Drop");
var _hocs = require("../hocs");
var _utils = require("../../utils");
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj["default"] = obj; return newObj; } }
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
var DropButton =
/*#__PURE__*/
function (_Component) {
_inheritsLoose(DropButton, _Component);
function DropButton(props) {
var _this;
_this = _Component.call(this, props) || this;
_defineProperty(_assertThisInitialized(_this), "buttonRef", (0, _react.createRef)());
_defineProperty(_assertThisInitialized(_this), "onDropClose", function () {
var onClose = _this.props.onClose;
_this.setState({
show: false
}, function () {
if (onClose) {
onClose();
}
});
});
_defineProperty(_assertThisInitialized(_this), "onToggle", function (event) {
var _this$props = _this.props,
onClick = _this$props.onClick,
onClose = _this$props.onClose,
onOpen = _this$props.onOpen;
var show = _this.state.show;
_this.setState({
show: !show
}, function () {
return show ? onClose && onClose() : onOpen && onOpen();
});
if (onClick) {
onClick(event);
}
});
_this.state = {
show: props.open || false
};
return _this;
}
DropButton.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, prevState) {
var show = prevState.show;
var open = nextProps.open;
if (open !== undefined && open !== show) {
return {
show: open
};
}
return null;
};
var _proto = DropButton.prototype;
_proto.componentDidMount = function componentDidMount() {
var open = this.props.open;
if (open) {
this.forceUpdate();
}
};
_proto.componentDidUpdate = function componentDidUpdate(prevProps, prevState) {
var forwardRef = this.props.forwardRef;
var show = this.state.show;
if (!show && prevState.show) {
// focus on the button if the drop is closed
(0, _utils.setFocusWithoutScroll)((forwardRef || this.buttonRef).current);
}
};
_proto.render = function render() {
var _this$props2 = this.props,
disabled = _this$props2.disabled,
dropAlign = _this$props2.dropAlign,
dropProps = _this$props2.dropProps,
forwardRef = _this$props2.forwardRef,
dropContent = _this$props2.dropContent,
dropTarget = _this$props2.dropTarget,
id = _this$props2.id,
open = _this$props2.open,
rest = _objectWithoutPropertiesLoose(_this$props2, ["disabled", "dropAlign", "dropProps", "forwardRef", "dropContent", "dropTarget", "id", "open"]);
var show = this.state.show;
delete rest.onClose;
delete rest.onOpen;
var drop;
if (show && (forwardRef || this.buttonRef).current) {
drop = _react["default"].createElement(_Drop.Drop, _extends({
id: id ? id + "__drop" : undefined,
restrictFocus: true,
align: dropAlign,
target: dropTarget || (forwardRef || this.buttonRef).current,
onClickOutside: this.onDropClose,
onEsc: this.onDropClose
}, dropProps), dropContent);
}
return _react["default"].createElement(_react["default"].Fragment, null, _react["default"].createElement(_Button.Button, _extends({
id: id,
ref: forwardRef || this.buttonRef,
disabled: disabled
}, rest, {
onClick: this.onToggle
})), drop);
};
return DropButton;
}(_react.Component);
_defineProperty(DropButton, "defaultProps", {
a11yTitle: 'Open Drop',
dropAlign: {
top: 'top',
left: 'left'
}
});
var DropButtonDoc;
if (process.env.NODE_ENV !== 'production') {
DropButtonDoc = require('./doc').doc(DropButton); // eslint-disable-line global-require
}
var DropButtonWrapper = (0, _recompose.compose)(_hocs.withForwardRef)(DropButtonDoc || DropButton);
exports.DropButton = DropButtonWrapper;