payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
120 lines (119 loc) • 12.4 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "Dropzone", {
enumerable: true,
get: function() {
return Dropzone;
}
});
const _react = /*#__PURE__*/ _interop_require_default(require("react"));
const _reacti18next = require("react-i18next");
const _Button = /*#__PURE__*/ _interop_require_default(require("../Button"));
require("./index.scss");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
const handleDragOver = (e)=>{
e.preventDefault();
e.stopPropagation();
};
const baseClass = 'dropzone';
const Dropzone = ({ onChange, className, mimeTypes })=>{
const dropRef = _react.default.useRef(null);
const [dragging, setDragging] = _react.default.useState(false);
const inputRef = _react.default.useRef(null);
const { t } = (0, _reacti18next.useTranslation)([
'upload',
'general'
]);
const handlePaste = _react.default.useCallback((e)=>{
e.preventDefault();
e.stopPropagation();
if (e.clipboardData.files && e.clipboardData.files.length > 0) {
onChange(e.clipboardData.files);
}
}, [
onChange
]);
const handleDragEnter = _react.default.useCallback((e)=>{
e.preventDefault();
e.stopPropagation();
setDragging(true);
}, []);
const handleDragLeave = _react.default.useCallback((e)=>{
e.preventDefault();
e.stopPropagation();
setDragging(false);
}, []);
const handleDrop = _react.default.useCallback((e)=>{
e.preventDefault();
e.stopPropagation();
setDragging(false);
if (e.dataTransfer.files && e.dataTransfer.files.length > 0) {
onChange(e.dataTransfer.files);
setDragging(false);
e.dataTransfer.clearData();
}
}, [
onChange
]);
const handleFileSelection = _react.default.useCallback((e)=>{
if (e.target.files && e.target.files.length > 0) {
onChange(e.target.files);
}
}, [
onChange
]);
_react.default.useEffect(()=>{
const div = dropRef.current;
if (div) {
div.addEventListener('dragenter', handleDragEnter);
div.addEventListener('dragleave', handleDragLeave);
div.addEventListener('dragover', handleDragOver);
div.addEventListener('drop', handleDrop);
div.addEventListener('paste', handlePaste);
return ()=>{
div.removeEventListener('dragenter', handleDragEnter);
div.removeEventListener('dragleave', handleDragLeave);
div.removeEventListener('dragover', handleDragOver);
div.removeEventListener('drop', handleDrop);
div.removeEventListener('paste', handlePaste);
};
}
return ()=>null;
}, [
handleDragEnter,
handleDragLeave,
handleDrop,
handlePaste
]);
const classes = [
baseClass,
className,
dragging ? 'dragging' : ''
].filter(Boolean).join(' ');
return /*#__PURE__*/ _react.default.createElement("div", {
ref: dropRef,
className: classes
}, /*#__PURE__*/ _react.default.createElement(_Button.default, {
size: "small",
buttonStyle: "secondary",
onClick: ()=>{
inputRef.current.click();
},
className: `${baseClass}__file-button`
}, t('selectFile')), /*#__PURE__*/ _react.default.createElement("input", {
ref: inputRef,
type: "file",
accept: mimeTypes?.join(','),
onChange: handleFileSelection,
className: `${baseClass}__hidden-input`
}), /*#__PURE__*/ _react.default.createElement("p", {
className: `${baseClass}__label`
}, t('general:or'), " ", t('dragAndDrop')));
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/Dropzone/index.tsx"],"sourcesContent":["import React from 'react'\nimport { useTranslation } from 'react-i18next'\nimport Button from '../Button'\n\nimport './index.scss'\n\nconst handleDragOver = (e: DragEvent) => {\n  e.preventDefault()\n  e.stopPropagation()\n}\n\nconst baseClass = 'dropzone'\n\ntype Props = {\n  onChange: (e: FileList) => void\n  className?: string\n  mimeTypes?: string[]\n}\n\nexport const Dropzone: React.FC<Props> = ({ onChange, className, mimeTypes }) => {\n  const dropRef = React.useRef<HTMLDivElement>(null)\n  const [dragging, setDragging] = React.useState(false)\n  const inputRef = React.useRef(null)\n\n  const { t } = useTranslation(['upload', 'general'])\n\n  const handlePaste = React.useCallback(\n    (e: ClipboardEvent) => {\n      e.preventDefault()\n      e.stopPropagation()\n\n      if (e.clipboardData.files && e.clipboardData.files.length > 0) {\n        onChange(e.clipboardData.files)\n      }\n    },\n    [onChange],\n  )\n\n  const handleDragEnter = React.useCallback((e: DragEvent) => {\n    e.preventDefault()\n    e.stopPropagation()\n    setDragging(true)\n  }, [])\n\n  const handleDragLeave = React.useCallback((e: DragEvent) => {\n    e.preventDefault()\n    e.stopPropagation()\n    setDragging(false)\n  }, [])\n\n  const handleDrop = React.useCallback(\n    (e: DragEvent) => {\n      e.preventDefault()\n      e.stopPropagation()\n      setDragging(false)\n\n      if (e.dataTransfer.files && e.dataTransfer.files.length > 0) {\n        onChange(e.dataTransfer.files)\n        setDragging(false)\n\n        e.dataTransfer.clearData()\n      }\n    },\n    [onChange],\n  )\n\n  const handleFileSelection = React.useCallback(\n    (e: React.ChangeEvent<HTMLInputElement>) => {\n      if (e.target.files && e.target.files.length > 0) {\n        onChange(e.target.files)\n      }\n    },\n    [onChange],\n  )\n\n  React.useEffect(() => {\n    const div = dropRef.current\n\n    if (div) {\n      div.addEventListener('dragenter', handleDragEnter)\n      div.addEventListener('dragleave', handleDragLeave)\n      div.addEventListener('dragover', handleDragOver)\n      div.addEventListener('drop', handleDrop)\n      div.addEventListener('paste', handlePaste)\n\n      return () => {\n        div.removeEventListener('dragenter', handleDragEnter)\n        div.removeEventListener('dragleave', handleDragLeave)\n        div.removeEventListener('dragover', handleDragOver)\n        div.removeEventListener('drop', handleDrop)\n        div.removeEventListener('paste', handlePaste)\n      }\n    }\n\n    return () => null\n  }, [handleDragEnter, handleDragLeave, handleDrop, handlePaste])\n\n  const classes = [baseClass, className, dragging ? 'dragging' : ''].filter(Boolean).join(' ')\n\n  return (\n    <div ref={dropRef} className={classes}>\n      <Button\n        size=\"small\"\n        buttonStyle=\"secondary\"\n        onClick={() => {\n          inputRef.current.click()\n        }}\n        className={`${baseClass}__file-button`}\n      >\n        {t('selectFile')}\n      </Button>\n\n      <input\n        ref={inputRef}\n        type=\"file\"\n        accept={mimeTypes?.join(',')}\n        onChange={handleFileSelection}\n        className={`${baseClass}__hidden-input`}\n      />\n\n      <p className={`${baseClass}__label`}>\n        {t('general:or')} {t('dragAndDrop')}\n      </p>\n    </div>\n  )\n}\n"],"names":["Dropzone","handleDragOver","e","preventDefault","stopPropagation","baseClass","onChange","className","mimeTypes","dropRef","React","useRef","dragging","setDragging","useState","inputRef","t","useTranslation","handlePaste","useCallback","clipboardData","files","length","handleDragEnter","handleDragLeave","handleDrop","dataTransfer","clearData","handleFileSelection","target","useEffect","div","current","addEventListener","removeEventListener","classes","filter","Boolean","join","ref","Button","size","buttonStyle","onClick","click","input","type","accept","p"],"mappings":"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"}