import classNames from 'classnames'; import useMergedState from 'rc-util/lib/hooks/useMergedState'; import KeyCode from 'rc-util/lib/KeyCode'; import * as React from 'react'; import type { ButtonProps, LegacyButtonType } from '../button/button'; import { ConfigContext } from '../config-provider'; import Popover from '../popover'; import type { AbstractTooltipProps } from '../tooltip'; import type { RenderFunction } from '../_util/getRenderPropValue'; import { cloneElement } from '../_util/reactNode'; import PurePanel, { Overlay } from './PurePanel'; import usePopconfirmStyle from './style'; export interface PopconfirmProps extends AbstractTooltipProps { title: 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; } export interface PopconfirmState { open?: boolean; } const Popconfirm = React.forwardRef((props, ref) => { const { getPrefixCls } = React.useContext(ConfigContext); const [open, setOpen] = useMergedState(false, { value: props.open, defaultValue: props.defaultOpen, }); // const isDestroyed = useDestroyed(); const settingOpen = ( value: boolean, e?: React.MouseEvent | React.KeyboardEvent, ) => { setOpen(value, true); props.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 onKeyDown = (e: React.KeyboardEvent) => { if (e.keyCode === KeyCode.ESC && open) { settingOpen(false, e); } }; const onOpenChange = (value: boolean) => { const { disabled } = props; if (disabled) { return; } settingOpen(value); }; const { prefixCls: customizePrefixCls, placement, children, overlayClassName, ...restProps } = props; const prefixCls = getPrefixCls('popconfirm', customizePrefixCls); const overlayClassNames = classNames(prefixCls, overlayClassName); const [wrapSSR] = usePopconfirmStyle(prefixCls); return wrapSSR( } overlayClassName={overlayClassNames} ref={ref as any} data-popover-inject > {cloneElement(children, { onKeyDown: (e: React.KeyboardEvent) => { if (React.isValidElement(children)) { children?.props.onKeyDown?.(e); } onKeyDown(e); }, })} , ); }) as React.ForwardRefExoticComponent< React.PropsWithoutRef & React.RefAttributes > & { _InternalPanelDoNotUseOrYouWillBeFired: typeof PurePanel; }; Popconfirm.defaultProps = { trigger: 'click' as PopconfirmProps['trigger'], disabled: false, }; // We don't care debug panel /* istanbul ignore next */ Popconfirm._InternalPanelDoNotUseOrYouWillBeFired = PurePanel; export default Popconfirm;