2016-11-22 14:19:08 -06:00
|
|
|
import React from 'react';
|
|
|
|
import ReactModal from 'react-modal';
|
|
|
|
import {Link} from './link.js';
|
|
|
|
|
|
|
|
|
2016-10-20 21:25:32 -04:00
|
|
|
var Modal = React.createClass({
|
|
|
|
propTypes: {
|
|
|
|
type: React.PropTypes.oneOf(['alert', 'confirm', 'custom']),
|
|
|
|
onConfirmed: React.PropTypes.func,
|
|
|
|
onAborted: React.PropTypes.func,
|
|
|
|
confirmButtonLabel: React.PropTypes.string,
|
|
|
|
abortButtonLabel: React.PropTypes.string,
|
2016-10-26 03:22:05 -04:00
|
|
|
confirmButtonDisabled: React.PropTypes.bool,
|
|
|
|
abortButtonDisabled: React.PropTypes.bool,
|
2016-10-20 21:25:32 -04:00
|
|
|
},
|
|
|
|
getDefaultProps: function() {
|
|
|
|
return {
|
|
|
|
type: 'alert',
|
|
|
|
confirmButtonLabel: 'OK',
|
|
|
|
abortButtonLabel: 'Cancel',
|
2016-10-26 03:22:05 -04:00
|
|
|
confirmButtonDisabled: false,
|
|
|
|
abortButtonDisabled: false,
|
2016-10-20 21:25:32 -04:00
|
|
|
};
|
|
|
|
},
|
|
|
|
render: function() {
|
|
|
|
var props = Object.assign({}, this.props);
|
|
|
|
|
|
|
|
if (typeof props.className == 'undefined') {
|
|
|
|
props.className = 'modal';
|
|
|
|
} else {
|
|
|
|
props.className += ' modal';
|
|
|
|
}
|
|
|
|
|
|
|
|
if (typeof props.overlayClassName == 'undefined') {
|
|
|
|
props.overlayClassName = 'modal-overlay';
|
|
|
|
} else {
|
|
|
|
props.overlayClassName += ' modal-overlay';
|
|
|
|
}
|
|
|
|
|
|
|
|
props.onCloseRequested = props.onAborted || props.onConfirmed;
|
|
|
|
|
2016-10-22 01:04:24 -04:00
|
|
|
if (this.props.type == 'custom') {
|
|
|
|
var buttons = null;
|
|
|
|
} else {
|
2016-10-20 21:25:32 -04:00
|
|
|
var buttons = (
|
|
|
|
<div className="modal__buttons">
|
2016-10-22 01:04:24 -04:00
|
|
|
{this.props.type == 'confirm'
|
2016-10-26 03:22:05 -04:00
|
|
|
? <Link button="alt" label={props.abortButtonLabel} className="modal__button" disabled={this.props.abortButtonDisabled} onClick={props.onAborted} />
|
2016-10-22 01:04:24 -04:00
|
|
|
: null}
|
2016-10-26 03:22:05 -04:00
|
|
|
<Link button="primary" label={props.confirmButtonLabel} className="modal__button" disabled={this.props.confirmButtonDisabled} onClick={props.onConfirmed} />
|
2016-10-20 21:25:32 -04:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<ReactModal {...props}>
|
2016-11-24 23:03:03 -05:00
|
|
|
<div>
|
|
|
|
{this.props.children}
|
|
|
|
</div>
|
2016-10-20 21:25:32 -04:00
|
|
|
{buttons}
|
|
|
|
</ReactModal>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
2016-11-22 14:19:08 -06:00
|
|
|
|
|
|
|
export default Modal;
|