react-native-gesture-handler 1.10.3 → 2.1.2
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +7 -6
- package/android/build.gradle +49 -1
- package/android/common/src/main/java/com/swmansion/common/GestureHandlerStateManager.kt +5 -0
- package/android/gradle.properties +19 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/BaseGestureHandlerInteractionController.kt +18 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/Extensions.kt +11 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/FlingGestureHandler.kt +96 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/GestureHandler.kt +713 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/GestureHandlerInteractionController.kt +8 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/GestureHandlerOrchestrator.kt +562 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/GestureHandlerRegistry.kt +8 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/GestureHandlerRegistryImpl.kt +21 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/GestureUtils.kt +49 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/LongPressGestureHandler.kt +97 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/ManualGestureHandler.kt +11 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/NativeViewGestureHandler.kt +129 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/OnTouchEventListener.kt +9 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/PanGestureHandler.kt +289 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/PinchGestureHandler.kt +88 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/{PointerEventsConfig.java → PointerEventsConfig.kt} +3 -5
- package/android/lib/src/main/java/com/swmansion/gesturehandler/RotationGestureDetector.kt +125 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/RotationGestureHandler.kt +79 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/TapGestureHandler.kt +167 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/ViewConfigurationHelper.kt +10 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerButtonViewManager.kt +348 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerEnabledRootView.kt +57 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerEvent.kt +59 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerEventDataExtractor.kt +8 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerInteractionManager.kt +61 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerModule.kt +686 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerPackage.kt +17 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRegistry.kt +95 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootHelper.kt +132 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootInterface.kt +5 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootView.kt +68 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootViewManager.kt +34 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerStateChangeEvent.kt +66 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerTouchEvent.kt +69 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNViewConfigurationHelper.kt +51 -0
- package/ios/Handlers/RNFlingHandler.m +78 -5
- package/ios/Handlers/RNForceTouchHandler.m +29 -4
- package/ios/Handlers/RNLongPressHandler.m +105 -3
- package/ios/Handlers/RNManualHandler.h +4 -0
- package/ios/Handlers/RNManualHandler.m +73 -0
- package/ios/Handlers/RNNativeViewHandler.m +30 -2
- package/ios/Handlers/RNPanHandler.m +64 -4
- package/ios/Handlers/RNPinchHandler.m +61 -2
- package/ios/Handlers/RNRotationHandler.m +60 -1
- package/ios/Handlers/RNTapHandler.m +55 -8
- package/ios/RNGestureHandler.h +18 -4
- package/ios/RNGestureHandler.m +123 -13
- package/ios/RNGestureHandlerEvents.h +9 -0
- package/ios/RNGestureHandlerEvents.m +34 -0
- package/ios/RNGestureHandlerManager.h +7 -0
- package/ios/RNGestureHandlerManager.m +62 -34
- package/ios/RNGestureHandlerModule.m +39 -3
- package/ios/RNGestureHandlerPointerTracker.h +25 -0
- package/ios/RNGestureHandlerPointerTracker.m +237 -0
- package/ios/RNGestureHandlerRegistry.h +1 -0
- package/ios/RNGestureHandlerRegistry.m +10 -0
- package/ios/RNGestureHandlerStateManager.h +5 -0
- package/ios/RNManualActivationRecognizer.h +10 -0
- package/ios/RNManualActivationRecognizer.m +80 -0
- package/ios/RNRootViewGestureRecognizer.m +1 -1
- package/ios/RNTouchEventType.h +9 -0
- package/lib/commonjs/EventType.js +16 -0
- package/lib/commonjs/EventType.js.map +1 -0
- package/lib/commonjs/GestureHandlerRootView.android.js +1 -13
- package/lib/commonjs/GestureHandlerRootView.android.js.map +1 -1
- package/lib/commonjs/GestureHandlerRootView.js +11 -3
- package/lib/commonjs/GestureHandlerRootView.js.map +1 -1
- package/lib/commonjs/RNGestureHandlerModule.js +3 -1
- package/lib/commonjs/RNGestureHandlerModule.js.map +1 -1
- package/lib/commonjs/RNGestureHandlerModule.web.js +2 -2
- package/lib/commonjs/RNGestureHandlerModule.web.js.map +1 -1
- package/lib/commonjs/components/DrawerLayout.js +41 -37
- package/lib/commonjs/components/DrawerLayout.js.map +1 -1
- package/lib/commonjs/components/GestureButtons.js.map +1 -1
- package/lib/commonjs/components/GestureComponents.js +31 -12
- package/lib/commonjs/components/GestureComponents.js.map +1 -1
- package/lib/commonjs/components/Swipeable.js +10 -6
- package/lib/commonjs/components/Swipeable.js.map +1 -1
- package/lib/commonjs/components/touchables/GenericTouchable.js +2 -1
- package/lib/commonjs/components/touchables/GenericTouchable.js.map +1 -1
- package/lib/commonjs/components/touchables/TouchableOpacity.js +1 -1
- package/lib/commonjs/components/touchables/TouchableOpacity.js.map +1 -1
- package/lib/commonjs/gestureHandlerRootHOC.js +1 -1
- package/lib/commonjs/gestureHandlerRootHOC.js.map +1 -1
- package/lib/commonjs/handlers/FlingGestureHandler.js +23 -0
- package/lib/commonjs/handlers/FlingGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/ForceTouchGestureHandler.js +44 -0
- package/lib/commonjs/handlers/ForceTouchGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/LongPressGestureHandler.js +23 -0
- package/lib/commonjs/handlers/LongPressGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/NativeViewGestureHandler.js +6 -4
- package/lib/commonjs/handlers/NativeViewGestureHandler.js.map +1 -1
- package/lib/commonjs/handlers/PanGestureHandler.js +121 -0
- package/lib/commonjs/handlers/PanGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/PinchGestureHandler.js +21 -0
- package/lib/commonjs/handlers/PinchGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/RotationGestureHandler.js +21 -0
- package/lib/commonjs/handlers/RotationGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/TapGestureHandler.js +23 -0
- package/lib/commonjs/handlers/TapGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/createHandler.js +52 -83
- package/lib/commonjs/handlers/createHandler.js.map +1 -1
- package/lib/commonjs/handlers/gestureHandlerCommon.js +80 -0
- package/lib/commonjs/handlers/gestureHandlerCommon.js.map +1 -0
- package/lib/commonjs/handlers/gestures/GestureDetector.js +440 -0
- package/lib/commonjs/handlers/gestures/GestureDetector.js.map +1 -0
- package/lib/commonjs/handlers/gestures/eventReceiver.js +135 -0
- package/lib/commonjs/handlers/gestures/eventReceiver.js.map +1 -0
- package/lib/commonjs/handlers/gestures/flingGesture.js +34 -0
- package/lib/commonjs/handlers/gestures/flingGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/forceTouchGesture.js +65 -0
- package/lib/commonjs/handlers/gestures/forceTouchGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/gesture.js +193 -0
- package/lib/commonjs/handlers/gestures/gesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/gestureComposition.js +94 -0
- package/lib/commonjs/handlers/gestures/gestureComposition.js.map +1 -0
- package/lib/commonjs/handlers/gestures/gestureObjects.js +85 -0
- package/lib/commonjs/handlers/gestures/gestureObjects.js.map +1 -0
- package/lib/commonjs/handlers/gestures/gestureStateManager.js +58 -0
- package/lib/commonjs/handlers/gestures/gestureStateManager.js.map +1 -0
- package/lib/commonjs/handlers/gestures/longPressGesture.js +34 -0
- package/lib/commonjs/handlers/gestures/longPressGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/manualGesture.js +31 -0
- package/lib/commonjs/handlers/gestures/manualGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/nativeGesture.js +34 -0
- package/lib/commonjs/handlers/gestures/nativeGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/panGesture.js +144 -0
- package/lib/commonjs/handlers/gestures/panGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/pinchGesture.js +45 -0
- package/lib/commonjs/handlers/gestures/pinchGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/reanimatedWrapper.js +24 -0
- package/lib/commonjs/handlers/gestures/reanimatedWrapper.js.map +1 -0
- package/lib/commonjs/handlers/gestures/rotationGesture.js +45 -0
- package/lib/commonjs/handlers/gestures/rotationGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/tapGesture.js +59 -0
- package/lib/commonjs/handlers/gestures/tapGesture.js.map +1 -0
- package/lib/commonjs/handlers/handlersRegistry.js +31 -0
- package/lib/commonjs/handlers/handlersRegistry.js.map +1 -0
- package/lib/commonjs/index.js +146 -8
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/init.js +13 -0
- package/lib/commonjs/init.js.map +1 -0
- package/lib/commonjs/mocks.js +31 -2
- package/lib/commonjs/mocks.js.map +1 -1
- package/lib/commonjs/utils.js +15 -0
- package/lib/commonjs/utils.js.map +1 -0
- package/lib/commonjs/web/Errors.js +1 -1
- package/lib/commonjs/web/Errors.js.map +1 -1
- package/lib/commonjs/web/GestureHandler.js +4 -6
- package/lib/commonjs/web/GestureHandler.js.map +1 -1
- package/lib/commonjs/web/NodeManager.js +8 -2
- package/lib/commonjs/web/NodeManager.js.map +1 -1
- package/lib/module/EventType.js +8 -0
- package/lib/module/EventType.js.map +1 -0
- package/lib/module/GestureHandlerRootView.android.js +2 -14
- package/lib/module/GestureHandlerRootView.android.js.map +1 -1
- package/lib/module/GestureHandlerRootView.js +5 -1
- package/lib/module/GestureHandlerRootView.js.map +1 -1
- package/lib/module/RNGestureHandlerModule.js +3 -1
- package/lib/module/RNGestureHandlerModule.js.map +1 -1
- package/lib/module/RNGestureHandlerModule.web.js +2 -2
- package/lib/module/RNGestureHandlerModule.web.js.map +1 -1
- package/lib/module/components/DrawerLayout.js +43 -40
- package/lib/module/components/DrawerLayout.js.map +1 -1
- package/lib/module/components/GestureButtons.js.map +1 -1
- package/lib/module/components/GestureComponents.js +29 -11
- package/lib/module/components/GestureComponents.js.map +1 -1
- package/lib/module/components/Swipeable.js +9 -6
- package/lib/module/components/Swipeable.js.map +1 -1
- package/lib/module/components/touchables/GenericTouchable.js +2 -1
- package/lib/module/components/touchables/GenericTouchable.js.map +1 -1
- package/lib/module/components/touchables/TouchableOpacity.js +1 -1
- package/lib/module/components/touchables/TouchableOpacity.js.map +1 -1
- package/lib/module/gestureHandlerRootHOC.js +1 -1
- package/lib/module/gestureHandlerRootHOC.js.map +1 -1
- package/lib/module/handlers/FlingGestureHandler.js +10 -0
- package/lib/module/handlers/FlingGestureHandler.js.map +1 -0
- package/lib/module/handlers/ForceTouchGestureHandler.js +29 -0
- package/lib/module/handlers/ForceTouchGestureHandler.js.map +1 -0
- package/lib/module/handlers/LongPressGestureHandler.js +10 -0
- package/lib/module/handlers/LongPressGestureHandler.js.map +1 -0
- package/lib/module/handlers/NativeViewGestureHandler.js +4 -3
- package/lib/module/handlers/NativeViewGestureHandler.js.map +1 -1
- package/lib/module/handlers/PanGestureHandler.js +106 -0
- package/lib/module/handlers/PanGestureHandler.js.map +1 -0
- package/lib/module/handlers/PinchGestureHandler.js +9 -0
- package/lib/module/handlers/PinchGestureHandler.js.map +1 -0
- package/lib/module/handlers/RotationGestureHandler.js +9 -0
- package/lib/module/handlers/RotationGestureHandler.js.map +1 -0
- package/lib/module/handlers/TapGestureHandler.js +10 -0
- package/lib/module/handlers/TapGestureHandler.js.map +1 -0
- package/lib/module/handlers/createHandler.js +41 -76
- package/lib/module/handlers/createHandler.js.map +1 -1
- package/lib/module/handlers/gestureHandlerCommon.js +66 -0
- package/lib/module/handlers/gestureHandlerCommon.js.map +1 -0
- package/lib/module/handlers/gestures/GestureDetector.js +402 -0
- package/lib/module/handlers/gestures/GestureDetector.js.map +1 -0
- package/lib/module/handlers/gestures/eventReceiver.js +120 -0
- package/lib/module/handlers/gestures/eventReceiver.js.map +1 -0
- package/lib/module/handlers/gestures/flingGesture.js +24 -0
- package/lib/module/handlers/gestures/flingGesture.js.map +1 -0
- package/lib/module/handlers/gestures/forceTouchGesture.js +56 -0
- package/lib/module/handlers/gestures/forceTouchGesture.js.map +1 -0
- package/lib/module/handlers/gestures/gesture.js +175 -0
- package/lib/module/handlers/gestures/gesture.js.map +1 -0
- package/lib/module/handlers/gestures/gestureComposition.js +79 -0
- package/lib/module/handlers/gestures/gestureComposition.js.map +1 -0
- package/lib/module/handlers/gestures/gestureObjects.js +67 -0
- package/lib/module/handlers/gestures/gestureObjects.js.map +1 -0
- package/lib/module/handlers/gestures/gestureStateManager.js +48 -0
- package/lib/module/handlers/gestures/gestureStateManager.js.map +1 -0
- package/lib/module/handlers/gestures/longPressGesture.js +24 -0
- package/lib/module/handlers/gestures/longPressGesture.js.map +1 -0
- package/lib/module/handlers/gestures/manualGesture.js +22 -0
- package/lib/module/handlers/gestures/manualGesture.js.map +1 -0
- package/lib/module/handlers/gestures/nativeGesture.js +24 -0
- package/lib/module/handlers/gestures/nativeGesture.js.map +1 -0
- package/lib/module/handlers/gestures/panGesture.js +135 -0
- package/lib/module/handlers/gestures/panGesture.js.map +1 -0
- package/lib/module/handlers/gestures/pinchGesture.js +36 -0
- package/lib/module/handlers/gestures/pinchGesture.js.map +1 -0
- package/lib/module/handlers/gestures/reanimatedWrapper.js +19 -0
- package/lib/module/handlers/gestures/reanimatedWrapper.js.map +1 -0
- package/lib/module/handlers/gestures/rotationGesture.js +36 -0
- package/lib/module/handlers/gestures/rotationGesture.js.map +1 -0
- package/lib/module/handlers/gestures/tapGesture.js +49 -0
- package/lib/module/handlers/gestures/tapGesture.js.map +1 -0
- package/lib/module/handlers/handlersRegistry.js +16 -0
- package/lib/module/handlers/handlersRegistry.js.map +1 -0
- package/lib/module/index.js +22 -1
- package/lib/module/index.js.map +1 -1
- package/lib/module/init.js +5 -0
- package/lib/module/init.js.map +1 -0
- package/lib/module/mocks.js +31 -2
- package/lib/module/mocks.js.map +1 -1
- package/lib/module/utils.js +8 -0
- package/lib/module/utils.js.map +1 -0
- package/lib/module/web/Errors.js +1 -1
- package/lib/module/web/Errors.js.map +1 -1
- package/lib/module/web/GestureHandler.js +4 -6
- package/lib/module/web/GestureHandler.js.map +1 -1
- package/lib/module/web/NodeManager.js +8 -2
- package/lib/module/web/NodeManager.js.map +1 -1
- package/lib/typescript/EventType.d.ts +8 -0
- package/lib/typescript/GestureHandlerRootView.android.d.ts +2 -4
- package/lib/typescript/GestureHandlerRootView.d.ts +5 -2
- package/lib/typescript/RNGestureHandlerModule.d.ts +1 -1
- package/lib/typescript/RNGestureHandlerModule.web.d.ts +1 -1
- package/lib/typescript/components/DrawerLayout.d.ts +50 -1
- package/lib/typescript/components/GestureButtons.d.ts +36 -0
- package/lib/typescript/components/GestureComponents.d.ts +8 -35
- package/lib/typescript/components/Swipeable.d.ts +73 -6
- package/lib/typescript/components/touchables/GenericTouchable.d.ts +2 -2
- package/lib/typescript/components/touchables/TouchableHighlight.d.ts +1 -0
- package/lib/typescript/components/touchables/TouchableOpacity.d.ts +1 -0
- package/lib/typescript/handlers/FlingGestureHandler.d.ts +33 -0
- package/lib/typescript/handlers/ForceTouchGestureHandler.d.ts +43 -0
- package/lib/typescript/handlers/LongPressGestureHandler.d.ts +55 -0
- package/lib/typescript/handlers/NativeViewGestureHandler.d.ts +19 -4
- package/lib/typescript/handlers/PanGestureHandler.d.ts +137 -0
- package/lib/typescript/handlers/PinchGestureHandler.d.ts +28 -0
- package/lib/typescript/handlers/RotationGestureHandler.d.ts +28 -0
- package/lib/typescript/handlers/TapGestureHandler.d.ts +56 -0
- package/lib/typescript/handlers/createHandler.d.ts +1 -1
- package/lib/typescript/handlers/gestureHandlerCommon.d.ts +62 -0
- package/lib/typescript/handlers/gestureHandlerTypesCompat.d.ts +8 -1
- package/lib/typescript/handlers/gestures/GestureDetector.d.ts +16 -0
- package/lib/typescript/handlers/gestures/eventReceiver.d.ts +2 -0
- package/lib/typescript/handlers/gestures/flingGesture.d.ts +9 -0
- package/lib/typescript/handlers/gestures/forceTouchGesture.d.ts +16 -0
- package/lib/typescript/handlers/gestures/gesture.d.ts +97 -0
- package/lib/typescript/handlers/gestures/gestureComposition.d.ts +21 -0
- package/lib/typescript/handlers/gestures/gestureObjects.d.ts +39 -0
- package/lib/typescript/handlers/gestures/gestureStateManager.d.ts +9 -0
- package/lib/typescript/handlers/gestures/longPressGesture.d.ts +9 -0
- package/lib/typescript/handlers/gestures/manualGesture.d.ts +7 -0
- package/lib/typescript/handlers/gestures/nativeGesture.d.ts +9 -0
- package/lib/typescript/handlers/gestures/panGesture.d.ts +26 -0
- package/lib/typescript/handlers/gestures/pinchGesture.d.ts +12 -0
- package/lib/typescript/handlers/gestures/reanimatedWrapper.d.ts +14 -0
- package/lib/typescript/handlers/gestures/rotationGesture.d.ts +12 -0
- package/lib/typescript/handlers/gestures/tapGesture.d.ts +14 -0
- package/lib/typescript/handlers/handlersRegistry.d.ts +6 -0
- package/lib/typescript/index.d.ts +29 -2
- package/lib/typescript/init.d.ts +1 -0
- package/lib/typescript/mocks.d.ts +21 -2
- package/lib/typescript/utils.d.ts +1 -0
- package/lib/typescript/web/FlingGestureHandler.d.ts +0 -1
- package/lib/typescript/web/GestureHandler.d.ts +0 -1
- package/lib/typescript/web/PanGestureHandler.d.ts +0 -1
- package/lib/typescript/web/PinchGestureHandler.d.ts +0 -1
- package/lib/typescript/web/PressGestureHandler.d.ts +0 -1
- package/lib/typescript/web/RotationGestureHandler.d.ts +0 -1
- package/lib/typescript/web/TapGestureHandler.d.ts +0 -1
- package/package.json +8 -5
- package/src/EventType.ts +10 -0
- package/src/GestureHandlerRootView.android.tsx +9 -25
- package/src/GestureHandlerRootView.tsx +11 -2
- package/src/RNGestureHandlerModule.ts +5 -1
- package/src/RNGestureHandlerModule.web.ts +1 -0
- package/src/components/DrawerLayout.tsx +114 -41
- package/src/components/GestureButtons.tsx +45 -5
- package/src/components/GestureComponents.tsx +47 -41
- package/src/components/Swipeable.tsx +108 -21
- package/src/components/touchables/GenericTouchable.tsx +2 -1
- package/src/components/touchables/TouchableOpacity.tsx +1 -1
- package/src/handlers/FlingGestureHandler.ts +57 -0
- package/src/handlers/ForceTouchGestureHandler.ts +83 -0
- package/src/handlers/LongPressGestureHandler.ts +84 -0
- package/src/handlers/NativeViewGestureHandler.ts +31 -7
- package/src/handlers/PanGestureHandler.ts +321 -0
- package/src/handlers/PinchGestureHandler.ts +46 -0
- package/src/handlers/RotationGestureHandler.ts +46 -0
- package/src/handlers/TapGestureHandler.ts +90 -0
- package/src/handlers/createHandler.ts +54 -79
- package/src/handlers/gestureHandlerCommon.ts +185 -0
- package/src/handlers/gestureHandlerTypesCompat.ts +19 -5
- package/src/handlers/gestures/GestureDetector.tsx +519 -0
- package/src/handlers/gestures/eventReceiver.ts +151 -0
- package/src/handlers/gestures/flingGesture.ts +27 -0
- package/src/handlers/gestures/forceTouchGesture.ts +74 -0
- package/src/handlers/gestures/gesture.ts +292 -0
- package/src/handlers/gestures/gestureComposition.ts +109 -0
- package/src/handlers/gestures/gestureObjects.ts +79 -0
- package/src/handlers/gestures/gestureStateManager.ts +60 -0
- package/src/handlers/gestures/longPressGesture.ts +27 -0
- package/src/handlers/gestures/manualGesture.ts +31 -0
- package/src/handlers/gestures/nativeGesture.ts +27 -0
- package/src/handlers/gestures/panGesture.ts +147 -0
- package/src/handlers/gestures/pinchGesture.ts +51 -0
- package/src/handlers/gestures/reanimatedWrapper.ts +45 -0
- package/src/handlers/gestures/rotationGesture.ts +51 -0
- package/src/handlers/gestures/tapGesture.ts +52 -0
- package/src/handlers/handlersRegistry.ts +22 -0
- package/src/index.ts +57 -17
- package/src/init.ts +5 -0
- package/src/mocks.ts +42 -2
- package/src/utils.ts +7 -0
- package/src/web/GestureHandler.ts +1 -2
- package/src/web/NodeManager.ts +5 -0
- package/android/lib/src/main/java/com/swmansion/gesturehandler/BaseGestureHandlerInteractionController.java +0 -23
- package/android/lib/src/main/java/com/swmansion/gesturehandler/FlingGestureHandler.java +0 -110
- package/android/lib/src/main/java/com/swmansion/gesturehandler/GestureHandler.java +0 -531
- package/android/lib/src/main/java/com/swmansion/gesturehandler/GestureHandlerInteractionController.java +0 -8
- package/android/lib/src/main/java/com/swmansion/gesturehandler/GestureHandlerOrchestrator.java +0 -543
- package/android/lib/src/main/java/com/swmansion/gesturehandler/GestureHandlerRegistry.java +0 -10
- package/android/lib/src/main/java/com/swmansion/gesturehandler/GestureHandlerRegistryImpl.java +0 -29
- package/android/lib/src/main/java/com/swmansion/gesturehandler/GestureUtils.java +0 -53
- package/android/lib/src/main/java/com/swmansion/gesturehandler/LongPressGestureHandler.java +0 -81
- package/android/lib/src/main/java/com/swmansion/gesturehandler/NativeViewGestureHandler.java +0 -110
- package/android/lib/src/main/java/com/swmansion/gesturehandler/OnTouchEventListener.java +0 -8
- package/android/lib/src/main/java/com/swmansion/gesturehandler/PanGestureHandler.java +0 -312
- package/android/lib/src/main/java/com/swmansion/gesturehandler/PinchGestureHandler.java +0 -109
- package/android/lib/src/main/java/com/swmansion/gesturehandler/RotationGestureDetector.java +0 -169
- package/android/lib/src/main/java/com/swmansion/gesturehandler/RotationGestureHandler.java +0 -96
- package/android/lib/src/main/java/com/swmansion/gesturehandler/TapGestureHandler.java +0 -172
- package/android/lib/src/main/java/com/swmansion/gesturehandler/ViewConfigurationHelper.java +0 -10
- package/android/src/main/java/com/facebook/react/views/modal/RNGHModalUtils.java +0 -21
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerButtonViewManager.java +0 -296
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerEnabledRootView.java +0 -72
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerEvent.java +0 -77
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerEventDataExtractor.java +0 -8
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerInteractionManager.java +0 -86
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerModule.java +0 -731
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerPackage.java +0 -31
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRegistry.java +0 -101
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootHelper.java +0 -151
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootInterface.java +0 -7
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootView.java +0 -76
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootViewManager.java +0 -49
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerStateChangeEvent.java +0 -82
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNViewConfigurationHelper.java +0 -61
- package/lib/commonjs/handlers/gestureHandlers.js +0 -236
- package/lib/commonjs/handlers/gestureHandlers.js.map +0 -1
- package/lib/module/handlers/gestureHandlers.js +0 -216
- package/lib/module/handlers/gestureHandlers.js.map +0 -1
- package/lib/typescript/handlers/gestureHandlers.d.ts +0 -158
- package/src/handlers/gestureHandlers.ts +0 -511
@@ -0,0 +1,519 @@
|
|
1
|
+
import React, { useEffect, useRef } from 'react';
|
2
|
+
import {
|
3
|
+
GestureType,
|
4
|
+
HandlerCallbacks,
|
5
|
+
BaseGesture,
|
6
|
+
GestureRef,
|
7
|
+
CALLBACK_TYPE,
|
8
|
+
} from './gesture';
|
9
|
+
import { Reanimated, SharedValue } from './reanimatedWrapper';
|
10
|
+
import { registerHandler, unregisterHandler } from '../handlersRegistry';
|
11
|
+
import RNGestureHandlerModule from '../../RNGestureHandlerModule';
|
12
|
+
import {
|
13
|
+
baseGestureHandlerWithMonitorProps,
|
14
|
+
filterConfig,
|
15
|
+
findNodeHandle,
|
16
|
+
GestureTouchEvent,
|
17
|
+
GestureUpdateEvent,
|
18
|
+
GestureStateChangeEvent,
|
19
|
+
} from '../gestureHandlerCommon';
|
20
|
+
import {
|
21
|
+
GestureStateManager,
|
22
|
+
GestureStateManagerType,
|
23
|
+
} from './gestureStateManager';
|
24
|
+
import { flingGestureHandlerProps } from '../FlingGestureHandler';
|
25
|
+
import { forceTouchGestureHandlerProps } from '../ForceTouchGestureHandler';
|
26
|
+
import { longPressGestureHandlerProps } from '../LongPressGestureHandler';
|
27
|
+
import {
|
28
|
+
panGestureHandlerProps,
|
29
|
+
panGestureHandlerCustomNativeProps,
|
30
|
+
} from '../PanGestureHandler';
|
31
|
+
import { tapGestureHandlerProps } from '../TapGestureHandler';
|
32
|
+
import { State } from '../../State';
|
33
|
+
import { EventType } from '../../EventType';
|
34
|
+
import { ComposedGesture } from './gestureComposition';
|
35
|
+
|
36
|
+
const ALLOWED_PROPS = [
|
37
|
+
...baseGestureHandlerWithMonitorProps,
|
38
|
+
...tapGestureHandlerProps,
|
39
|
+
...panGestureHandlerProps,
|
40
|
+
...panGestureHandlerCustomNativeProps,
|
41
|
+
...longPressGestureHandlerProps,
|
42
|
+
...forceTouchGestureHandlerProps,
|
43
|
+
...flingGestureHandlerProps,
|
44
|
+
];
|
45
|
+
|
46
|
+
export type GestureConfigReference = {
|
47
|
+
config: GestureType[];
|
48
|
+
animatedEventHandler: unknown;
|
49
|
+
animatedHandlers: SharedValue<
|
50
|
+
HandlerCallbacks<Record<string, unknown>>[] | null
|
51
|
+
> | null;
|
52
|
+
firstExecution: boolean;
|
53
|
+
useAnimated: boolean;
|
54
|
+
};
|
55
|
+
|
56
|
+
function convertToHandlerTag(ref: GestureRef): number {
|
57
|
+
if (typeof ref === 'number') {
|
58
|
+
return ref;
|
59
|
+
} else if (ref instanceof BaseGesture) {
|
60
|
+
return ref.handlerTag;
|
61
|
+
} else {
|
62
|
+
// @ts-ignore in this case it should be a ref either to gesture object or
|
63
|
+
// a gesture handler component, in both cases handlerTag property exists
|
64
|
+
return ref.current?.handlerTag ?? -1;
|
65
|
+
}
|
66
|
+
}
|
67
|
+
|
68
|
+
function extractValidHandlerTags(interactionGroup: GestureRef[] | undefined) {
|
69
|
+
return (
|
70
|
+
interactionGroup?.map(convertToHandlerTag)?.filter((tag) => tag > 0) ?? []
|
71
|
+
);
|
72
|
+
}
|
73
|
+
|
74
|
+
function dropHandlers(preparedGesture: GestureConfigReference) {
|
75
|
+
for (const handler of preparedGesture.config) {
|
76
|
+
RNGestureHandlerModule.dropGestureHandler(handler.handlerTag);
|
77
|
+
|
78
|
+
unregisterHandler(handler.handlerTag);
|
79
|
+
}
|
80
|
+
}
|
81
|
+
|
82
|
+
interface AttachHandlersConfig {
|
83
|
+
preparedGesture: GestureConfigReference;
|
84
|
+
gestureConfig: ComposedGesture | GestureType | undefined;
|
85
|
+
gesture: GestureType[];
|
86
|
+
viewTag: number;
|
87
|
+
useAnimated: boolean;
|
88
|
+
}
|
89
|
+
|
90
|
+
function attachHandlers({
|
91
|
+
preparedGesture,
|
92
|
+
gestureConfig,
|
93
|
+
gesture,
|
94
|
+
viewTag,
|
95
|
+
useAnimated,
|
96
|
+
}: AttachHandlersConfig) {
|
97
|
+
if (!preparedGesture.firstExecution) {
|
98
|
+
gestureConfig?.initialize();
|
99
|
+
} else {
|
100
|
+
preparedGesture.firstExecution = false;
|
101
|
+
}
|
102
|
+
|
103
|
+
// use setImmediate to extract handlerTags, because all refs should be initialized
|
104
|
+
// when it's ran
|
105
|
+
setImmediate(() => {
|
106
|
+
gestureConfig?.prepare();
|
107
|
+
});
|
108
|
+
|
109
|
+
for (const handler of gesture) {
|
110
|
+
RNGestureHandlerModule.createGestureHandler(
|
111
|
+
handler.handlerName,
|
112
|
+
handler.handlerTag,
|
113
|
+
filterConfig(handler.config, ALLOWED_PROPS)
|
114
|
+
);
|
115
|
+
|
116
|
+
registerHandler(handler.handlerTag, handler);
|
117
|
+
|
118
|
+
// use setImmediate to extract handlerTags, because all refs should be initialized
|
119
|
+
// when it's ran
|
120
|
+
setImmediate(() => {
|
121
|
+
let requireToFail: number[] = [];
|
122
|
+
if (handler.config.requireToFail) {
|
123
|
+
requireToFail = extractValidHandlerTags(handler.config.requireToFail);
|
124
|
+
}
|
125
|
+
|
126
|
+
let simultaneousWith: number[] = [];
|
127
|
+
if (handler.config.simultaneousWith) {
|
128
|
+
simultaneousWith = extractValidHandlerTags(
|
129
|
+
handler.config.simultaneousWith
|
130
|
+
);
|
131
|
+
}
|
132
|
+
|
133
|
+
RNGestureHandlerModule.updateGestureHandler(
|
134
|
+
handler.handlerTag,
|
135
|
+
filterConfig(handler.config, ALLOWED_PROPS, {
|
136
|
+
simultaneousHandlers: simultaneousWith,
|
137
|
+
waitFor: requireToFail,
|
138
|
+
})
|
139
|
+
);
|
140
|
+
});
|
141
|
+
}
|
142
|
+
preparedGesture.config = gesture;
|
143
|
+
|
144
|
+
for (const gesture of preparedGesture.config) {
|
145
|
+
RNGestureHandlerModule.attachGestureHandler(
|
146
|
+
gesture.handlerTag,
|
147
|
+
viewTag,
|
148
|
+
!useAnimated // send direct events when using animatedGesture, device events otherwise
|
149
|
+
);
|
150
|
+
}
|
151
|
+
|
152
|
+
if (preparedGesture.animatedHandlers) {
|
153
|
+
preparedGesture.animatedHandlers.value = (gesture.map(
|
154
|
+
(g) => g.handlers
|
155
|
+
) as unknown) as HandlerCallbacks<Record<string, unknown>>[];
|
156
|
+
}
|
157
|
+
}
|
158
|
+
|
159
|
+
function updateHandlers(
|
160
|
+
preparedGesture: GestureConfigReference,
|
161
|
+
gestureConfig: ComposedGesture | GestureType | undefined,
|
162
|
+
gesture: GestureType[]
|
163
|
+
) {
|
164
|
+
gestureConfig?.prepare();
|
165
|
+
|
166
|
+
for (let i = 0; i < gesture.length; i++) {
|
167
|
+
const handler = preparedGesture.config[i];
|
168
|
+
|
169
|
+
gesture[i].handlerTag = handler.handlerTag;
|
170
|
+
gesture[i].handlers.handlerTag = handler.handlerTag;
|
171
|
+
}
|
172
|
+
|
173
|
+
// use setImmediate to extract handlerTags, because when it's ran, all refs should be updated
|
174
|
+
// and handlerTags in BaseGesture references should be updated in the loop above (we need to wait
|
175
|
+
// in case of external relations)
|
176
|
+
setImmediate(() => {
|
177
|
+
for (let i = 0; i < gesture.length; i++) {
|
178
|
+
const handler = preparedGesture.config[i];
|
179
|
+
|
180
|
+
handler.config = gesture[i].config;
|
181
|
+
handler.handlers = gesture[i].handlers;
|
182
|
+
handler.handlers.handlerTag = handler.handlerTag;
|
183
|
+
|
184
|
+
const requireToFail = extractValidHandlerTags(
|
185
|
+
handler.config.requireToFail
|
186
|
+
);
|
187
|
+
|
188
|
+
const simultaneousWith = extractValidHandlerTags(
|
189
|
+
handler.config.simultaneousWith
|
190
|
+
);
|
191
|
+
|
192
|
+
RNGestureHandlerModule.updateGestureHandler(
|
193
|
+
handler.handlerTag,
|
194
|
+
filterConfig(handler.config, ALLOWED_PROPS, {
|
195
|
+
simultaneousHandlers: simultaneousWith,
|
196
|
+
waitFor: requireToFail,
|
197
|
+
})
|
198
|
+
);
|
199
|
+
|
200
|
+
registerHandler(handler.handlerTag, handler);
|
201
|
+
}
|
202
|
+
|
203
|
+
if (preparedGesture.animatedHandlers) {
|
204
|
+
preparedGesture.animatedHandlers.value = (preparedGesture.config.map(
|
205
|
+
(g) => g.handlers
|
206
|
+
) as unknown) as HandlerCallbacks<Record<string, unknown>>[];
|
207
|
+
}
|
208
|
+
});
|
209
|
+
}
|
210
|
+
|
211
|
+
function needsToReattach(
|
212
|
+
preparedGesture: GestureConfigReference,
|
213
|
+
gesture: GestureType[]
|
214
|
+
) {
|
215
|
+
if (gesture.length !== preparedGesture.config.length) {
|
216
|
+
return true;
|
217
|
+
}
|
218
|
+
for (let i = 0; i < gesture.length; i++) {
|
219
|
+
if (gesture[i].handlerName !== preparedGesture.config[i].handlerName) {
|
220
|
+
return true;
|
221
|
+
}
|
222
|
+
}
|
223
|
+
|
224
|
+
return false;
|
225
|
+
}
|
226
|
+
|
227
|
+
function useAnimatedGesture(preparedGesture: GestureConfigReference) {
|
228
|
+
if (!Reanimated) {
|
229
|
+
return;
|
230
|
+
}
|
231
|
+
|
232
|
+
function isStateChangeEvent(
|
233
|
+
event: GestureUpdateEvent | GestureStateChangeEvent | GestureTouchEvent
|
234
|
+
): event is GestureStateChangeEvent {
|
235
|
+
'worklet';
|
236
|
+
// @ts-ignore Yes, the oldState prop is missing on GestureTouchEvent, that's the point
|
237
|
+
return event.oldState != null;
|
238
|
+
}
|
239
|
+
|
240
|
+
function isTouchEvent(
|
241
|
+
event: GestureUpdateEvent | GestureStateChangeEvent | GestureTouchEvent
|
242
|
+
): event is GestureTouchEvent {
|
243
|
+
'worklet';
|
244
|
+
return event.eventType != null;
|
245
|
+
}
|
246
|
+
|
247
|
+
function getHandler(
|
248
|
+
type: CALLBACK_TYPE,
|
249
|
+
gesture: HandlerCallbacks<Record<string, unknown>>
|
250
|
+
) {
|
251
|
+
'worklet';
|
252
|
+
switch (type) {
|
253
|
+
case CALLBACK_TYPE.BEGAN:
|
254
|
+
return gesture.onBegin;
|
255
|
+
case CALLBACK_TYPE.START:
|
256
|
+
return gesture.onStart;
|
257
|
+
case CALLBACK_TYPE.UPDATE:
|
258
|
+
return gesture.onUpdate;
|
259
|
+
case CALLBACK_TYPE.CHANGE:
|
260
|
+
return gesture.onChange;
|
261
|
+
case CALLBACK_TYPE.END:
|
262
|
+
return gesture.onEnd;
|
263
|
+
case CALLBACK_TYPE.FINALIZE:
|
264
|
+
return gesture.onFinalize;
|
265
|
+
case CALLBACK_TYPE.TOUCHES_DOWN:
|
266
|
+
return gesture.onTouchesDown;
|
267
|
+
case CALLBACK_TYPE.TOUCHES_MOVE:
|
268
|
+
return gesture.onTouchesMove;
|
269
|
+
case CALLBACK_TYPE.TOUCHES_UP:
|
270
|
+
return gesture.onTouchesUp;
|
271
|
+
case CALLBACK_TYPE.TOUCHES_CANCELLED:
|
272
|
+
return gesture.onTouchesCancelled;
|
273
|
+
}
|
274
|
+
}
|
275
|
+
|
276
|
+
function touchEventTypeToCallbackType(eventType: EventType): CALLBACK_TYPE {
|
277
|
+
'worklet';
|
278
|
+
switch (eventType) {
|
279
|
+
case EventType.TOUCHES_DOWN:
|
280
|
+
return CALLBACK_TYPE.TOUCHES_DOWN;
|
281
|
+
case EventType.TOUCHES_MOVE:
|
282
|
+
return CALLBACK_TYPE.TOUCHES_MOVE;
|
283
|
+
case EventType.TOUCHES_UP:
|
284
|
+
return CALLBACK_TYPE.TOUCHES_UP;
|
285
|
+
case EventType.TOUCHES_CANCELLED:
|
286
|
+
return CALLBACK_TYPE.TOUCHES_CANCELLED;
|
287
|
+
}
|
288
|
+
return CALLBACK_TYPE.UNDEFINED;
|
289
|
+
}
|
290
|
+
|
291
|
+
function runWorklet(
|
292
|
+
type: CALLBACK_TYPE,
|
293
|
+
gesture: HandlerCallbacks<Record<string, unknown>>,
|
294
|
+
event: GestureStateChangeEvent | GestureUpdateEvent | GestureTouchEvent,
|
295
|
+
...args: any[]
|
296
|
+
) {
|
297
|
+
'worklet';
|
298
|
+
const handler = getHandler(type, gesture);
|
299
|
+
if (gesture.isWorklet[type]) {
|
300
|
+
// @ts-ignore Logic below makes sure the correct event is send to the
|
301
|
+
// correct handler.
|
302
|
+
handler?.(event, ...args);
|
303
|
+
} else if (handler) {
|
304
|
+
console.warn('Animated gesture callback must be a worklet');
|
305
|
+
}
|
306
|
+
}
|
307
|
+
|
308
|
+
// Hooks are called conditionally, but the condition is whether the
|
309
|
+
// react-native-reanimated is installed, which shouldn't change while running
|
310
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks
|
311
|
+
const sharedHandlersCallbacks = Reanimated.useSharedValue<
|
312
|
+
HandlerCallbacks<Record<string, unknown>>[] | null
|
313
|
+
>(null);
|
314
|
+
|
315
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks
|
316
|
+
const lastUpdateEvent = Reanimated.useSharedValue<
|
317
|
+
(GestureUpdateEvent | undefined)[]
|
318
|
+
>([]);
|
319
|
+
|
320
|
+
// not every gesture needs a state controller, init them lazily
|
321
|
+
const stateControllers: GestureStateManagerType[] = [];
|
322
|
+
|
323
|
+
const callback = (
|
324
|
+
event: GestureStateChangeEvent | GestureUpdateEvent | GestureTouchEvent
|
325
|
+
) => {
|
326
|
+
'worklet';
|
327
|
+
|
328
|
+
const currentCallback = sharedHandlersCallbacks.value;
|
329
|
+
if (!currentCallback) {
|
330
|
+
return;
|
331
|
+
}
|
332
|
+
|
333
|
+
for (let i = 0; i < currentCallback.length; i++) {
|
334
|
+
const gesture = currentCallback[i];
|
335
|
+
|
336
|
+
if (event.handlerTag === gesture.handlerTag) {
|
337
|
+
if (isStateChangeEvent(event)) {
|
338
|
+
if (
|
339
|
+
event.oldState === State.UNDETERMINED &&
|
340
|
+
event.state === State.BEGAN
|
341
|
+
) {
|
342
|
+
runWorklet(CALLBACK_TYPE.BEGAN, gesture, event);
|
343
|
+
} else if (
|
344
|
+
(event.oldState === State.BEGAN ||
|
345
|
+
event.oldState === State.UNDETERMINED) &&
|
346
|
+
event.state === State.ACTIVE
|
347
|
+
) {
|
348
|
+
runWorklet(CALLBACK_TYPE.START, gesture, event);
|
349
|
+
lastUpdateEvent.value[gesture.handlerTag] = undefined;
|
350
|
+
} else if (
|
351
|
+
event.oldState !== event.state &&
|
352
|
+
event.state === State.END
|
353
|
+
) {
|
354
|
+
if (event.oldState === State.ACTIVE) {
|
355
|
+
runWorklet(CALLBACK_TYPE.END, gesture, event, true);
|
356
|
+
}
|
357
|
+
runWorklet(CALLBACK_TYPE.FINALIZE, gesture, event, true);
|
358
|
+
} else if (
|
359
|
+
(event.state === State.FAILED || event.state === State.CANCELLED) &&
|
360
|
+
event.state !== event.oldState
|
361
|
+
) {
|
362
|
+
if (event.oldState === State.ACTIVE) {
|
363
|
+
runWorklet(CALLBACK_TYPE.END, gesture, event, false);
|
364
|
+
}
|
365
|
+
runWorklet(CALLBACK_TYPE.FINALIZE, gesture, event, false);
|
366
|
+
}
|
367
|
+
} else if (isTouchEvent(event)) {
|
368
|
+
if (!stateControllers[i]) {
|
369
|
+
stateControllers[i] = GestureStateManager.create(event.handlerTag);
|
370
|
+
}
|
371
|
+
|
372
|
+
if (event.eventType !== EventType.UNDETERMINED) {
|
373
|
+
runWorklet(
|
374
|
+
touchEventTypeToCallbackType(event.eventType),
|
375
|
+
gesture,
|
376
|
+
event,
|
377
|
+
stateControllers[i]
|
378
|
+
);
|
379
|
+
}
|
380
|
+
} else {
|
381
|
+
runWorklet(CALLBACK_TYPE.UPDATE, gesture, event);
|
382
|
+
|
383
|
+
if (gesture.onChange && gesture.changeEventCalculator) {
|
384
|
+
runWorklet(
|
385
|
+
CALLBACK_TYPE.CHANGE,
|
386
|
+
gesture,
|
387
|
+
gesture.changeEventCalculator?.(
|
388
|
+
event,
|
389
|
+
lastUpdateEvent.value[gesture.handlerTag]
|
390
|
+
)
|
391
|
+
);
|
392
|
+
|
393
|
+
lastUpdateEvent.value[gesture.handlerTag] = event;
|
394
|
+
}
|
395
|
+
}
|
396
|
+
}
|
397
|
+
}
|
398
|
+
};
|
399
|
+
|
400
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks
|
401
|
+
const event = Reanimated.useEvent(
|
402
|
+
callback,
|
403
|
+
['onGestureHandlerStateChange', 'onGestureHandlerEvent'],
|
404
|
+
true
|
405
|
+
);
|
406
|
+
|
407
|
+
preparedGesture.animatedEventHandler = event;
|
408
|
+
preparedGesture.animatedHandlers = sharedHandlersCallbacks;
|
409
|
+
}
|
410
|
+
|
411
|
+
interface GestureDetectorProps {
|
412
|
+
gesture?: ComposedGesture | GestureType;
|
413
|
+
}
|
414
|
+
export const GestureDetector: React.FunctionComponent<GestureDetectorProps> = (
|
415
|
+
props
|
416
|
+
) => {
|
417
|
+
const gestureConfig = props.gesture;
|
418
|
+
const gesture = gestureConfig?.toGestureArray?.() ?? [];
|
419
|
+
const useAnimated =
|
420
|
+
gesture.find((gesture) =>
|
421
|
+
gesture.handlers.isWorklet.reduce((prev, current) => prev || current)
|
422
|
+
) != null;
|
423
|
+
const viewRef = useRef(null);
|
424
|
+
const firstRenderRef = useRef(true);
|
425
|
+
|
426
|
+
const preparedGesture = React.useRef<GestureConfigReference>({
|
427
|
+
config: gesture,
|
428
|
+
animatedEventHandler: null,
|
429
|
+
animatedHandlers: null,
|
430
|
+
firstExecution: true,
|
431
|
+
useAnimated: useAnimated,
|
432
|
+
}).current;
|
433
|
+
|
434
|
+
if (useAnimated !== preparedGesture.useAnimated) {
|
435
|
+
throw new Error(
|
436
|
+
'You cannot change whether you are using gesture or animatedGesture while the app is running'
|
437
|
+
);
|
438
|
+
}
|
439
|
+
|
440
|
+
if (preparedGesture.firstExecution) {
|
441
|
+
gestureConfig?.initialize?.();
|
442
|
+
}
|
443
|
+
|
444
|
+
if (useAnimated) {
|
445
|
+
// Whether animatedGesture or gesture is used shouldn't change
|
446
|
+
// during while an app is running
|
447
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks
|
448
|
+
useAnimatedGesture(preparedGesture);
|
449
|
+
}
|
450
|
+
|
451
|
+
useEffect(() => {
|
452
|
+
firstRenderRef.current = true;
|
453
|
+
const viewTag = findNodeHandle(viewRef.current) as number;
|
454
|
+
attachHandlers({
|
455
|
+
preparedGesture,
|
456
|
+
gestureConfig,
|
457
|
+
gesture,
|
458
|
+
viewTag,
|
459
|
+
useAnimated,
|
460
|
+
});
|
461
|
+
|
462
|
+
return () => {
|
463
|
+
dropHandlers(preparedGesture);
|
464
|
+
};
|
465
|
+
}, []);
|
466
|
+
|
467
|
+
useEffect(() => {
|
468
|
+
if (!firstRenderRef.current) {
|
469
|
+
const viewTag = findNodeHandle(viewRef.current) as number;
|
470
|
+
|
471
|
+
if (needsToReattach(preparedGesture, gesture)) {
|
472
|
+
dropHandlers(preparedGesture);
|
473
|
+
attachHandlers({
|
474
|
+
preparedGesture,
|
475
|
+
gestureConfig,
|
476
|
+
gesture,
|
477
|
+
viewTag,
|
478
|
+
useAnimated,
|
479
|
+
});
|
480
|
+
} else {
|
481
|
+
updateHandlers(preparedGesture, gestureConfig, gesture);
|
482
|
+
}
|
483
|
+
} else {
|
484
|
+
firstRenderRef.current = false;
|
485
|
+
}
|
486
|
+
}, [props]);
|
487
|
+
|
488
|
+
if (useAnimated) {
|
489
|
+
return (
|
490
|
+
<AnimatedWrap
|
491
|
+
ref={viewRef}
|
492
|
+
onGestureHandlerEvent={preparedGesture.animatedEventHandler}>
|
493
|
+
{props.children}
|
494
|
+
</AnimatedWrap>
|
495
|
+
);
|
496
|
+
} else {
|
497
|
+
return <Wrap ref={viewRef}>{props.children}</Wrap>;
|
498
|
+
}
|
499
|
+
};
|
500
|
+
|
501
|
+
class Wrap extends React.Component<{ onGestureHandlerEvent?: unknown }> {
|
502
|
+
render() {
|
503
|
+
// I don't think that fighting with types over such a simple function is worth it
|
504
|
+
// The only thing it does is add 'collapsable: false' to the child component
|
505
|
+
// to make sure it is in the native view hierarchy so the detector can find
|
506
|
+
// correct viewTag to attach to.
|
507
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
508
|
+
const child: any = React.Children.only(this.props.children);
|
509
|
+
|
510
|
+
return React.cloneElement(
|
511
|
+
child,
|
512
|
+
{ collapsable: false },
|
513
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
|
514
|
+
child.props.children
|
515
|
+
);
|
516
|
+
}
|
517
|
+
}
|
518
|
+
|
519
|
+
const AnimatedWrap = Reanimated?.default?.createAnimatedComponent(Wrap) ?? Wrap;
|
@@ -0,0 +1,151 @@
|
|
1
|
+
import { DeviceEventEmitter, EmitterSubscription } from 'react-native';
|
2
|
+
import { State } from '../../State';
|
3
|
+
import { EventType } from '../../EventType';
|
4
|
+
import {
|
5
|
+
GestureTouchEvent,
|
6
|
+
GestureUpdateEvent,
|
7
|
+
GestureStateChangeEvent,
|
8
|
+
} from '../gestureHandlerCommon';
|
9
|
+
import { GestureStateManagerType } from './gestureStateManager';
|
10
|
+
import { findHandler } from '../handlersRegistry';
|
11
|
+
import { BaseGesture } from './gesture';
|
12
|
+
|
13
|
+
let gestureHandlerEventSubscription: EmitterSubscription | null = null;
|
14
|
+
let gestureHandlerStateChangeEventSubscription: EmitterSubscription | null = null;
|
15
|
+
|
16
|
+
const dummyStateManager: GestureStateManagerType = {
|
17
|
+
begin: () => {
|
18
|
+
console.warn(
|
19
|
+
'You have to use react-native-reanimated in order to control the state of the gesture.'
|
20
|
+
);
|
21
|
+
},
|
22
|
+
activate: () => {
|
23
|
+
console.warn(
|
24
|
+
'You have to use react-native-reanimated in order to control the state of the gesture.'
|
25
|
+
);
|
26
|
+
},
|
27
|
+
end: () => {
|
28
|
+
console.warn(
|
29
|
+
'You have to use react-native-reanimated in order to control the state of the gesture.'
|
30
|
+
);
|
31
|
+
},
|
32
|
+
fail: () => {
|
33
|
+
console.warn(
|
34
|
+
'You have to use react-native-reanimated in order to control the state of the gesture.'
|
35
|
+
);
|
36
|
+
},
|
37
|
+
};
|
38
|
+
|
39
|
+
const lastUpdateEvent: (GestureUpdateEvent | undefined)[] = [];
|
40
|
+
|
41
|
+
function isStateChangeEvent(
|
42
|
+
event: GestureUpdateEvent | GestureStateChangeEvent | GestureTouchEvent
|
43
|
+
): event is GestureStateChangeEvent {
|
44
|
+
// @ts-ignore oldState doesn't exist on GestureTouchEvent and that's the point
|
45
|
+
return event.oldState != null;
|
46
|
+
}
|
47
|
+
|
48
|
+
function isTouchEvent(
|
49
|
+
event: GestureUpdateEvent | GestureStateChangeEvent | GestureTouchEvent
|
50
|
+
): event is GestureTouchEvent {
|
51
|
+
return event.eventType != null;
|
52
|
+
}
|
53
|
+
|
54
|
+
function onGestureHandlerEvent(
|
55
|
+
event: GestureUpdateEvent | GestureStateChangeEvent | GestureTouchEvent
|
56
|
+
) {
|
57
|
+
const handler = findHandler(event.handlerTag) as BaseGesture<
|
58
|
+
Record<string, unknown>
|
59
|
+
>;
|
60
|
+
|
61
|
+
if (handler) {
|
62
|
+
if (isStateChangeEvent(event)) {
|
63
|
+
if (
|
64
|
+
event.oldState === State.UNDETERMINED &&
|
65
|
+
event.state === State.BEGAN
|
66
|
+
) {
|
67
|
+
handler.handlers.onBegin?.(event);
|
68
|
+
} else if (
|
69
|
+
(event.oldState === State.BEGAN ||
|
70
|
+
event.oldState === State.UNDETERMINED) &&
|
71
|
+
event.state === State.ACTIVE
|
72
|
+
) {
|
73
|
+
handler.handlers.onStart?.(event);
|
74
|
+
lastUpdateEvent[handler.handlers.handlerTag] = event;
|
75
|
+
} else if (event.oldState !== event.state && event.state === State.END) {
|
76
|
+
if (event.oldState === State.ACTIVE) {
|
77
|
+
handler.handlers.onEnd?.(event, true);
|
78
|
+
}
|
79
|
+
handler.handlers.onFinalize?.(event, true);
|
80
|
+
lastUpdateEvent[handler.handlers.handlerTag] = undefined;
|
81
|
+
} else if (
|
82
|
+
(event.state === State.FAILED || event.state === State.CANCELLED) &&
|
83
|
+
event.oldState !== event.state
|
84
|
+
) {
|
85
|
+
if (event.oldState === State.ACTIVE) {
|
86
|
+
handler.handlers.onEnd?.(event, false);
|
87
|
+
}
|
88
|
+
handler.handlers.onFinalize?.(event, false);
|
89
|
+
lastUpdateEvent[handler.handlers.handlerTag] = undefined;
|
90
|
+
}
|
91
|
+
} else if (isTouchEvent(event)) {
|
92
|
+
switch (event.eventType) {
|
93
|
+
case EventType.TOUCHES_DOWN:
|
94
|
+
handler.handlers?.onTouchesDown?.(event, dummyStateManager);
|
95
|
+
break;
|
96
|
+
case EventType.TOUCHES_MOVE:
|
97
|
+
handler.handlers?.onTouchesMove?.(event, dummyStateManager);
|
98
|
+
break;
|
99
|
+
case EventType.TOUCHES_UP:
|
100
|
+
handler.handlers?.onTouchesUp?.(event, dummyStateManager);
|
101
|
+
break;
|
102
|
+
case EventType.TOUCHES_CANCELLED:
|
103
|
+
handler.handlers?.onTouchesCancelled?.(event, dummyStateManager);
|
104
|
+
break;
|
105
|
+
}
|
106
|
+
} else {
|
107
|
+
handler.handlers.onUpdate?.(event);
|
108
|
+
|
109
|
+
if (handler.handlers.onChange && handler.handlers.changeEventCalculator) {
|
110
|
+
handler.handlers.onChange?.(
|
111
|
+
handler.handlers.changeEventCalculator?.(
|
112
|
+
event,
|
113
|
+
lastUpdateEvent[handler.handlers.handlerTag]
|
114
|
+
)
|
115
|
+
);
|
116
|
+
|
117
|
+
lastUpdateEvent[handler.handlers.handlerTag] = event;
|
118
|
+
}
|
119
|
+
}
|
120
|
+
}
|
121
|
+
}
|
122
|
+
|
123
|
+
export function startListening() {
|
124
|
+
stopListening();
|
125
|
+
|
126
|
+
gestureHandlerEventSubscription = DeviceEventEmitter.addListener(
|
127
|
+
'onGestureHandlerEvent',
|
128
|
+
onGestureHandlerEvent
|
129
|
+
);
|
130
|
+
|
131
|
+
gestureHandlerStateChangeEventSubscription = DeviceEventEmitter.addListener(
|
132
|
+
'onGestureHandlerStateChange',
|
133
|
+
onGestureHandlerEvent
|
134
|
+
);
|
135
|
+
}
|
136
|
+
|
137
|
+
export function stopListening() {
|
138
|
+
if (gestureHandlerEventSubscription) {
|
139
|
+
DeviceEventEmitter.removeSubscription(gestureHandlerEventSubscription);
|
140
|
+
|
141
|
+
gestureHandlerEventSubscription = null;
|
142
|
+
}
|
143
|
+
|
144
|
+
if (gestureHandlerStateChangeEventSubscription) {
|
145
|
+
DeviceEventEmitter.removeSubscription(
|
146
|
+
gestureHandlerStateChangeEventSubscription
|
147
|
+
);
|
148
|
+
|
149
|
+
gestureHandlerStateChangeEventSubscription = null;
|
150
|
+
}
|
151
|
+
}
|
@@ -0,0 +1,27 @@
|
|
1
|
+
import { BaseGesture, BaseGestureConfig } from './gesture';
|
2
|
+
import {
|
3
|
+
FlingGestureConfig,
|
4
|
+
FlingGestureHandlerEventPayload,
|
5
|
+
} from '../FlingGestureHandler';
|
6
|
+
|
7
|
+
export class FlingGesture extends BaseGesture<FlingGestureHandlerEventPayload> {
|
8
|
+
public config: BaseGestureConfig & FlingGestureConfig = {};
|
9
|
+
|
10
|
+
constructor() {
|
11
|
+
super();
|
12
|
+
|
13
|
+
this.handlerName = 'FlingGestureHandler';
|
14
|
+
}
|
15
|
+
|
16
|
+
numberOfPointers(pointers: number) {
|
17
|
+
this.config.numberOfPointers = pointers;
|
18
|
+
return this;
|
19
|
+
}
|
20
|
+
|
21
|
+
direction(direction: number) {
|
22
|
+
this.config.direction = direction;
|
23
|
+
return this;
|
24
|
+
}
|
25
|
+
}
|
26
|
+
|
27
|
+
export type FlingGestureType = InstanceType<typeof FlingGesture>;
|