'use strict'; import React from 'react'; import ReactS3FineUploader from '../ascribe_uploader/react_s3_fine_uploader'; import AppConstants from '../../constants/application_constants'; import { getCookie } from '../../utils/fetch_api_utils'; let InputFineUploader = React.createClass({ propTypes: { setIsUploadReady: React.PropTypes.func, isReadyForFormSubmission: React.PropTypes.func, submitFileName: React.PropTypes.func, areAssetsDownloadable: React.PropTypes.bool, onClick: React.PropTypes.func, keyRoutine: React.PropTypes.shape({ url: React.PropTypes.string, fileClass: React.PropTypes.string }), createBlobRoutine: React.PropTypes.shape({ url: React.PropTypes.string }), validation: React.PropTypes.shape({ itemLimit: React.PropTypes.number, sizeLimit: React.PropTypes.string, allowedExtensions: React.PropTypes.arrayOf(React.PropTypes.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: React.PropTypes.bool, onLoggedOut: React.PropTypes.func, enableLocalHashing: React.PropTypes.bool, uploadMethod: React.PropTypes.string, // provided by Property disabled: React.PropTypes.bool, // A class of a file the user has to upload // Needs to be defined both in singular as well as in plural fileClassToUpload: React.PropTypes.shape({ singular: React.PropTypes.string, plural: React.PropTypes.string }) }, getInitialState() { return { value: null }; }, submitFile(file){ this.setState({ value: file.key }); if(typeof this.props.submitFileName === 'function') { this.props.submitFileName(file.originalName); } }, reset() { this.refs.fineuploader.reset(); }, render() { let editable = this.props.isFineUploaderActive; // if disabled is actually set by property, we want to override // isFineUploaderActive if(typeof this.props.disabled !== 'undefined') { editable = !this.props.disabled; } return ( ); } }); export default InputFineUploader;