summaryrefslogtreecommitdiffstats
path: root/web/react/components/invite_member_modal.jsx
diff options
context:
space:
mode:
authorhmhealey <harrisonmhealey@gmail.com>2015-11-02 17:35:59 -0500
committerhmhealey <harrisonmhealey@gmail.com>2015-11-02 17:35:59 -0500
commit6428878e20fa54b7bb6b2bf6e0aaaeb637affa59 (patch)
tree56c32ca5cb1569de8289dbc23a14680285505ed5 /web/react/components/invite_member_modal.jsx
parent02b9414e0f0169c99044ad96456290766ffcd585 (diff)
downloadchat-6428878e20fa54b7bb6b2bf6e0aaaeb637affa59.tar.gz
chat-6428878e20fa54b7bb6b2bf6e0aaaeb637affa59.tar.bz2
chat-6428878e20fa54b7bb6b2bf6e0aaaeb637affa59.zip
Moved InviteMemberModal to be controlled by a store
Diffstat (limited to 'web/react/components/invite_member_modal.jsx')
-rw-r--r--web/react/components/invite_member_modal.jsx40
1 files changed, 33 insertions, 7 deletions
diff --git a/web/react/components/invite_member_modal.jsx b/web/react/components/invite_member_modal.jsx
index 71f72625d..c09477a69 100644
--- a/web/react/components/invite_member_modal.jsx
+++ b/web/react/components/invite_member_modal.jsx
@@ -2,7 +2,10 @@
// See License.txt for license information.
var utils = require('../utils/utils.jsx');
+var ActionTypes = require('../utils/constants.jsx').ActionTypes;
+var AppDispatcher = require('../dispatcher/app_dispatcher.jsx');
var Client = require('../utils/client.jsx');
+var ModalStore = require('../stores/modal_store.jsx');
var UserStore = require('../stores/user_store.jsx');
var TeamStore = require('../stores/team_store.jsx');
var ConfirmModal = require('./confirm_modal.jsx');
@@ -13,6 +16,7 @@ export default class InviteMemberModal extends React.Component {
constructor(props) {
super(props);
+ this.handleToggle = this.handleToggle.bind(this);
this.handleSubmit = this.handleSubmit.bind(this);
this.handleHide = this.handleHide.bind(this);
this.addInviteFields = this.addInviteFields.bind(this);
@@ -20,6 +24,7 @@ export default class InviteMemberModal extends React.Component {
this.removeInviteFields = this.removeInviteFields.bind(this);
this.state = {
+ show: false,
inviteIds: [0],
idCount: 0,
emailErrors: {},
@@ -30,6 +35,20 @@ export default class InviteMemberModal extends React.Component {
};
}
+ componentDidMount() {
+ ModalStore.addModalListener(ActionTypes.TOGGLE_INVITE_MEMBER_MODAL, this.handleToggle);
+ }
+
+ componentWillUnmount() {
+ ModalStore.removeModalListener(ActionTypes.TOGGLE_INVITE_MEMBER_MODAL, this.handleToggle);
+ }
+
+ handleToggle(value) {
+ this.setState({
+ show: value
+ });
+ }
+
handleSubmit() {
if (!this.state.emailEnabled) {
return;
@@ -108,12 +127,14 @@ export default class InviteMemberModal extends React.Component {
this.clearFields();
- this.setState({showConfirmModal: false});
- this.props.onModalDismissed();
+ this.setState({
+ show: false,
+ showConfirmModal: false
+ });
}
- componentDidUpdate(prevProps) {
- if (!prevProps.show && this.props.show) {
+ componentDidUpdate(prevProps, prevState) {
+ if (!prevState.show && this.state.show) {
$(ReactDOM.findDOMNode(this.refs.modalBody)).css('max-height', $(window).height() - 300);
if ($(window).width() > 768) {
$(ReactDOM.findDOMNode(this.refs.modalBody)).perfectScrollbar();
@@ -331,7 +352,7 @@ export default class InviteMemberModal extends React.Component {
<div>
<Modal
className='modal-invite-member'
- show={this.props.show}
+ show={this.state.show}
onHide={this.handleHide.bind(this, true)}
enforceFocus={!this.state.showConfirmModal}
>
@@ -369,9 +390,14 @@ export default class InviteMemberModal extends React.Component {
return null;
}
+
+ static show() {
+ AppDispatcher.handleViewAction({
+ type: ActionTypes.TOGGLE_INVITE_MEMBER_MODAL,
+ value: true
+ });
+ }
}
InviteMemberModal.propTypes = {
- show: React.PropTypes.bool.isRequired,
- onModalDismissed: React.PropTypes.func.isRequired
};