import classNames from 'classnames'; import * as React from 'react'; import ConfigProvider from '../config-provider'; import ActionButton from '../_util/ActionButton'; import { getTransitionName } from '../_util/motion'; import warning from '../_util/warning'; import type { ModalFuncProps } from './Modal'; import Dialog from './Modal'; interface ConfirmDialogProps extends ModalFuncProps { afterClose?: () => void; close: (...args: any[]) => void; autoFocusButton?: null | 'ok' | 'cancel'; rootPrefixCls: string; iconPrefixCls?: string; } const ConfirmDialog = (props: ConfirmDialogProps) => { const { icon, onCancel, onOk, close, zIndex, afterClose, visible, open, keyboard, centered, getContainer, maskStyle, okText, okButtonProps, cancelText, cancelButtonProps, direction, prefixCls, wrapClassName, rootPrefixCls, iconPrefixCls, bodyStyle, closable = false, closeIcon, modalRender, focusTriggerAfterClose, } = props; if (process.env.NODE_ENV !== 'production') { warning( !(typeof icon === 'string' && icon.length > 2), 'Modal', `\`icon\` is using ReactNode instead of string naming in v4. Please check \`${icon}\` at https://ant.design/components/icon`, ); warning( visible === undefined, 'Modal', `\`visible\` is deprecated, please use \`open\` instead.`, ); } // 支持传入{ icon: null }来隐藏`Modal.confirm`默认的Icon const okType = props.okType || 'primary'; const contentPrefixCls = `${prefixCls}-confirm`; // 默认为 true,保持向下兼容 const okCancel = 'okCancel' in props ? props.okCancel! : true; const width = props.width || 416; const style = props.style || {}; const mask = props.mask === undefined ? true : props.mask; // 默认为 false,保持旧版默认行为 const maskClosable = props.maskClosable === undefined ? false : props.maskClosable; const autoFocusButton = props.autoFocusButton === null ? false : props.autoFocusButton || 'ok'; const classString = classNames( contentPrefixCls, `${contentPrefixCls}-${props.type}`, { [`${contentPrefixCls}-rtl`]: direction === 'rtl' }, props.className, ); const cancelButton = okCancel && ( {cancelText} ); return ( close?.({ triggerCancel: true })} open={open || visible} title="" footer="" transitionName={getTransitionName(rootPrefixCls, 'zoom', props.transitionName)} maskTransitionName={getTransitionName(rootPrefixCls, 'fade', props.maskTransitionName)} mask={mask} maskClosable={maskClosable} maskStyle={maskStyle} style={style} bodyStyle={bodyStyle} width={width} zIndex={zIndex} afterClose={afterClose} keyboard={keyboard} centered={centered} getContainer={getContainer} closable={closable} closeIcon={closeIcon} modalRender={modalRender} focusTriggerAfterClose={focusTriggerAfterClose} > {icon} {props.title === undefined ? null : ( {props.title} )} {props.content} {cancelButton} {okText} ); }; export default ConfirmDialog;