UNPKG

4.8 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3exports.FileUpload = void 0;
4const tslib_1 = require("tslib");
5const React = tslib_1.__importStar(require("react"));
6const react_dropzone_1 = tslib_1.__importDefault(require("react-dropzone"));
7const FileUploadField_1 = require("./FileUploadField");
8const fileUtils_1 = require("../../helpers/fileUtils");
9const file_selector_1 = require("file-selector");
10const FileUpload = (_a) => {
11 var { id, type, value = type === fileUtils_1.fileReaderType.text || type === fileUtils_1.fileReaderType.dataURL ? '' : null, filename = '', children = null, onChange = () => { }, onFileInputChange = null, onReadStarted = () => { }, onReadFinished = () => { }, onReadFailed = () => { }, onClearClick, onClick = event => event.preventDefault(), onTextChange, onDataChange, dropzoneProps = {} } = _a, props = tslib_1.__rest(_a, ["id", "type", "value", "filename", "children", "onChange", "onFileInputChange", "onReadStarted", "onReadFinished", "onReadFailed", "onClearClick", "onClick", "onTextChange", "onDataChange", "dropzoneProps"]);
12 const onDropAccepted = (acceptedFiles, event) => {
13 if (acceptedFiles.length > 0) {
14 const fileHandle = acceptedFiles[0];
15 if (event.type === 'drop') {
16 onFileInputChange === null || onFileInputChange === void 0 ? void 0 : onFileInputChange(event, fileHandle);
17 }
18 if (type === fileUtils_1.fileReaderType.text || type === fileUtils_1.fileReaderType.dataURL) {
19 onChange('', fileHandle.name, event); // Show the filename while reading
20 onReadStarted(fileHandle);
21 fileUtils_1.readFile(fileHandle, type)
22 .then(data => {
23 onReadFinished(fileHandle);
24 onChange(data, fileHandle.name, event);
25 onDataChange === null || onDataChange === void 0 ? void 0 : onDataChange(data);
26 })
27 .catch((error) => {
28 onReadFailed(error, fileHandle);
29 onReadFinished(fileHandle);
30 onChange('', '', event); // Clear the filename field on a failure
31 onDataChange === null || onDataChange === void 0 ? void 0 : onDataChange('');
32 });
33 }
34 else {
35 onChange(fileHandle, fileHandle.name, event);
36 }
37 }
38 dropzoneProps.onDropAccepted && dropzoneProps.onDropAccepted(acceptedFiles, event);
39 };
40 const onDropRejected = (rejectedFiles, event) => {
41 if (rejectedFiles.length > 0) {
42 onChange('', rejectedFiles[0].name, event);
43 }
44 dropzoneProps.onDropRejected && dropzoneProps.onDropRejected(rejectedFiles, event);
45 };
46 const fileInputRef = React.useRef();
47 const setFileValue = (filename) => {
48 fileInputRef.current.value = filename;
49 };
50 const onClearButtonClick = (event) => {
51 onChange('', '', event);
52 onClearClick === null || onClearClick === void 0 ? void 0 : onClearClick(event);
53 setFileValue(null);
54 };
55 return (React.createElement(react_dropzone_1.default, Object.assign({ multiple: false }, dropzoneProps, { onDropAccepted: onDropAccepted, onDropRejected: onDropRejected }), ({ getRootProps, getInputProps, isDragActive, open }) => {
56 const oldInputProps = getInputProps();
57 const inputProps = Object.assign(Object.assign({}, oldInputProps), { onChange: (e) => tslib_1.__awaiter(void 0, void 0, void 0, function* () {
58 var _a;
59 (_a = oldInputProps.onChange) === null || _a === void 0 ? void 0 : _a.call(oldInputProps, e);
60 const files = yield file_selector_1.fromEvent(e.nativeEvent);
61 if (files.length === 1) {
62 onFileInputChange === null || onFileInputChange === void 0 ? void 0 : onFileInputChange(e, files[0]);
63 }
64 }) });
65 return (React.createElement(FileUploadField_1.FileUploadField, Object.assign({}, getRootProps(Object.assign(Object.assign({}, props), { refKey: 'containerRef', onClick: event => event.preventDefault() })), { tabIndex: null, id: id, type: type, filename: filename, value: value, onChange: onChange, isDragActive: isDragActive, onBrowseButtonClick: open, onClearButtonClick: onClearButtonClick, onTextAreaClick: onClick, onTextChange: onTextChange }),
66 React.createElement("input", Object.assign({}, inputProps, { ref: input => {
67 fileInputRef.current = input;
68 inputProps.ref(input);
69 } })),
70 children));
71 }));
72};
73exports.FileUpload = FileUpload;
74exports.FileUpload.displayName = 'FileUpload';
75//# sourceMappingURL=FileUpload.js.map
\No newline at end of file