summaryrefslogtreecommitdiffstats
path: root/web/react/components/delete_post_modal.jsx
blob: c88b548d18b968ccf631d88646dca9ad3a7f3c0a (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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
// Copyright (c) 2015 Spinpunch, Inc. All Rights Reserved.
// See License.txt for license information.

var Client = require('../utils/client.jsx');
var PostStore = require('../stores/post_store.jsx');
var utils = require('../utils/utils.jsx');
var AsyncClient = require('../utils/async_client.jsx');
var AppDispatcher = require('../dispatcher/app_dispatcher.jsx');
var Constants = require('../utils/constants.jsx');
var ActionTypes = Constants.ActionTypes;

module.exports = React.createClass({
    handleDelete: function(e) {
        Client.deletePost(this.state.channel_id, this.state.post_id,
            function(data) {
                var selected_list = this.state.selectedList;
                if (selected_list && selected_list.order && selected_list.order.length > 0) {
                    var selected_post = selected_list.posts[selected_list.order[0]];
                    if ((selected_post.id === this.state.post_id && this.state.title === "Post") || selected_post.root_id === this.state.post_id) {
                        AppDispatcher.handleServerAction({
                            type: ActionTypes.RECIEVED_SEARCH,
                            results: null
                        });

                        AppDispatcher.handleServerAction({
                            type: ActionTypes.RECIEVED_POST_SELECTED,
                            results: null
                        });
                    } else if (selected_post.id === this.state.post_id && this.state.title === "Comment") {
                        if (selected_post.root_id && selected_post.root_id.length > 0 && selected_list.posts[selected_post.root_id]) {
                            selected_list.order = [selected_post.root_id];
                            delete selected_list.posts[selected_post.id];

                            AppDispatcher.handleServerAction({
                                type: ActionTypes.RECIEVED_POST_SELECTED,
                                post_list: selected_list
                            });

                            AppDispatcher.handleServerAction({
                                type: ActionTypes.RECIEVED_SEARCH,
                                results: null
                            });
                        }
                    }
                }
                AsyncClient.getPosts(true, this.state.channel_id);
            }.bind(this),
            function(err) {
                AsyncClient.dispatchError(err, "deletePost");
            }.bind(this)
        );
    },
    componentDidMount: function() {
        var self = this;
        $(this.refs.modal.getDOMNode()).on('show.bs.modal', function(e) {
            var newState = {};
            if(sessionStorage.getItem('edit_state_transfer')) {
                newState = JSON.parse(sessionStorage.getItem('edit_state_transfer'));
                sessionStorage.removeItem('edit_state_transfer');
            } else {
                var button = e.relatedTarget;
                newState = { title: $(button).attr('data-title'), channel_id: $(button).attr('data-channelid'), post_id: $(button).attr('data-postid'), comments: $(button).attr('data-comments') };
            }
            self.setState(newState)
        });
        PostStore.addSelectedPostChangeListener(this._onChange);
    },
    componentWillUnmount: function() {
        PostStore.removeSelectedPostChangeListener(this._onChange);
    },
    _onChange: function() {
        var newList = PostStore.getSelectedPost();
        if (!utils.areStatesEqual(this.state.selectedList, newList)) {
            this.setState({ selectedList: newList });
        }
    },
    getInitialState: function() {
        return { title: "", post_id: "", channel_id: "", selectedList: PostStore.getSelectedPost(), comments: 0 };
    },
    render: function() {
        var error = this.state.error ? <div className='form-group has-error'><label className='control-label'>{ this.state.error }</label></div> : null;

        return (
            <div className="modal fade" id="delete_post" ref="modal" role="dialog" aria-hidden="true">
              <div className="modal-dialog modal-push-down">
                <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">Confirm {this.state.title} Delete</h4>
                  </div>
                  <div className="modal-body">
                    Are you sure you want to delete the {this.state.title.toLowerCase()}?
                    <br/>
                    <br/>
                    { this.state.comments > 0 ?
                        "This post has " + this.state.comments + " comment(s) on it."
                    : "" }
                  </div>
                  <div className="modal-footer">
                    <button type="button" className="btn btn-default" data-dismiss="modal">Close</button>
                    <button type="button" className="btn btn-danger" data-dismiss="modal" onClick={this.handleDelete}>Delete</button>
                  </div>
                </div>
              </div>
            </div>
        );
    }
});