Changelog
Here is the change log since version 5.
8.0.1 Release
Summary: fixes origin on Pinch for Safari desktop.
Fixed
- adds origin to GestureEvent (used on Safari Desktop). Fixes #226.
8.0.0
Summary: Major refactoring by thephoenixofthevoid. This release has some significant underlying changes that may break some specific edge cases (like scrolling while dragging on mobile).
Breaking
- The app uses PointerEventwherever it can, dropping support for some older browsers.
- When adding events directly to the dom element using domTargetyou no longer need to clean the effect yourself.
// beforeconst bind = useDrag(() => {/* your logic */},{ domTarget: window })React.useEffect(bind, [bind])// afteruseDrag(() => {/* your logic */},{ domTarget: window })
- Handlers are being fired even if the gesture is not intentional #3dacf8f but only with the triggerAllEventsflag set totrue#5c77db7. This allows manipulation of events at all times. Fixes #175.
- When using native handlers, the shared state is now being forwarded #186.
// beforeconst bind = useGesture({onClick: event => console.log(event),})// afterconst bind = useGesture({onClick: ({ event, ...fullState }) => console.log(event), // you can do something with the fullState})
Added
- Drag and pinch now works on multiple dom elements at once #170.
- Drag option { filterTaps: true }will also prevent unwanted taps on children elements #173.
- Config options bounds,distanceBoundsandangleBoundscan now be functions excuted at the start of each gesture. The function is passed the gesture state as an argument.
- When a function, initialis passed the gesture state as an argument so that you can computeinitialbased onargs.
- User facing intentionaloption that is set totruewhen the gesture is intentional (useful when usingthresholdorfilterTapsoptions).
Fixed
- Various Typescript types.
- Hooks configuration is no longer recreated on every render.
7.0.15 Release
Summary: Fixes touchcancel on drag.
Fixed
- Touch cancel listener was set for mouse devices đ .
7.0.14 Release
Summary: Refactoring thanks to thephoenixofthevoid [PR #160] and further fix for on tap recognition on mobile devices.
Fixed
- Fixes #149 when setting state.
7.0.13 Release
Summary: TS type fix. Should fix #158.
Fixed
- Fixes types for UserHandlersPartial.
7.0.12 Release
Summary: TS onDragEnd and onDragStart definition fix.
Fixed
- onDragStartand- onDragEndare also React Handlers, which were overriding Gesture handlers definitions.
7.0.11 Release
Summary: fixes move / hover order.
Fixed
- hover in â mouse move â mouse stops â hover out.
7.0.10 Release
Summary: doesn't use webkit gesture events when using React native handlers.
Fixed
- Only uses webkit gesture events on iOS devices when domTargetis specified.
7.0.9 Release
Summary: different strategy for fixing #149.
Fixed
- Checks on the timestamps to filter emulated mousedownevents.
7.0.8 Release
Summary: fixes 7.0.7 for native handlers.
Fixed
- Makes fix of 7.0.7work for native React handlers. Fixes #149.
7.0.7 Release
Summary: fixes double drag gestures on touch screens.
Fixed
- Prevents touch screens from firing the drag gesture twice.
7.0.6 Release
Summary: fixes onGestureEnd logic.
Fixed
- Prevents onPinchEndfrom firing when releasing the pointer without actually triggering pinch in the first place. Fixes #148.
- Fixes onGestureEndlogic for other gestures.
7.0.5 Release
Summary: blocked bug fixes on debounced gestures.
Fixed
- Passes delta: [0,0]when gesture is blocked so debounced gestures can calculate distance. Fixes #140.
7.0.4 Release
Summary: drag should work on multi pointers devices.
Fixed
- Adds both mouse and touch handlers for drag.
7.0.3 Release
Summary: type fixes.
Fixed
- DragState type fix.
7.0.2 Release
Summary: onHover fires before onMove.
Fixed
- onHoverfires before- onMove.
7.0.1 Release
Summary: Fix exporting the useHover hook.
Fixed
- Exports the useHoverhook.
7.0.0 Release
Summary: Major release introducing new features and options renaming. This is a full rewrite.
Breaking
- Options for useGestureare now separated per gesture;
- Options for event are now structured differently.
- dragDelayis now renamed- delay.
Before
useGesture(fn, {enabled: true,event: { passive: true, capture: false },pointerEvents: true,wheel: false,dragDelay: 100,})
After
useGesture(fn, {enabled: true,eventOptions: { passive: true, capture: false, pointer: true },wheel: {enabled: false,},drag: {delay: 100,},})// oruseDrag(fn, {eventOptions: { passive: true, capture: false, pointer: true },delay: 100,})
Added
- State attribute lastOffset: offset when the last gesture started.
- State attribute startTime: gesture start time.
- State attribute elapsedTime: gesture elapsed time.
- Drag state attribute swipe: indicates if the drag was a swipe.
- Drag state attribute tap: is the drag assimilated to a tap.
- Option initial: the initial movement or a function that returns the initial movement.
- Option threshold: the handler will fire only when the gesture displacement is greater than the threshold.
- Option rubberband: the elasticity coefficient of the gesture when going out of bounds.
- XY option axis: constraints the gesture to the axis.
- XY option lockDirection: if true, the gesture will lock the first detected direction.
- XY option bounds: limits the gesture movement and offset to the specified bounds.
- Pinch option distanceBounds: limits the distance movement and offset to the specified bounds.
- Pinch option angleBounds: limits the angle movement and offset to the specified bounds.
- New doc website!
Fixed
- Native handlers now update with state #117
- When a ref is null on unmount, bind now returns the correct cleaning function #115
6.0.14 Release
Summary: Fixes Pointer Events on hover.
Fixed
- Fixes getEventBindings/this.onEnd -> this.onPointerLeave
6.0.13 Invalid Release
6.0.12 Release
Summary: Fixes Typescript import.
Fixed
- Added Omitto the types import list.
6.0.11 Release
Summary: Continues fixing of start state.
Fixed
- Fixes previousattribute in start state.
6.0.10 Release
Summary: Fixes start state.
Fixed
- Fixes #97 (follow up of #96 with fixes of distance and direction)
6.0.9 Release
Summary: Fixes refactoring of 6.0.8.
6.0.8 Release
Summary: Fixes bug with continuous gestures.
Fixed
- Scroll and wheel are continuous gestures and should therefore init delta, movement and offset as soon as they start (#96)
6.0.7 Release
Summary: Fixes bug with dragDelay.
Fixed
- Drag no longer reset after dragDelaywhen drag is forced with mouse move.
6.0.6 Release
Summary: Fixes types đ¤Śâ
6.0.5 Release
Summary: Tweak of 6.0.4.
Improved
- Moving the cursor when dragging doesn't wait for dragDelaytimeout.
6.0.4 Release
Summary: Added option to detect clicks from drag triggers.
Added
- Added dragDelayconfig attribute to trigger drag after a given delay.
6.0.3 Release
Summary: Minor additions.
Added
- Added originfor wheel pinching (matching cursor position).
- Added originfor trackpad gesture event pinching (matching cursor position).
6.0.2 Release
Summary: Re-introducing pointer-events.
Added
- Pointer Events are supported again with config: { pointerEvents: true }.
Breaking
- Removed transformfunction: it was originally introduced forreact-three-fibersupport but resulted useless eventually.
6.0.1 Release
Summary: Bug fix.
Fixed
- Pinching with wheel could return undefined angle. It now returns previous angle or 0.
6.0.0 Release
Summary: Refinement release, better naming of keys, with breaking changes.
Breaking
- tempis no longer supported. Please use- memo.
- deltanow calculates the delta between current and previous values.
- Former deltais replaced bymovement(xy - initial).
- Former localis replaced byoffset.
- lastLocalhas been removed.
- onActionhandler as an alias for- onDragis not supported anymore.
- useGesturedoesn't support a function as a shortcut for- onDrag. Please use- useDragfrom now on.
Added
- Added directionto pinch gestures.
- Added deltathat just calculates the delta between current and previous values.
- Added addVandsubVas convenient exports for adding and substracting vectors formed as arrays.
- Added a warning when using trackpad zoom without a domTargetorevent.passiveset to true.
- Added a gesturekey to the event passed to handlers indicating which gesture originated the event.
Fixed
- Fixed velocity for angle on pinch gestures.
- Doesn't trigger the onWheelhandler when the ctrl key is pressed andonPinchis active #80.
5.2.4 Release
Summary: Minor release.
Fixed
- memonow works as expected when returning- 0from the handler.
5.2.3 Release
Summary: Minor release.
Fixed
- Changed the default timeout for debounced events.
5.2.1 Release
Summary: Minor release.
Fixed
- Fixed issue with Webkit Gesture Recognizer.
5.2.0 Release
Summary: Introducing shorthand hooks for gestures.
Added
- useDrag,- useMove,- useHover,- useScroll,- useWheel,- usePinchhooks have been added.
Changed
- temprenamed to- memo.
5.1.3 Release
Summary: Better build process and TypeScript improvements.
Added
- Build process now uses tsdxinstead ofrollup.
Fixed
- Event type fixing in TypeScript.
5.1.2 Release
Summary: Minor release fixing TypeScript export.
Fixed
- import { useGesture } from 'react-use-gesture'should now be functional.
5.1.0 Release (do not use)
5.1.1 Release
Summary: important release introducing trackpad gestures. The library has been fully rewritten in TypeScript with some important refactoring involved.
Added
- Support for for zoom and rotate on trackpad for Safari.
- Support for zoom on trackpad for Chrome and Firefox.
- Added buttonsattribute to pointer-related gesture state.
- Added originattribute to pinch gesture.
- Accepts support for genuine element handlers (such as onMouseDown) to prevent overriding when passing the prop directly to the bound component.
Fixed
- Drag gesture will interrupt if a move event has no button pressed (that could happen if triggering a right click) and then moving the mouse around.
Breaking
- configobject must be passed as a second argument.
5.0.2 Release
Summary: minor release.
Fixed
- Added onHoverin Typescript definitions.
5.0.1 Release
Summary: release updating dev dependencies and fixing minor bugs.
Fixed
- Fixed a bug where - onDragEndor- onPinchEndwould be called too late when the gestures are canceled #52
- Wheel and scroll gestures are also returning modifier keys. 
5.0.0 Release
Summary (recap from betas): major release introducing additional gestures on top of drag: pinch, scroll, wheel, hover and move are now supported. This release is dropping support for high-order and render-props component and can only be used through React hooks đŁ. Therefore react-with-gesture is now react-use-gesture.
Added
- Support for pinch, scroll, wheel, move and hover events. Each gesture has now an - activeboolean prop that lets you know whether itâs currently active. State also include- dragging,- moving,- scrolling,- wheeling,- pinching, and- hoveringbooleans so that you can know within a gesture handler the running state of all others.
- Support for dynamically enabling or disabling gestures in the - configobject:- useGesture(actions, { enabled: false })or- useGesture(actions, { drag: true, move: false })if you want to disable or enable gestures individually.
- You can now add a gesture to a dom node or the - window(useful for scroll) with the- domTargetconfig prop. In that case you shouldnât spread- bindin a component but use the- useEffecthook that will take care of adding and removing listeners:
const bind = useGesture({ onScroll: () => {...} }, { domTarget: window })React.useEffect(bind, [bind])
- Individual per-axis velocity has been added in gesture state props as - vxvy: vector2.
- There's a new - transformconfig prop that can be passed to change the way- xand- yare calculated (useful for canvas which inverts axis compared to the dom).
- Experimental support for pointer events through config: - { event : { pointerEvents: true } }.
- Tests with - react-testing-library.
- Travis integration. 
Improved
- State and props are no longer frozen, meaning you can now use state or props values from your component inside your handler and they will be up to date.
const [dragCount, setDragCount] = useState(0)const bind = useGesture({onDrag: ({ first }) => {console.log(dragCount) //<-- count will be up to dateif (first) setDragCount(dragCount + 1)},})
- Readme should be clearer (hopefully)!
Breaking
- HOC and render-props component support has been dropped. Hooks usage is enforced, therefore this package requires React 16.8+. 
- Default syntax - [bind, props] = useGesture()has been dropped in favor of- bind = useGesture({ onDrag: () => {...} })which is more performance-effective since it doesnât render on each frame.
- onActionprop is now an alias of- onDragbut should be avoided as its support could be dropped at any time. Subsequently,- onUpand- onDownhave been dropped, and there's now- on[Gesture]Startand- on[Gesture]Endhandlers.
- configobject should now be passed as a second argument.
// from this:useGesture({ onAction: () => {}, config })// to this:useGesture({ onDrag: () => {} }, { ...config })
- touchand- mouseconfig props are dropped.
5.0.0-beta.8 Release
Summary: Removed default export to match TypeScript import in JS.
Breaking
- You should now import useGesture as follows: import { useGesture } from 'react-use-gesture'
5.0.0-beta.7 Release
Summary: Minor bug fixing.
Fixed
- firstwas still set to- truewhen the gesture finished if no movement was registered.
5.0.0-beta.6 Release
Summary: Minor bug fixing.
Fixed
- NaNor- Infinityvelocities are now set to- 0.
5.0.0-beta.5 Release
Summary: bug fixing and more tests.
Improved
- domTargetnow accepts refs.
- Tests are now testing domTarget.
- Tests are now testing bindpassing arguments.
Fixed
- onMoveEndshouldn't fire if state isn't moving (ie- onLeavewas triggered).
- Performance optimizations were removed as they were conflicting with passing args to bind.
5.0.0-beta.4 Release
Summary: bug fixing and added tests!
Added
- Tests have been added with - react-testing-library: they still throw a warning about some tests not being wrapped in- act(...)but this is probably because of async debouncing in move, scroll, wheel events and RAF for- cancelin drag and pinch.
- Added Travis integration. 
Improved
- Now using dtslintfor Typescript definitions and tests.
Fixed
- firstwas always returning true and this is no longer the case.
- activewasn't set to- truewhen moving in- onMove.
- Added - activeset to- falseon- mouseLeavefor- onHover. This might not be a good idea though.
5.0.0-beta.3 Release
Summary: major release introducing additional gestures on top of drag: pinch, scroll, wheel, hover and move are now supported. This release is dropping support for high-order and render-props component and can only be used through React hooks đŁ. Therefore react-with-gesture is now react-use-gesture.
Added
- Support for pinch, scroll, wheel, move and hover events. Each gesture has now an - activeboolean prop that lets you know whether itâs currently active. State also include- dragging,- moving,- scrolling,- wheeling,- pinching, and- hoveringbooleans so that you can know within a gesture handler the running state of all others.
- Support for dynamically enabling or disabling gestures in the - configobject:- useGesture(actions, { enabled: false })or- useGesture(actions, { drag: true, move: false })if you want to disable or enable gestures individually.
- You can now add a gesture to a dom node or the - window(useful for scroll) with the- domTargetconfig prop. In that case you shouldnât spread- bindin a component but use the- useEffecthook that will take care of adding and removing listeners:
const bind = useGesture({ onScroll: () => {...} }, { domTarget: window })React.useEffect(bind, [bind])
- Individual per-axis velocity has been added in gesture state props as - vxvy: vector2.
- There's a new - transformconfig prop that can be passed to change the way- xand- yare calculated (useful for canvas which inverts axis compared to the dom).
- Experimental support for pointer events through config: - { event : { pointerEvents: true } }.
Improved
- useGesturereturned value is now cached which should produce better performance in case of frequent renders produced by external factors (i.e. prop change).
- State and props are no longer frozen, meaning you can now use state or props values from your component inside your handler and they will be up to date. 
const [dragCount, setDragCount] = useState(0)const bind = useGesture({onDrag: ({ first }) => {console.log(dragCount) //<-- count will be up to dateif (first) setDragCount(dragCount + 1)},})
- Readme should be clearer (hopefully)!
Breaking
- HOC and render-props component support has been dropped. Hooks usage is enforced, therefore this package requires React 16.8+. 
- Default syntax - [bind, props] = useGesture()has been dropped in favor of- bind = useGesture({ onDrag: () => {...} })which is more performance-effective since it doesnât render on each frame.
- onActionprop is now an alias of- onDragbut should be avoided as its support could be dropped at any time. Subsequently,- onUpand- onDownhave been dropped, and there's now- on[Gesture]Startand- on[Gesture]Endhandlers.
- configobject should now be passed as a second argument.
// from this:useGesture({ onAction: () => {}, config })// to this:useGesture({ onDrag: () => {} }, { ...config })
- touchand- mouseconfig props are dropped.
