Merge pull request #850 from ant-design/fix-modal

fix: cyclic reference in Modal
This commit is contained in:
afc163 2016-01-12 17:26:26 +08:00
commit 6728760402
3 changed files with 78 additions and 75 deletions

View File

@ -0,0 +1,76 @@
import React from 'react';
import Dialog from 'rc-dialog';
import { Dom } from 'rc-util';
import Button from '../button';
function noop() {}
let mousePosition;
let mousePositionEventBinded;
let AntModal = React.createClass({
getDefaultProps() {
return {
prefixCls: 'ant-modal',
onOk: noop,
onCancel: noop,
okText: '确定',
cancelText: '取消',
width: 520,
transitionName: 'zoom',
maskAnimation: 'fade',
confirmLoading: false,
visible: false
};
},
handleCancel() {
this.props.onCancel();
},
handleOk() {
this.props.onOk();
},
componentDidMount() {
if (mousePositionEventBinded) {
return;
}
//
Dom.addEventListener(document.body, 'click', function onDocumentMousemove(e) {
mousePosition = {
x: e.pageX,
y: e.pageY
};
// 20ms
// zoom
//
setTimeout(() => mousePosition = null, 20);
});
mousePositionEventBinded = true;
},
render() {
let props = this.props;
let defaultFooter = [
<Button key="cancel"
type="ghost"
size="large"
onClick={this.handleCancel}>
{props.cancelText}
</Button>,
<Button key="confirm"
type="primary"
size="large"
loading={props.confirmLoading}
onClick={this.handleOk}>
{props.okText}
</Button>
];
let footer = props.footer || defaultFooter;
return <Dialog onClose={this.handleCancel} footer={footer} {...props}
visible={props.visible} mousePosition={mousePosition} />;
}
});
export default AntModal;

View File

@ -1,6 +1,6 @@
import React from 'react';
import ReactDOM from 'react-dom';
import Dialog from './index';
import Dialog from './modal';
import Icon from '../icon';
import Button from '../button';

View File

@ -1,78 +1,5 @@
import React from 'react';
import Dialog from 'rc-dialog';
import { Dom } from 'rc-util';
import AntModal from './Modal';
import confirm from './confirm';
import Button from '../button';
function noop() {}
let mousePosition;
let mousePositionEventBinded;
let AntModal = React.createClass({
getDefaultProps() {
return {
prefixCls: 'ant-modal',
onOk: noop,
onCancel: noop,
okText: '确定',
cancelText: '取消',
width: 520,
transitionName: 'zoom',
maskAnimation: 'fade',
confirmLoading: false,
visible: false
};
},
handleCancel() {
this.props.onCancel();
},
handleOk() {
this.props.onOk();
},
componentDidMount() {
if (mousePositionEventBinded) {
return;
}
//
Dom.addEventListener(document.body, 'click', function onDocumentMousemove(e) {
mousePosition = {
x: e.pageX,
y: e.pageY
};
// 20ms
// zoom
//
setTimeout(() => mousePosition = null, 20);
});
mousePositionEventBinded = true;
},
render() {
let props = this.props;
let defaultFooter = [
<Button key="cancel"
type="ghost"
size="large"
onClick={this.handleCancel}>
{props.cancelText}
</Button>,
<Button key="confirm"
type="primary"
size="large"
loading={props.confirmLoading}
onClick={this.handleOk}>
{props.okText}
</Button>
];
let footer = props.footer || defaultFooter;
return <Dialog onClose={this.handleCancel} footer={footer} {...props}
visible={props.visible} mousePosition={mousePosition} />;
}
});
AntModal.info = function (props) {
props.iconClassName = 'info-circle';