From d1955b982c32dfa7a1eff9988b4570cb870fa8df Mon Sep 17 00:00:00 2001 From: Reed Garmsen Date: Thu, 20 Aug 2015 09:46:51 -0700 Subject: Users are now placed in the channel after joining it from the 'More...' channel menu --- web/react/components/more_channels.jsx | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) (limited to 'web') diff --git a/web/react/components/more_channels.jsx b/web/react/components/more_channels.jsx index 5261ed6a7..56366cde4 100644 --- a/web/react/components/more_channels.jsx +++ b/web/react/components/more_channels.jsx @@ -45,9 +45,10 @@ module.exports = React.createClass({ }, handleJoin: function(id) { client.joinChannel(id, - function() { + function(data) { $(this.refs.modal.getDOMNode()).modal('hide'); asyncClient.getChannel(id); + utils.switchChannel(data); }.bind(this), function(err) { this.state.serverError = err.message; -- cgit v1.2.3-1-g7c22 From 173326941d9f4aa7f907fd6f2615fad8c7511272 Mon Sep 17 00:00:00 2001 From: Reed Garmsen Date: Thu, 20 Aug 2015 11:40:53 -0700 Subject: Cosmetic reformatting of more_channels.jsx --- web/react/components/more_channels.jsx | 91 +++++++++++++++++++++++----------- 1 file changed, 62 insertions(+), 29 deletions(-) (limited to 'web') diff --git a/web/react/components/more_channels.jsx b/web/react/components/more_channels.jsx index 56366cde4..bc634ba55 100644 --- a/web/react/components/more_channels.jsx +++ b/web/react/components/more_channels.jsx @@ -14,11 +14,20 @@ function getStateFromStores() { }; } -module.exports = React.createClass({ - displayName: 'MoreChannelsModal', +export default class MoreChannels extends React.Component { + constructor(props) { + super(props); - componentDidMount: function() { - ChannelStore.addMoreChangeListener(this._onChange); + this.onListenerChange = this.onListenerChange.bind(this); + this.handleJoin = this.handleJoin.bind(this); + this.handleNewChannel = this.handleNewChannel.bind(this); + + var initState = getStateFromStores(); + initState.channelType = ''; + this.state = initState; + } + componentDidMount() { + ChannelStore.addMoreChangeListener(this.onListenerChange); $(this.refs.modal.getDOMNode()).on('shown.bs.modal', function shown() { asyncClient.getMoreChannels(true); }); @@ -28,44 +37,39 @@ module.exports = React.createClass({ var button = e.relatedTarget; self.setState({channelType: $(button).attr('data-channeltype')}); }); - }, - componentWillUnmount: function() { - ChannelStore.removeMoreChangeListener(this._onChange); - }, - _onChange: function() { + } + componentWillUnmount() { + ChannelStore.removeMoreChangeListener(this.onListenerChange); + } + onListenerChange() { var newState = getStateFromStores(); if (!utils.areStatesEqual(newState.channels, this.state.channels)) { this.setState(newState); } - }, - getInitialState: function() { - var initState = getStateFromStores(); - initState.channelType = ''; - return initState; - }, - handleJoin: function(id) { + } + handleJoin(id) { client.joinChannel(id, - function(data) { + function joinSuccess(data) { $(this.refs.modal.getDOMNode()).modal('hide'); asyncClient.getChannel(id); utils.switchChannel(data); }.bind(this), - function(err) { + function joinFail(err) { this.state.serverError = err.message; this.setState(this.state); }.bind(this) ); - }, - handleNewChannel: function() { + } + handleNewChannel() { $(this.refs.modal.getDOMNode()).modal('hide'); - }, - render: function() { + } + render() { var serverError; if (this.state.serverError) { serverError =
; } - var outter = this; + var self = this; var moreChannels; if (this.state.channels != null) { @@ -82,7 +86,12 @@ module.exports = React.createClass({

{channel.display_name}

{channel.description}

- + + + ); })} @@ -103,23 +112,47 @@ module.exports = React.createClass({ } return ( -