@uiw/react-drag-event-interactive
Advanced tools
Comparing version 0.0.19 to 0.0.20
@@ -59,3 +59,3 @@ "use strict"; | ||
if (hasTouched.current && !(0, _utils.isTouch)(event)) return false; | ||
if (!hasTouched.current) hasTouched.current = (0, _utils.isTouch)(event); | ||
hasTouched.current = (0, _utils.isTouch)(event); | ||
return true; | ||
@@ -112,2 +112,2 @@ }; | ||
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    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"]} | ||
//# 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":";;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;4BAQeA,eAAMC,UAAN,CAAmD,UAACC,KAAD,EAAQC,GAAR,EAAgB;AAChF,yBAAmFD,KAAnF,CAAQE,SAAR;AAAA,MAAQA,SAAR,iCAAoB,qBAApB;AAAA,MAA2CC,SAA3C,GAAmFH,KAAnF,CAA2CG,SAA3C;AAAA,MAAsDC,MAAtD,GAAmFJ,KAAnF,CAAsDI,MAAtD;AAAA,MAA8DC,MAA9D,GAAmFL,KAAnF,CAA8DK,MAA9D;AAAA,MAAyEC,KAAzE,0CAAmFN,KAAnF;AACA,MAAMO,SAAS,GAAG,mBAAuB,IAAvB,CAAlB;AACA,MAAMC,UAAU,GAAG,mBAAO,KAAP,CAAnB;;AACA,kBAAkC,qBAAS,KAAT,CAAlC;AAAA;AAAA,MAAOC,UAAP;AAAA,MAAmBC,WAAnB;;AACA,MAAMC,cAAc,GAAG,6BAAuDP,MAAvD,CAAvB;AACA,MAAMQ,aAAa,GAAG,6BAAuDP,MAAvD,CAAtB,CANgF,CAQhF;AACA;;AACA,MAAMQ,OAAO,GAAG,SAAVA,OAAU,CAACC,KAAD,EAA6C;AAC3D,QAAIN,UAAU,CAACO,OAAX,IAAsB,CAAC,oBAAQD,KAAR,CAA3B,EAA2C,OAAO,KAAP;AAC3CN,IAAAA,UAAU,CAACO,OAAX,GAAqB,oBAAQD,KAAR,CAArB;AACA,WAAO,IAAP;AACD,GAJD;;AAMA,MAAME,UAAU,GAAG,wBACjB,UAACF,KAAD,EAAoC;AAClC,mCAAmBA,KAAnB,EADkC,CAElC;AACA;AACA;AACA;AACA;;AACA,QAAMG,MAAM,GAAG,oBAAQH,KAAR,IAAiBA,KAAK,CAACI,OAAN,CAAcC,MAAd,GAAuB,CAAxC,GAA4CL,KAAK,CAACM,OAAN,GAAgB,CAA3E;;AACA,QAAIH,MAAM,IAAIV,SAAS,CAACQ,OAAxB,EAAiC;AAC/BJ,MAAAA,cAAc,IAAIA,cAAc,CAAC,gCAAoBJ,SAAS,CAACQ,OAA9B,EAAwCD,KAAxC,CAAD,EAAiDA,KAAjD,CAAhC;AACD,KAFD,MAEO;AACLJ,MAAAA,WAAW,CAAC,KAAD,CAAX;AACD;AACF,GAdgB,EAejB,CAACC,cAAD,CAfiB,CAAnB;AAkBA,MAAMU,aAAa,GAAG,wBAAY;AAAA,WAAMX,WAAW,CAAC,KAAD,CAAjB;AAAA,GAAZ,EAAsC,EAAtC,CAAtB;AACA,MAAMY,oBAAoB,GAAG,wBAAY,UAACC,KAAD,EAAoB;AAC3D,QAAMC,WAAW,GAAGD,KAAK,GAAGE,MAAM,CAACC,gBAAV,GAA6BD,MAAM,CAACE,mBAA7D;AACAH,IAAAA,WAAW,CAAChB,UAAU,CAACO,OAAX,GAAqB,WAArB,GAAmC,WAApC,EAAiDC,UAAjD,CAAX;AACAQ,IAAAA,WAAW,CAAChB,UAAU,CAACO,OAAX,GAAqB,UAArB,GAAkC,SAAnC,EAA8CM,aAA9C,CAAX;AACD,GAJ4B,EAI1B,EAJ0B,CAA7B;AAMA,wBAAU,YAAM;AACdC,IAAAA,oBAAoB,CAACb,UAAD,CAApB;AACA,WAAO,YAAM;AACXA,MAAAA,UAAU,IAAIa,oBAAoB,CAAC,KAAD,CAAlC;AACD,KAFD;AAGD,GALD,EAKG,CAACb,UAAD,EAAaa,oBAAb,CALH;AAOA,MAAMM,eAAe,GAAG,wBACtB,UAACd,KAAD,EAAgD;AAC9C,mCAAmBA,KAAK,CAACe,WAAzB;AACA,QAAI,CAAChB,OAAO,CAACC,KAAK,CAACe,WAAP,CAAZ,EAAiC;AACjCjB,IAAAA,aAAa,IAAIA,aAAa,CAAC,gCAAoBL,SAAS,CAACQ,OAA9B,EAAwCD,KAAK,CAACe,WAA9C,CAAD,EAA6Df,KAAK,CAACe,WAAnE,CAA9B;AACAnB,IAAAA,WAAW,CAAC,IAAD,CAAX;AACD,GANqB,EAOtB,CAACE,aAAD,CAPsB,CAAxB;AAUA,sBACE,+DACMN,KADN;AAEE,IAAA,SAAS,EAAE,CAACJ,SAAD,EAAYC,SAAS,IAAI,EAAzB,EAA6B2B,MAA7B,CAAoCC,OAApC,EAA6CC,IAA7C,CAAkD,GAAlD,CAFb;AAGE,IAAA,KAAK,8DACA1B,KAAK,CAAC2B,KADN;AAEHC,MAAAA,WAAW,EAAE;AAFV,MAHP;AAOE,IAAA,GAAG,EAAE3B,SAPP;AAQE,IAAA,QAAQ,EAAE,CARZ;AASE,IAAA,WAAW,EAAEqB,eATf;AAUE,IAAA,YAAY,EAAEA;AAVhB,KADF;AAcD,CAxEc,C","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"]} |
@@ -31,3 +31,3 @@ import _extends from "@babel/runtime/helpers/extends"; | ||
if (hasTouched.current && !isTouch(event)) return false; | ||
if (!hasTouched.current) hasTouched.current = isTouch(event); | ||
hasTouched.current = isTouch(event); | ||
return true; | ||
@@ -82,2 +82,2 @@ }; | ||
}); | ||
//# 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"]} | ||
//# 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"]} |
{ | ||
"name": "@uiw/react-drag-event-interactive", | ||
"version": "0.0.19", | ||
"version": "0.0.20", | ||
"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
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
49715