119 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			119 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Vue
		
	
	
| import classNames from 'classnames';
 | ||
| import Icon from '../icon';
 | ||
| import Dialog from './Modal';
 | ||
| import ActionButton from './ActionButton';
 | ||
| import { getConfirmLocale } from './locale';
 | ||
| import warning from '../_util/warning';
 | ||
| 
 | ||
| export default {
 | ||
|   functional: true,
 | ||
|   render(h, context) {
 | ||
|     const { props } = context;
 | ||
|     const {
 | ||
|       onCancel,
 | ||
|       onOk,
 | ||
|       close,
 | ||
|       zIndex,
 | ||
|       afterClose,
 | ||
|       visible,
 | ||
|       keyboard,
 | ||
|       centered,
 | ||
|       getContainer,
 | ||
|       maskStyle,
 | ||
|       okButtonProps,
 | ||
|       cancelButtonProps,
 | ||
|       iconType = 'question-circle',
 | ||
|       closable = false,
 | ||
|     } = props;
 | ||
|     warning(
 | ||
|       !('iconType' in props),
 | ||
|       `The property 'iconType' is deprecated. Use the property 'icon' instead.`,
 | ||
|     );
 | ||
|     const icon = props.icon ? props.icon : iconType;
 | ||
|     const okType = props.okType || 'primary';
 | ||
|     const prefixCls = props.prefixCls || 'ant-modal';
 | ||
|     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 runtimeLocale = getConfirmLocale();
 | ||
|     const okText = props.okText || (okCancel ? runtimeLocale.okText : runtimeLocale.justOkText);
 | ||
|     const cancelText = props.cancelText || runtimeLocale.cancelText;
 | ||
|     const autoFocusButton = props.autoFocusButton === null ? false : props.autoFocusButton || 'ok';
 | ||
|     const transitionName = props.transitionName || 'zoom';
 | ||
|     const maskTransitionName = props.maskTransitionName || 'fade';
 | ||
| 
 | ||
|     const classString = classNames(
 | ||
|       contentPrefixCls,
 | ||
|       `${contentPrefixCls}-${props.type}`,
 | ||
|       `${prefixCls}-${props.type}`,
 | ||
|       props.class,
 | ||
|     );
 | ||
| 
 | ||
|     const cancelButton = okCancel && (
 | ||
|       <ActionButton
 | ||
|         actionFn={onCancel}
 | ||
|         closeModal={close}
 | ||
|         autoFocus={autoFocusButton === 'cancel'}
 | ||
|         buttonProps={cancelButtonProps}
 | ||
|       >
 | ||
|         {cancelText}
 | ||
|       </ActionButton>
 | ||
|     );
 | ||
|     const iconNode = typeof icon === 'string' ? <Icon type={icon} /> : icon(h);
 | ||
| 
 | ||
|     return (
 | ||
|       <Dialog
 | ||
|         prefixCls={prefixCls}
 | ||
|         class={classString}
 | ||
|         wrapClassName={classNames({ [`${contentPrefixCls}-centered`]: !!centered })}
 | ||
|         onCancel={e => close({ triggerCancel: true }, e)}
 | ||
|         visible={visible}
 | ||
|         closable={closable}
 | ||
|         title=""
 | ||
|         transitionName={transitionName}
 | ||
|         footer=""
 | ||
|         maskTransitionName={maskTransitionName}
 | ||
|         mask={mask}
 | ||
|         maskClosable={maskClosable}
 | ||
|         maskStyle={maskStyle}
 | ||
|         style={style}
 | ||
|         width={width}
 | ||
|         zIndex={zIndex}
 | ||
|         afterClose={afterClose}
 | ||
|         keyboard={keyboard}
 | ||
|         centered={centered}
 | ||
|         getContainer={getContainer}
 | ||
|       >
 | ||
|         <div class={`${contentPrefixCls}-body-wrapper`}>
 | ||
|           <div class={`${contentPrefixCls}-body`}>
 | ||
|             {iconNode}
 | ||
|             <span class={`${contentPrefixCls}-title`}>
 | ||
|               {typeof props.title === 'function' ? props.title(h) : props.title}
 | ||
|             </span>
 | ||
|             <div class={`${contentPrefixCls}-content`}>
 | ||
|               {typeof props.content === 'function' ? props.content(h) : props.content}
 | ||
|             </div>
 | ||
|           </div>
 | ||
|           <div class={`${contentPrefixCls}-btns`}>
 | ||
|             {cancelButton}
 | ||
|             <ActionButton
 | ||
|               type={okType}
 | ||
|               actionFn={onOk}
 | ||
|               closeModal={close}
 | ||
|               autoFocus={autoFocusButton === 'ok'}
 | ||
|               buttonProps={okButtonProps}
 | ||
|             >
 | ||
|               {okText}
 | ||
|             </ActionButton>
 | ||
|           </div>
 | ||
|         </div>
 | ||
|       </Dialog>
 | ||
|     );
 | ||
|   },
 | ||
| };
 |