import * as React from 'react'; import { Item } from 'rc-menu'; import * as PropTypes from 'prop-types'; import Tooltip from '../tooltip'; import { ClickParam } from './index'; interface MenuItemProps { rootPrefixCls?: string; disabled?: boolean; level?: number; title?: React.ReactNode; children?: React.ReactNode; className?: string; style?: React.CSSProperties; onClick?: (param: ClickParam) => void; onMouseEnter?: (e: { key: string; domEvent: MouseEvent }) => void; onMouseLeave?: (e: { key: string; domEvent: MouseEvent }) => void; } class MenuItem extends React.Component { static contextTypes = { inlineCollapsed: PropTypes.bool, }; static isMenuItem = 1; context: any; private menuItem: any; onKeyDown = (e: React.MouseEvent) => { this.menuItem.onKeyDown(e); }; saveMenuItem = (menuItem: any) => { this.menuItem = menuItem; }; render() { const { inlineCollapsed } = this.context; const { level, children, rootPrefixCls } = this.props; const { title, ...rest } = this.props; let titleNode; if (inlineCollapsed) { titleNode = title || (level === 1 ? children : ''); } return ( ); } } export default MenuItem;