@sb1/ffe-file-upload-react
Version:
Upload file button with validation and list of uploaded files.
54 lines (53 loc) • 5.13 kB
JavaScript
import React, { useRef, useState } from 'react';
import { FileItem } from './FileItem';
import classNames from 'classnames';
import { SecondaryButton } from '@sb1/ffe-buttons-react';
import { Icon } from '@sb1/ffe-icons-react';
export function FileUpload(_a) {
var id = _a.id, label = _a.label, files = _a.files, cancelText = _a.cancelText, deleteText = _a.deleteText, multiple = _a.multiple, title = _a.title, infoText = _a.infoText, infoSubText = _a.infoSubText, uploadTitle = _a.uploadTitle, uploadMicroText = _a.uploadMicroText, uploadSubText = _a.uploadSubText, _b = _a.accept, accept = _b === void 0 ? '*' : _b, onFilesDropped = _a.onFilesDropped, onFileDeleted = _a.onFileDeleted, onFilesSelected = _a.onFilesSelected;
var _c = useState(false), isHover = _c[0], setIsHover = _c[1];
var fileInputElement = useRef(null);
var downloadIcon = '';
var handleFilesDropped = function (event) {
event.preventDefault();
setIsHover(false);
onFilesDropped(event.dataTransfer.files);
};
var handleFileDeleted = function (event) {
onFileDeleted(files[event.currentTarget.id]);
};
var triggerUploadFileNativeHandler = function () {
// clear file input to trigger onChange when uploading same filename
if (fileInputElement.current) {
fileInputElement.current.value = '';
fileInputElement.current.click();
}
};
var handleFileSelected = function (event) {
onFilesSelected(event.target.files);
};
return (React.createElement("div", { className: "ffe-file-upload" },
React.createElement("div", { className: "ffe-file-upload__title" }, title),
Object.keys(files).length > 0 ? (React.createElement("div", { className: "ffe-file-upload__file-items-section" }, Object.keys(files).map(function (file) { return (React.createElement(FileItem, { key: file, file: files[file], cancelText: cancelText, deleteText: deleteText, onFileDeleted: handleFileDeleted })); }))) : (React.createElement("div", { className: "ffe-file-upload__info-section" },
React.createElement("div", { className: "ffe-file-upload__info-section-text" }, infoText),
React.createElement("div", { className: "ffe-file-upload__info-section-subtext" }, infoSubText))),
React.createElement("div", { className: "ffe-file-upload__upload-section", onDrop: handleFilesDropped, onDragOver: function (event) {
event.preventDefault();
setIsHover(true);
}, onDragLeave: function () { return setIsHover(false); } },
React.createElement("div", { className: classNames('ffe-file-upload__upload-section-border', {
'ffe-file-upload__upload-section-border--hover': isHover,
}) },
React.createElement("div", { className: "ffe-file-upload__upload-section-title" }, uploadTitle),
React.createElement("div", { className: "ffe-file-upload__upload-section-microtext" }, uploadMicroText),
React.createElement(SecondaryButton, { tabIndex: 0, as: "label", htmlFor: id, leftIcon: React.createElement(Icon, { fileUrl: downloadIcon, size: "md" }), onClick: function (e) {
e.preventDefault();
triggerUploadFileNativeHandler();
}, onKeyUp: function (e) {
if (e.key === 'Enter' || e.key === ' ') {
triggerUploadFileNativeHandler();
}
} }, label),
React.createElement("input", { id: id, type: "file", multiple: multiple, ref: fileInputElement, onChange: handleFileSelected, accept: accept }),
React.createElement("div", { className: "ffe-file-upload__upload-section-subtext" }, uploadSubText)))));
}