import * as React from 'react'; import type { AbstractTooltipProps, TooltipPlacement } from '../tooltip'; import Tooltip from '../tooltip'; import { ConfigContext } from '../config-provider'; import type { RenderFunction } from '../_util/getRenderPropValue'; import { getRenderPropValue } from '../_util/getRenderPropValue'; import { getTransitionName } from '../_util/motion'; export interface PopoverProps extends AbstractTooltipProps { title?: React.ReactNode | RenderFunction; content?: React.ReactNode | RenderFunction; } const Popover = React.forwardRef( ({ prefixCls: customizePrefixCls, title, content, ...otherProps }, ref) => { const { getPrefixCls } = React.useContext(ConfigContext); const getOverlay = (prefixCls: string) => { if (!title && !content) return undefined; return ( <> {title &&
{getRenderPropValue(title)}
}
{getRenderPropValue(content)}
); }; const prefixCls = getPrefixCls('popover', customizePrefixCls); const rootPrefixCls = getPrefixCls(); return ( ); }, ); Popover.displayName = 'Popover'; Popover.defaultProps = { placement: 'top' as TooltipPlacement, trigger: 'hover', mouseEnterDelay: 0.1, mouseLeaveDelay: 0.1, overlayStyle: {}, }; export default Popover;