2018-03-19 10:16:27 +08:00
|
|
|
|
|
2018-03-06 19:14:41 +08:00
|
|
|
|
import classNames from 'classnames'
|
|
|
|
|
import Icon from '../icon'
|
|
|
|
|
import Dialog from './Modal'
|
|
|
|
|
import ActionButton from './ActionButton'
|
|
|
|
|
import { getConfirmLocale } from './locale'
|
|
|
|
|
|
|
|
|
|
export default {
|
|
|
|
|
functional: true,
|
2018-03-06 22:53:32 +08:00
|
|
|
|
render (h, context) {
|
2018-03-22 17:23:51 +08:00
|
|
|
|
const { props } = context
|
2018-12-09 17:34:27 +08:00
|
|
|
|
const { onCancel, onOk, close, zIndex, afterClose, visible,
|
|
|
|
|
keyboard, centered, getContainer, maskStyle, okButtonProps, cancelButtonProps } = props
|
2018-03-06 19:14:41 +08:00
|
|
|
|
const iconType = props.iconType || 'question-circle'
|
|
|
|
|
const okType = props.okType || 'primary'
|
2018-12-09 17:34:27 +08:00
|
|
|
|
const prefixCls = props.prefixCls || 'ant-modal'
|
|
|
|
|
const contentPrefixCls = `${prefixCls}-confirm`
|
2018-03-06 19:14:41 +08:00
|
|
|
|
// 默认为 true,保持向下兼容
|
|
|
|
|
const okCancel = ('okCancel' in props) ? props.okCancel : true
|
|
|
|
|
const width = props.width || 416
|
|
|
|
|
const style = props.style || {}
|
|
|
|
|
// 默认为 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
|
2018-12-09 17:34:27 +08:00
|
|
|
|
const autoFocusButton = props.autoFocusButton === null ? false : props.autoFocusButton || 'ok'
|
2018-03-06 19:14:41 +08:00
|
|
|
|
|
|
|
|
|
const classString = classNames(
|
2018-12-09 17:34:27 +08:00
|
|
|
|
contentPrefixCls,
|
|
|
|
|
`${contentPrefixCls}-${props.type}`,
|
2018-03-06 19:14:41 +08:00
|
|
|
|
`${prefixCls}-${props.type}`,
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
const cancelButton = okCancel && (
|
2018-12-09 17:34:27 +08:00
|
|
|
|
<ActionButton
|
|
|
|
|
actionFn={onCancel}
|
|
|
|
|
closeModal={close}
|
|
|
|
|
autoFocus={autoFocusButton === 'cancel'} buttonProps={cancelButtonProps}
|
|
|
|
|
>
|
2018-03-06 19:14:41 +08:00
|
|
|
|
{cancelText}
|
|
|
|
|
</ActionButton>
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<Dialog
|
2018-12-09 17:34:27 +08:00
|
|
|
|
prefixCls={prefixCls}
|
2018-03-06 19:14:41 +08:00
|
|
|
|
class={classString}
|
2018-12-09 17:34:27 +08:00
|
|
|
|
wrapClassName={classNames({ [`${contentPrefixCls}-centered`]: !!centered })}
|
2018-03-06 19:14:41 +08:00
|
|
|
|
onCancel={(e) => close({ triggerCancel: true }, e)}
|
|
|
|
|
visible={visible}
|
|
|
|
|
title=''
|
|
|
|
|
transitionName='zoom'
|
|
|
|
|
footer=''
|
|
|
|
|
maskTransitionName='fade'
|
|
|
|
|
maskClosable={maskClosable}
|
2018-12-09 17:34:27 +08:00
|
|
|
|
maskStyle={maskStyle}
|
2018-03-06 19:14:41 +08:00
|
|
|
|
style={style}
|
|
|
|
|
width={width}
|
|
|
|
|
zIndex={zIndex}
|
|
|
|
|
afterClose={afterClose}
|
2018-04-07 14:29:59 +08:00
|
|
|
|
keyboard={keyboard}
|
2018-12-09 17:34:27 +08:00
|
|
|
|
centered={centered}
|
|
|
|
|
getContainer={getContainer}
|
2018-03-06 19:14:41 +08:00
|
|
|
|
>
|
2018-12-09 17:34:27 +08:00
|
|
|
|
<div class={`${contentPrefixCls}-body-wrapper`}>
|
|
|
|
|
<div class={`${contentPrefixCls}-body`}>
|
2018-03-06 19:14:41 +08:00
|
|
|
|
<Icon type={iconType} />
|
2018-12-09 17:34:27 +08:00
|
|
|
|
<span class={`${contentPrefixCls}-title`}>{props.title}</span>
|
|
|
|
|
<div class={`${contentPrefixCls}-content`}>{props.content}</div>
|
2018-03-06 19:14:41 +08:00
|
|
|
|
</div>
|
2018-12-09 17:34:27 +08:00
|
|
|
|
<div class={`${contentPrefixCls}-btns`}>
|
2018-03-06 19:14:41 +08:00
|
|
|
|
{cancelButton}
|
2018-12-09 17:34:27 +08:00
|
|
|
|
<ActionButton type={okType} actionFn={onOk} closeModal={close} autoFocus={autoFocusButton === 'ok'} buttonProps={okButtonProps}>
|
2018-03-06 19:14:41 +08:00
|
|
|
|
{okText}
|
|
|
|
|
</ActionButton>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</Dialog>)
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
|