import React from 'react'; import Tooltip from 'rc-tooltip'; import Icon from '../icon'; import Button from '../button'; import getPlacements from '../popover/placements'; const placements = getPlacements(); const prefixCls = 'ant-popover'; const noop = function () {}; const transitionNames = { top: 'zoom-down', bottom: 'zoom-up', left: 'zoom-right', right: 'zoom-left', topLeft: 'zoom-down', bottomLeft: 'zoom-up', leftTop: 'zoom-right', rightTop: 'zoom-left', topRight: 'zoom-down', bottomRight: 'zoom-up', leftBottom: 'zoom-right', rightBottom: 'zoom-left', }; export default React.createClass({ getInitialState() { return { visible: false }; }, getDefaultProps() { return { transitionName: '', placement: 'top', trigger: 'click', overlayStyle: {}, onConfirm: noop, onCancel: noop, okText: '确定', cancelText: '取消', onVisibleChange() {}, }; }, componentWillReceiveProps(nextProps) { if ('visible' in nextProps) { this.setState({ visible: nextProps.visible }); } }, confirm() { this.setVisible(false); this.props.onConfirm.call(this); }, cancel() { this.setVisible(false); this.props.onCancel.call(this); }, onVisibleChange(visible) { this.setVisible(visible); this.props.onVisibleChange(visible); }, setVisible(visible) { if (!('visible' in this.props)) { this.setState({ visible }); } }, render() { const { title, okText, cancelText, placement, overlayStyle, trigger, ...restProps } = this.props; const overlay = (