kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
181 lines (174 loc) • 28.2 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _react = _interopRequireWildcard(require("react"));
var _window = _interopRequireDefault(require("global/window"));
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
// SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
/**
* Copied from https://github.com/sarink/react-file-drop
* For React 16.8 compatibility
*/
var isIE = function isIE() {
return _window["default"] && _window["default"].navigator && ((_window["default"].navigator.userAgent || []).includes('MSIE') || (_window["default"].navigator.appVersion || []).includes('Trident/'));
};
var eventHasFiles = function eventHasFiles(event) {
// In most browsers this is an array, but in IE11 it's an Object :(
var hasFiles = false;
if (event.dataTransfer) {
var types = event.dataTransfer.types;
for (var keyOrIndex in types) {
if (types[keyOrIndex] === 'Files') {
hasFiles = true;
break;
}
}
}
return hasFiles;
};
var FileDrop = function FileDrop(_ref) {
var _ref$dropEffect = _ref.dropEffect,
dropEffect = _ref$dropEffect === void 0 ? 'copy' : _ref$dropEffect,
_ref$frame = _ref.frame,
frame = _ref$frame === void 0 ? _window["default"] ? _window["default"].document : undefined : _ref$frame,
_ref$className = _ref.className,
className = _ref$className === void 0 ? 'file-drop' : _ref$className,
_ref$targetClassName = _ref.targetClassName,
targetClassName = _ref$targetClassName === void 0 ? 'file-drop-target' : _ref$targetClassName,
_ref$draggingOverFram = _ref.draggingOverFrameClassName,
draggingOverFrameClassName = _ref$draggingOverFram === void 0 ? 'file-drop-dragging-over-frame' : _ref$draggingOverFram,
_ref$draggingOverTarg = _ref.draggingOverTargetClassName,
draggingOverTargetClassName = _ref$draggingOverTarg === void 0 ? 'file-drop-dragging-over-target' : _ref$draggingOverTarg,
onDragOver = _ref.onDragOver,
onDragLeave = _ref.onDragLeave,
onDrop = _ref.onDrop,
onFrameDragEnter = _ref.onFrameDragEnter,
onFrameDragLeave = _ref.onFrameDragLeave,
onFrameDrop = _ref.onFrameDrop,
children = _ref.children;
var _useState = (0, _react.useState)(false),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
draggingOverTarget = _useState2[0],
setDraggingOverTarget = _useState2[1];
var _useState3 = (0, _react.useState)(false),
_useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
draggingOverFrame = _useState4[0],
setDraggingOverFrame = _useState4[1];
var _useState5 = (0, _react.useState)(0),
_useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
frameDragCounter = _useState6[0],
setFrameDragCounter = _useState6[1];
var prevFrame = (0, _react.useRef)(frame);
(0, _react.useEffect)(function () {
// componentDidMount
startFrameListeners(frame);
resetDragging();
_window["default"].addEventListener('dragover', handleWindowDragOverOrDrop);
_window["default"].addEventListener('drop', handleWindowDragOverOrDrop);
return function () {
// componentWillUnmount
stopFrameListeners(frame);
_window["default"].removeEventListener('dragover', handleWindowDragOverOrDrop);
_window["default"].removeEventListener('drop', handleWindowDragOverOrDrop);
};
// eslint-disable-next-line react-hooks/exhaustive-deps
}, []);
var resetDragging = (0, _react.useCallback)(function () {
setFrameDragCounter(0);
setDraggingOverTarget(false);
setDraggingOverFrame(false);
}, []);
var handleWindowDragOverOrDrop = (0, _react.useCallback)(function (event) {
// This prevents the browser from trying to load whatever file the user dropped on the window
event.preventDefault();
}, []);
var handleFrameDrag = (0, _react.useCallback)(function (event) {
// Only allow dragging of files
if (!eventHasFiles(event)) return;
// We are listening for events on the 'frame', so every time the user drags over any element in the frame's tree,
// the event bubbles up to the frame. By keeping count of how many "dragenters" we get, we can tell if they are still
// "draggingOverFrame" (b/c you get one "dragenter" initially, and one "dragenter"/one "dragleave" for every bubble)
// This is far better than a "dragover" handler, which would be calling `setState` continuously.
var newDragCounterValue = frameDragCounter + (event.type === 'dragenter' ? 1 : -1);
setFrameDragCounter(newDragCounterValue);
if (newDragCounterValue === 1) {
setDraggingOverFrame(true);
if (onFrameDragEnter) onFrameDragEnter(event);
return;
}
if (newDragCounterValue === 0) {
setDraggingOverFrame(false);
if (onFrameDragLeave) onFrameDragLeave(event);
return;
}
}, [frameDragCounter, setDraggingOverFrame, onFrameDragEnter, onFrameDragLeave]);
var handleFrameDrop = (0, _react.useCallback)(function (event) {
event.preventDefault();
if (!draggingOverTarget) {
resetDragging();
if (onFrameDrop) onFrameDrop(event);
}
}, [onFrameDrop, draggingOverTarget, resetDragging]);
var handleDragOver = (0, _react.useCallback)(function (event) {
if (eventHasFiles(event)) {
setDraggingOverTarget(true);
if (!isIE() && dropEffect) event.dataTransfer.dropEffect = dropEffect;
if (onDragOver) onDragOver(event);
}
}, [dropEffect, onDragOver]);
var handleDragLeave = (0, _react.useCallback)(function (event) {
setDraggingOverTarget(false);
if (onDragLeave) onDragLeave(event);
}, [onDragLeave]);
var handleDrop = (0, _react.useCallback)(function (event) {
if (onDrop && eventHasFiles(event)) {
var files = event.dataTransfer ? event.dataTransfer.files : null;
onDrop(files, event);
}
resetDragging();
}, [onDrop, resetDragging]);
var stopFrameListeners = (0, _react.useCallback)(function (frame) {
if (frame) {
frame.removeEventListener('dragenter', handleFrameDrag);
frame.removeEventListener('dragleave', handleFrameDrag);
frame.removeEventListener('drop', handleFrameDrop);
}
}, [handleFrameDrag, handleFrameDrop]);
var startFrameListeners = (0, _react.useCallback)(function (frame) {
if (frame) {
frame.addEventListener('dragenter', handleFrameDrag);
frame.addEventListener('dragleave', handleFrameDrag);
frame.addEventListener('drop', handleFrameDrop);
}
}, [handleFrameDrag, handleFrameDrop]);
(0, _react.useEffect)(function () {
// componentDidUpdate
if (prevFrame.current !== frame) {
resetDragging();
stopFrameListeners(prevFrame.current);
startFrameListeners(frame);
prevFrame.current = frame;
}
}, [frame, resetDragging, stopFrameListeners, startFrameListeners]);
// Render
var fileDropTargetClassName = targetClassName;
if (draggingOverFrame) fileDropTargetClassName += " ".concat(draggingOverFrameClassName);
if (draggingOverTarget) fileDropTargetClassName += " ".concat(draggingOverTargetClassName);
return /*#__PURE__*/_react["default"].createElement("div", {
className: className,
onDragOver: handleDragOver,
onDragLeave: handleDragLeave,
onDrop: handleDrop
}, /*#__PURE__*/_react["default"].createElement("div", {
className: fileDropTargetClassName
}, children));
};
var _default = exports["default"] = FileDrop;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_window","_interopRequireDefault","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","isIE","Window","navigator","userAgent","includes","appVersion","eventHasFiles","event","hasFiles","dataTransfer","types","keyOrIndex","FileDrop","_ref","_ref$dropEffect","dropEffect","_ref$frame","frame","document","undefined","_ref$className","className","_ref$targetClassName","targetClassName","_ref$draggingOverFram","draggingOverFrameClassName","_ref$draggingOverTarg","draggingOverTargetClassName","onDragOver","onDragLeave","onDrop","onFrameDragEnter","onFrameDragLeave","onFrameDrop","children","_useState","useState","_useState2","_slicedToArray2","draggingOverTarget","setDraggingOverTarget","_useState3","_useState4","draggingOverFrame","setDraggingOverFrame","_useState5","_useState6","frameDragCounter","setFrameDragCounter","prevFrame","useRef","useEffect","startFrameListeners","resetDragging","addEventListener","handleWindowDragOverOrDrop","stopFrameListeners","removeEventListener","useCallback","preventDefault","handleFrameDrag","newDragCounterValue","type","handleFrameDrop","handleDragOver","handleDragLeave","handleDrop","files","current","fileDropTargetClassName","concat","createElement","_default","exports"],"sources":["../../../src/common/file-uploader/file-drop.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\n/**\n * Copied from https://github.com/sarink/react-file-drop\n * For React 16.8 compatibility\n */\nimport React, {ReactNode, useCallback, useEffect, useState, useRef} from 'react';\nimport Window from 'global/window';\n\nconst isIE = () =>\n  Window &&\n  Window.navigator &&\n  ((Window.navigator.userAgent || []).includes('MSIE') ||\n    (Window.navigator.appVersion || []).includes('Trident/'));\n\nconst eventHasFiles = event => {\n  // In most browsers this is an array, but in IE11 it's an Object :(\n\n  let hasFiles = false;\n  if (event.dataTransfer) {\n    const types = event.dataTransfer.types;\n    for (const keyOrIndex in types) {\n      if (types[keyOrIndex] === 'Files') {\n        hasFiles = true;\n        break;\n      }\n    }\n  }\n  return hasFiles;\n};\n\nexport type FileDropProps = {\n  dropEffect?: 'copy' | 'move' | 'link' | 'none';\n  frame?: typeof document | typeof Window | HTMLElement;\n  className?: string;\n  targetClassName?: string;\n  draggingOverFrameClassName?: string;\n  draggingOverTargetClassName?: string;\n  onDragOver?: (event: any) => void;\n  onDragLeave?: (event: any) => void;\n  onDrop?: (fileList: FileList, event: any) => void;\n  onFrameDragEnter?: (event: any) => void;\n  onFrameDragLeave?: (event: any) => void;\n  onFrameDrop?: (event: any) => void;\n  children?: ReactNode;\n};\n\nconst FileDrop = ({\n  dropEffect = 'copy',\n  frame = Window ? Window.document : undefined,\n  className = 'file-drop',\n  targetClassName = 'file-drop-target',\n  draggingOverFrameClassName = 'file-drop-dragging-over-frame',\n  draggingOverTargetClassName = 'file-drop-dragging-over-target',\n  onDragOver,\n  onDragLeave,\n  onDrop,\n  onFrameDragEnter,\n  onFrameDragLeave,\n  onFrameDrop,\n  children\n}: FileDropProps) => {\n  const [draggingOverTarget, setDraggingOverTarget] = useState(false);\n  const [draggingOverFrame, setDraggingOverFrame] = useState(false);\n  const [frameDragCounter, setFrameDragCounter] = useState(0);\n\n  const prevFrame = useRef(frame);\n\n  useEffect(() => {\n    // componentDidMount\n    startFrameListeners(frame);\n    resetDragging();\n    Window.addEventListener('dragover', handleWindowDragOverOrDrop);\n    Window.addEventListener('drop', handleWindowDragOverOrDrop);\n\n    return () => {\n      // componentWillUnmount\n      stopFrameListeners(frame);\n      Window.removeEventListener('dragover', handleWindowDragOverOrDrop);\n      Window.removeEventListener('drop', handleWindowDragOverOrDrop);\n    };\n\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, []);\n\n  const resetDragging = useCallback(() => {\n    setFrameDragCounter(0);\n    setDraggingOverTarget(false);\n    setDraggingOverFrame(false);\n  }, []);\n\n  const handleWindowDragOverOrDrop = useCallback(event => {\n    // This prevents the browser from trying to load whatever file the user dropped on the window\n    event.preventDefault();\n  }, []);\n\n  const handleFrameDrag = useCallback(\n    event => {\n      // Only allow dragging of files\n      if (!eventHasFiles(event)) return;\n\n      // We are listening for events on the 'frame', so every time the user drags over any element in the frame's tree,\n      // the event bubbles up to the frame. By keeping count of how many \"dragenters\" we get, we can tell if they are still\n      // \"draggingOverFrame\" (b/c you get one \"dragenter\" initially, and one \"dragenter\"/one \"dragleave\" for every bubble)\n      // This is far better than a \"dragover\" handler, which would be calling `setState` continuously.\n      const newDragCounterValue = frameDragCounter + (event.type === 'dragenter' ? 1 : -1);\n      setFrameDragCounter(newDragCounterValue);\n\n      if (newDragCounterValue === 1) {\n        setDraggingOverFrame(true);\n        if (onFrameDragEnter) onFrameDragEnter(event);\n        return;\n      }\n\n      if (newDragCounterValue === 0) {\n        setDraggingOverFrame(false);\n        if (onFrameDragLeave) onFrameDragLeave(event);\n        return;\n      }\n    },\n    [frameDragCounter, setDraggingOverFrame, onFrameDragEnter, onFrameDragLeave]\n  );\n\n  const handleFrameDrop = useCallback(\n    event => {\n      event.preventDefault();\n      if (!draggingOverTarget) {\n        resetDragging();\n        if (onFrameDrop) onFrameDrop(event);\n      }\n    },\n    [onFrameDrop, draggingOverTarget, resetDragging]\n  );\n\n  const handleDragOver = useCallback(\n    event => {\n      if (eventHasFiles(event)) {\n        setDraggingOverTarget(true);\n        if (!isIE() && dropEffect) event.dataTransfer.dropEffect = dropEffect;\n        if (onDragOver) onDragOver(event);\n      }\n    },\n    [dropEffect, onDragOver]\n  );\n\n  const handleDragLeave = useCallback(\n    event => {\n      setDraggingOverTarget(false);\n\n      if (onDragLeave) onDragLeave(event);\n    },\n    [onDragLeave]\n  );\n\n  const handleDrop = useCallback(\n    event => {\n      if (onDrop && eventHasFiles(event)) {\n        const files = event.dataTransfer ? event.dataTransfer.files : null;\n        onDrop(files, event);\n      }\n      resetDragging();\n    },\n    [onDrop, resetDragging]\n  );\n\n  const stopFrameListeners = useCallback(\n    frame => {\n      if (frame) {\n        frame.removeEventListener('dragenter', handleFrameDrag);\n        frame.removeEventListener('dragleave', handleFrameDrag);\n        frame.removeEventListener('drop', handleFrameDrop);\n      }\n    },\n    [handleFrameDrag, handleFrameDrop]\n  );\n\n  const startFrameListeners = useCallback(\n    frame => {\n      if (frame) {\n        frame.addEventListener('dragenter', handleFrameDrag);\n        frame.addEventListener('dragleave', handleFrameDrag);\n        frame.addEventListener('drop', handleFrameDrop);\n      }\n    },\n    [handleFrameDrag, handleFrameDrop]\n  );\n\n  useEffect(() => {\n    // componentDidUpdate\n    if (prevFrame.current !== frame) {\n      resetDragging();\n      stopFrameListeners(prevFrame.current);\n      startFrameListeners(frame);\n\n      prevFrame.current = frame;\n    }\n  }, [frame, resetDragging, stopFrameListeners, startFrameListeners]);\n\n  // Render\n  let fileDropTargetClassName = targetClassName;\n  if (draggingOverFrame) fileDropTargetClassName += ` ${draggingOverFrameClassName}`;\n  if (draggingOverTarget) fileDropTargetClassName += ` ${draggingOverTargetClassName}`;\n\n  return (\n    <div\n      className={className}\n      onDragOver={handleDragOver}\n      onDragLeave={handleDragLeave}\n      onDrop={handleDrop}\n    >\n      <div className={fileDropTargetClassName}>{children}</div>\n    </div>\n  );\n};\n\nexport default FileDrop;\n"],"mappings":"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","ignoreList":[]}
;