summaryrefslogtreecommitdiffstats
path: root/web/react/components/removed_from_channel_modal.jsx
blob: 4a49e1c9885ae114f26255d3f31e1659f8fb0b8e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
// Copyright (c) 2015 Spinpunch, Inc. All Rights Reserved.
// See License.txt for license information.

var ChannelStore = require('../stores/channel_store.jsx');
var UserStore = require('../stores/user_store.jsx');
var BrowserStore = require('../stores/browser_store.jsx')
var utils = require('../utils/utils.jsx');

module.exports = React.createClass({
    handleShow: function() {
      var newState = {};
      if(BrowserStore.getItem("channel-removed-state")) {
        newState = BrowserStore.getItem("channel-removed-state");
        BrowserStore.removeItem("channel-removed-state");
      }

      this.setState(newState);
    },
    handleClose: function() {
      var townSquare = ChannelStore.getByName("town-square");
      utils.switchChannel(townSquare);

      this.setState({channelName: "", remover: ""});
    },
    componentDidMount: function() {
      $(this.getDOMNode()).on('show.bs.modal',this.handleShow);
      $(this.getDOMNode()).on('hidden.bs.modal',this.handleClose);
    },
    componentWillUnmount: function() {
      $(this.getDOMNode()).off('show.bs.modal',this.handleShow);
      $(this.getDOMNode()).off('hidden.bs.modal',this.handleClose);
    },
    getInitialState: function() {
      return {channelName: "", remover: ""}
    },
    render: function() {
        var currentUser = UserStore.getCurrentUser();
        var channelName = this.state.channelName ? this.state.channelName : "the channel"
        var remover = this.state.remover ? this.state.remover : "Someone"

        if (currentUser != null) {
            return (
                <div className='modal fade' ref='modal' id='removed_from_channel' tabIndex='-1' role='dialog' aria-hidden='true'>
                   <div className='modal-dialog'>
                      <div className='modal-content'>
                        <div className='modal-header'>
                          <button type='button' className='close' data-dismiss='modal' aria-label='Close'><span aria-hidden='true'>&times;</span></button>
                          <h4 className='modal-title'>Removed from <span className='name'>{channelName}</span></h4>
                        </div>
                        <div className='modal-body'>
                            <p>{remover} removed you from {channelName}</p>
                        </div>
                        <div className='modal-footer'>
                          <button type='button' className='btn btn-primary' data-dismiss='modal'>Okay</button>
                        </div>
                      </div>
                   </div>
                </div>
            );
        } else {
            return <div/>;
        }
    }
});