@wordpress/components
Version:
UI components for WordPress.
89 lines (72 loc) • 2.47 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.MenuItem = MenuItem;
exports.default = void 0;
var _element = require("@wordpress/element");
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _classnames = _interopRequireDefault(require("classnames"));
var _shortcut = _interopRequireDefault(require("../shortcut"));
var _button = _interopRequireDefault(require("../button"));
var _icon = _interopRequireDefault(require("../icon"));
// @ts-nocheck
/**
* External dependencies
*/
/**
* WordPress dependencies
*/
/**
* Internal dependencies
*/
function MenuItem(props, ref) {
let {
children,
info,
className,
icon,
iconPosition = 'right',
shortcut,
isSelected,
role = 'menuitem',
suffix,
...buttonProps
} = props;
className = (0, _classnames.default)('components-menu-item__button', className);
if (info) {
children = (0, _element.createElement)("span", {
className: "components-menu-item__info-wrapper"
}, (0, _element.createElement)("span", {
className: "components-menu-item__item"
}, children), (0, _element.createElement)("span", {
className: "components-menu-item__info"
}, info));
}
if (icon && typeof icon !== 'string') {
icon = (0, _element.cloneElement)(icon, {
className: (0, _classnames.default)('components-menu-items__item-icon', {
'has-icon-right': iconPosition === 'right'
})
});
}
return (0, _element.createElement)(_button.default, (0, _extends2.default)({
ref: ref // Make sure aria-checked matches spec https://www.w3.org/TR/wai-aria-1.1/#aria-checked
,
"aria-checked": role === 'menuitemcheckbox' || role === 'menuitemradio' ? isSelected : undefined,
role: role,
icon: iconPosition === 'left' ? icon : undefined,
className: className
}, buttonProps), (0, _element.createElement)("span", {
className: "components-menu-item__item"
}, children), !suffix && (0, _element.createElement)(_shortcut.default, {
className: "components-menu-item__shortcut",
shortcut: shortcut
}), !suffix && icon && iconPosition === 'right' && (0, _element.createElement)(_icon.default, {
icon: icon
}), suffix);
}
var _default = (0, _element.forwardRef)(MenuItem);
exports.default = _default;
//# sourceMappingURL=index.js.map