import * as React from 'react'; import Tooltip, { AbstractTooltipProps, TooltipPlacement, TooltipTrigger } from '../tooltip'; import { ConfigConsumer, ConfigConsumerProps } from '../config-provider'; export interface PopoverProps extends AbstractTooltipProps { title?: React.ReactNode; content?: React.ReactNode; } export default class Popover extends React.Component { static defaultProps = { placement: 'top' as TooltipPlacement, transitionName: 'zoom-big', trigger: 'hover' as TooltipTrigger, mouseEnterDelay: 0.1, mouseLeaveDelay: 0.1, overlayStyle: {}, }; private tooltip: Tooltip; getPopupDomNode() { return this.tooltip.getPopupDomNode(); } getOverlay(prefixCls: string) { const { title, content } = this.props; return (
{title &&
{title}
}
{content}
); } saveTooltip = (node: any) => { this.tooltip = node; }; renderPopover = ({ getPrefixCls }: ConfigConsumerProps) => { const { prefixCls: customizePrefixCls, ...props } = this.props; delete props.title; const prefixCls = getPrefixCls('popover', customizePrefixCls); return ( ); }; render() { return {this.renderPopover}; } }