1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-14 23:07:45 +01:00
onion/js/components/ascribe_uploader/file_drag_and_drop.js

181 lines
6.3 KiB
JavaScript
Raw Normal View History

'use strict';
2015-06-23 10:16:53 +02:00
import React from 'react';
2015-07-07 18:07:12 +02:00
import FileDragAndDropDialog from './file_drag_and_drop_dialog';
2015-06-23 10:16:53 +02:00
import FileDragAndDropPreviewIterator from './file_drag_and_drop_preview_iterator';
// Taken from: https://github.com/fedosejev/react-file-drag-and-drop
2015-06-30 11:56:38 +02:00
let FileDragAndDrop = React.createClass({
2015-06-23 10:16:53 +02:00
propTypes: {
2015-06-29 13:41:37 +02:00
className: React.PropTypes.string,
2015-06-23 10:16:53 +02:00
onDragStart: React.PropTypes.func,
onDrop: React.PropTypes.func.isRequired,
onDrag: React.PropTypes.func,
2015-06-23 10:16:53 +02:00
onDragEnter: React.PropTypes.func,
onLeave: React.PropTypes.func,
onDragLeave: React.PropTypes.func,
2015-06-23 10:16:53 +02:00
onDragOver: React.PropTypes.func,
onDragEnd: React.PropTypes.func,
filesToUpload: React.PropTypes.array,
handleDeleteFile: React.PropTypes.func,
2015-06-29 10:01:54 +02:00
handleCancelFile: React.PropTypes.func,
2015-06-29 17:37:14 +02:00
handlePauseFile: React.PropTypes.func,
handleResumeFile: React.PropTypes.func,
multiple: React.PropTypes.bool,
2015-06-30 13:53:02 +02:00
dropzoneInactive: React.PropTypes.bool,
areAssetsDownloadable: React.PropTypes.bool,
areAssetsEditable: React.PropTypes.bool
2015-06-23 10:16:53 +02:00
},
handleDragStart(event) {
if (typeof this.props.onDragStart === 'function') {
this.props.onDragStart(event);
}
},
handleDrag(event) {
if (typeof this.props.onDrag === 'function') {
this.props.onDrag(event);
}
},
handleDragEnd(event) {
if (typeof this.props.onDragEnd === 'function') {
this.props.onDragEnd(event);
}
},
handleDragEnter(event) {
if (typeof this.props.onDragEnter === 'function') {
this.props.onDragEnter(event);
}
},
handleDragLeave(event) {
if (typeof this.props.onDragLeave === 'function') {
this.props.onDragLeave(event);
}
},
handleDragOver(event) {
event.preventDefault();
if (typeof this.props.onDragOver === 'function') {
this.props.onDragOver(event);
}
},
handleDrop(event) {
event.preventDefault();
event.stopPropagation();
let files;
// handle Drag and Drop
if(event.dataTransfer && event.dataTransfer.files.length > 0) {
files = event.dataTransfer.files;
} else if(event.target.files) { // handle input type file
files = event.target.files;
}
if(typeof this.props.onDrop === 'function' && files) {
this.props.onDrop(files);
}
},
handleDeleteFile(fileId) {
// input's value is not change the second time someone
// inputs the same file again, therefore we need to reset its value
this.refs.fileinput.getDOMNode().value = '';
this.props.handleDeleteFile(fileId);
},
2015-06-29 10:01:54 +02:00
handleCancelFile(fileId) {
// input's value is not change the second time someone
// inputs the same file again, therefore we need to reset its value
this.refs.fileinput.getDOMNode().value = '';
this.props.handleCancelFile(fileId);
},
2015-06-29 17:37:14 +02:00
handlePauseFile(fileId) {
// input's value is not change the second time someone
// inputs the same file again, therefore we need to reset its value
this.refs.fileinput.getDOMNode().value = '';
this.props.handlePauseFile(fileId);
},
handleResumeFile(fileId) {
// input's value is not change the second time someone
// inputs the same file again, therefore we need to reset its value
this.refs.fileinput.getDOMNode().value = '';
this.props.handleResumeFile(fileId);
},
handleOnClick(event) {
// when multiple is set to false and the user already uploaded a piece,
// do not propagate event
if(this.props.dropzoneInactive) {
return;
}
2015-06-30 11:56:38 +02:00
// Firefox only recognizes the simulated mouse click if bubbles is set to true,
// but since Google Chrome propagates the event much further than needed, we
// need to stop propagation as soon as the event is created
2015-06-30 13:32:41 +02:00
var evt = new MouseEvent('click', {
2015-06-30 11:56:38 +02:00
view: window,
bubbles: true,
2015-06-30 13:32:41 +02:00
cancelable: true
2015-06-30 11:56:38 +02:00
});
2015-06-30 11:56:38 +02:00
evt.stopPropagation();
this.refs.fileinput.getDOMNode().dispatchEvent(evt);
2015-06-23 10:16:53 +02:00
},
render: function () {
2015-06-29 11:44:16 +02:00
// has files only is true if there are files that do not have the status deleted or canceled
2015-06-30 17:57:20 +02:00
let hasFiles = this.props.filesToUpload.filter((file) => file.status !== 'deleted' && file.status !== 'canceled' && file.size !== -1).length > 0;
2015-06-29 14:36:55 +02:00
let className = hasFiles ? 'has-files ' : '';
className += this.props.dropzoneInactive ? 'inactive-dropzone' : 'active-dropzone';
2015-06-29 14:36:55 +02:00
className += this.props.className ? ' ' + this.props.className : '';
2015-06-23 10:16:53 +02:00
return (
<div
className={className}
2015-06-23 10:16:53 +02:00
onDragStart={this.handleDragStart}
onDrag={this.handleDrop}
onDragEnter={this.handleDragEnter}
onDragLeave={this.handleDragLeave}
onDragOver={this.handleDragOver}
onDrop={this.handleDrop}
onDragEnd={this.handleDragEnd}>
2015-07-08 10:15:58 +02:00
<FileDragAndDropDialog
2015-07-07 18:07:12 +02:00
multipleFiles={this.props.multiple}
hasFiles={hasFiles}
2015-07-03 19:08:56 +02:00
onClick={this.handleOnClick}/>
2015-06-23 13:55:05 +02:00
<FileDragAndDropPreviewIterator
2015-06-23 10:16:53 +02:00
files={this.props.filesToUpload}
2015-06-29 10:01:54 +02:00
handleDeleteFile={this.handleDeleteFile}
2015-06-29 17:37:14 +02:00
handleCancelFile={this.handleCancelFile}
handlePauseFile={this.handlePauseFile}
2015-06-30 13:53:02 +02:00
handleResumeFile={this.handleResumeFile}
areAssetsDownloadable={this.props.areAssetsDownloadable}
areAssetsEditable={this.props.areAssetsEditable}/>
2015-06-23 10:16:53 +02:00
<input
multiple={this.props.multiple}
2015-06-23 10:16:53 +02:00
ref="fileinput"
2015-06-23 13:55:05 +02:00
type="file"
2015-06-23 10:16:53 +02:00
style={{
display: 'none',
2015-06-23 13:55:05 +02:00
height: 0,
width: 0
2015-06-23 10:16:53 +02:00
}}
onChange={this.handleDrop} />
</div>
);
}
});
2015-07-03 19:08:56 +02:00
export default FileDragAndDrop;