Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
Size: Mime:
"use strict";

Object.defineProperty(exports, "__esModule", {
  value: true
});
exports["default"] = exports.menuItemPropTypes = void 0;

var _react = _interopRequireDefault(require("react"));

var _propTypes = _interopRequireDefault(require("prop-types"));

var _reactAriaMenubutton = require("react-aria-menubutton");

var _classnames = _interopRequireDefault(require("classnames"));

var _pickDataAttributes = _interopRequireDefault(require("../../../../utils/pickDataAttributes"));

function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }

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 _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }

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; }

var MenuItem = function MenuItem(_ref) {
  var className = _ref.className,
      children = _ref.children,
      indented = _ref.indented,
      item = _ref.item;

  var label = item.label,
      to = item.to,
      action = item.action,
      target = item.target,
      rest = _objectWithoutProperties(item, ["label", "to", "action", "target"]);

  var isLink = !!to;
  var isHandler = action && typeof action === 'function';
  var isClickable = isLink || isHandler;

  var handleClick = function handleClick(e) {
    if (isHandler) {
      e.preventDefault();
      action();
    }
  };

  return /*#__PURE__*/_react["default"].createElement("li", {
    className: className
  }, /*#__PURE__*/_react["default"].createElement(_reactAriaMenubutton.MenuItem, _extends({
    className: (0, _classnames["default"])({
      'Menu-item': true,
      'u-indented': indented,
      'u-noPointer': !isClickable
    }),
    tag: isLink ? 'a' : 'span',
    href: action ? null : to,
    target: target,
    onClick: handleClick
  }, (0, _pickDataAttributes["default"])(rest)), label), children);
};

var menuItemPropTypes = {
  label: _propTypes["default"].node.isRequired,
  to: _propTypes["default"].string,
  action: _propTypes["default"].func,
  target: _propTypes["default"].string
};
exports.menuItemPropTypes = menuItemPropTypes;
MenuItem.propTypes = {
  className: _propTypes["default"].string,
  children: _propTypes["default"].node,
  indented: _propTypes["default"].bool,
  item: _propTypes["default"].shape(menuItemPropTypes)
};
MenuItem.defaultProps = {
  className: '',
  children: undefined,
  indented: false,
  item: {
    to: undefined,
    action: undefined,
    target: '_self'
  }
};
var _default = MenuItem;
exports["default"] = _default;