import React, { PropTypes } from 'react'; import Dialog from 'rc-dialog'; import { Dom } from 'rc-util'; import Button from '../button'; function noop() {} let mousePosition; let mousePositionEventBinded; const AntModal = React.createClass({ getDefaultProps() { return { prefixCls: 'ant-modal', onOk: noop, onCancel: noop, okText: '确定', cancelText: '取消', width: 520, transitionName: 'zoom', maskAnimation: 'fade', confirmLoading: false, visible: false, }; }, propTypes: { prefixCls: PropTypes.string, onOk: PropTypes.func, onCancel: PropTypes.func, okText: PropTypes.node, cancelText: PropTypes.node, width: PropTypes.oneOfType([PropTypes.number, PropTypes.string]), confirmLoading: PropTypes.bool, visible: PropTypes.bool, align: PropTypes.object, footer: PropTypes.node, title: PropTypes.node, closable: PropTypes.bool, }, handleCancel(e) { this.props.onCancel(e); }, handleOk() { this.props.onOk(); }, componentDidMount() { if (mousePositionEventBinded) { return; } // 只有点击事件支持从鼠标位置动画展开 Dom.addEventListener(document.documentElement, 'click', (e) => { mousePosition = { x: e.pageX, y: e.pageY }; // 20ms 内发生过点击事件,则从点击位置动画展示 // 否则直接 zoom 展示 // 这样可以兼容非点击方式展开 setTimeout(() => mousePosition = null, 20); }); mousePositionEventBinded = true; }, render() { let props = this.props; let defaultFooter = [ , ]; let footer = props.footer || defaultFooter; return ( ); } }); export default AntModal;