'use strict'; import React from 'react'; import ReactS3FineUploader from '../ascribe_uploader/react_s3_fine_uploader'; import FileDragAndDrop from '../ascribe_uploader/ascribe_file_drag_and_drop/file_drag_and_drop'; import AppConstants from '../../constants/application_constants'; import { getCookie } from '../../utils/fetch_api_utils'; const { func, bool, shape, string, number, arrayOf } = React.PropTypes; const InputFineUploader = React.createClass({ propTypes: { setIsUploadReady: func, isReadyForFormSubmission: func, submitFile: func, fileInputElement: func, areAssetsDownloadable: bool, keyRoutine: shape({ url: string, fileClass: string }), createBlobRoutine: shape({ url: string }), validation: shape({ itemLimit: number, sizeLimit: string, allowedExtensions: arrayOf(string) }), // isFineUploaderActive is used to lock react fine uploader in case // a user is actually not logged in already to prevent him from droping files // before login in isFineUploaderActive: bool, enableLocalHashing: bool, uploadMethod: string, // provided by Property disabled: bool, // A class of a file the user has to upload // Needs to be defined both in singular as well as in plural fileClassToUpload: shape({ singular: string, plural: string }), handleChangedFile: func, onValidationFailed: func, // Provided by `Property` onChange: React.PropTypes.func }, getDefaultProps() { return { fileInputElement: FileDragAndDrop }; }, getInitialState() { return { value: null, file: null }; }, submitFile(file) { this.setState({ file, value: file.key }); if(this.state.value && typeof this.props.onChange === 'function') { this.props.onChange({ target: { value: this.state.value } }); } if(typeof this.props.submitFile === 'function') { this.props.submitFile(file); } }, reset() { this.refs.fineuploader.reset(); }, createBlobRoutine() { const { fineuploader } = this.refs; const { file } = this.state; fineuploader.createBlob(file); }, render() { const { areAssetsDownloadable, enableLocalHashing, createBlobRoutine, disabled, fileClassToUpload, fileInputElement, isFineUploaderActive, isReadyForFormSubmission, keyRoutine, onValidationFailed, setIsUploadReady, uploadMethod, validation, handleChangedFile } = this.props; let editable = isFineUploaderActive; // if disabled is actually set by property, we want to override // isFineUploaderActive if(typeof disabled !== 'undefined') { editable = !disabled; } return ( ); } }); export default InputFineUploader;