UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

120 lines (119 loc) • 12.4 kB
"use strict"; 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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"}