Socket
Socket
Sign inDemoInstall

@uiw/react-drag-event-interactive

Package Overview
Dependencies
Maintainers
1
Versions
81
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@uiw/react-drag-event-interactive - npm Package Compare versions

Comparing version 0.0.18 to 0.0.19

1

lib/cjs/index.d.ts

@@ -5,2 +5,3 @@ import React from 'react';

export interface InteractiveProps extends React.HTMLAttributes<HTMLDivElement> {
prefixCls?: string;
onMove?: (interaction: Interaction, event: MouseEvent | TouchEvent) => void;

@@ -7,0 +8,0 @@ onDown?: (offset: Interaction, event: MouseEvent | TouchEvent) => void;

@@ -15,2 +15,4 @@ "use strict";

var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));

@@ -35,6 +37,9 @@

});
var _excluded = ["onMove", "onDown"];
var _excluded = ["prefixCls", "className", "onMove", "onDown"];
var _default = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
var onMove = props.onMove,
var _props$prefixCls = props.prefixCls,
prefixCls = _props$prefixCls === void 0 ? 'w-color-interactive' : _props$prefixCls,
className = props.className,
onMove = props.onMove,
onDown = props.onDown,

@@ -96,3 +101,8 @@ reset = (0, _objectWithoutProperties2.default)(props, _excluded);

return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({}, reset, {
className: [prefixCls, className || ''].filter(Boolean).join(' '),
style: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, reset.style), {}, {
touchAction: 'none'
}),
ref: container,
tabIndex: 0,
onMouseDown: handleMoveStart,

@@ -104,2 +114,2 @@ onTouchStart: handleMoveStart

exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9pbmRleC50c3giXSwibmFtZXMiOlsiUmVhY3QiLCJmb3J3YXJkUmVmIiwicHJvcHMiLCJyZWYiLCJvbk1vdmUiLCJvbkRvd24iLCJyZXNldCIsImNvbnRhaW5lciIsImhhc1RvdWNoZWQiLCJpc0RyYWdnaW5nIiwic2V0RHJhZ2dpbmciLCJvbk1vdmVDYWxsYmFjayIsIm9uS2V5Q2FsbGJhY2siLCJpc1ZhbGlkIiwiZXZlbnQiLCJjdXJyZW50IiwiaGFuZGxlTW92ZSIsImlzRG93biIsInRvdWNoZXMiLCJsZW5ndGgiLCJidXR0b25zIiwiaGFuZGxlTW92ZUVuZCIsInRvZ2dsZURvY3VtZW50RXZlbnRzIiwic3RhdGUiLCJ0b2dnbGVFdmVudCIsIndpbmRvdyIsImFkZEV2ZW50TGlzdGVuZXIiLCJyZW1vdmVFdmVudExpc3RlbmVyIiwiaGFuZGxlTW92ZVN0YXJ0IiwibmF0aXZlRXZlbnQiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUVBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7Ozs0QkFPZUEsZUFBTUMsVUFBTixDQUFtRCxVQUFDQyxLQUFELEVBQVFDLEdBQVIsRUFBZ0I7QUFDaEYsTUFBUUMsTUFBUixHQUFxQ0YsS0FBckMsQ0FBUUUsTUFBUjtBQUFBLE1BQWdCQyxNQUFoQixHQUFxQ0gsS0FBckMsQ0FBZ0JHLE1BQWhCO0FBQUEsTUFBMkJDLEtBQTNCLDBDQUFxQ0osS0FBckM7QUFDQSxNQUFNSyxTQUFTLEdBQUcsbUJBQXVCLElBQXZCLENBQWxCO0FBQ0EsTUFBTUMsVUFBVSxHQUFHLG1CQUFPLEtBQVAsQ0FBbkI7O0FBQ0Esa0JBQWtDLHFCQUFTLEtBQVQsQ0FBbEM7QUFBQTtBQUFBLE1BQU9DLFVBQVA7QUFBQSxNQUFtQkMsV0FBbkI7O0FBQ0EsTUFBTUMsY0FBYyxHQUFHLDZCQUF1RFAsTUFBdkQsQ0FBdkI7QUFDQSxNQUFNUSxhQUFhLEdB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Y2ssIHVzZUVmZmVjdCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGlzVG91Y2gsIHByZXZlbnREZWZhdWx0TW92ZSwgZ2V0UmVsYXRpdmVQb3NpdGlvbiwgSW50ZXJhY3Rpb24sIHVzZUV2ZW50Q2FsbGJhY2sgfSBmcm9tICcuL3V0aWxzJztcblxuZXhwb3J0ICogZnJvbSAnLi91dGlscyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW50ZXJhY3RpdmVQcm9wcyBleHRlbmRzIFJlYWN0LkhUTUxBdHRyaWJ1dGVzPEhUTUxEaXZFbGVtZW50PiB7XG4gIG9uTW92ZT86IChpbnRlcmFjdGlvbjogSW50ZXJhY3Rpb24sIGV2ZW50OiBNb3VzZUV2ZW50IHwgVG91Y2hFdmVudCkgPT4gdm9pZDtcbiAgb25Eb3duPzogKG9mZnNldDogSW50ZXJhY3Rpb24sIGV2ZW50OiBNb3VzZUV2ZW50IHwgVG91Y2hFdmVudCkgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGRlZmF1bHQgUmVhY3QuZm9yd2FyZFJlZjxIVE1MRGl2RWxlbWVudCwgSW50ZXJhY3RpdmVQcm9wcz4oKHByb3BzLCByZWYpID0+IHtcbiAgY29uc3QgeyBvbk1vdmUsIG9uRG93biwgLi4ucmVzZXQgfSA9IHByb3BzO1xuICBjb25zdCBjb250YWluZXIgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQ+KG51bGwpO1xuICBjb25zdCBoYXNUb3VjaGVkID0gdXNlUmVmKGZhbHNlKTtcbiAgY29uc3QgW2lzRHJhZ2dpbmcsIHNldERyYWdnaW5nXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3Qgb25Nb3ZlQ2FsbGJhY2sgPSB1c2VFdmVudENhbGxiYWNrPEludGVyYWN0aW9uLCBNb3VzZUV2ZW50IHwgVG91Y2hFdmVudD4ob25Nb3ZlKTtcbiAgY29uc3Qgb25LZXlDYWxsYmFjayA9IHVzZUV2ZW50Q2FsbGJhY2s8SW50ZXJhY3Rpb24sIE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50PihvbkRvd24pO1xuXG4gIC8vIFByZXZlbnQgbW9iaWxlIGJyb3dzZXJzIGZyb20gaGFuZGxpbmcgbW91c2UgZXZlbnRzIChjb25mbGljdGluZyB3aXRoIHRvdWNoIG9uZXMpLlxuICAvLyBJZiB3ZSBkZXRlY3RlZCBhIHRvdWNoIGludGVyYWN0aW9uIGJlZm9yZSwgd2UgcHJlZmVyIHJlYWN0aW5nIHRvIHRvdWNoIGV2ZW50cyBvbmx5LlxuICBjb25zdCBpc1ZhbGlkID0gKGV2ZW50OiBNb3VzZUV2ZW50IHwgVG91Y2hFdmVudCk6IGJvb2xlYW4gPT4ge1xuICAgIGlmIChoYXNUb3VjaGVkLmN1cnJlbnQgJiYgIWlzVG91Y2goZXZlbnQpKSByZXR1cm4gZmFsc2U7XG4gICAgaWYgKCFoYXNUb3VjaGVkLmN1cnJlbnQpIGhhc1RvdWNoZWQuY3VycmVudCA9IGlzVG91Y2goZXZlbnQpO1xuICAgIHJldHVybiB0cnVlO1xuICB9O1xuXG4gIGNvbnN0IGhhbmRsZU1vdmUgPSB1c2VDYWxsYmFjayhcbiAgICAoZXZlbnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICBwcmV2ZW50RGVmYXVsdE1vdmUoZXZlbnQpO1xuICAgICAgLy8gSWYgdXNlciBtb3ZlcyB0aGUgcG9pbnRlciBvdXRzaWRlIG9mIHRoZSB3aW5kb3cgb3IgaWZyYW1lIGJvdW5kcyBhbmQgcmVsZWFzZSBpdCB0aGVyZSxcbiAgICAgIC8vIGBtb3VzZXVwYC9gdG91Y2hlbmRgIHdvbid0IGJlIGZpcmVkLiBJbiBvcmRlciB0byBzdG9wIHRoZSBwaWNrZXIgZnJvbSBmb2xsb3dpbmcgdGhlIGN1cnNvclxuICAgICAgLy8gYWZ0ZXIgdGhlIHVzZXIgaGFzIG1vdmVkIHRoZSBtb3VzZS9maW5nZXIgYmFjayB0byB0aGUgZG9jdW1lbnQsIHdlIGNoZWNrIGBldmVudC5idXR0b25zYFxuICAgICAgLy8gYW5kIGBldmVudC50b3VjaGVzYC4gSXQgYWxsb3dzIHVzIHRvIGRldGVjdCB0aGF0IHRoZSB1c2VyIGlzIGp1c3QgbW92aW5nIGhpcyBwb2ludGVyXG4gICAgICAvLyB3aXRob3V0IHByZXNzaW5nIGl0IGRvd25cbiAgICAgIGNvbnN0IGlzRG93biA9IGlzVG91Y2goZXZlbnQpID8gZXZlbnQudG91Y2hlcy5sZW5ndGggPiAwIDogZXZlbnQuYnV0dG9ucyA+IDA7XG5cbiAgICAgIGlmIChpc0Rvd24gJiYgY29udGFpbmVyLmN1cnJlbnQpIHtcbiAgICAgICAgb25Nb3ZlQ2FsbGJhY2sgJiYgb25Nb3ZlQ2FsbGJhY2soZ2V0UmVsYXRpdmVQb3NpdGlvbihjb250YWluZXIuY3VycmVudCEsIGV2ZW50KSwgZXZlbnQpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgc2V0RHJhZ2dpbmcoZmFsc2UpO1xuICAgICAgfVxuICAgIH0sXG4gICAgW29uTW92ZUNhbGxiYWNrXSxcbiAgKTtcblxuICBjb25zdCBoYW5kbGVNb3ZlRW5kID0gdXNlQ2FsbGJhY2soKCkgPT4gc2V0RHJhZ2dpbmcoZmFsc2UpLCBbXSk7XG5cbiAgY29uc3QgdG9nZ2xlRG9jdW1lbnRFdmVudHMgPSB1c2VDYWxsYmFjaygoc3RhdGU6IGJvb2xlYW4pID0+IHtcbiAgICBjb25zdCB0b2dnbGVFdmVudCA9IHN0YXRlID8gd2luZG93LmFkZEV2ZW50TGlzdGVuZXIgOiB3aW5kb3cucmVtb3ZlRXZlbnRMaXN0ZW5lcjtcbiAgICB0b2dnbGVFdmVudChoYXNUb3VjaGVkLmN1cnJlbnQgPyAndG91Y2htb3ZlJyA6ICdtb3VzZW1vdmUnLCBoYW5kbGVNb3ZlKTtcbiAgICB0b2dnbGVFdmVudChoYXNUb3VjaGVkLmN1cnJlbnQgPyAndG91Y2hlbmQnIDogJ21vdXNldXAnLCBoYW5kbGVNb3ZlRW5kKTtcbiAgfSwgW10pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgdG9nZ2xlRG9jdW1lbnRFdmVudHMoaXNEcmFnZ2luZyk7XG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIGlzRHJhZ2dpbmcgJiYgdG9nZ2xlRG9jdW1lbnRFdmVudHMoZmFsc2UpO1xuICAgIH07XG4gIH0sIFtpc0RyYWdnaW5nLCB0b2dnbGVEb2N1bWVudEV2ZW50c10pO1xuXG4gIGNvbnN0IGhhbmRsZU1vdmVTdGFydCA9IHVzZUNhbGxiYWNrKFxuICAgIChldmVudDogUmVhY3QuTW91c2VFdmVudCB8IFJlYWN0LlRvdWNoRXZlbnQpID0+IHtcbiAgICAgIHByZXZlbnREZWZhdWx0TW92ZShldmVudC5uYXRpdmVFdmVudCk7XG4gICAgICBpZiAoIWlzVmFsaWQoZXZlbnQubmF0aXZlRXZlbnQpKSByZXR1cm47XG4gICAgICBvbktleUNhbGxiYWNrICYmIG9uS2V5Q2FsbGJhY2soZ2V0UmVsYXRpdmVQb3NpdGlvbihjb250YWluZXIuY3VycmVudCEsIGV2ZW50Lm5hdGl2ZUV2ZW50KSwgZXZlbnQubmF0aXZlRXZlbnQpO1xuICAgICAgc2V0RHJhZ2dpbmcodHJ1ZSk7XG4gICAgfSxcbiAgICBbb25LZXlDYWxsYmFja10sXG4gICk7XG5cbiAgcmV0dXJuIDxkaXYgey4uLnJlc2V0fSByZWY9e2NvbnRhaW5lcn0gb25Nb3VzZURvd249e2hhbmRsZU1vdmVTdGFydH0gb25Ub3VjaFN0YXJ0PXtoYW5kbGVNb3ZlU3RhcnR9IC8+O1xufSk7XG4iXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["React","forwardRef","props","ref","prefixCls","className","onMove","onDown","reset","container","hasTouched","isDragging","setDragging","onMoveCallback","onKeyCallback","isValid","event","current","handleMove","isDown","touches","length","buttons","handleMoveEnd","toggleDocumentEvents","state","toggleEvent","window","addEventListener","removeEventListener","handleMoveStart","nativeEvent","filter","Boolean","join","style","touchAction"],"mappings":"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","sourcesContent":["import React, { useRef, useState, useCallback, useEffect } from 'react';\nimport { isTouch, preventDefaultMove, getRelativePosition, Interaction, useEventCallback } from './utils';\n\nexport * from './utils';\n\nexport interface InteractiveProps extends React.HTMLAttributes<HTMLDivElement> {\n  prefixCls?: string;\n  onMove?: (interaction: Interaction, event: MouseEvent | TouchEvent) => void;\n  onDown?: (offset: Interaction, event: MouseEvent | TouchEvent) => void;\n}\n\nexport default React.forwardRef<HTMLDivElement, InteractiveProps>((props, ref) => {\n  const { prefixCls = 'w-color-interactive', className, onMove, onDown, ...reset } = props;\n  const container = useRef<HTMLDivElement>(null);\n  const hasTouched = useRef(false);\n  const [isDragging, setDragging] = useState(false);\n  const onMoveCallback = useEventCallback<Interaction, MouseEvent | TouchEvent>(onMove);\n  const onKeyCallback = useEventCallback<Interaction, MouseEvent | TouchEvent>(onDown);\n\n  // Prevent mobile browsers from handling mouse events (conflicting with touch ones).\n  // If we detected a touch interaction before, we prefer reacting to touch events only.\n  const isValid = (event: MouseEvent | TouchEvent): boolean => {\n    if (hasTouched.current && !isTouch(event)) return false;\n    if (!hasTouched.current) hasTouched.current = isTouch(event);\n    return true;\n  };\n\n  const handleMove = useCallback(\n    (event: MouseEvent | TouchEvent) => {\n      preventDefaultMove(event);\n      // If user moves the pointer outside of the window or iframe bounds and release it there,\n      // `mouseup`/`touchend` won't be fired. In order to stop the picker from following the cursor\n      // after the user has moved the mouse/finger back to the document, we check `event.buttons`\n      // and `event.touches`. It allows us to detect that the user is just moving his pointer\n      // without pressing it down\n      const isDown = isTouch(event) ? event.touches.length > 0 : event.buttons > 0;\n      if (isDown && container.current) {\n        onMoveCallback && onMoveCallback(getRelativePosition(container.current!, event), event);\n      } else {\n        setDragging(false);\n      }\n    },\n    [onMoveCallback],\n  );\n\n  const handleMoveEnd = useCallback(() => setDragging(false), []);\n  const toggleDocumentEvents = useCallback((state: boolean) => {\n    const toggleEvent = state ? window.addEventListener : window.removeEventListener;\n    toggleEvent(hasTouched.current ? 'touchmove' : 'mousemove', handleMove);\n    toggleEvent(hasTouched.current ? 'touchend' : 'mouseup', handleMoveEnd);\n  }, []);\n\n  useEffect(() => {\n    toggleDocumentEvents(isDragging);\n    return () => {\n      isDragging && toggleDocumentEvents(false);\n    };\n  }, [isDragging, toggleDocumentEvents]);\n\n  const handleMoveStart = useCallback(\n    (event: React.MouseEvent | React.TouchEvent) => {\n      preventDefaultMove(event.nativeEvent);\n      if (!isValid(event.nativeEvent)) return;\n      onKeyCallback && onKeyCallback(getRelativePosition(container.current!, event.nativeEvent), event.nativeEvent);\n      setDragging(true);\n    },\n    [onKeyCallback],\n  );\n\n  return (\n    <div\n      {...reset}\n      className={[prefixCls, className || ''].filter(Boolean).join(' ')}\n      style={{\n        ...reset.style,\n        touchAction: 'none',\n      }}\n      ref={container}\n      tabIndex={0}\n      onMouseDown={handleMoveStart}\n      onTouchStart={handleMoveStart}\n    />\n  );\n});\n"]}

4

lib/cjs/utils.js

@@ -33,3 +33,3 @@ "use strict";

var preventDefaultMove = function preventDefaultMove(event) {
!isTouch(event) && event.preventDefault();
!isTouch(event) && event.preventDefault && event.preventDefault();
}; // Clamps a value between an upper and lower bound.

@@ -62,2 +62,2 @@ // We use ternary operators because it makes the minified code

exports.getRelativePosition = getRelativePosition;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy50cyJdLCJuYW1lcyI6WyJ1c2VFdmVudENhbGxiYWNrIiwiaGFuZGxlciIsImNhbGxiYWNrUmVmIiwiY3VycmVudCIsInZhbHVlIiwiZXZlbnQiLCJpc1RvdWNoIiwicHJldmVudERlZmF1bHRNb3ZlIiwicHJldmVudERlZmF1bHQiLCJjbGFtcCIsIm51bWJlciIsIm1pbiIsIm1heCIsImdldFJlbGF0aXZlUG9zaXRpb24iLCJub2RlIiwicmVjdCIsImdldEJvdW5kaW5nQ2xpZW50UmVjdCIsInBvaW50ZXIiLCJ0b3VjaGVzIiwibGVmdCIsInBhZ2VYIiwid2luZG93IiwicGFnZVhPZmZzZXQiLCJ3aWR0aCIsInRvcCIsInBhZ2VZIiwicGFnZVlPZmZzZXQiLCJoZWlnaHQiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUE7O0FBRUE7QUFDTyxTQUFTQSxnQkFBVCxDQUFnQ0MsT0FBaEMsRUFBc0c7QUFDM0csTUFBTUMsV0FBVyxHQUFHLG1CQUFPRCxPQUFQLENBQXBCO0FBRUEsd0JBQVUsWUFBTTtBQUNkQyxJQUFBQSxXQUFXLENBQUNDLE9BQVosR0FBc0JGLE9BQXRCO0FBQ0QsR0FGRDtBQUlBLFNBQU8sd0JBQVksVUFBQ0csS0FBRCxFQUFXQyxLQUFYO0FBQUEsV0FBd0JILFdBQVcsQ0FBQ0MsT0FBWixJQUF1QkQsV0FBVyxDQUFDQyxPQUFaLENBQW9CQyxLQUFwQixFQUEyQkMsS0FBM0IsQ0FBL0M7QUFBQSxHQUFaLEVBQThGLEVBQTlGLENBQVA7QUFDRCxDLENBRUQ7OztBQUNPLElBQU1DLE9BQU8sR0FBRyxTQUFWQSxPQUFVLENBQUNELEtBQUQ7QUFBQSxTQUF5RCxhQUFhQSxLQUF0RTtBQUFBLENBQWhCLEMsQ0FFUDtBQUNBO0FBQ0E7Ozs7O0FBQ08sSUFBTUUsa0JBQWtCLEdBQUcsU0FBckJBLGtCQUFxQixDQUFDRixLQUFELEVBQTBDO0FBQzFFLEdBQUNDLE9BQU8sQ0FBQ0QsS0FBRCxDQUFSLElBQW1CQSxLQUFLLENBQUNHLGNBQU4sRUFBbkI7QUFDRCxDQUZNLEMsQ0FHUDtBQUNBO0FBQ0E7Ozs7O0FBQ08sSUFBTUMsS0FBSyxHQUFHLFNBQVJBLEtBQVEsQ0FBQ0MsTUFBRCxFQUE4QztBQUFBLE1BQTdCQyxHQUE2Qix1RUFBdkIsQ0FBdUI7QUFBQSxNQUFwQkMsR0FBb0IsdUVBQWQsQ0FBYztBQUNqRSxTQUFPRixNQUFNLEdBQUdFLEdBQVQsR0FBZUEsR0FBZixHQUFxQkYsTUFBTSxHQUFHQyxHQUFULEdBQWVBLEdBQWYsR0FBcUJELE1BQWpEO0FBQ0QsQ0FGTTs7OztBQVNQO0FBQ08sSUFBTUcsbUJBQW1CLEdBQUcsU0FBdEJBLG1CQUFzQixDQUFDQyxJQUFELEVBQXVCVCxLQUF2QixFQUF1RTtBQUN4RyxNQUFNVSxJQUFJLEdBQUdELElBQUksQ0FBQ0UscUJBQUwsRUFBYixDQUR3RyxDQUd4Rzs7QUFDQSxNQUFNQyxPQUFPLEdBQUdYLE9BQU8sQ0FBQ0QsS0FBRCxDQUFQLEdBQWlCQSxLQUFLLENBQUNhLE9BQU4sQ0FBYyxDQUFkLENBQWpCLEdBQXFDYixLQUFyRDtBQUVBLFNBQU87QUFDTGMsSUFBQUEsSUFBSSxFQUFFVixLQUFLLENBQUMsQ0FBQ1EsT0FBTyxDQUFDRyxLQUFSLElBQWlCTCxJQUFJLENBQUNJLElBQUwsR0FBWUUsTUFBTSxDQUFDQyxXQUFwQyxDQUFELElBQXFEUCxJQUFJLENBQUNRLEtBQTNELENBRE47QUFFTEMsSUFBQUEsR0FBRyxFQUFFZixLQUFLLENBQUMsQ0FBQ1EsT0FBTyxDQUFDUSxLQUFSLElBQWlCVixJQUFJLENBQUNTLEdBQUwsR0FBV0gsTUFBTSxDQUFDSyxXQUFuQyxDQUFELElBQW9EWCxJQUFJLENBQUNZLE1BQTFEO0FBRkwsR0FBUDtBQUlELENBVk0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VSZWYsIHVzZUVmZmVjdCwgdXNlQ2FsbGJhY2sgfSBmcm9tICdyZWFjdCc7XG5cbi8vIFNhdmVzIGluY29taW5nIGhhbmRsZXIgdG8gdGhlIHJlZiBpbiBvcmRlciB0byBhdm9pZCBcInVzZUNhbGxiYWNrIGhlbGxcIlxuZXhwb3J0IGZ1bmN0aW9uIHVzZUV2ZW50Q2FsbGJhY2s8VCwgSz4oaGFuZGxlcj86ICh2YWx1ZTogVCwgZXZlbnQ6IEspID0+IHZvaWQpOiAodmFsdWU6IFQsIGV2ZW50OiBLKSA9PiB2b2lkIHtcbiAgY29uc3QgY2FsbGJhY2tSZWYgPSB1c2VSZWYoaGFuZGxlcik7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjYWxsYmFja1JlZi5jdXJyZW50ID0gaGFuZGxlcjtcbiAgfSk7XG5cbiAgcmV0dXJuIHVzZUNhbGxiYWNrKCh2YWx1ZTogVCwgZXZlbnQ6IEspID0+IGNhbGxiYWNrUmVmLmN1cnJlbnQgJiYgY2FsbGJhY2tSZWYuY3VycmVudCh2YWx1ZSwgZXZlbnQpLCBbXSk7XG59XG5cbi8vIENoZWNrIGlmIGFuIGV2ZW50IHdhcyB0cmlnZ2VyZWQgYnkgdG91Y2hcbmV4cG9ydCBjb25zdCBpc1RvdWNoID0gKGV2ZW50OiBNb3VzZUV2ZW50IHwgVG91Y2hFdmVudCk6IGV2ZW50IGlzIFRvdWNoRXZlbnQgPT4gJ3RvdWNoZXMnIGluIGV2ZW50O1xuXG4vLyBCcm93c2VycyBpbnRyb2R1Y2VkIGFuIGludGVydmVudGlvbiwgbWFraW5nIHRvdWNoIGV2ZW50cyBwYXNzaXZlIGJ5IGRlZmF1bHQuXG4vLyBUaGlzIHdvcmthcm91bmQgcmVtb3ZlcyBgcHJldmVudERlZmF1bHRgIGNhbGwgZnJvbSB0aGUgdG91Y2ggaGFuZGxlcnMuXG4vLyBodHRwczovL2dpdGh1Yi5jb20vZmFjZWJvb2svcmVhY3QvaXNzdWVzLzE5NjUxXG5leHBvcnQgY29uc3QgcHJldmVudERlZmF1bHRNb3ZlID0gKGV2ZW50OiBNb3VzZUV2ZW50IHwgVG91Y2hFdmVudCk6IHZvaWQgPT4ge1xuICAhaXNUb3VjaChldmVudCkgJiYgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbn07XG4vLyBDbGFtcHMgYSB2YWx1ZSBiZXR3ZWVuIGFuIHVwcGVyIGFuZCBsb3dlciBib3VuZC5cbi8vIFdlIHVzZSB0ZXJuYXJ5IG9wZXJhdG9ycyBiZWNhdXNlIGl0IG1ha2VzIHRoZSBtaW5pZmllZCBjb2RlXG4vLyAyIHRpbWVzIHNob3J0ZXIgdGhlbiBgTWF0aC5taW4oTWF0aC5tYXgoYSxiKSxjKWBcbmV4cG9ydCBjb25zdCBjbGFtcCA9IChudW1iZXI6IG51bWJlciwgbWluID0gMCwgbWF4ID0gMSk6IG51bWJlciA9PiB7XG4gIHJldHVybiBudW1iZXIgPiBtYXggPyBtYXggOiBudW1iZXIgPCBtaW4gPyBtaW4gOiBudW1iZXI7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIEludGVyYWN0aW9uIHtcbiAgbGVmdDogbnVtYmVyO1xuICB0b3A6IG51bWJlcjtcbn1cblxuLy8gUmV0dXJucyBhIHJlbGF0aXZlIHBvc2l0aW9uIG9mIHRoZSBwb2ludGVyIGluc2lkZSB0aGUgbm9kZSdzIGJvdW5kaW5nIGJveFxuZXhwb3J0IGNvbnN0IGdldFJlbGF0aXZlUG9zaXRpb24gPSAobm9kZTogSFRNTERpdkVsZW1lbnQsIGV2ZW50OiBNb3VzZUV2ZW50IHwgVG91Y2hFdmVudCk6IEludGVyYWN0aW9uID0+IHtcbiAgY29uc3QgcmVjdCA9IG5vZGUuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG5cbiAgLy8gR2V0IHVzZXIncyBwb2ludGVyIHBvc2l0aW9uIGZyb20gYHRvdWNoZXNgIGFycmF5IGlmIGl0J3MgYSBgVG91Y2hFdmVudGBcbiAgY29uc3QgcG9pbnRlciA9IGlzVG91Y2goZXZlbnQpID8gZXZlbnQudG91Y2hlc1swXSA6IChldmVudCBhcyBNb3VzZUV2ZW50KTtcblxuICByZXR1cm4ge1xuICAgIGxlZnQ6IGNsYW1wKChwb2ludGVyLnBhZ2VYIC0gKHJlY3QubGVmdCArIHdpbmRvdy5wYWdlWE9mZnNldCkpIC8gcmVjdC53aWR0aCksXG4gICAgdG9wOiBjbGFtcCgocG9pbnRlci5wYWdlWSAtIChyZWN0LnRvcCArIHdpbmRvdy5wYWdlWU9mZnNldCkpIC8gcmVjdC5oZWlnaHQpLFxuICB9O1xufTtcbiJdfQ==
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy50cyJdLCJuYW1lcyI6WyJ1c2VFdmVudENhbGxiYWNrIiwiaGFuZGxlciIsImNhbGxiYWNrUmVmIiwiY3VycmVudCIsInZhbHVlIiwiZXZlbnQiLCJpc1RvdWNoIiwicHJldmVudERlZmF1bHRNb3ZlIiwicHJldmVudERlZmF1bHQiLCJjbGFtcCIsIm51bWJlciIsIm1pbiIsIm1heCIsImdldFJlbGF0aXZlUG9zaXRpb24iLCJub2RlIiwicmVjdCIsImdldEJvdW5kaW5nQ2xpZW50UmVjdCIsInBvaW50ZXIiLCJ0b3VjaGVzIiwibGVmdCIsInBhZ2VYIiwid2luZG93IiwicGFnZVhPZmZzZXQiLCJ3aWR0aCIsInRvcCIsInBhZ2VZIiwicGFnZVlPZmZzZXQiLCJoZWlnaHQiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUE7O0FBRUE7QUFDTyxTQUFTQSxnQkFBVCxDQUFnQ0MsT0FBaEMsRUFBc0c7QUFDM0csTUFBTUMsV0FBVyxHQUFHLG1CQUFPRCxPQUFQLENBQXBCO0FBRUEsd0JBQVUsWUFBTTtBQUNkQyxJQUFBQSxXQUFXLENBQUNDLE9BQVosR0FBc0JGLE9BQXRCO0FBQ0QsR0FGRDtBQUlBLFNBQU8sd0JBQVksVUFBQ0csS0FBRCxFQUFXQyxLQUFYO0FBQUEsV0FBd0JILFdBQVcsQ0FBQ0MsT0FBWixJQUF1QkQsV0FBVyxDQUFDQyxPQUFaLENBQW9CQyxLQUFwQixFQUEyQkMsS0FBM0IsQ0FBL0M7QUFBQSxHQUFaLEVBQThGLEVBQTlGLENBQVA7QUFDRCxDLENBRUQ7OztBQUNPLElBQU1DLE9BQU8sR0FBRyxTQUFWQSxPQUFVLENBQUNELEtBQUQ7QUFBQSxTQUF5RCxhQUFhQSxLQUF0RTtBQUFBLENBQWhCLEMsQ0FFUDtBQUNBO0FBQ0E7Ozs7O0FBQ08sSUFBTUUsa0JBQWtCLEdBQUcsU0FBckJBLGtCQUFxQixDQUFDRixLQUFELEVBQTBDO0FBQzFFLEdBQUNDLE9BQU8sQ0FBQ0QsS0FBRCxDQUFSLElBQW1CQSxLQUFLLENBQUNHLGNBQXpCLElBQTJDSCxLQUFLLENBQUNHLGNBQU4sRUFBM0M7QUFDRCxDQUZNLEMsQ0FHUDtBQUNBO0FBQ0E7Ozs7O0FBQ08sSUFBTUMsS0FBSyxHQUFHLFNBQVJBLEtBQVEsQ0FBQ0MsTUFBRCxFQUE4QztBQUFBLE1BQTdCQyxHQUE2Qix1RUFBdkIsQ0FBdUI7QUFBQSxNQUFwQkMsR0FBb0IsdUVBQWQsQ0FBYztBQUNqRSxTQUFPRixNQUFNLEdBQUdFLEdBQVQsR0FBZUEsR0FBZixHQUFxQkYsTUFBTSxHQUFHQyxHQUFULEdBQWVBLEdBQWYsR0FBcUJELE1BQWpEO0FBQ0QsQ0FGTTs7OztBQVNQO0FBQ08sSUFBTUcsbUJBQW1CLEdBQUcsU0FBdEJBLG1CQUFzQixDQUFDQyxJQUFELEVBQXVCVCxLQUF2QixFQUF1RTtBQUN4RyxNQUFNVSxJQUFJLEdBQUdELElBQUksQ0FBQ0UscUJBQUwsRUFBYixDQUR3RyxDQUd4Rzs7QUFDQSxNQUFNQyxPQUFPLEdBQUdYLE9BQU8sQ0FBQ0QsS0FBRCxDQUFQLEdBQWlCQSxLQUFLLENBQUNhLE9BQU4sQ0FBYyxDQUFkLENBQWpCLEdBQXFDYixLQUFyRDtBQUVBLFNBQU87QUFDTGMsSUFBQUEsSUFBSSxFQUFFVixLQUFLLENBQUMsQ0FBQ1EsT0FBTyxDQUFDRyxLQUFSLElBQWlCTCxJQUFJLENBQUNJLElBQUwsR0FBWUUsTUFBTSxDQUFDQyxXQUFwQyxDQUFELElBQXFEUCxJQUFJLENBQUNRLEtBQTNELENBRE47QUFFTEMsSUFBQUEsR0FBRyxFQUFFZixLQUFLLENBQUMsQ0FBQ1EsT0FBTyxDQUFDUSxLQUFSLElBQWlCVixJQUFJLENBQUNTLEdBQUwsR0FBV0gsTUFBTSxDQUFDSyxXQUFuQyxDQUFELElBQW9EWCxJQUFJLENBQUNZLE1BQTFEO0FBRkwsR0FBUDtBQUlELENBVk0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VSZWYsIHVzZUVmZmVjdCwgdXNlQ2FsbGJhY2ssIHVzZUxheW91dEVmZmVjdCB9IGZyb20gJ3JlYWN0JztcblxuLy8gU2F2ZXMgaW5jb21pbmcgaGFuZGxlciB0byB0aGUgcmVmIGluIG9yZGVyIHRvIGF2b2lkIFwidXNlQ2FsbGJhY2sgaGVsbFwiXG5leHBvcnQgZnVuY3Rpb24gdXNlRXZlbnRDYWxsYmFjazxULCBLPihoYW5kbGVyPzogKHZhbHVlOiBULCBldmVudDogSykgPT4gdm9pZCk6ICh2YWx1ZTogVCwgZXZlbnQ6IEspID0+IHZvaWQge1xuICBjb25zdCBjYWxsYmFja1JlZiA9IHVzZVJlZihoYW5kbGVyKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNhbGxiYWNrUmVmLmN1cnJlbnQgPSBoYW5kbGVyO1xuICB9KTtcblxuICByZXR1cm4gdXNlQ2FsbGJhY2soKHZhbHVlOiBULCBldmVudDogSykgPT4gY2FsbGJhY2tSZWYuY3VycmVudCAmJiBjYWxsYmFja1JlZi5jdXJyZW50KHZhbHVlLCBldmVudCksIFtdKTtcbn1cblxuLy8gQ2hlY2sgaWYgYW4gZXZlbnQgd2FzIHRyaWdnZXJlZCBieSB0b3VjaFxuZXhwb3J0IGNvbnN0IGlzVG91Y2ggPSAoZXZlbnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KTogZXZlbnQgaXMgVG91Y2hFdmVudCA9PiAndG91Y2hlcycgaW4gZXZlbnQ7XG5cbi8vIEJyb3dzZXJzIGludHJvZHVjZWQgYW4gaW50ZXJ2ZW50aW9uLCBtYWtpbmcgdG91Y2ggZXZlbnRzIHBhc3NpdmUgYnkgZGVmYXVsdC5cbi8vIFRoaXMgd29ya2Fyb3VuZCByZW1vdmVzIGBwcmV2ZW50RGVmYXVsdGAgY2FsbCBmcm9tIHRoZSB0b3VjaCBoYW5kbGVycy5cbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9mYWNlYm9vay9yZWFjdC9pc3N1ZXMvMTk2NTFcbmV4cG9ydCBjb25zdCBwcmV2ZW50RGVmYXVsdE1vdmUgPSAoZXZlbnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KTogdm9pZCA9PiB7XG4gICFpc1RvdWNoKGV2ZW50KSAmJiBldmVudC5wcmV2ZW50RGVmYXVsdCAmJiBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xufTtcbi8vIENsYW1wcyBhIHZhbHVlIGJldHdlZW4gYW4gdXBwZXIgYW5kIGxvd2VyIGJvdW5kLlxuLy8gV2UgdXNlIHRlcm5hcnkgb3BlcmF0b3JzIGJlY2F1c2UgaXQgbWFrZXMgdGhlIG1pbmlmaWVkIGNvZGVcbi8vIDIgdGltZXMgc2hvcnRlciB0aGVuIGBNYXRoLm1pbihNYXRoLm1heChhLGIpLGMpYFxuZXhwb3J0IGNvbnN0IGNsYW1wID0gKG51bWJlcjogbnVtYmVyLCBtaW4gPSAwLCBtYXggPSAxKTogbnVtYmVyID0+IHtcbiAgcmV0dXJuIG51bWJlciA+IG1heCA/IG1heCA6IG51bWJlciA8IG1pbiA/IG1pbiA6IG51bWJlcjtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW50ZXJhY3Rpb24ge1xuICBsZWZ0OiBudW1iZXI7XG4gIHRvcDogbnVtYmVyO1xufVxuXG4vLyBSZXR1cm5zIGEgcmVsYXRpdmUgcG9zaXRpb24gb2YgdGhlIHBvaW50ZXIgaW5zaWRlIHRoZSBub2RlJ3MgYm91bmRpbmcgYm94XG5leHBvcnQgY29uc3QgZ2V0UmVsYXRpdmVQb3NpdGlvbiA9IChub2RlOiBIVE1MRGl2RWxlbWVudCwgZXZlbnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KTogSW50ZXJhY3Rpb24gPT4ge1xuICBjb25zdCByZWN0ID0gbm9kZS5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcblxuICAvLyBHZXQgdXNlcidzIHBvaW50ZXIgcG9zaXRpb24gZnJvbSBgdG91Y2hlc2AgYXJyYXkgaWYgaXQncyBhIGBUb3VjaEV2ZW50YFxuICBjb25zdCBwb2ludGVyID0gaXNUb3VjaChldmVudCkgPyBldmVudC50b3VjaGVzWzBdIDogKGV2ZW50IGFzIE1vdXNlRXZlbnQpO1xuXG4gIHJldHVybiB7XG4gICAgbGVmdDogY2xhbXAoKHBvaW50ZXIucGFnZVggLSAocmVjdC5sZWZ0ICsgd2luZG93LnBhZ2VYT2Zmc2V0KSkgLyByZWN0LndpZHRoKSxcbiAgICB0b3A6IGNsYW1wKChwb2ludGVyLnBhZ2VZIC0gKHJlY3QudG9wICsgd2luZG93LnBhZ2VZT2Zmc2V0KSkgLyByZWN0LmhlaWdodCksXG4gIH07XG59O1xuIl19

@@ -5,2 +5,3 @@ import React from 'react';

export interface InteractiveProps extends React.HTMLAttributes<HTMLDivElement> {
prefixCls?: string;
onMove?: (interaction: Interaction, event: MouseEvent | TouchEvent) => void;

@@ -7,0 +8,0 @@ onDown?: (offset: Interaction, event: MouseEvent | TouchEvent) => void;

import _extends from "@babel/runtime/helpers/extends";
import _objectSpread from "@babel/runtime/helpers/objectSpread2";
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
var _excluded = ["onMove", "onDown"];
var _excluded = ["prefixCls", "className", "onMove", "onDown"];
import React, { useRef, useState, useCallback, useEffect } from 'react';

@@ -9,3 +10,6 @@ import { isTouch, preventDefaultMove, getRelativePosition, useEventCallback } from './utils';

export default /*#__PURE__*/React.forwardRef(function (props, ref) {
var onMove = props.onMove,
var _props$prefixCls = props.prefixCls,
prefixCls = _props$prefixCls === void 0 ? 'w-color-interactive' : _props$prefixCls,
className = props.className,
onMove = props.onMove,
onDown = props.onDown,

@@ -68,3 +72,8 @@ reset = _objectWithoutProperties(props, _excluded);

return /*#__PURE__*/React.createElement("div", _extends({}, reset, {
className: [prefixCls, className || ''].filter(Boolean).join(' '),
style: _objectSpread(_objectSpread({}, reset.style), {}, {
touchAction: 'none'
}),
ref: container,
tabIndex: 0,
onMouseDown: handleMoveStart,

@@ -74,2 +83,2 @@ onTouchStart: handleMoveStart

});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["React","useRef","useState","useCallback","useEffect","isTouch","preventDefaultMove","getRelativePosition","useEventCallback","forwardRef","props","ref","onMove","onDown","reset","container","hasTouched","isDragging","setDragging","onMoveCallback","onKeyCallback","isValid","event","current","handleMove","isDown","touches","length","buttons","handleMoveEnd","toggleDocumentEvents","state","toggleEvent","window","addEventListener","removeEventListener","handleMoveStart","nativeEvent"],"mappings":"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","sourcesContent":["import React, { useRef, useState, useCallback, useEffect } from 'react';\nimport { isTouch, preventDefaultMove, getRelativePosition, Interaction, useEventCallback } from './utils';\n\nexport * from './utils';\n\nexport interface InteractiveProps extends React.HTMLAttributes<HTMLDivElement> {\n  onMove?: (interaction: Interaction, event: MouseEvent | TouchEvent) => void;\n  onDown?: (offset: Interaction, event: MouseEvent | TouchEvent) => void;\n}\n\nexport default React.forwardRef<HTMLDivElement, InteractiveProps>((props, ref) => {\n  const { onMove, onDown, ...reset } = props;\n  const container = useRef<HTMLDivElement>(null);\n  const hasTouched = useRef(false);\n  const [isDragging, setDragging] = useState(false);\n  const onMoveCallback = useEventCallback<Interaction, MouseEvent | TouchEvent>(onMove);\n  const onKeyCallback = useEventCallback<Interaction, MouseEvent | TouchEvent>(onDown);\n\n  // Prevent mobile browsers from handling mouse events (conflicting with touch ones).\n  // If we detected a touch interaction before, we prefer reacting to touch events only.\n  const isValid = (event: MouseEvent | TouchEvent): boolean => {\n    if (hasTouched.current && !isTouch(event)) return false;\n    if (!hasTouched.current) hasTouched.current = isTouch(event);\n    return true;\n  };\n\n  const handleMove = useCallback(\n    (event: MouseEvent | TouchEvent) => {\n      preventDefaultMove(event);\n      // If user moves the pointer outside of the window or iframe bounds and release it there,\n      // `mouseup`/`touchend` won't be fired. In order to stop the picker from following the cursor\n      // after the user has moved the mouse/finger back to the document, we check `event.buttons`\n      // and `event.touches`. It allows us to detect that the user is just moving his pointer\n      // without pressing it down\n      const isDown = isTouch(event) ? event.touches.length > 0 : event.buttons > 0;\n\n      if (isDown && container.current) {\n        onMoveCallback && onMoveCallback(getRelativePosition(container.current!, event), event);\n      } else {\n        setDragging(false);\n      }\n    },\n    [onMoveCallback],\n  );\n\n  const handleMoveEnd = useCallback(() => setDragging(false), []);\n\n  const toggleDocumentEvents = useCallback((state: boolean) => {\n    const toggleEvent = state ? window.addEventListener : window.removeEventListener;\n    toggleEvent(hasTouched.current ? 'touchmove' : 'mousemove', handleMove);\n    toggleEvent(hasTouched.current ? 'touchend' : 'mouseup', handleMoveEnd);\n  }, []);\n\n  useEffect(() => {\n    toggleDocumentEvents(isDragging);\n    return () => {\n      isDragging && toggleDocumentEvents(false);\n    };\n  }, [isDragging, toggleDocumentEvents]);\n\n  const handleMoveStart = useCallback(\n    (event: React.MouseEvent | React.TouchEvent) => {\n      preventDefaultMove(event.nativeEvent);\n      if (!isValid(event.nativeEvent)) return;\n      onKeyCallback && onKeyCallback(getRelativePosition(container.current!, event.nativeEvent), event.nativeEvent);\n      setDragging(true);\n    },\n    [onKeyCallback],\n  );\n\n  return <div {...reset} ref={container} onMouseDown={handleMoveStart} onTouchStart={handleMoveStart} />;\n});\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["React","useRef","useState","useCallback","useEffect","isTouch","preventDefaultMove","getRelativePosition","useEventCallback","forwardRef","props","ref","prefixCls","className","onMove","onDown","reset","container","hasTouched","isDragging","setDragging","onMoveCallback","onKeyCallback","isValid","event","current","handleMove","isDown","touches","length","buttons","handleMoveEnd","toggleDocumentEvents","state","toggleEvent","window","addEventListener","removeEventListener","handleMoveStart","nativeEvent","filter","Boolean","join","style","touchAction"],"mappings":"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","sourcesContent":["import React, { useRef, useState, useCallback, useEffect } from 'react';\nimport { isTouch, preventDefaultMove, getRelativePosition, Interaction, useEventCallback } from './utils';\n\nexport * from './utils';\n\nexport interface InteractiveProps extends React.HTMLAttributes<HTMLDivElement> {\n  prefixCls?: string;\n  onMove?: (interaction: Interaction, event: MouseEvent | TouchEvent) => void;\n  onDown?: (offset: Interaction, event: MouseEvent | TouchEvent) => void;\n}\n\nexport default React.forwardRef<HTMLDivElement, InteractiveProps>((props, ref) => {\n  const { prefixCls = 'w-color-interactive', className, onMove, onDown, ...reset } = props;\n  const container = useRef<HTMLDivElement>(null);\n  const hasTouched = useRef(false);\n  const [isDragging, setDragging] = useState(false);\n  const onMoveCallback = useEventCallback<Interaction, MouseEvent | TouchEvent>(onMove);\n  const onKeyCallback = useEventCallback<Interaction, MouseEvent | TouchEvent>(onDown);\n\n  // Prevent mobile browsers from handling mouse events (conflicting with touch ones).\n  // If we detected a touch interaction before, we prefer reacting to touch events only.\n  const isValid = (event: MouseEvent | TouchEvent): boolean => {\n    if (hasTouched.current && !isTouch(event)) return false;\n    if (!hasTouched.current) hasTouched.current = isTouch(event);\n    return true;\n  };\n\n  const handleMove = useCallback(\n    (event: MouseEvent | TouchEvent) => {\n      preventDefaultMove(event);\n      // If user moves the pointer outside of the window or iframe bounds and release it there,\n      // `mouseup`/`touchend` won't be fired. In order to stop the picker from following the cursor\n      // after the user has moved the mouse/finger back to the document, we check `event.buttons`\n      // and `event.touches`. It allows us to detect that the user is just moving his pointer\n      // without pressing it down\n      const isDown = isTouch(event) ? event.touches.length > 0 : event.buttons > 0;\n      if (isDown && container.current) {\n        onMoveCallback && onMoveCallback(getRelativePosition(container.current!, event), event);\n      } else {\n        setDragging(false);\n      }\n    },\n    [onMoveCallback],\n  );\n\n  const handleMoveEnd = useCallback(() => setDragging(false), []);\n  const toggleDocumentEvents = useCallback((state: boolean) => {\n    const toggleEvent = state ? window.addEventListener : window.removeEventListener;\n    toggleEvent(hasTouched.current ? 'touchmove' : 'mousemove', handleMove);\n    toggleEvent(hasTouched.current ? 'touchend' : 'mouseup', handleMoveEnd);\n  }, []);\n\n  useEffect(() => {\n    toggleDocumentEvents(isDragging);\n    return () => {\n      isDragging && toggleDocumentEvents(false);\n    };\n  }, [isDragging, toggleDocumentEvents]);\n\n  const handleMoveStart = useCallback(\n    (event: React.MouseEvent | React.TouchEvent) => {\n      preventDefaultMove(event.nativeEvent);\n      if (!isValid(event.nativeEvent)) return;\n      onKeyCallback && onKeyCallback(getRelativePosition(container.current!, event.nativeEvent), event.nativeEvent);\n      setDragging(true);\n    },\n    [onKeyCallback],\n  );\n\n  return (\n    <div\n      {...reset}\n      className={[prefixCls, className || ''].filter(Boolean).join(' ')}\n      style={{\n        ...reset.style,\n        touchAction: 'none',\n      }}\n      ref={container}\n      tabIndex={0}\n      onMouseDown={handleMoveStart}\n      onTouchStart={handleMoveStart}\n    />\n  );\n});\n"]}

@@ -20,3 +20,3 @@ import { useRef, useEffect, useCallback } from 'react'; // Saves incoming handler to the ref in order to avoid "useCallback hell"

export var preventDefaultMove = function preventDefaultMove(event) {
!isTouch(event) && event.preventDefault();
!isTouch(event) && event.preventDefault && event.preventDefault();
}; // Clamps a value between an upper and lower bound.

@@ -41,2 +41,2 @@ // We use ternary operators because it makes the minified code

};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy50cyJdLCJuYW1lcyI6WyJ1c2VSZWYiLCJ1c2VFZmZlY3QiLCJ1c2VDYWxsYmFjayIsInVzZUV2ZW50Q2FsbGJhY2siLCJoYW5kbGVyIiwiY2FsbGJhY2tSZWYiLCJjdXJyZW50IiwidmFsdWUiLCJldmVudCIsImlzVG91Y2giLCJwcmV2ZW50RGVmYXVsdE1vdmUiLCJwcmV2ZW50RGVmYXVsdCIsImNsYW1wIiwibnVtYmVyIiwibWluIiwibWF4IiwiZ2V0UmVsYXRpdmVQb3NpdGlvbiIsIm5vZGUiLCJyZWN0IiwiZ2V0Qm91bmRpbmdDbGllbnRSZWN0IiwicG9pbnRlciIsInRvdWNoZXMiLCJsZWZ0IiwicGFnZVgiLCJ3aW5kb3ciLCJwYWdlWE9mZnNldCIsIndpZHRoIiwidG9wIiwicGFnZVkiLCJwYWdlWU9mZnNldCIsImhlaWdodCJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsTUFBVCxFQUFpQkMsU0FBakIsRUFBNEJDLFdBQTVCLFFBQStDLE9BQS9DLEMsQ0FFQTs7QUFDQSxPQUFPLFNBQVNDLGdCQUFULENBQWdDQyxPQUFoQyxFQUFzRztBQUMzRyxNQUFNQyxXQUFXLEdBQUdMLE1BQU0sQ0FBQ0ksT0FBRCxDQUExQjtBQUVBSCxFQUFBQSxTQUFTLENBQUMsWUFBTTtBQUNkSSxJQUFBQSxXQUFXLENBQUNDLE9BQVosR0FBc0JGLE9BQXRCO0FBQ0QsR0FGUSxDQUFUO0FBSUEsU0FBT0YsV0FBVyxDQUFDLFVBQUNLLEtBQUQsRUFBV0MsS0FBWDtBQUFBLFdBQXdCSCxXQUFXLENBQUNDLE9BQVosSUFBdUJELFdBQVcsQ0FBQ0MsT0FBWixDQUFvQkMsS0FBcEIsRUFBMkJDLEtBQTNCLENBQS9DO0FBQUEsR0FBRCxFQUFtRixFQUFuRixDQUFsQjtBQUNELEMsQ0FFRDs7QUFDQSxPQUFPLElBQU1DLE9BQU8sR0FBRyxTQUFWQSxPQUFVLENBQUNELEtBQUQ7QUFBQSxTQUF5RCxhQUFhQSxLQUF0RTtBQUFBLENBQWhCLEMsQ0FFUDtBQUNBO0FBQ0E7O0FBQ0EsT0FBTyxJQUFNRSxrQkFBa0IsR0FBRyxTQUFyQkEsa0JBQXFCLENBQUNGLEtBQUQsRUFBMEM7QUFDMUUsR0FBQ0MsT0FBTyxDQUFDRCxLQUFELENBQVIsSUFBbUJBLEtBQUssQ0FBQ0csY0FBTixFQUFuQjtBQUNELENBRk0sQyxDQUdQO0FBQ0E7QUFDQTs7QUFDQSxPQUFPLElBQU1DLEtBQUssR0FBRyxTQUFSQSxLQUFRLENBQUNDLE1BQUQsRUFBOEM7QUFBQSxNQUE3QkMsR0FBNkIsdUVBQXZCLENBQXVCO0FBQUEsTUFBcEJDLEdBQW9CLHVFQUFkLENBQWM7QUFDakUsU0FBT0YsTUFBTSxHQUFHRSxHQUFULEdBQWVBLEdBQWYsR0FBcUJGLE1BQU0sR0FBR0MsR0FBVCxHQUFlQSxHQUFmLEdBQXFCRCxNQUFqRDtBQUNELENBRk07QUFTUDtBQUNBLE9BQU8sSUFBTUcsbUJBQW1CLEdBQUcsU0FBdEJBLG1CQUFzQixDQUFDQyxJQUFELEVBQXVCVCxLQUF2QixFQUF1RTtBQUN4RyxNQUFNVSxJQUFJLEdBQUdELElBQUksQ0FBQ0UscUJBQUwsRUFBYixDQUR3RyxDQUd4Rzs7QUFDQSxNQUFNQyxPQUFPLEdBQUdYLE9BQU8sQ0FBQ0QsS0FBRCxDQUFQLEdBQWlCQSxLQUFLLENBQUNhLE9BQU4sQ0FBYyxDQUFkLENBQWpCLEdBQXFDYixLQUFyRDtBQUVBLFNBQU87QUFDTGMsSUFBQUEsSUFBSSxFQUFFVixLQUFLLENBQUMsQ0FBQ1EsT0FBTyxDQUFDRyxLQUFSLElBQWlCTCxJQUFJLENBQUNJLElBQUwsR0FBWUUsTUFBTSxDQUFDQyxXQUFwQyxDQUFELElBQXFEUCxJQUFJLENBQUNRLEtBQTNELENBRE47QUFFTEMsSUFBQUEsR0FBRyxFQUFFZixLQUFLLENBQUMsQ0FBQ1EsT0FBTyxDQUFDUSxLQUFSLElBQWlCVixJQUFJLENBQUNTLEdBQUwsR0FBV0gsTUFBTSxDQUFDSyxXQUFuQyxDQUFELElBQW9EWCxJQUFJLENBQUNZLE1BQTFEO0FBRkwsR0FBUDtBQUlELENBVk0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VSZWYsIHVzZUVmZmVjdCwgdXNlQ2FsbGJhY2sgfSBmcm9tICdyZWFjdCc7XG5cbi8vIFNhdmVzIGluY29taW5nIGhhbmRsZXIgdG8gdGhlIHJlZiBpbiBvcmRlciB0byBhdm9pZCBcInVzZUNhbGxiYWNrIGhlbGxcIlxuZXhwb3J0IGZ1bmN0aW9uIHVzZUV2ZW50Q2FsbGJhY2s8VCwgSz4oaGFuZGxlcj86ICh2YWx1ZTogVCwgZXZlbnQ6IEspID0+IHZvaWQpOiAodmFsdWU6IFQsIGV2ZW50OiBLKSA9PiB2b2lkIHtcbiAgY29uc3QgY2FsbGJhY2tSZWYgPSB1c2VSZWYoaGFuZGxlcik7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjYWxsYmFja1JlZi5jdXJyZW50ID0gaGFuZGxlcjtcbiAgfSk7XG5cbiAgcmV0dXJuIHVzZUNhbGxiYWNrKCh2YWx1ZTogVCwgZXZlbnQ6IEspID0+IGNhbGxiYWNrUmVmLmN1cnJlbnQgJiYgY2FsbGJhY2tSZWYuY3VycmVudCh2YWx1ZSwgZXZlbnQpLCBbXSk7XG59XG5cbi8vIENoZWNrIGlmIGFuIGV2ZW50IHdhcyB0cmlnZ2VyZWQgYnkgdG91Y2hcbmV4cG9ydCBjb25zdCBpc1RvdWNoID0gKGV2ZW50OiBNb3VzZUV2ZW50IHwgVG91Y2hFdmVudCk6IGV2ZW50IGlzIFRvdWNoRXZlbnQgPT4gJ3RvdWNoZXMnIGluIGV2ZW50O1xuXG4vLyBCcm93c2VycyBpbnRyb2R1Y2VkIGFuIGludGVydmVudGlvbiwgbWFraW5nIHRvdWNoIGV2ZW50cyBwYXNzaXZlIGJ5IGRlZmF1bHQuXG4vLyBUaGlzIHdvcmthcm91bmQgcmVtb3ZlcyBgcHJldmVudERlZmF1bHRgIGNhbGwgZnJvbSB0aGUgdG91Y2ggaGFuZGxlcnMuXG4vLyBodHRwczovL2dpdGh1Yi5jb20vZmFjZWJvb2svcmVhY3QvaXNzdWVzLzE5NjUxXG5leHBvcnQgY29uc3QgcHJldmVudERlZmF1bHRNb3ZlID0gKGV2ZW50OiBNb3VzZUV2ZW50IHwgVG91Y2hFdmVudCk6IHZvaWQgPT4ge1xuICAhaXNUb3VjaChldmVudCkgJiYgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbn07XG4vLyBDbGFtcHMgYSB2YWx1ZSBiZXR3ZWVuIGFuIHVwcGVyIGFuZCBsb3dlciBib3VuZC5cbi8vIFdlIHVzZSB0ZXJuYXJ5IG9wZXJhdG9ycyBiZWNhdXNlIGl0IG1ha2VzIHRoZSBtaW5pZmllZCBjb2RlXG4vLyAyIHRpbWVzIHNob3J0ZXIgdGhlbiBgTWF0aC5taW4oTWF0aC5tYXgoYSxiKSxjKWBcbmV4cG9ydCBjb25zdCBjbGFtcCA9IChudW1iZXI6IG51bWJlciwgbWluID0gMCwgbWF4ID0gMSk6IG51bWJlciA9PiB7XG4gIHJldHVybiBudW1iZXIgPiBtYXggPyBtYXggOiBudW1iZXIgPCBtaW4gPyBtaW4gOiBudW1iZXI7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIEludGVyYWN0aW9uIHtcbiAgbGVmdDogbnVtYmVyO1xuICB0b3A6IG51bWJlcjtcbn1cblxuLy8gUmV0dXJucyBhIHJlbGF0aXZlIHBvc2l0aW9uIG9mIHRoZSBwb2ludGVyIGluc2lkZSB0aGUgbm9kZSdzIGJvdW5kaW5nIGJveFxuZXhwb3J0IGNvbnN0IGdldFJlbGF0aXZlUG9zaXRpb24gPSAobm9kZTogSFRNTERpdkVsZW1lbnQsIGV2ZW50OiBNb3VzZUV2ZW50IHwgVG91Y2hFdmVudCk6IEludGVyYWN0aW9uID0+IHtcbiAgY29uc3QgcmVjdCA9IG5vZGUuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG5cbiAgLy8gR2V0IHVzZXIncyBwb2ludGVyIHBvc2l0aW9uIGZyb20gYHRvdWNoZXNgIGFycmF5IGlmIGl0J3MgYSBgVG91Y2hFdmVudGBcbiAgY29uc3QgcG9pbnRlciA9IGlzVG91Y2goZXZlbnQpID8gZXZlbnQudG91Y2hlc1swXSA6IChldmVudCBhcyBNb3VzZUV2ZW50KTtcblxuICByZXR1cm4ge1xuICAgIGxlZnQ6IGNsYW1wKChwb2ludGVyLnBhZ2VYIC0gKHJlY3QubGVmdCArIHdpbmRvdy5wYWdlWE9mZnNldCkpIC8gcmVjdC53aWR0aCksXG4gICAgdG9wOiBjbGFtcCgocG9pbnRlci5wYWdlWSAtIChyZWN0LnRvcCArIHdpbmRvdy5wYWdlWU9mZnNldCkpIC8gcmVjdC5oZWlnaHQpLFxuICB9O1xufTtcbiJdfQ==
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy50cyJdLCJuYW1lcyI6WyJ1c2VSZWYiLCJ1c2VFZmZlY3QiLCJ1c2VDYWxsYmFjayIsInVzZUV2ZW50Q2FsbGJhY2siLCJoYW5kbGVyIiwiY2FsbGJhY2tSZWYiLCJjdXJyZW50IiwidmFsdWUiLCJldmVudCIsImlzVG91Y2giLCJwcmV2ZW50RGVmYXVsdE1vdmUiLCJwcmV2ZW50RGVmYXVsdCIsImNsYW1wIiwibnVtYmVyIiwibWluIiwibWF4IiwiZ2V0UmVsYXRpdmVQb3NpdGlvbiIsIm5vZGUiLCJyZWN0IiwiZ2V0Qm91bmRpbmdDbGllbnRSZWN0IiwicG9pbnRlciIsInRvdWNoZXMiLCJsZWZ0IiwicGFnZVgiLCJ3aW5kb3ciLCJwYWdlWE9mZnNldCIsIndpZHRoIiwidG9wIiwicGFnZVkiLCJwYWdlWU9mZnNldCIsImhlaWdodCJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsTUFBVCxFQUFpQkMsU0FBakIsRUFBNEJDLFdBQTVCLFFBQWdFLE9BQWhFLEMsQ0FFQTs7QUFDQSxPQUFPLFNBQVNDLGdCQUFULENBQWdDQyxPQUFoQyxFQUFzRztBQUMzRyxNQUFNQyxXQUFXLEdBQUdMLE1BQU0sQ0FBQ0ksT0FBRCxDQUExQjtBQUVBSCxFQUFBQSxTQUFTLENBQUMsWUFBTTtBQUNkSSxJQUFBQSxXQUFXLENBQUNDLE9BQVosR0FBc0JGLE9BQXRCO0FBQ0QsR0FGUSxDQUFUO0FBSUEsU0FBT0YsV0FBVyxDQUFDLFVBQUNLLEtBQUQsRUFBV0MsS0FBWDtBQUFBLFdBQXdCSCxXQUFXLENBQUNDLE9BQVosSUFBdUJELFdBQVcsQ0FBQ0MsT0FBWixDQUFvQkMsS0FBcEIsRUFBMkJDLEtBQTNCLENBQS9DO0FBQUEsR0FBRCxFQUFtRixFQUFuRixDQUFsQjtBQUNELEMsQ0FFRDs7QUFDQSxPQUFPLElBQU1DLE9BQU8sR0FBRyxTQUFWQSxPQUFVLENBQUNELEtBQUQ7QUFBQSxTQUF5RCxhQUFhQSxLQUF0RTtBQUFBLENBQWhCLEMsQ0FFUDtBQUNBO0FBQ0E7O0FBQ0EsT0FBTyxJQUFNRSxrQkFBa0IsR0FBRyxTQUFyQkEsa0JBQXFCLENBQUNGLEtBQUQsRUFBMEM7QUFDMUUsR0FBQ0MsT0FBTyxDQUFDRCxLQUFELENBQVIsSUFBbUJBLEtBQUssQ0FBQ0csY0FBekIsSUFBMkNILEtBQUssQ0FBQ0csY0FBTixFQUEzQztBQUNELENBRk0sQyxDQUdQO0FBQ0E7QUFDQTs7QUFDQSxPQUFPLElBQU1DLEtBQUssR0FBRyxTQUFSQSxLQUFRLENBQUNDLE1BQUQsRUFBOEM7QUFBQSxNQUE3QkMsR0FBNkIsdUVBQXZCLENBQXVCO0FBQUEsTUFBcEJDLEdBQW9CLHVFQUFkLENBQWM7QUFDakUsU0FBT0YsTUFBTSxHQUFHRSxHQUFULEdBQWVBLEdBQWYsR0FBcUJGLE1BQU0sR0FBR0MsR0FBVCxHQUFlQSxHQUFmLEdBQXFCRCxNQUFqRDtBQUNELENBRk07QUFTUDtBQUNBLE9BQU8sSUFBTUcsbUJBQW1CLEdBQUcsU0FBdEJBLG1CQUFzQixDQUFDQyxJQUFELEVBQXVCVCxLQUF2QixFQUF1RTtBQUN4RyxNQUFNVSxJQUFJLEdBQUdELElBQUksQ0FBQ0UscUJBQUwsRUFBYixDQUR3RyxDQUd4Rzs7QUFDQSxNQUFNQyxPQUFPLEdBQUdYLE9BQU8sQ0FBQ0QsS0FBRCxDQUFQLEdBQWlCQSxLQUFLLENBQUNhLE9BQU4sQ0FBYyxDQUFkLENBQWpCLEdBQXFDYixLQUFyRDtBQUVBLFNBQU87QUFDTGMsSUFBQUEsSUFBSSxFQUFFVixLQUFLLENBQUMsQ0FBQ1EsT0FBTyxDQUFDRyxLQUFSLElBQWlCTCxJQUFJLENBQUNJLElBQUwsR0FBWUUsTUFBTSxDQUFDQyxXQUFwQyxDQUFELElBQXFEUCxJQUFJLENBQUNRLEtBQTNELENBRE47QUFFTEMsSUFBQUEsR0FBRyxFQUFFZixLQUFLLENBQUMsQ0FBQ1EsT0FBTyxDQUFDUSxLQUFSLElBQWlCVixJQUFJLENBQUNTLEdBQUwsR0FBV0gsTUFBTSxDQUFDSyxXQUFuQyxDQUFELElBQW9EWCxJQUFJLENBQUNZLE1BQTFEO0FBRkwsR0FBUDtBQUlELENBVk0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VSZWYsIHVzZUVmZmVjdCwgdXNlQ2FsbGJhY2ssIHVzZUxheW91dEVmZmVjdCB9IGZyb20gJ3JlYWN0JztcblxuLy8gU2F2ZXMgaW5jb21pbmcgaGFuZGxlciB0byB0aGUgcmVmIGluIG9yZGVyIHRvIGF2b2lkIFwidXNlQ2FsbGJhY2sgaGVsbFwiXG5leHBvcnQgZnVuY3Rpb24gdXNlRXZlbnRDYWxsYmFjazxULCBLPihoYW5kbGVyPzogKHZhbHVlOiBULCBldmVudDogSykgPT4gdm9pZCk6ICh2YWx1ZTogVCwgZXZlbnQ6IEspID0+IHZvaWQge1xuICBjb25zdCBjYWxsYmFja1JlZiA9IHVzZVJlZihoYW5kbGVyKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNhbGxiYWNrUmVmLmN1cnJlbnQgPSBoYW5kbGVyO1xuICB9KTtcblxuICByZXR1cm4gdXNlQ2FsbGJhY2soKHZhbHVlOiBULCBldmVudDogSykgPT4gY2FsbGJhY2tSZWYuY3VycmVudCAmJiBjYWxsYmFja1JlZi5jdXJyZW50KHZhbHVlLCBldmVudCksIFtdKTtcbn1cblxuLy8gQ2hlY2sgaWYgYW4gZXZlbnQgd2FzIHRyaWdnZXJlZCBieSB0b3VjaFxuZXhwb3J0IGNvbnN0IGlzVG91Y2ggPSAoZXZlbnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KTogZXZlbnQgaXMgVG91Y2hFdmVudCA9PiAndG91Y2hlcycgaW4gZXZlbnQ7XG5cbi8vIEJyb3dzZXJzIGludHJvZHVjZWQgYW4gaW50ZXJ2ZW50aW9uLCBtYWtpbmcgdG91Y2ggZXZlbnRzIHBhc3NpdmUgYnkgZGVmYXVsdC5cbi8vIFRoaXMgd29ya2Fyb3VuZCByZW1vdmVzIGBwcmV2ZW50RGVmYXVsdGAgY2FsbCBmcm9tIHRoZSB0b3VjaCBoYW5kbGVycy5cbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9mYWNlYm9vay9yZWFjdC9pc3N1ZXMvMTk2NTFcbmV4cG9ydCBjb25zdCBwcmV2ZW50RGVmYXVsdE1vdmUgPSAoZXZlbnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KTogdm9pZCA9PiB7XG4gICFpc1RvdWNoKGV2ZW50KSAmJiBldmVudC5wcmV2ZW50RGVmYXVsdCAmJiBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xufTtcbi8vIENsYW1wcyBhIHZhbHVlIGJldHdlZW4gYW4gdXBwZXIgYW5kIGxvd2VyIGJvdW5kLlxuLy8gV2UgdXNlIHRlcm5hcnkgb3BlcmF0b3JzIGJlY2F1c2UgaXQgbWFrZXMgdGhlIG1pbmlmaWVkIGNvZGVcbi8vIDIgdGltZXMgc2hvcnRlciB0aGVuIGBNYXRoLm1pbihNYXRoLm1heChhLGIpLGMpYFxuZXhwb3J0IGNvbnN0IGNsYW1wID0gKG51bWJlcjogbnVtYmVyLCBtaW4gPSAwLCBtYXggPSAxKTogbnVtYmVyID0+IHtcbiAgcmV0dXJuIG51bWJlciA+IG1heCA/IG1heCA6IG51bWJlciA8IG1pbiA/IG1pbiA6IG51bWJlcjtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW50ZXJhY3Rpb24ge1xuICBsZWZ0OiBudW1iZXI7XG4gIHRvcDogbnVtYmVyO1xufVxuXG4vLyBSZXR1cm5zIGEgcmVsYXRpdmUgcG9zaXRpb24gb2YgdGhlIHBvaW50ZXIgaW5zaWRlIHRoZSBub2RlJ3MgYm91bmRpbmcgYm94XG5leHBvcnQgY29uc3QgZ2V0UmVsYXRpdmVQb3NpdGlvbiA9IChub2RlOiBIVE1MRGl2RWxlbWVudCwgZXZlbnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KTogSW50ZXJhY3Rpb24gPT4ge1xuICBjb25zdCByZWN0ID0gbm9kZS5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcblxuICAvLyBHZXQgdXNlcidzIHBvaW50ZXIgcG9zaXRpb24gZnJvbSBgdG91Y2hlc2AgYXJyYXkgaWYgaXQncyBhIGBUb3VjaEV2ZW50YFxuICBjb25zdCBwb2ludGVyID0gaXNUb3VjaChldmVudCkgPyBldmVudC50b3VjaGVzWzBdIDogKGV2ZW50IGFzIE1vdXNlRXZlbnQpO1xuXG4gIHJldHVybiB7XG4gICAgbGVmdDogY2xhbXAoKHBvaW50ZXIucGFnZVggLSAocmVjdC5sZWZ0ICsgd2luZG93LnBhZ2VYT2Zmc2V0KSkgLyByZWN0LndpZHRoKSxcbiAgICB0b3A6IGNsYW1wKChwb2ludGVyLnBhZ2VZIC0gKHJlY3QudG9wICsgd2luZG93LnBhZ2VZT2Zmc2V0KSkgLyByZWN0LmhlaWdodCksXG4gIH07XG59O1xuIl19
{
"name": "@uiw/react-drag-event-interactive",
"version": "0.0.18",
"version": "0.0.19",
"description": "react drag event interactive",

@@ -5,0 +5,0 @@ "homepage": "https://uiwjs.github.io/react-color/#react-drag-event-interactive",

@@ -1,2 +0,2 @@

import { useRef, useEffect, useCallback } from 'react';
import { useRef, useEffect, useCallback, useLayoutEffect } from 'react';

@@ -21,3 +21,3 @@ // Saves incoming handler to the ref in order to avoid "useCallback hell"

export const preventDefaultMove = (event: MouseEvent | TouchEvent): void => {
!isTouch(event) && event.preventDefault();
!isTouch(event) && event.preventDefault && event.preventDefault();
};

@@ -24,0 +24,0 @@ // Clamps a value between an upper and lower bound.

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc