"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.SIZES = exports.LAYOUT_ALIGN = exports.EuiContextMenuItem = void 0; var _react = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _classnames = _interopRequireDefault(require("classnames")); var _common = require("../common"); var _icon = require("../icon"); var _tool_tip = require("../tool_tip"); var _services = require("../../services"); var _href_validator = require("../../services/security/href_validator"); var _react2 = require("@emotion/react"); var _excluded = ["children", "className", "hasPanel", "icon", "buttonRef", "disabled", "layoutAlign", "toolTipTitle", "toolTipContent", "toolTipPosition", "href", "target", "rel", "size"]; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } function _extends() { _extends = Object.assign ? Object.assign.bind() : 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 _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } 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; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } /* * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one * or more contributor license agreements. Licensed under the Elastic License * 2.0 and the Server Side Public License, v 1; you may not use this file except * in compliance with, at your election, the Elastic License 2.0 or the Server * Side Public License, v 1. */ var sizeToClassNameMap = { s: 'euiContextMenuItem--small', m: null }; var SIZES = (0, _common.keysOf)(sizeToClassNameMap); exports.SIZES = SIZES; var layoutAlignToClassNames = { center: null, top: 'euiContextMenu__itemLayout--top', bottom: 'euiContextMenu__itemLayout--bottom' }; var LAYOUT_ALIGN = (0, _common.keysOf)(layoutAlignToClassNames); exports.LAYOUT_ALIGN = LAYOUT_ALIGN; var EuiContextMenuItem = /*#__PURE__*/function (_Component) { _inherits(EuiContextMenuItem, _Component); var _super = _createSuper(EuiContextMenuItem); function EuiContextMenuItem() { _classCallCheck(this, EuiContextMenuItem); return _super.apply(this, arguments); } _createClass(EuiContextMenuItem, [{ key: "render", value: function render() { var _this$props = this.props, children = _this$props.children, className = _this$props.className, hasPanel = _this$props.hasPanel, icon = _this$props.icon, buttonRef = _this$props.buttonRef, _disabled = _this$props.disabled, _this$props$layoutAli = _this$props.layoutAlign, layoutAlign = _this$props$layoutAli === void 0 ? 'center' : _this$props$layoutAli, toolTipTitle = _this$props.toolTipTitle, toolTipContent = _this$props.toolTipContent, _this$props$toolTipPo = _this$props.toolTipPosition, toolTipPosition = _this$props$toolTipPo === void 0 ? 'right' : _this$props$toolTipPo, href = _this$props.href, target = _this$props.target, rel = _this$props.rel, size = _this$props.size, rest = _objectWithoutProperties(_this$props, _excluded); var iconInstance; var isHrefValid = !href || (0, _href_validator.validateHref)(href); var disabled = _disabled || !isHrefValid; if (icon) { switch (_typeof(icon)) { case 'string': iconInstance = (0, _react2.jsx)(_icon.EuiIcon, { type: icon, size: "m", className: "euiContextMenu__icon", color: "inherit" // forces the icon to inherit its parent color }); break; default: // Assume it's already an instance of an icon. iconInstance = /*#__PURE__*/(0, _react.cloneElement)(icon, { className: 'euiContextMenu__icon' }); } } var arrow; if (hasPanel) { arrow = (0, _react2.jsx)(_icon.EuiIcon, { type: "arrowRight", size: "m", className: "euiContextMenu__arrow" }); } var classes = (0, _classnames.default)('euiContextMenuItem', size && sizeToClassNameMap[size], className, { 'euiContextMenuItem-isDisabled': disabled }); var layoutClasses = (0, _classnames.default)('euiContextMenu__itemLayout', layoutAlignToClassNames[layoutAlign]); var buttonInner = (0, _react2.jsx)("span", { className: layoutClasses }, iconInstance, (0, _react2.jsx)("span", { className: "euiContextMenuItem__text" }, children), arrow); var button; // elements don't respect the `disabled` attribute. So if we're disabled, we'll just pretend // this is a button and piggyback off its disabled styles. if (href && !disabled) { var secureRel = (0, _services.getSecureRelForTarget)({ href: href, target: target, rel: rel }); button = (0, _react2.jsx)("a", _extends({ className: classes, href: href, target: target, rel: secureRel, ref: buttonRef }, rest), buttonInner); } else { button = (0, _react2.jsx)("button", _extends({ disabled: disabled, className: classes, type: "button", ref: buttonRef }, rest), buttonInner); } if (toolTipContent) { return (0, _react2.jsx)(_tool_tip.EuiToolTip, { title: toolTipTitle ? toolTipTitle : null, content: toolTipContent, anchorClassName: "eui-displayBlock", position: toolTipPosition }, button); } else { return button; } } }]); return EuiContextMenuItem; }(_react.Component); exports.EuiContextMenuItem = EuiContextMenuItem; EuiContextMenuItem.propTypes = { className: _propTypes.default.string, "aria-label": _propTypes.default.string, "data-test-subj": _propTypes.default.string, css: _propTypes.default.any, icon: _propTypes.default.oneOfType([_propTypes.default.element.isRequired, _propTypes.default.string.isRequired, _propTypes.default.any.isRequired]), hasPanel: _propTypes.default.bool, disabled: _propTypes.default.bool, onClick: _propTypes.default.func, buttonRef: _propTypes.default.any, /** * Required if using a tooltip. Add an optional tooltip on hover */ toolTipContent: _propTypes.default.node, /** * Optional title for the tooltip */ toolTipTitle: _propTypes.default.node, /** * Dictates the position of the tooltip. */ toolTipPosition: _propTypes.default.oneOf(["top", "right", "bottom", "left"]), href: _propTypes.default.string, target: _propTypes.default.string, rel: _propTypes.default.string, /** * How to align icon with content of button */ layoutAlign: _propTypes.default.oneOf(["center", "top", "bottom"]), /** * Reduce the size to `s` when in need of a more compressed menu */ size: _propTypes.default.oneOf(["s", "m"]) };