import * as React from 'react'; import ExclamationCircleFilled from '@ant-design/icons/ExclamationCircleFilled'; import classNames from 'classnames'; import useMergedState from 'rc-util/lib/hooks/useMergedState'; import omit from 'rc-util/lib/omit'; import type { RenderFunction } from '../_util/getRenderPropValue'; import type { ButtonProps, LegacyButtonType } from '../button/button'; import { ConfigContext } from '../config-provider'; import type { PopoverProps } from '../popover'; import Popover from '../popover'; import type { AbstractTooltipProps, TooltipRef } from '../tooltip'; import PurePanel, { Overlay } from './PurePanel'; import useStyle from './style'; export interface PopconfirmProps extends AbstractTooltipProps { title: React.ReactNode | RenderFunction; description?: React.ReactNode | RenderFunction; disabled?: boolean; onConfirm?: (e?: React.MouseEvent) => void; onCancel?: (e?: React.MouseEvent) => void; okText?: React.ReactNode; okType?: LegacyButtonType; cancelText?: React.ReactNode; okButtonProps?: ButtonProps; cancelButtonProps?: ButtonProps; showCancel?: boolean; icon?: React.ReactNode; onOpenChange?: ( open: boolean, e?: React.MouseEvent | React.KeyboardEvent, ) => void; onPopupClick?: (e: React.MouseEvent) => void; } export interface PopconfirmState { open?: boolean; } const InternalPopconfirm = React.forwardRef((props, ref) => { const { prefixCls: customizePrefixCls, placement = 'top', trigger = 'click', okType = 'primary', icon = , children, overlayClassName, onOpenChange, onVisibleChange, overlayStyle, styles, classNames: popconfirmClassNames, ...restProps } = props; const { getPrefixCls, popconfirm } = React.useContext(ConfigContext); const [open, setOpen] = useMergedState(false, { value: props.open ?? props.visible, defaultValue: props.defaultOpen ?? props.defaultVisible, }); const settingOpen: PopoverProps['onOpenChange'] = (value, e) => { setOpen(value, true); onVisibleChange?.(value); onOpenChange?.(value, e); }; const close = (e: React.MouseEvent) => { settingOpen(false, e); }; const onConfirm = (e: React.MouseEvent) => props.onConfirm?.call(this, e); const onCancel = (e: React.MouseEvent) => { settingOpen(false, e); props.onCancel?.call(this, e); }; const onInternalOpenChange: PopoverProps['onOpenChange'] = (value, e) => { const { disabled = false } = props; if (disabled) { return; } settingOpen(value, e); }; const prefixCls = getPrefixCls('popconfirm', customizePrefixCls); const rootClassNames = classNames( prefixCls, overlayClassName, popconfirm?.classNames?.root, popconfirmClassNames?.root, ); const bodyClassNames = classNames(popconfirm?.classNames?.body, popconfirmClassNames?.body); const [wrapCSSVar] = useStyle(prefixCls); return wrapCSSVar( } data-popover-inject > {children} , ); }); type CompoundedComponent = typeof InternalPopconfirm & { _InternalPanelDoNotUseOrYouWillBeFired: typeof PurePanel; }; const Popconfirm = InternalPopconfirm as CompoundedComponent; // We don't care debug panel /* istanbul ignore next */ Popconfirm._InternalPanelDoNotUseOrYouWillBeFired = PurePanel; if (process.env.NODE_ENV !== 'production') { Popconfirm.displayName = 'Popconfirm'; } export default Popconfirm;