import React from 'react'; import Menu from 'rc-menu'; import animation from '../common/openAnimation'; function noop() { } const AntMenu = React.createClass({ getDefaultProps() { return { prefixCls: 'ant-menu', onClick: noop, onOpen: noop, onClose: noop, }; }, getInitialState() { return { openKeys: [] }; }, handleClick() { this.setState({ openKeys: [] }); this.props.onClick(); }, handleOpenKeys(e) { this.setState({ openKeys: e.openKeys }); this.props.onOpen(); }, handleCloseKeys(e) { this.setState({ openKeys: e.openKeys }); this.props.onClose(); }, render() { let openAnimation = ''; switch (this.props.mode) { case 'horizontal': openAnimation = 'slide-up'; break; case 'vertical': openAnimation = 'zoom-big'; break; case 'inline': openAnimation = animation; break; default: } let props = { openKeys: this.state.openKeys, onClick: this.handleClick, onOpen: this.handleOpenKeys, onClose: this.handleCloseKeys, }; if (this.props.mode === 'inline') { return
; } else { return ; } } }); AntMenu.Divider = Menu.Divider; AntMenu.Item = Menu.Item; AntMenu.SubMenu = Menu.SubMenu; export default AntMenu;