summaryrefslogtreecommitdiffstats
path: root/web/react/components/file_upload.jsx
diff options
context:
space:
mode:
authorhmhealey <harrisonmhealey@gmail.com>2015-08-10 08:41:18 -0400
committerhmhealey <harrisonmhealey@gmail.com>2015-08-10 14:04:23 -0400
commit4e8af44370bfb4276e009526045a4983d5ff245a (patch)
tree901e39bc69433a9c77325923cfcb08da93ab3dd5 /web/react/components/file_upload.jsx
parent20d755f3dd5c797413177752884d8589c1f46931 (diff)
downloadchat-4e8af44370bfb4276e009526045a4983d5ff245a.tar.gz
chat-4e8af44370bfb4276e009526045a4983d5ff245a.tar.bz2
chat-4e8af44370bfb4276e009526045a4983d5ff245a.zip
Added the ability to cancel file uploads on posts
Diffstat (limited to 'web/react/components/file_upload.jsx')
-rw-r--r--web/react/components/file_upload.jsx37
1 files changed, 36 insertions, 1 deletions
diff --git a/web/react/components/file_upload.jsx b/web/react/components/file_upload.jsx
index c02afc5e9..11b3b3cee 100644
--- a/web/react/components/file_upload.jsx
+++ b/web/react/components/file_upload.jsx
@@ -4,8 +4,12 @@
var client = require('../utils/client.jsx');
var Constants = require('../utils/constants.jsx');
var ChannelStore = require('../stores/channel_store.jsx');
+var utils = require('../utils/utils.jsx');
module.exports = React.createClass({
+ getInitialState: function() {
+ return {requests: {}};
+ },
handleChange: function() {
var element = $(this.refs.fileInput.getDOMNode());
var files = element.prop('files');
@@ -40,16 +44,26 @@ module.exports = React.createClass({
formData.append('channel_id', channel_id);
formData.append('files', files[i], files[i].name);
- client.uploadFile(formData,
+ var request = client.uploadFile(formData,
function(data) {
parsedData = $.parseJSON(data);
this.props.onFileUpload(parsedData['filenames'], channel_id);
+
+ var requests = this.state.requests;
+ for (var i = 0; i < parsedData['filenames'].length; i++) {
+ delete requests[utils.getFileName(parsedData['filenames'][i])];
+ }
+ this.setState({requests: requests});
}.bind(this),
function(err) {
this.props.onUploadError(err);
}.bind(this)
);
+ var requests = this.state.requests;
+ requests[files[i].name] = request;
+ this.setState({requests: requests});
+
this.props.onUploadStart([files[i].name], channel_id);
}
@@ -121,18 +135,39 @@ module.exports = React.createClass({
function(data) {
parsedData = $.parseJSON(data);
self.props.onFileUpload(parsedData['filenames'], channel_id);
+
+ var requests = self.state.requests;
+ for (var i = 0; i < parsedData['filenames'].length; i++) {
+ delete requests[utils.getFileName(parsedData['filenames'][i])];
+ }
+ self.setState({requests: requests});
},
function(err) {
self.props.onUploadError(err);
}
);
+ var requests = self.state.requests;
+ requests[files[i].name] = request;
+ self.setState({requests: requests});
+
self.props.onUploadStart([name], channel_id);
}
}
}
});
},
+ cancelUpload: function(filename) {
+ var requests = this.state.requests;
+ var request = requests[filename];
+
+ if (request) {
+ request.abort();
+
+ delete requests[filename];
+ this.setState({requests: requests});
+ }
+ },
render: function() {
return (
<span ref="input" className="btn btn-file"><span><i className="glyphicon glyphicon-paperclip"></i></span><input ref="fileInput" type="file" onChange={this.handleChange} multiple/></span>