import React, { PropTypes } from 'react'; import { truncateMiddle } from '../../lib/textHelper'; import { Loader } from '../UI'; import AssetProxy, { createAssetProxy } from '../../valueObjects/AssetProxy'; import styles from './FileControl.css'; const MAX_DISPLAY_LENGTH = 50; export default class FileControl extends React.Component { state = { processing: false, }; promise = null; isValid = () => { if (this.promise) { return this.promise; } return { error: false }; }; handleFileInputRef = (el) => { this._fileInput = el; }; handleClick = (e) => { this._fileInput.click(); }; handleDragEnter = (e) => { e.stopPropagation(); e.preventDefault(); }; handleDragOver = (e) => { e.stopPropagation(); e.preventDefault(); }; handleChange = (e) => { e.stopPropagation(); e.preventDefault(); const fileList = e.dataTransfer ? e.dataTransfer.files : e.target.files; const files = [...fileList]; const imageType = /^image\//; // Return the first file on the list const file = files[0]; this.props.onRemoveAsset(this.props.value); if (file) { this.setState({ processing: true }); this.promise = createAssetProxy(file.name, file, false, this.props.field.get('private', false)) .then((assetProxy) => { this.setState({ processing: false }); this.props.onAddAsset(assetProxy); this.props.onChange(assetProxy.public_path); }); } else { this.props.onChange(null); } }; renderFileName = () => { if (!this.props.value) return null; if (this.value instanceof AssetProxy) { return truncateMiddle(this.props.value.path, MAX_DISPLAY_LENGTH); } else { return truncateMiddle(this.props.value, MAX_DISPLAY_LENGTH); } }; render() { const { processing } = this.state; const fileName = this.renderFileName(); if (processing) { return (
); } return (
{fileName ? fileName : 'Click here to upload a file from your computer, or drag and drop a file directly into this box'}
); } } FileControl.propTypes = { onAddAsset: PropTypes.func.isRequired, onChange: PropTypes.func.isRequired, onRemoveAsset: PropTypes.func.isRequired, value: PropTypes.node, field: PropTypes.object, };