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.24 to 0.0.25

4

lib/cjs/index.d.ts

@@ -9,3 +9,3 @@ import React from 'react';

}
declare const _default: React.ForwardRefExoticComponent<InteractiveProps & React.RefAttributes<HTMLDivElement>>;
export default _default;
declare const Interactive: React.ForwardRefExoticComponent<InteractiveProps & React.RefAttributes<HTMLDivElement>>;
export default Interactive;

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

var _default = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
var Interactive = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
var _props$prefixCls = props.prefixCls,

@@ -111,3 +111,5 @@ prefixCls = _props$prefixCls === void 0 ? 'w-color-interactive' : _props$prefixCls,

Interactive.displayName = 'Interactive';
var _default = Interactive;
exports.default = _default;
//# 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    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"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["Interactive","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","displayName"],"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\nconst Interactive = 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    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\nInteractive.displayName = 'Interactive';\n\nexport default Interactive;\n"]}

@@ -9,3 +9,3 @@ import React from 'react';

}
declare const _default: React.ForwardRefExoticComponent<InteractiveProps & React.RefAttributes<HTMLDivElement>>;
export default _default;
declare const Interactive: React.ForwardRefExoticComponent<InteractiveProps & React.RefAttributes<HTMLDivElement>>;
export default Interactive;

@@ -9,3 +9,3 @@ import _extends from "@babel/runtime/helpers/extends";

export * from './utils';
export default /*#__PURE__*/React.forwardRef(function (props, ref) {
var Interactive = /*#__PURE__*/React.forwardRef(function (props, ref) {
var _props$prefixCls = props.prefixCls,

@@ -82,2 +82,4 @@ prefixCls = _props$prefixCls === void 0 ? 'w-color-interactive' : _props$prefixCls,

});
//# 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    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"]}
Interactive.displayName = 'Interactive';
export default Interactive;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["React","useRef","useState","useCallback","useEffect","isTouch","preventDefaultMove","getRelativePosition","useEventCallback","Interactive","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","displayName"],"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\nconst Interactive = 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    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\nInteractive.displayName = 'Interactive';\n\nexport default Interactive;\n"]}
{
"name": "@uiw/react-drag-event-interactive",
"version": "0.0.24",
"version": "0.0.25",
"description": "react drag event interactive",

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

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