@wordpress/components
Version:
UI components for WordPress.
81 lines (74 loc) • 2.55 kB
JavaScript
import _extends from "@babel/runtime/helpers/esm/extends";
import { createElement } from "@wordpress/element";
/**
* External dependencies
*/
import classnames from 'classnames';
import { isString } from 'lodash';
/**
* WordPress dependencies
*/
import { cloneElement, forwardRef } from '@wordpress/element';
/**
* Internal dependencies
*/
import Shortcut from '../shortcut';
import Button from '../button';
import Icon from '../icon';
/**
* Renders a generic menu item for use inside the more menu.
*
* @param {Object} props Component props.
* @param {WPElement} props.children Element to render as child of button.
* @param {string} props.info Text to use as description for button text.
* @param {string} props.className Class to set on the container.
* @param {WPIcon} props.icon Button's `icon` prop.
* @param {string|Object} props.shortcut Shortcut's `shortcut` prop.
* @param {boolean} props.isSelected Whether or not the menu item is currently selected.
* @param {string} [props.role="menuitem"] ARIA role of the menu item.
* @param {Object} ref React Element ref.
*
* @return {WPComponent} The component to be rendered.
*/
export function MenuItem({
children,
info,
className,
icon,
shortcut,
isSelected,
role = 'menuitem',
...props
}, ref) {
className = classnames('components-menu-item__button', className);
if (info) {
children = createElement("span", {
className: "components-menu-item__info-wrapper"
}, createElement("span", {
className: "components-menu-item__item"
}, children), createElement("span", {
className: "components-menu-item__info"
}, info));
}
if (icon && !isString(icon)) {
icon = cloneElement(icon, {
className: 'components-menu-items__item-icon'
});
}
return createElement(Button, _extends({
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,
className: className
}, props), createElement("span", {
className: "components-menu-item__item"
}, children), createElement(Shortcut, {
className: "components-menu-item__shortcut",
shortcut: shortcut
}), icon && createElement(Icon, {
icon: icon
}));
}
export default forwardRef(MenuItem);
//# sourceMappingURL=index.js.map