@react-native-oh-tpl/react-native-gesture-handler 2.12.1-0.0.1 → 2.12.6-2
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +1 -62
- package/{LICENSE → harmony/gesture_handler/LICENSE} +21 -21
- package/harmony/gesture_handler/OAT.xml +44 -0
- package/harmony/gesture_handler/README.OpenSource +11 -0
- package/harmony/gesture_handler/README.md +1 -0
- package/harmony/gesture_handler/build-profile.json5 +8 -0
- package/harmony/gesture_handler/hvigorfile.ts +2 -0
- package/harmony/gesture_handler/index.ets +3 -0
- package/harmony/gesture_handler/oh-package.json5 +13 -0
- package/harmony/gesture_handler/src/main/cpp/CMakeLists.txt +8 -0
- package/harmony/gesture_handler/src/main/cpp/GestureHandlerPackage.cpp +34 -0
- package/harmony/gesture_handler/src/main/cpp/GestureHandlerPackage.h +15 -0
- package/harmony/gesture_handler/src/main/cpp/RNGestureHandlerButtonComponentDescriptor.h +60 -0
- package/harmony/gesture_handler/src/main/cpp/RNGestureHandlerModule.cpp +17 -0
- package/harmony/gesture_handler/src/main/cpp/RNGestureHandlerModule.h +12 -0
- package/harmony/gesture_handler/src/main/cpp/RNGestureHandlerRootViewComponentDescriptor.h +60 -0
- package/{src/web/tools → harmony/gesture_handler/src/main/ets}/CircularBuffer.ts +42 -42
- package/harmony/gesture_handler/src/main/ets/Event.ts +68 -0
- package/harmony/gesture_handler/src/main/ets/EventDispatcher.ts +38 -0
- package/harmony/gesture_handler/src/main/ets/GestureHandler.ts +663 -0
- package/harmony/gesture_handler/src/main/ets/GestureHandlerArkUIAdapter.ets +202 -0
- package/harmony/gesture_handler/src/main/ets/GestureHandlerFactory.ts +45 -0
- package/harmony/gesture_handler/src/main/ets/GestureHandlerOrchestrator.ts +280 -0
- package/harmony/gesture_handler/src/main/ets/GestureHandlerPackage.ts +22 -0
- package/harmony/gesture_handler/src/main/ets/GestureHandlerRegistry.ts +28 -0
- package/{src/web/tools → harmony/gesture_handler/src/main/ets}/InteractionManager.ts +109 -130
- package/{src/web/tools → harmony/gesture_handler/src/main/ets}/LeastSquareSolver.ts +182 -182
- package/harmony/gesture_handler/src/main/ets/NativeViewGestureHandler.ts +115 -0
- package/harmony/gesture_handler/src/main/ets/OutgoingEvent.ts +34 -0
- package/harmony/gesture_handler/src/main/ets/PanGestureHandler.ts +328 -0
- package/{src/web/tools → harmony/gesture_handler/src/main/ets}/PointerTracker.ts +239 -240
- package/harmony/gesture_handler/src/main/ets/RNGHError.ts +5 -0
- package/harmony/gesture_handler/src/main/ets/RNGHLogger.ts +29 -0
- package/harmony/gesture_handler/src/main/ets/RNGHRootTouchHandler.ets +58 -0
- package/harmony/gesture_handler/src/main/ets/RNGestureHandlerButton.ets +37 -0
- package/harmony/gesture_handler/src/main/ets/RNGestureHandlerModule.ts +125 -0
- package/harmony/gesture_handler/src/main/ets/RNGestureHandlerRootView.ets +57 -0
- package/harmony/gesture_handler/src/main/ets/RNOHScrollLocker.ts +11 -0
- package/harmony/gesture_handler/src/main/ets/State.ts +47 -0
- package/harmony/gesture_handler/src/main/ets/TapGestureHandler.ts +206 -0
- package/harmony/gesture_handler/src/main/ets/Vector2D.ts +36 -0
- package/{src/web/tools → harmony/gesture_handler/src/main/ets}/VelocityTracker.ts +98 -98
- package/harmony/gesture_handler/src/main/ets/View.ts +71 -0
- package/harmony/gesture_handler/src/main/ets/ViewRegistry.ts +43 -0
- package/harmony/gesture_handler/src/main/ets/pages/Index.ets +17 -0
- package/harmony/gesture_handler/src/main/ets/webviewability/WebviewAbility.ts +41 -0
- package/harmony/gesture_handler/src/main/module.json5 +7 -0
- package/harmony/gesture_handler/src/main/resources/base/element/color.json +8 -0
- package/harmony/gesture_handler/src/main/resources/base/element/string.json +16 -0
- package/harmony/gesture_handler/src/main/resources/base/media/icon.png +0 -0
- package/harmony/gesture_handler/src/main/resources/base/profile/main_pages.json +5 -0
- package/harmony/gesture_handler/src/main/resources/en_US/element/string.json +16 -0
- package/harmony/gesture_handler/src/main/resources/zh_CN/element/string.json +16 -0
- package/harmony/gesture_handler/ts.ts +1 -0
- package/harmony/gesture_handler.har +0 -0
- package/lib/commonjs/RNGestureHandlerModule.js +2 -22
- package/lib/commonjs/RNGestureHandlerModule.js.map +1 -1
- package/lib/commonjs/components/GestureButtons.js +88 -142
- package/lib/commonjs/components/GestureButtons.js.map +1 -1
- package/lib/commonjs/components/GestureHandlerButton.js +2 -7
- package/lib/commonjs/components/GestureHandlerButton.js.map +1 -1
- package/lib/commonjs/components/GestureHandlerRootView.js +13 -13
- package/lib/commonjs/components/GestureHandlerRootView.js.map +1 -1
- package/lib/commonjs/components/RNGestureHandlerButton.js +23 -0
- package/lib/commonjs/components/RNGestureHandlerButton.js.map +1 -0
- package/lib/commonjs/components/touchables/GenericTouchable.js +103 -145
- package/lib/commonjs/components/touchables/GenericTouchable.js.map +1 -1
- package/lib/commonjs/components/touchables/TouchableOpacity.js +34 -53
- package/lib/commonjs/components/touchables/TouchableOpacity.js.map +1 -1
- package/lib/commonjs/components/touchables/TouchableWithoutFeedback.js +4 -12
- package/lib/commonjs/components/touchables/TouchableWithoutFeedback.js.map +1 -1
- package/lib/commonjs/components/touchables/index.js +2 -21
- package/lib/commonjs/components/touchables/index.js.map +1 -1
- package/lib/commonjs/handlers/NativeViewGestureHandler.js +6 -14
- package/lib/commonjs/handlers/NativeViewGestureHandler.js.map +1 -1
- package/lib/commonjs/handlers/PanGestureHandler.js +12 -32
- package/lib/commonjs/handlers/PanGestureHandler.js.map +1 -1
- package/lib/commonjs/handlers/TapGestureHandler.js +6 -11
- package/lib/commonjs/handlers/TapGestureHandler.js.map +1 -1
- package/lib/commonjs/handlers/createHandler.js +141 -223
- package/lib/commonjs/handlers/createHandler.js.map +1 -1
- package/lib/commonjs/handlers/createNativeWrapper.js +22 -32
- package/lib/commonjs/handlers/createNativeWrapper.js.map +1 -1
- package/lib/commonjs/handlers/gestureHandlerCommon.js +6 -87
- package/lib/commonjs/handlers/gestureHandlerCommon.js.map +1 -1
- package/lib/commonjs/handlers/gestures/GestureDetector.js +111 -226
- package/lib/commonjs/handlers/gestures/GestureDetector.js.map +1 -1
- package/lib/commonjs/index.js +168 -211
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/init.js +7 -15
- package/lib/commonjs/init.js.map +1 -1
- package/lib/module/RNGestureHandlerModule.js +2 -18
- package/lib/module/RNGestureHandlerModule.js.map +1 -1
- package/lib/module/components/GestureButtons.js +83 -121
- package/lib/module/components/GestureButtons.js.map +1 -1
- package/lib/module/components/GestureHandlerButton.js +2 -2
- package/lib/module/components/GestureHandlerButton.js.map +1 -1
- package/lib/module/components/GestureHandlerRootView.js +11 -3
- package/lib/module/components/GestureHandlerRootView.js.map +1 -1
- package/lib/module/components/RNGestureHandlerButton.js +17 -0
- package/lib/module/components/RNGestureHandlerButton.js.map +1 -0
- package/lib/module/components/touchables/GenericTouchable.js +98 -133
- package/lib/module/components/touchables/GenericTouchable.js.map +1 -1
- package/lib/module/components/touchables/TouchableOpacity.js +29 -43
- package/lib/module/components/touchables/TouchableOpacity.js.map +1 -1
- package/lib/module/components/touchables/TouchableWithoutFeedback.js +1 -2
- package/lib/module/components/touchables/TouchableWithoutFeedback.js.map +1 -1
- package/lib/module/components/touchables/index.js +5 -2
- package/lib/module/components/touchables/index.js.map +1 -1
- package/lib/module/handlers/NativeViewGestureHandler.js +1 -1
- package/lib/module/handlers/NativeViewGestureHandler.js.map +1 -1
- package/lib/module/handlers/PanGestureHandler.js +6 -21
- package/lib/module/handlers/PanGestureHandler.js.map +1 -1
- package/lib/module/handlers/TapGestureHandler.js +2 -1
- package/lib/module/handlers/TapGestureHandler.js.map +1 -1
- package/lib/module/handlers/createHandler.js +140 -196
- package/lib/module/handlers/createHandler.js.map +1 -1
- package/lib/module/handlers/createNativeWrapper.js +17 -22
- package/lib/module/handlers/createNativeWrapper.js.map +1 -1
- package/lib/module/handlers/gestureHandlerCommon.js +5 -71
- package/lib/module/handlers/gestureHandlerCommon.js.map +1 -1
- package/lib/module/handlers/gestures/GestureDetector.js +99 -175
- package/lib/module/handlers/gestures/GestureDetector.js.map +1 -1
- package/lib/module/index.js +160 -18
- package/lib/module/index.js.map +1 -1
- package/lib/module/init.js +6 -5
- package/lib/module/init.js.map +1 -1
- package/lib/typescript/RNGestureHandlerModule.d.ts +7 -13
- package/lib/typescript/RNGestureHandlerModule.d.ts.map +1 -0
- package/lib/typescript/components/GestureButtons.d.ts +122 -121
- package/lib/typescript/components/GestureButtons.d.ts.map +1 -0
- package/lib/typescript/components/GestureHandlerButton.d.ts +5 -4
- package/lib/typescript/components/GestureHandlerButton.d.ts.map +1 -0
- package/lib/typescript/components/GestureHandlerRootView.d.ts +7 -6
- package/lib/typescript/components/GestureHandlerRootView.d.ts.map +1 -0
- package/lib/typescript/components/RNGestureHandlerButton.d.ts +2 -0
- package/lib/typescript/components/RNGestureHandlerButton.d.ts.map +1 -0
- package/lib/typescript/components/touchables/GenericTouchable.d.ts +68 -68
- package/lib/typescript/components/touchables/GenericTouchable.d.ts.map +1 -0
- package/lib/typescript/components/touchables/TouchableOpacity.d.ts +26 -25
- package/lib/typescript/components/touchables/TouchableOpacity.d.ts.map +1 -0
- package/lib/typescript/components/touchables/TouchableWithoutFeedback.d.ts +8 -7
- package/lib/typescript/components/touchables/TouchableWithoutFeedback.d.ts.map +1 -0
- package/lib/typescript/components/touchables/index.d.ts +4 -7
- package/lib/typescript/components/touchables/index.d.ts.map +1 -0
- package/lib/typescript/handlers/NativeViewGestureHandler.d.ts +29 -28
- package/lib/typescript/handlers/NativeViewGestureHandler.d.ts.map +1 -0
- package/lib/typescript/handlers/PanGestureHandler.d.ts +140 -139
- package/lib/typescript/handlers/PanGestureHandler.d.ts.map +1 -0
- package/lib/typescript/handlers/TapGestureHandler.d.ts +58 -57
- package/lib/typescript/handlers/TapGestureHandler.d.ts.map +1 -0
- package/lib/typescript/handlers/createHandler.d.ts +12 -11
- package/lib/typescript/handlers/createHandler.d.ts.map +1 -0
- package/lib/typescript/handlers/createNativeWrapper.d.ts +4 -3
- package/lib/typescript/handlers/createNativeWrapper.d.ts.map +1 -0
- package/lib/typescript/handlers/gestureHandlerCommon.d.ts +2 -68
- package/lib/typescript/handlers/gestureHandlerCommon.d.ts.map +1 -0
- package/lib/typescript/handlers/gestures/GestureDetector.d.ts +24 -19
- package/lib/typescript/handlers/gestures/GestureDetector.d.ts.map +1 -0
- package/lib/typescript/index.d.ts +9 -52
- package/lib/typescript/index.d.ts.map +1 -0
- package/lib/typescript/init.d.ts +3 -2
- package/lib/typescript/init.d.ts.map +1 -0
- package/package.json +70 -156
- package/src/RNGestureHandlerModule.ts +6 -50
- package/src/components/GestureButtons.tsx +334 -332
- package/src/components/GestureHandlerButton.tsx +5 -5
- package/src/components/GestureHandlerRootView.tsx +34 -23
- package/src/components/RNGestureHandlerButton.tsx +23 -0
- package/src/components/touchables/GenericTouchable.tsx +301 -301
- package/src/components/touchables/TouchableOpacity.tsx +76 -75
- package/src/components/touchables/TouchableWithoutFeedback.tsx +14 -14
- package/src/components/touchables/index.ts +7 -7
- package/src/handlers/NativeViewGestureHandler.ts +55 -55
- package/src/handlers/PanGestureHandler.ts +327 -325
- package/src/handlers/TapGestureHandler.ts +95 -94
- package/src/handlers/createHandler.tsx +535 -533
- package/src/handlers/createNativeWrapper.tsx +81 -80
- package/src/handlers/gestureHandlerCommon.ts +15 -250
- package/src/handlers/gestures/GestureDetector.tsx +823 -822
- package/src/index.ts +172 -174
- package/src/init.ts +18 -18
- package/DrawerLayout/package.json +0 -6
- package/RNGestureHandler.podspec +0 -44
- package/Swipeable/package.json +0 -6
- package/android/build.gradle +0 -209
- package/android/common/src/main/java/com/swmansion/common/GestureHandlerStateManager.kt +0 -5
- package/android/fabric/src/main/java/com/swmansion/gesturehandler/RNGestureHandlerComponentsRegistry.java +0 -29
- package/android/fabric/src/main/java/com/swmansion/gesturehandler/ReactContextExtensions.kt +0 -12
- package/android/gradle.properties +0 -19
- package/android/noreanimated/src/main/java/com/swmansion/gesturehandler/ReanimatedEventDispatcher.kt +0 -10
- package/android/paper/src/main/java/com/facebook/react/viewmanagers/RNGestureHandlerButtonManagerDelegate.java +0 -50
- package/android/paper/src/main/java/com/facebook/react/viewmanagers/RNGestureHandlerButtonManagerInterface.java +0 -23
- package/android/paper/src/main/java/com/facebook/react/viewmanagers/RNGestureHandlerRootViewManagerDelegate.java +0 -25
- package/android/paper/src/main/java/com/facebook/react/viewmanagers/RNGestureHandlerRootViewManagerInterface.java +0 -16
- package/android/paper/src/main/java/com/swmansion/gesturehandler/ReactContextExtensions.kt +0 -13
- package/android/reanimated/src/main/java/com/swmansion/gesturehandler/ReanimatedEventDispatcher.kt +0 -17
- package/android/src/main/AndroidManifest.xml +0 -3
- package/android/src/main/java/com/swmansion/gesturehandler/RNGestureHandlerPackage.kt +0 -21
- package/android/src/main/java/com/swmansion/gesturehandler/core/FlingGestureHandler.kt +0 -100
- package/android/src/main/java/com/swmansion/gesturehandler/core/GestureHandler.kt +0 -807
- package/android/src/main/java/com/swmansion/gesturehandler/core/GestureHandlerInteractionController.kt +0 -8
- package/android/src/main/java/com/swmansion/gesturehandler/core/GestureHandlerOrchestrator.kt +0 -671
- package/android/src/main/java/com/swmansion/gesturehandler/core/GestureHandlerRegistry.kt +0 -8
- package/android/src/main/java/com/swmansion/gesturehandler/core/GestureUtils.kt +0 -47
- package/android/src/main/java/com/swmansion/gesturehandler/core/HoverGestureHandler.kt +0 -120
- package/android/src/main/java/com/swmansion/gesturehandler/core/LongPressGestureHandler.kt +0 -100
- package/android/src/main/java/com/swmansion/gesturehandler/core/ManualGestureHandler.kt +0 -11
- package/android/src/main/java/com/swmansion/gesturehandler/core/NativeViewGestureHandler.kt +0 -257
- package/android/src/main/java/com/swmansion/gesturehandler/core/OnTouchEventListener.kt +0 -9
- package/android/src/main/java/com/swmansion/gesturehandler/core/PanGestureHandler.kt +0 -322
- package/android/src/main/java/com/swmansion/gesturehandler/core/PinchGestureHandler.kt +0 -103
- package/android/src/main/java/com/swmansion/gesturehandler/core/PointerEventsConfig.kt +0 -23
- package/android/src/main/java/com/swmansion/gesturehandler/core/RotationGestureDetector.kt +0 -125
- package/android/src/main/java/com/swmansion/gesturehandler/core/RotationGestureHandler.kt +0 -93
- package/android/src/main/java/com/swmansion/gesturehandler/core/ScaleGestureDetector.java +0 -558
- package/android/src/main/java/com/swmansion/gesturehandler/core/TapGestureHandler.kt +0 -168
- package/android/src/main/java/com/swmansion/gesturehandler/core/ViewConfigurationHelper.kt +0 -10
- package/android/src/main/java/com/swmansion/gesturehandler/react/Extensions.kt +0 -16
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerButtonViewManager.kt +0 -423
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerEnabledRootView.kt +0 -15
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerEvent.kt +0 -75
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerInteractionManager.kt +0 -74
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerModule.kt +0 -702
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRegistry.kt +0 -100
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootHelper.kt +0 -142
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootInterface.kt +0 -5
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootView.kt +0 -78
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootViewManager.kt +0 -51
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerStateChangeEvent.kt +0 -78
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerTouchEvent.kt +0 -69
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNViewConfigurationHelper.kt +0 -51
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/FlingGestureHandlerEventDataBuilder.kt +0 -30
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/GestureHandlerEventDataBuilder.kt +0 -22
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/HoverGestureHandlerEventDataBuilder.kt +0 -30
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/LongPressGestureHandlerEventDataBuilder.kt +0 -33
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/ManualGestureHandlerEventDataBuilder.kt +0 -5
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/NativeGestureHandlerEventDataBuilder.kt +0 -18
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/PanGestureHandlerEventDataBuilder.kt +0 -42
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/PinchGestureHandlerEventDataBuilder.kt +0 -30
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/RotationGestureHandlerEventDataBuilder.kt +0 -30
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/TapGestureHandlerEventDataBuilder.kt +0 -30
- package/android/src/main/jni/CMakeLists.txt +0 -37
- package/android/src/main/jni/cpp-adapter.cpp +0 -44
- package/ios/Handlers/RNFlingHandler.h +0 -4
- package/ios/Handlers/RNFlingHandler.m +0 -152
- package/ios/Handlers/RNForceTouchHandler.h +0 -4
- package/ios/Handlers/RNForceTouchHandler.m +0 -175
- package/ios/Handlers/RNHoverHandler.h +0 -12
- package/ios/Handlers/RNHoverHandler.m +0 -153
- package/ios/Handlers/RNLongPressHandler.h +0 -12
- package/ios/Handlers/RNLongPressHandler.m +0 -183
- package/ios/Handlers/RNManualHandler.h +0 -4
- package/ios/Handlers/RNManualHandler.m +0 -88
- package/ios/Handlers/RNNativeViewHandler.h +0 -15
- package/ios/Handlers/RNNativeViewHandler.mm +0 -193
- package/ios/Handlers/RNPanHandler.h +0 -12
- package/ios/Handlers/RNPanHandler.m +0 -331
- package/ios/Handlers/RNPinchHandler.h +0 -12
- package/ios/Handlers/RNPinchHandler.m +0 -95
- package/ios/Handlers/RNRotationHandler.h +0 -12
- package/ios/Handlers/RNRotationHandler.m +0 -93
- package/ios/Handlers/RNTapHandler.h +0 -12
- package/ios/Handlers/RNTapHandler.m +0 -265
- package/ios/RNGHTouchEventType.h +0 -9
- package/ios/RNGestureHandler.h +0 -90
- package/ios/RNGestureHandler.m +0 -493
- package/ios/RNGestureHandler.xcodeproj/project.pbxproj +0 -690
- package/ios/RNGestureHandler.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +0 -8
- package/ios/RNGestureHandlerActionType.h +0 -10
- package/ios/RNGestureHandlerButton.h +0 -19
- package/ios/RNGestureHandlerButton.m +0 -77
- package/ios/RNGestureHandlerButtonComponentView.h +0 -17
- package/ios/RNGestureHandlerButtonComponentView.mm +0 -64
- package/ios/RNGestureHandlerButtonManager.h +0 -5
- package/ios/RNGestureHandlerButtonManager.m +0 -34
- package/ios/RNGestureHandlerDirection.h +0 -8
- package/ios/RNGestureHandlerEvents.h +0 -65
- package/ios/RNGestureHandlerEvents.m +0 -260
- package/ios/RNGestureHandlerManager.h +0 -35
- package/ios/RNGestureHandlerManager.mm +0 -367
- package/ios/RNGestureHandlerModule.h +0 -7
- package/ios/RNGestureHandlerModule.mm +0 -320
- package/ios/RNGestureHandlerPointerTracker.h +0 -25
- package/ios/RNGestureHandlerPointerTracker.m +0 -243
- package/ios/RNGestureHandlerRegistry.h +0 -21
- package/ios/RNGestureHandlerRegistry.m +0 -63
- package/ios/RNGestureHandlerRootViewComponentView.mm +0 -21
- package/ios/RNGestureHandlerState.h +0 -10
- package/ios/RNGestureHandlerStateManager.h +0 -5
- package/ios/RNManualActivationRecognizer.h +0 -10
- package/ios/RNManualActivationRecognizer.m +0 -88
- package/ios/RNRootViewGestureRecognizer.h +0 -17
- package/ios/RNRootViewGestureRecognizer.m +0 -106
- package/jest-utils/package.json +0 -6
- package/jestSetup.js +0 -7
- package/lib/commonjs/ActionType.js +0 -15
- package/lib/commonjs/ActionType.js.map +0 -1
- package/lib/commonjs/Directions.js +0 -15
- package/lib/commonjs/Directions.js.map +0 -1
- package/lib/commonjs/EnableNewWebImplementation.js +0 -35
- package/lib/commonjs/EnableNewWebImplementation.js.map +0 -1
- package/lib/commonjs/GestureHandlerRootViewContext.js +0 -15
- package/lib/commonjs/GestureHandlerRootViewContext.js.map +0 -1
- package/lib/commonjs/PlatformConstants.js +0 -15
- package/lib/commonjs/PlatformConstants.js.map +0 -1
- package/lib/commonjs/PlatformConstants.web.js +0 -14
- package/lib/commonjs/PlatformConstants.web.js.map +0 -1
- package/lib/commonjs/RNGestureHandlerModule.macos.js +0 -149
- package/lib/commonjs/RNGestureHandlerModule.macos.js.map +0 -1
- package/lib/commonjs/RNGestureHandlerModule.web.js +0 -163
- package/lib/commonjs/RNGestureHandlerModule.web.js.map +0 -1
- package/lib/commonjs/RNGestureHandlerModule.windows.js +0 -158
- package/lib/commonjs/RNGestureHandlerModule.windows.js.map +0 -1
- package/lib/commonjs/RNRenderer.js +0 -16
- package/lib/commonjs/RNRenderer.js.map +0 -1
- package/lib/commonjs/RNRenderer.web.js +0 -11
- package/lib/commonjs/RNRenderer.web.js.map +0 -1
- package/lib/commonjs/State.js +0 -18
- package/lib/commonjs/State.js.map +0 -1
- package/lib/commonjs/TouchEventType.js +0 -16
- package/lib/commonjs/TouchEventType.js.map +0 -1
- package/lib/commonjs/components/DrawerLayout.js +0 -566
- package/lib/commonjs/components/DrawerLayout.js.map +0 -1
- package/lib/commonjs/components/GestureComponents.js +0 -115
- package/lib/commonjs/components/GestureComponents.js.map +0 -1
- package/lib/commonjs/components/GestureComponents.web.js +0 -52
- package/lib/commonjs/components/GestureComponents.web.js.map +0 -1
- package/lib/commonjs/components/GestureHandlerButton.web.js +0 -24
- package/lib/commonjs/components/GestureHandlerButton.web.js.map +0 -1
- package/lib/commonjs/components/GestureHandlerRootView.android.js +0 -31
- package/lib/commonjs/components/GestureHandlerRootView.android.js.map +0 -1
- package/lib/commonjs/components/GestureHandlerRootView.web.js +0 -25
- package/lib/commonjs/components/GestureHandlerRootView.web.js.map +0 -1
- package/lib/commonjs/components/Swipeable.js +0 -408
- package/lib/commonjs/components/Swipeable.js.map +0 -1
- package/lib/commonjs/components/gestureHandlerRootHOC.js +0 -40
- package/lib/commonjs/components/gestureHandlerRootHOC.js.map +0 -1
- package/lib/commonjs/components/touchables/TouchableHighlight.js +0 -109
- package/lib/commonjs/components/touchables/TouchableHighlight.js.map +0 -1
- package/lib/commonjs/components/touchables/TouchableNativeFeedback.android.js +0 -100
- package/lib/commonjs/components/touchables/TouchableNativeFeedback.android.js.map +0 -1
- package/lib/commonjs/components/touchables/TouchableNativeFeedback.js +0 -12
- package/lib/commonjs/components/touchables/TouchableNativeFeedback.js.map +0 -1
- package/lib/commonjs/getReactNativeVersion.js +0 -22
- package/lib/commonjs/getReactNativeVersion.js.map +0 -1
- package/lib/commonjs/getReactNativeVersion.web.js +0 -11
- package/lib/commonjs/getReactNativeVersion.web.js.map +0 -1
- package/lib/commonjs/getShadowNodeFromRef.js +0 -27
- package/lib/commonjs/getShadowNodeFromRef.js.map +0 -1
- package/lib/commonjs/getShadowNodeFromRef.web.js +0 -15
- package/lib/commonjs/getShadowNodeFromRef.web.js.map +0 -1
- package/lib/commonjs/ghQueueMicrotask.js +0 -12
- package/lib/commonjs/ghQueueMicrotask.js.map +0 -1
- package/lib/commonjs/handlers/FlingGestureHandler.js +0 -25
- package/lib/commonjs/handlers/FlingGestureHandler.js.map +0 -1
- package/lib/commonjs/handlers/ForceTouchGestureHandler.js +0 -49
- package/lib/commonjs/handlers/ForceTouchGestureHandler.js.map +0 -1
- package/lib/commonjs/handlers/LongPressGestureHandler.js +0 -27
- package/lib/commonjs/handlers/LongPressGestureHandler.js.map +0 -1
- package/lib/commonjs/handlers/PinchGestureHandler.js +0 -23
- package/lib/commonjs/handlers/PinchGestureHandler.js.map +0 -1
- package/lib/commonjs/handlers/PressabilityDebugView.js +0 -14
- package/lib/commonjs/handlers/PressabilityDebugView.js.map +0 -1
- package/lib/commonjs/handlers/PressabilityDebugView.web.js +0 -12
- package/lib/commonjs/handlers/PressabilityDebugView.web.js.map +0 -1
- package/lib/commonjs/handlers/RotationGestureHandler.js +0 -23
- package/lib/commonjs/handlers/RotationGestureHandler.js.map +0 -1
- package/lib/commonjs/handlers/gestureHandlerTypesCompat.js +0 -6
- package/lib/commonjs/handlers/gestureHandlerTypesCompat.js.map +0 -1
- package/lib/commonjs/handlers/gestures/eventReceiver.js +0 -147
- package/lib/commonjs/handlers/gestures/eventReceiver.js.map +0 -1
- package/lib/commonjs/handlers/gestures/flingGesture.js +0 -34
- package/lib/commonjs/handlers/gestures/flingGesture.js.map +0 -1
- package/lib/commonjs/handlers/gestures/forceTouchGesture.js +0 -65
- package/lib/commonjs/handlers/gestures/forceTouchGesture.js.map +0 -1
- package/lib/commonjs/handlers/gestures/gesture.js +0 -241
- package/lib/commonjs/handlers/gestures/gesture.js.map +0 -1
- package/lib/commonjs/handlers/gestures/gestureComposition.js +0 -105
- package/lib/commonjs/handlers/gestures/gestureComposition.js.map +0 -1
- package/lib/commonjs/handlers/gestures/gestureObjects.js +0 -90
- package/lib/commonjs/handlers/gestures/gestureObjects.js.map +0 -1
- package/lib/commonjs/handlers/gestures/gestureStateManager.js +0 -65
- package/lib/commonjs/handlers/gestures/gestureStateManager.js.map +0 -1
- package/lib/commonjs/handlers/gestures/gestureStateManager.web.js +0 -32
- package/lib/commonjs/handlers/gestures/gestureStateManager.web.js.map +0 -1
- package/lib/commonjs/handlers/gestures/hoverGesture.js +0 -74
- package/lib/commonjs/handlers/gestures/hoverGesture.js.map +0 -1
- package/lib/commonjs/handlers/gestures/longPressGesture.js +0 -35
- package/lib/commonjs/handlers/gestures/longPressGesture.js.map +0 -1
- package/lib/commonjs/handlers/gestures/manualGesture.js +0 -31
- package/lib/commonjs/handlers/gestures/manualGesture.js.map +0 -1
- package/lib/commonjs/handlers/gestures/nativeGesture.js +0 -34
- package/lib/commonjs/handlers/gestures/nativeGesture.js.map +0 -1
- package/lib/commonjs/handlers/gestures/panGesture.js +0 -149
- package/lib/commonjs/handlers/gestures/panGesture.js.map +0 -1
- package/lib/commonjs/handlers/gestures/pinchGesture.js +0 -45
- package/lib/commonjs/handlers/gestures/pinchGesture.js.map +0 -1
- package/lib/commonjs/handlers/gestures/reanimatedWrapper.js +0 -37
- package/lib/commonjs/handlers/gestures/reanimatedWrapper.js.map +0 -1
- package/lib/commonjs/handlers/gestures/rotationGesture.js +0 -45
- package/lib/commonjs/handlers/gestures/rotationGesture.js.map +0 -1
- package/lib/commonjs/handlers/gestures/tapGesture.js +0 -60
- package/lib/commonjs/handlers/gestures/tapGesture.js.map +0 -1
- package/lib/commonjs/handlers/handlersRegistry.js +0 -67
- package/lib/commonjs/handlers/handlersRegistry.js.map +0 -1
- package/lib/commonjs/jestUtils/index.js +0 -20
- package/lib/commonjs/jestUtils/index.js.map +0 -1
- package/lib/commonjs/jestUtils/jestUtils.js +0 -375
- package/lib/commonjs/jestUtils/jestUtils.js.map +0 -1
- package/lib/commonjs/mocks.js +0 -66
- package/lib/commonjs/mocks.js.map +0 -1
- package/lib/commonjs/specs/RNGestureHandlerButtonNativeComponent.js +0 -15
- package/lib/commonjs/specs/RNGestureHandlerButtonNativeComponent.js.map +0 -1
- package/lib/commonjs/specs/RNGestureHandlerRootViewNativeComponent.js +0 -15
- package/lib/commonjs/specs/RNGestureHandlerRootViewNativeComponent.js.map +0 -1
- package/lib/commonjs/typeUtils.js +0 -2
- package/lib/commonjs/typeUtils.js.map +0 -1
- package/lib/commonjs/utils.js +0 -63
- package/lib/commonjs/utils.js.map +0 -1
- package/lib/commonjs/web/constants.js +0 -16
- package/lib/commonjs/web/constants.js.map +0 -1
- package/lib/commonjs/web/detectors/RotationGestureDetector.js +0 -165
- package/lib/commonjs/web/detectors/RotationGestureDetector.js.map +0 -1
- package/lib/commonjs/web/detectors/ScaleGestureDetector.js +0 -156
- package/lib/commonjs/web/detectors/ScaleGestureDetector.js.map +0 -1
- package/lib/commonjs/web/handlers/FlingGestureHandler.js +0 -167
- package/lib/commonjs/web/handlers/FlingGestureHandler.js.map +0 -1
- package/lib/commonjs/web/handlers/GestureHandler.js +0 -794
- package/lib/commonjs/web/handlers/GestureHandler.js.map +0 -1
- package/lib/commonjs/web/handlers/HoverGestureHandler.js +0 -62
- package/lib/commonjs/web/handlers/HoverGestureHandler.js.map +0 -1
- package/lib/commonjs/web/handlers/LongPressGestureHandler.js +0 -151
- package/lib/commonjs/web/handlers/LongPressGestureHandler.js.map +0 -1
- package/lib/commonjs/web/handlers/ManualGestureHandler.js +0 -61
- package/lib/commonjs/web/handlers/ManualGestureHandler.js.map +0 -1
- package/lib/commonjs/web/handlers/NativeViewGestureHandler.js +0 -178
- package/lib/commonjs/web/handlers/NativeViewGestureHandler.js.map +0 -1
- package/lib/commonjs/web/handlers/PanGestureHandler.js +0 -448
- package/lib/commonjs/web/handlers/PanGestureHandler.js.map +0 -1
- package/lib/commonjs/web/handlers/PinchGestureHandler.js +0 -174
- package/lib/commonjs/web/handlers/PinchGestureHandler.js.map +0 -1
- package/lib/commonjs/web/handlers/RotationGestureHandler.js +0 -186
- package/lib/commonjs/web/handlers/RotationGestureHandler.js.map +0 -1
- package/lib/commonjs/web/handlers/TapGestureHandler.js +0 -280
- package/lib/commonjs/web/handlers/TapGestureHandler.js.map +0 -1
- package/lib/commonjs/web/interfaces.js +0 -55
- package/lib/commonjs/web/interfaces.js.map +0 -1
- package/lib/commonjs/web/tools/CircularBuffer.js +0 -59
- package/lib/commonjs/web/tools/CircularBuffer.js.map +0 -1
- package/lib/commonjs/web/tools/EventManager.js +0 -127
- package/lib/commonjs/web/tools/EventManager.js.map +0 -1
- package/lib/commonjs/web/tools/GestureHandlerDelegate.js +0 -6
- package/lib/commonjs/web/tools/GestureHandlerDelegate.js.map +0 -1
- package/lib/commonjs/web/tools/GestureHandlerOrchestrator.js +0 -349
- package/lib/commonjs/web/tools/GestureHandlerOrchestrator.js.map +0 -1
- package/lib/commonjs/web/tools/GestureHandlerWebDelegate.js +0 -118
- package/lib/commonjs/web/tools/GestureHandlerWebDelegate.js.map +0 -1
- package/lib/commonjs/web/tools/InteractionManager.js +0 -114
- package/lib/commonjs/web/tools/InteractionManager.js.map +0 -1
- package/lib/commonjs/web/tools/LeastSquareSolver.js +0 -204
- package/lib/commonjs/web/tools/LeastSquareSolver.js.map +0 -1
- package/lib/commonjs/web/tools/NodeManager.js +0 -48
- package/lib/commonjs/web/tools/NodeManager.js.map +0 -1
- package/lib/commonjs/web/tools/PointerEventManager.js +0 -198
- package/lib/commonjs/web/tools/PointerEventManager.js.map +0 -1
- package/lib/commonjs/web/tools/PointerTracker.js +0 -226
- package/lib/commonjs/web/tools/PointerTracker.js.map +0 -1
- package/lib/commonjs/web/tools/TouchEventManager.js +0 -138
- package/lib/commonjs/web/tools/TouchEventManager.js.map +0 -1
- package/lib/commonjs/web/tools/VelocityTracker.js +0 -111
- package/lib/commonjs/web/tools/VelocityTracker.js.map +0 -1
- package/lib/commonjs/web/utils.js +0 -15
- package/lib/commonjs/web/utils.js.map +0 -1
- package/lib/commonjs/web_hammer/DiscreteGestureHandler.js +0 -105
- package/lib/commonjs/web_hammer/DiscreteGestureHandler.js.map +0 -1
- package/lib/commonjs/web_hammer/DraggingGestureHandler.js +0 -53
- package/lib/commonjs/web_hammer/DraggingGestureHandler.js.map +0 -1
- package/lib/commonjs/web_hammer/Errors.js +0 -16
- package/lib/commonjs/web_hammer/Errors.js.map +0 -1
- package/lib/commonjs/web_hammer/FlingGestureHandler.js +0 -170
- package/lib/commonjs/web_hammer/FlingGestureHandler.js.map +0 -1
- package/lib/commonjs/web_hammer/GestureHandler.js +0 -579
- package/lib/commonjs/web_hammer/GestureHandler.js.map +0 -1
- package/lib/commonjs/web_hammer/IndiscreteGestureHandler.js +0 -54
- package/lib/commonjs/web_hammer/IndiscreteGestureHandler.js.map +0 -1
- package/lib/commonjs/web_hammer/LongPressGestureHandler.js +0 -71
- package/lib/commonjs/web_hammer/LongPressGestureHandler.js.map +0 -1
- package/lib/commonjs/web_hammer/NativeViewGestureHandler.js +0 -66
- package/lib/commonjs/web_hammer/NativeViewGestureHandler.js.map +0 -1
- package/lib/commonjs/web_hammer/NodeManager.js +0 -46
- package/lib/commonjs/web_hammer/NodeManager.js.map +0 -1
- package/lib/commonjs/web_hammer/PanGestureHandler.js +0 -208
- package/lib/commonjs/web_hammer/PanGestureHandler.js.map +0 -1
- package/lib/commonjs/web_hammer/PinchGestureHandler.js +0 -40
- package/lib/commonjs/web_hammer/PinchGestureHandler.js.map +0 -1
- package/lib/commonjs/web_hammer/PressGestureHandler.js +0 -188
- package/lib/commonjs/web_hammer/PressGestureHandler.js.map +0 -1
- package/lib/commonjs/web_hammer/RotationGestureHandler.js +0 -44
- package/lib/commonjs/web_hammer/RotationGestureHandler.js.map +0 -1
- package/lib/commonjs/web_hammer/TapGestureHandler.js +0 -192
- package/lib/commonjs/web_hammer/TapGestureHandler.js.map +0 -1
- package/lib/commonjs/web_hammer/constants.js +0 -64
- package/lib/commonjs/web_hammer/constants.js.map +0 -1
- package/lib/commonjs/web_hammer/utils.js +0 -42
- package/lib/commonjs/web_hammer/utils.js.map +0 -1
- package/lib/module/ActionType.js +0 -7
- package/lib/module/ActionType.js.map +0 -1
- package/lib/module/Directions.js +0 -7
- package/lib/module/Directions.js.map +0 -1
- package/lib/module/EnableNewWebImplementation.js +0 -22
- package/lib/module/EnableNewWebImplementation.js.map +0 -1
- package/lib/module/GestureHandlerRootViewContext.js +0 -3
- package/lib/module/GestureHandlerRootViewContext.js.map +0 -1
- package/lib/module/PlatformConstants.js +0 -5
- package/lib/module/PlatformConstants.js.map +0 -1
- package/lib/module/PlatformConstants.web.js +0 -7
- package/lib/module/PlatformConstants.web.js.map +0 -1
- package/lib/module/RNGestureHandlerModule.macos.js +0 -110
- package/lib/module/RNGestureHandlerModule.macos.js.map +0 -1
- package/lib/module/RNGestureHandlerModule.web.js +0 -122
- package/lib/module/RNGestureHandlerModule.web.js.map +0 -1
- package/lib/module/RNGestureHandlerModule.windows.js +0 -118
- package/lib/module/RNGestureHandlerModule.windows.js.map +0 -1
- package/lib/module/RNRenderer.js +0 -4
- package/lib/module/RNRenderer.js.map +0 -1
- package/lib/module/RNRenderer.web.js +0 -4
- package/lib/module/RNRenderer.web.js.map +0 -1
- package/lib/module/State.js +0 -10
- package/lib/module/State.js.map +0 -1
- package/lib/module/TouchEventType.js +0 -8
- package/lib/module/TouchEventType.js.map +0 -1
- package/lib/module/components/DrawerLayout.js +0 -551
- package/lib/module/components/DrawerLayout.js.map +0 -1
- package/lib/module/components/GestureComponents.js +0 -90
- package/lib/module/components/GestureComponents.js.map +0 -1
- package/lib/module/components/GestureComponents.web.js +0 -28
- package/lib/module/components/GestureComponents.web.js.map +0 -1
- package/lib/module/components/GestureHandlerButton.web.js +0 -9
- package/lib/module/components/GestureHandlerButton.web.js.map +0 -1
- package/lib/module/components/GestureHandlerRootView.android.js +0 -14
- package/lib/module/components/GestureHandlerRootView.android.js.map +0 -1
- package/lib/module/components/GestureHandlerRootView.web.js +0 -9
- package/lib/module/components/GestureHandlerRootView.web.js.map +0 -1
- package/lib/module/components/Swipeable.js +0 -390
- package/lib/module/components/Swipeable.js.map +0 -1
- package/lib/module/components/gestureHandlerRootHOC.js +0 -22
- package/lib/module/components/gestureHandlerRootHOC.js.map +0 -1
- package/lib/module/components/touchables/TouchableHighlight.js +0 -95
- package/lib/module/components/touchables/TouchableHighlight.js.map +0 -1
- package/lib/module/components/touchables/TouchableNativeFeedback.android.js +0 -84
- package/lib/module/components/touchables/TouchableNativeFeedback.android.js.map +0 -1
- package/lib/module/components/touchables/TouchableNativeFeedback.js +0 -3
- package/lib/module/components/touchables/TouchableNativeFeedback.js.map +0 -1
- package/lib/module/getReactNativeVersion.js +0 -10
- package/lib/module/getReactNativeVersion.js.map +0 -1
- package/lib/module/getReactNativeVersion.web.js +0 -4
- package/lib/module/getReactNativeVersion.web.js.map +0 -1
- package/lib/module/getShadowNodeFromRef.js +0 -20
- package/lib/module/getShadowNodeFromRef.js.map +0 -1
- package/lib/module/getShadowNodeFromRef.web.js +0 -8
- package/lib/module/getShadowNodeFromRef.web.js.map +0 -1
- package/lib/module/ghQueueMicrotask.js +0 -5
- package/lib/module/ghQueueMicrotask.js.map +0 -1
- package/lib/module/handlers/FlingGestureHandler.js +0 -11
- package/lib/module/handlers/FlingGestureHandler.js.map +0 -1
- package/lib/module/handlers/ForceTouchGestureHandler.js +0 -31
- package/lib/module/handlers/ForceTouchGestureHandler.js.map +0 -1
- package/lib/module/handlers/LongPressGestureHandler.js +0 -13
- package/lib/module/handlers/LongPressGestureHandler.js.map +0 -1
- package/lib/module/handlers/PinchGestureHandler.js +0 -10
- package/lib/module/handlers/PinchGestureHandler.js.map +0 -1
- package/lib/module/handlers/PressabilityDebugView.js +0 -3
- package/lib/module/handlers/PressabilityDebugView.js.map +0 -1
- package/lib/module/handlers/PressabilityDebugView.web.js +0 -5
- package/lib/module/handlers/PressabilityDebugView.web.js.map +0 -1
- package/lib/module/handlers/RotationGestureHandler.js +0 -10
- package/lib/module/handlers/RotationGestureHandler.js.map +0 -1
- package/lib/module/handlers/gestureHandlerTypesCompat.js +0 -2
- package/lib/module/handlers/gestureHandlerTypesCompat.js.map +0 -1
- package/lib/module/handlers/gestures/eventReceiver.js +0 -131
- package/lib/module/handlers/gestures/eventReceiver.js.map +0 -1
- package/lib/module/handlers/gestures/flingGesture.js +0 -24
- package/lib/module/handlers/gestures/flingGesture.js.map +0 -1
- package/lib/module/handlers/gestures/forceTouchGesture.js +0 -56
- package/lib/module/handlers/gestures/forceTouchGesture.js.map +0 -1
- package/lib/module/handlers/gestures/gesture.js +0 -222
- package/lib/module/handlers/gestures/gesture.js.map +0 -1
- package/lib/module/handlers/gestures/gestureComposition.js +0 -90
- package/lib/module/handlers/gestures/gestureComposition.js.map +0 -1
- package/lib/module/handlers/gestures/gestureObjects.js +0 -71
- package/lib/module/handlers/gestures/gestureObjects.js.map +0 -1
- package/lib/module/handlers/gestures/gestureStateManager.js +0 -54
- package/lib/module/handlers/gestures/gestureStateManager.js.map +0 -1
- package/lib/module/handlers/gestures/gestureStateManager.web.js +0 -21
- package/lib/module/handlers/gestures/gestureStateManager.web.js.map +0 -1
- package/lib/module/handlers/gestures/hoverGesture.js +0 -62
- package/lib/module/handlers/gestures/hoverGesture.js.map +0 -1
- package/lib/module/handlers/gestures/longPressGesture.js +0 -25
- package/lib/module/handlers/gestures/longPressGesture.js.map +0 -1
- package/lib/module/handlers/gestures/manualGesture.js +0 -22
- package/lib/module/handlers/gestures/manualGesture.js.map +0 -1
- package/lib/module/handlers/gestures/nativeGesture.js +0 -24
- package/lib/module/handlers/gestures/nativeGesture.js.map +0 -1
- package/lib/module/handlers/gestures/panGesture.js +0 -140
- package/lib/module/handlers/gestures/panGesture.js.map +0 -1
- package/lib/module/handlers/gestures/pinchGesture.js +0 -36
- package/lib/module/handlers/gestures/pinchGesture.js.map +0 -1
- package/lib/module/handlers/gestures/reanimatedWrapper.js +0 -30
- package/lib/module/handlers/gestures/reanimatedWrapper.js.map +0 -1
- package/lib/module/handlers/gestures/rotationGesture.js +0 -36
- package/lib/module/handlers/gestures/rotationGesture.js.map +0 -1
- package/lib/module/handlers/gestures/tapGesture.js +0 -50
- package/lib/module/handlers/gestures/tapGesture.js.map +0 -1
- package/lib/module/handlers/handlersRegistry.js +0 -44
- package/lib/module/handlers/handlersRegistry.js.map +0 -1
- package/lib/module/jestUtils/index.js +0 -2
- package/lib/module/jestUtils/index.js.map +0 -1
- package/lib/module/jestUtils/jestUtils.js +0 -350
- package/lib/module/jestUtils/jestUtils.js.map +0 -1
- package/lib/module/mocks.js +0 -56
- package/lib/module/mocks.js.map +0 -1
- package/lib/module/specs/RNGestureHandlerButtonNativeComponent.js +0 -3
- package/lib/module/specs/RNGestureHandlerButtonNativeComponent.js.map +0 -1
- package/lib/module/specs/RNGestureHandlerRootViewNativeComponent.js +0 -3
- package/lib/module/specs/RNGestureHandlerRootViewNativeComponent.js.map +0 -1
- package/lib/module/typeUtils.js +0 -2
- package/lib/module/typeUtils.js.map +0 -1
- package/lib/module/utils.js +0 -44
- package/lib/module/utils.js.map +0 -1
- package/lib/module/web/constants.js +0 -8
- package/lib/module/web/constants.js.map +0 -1
- package/lib/module/web/detectors/RotationGestureDetector.js +0 -155
- package/lib/module/web/detectors/RotationGestureDetector.js.map +0 -1
- package/lib/module/web/detectors/ScaleGestureDetector.js +0 -145
- package/lib/module/web/detectors/ScaleGestureDetector.js.map +0 -1
- package/lib/module/web/handlers/FlingGestureHandler.js +0 -152
- package/lib/module/web/handlers/FlingGestureHandler.js.map +0 -1
- package/lib/module/web/handlers/GestureHandler.js +0 -776
- package/lib/module/web/handlers/GestureHandler.js.map +0 -1
- package/lib/module/web/handlers/HoverGestureHandler.js +0 -47
- package/lib/module/web/handlers/HoverGestureHandler.js.map +0 -1
- package/lib/module/web/handlers/LongPressGestureHandler.js +0 -136
- package/lib/module/web/handlers/LongPressGestureHandler.js.map +0 -1
- package/lib/module/web/handlers/ManualGestureHandler.js +0 -49
- package/lib/module/web/handlers/ManualGestureHandler.js.map +0 -1
- package/lib/module/web/handlers/NativeViewGestureHandler.js +0 -163
- package/lib/module/web/handlers/NativeViewGestureHandler.js.map +0 -1
- package/lib/module/web/handlers/PanGestureHandler.js +0 -433
- package/lib/module/web/handlers/PanGestureHandler.js.map +0 -1
- package/lib/module/web/handlers/PinchGestureHandler.js +0 -159
- package/lib/module/web/handlers/PinchGestureHandler.js.map +0 -1
- package/lib/module/web/handlers/RotationGestureHandler.js +0 -171
- package/lib/module/web/handlers/RotationGestureHandler.js.map +0 -1
- package/lib/module/web/handlers/TapGestureHandler.js +0 -265
- package/lib/module/web/handlers/TapGestureHandler.js.map +0 -1
- package/lib/module/web/interfaces.js +0 -45
- package/lib/module/web/interfaces.js.map +0 -1
- package/lib/module/web/tools/CircularBuffer.js +0 -50
- package/lib/module/web/tools/CircularBuffer.js.map +0 -1
- package/lib/module/web/tools/EventManager.js +0 -118
- package/lib/module/web/tools/EventManager.js.map +0 -1
- package/lib/module/web/tools/GestureHandlerDelegate.js +0 -2
- package/lib/module/web/tools/GestureHandlerDelegate.js.map +0 -1
- package/lib/module/web/tools/GestureHandlerOrchestrator.js +0 -335
- package/lib/module/web/tools/GestureHandlerOrchestrator.js.map +0 -1
- package/lib/module/web/tools/GestureHandlerWebDelegate.js +0 -102
- package/lib/module/web/tools/GestureHandlerWebDelegate.js.map +0 -1
- package/lib/module/web/tools/InteractionManager.js +0 -105
- package/lib/module/web/tools/InteractionManager.js.map +0 -1
- package/lib/module/web/tools/LeastSquareSolver.js +0 -195
- package/lib/module/web/tools/LeastSquareSolver.js.map +0 -1
- package/lib/module/web/tools/NodeManager.js +0 -39
- package/lib/module/web/tools/NodeManager.js.map +0 -1
- package/lib/module/web/tools/PointerEventManager.js +0 -184
- package/lib/module/web/tools/PointerEventManager.js.map +0 -1
- package/lib/module/web/tools/PointerTracker.js +0 -213
- package/lib/module/web/tools/PointerTracker.js.map +0 -1
- package/lib/module/web/tools/TouchEventManager.js +0 -124
- package/lib/module/web/tools/TouchEventManager.js.map +0 -1
- package/lib/module/web/tools/VelocityTracker.js +0 -98
- package/lib/module/web/tools/VelocityTracker.js.map +0 -1
- package/lib/module/web/utils.js +0 -8
- package/lib/module/web/utils.js.map +0 -1
- package/lib/module/web_hammer/DiscreteGestureHandler.js +0 -94
- package/lib/module/web_hammer/DiscreteGestureHandler.js.map +0 -1
- package/lib/module/web_hammer/DraggingGestureHandler.js +0 -40
- package/lib/module/web_hammer/DraggingGestureHandler.js.map +0 -1
- package/lib/module/web_hammer/Errors.js +0 -7
- package/lib/module/web_hammer/Errors.js.map +0 -1
- package/lib/module/web_hammer/FlingGestureHandler.js +0 -156
- package/lib/module/web_hammer/FlingGestureHandler.js.map +0 -1
- package/lib/module/web_hammer/GestureHandler.js +0 -563
- package/lib/module/web_hammer/GestureHandler.js.map +0 -1
- package/lib/module/web_hammer/IndiscreteGestureHandler.js +0 -44
- package/lib/module/web_hammer/IndiscreteGestureHandler.js.map +0 -1
- package/lib/module/web_hammer/LongPressGestureHandler.js +0 -58
- package/lib/module/web_hammer/LongPressGestureHandler.js.map +0 -1
- package/lib/module/web_hammer/NativeViewGestureHandler.js +0 -49
- package/lib/module/web_hammer/NativeViewGestureHandler.js.map +0 -1
- package/lib/module/web_hammer/NodeManager.js +0 -33
- package/lib/module/web_hammer/NodeManager.js.map +0 -1
- package/lib/module/web_hammer/PanGestureHandler.js +0 -194
- package/lib/module/web_hammer/PanGestureHandler.js.map +0 -1
- package/lib/module/web_hammer/PinchGestureHandler.js +0 -29
- package/lib/module/web_hammer/PinchGestureHandler.js.map +0 -1
- package/lib/module/web_hammer/PressGestureHandler.js +0 -174
- package/lib/module/web_hammer/PressGestureHandler.js.map +0 -1
- package/lib/module/web_hammer/RotationGestureHandler.js +0 -32
- package/lib/module/web_hammer/RotationGestureHandler.js.map +0 -1
- package/lib/module/web_hammer/TapGestureHandler.js +0 -180
- package/lib/module/web_hammer/TapGestureHandler.js.map +0 -1
- package/lib/module/web_hammer/constants.js +0 -43
- package/lib/module/web_hammer/constants.js.map +0 -1
- package/lib/module/web_hammer/utils.js +0 -19
- package/lib/module/web_hammer/utils.js.map +0 -1
- package/lib/typescript/ActionType.d.ts +0 -7
- package/lib/typescript/Directions.d.ts +0 -7
- package/lib/typescript/EnableNewWebImplementation.d.ts +0 -3
- package/lib/typescript/GestureHandlerRootViewContext.d.ts +0 -3
- package/lib/typescript/PlatformConstants.d.ts +0 -5
- package/lib/typescript/PlatformConstants.web.d.ts +0 -4
- package/lib/typescript/RNGestureHandlerModule.macos.d.ts +0 -47
- package/lib/typescript/RNGestureHandlerModule.web.d.ts +0 -50
- package/lib/typescript/RNGestureHandlerModule.windows.d.ts +0 -48
- package/lib/typescript/RNRenderer.d.ts +0 -1
- package/lib/typescript/RNRenderer.web.d.ts +0 -3
- package/lib/typescript/State.d.ts +0 -9
- package/lib/typescript/TouchEventType.d.ts +0 -8
- package/lib/typescript/components/DrawerLayout.d.ts +0 -148
- package/lib/typescript/components/GestureComponents.d.ts +0 -22
- package/lib/typescript/components/GestureComponents.web.d.ts +0 -8
- package/lib/typescript/components/GestureHandlerButton.web.d.ts +0 -4
- package/lib/typescript/components/GestureHandlerRootView.android.d.ts +0 -6
- package/lib/typescript/components/GestureHandlerRootView.web.d.ts +0 -6
- package/lib/typescript/components/Swipeable.d.ts +0 -178
- package/lib/typescript/components/gestureHandlerRootHOC.d.ts +0 -3
- package/lib/typescript/components/touchables/TouchableHighlight.d.ts +0 -36
- package/lib/typescript/components/touchables/TouchableNativeFeedback.android.d.ts +0 -45
- package/lib/typescript/components/touchables/TouchableNativeFeedback.d.ts +0 -2
- package/lib/typescript/getReactNativeVersion.d.ts +0 -4
- package/lib/typescript/getReactNativeVersion.web.d.ts +0 -1
- package/lib/typescript/getShadowNodeFromRef.d.ts +0 -1
- package/lib/typescript/getShadowNodeFromRef.web.d.ts +0 -1
- package/lib/typescript/ghQueueMicrotask.d.ts +0 -1
- package/lib/typescript/handlers/FlingGestureHandler.d.ts +0 -34
- package/lib/typescript/handlers/ForceTouchGestureHandler.d.ts +0 -44
- package/lib/typescript/handlers/LongPressGestureHandler.d.ts +0 -56
- package/lib/typescript/handlers/PinchGestureHandler.d.ts +0 -29
- package/lib/typescript/handlers/PressabilityDebugView.d.ts +0 -1
- package/lib/typescript/handlers/PressabilityDebugView.web.d.ts +0 -1
- package/lib/typescript/handlers/RotationGestureHandler.d.ts +0 -29
- package/lib/typescript/handlers/gestureHandlerTypesCompat.d.ts +0 -42
- package/lib/typescript/handlers/gestures/eventReceiver.d.ts +0 -4
- package/lib/typescript/handlers/gestures/flingGesture.d.ts +0 -9
- package/lib/typescript/handlers/gestures/forceTouchGesture.d.ts +0 -15
- package/lib/typescript/handlers/gestures/gesture.d.ts +0 -110
- package/lib/typescript/handlers/gestures/gestureComposition.d.ts +0 -21
- package/lib/typescript/handlers/gestures/gestureObjects.d.ts +0 -41
- package/lib/typescript/handlers/gestures/gestureStateManager.d.ts +0 -9
- package/lib/typescript/handlers/gestures/gestureStateManager.web.d.ts +0 -4
- package/lib/typescript/handlers/gestures/hoverGesture.d.ts +0 -32
- package/lib/typescript/handlers/gestures/longPressGesture.d.ts +0 -9
- package/lib/typescript/handlers/gestures/manualGesture.d.ts +0 -7
- package/lib/typescript/handlers/gestures/nativeGesture.d.ts +0 -9
- package/lib/typescript/handlers/gestures/panGesture.d.ts +0 -26
- package/lib/typescript/handlers/gestures/pinchGesture.d.ts +0 -11
- package/lib/typescript/handlers/gestures/reanimatedWrapper.d.ts +0 -14
- package/lib/typescript/handlers/gestures/rotationGesture.d.ts +0 -12
- package/lib/typescript/handlers/gestures/tapGesture.d.ts +0 -14
- package/lib/typescript/handlers/handlersRegistry.d.ts +0 -14
- package/lib/typescript/jestUtils/index.d.ts +0 -1
- package/lib/typescript/jestUtils/jestUtils.d.ts +0 -28
- package/lib/typescript/mocks.d.ts +0 -44
- package/lib/typescript/specs/RNGestureHandlerButtonNativeComponent.d.ts +0 -14
- package/lib/typescript/specs/RNGestureHandlerRootViewNativeComponent.d.ts +0 -6
- package/lib/typescript/typeUtils.d.ts +0 -1
- package/lib/typescript/utils.d.ts +0 -8
- package/lib/typescript/web/constants.d.ts +0 -7
- package/lib/typescript/web/detectors/RotationGestureDetector.d.ts +0 -30
- package/lib/typescript/web/detectors/ScaleGestureDetector.d.ts +0 -29
- package/lib/typescript/web/handlers/FlingGestureHandler.d.ts +0 -27
- package/lib/typescript/web/handlers/GestureHandler.d.ts +0 -90
- package/lib/typescript/web/handlers/HoverGestureHandler.d.ts +0 -10
- package/lib/typescript/web/handlers/LongPressGestureHandler.d.ts +0 -26
- package/lib/typescript/web/handlers/ManualGestureHandler.d.ts +0 -12
- package/lib/typescript/web/handlers/NativeViewGestureHandler.d.ts +0 -24
- package/lib/typescript/web/handlers/PanGestureHandler.d.ts +0 -55
- package/lib/typescript/web/handlers/PinchGestureHandler.d.ts +0 -28
- package/lib/typescript/web/handlers/RotationGestureHandler.d.ts +0 -29
- package/lib/typescript/web/handlers/TapGestureHandler.d.ts +0 -39
- package/lib/typescript/web/interfaces.d.ts +0 -141
- package/lib/typescript/web/tools/CircularBuffer.d.ts +0 -11
- package/lib/typescript/web/tools/EventManager.d.ts +0 -34
- package/lib/typescript/web/tools/GestureHandlerDelegate.d.ts +0 -22
- package/lib/typescript/web/tools/GestureHandlerOrchestrator.d.ts +0 -29
- package/lib/typescript/web/tools/GestureHandlerWebDelegate.d.ts +0 -21
- package/lib/typescript/web/tools/InteractionManager.d.ts +0 -17
- package/lib/typescript/web/tools/LeastSquareSolver.d.ts +0 -12
- package/lib/typescript/web/tools/NodeManager.d.ts +0 -11
- package/lib/typescript/web/tools/PointerEventManager.d.ts +0 -8
- package/lib/typescript/web/tools/PointerTracker.d.ts +0 -53
- package/lib/typescript/web/tools/TouchEventManager.d.ts +0 -6
- package/lib/typescript/web/tools/VelocityTracker.d.ts +0 -13
- package/lib/typescript/web/utils.d.ts +0 -4
- package/lib/typescript/web_hammer/DiscreteGestureHandler.d.ts +0 -20
- package/lib/typescript/web_hammer/DraggingGestureHandler.d.ts +0 -15
- package/lib/typescript/web_hammer/Errors.d.ts +0 -3
- package/lib/typescript/web_hammer/FlingGestureHandler.d.ts +0 -43
- package/lib/typescript/web_hammer/GestureHandler.d.ts +0 -145
- package/lib/typescript/web_hammer/IndiscreteGestureHandler.d.ts +0 -40
- package/lib/typescript/web_hammer/LongPressGestureHandler.d.ts +0 -38
- package/lib/typescript/web_hammer/NativeViewGestureHandler.d.ts +0 -7
- package/lib/typescript/web_hammer/NodeManager.d.ts +0 -8
- package/lib/typescript/web_hammer/PanGestureHandler.d.ts +0 -56
- package/lib/typescript/web_hammer/PinchGestureHandler.d.ts +0 -13
- package/lib/typescript/web_hammer/PressGestureHandler.d.ts +0 -83
- package/lib/typescript/web_hammer/RotationGestureHandler.d.ts +0 -13
- package/lib/typescript/web_hammer/TapGestureHandler.d.ts +0 -57
- package/lib/typescript/web_hammer/constants.d.ts +0 -39
- package/lib/typescript/web_hammer/utils.d.ts +0 -9
- package/src/ActionType.ts +0 -9
- package/src/Directions.ts +0 -9
- package/src/EnableNewWebImplementation.ts +0 -35
- package/src/GestureHandlerRootViewContext.ts +0 -3
- package/src/PlatformConstants.ts +0 -8
- package/src/PlatformConstants.web.ts +0 -5
- package/src/RNGestureHandlerModule.macos.ts +0 -133
- package/src/RNGestureHandlerModule.web.ts +0 -146
- package/src/RNGestureHandlerModule.windows.ts +0 -144
- package/src/RNRenderer.ts +0 -3
- package/src/RNRenderer.web.ts +0 -3
- package/src/State.ts +0 -13
- package/src/TouchEventType.ts +0 -10
- package/src/components/DrawerLayout.tsx +0 -743
- package/src/components/GestureComponents.tsx +0 -148
- package/src/components/GestureComponents.web.tsx +0 -41
- package/src/components/GestureHandlerButton.web.tsx +0 -6
- package/src/components/GestureHandlerRootView.android.tsx +0 -24
- package/src/components/GestureHandlerRootView.web.tsx +0 -17
- package/src/components/Swipeable.tsx +0 -584
- package/src/components/gestureHandlerRootHOC.tsx +0 -32
- package/src/components/touchables/TouchableHighlight.tsx +0 -115
- package/src/components/touchables/TouchableNativeFeedback.android.tsx +0 -91
- package/src/components/touchables/TouchableNativeFeedback.tsx +0 -3
- package/src/getReactNativeVersion.ts +0 -11
- package/src/getReactNativeVersion.web.ts +0 -3
- package/src/getShadowNodeFromRef.ts +0 -22
- package/src/getShadowNodeFromRef.web.ts +0 -7
- package/src/ghQueueMicrotask.ts +0 -5
- package/src/handlers/FlingGestureHandler.ts +0 -59
- package/src/handlers/ForceTouchGestureHandler.ts +0 -90
- package/src/handlers/LongPressGestureHandler.ts +0 -88
- package/src/handlers/PinchGestureHandler.ts +0 -48
- package/src/handlers/PressabilityDebugView.tsx +0 -2
- package/src/handlers/PressabilityDebugView.web.tsx +0 -4
- package/src/handlers/RotationGestureHandler.ts +0 -48
- package/src/handlers/gestureHandlerTypesCompat.ts +0 -106
- package/src/handlers/gestures/eventReceiver.ts +0 -155
- package/src/handlers/gestures/flingGesture.ts +0 -27
- package/src/handlers/gestures/forceTouchGesture.ts +0 -74
- package/src/handlers/gestures/gesture.ts +0 -349
- package/src/handlers/gestures/gestureComposition.ts +0 -122
- package/src/handlers/gestures/gestureObjects.ts +0 -84
- package/src/handlers/gestures/gestureStateManager.ts +0 -62
- package/src/handlers/gestures/gestureStateManager.web.ts +0 -24
- package/src/handlers/gestures/hoverGesture.ts +0 -83
- package/src/handlers/gestures/longPressGesture.ts +0 -28
- package/src/handlers/gestures/manualGesture.ts +0 -31
- package/src/handlers/gestures/nativeGesture.ts +0 -27
- package/src/handlers/gestures/panGesture.ts +0 -152
- package/src/handlers/gestures/pinchGesture.ts +0 -51
- package/src/handlers/gestures/reanimatedWrapper.ts +0 -56
- package/src/handlers/gestures/rotationGesture.ts +0 -51
- package/src/handlers/gestures/tapGesture.ts +0 -53
- package/src/handlers/handlersRegistry.ts +0 -60
- package/src/jestUtils/index.ts +0 -1
- package/src/jestUtils/jestUtils.ts +0 -505
- package/src/mocks.ts +0 -67
- package/src/specs/RNGestureHandlerButtonNativeComponent.ts +0 -18
- package/src/specs/RNGestureHandlerRootViewNativeComponent.ts +0 -6
- package/src/typeUtils.ts +0 -1
- package/src/utils.ts +0 -54
- package/src/web/constants.ts +0 -8
- package/src/web/detectors/RotationGestureDetector.ts +0 -168
- package/src/web/detectors/ScaleGestureDetector.ts +0 -172
- package/src/web/handlers/FlingGestureHandler.ts +0 -161
- package/src/web/handlers/GestureHandler.ts +0 -849
- package/src/web/handlers/HoverGestureHandler.ts +0 -43
- package/src/web/handlers/LongPressGestureHandler.ts +0 -125
- package/src/web/handlers/ManualGestureHandler.ts +0 -43
- package/src/web/handlers/NativeViewGestureHandler.ts +0 -167
- package/src/web/handlers/PanGestureHandler.ts +0 -485
- package/src/web/handlers/PinchGestureHandler.ts +0 -158
- package/src/web/handlers/RotationGestureHandler.ts +0 -172
- package/src/web/handlers/TapGestureHandler.ts +0 -273
- package/src/web/interfaces.ts +0 -167
- package/src/web/tools/EventManager.ts +0 -104
- package/src/web/tools/GestureHandlerDelegate.ts +0 -23
- package/src/web/tools/GestureHandlerOrchestrator.ts +0 -389
- package/src/web/tools/GestureHandlerWebDelegate.ts +0 -115
- package/src/web/tools/NodeManager.ts +0 -43
- package/src/web/tools/PointerEventManager.ts +0 -202
- package/src/web/tools/TouchEventManager.ts +0 -167
- package/src/web/utils.ts +0 -8
- package/src/web_hammer/DiscreteGestureHandler.ts +0 -82
- package/src/web_hammer/DraggingGestureHandler.ts +0 -34
- package/src/web_hammer/Errors.ts +0 -7
- package/src/web_hammer/FlingGestureHandler.ts +0 -134
- package/src/web_hammer/GestureHandler.ts +0 -599
- package/src/web_hammer/IndiscreteGestureHandler.ts +0 -33
- package/src/web_hammer/LongPressGestureHandler.ts +0 -56
- package/src/web_hammer/NativeViewGestureHandler.ts +0 -47
- package/src/web_hammer/NodeManager.ts +0 -42
- package/src/web_hammer/PanGestureHandler.ts +0 -226
- package/src/web_hammer/PinchGestureHandler.ts +0 -25
- package/src/web_hammer/PressGestureHandler.ts +0 -167
- package/src/web_hammer/RotationGestureHandler.ts +0 -25
- package/src/web_hammer/TapGestureHandler.ts +0 -172
- package/src/web_hammer/constants.ts +0 -48
- package/src/web_hammer/utils.ts +0 -24
@@ -1,822 +1,823 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
} from '
|
27
|
-
import {
|
28
|
-
|
29
|
-
|
30
|
-
import {
|
31
|
-
|
32
|
-
|
33
|
-
} from '
|
34
|
-
import {
|
35
|
-
import {
|
36
|
-
import {
|
37
|
-
import {
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
import {
|
42
|
-
import {
|
43
|
-
import {
|
44
|
-
import
|
45
|
-
import {
|
46
|
-
import {
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
// if
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
}
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
|
191
|
-
|
192
|
-
|
193
|
-
|
194
|
-
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
|
205
|
-
|
206
|
-
|
207
|
-
|
208
|
-
|
209
|
-
|
210
|
-
|
211
|
-
|
212
|
-
|
213
|
-
|
214
|
-
|
215
|
-
|
216
|
-
|
217
|
-
|
218
|
-
|
219
|
-
|
220
|
-
|
221
|
-
|
222
|
-
|
223
|
-
|
224
|
-
|
225
|
-
|
226
|
-
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
|
231
|
-
|
232
|
-
|
233
|
-
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
252
|
-
|
253
|
-
|
254
|
-
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
|
262
|
-
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
|
270
|
-
|
271
|
-
|
272
|
-
//
|
273
|
-
|
274
|
-
|
275
|
-
|
276
|
-
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
handler
|
281
|
-
|
282
|
-
|
283
|
-
|
284
|
-
|
285
|
-
|
286
|
-
|
287
|
-
|
288
|
-
|
289
|
-
|
290
|
-
|
291
|
-
|
292
|
-
|
293
|
-
|
294
|
-
|
295
|
-
|
296
|
-
|
297
|
-
|
298
|
-
|
299
|
-
|
300
|
-
|
301
|
-
|
302
|
-
|
303
|
-
|
304
|
-
|
305
|
-
const
|
306
|
-
.
|
307
|
-
|
308
|
-
|
309
|
-
|
310
|
-
|
311
|
-
|
312
|
-
|
313
|
-
|
314
|
-
|
315
|
-
|
316
|
-
|
317
|
-
|
318
|
-
|
319
|
-
|
320
|
-
|
321
|
-
|
322
|
-
|
323
|
-
|
324
|
-
|
325
|
-
|
326
|
-
|
327
|
-
|
328
|
-
|
329
|
-
|
330
|
-
|
331
|
-
|
332
|
-
|
333
|
-
|
334
|
-
|
335
|
-
|
336
|
-
|
337
|
-
|
338
|
-
|
339
|
-
|
340
|
-
|
341
|
-
|
342
|
-
|
343
|
-
|
344
|
-
|
345
|
-
|
346
|
-
|
347
|
-
|
348
|
-
|
349
|
-
|
350
|
-
|
351
|
-
|
352
|
-
|
353
|
-
|
354
|
-
|
355
|
-
|
356
|
-
|
357
|
-
|
358
|
-
|
359
|
-
|
360
|
-
|
361
|
-
|
362
|
-
|
363
|
-
|
364
|
-
|
365
|
-
|
366
|
-
|
367
|
-
|
368
|
-
|
369
|
-
|
370
|
-
|
371
|
-
|
372
|
-
|
373
|
-
|
374
|
-
|
375
|
-
|
376
|
-
|
377
|
-
|
378
|
-
|
379
|
-
|
380
|
-
case CALLBACK_TYPE.
|
381
|
-
return gesture.
|
382
|
-
case CALLBACK_TYPE.
|
383
|
-
return gesture.
|
384
|
-
case CALLBACK_TYPE.
|
385
|
-
return gesture.
|
386
|
-
case CALLBACK_TYPE.
|
387
|
-
return gesture.
|
388
|
-
case CALLBACK_TYPE.
|
389
|
-
return gesture.
|
390
|
-
case CALLBACK_TYPE.
|
391
|
-
return gesture.
|
392
|
-
case CALLBACK_TYPE.
|
393
|
-
return gesture.
|
394
|
-
case CALLBACK_TYPE.
|
395
|
-
return gesture.
|
396
|
-
case CALLBACK_TYPE.
|
397
|
-
return gesture.
|
398
|
-
|
399
|
-
|
400
|
-
|
401
|
-
|
402
|
-
|
403
|
-
|
404
|
-
|
405
|
-
|
406
|
-
|
407
|
-
|
408
|
-
case TouchEventType.
|
409
|
-
return CALLBACK_TYPE.
|
410
|
-
case TouchEventType.
|
411
|
-
return CALLBACK_TYPE.
|
412
|
-
case TouchEventType.
|
413
|
-
return CALLBACK_TYPE.
|
414
|
-
|
415
|
-
|
416
|
-
}
|
417
|
-
|
418
|
-
|
419
|
-
|
420
|
-
|
421
|
-
|
422
|
-
|
423
|
-
|
424
|
-
|
425
|
-
|
426
|
-
|
427
|
-
|
428
|
-
|
429
|
-
|
430
|
-
|
431
|
-
|
432
|
-
}
|
433
|
-
|
434
|
-
|
435
|
-
|
436
|
-
|
437
|
-
|
438
|
-
|
439
|
-
|
440
|
-
|
441
|
-
|
442
|
-
|
443
|
-
|
444
|
-
|
445
|
-
//
|
446
|
-
|
447
|
-
|
448
|
-
|
449
|
-
|
450
|
-
|
451
|
-
|
452
|
-
|
453
|
-
|
454
|
-
|
455
|
-
|
456
|
-
|
457
|
-
|
458
|
-
const
|
459
|
-
|
460
|
-
|
461
|
-
|
462
|
-
|
463
|
-
|
464
|
-
|
465
|
-
|
466
|
-
|
467
|
-
|
468
|
-
|
469
|
-
|
470
|
-
|
471
|
-
|
472
|
-
|
473
|
-
|
474
|
-
|
475
|
-
|
476
|
-
|
477
|
-
|
478
|
-
|
479
|
-
(
|
480
|
-
|
481
|
-
event.
|
482
|
-
|
483
|
-
|
484
|
-
|
485
|
-
|
486
|
-
|
487
|
-
|
488
|
-
|
489
|
-
|
490
|
-
|
491
|
-
|
492
|
-
|
493
|
-
|
494
|
-
(
|
495
|
-
|
496
|
-
|
497
|
-
|
498
|
-
|
499
|
-
|
500
|
-
|
501
|
-
|
502
|
-
|
503
|
-
|
504
|
-
|
505
|
-
|
506
|
-
|
507
|
-
|
508
|
-
|
509
|
-
|
510
|
-
|
511
|
-
event,
|
512
|
-
|
513
|
-
|
514
|
-
|
515
|
-
|
516
|
-
|
517
|
-
|
518
|
-
|
519
|
-
|
520
|
-
|
521
|
-
|
522
|
-
|
523
|
-
|
524
|
-
|
525
|
-
|
526
|
-
|
527
|
-
|
528
|
-
|
529
|
-
|
530
|
-
|
531
|
-
|
532
|
-
|
533
|
-
|
534
|
-
|
535
|
-
|
536
|
-
|
537
|
-
|
538
|
-
|
539
|
-
|
540
|
-
|
541
|
-
|
542
|
-
|
543
|
-
|
544
|
-
|
545
|
-
|
546
|
-
|
547
|
-
|
548
|
-
|
549
|
-
|
550
|
-
//
|
551
|
-
//
|
552
|
-
//
|
553
|
-
//
|
554
|
-
//
|
555
|
-
//
|
556
|
-
//
|
557
|
-
//
|
558
|
-
//
|
559
|
-
//
|
560
|
-
//
|
561
|
-
//
|
562
|
-
//
|
563
|
-
// |
|
564
|
-
//
|
565
|
-
//
|
566
|
-
//
|
567
|
-
//
|
568
|
-
//
|
569
|
-
|
570
|
-
|
571
|
-
|
572
|
-
|
573
|
-
|
574
|
-
|
575
|
-
|
576
|
-
|
577
|
-
|
578
|
-
|
579
|
-
|
580
|
-
|
581
|
-
|
582
|
-
|
583
|
-
|
584
|
-
|
585
|
-
|
586
|
-
|
587
|
-
|
588
|
-
|
589
|
-
|
590
|
-
|
591
|
-
|
592
|
-
|
593
|
-
|
594
|
-
|
595
|
-
|
596
|
-
|
597
|
-
}
|
598
|
-
|
599
|
-
|
600
|
-
|
601
|
-
|
602
|
-
|
603
|
-
|
604
|
-
|
605
|
-
|
606
|
-
}
|
607
|
-
|
608
|
-
|
609
|
-
|
610
|
-
|
611
|
-
|
612
|
-
|
613
|
-
|
614
|
-
|
615
|
-
|
616
|
-
|
617
|
-
|
618
|
-
|
619
|
-
|
620
|
-
|
621
|
-
|
622
|
-
|
623
|
-
|
624
|
-
|
625
|
-
|
626
|
-
|
627
|
-
|
628
|
-
|
629
|
-
|
630
|
-
|
631
|
-
|
632
|
-
|
633
|
-
|
634
|
-
const
|
635
|
-
|
636
|
-
|
637
|
-
|
638
|
-
|
639
|
-
|
640
|
-
|
641
|
-
|
642
|
-
|
643
|
-
|
644
|
-
const
|
645
|
-
|
646
|
-
|
647
|
-
|
648
|
-
|
649
|
-
|
650
|
-
|
651
|
-
|
652
|
-
|
653
|
-
|
654
|
-
|
655
|
-
|
656
|
-
|
657
|
-
|
658
|
-
|
659
|
-
|
660
|
-
|
661
|
-
|
662
|
-
|
663
|
-
|
664
|
-
|
665
|
-
|
666
|
-
|
667
|
-
|
668
|
-
|
669
|
-
|
670
|
-
|
671
|
-
|
672
|
-
|
673
|
-
|
674
|
-
|
675
|
-
|
676
|
-
|
677
|
-
|
678
|
-
|
679
|
-
const
|
680
|
-
|
681
|
-
|
682
|
-
|
683
|
-
|
684
|
-
|
685
|
-
|
686
|
-
|
687
|
-
|
688
|
-
|
689
|
-
|
690
|
-
|
691
|
-
|
692
|
-
|
693
|
-
|
694
|
-
state.
|
695
|
-
|
696
|
-
|
697
|
-
|
698
|
-
|
699
|
-
|
700
|
-
|
701
|
-
|
702
|
-
|
703
|
-
|
704
|
-
//
|
705
|
-
|
706
|
-
|
707
|
-
|
708
|
-
|
709
|
-
|
710
|
-
|
711
|
-
|
712
|
-
|
713
|
-
|
714
|
-
|
715
|
-
|
716
|
-
|
717
|
-
|
718
|
-
//
|
719
|
-
|
720
|
-
|
721
|
-
|
722
|
-
|
723
|
-
|
724
|
-
state.
|
725
|
-
|
726
|
-
|
727
|
-
|
728
|
-
|
729
|
-
|
730
|
-
|
731
|
-
|
732
|
-
|
733
|
-
|
734
|
-
|
735
|
-
|
736
|
-
|
737
|
-
|
738
|
-
|
739
|
-
|
740
|
-
|
741
|
-
|
742
|
-
|
743
|
-
|
744
|
-
|
745
|
-
|
746
|
-
|
747
|
-
|
748
|
-
|
749
|
-
|
750
|
-
|
751
|
-
|
752
|
-
|
753
|
-
|
754
|
-
|
755
|
-
|
756
|
-
|
757
|
-
|
758
|
-
if
|
759
|
-
|
760
|
-
|
761
|
-
|
762
|
-
|
763
|
-
//
|
764
|
-
|
765
|
-
|
766
|
-
|
767
|
-
|
768
|
-
|
769
|
-
|
770
|
-
|
771
|
-
|
772
|
-
|
773
|
-
|
774
|
-
|
775
|
-
|
776
|
-
|
777
|
-
|
778
|
-
|
779
|
-
|
780
|
-
|
781
|
-
|
782
|
-
|
783
|
-
|
784
|
-
|
785
|
-
{
|
786
|
-
|
787
|
-
|
788
|
-
|
789
|
-
|
790
|
-
|
791
|
-
}
|
792
|
-
|
793
|
-
|
794
|
-
|
795
|
-
|
796
|
-
children
|
797
|
-
|
798
|
-
|
799
|
-
|
800
|
-
|
801
|
-
//
|
802
|
-
//
|
803
|
-
//
|
804
|
-
//
|
805
|
-
|
806
|
-
|
807
|
-
|
808
|
-
|
809
|
-
|
810
|
-
|
811
|
-
|
812
|
-
|
813
|
-
|
814
|
-
|
815
|
-
|
816
|
-
|
817
|
-
|
818
|
-
|
819
|
-
|
820
|
-
}
|
821
|
-
|
822
|
-
|
1
|
+
/**
|
2
|
+
* Why is this file patched?
|
3
|
+
* - replacing import to RNGestureHandlerModule - original code uses (old) Native Modules but RNOH supports only Turbo Modules
|
4
|
+
*/
|
5
|
+
|
6
|
+
import React, { useContext, useEffect, useRef, useState } from 'react';
|
7
|
+
import {
|
8
|
+
GestureType,
|
9
|
+
HandlerCallbacks,
|
10
|
+
BaseGesture,
|
11
|
+
GestureRef,
|
12
|
+
CALLBACK_TYPE,
|
13
|
+
} from 'react-native-gesture-handler/src/handlers/gestures/gesture';
|
14
|
+
import { Reanimated, SharedValue } from 'react-native-gesture-handler/src/handlers/gestures/reanimatedWrapper';
|
15
|
+
import { registerHandler, unregisterHandler } from 'react-native-gesture-handler/src/handlers/handlersRegistry';
|
16
|
+
import { RNGestureHandlerModule } from '../../RNGestureHandlerModule'; // RNGH: patch
|
17
|
+
import {
|
18
|
+
baseGestureHandlerWithMonitorProps,
|
19
|
+
filterConfig,
|
20
|
+
findNodeHandle,
|
21
|
+
GestureTouchEvent,
|
22
|
+
GestureUpdateEvent,
|
23
|
+
GestureStateChangeEvent,
|
24
|
+
HandlerStateChangeEvent,
|
25
|
+
UserSelect,
|
26
|
+
} from 'react-native-gesture-handler/src/handlers/gestureHandlerCommon';
|
27
|
+
import {
|
28
|
+
scheduleFlushOperations,
|
29
|
+
} from '../gestureHandlerCommon'; // RNGH: patch
|
30
|
+
import {
|
31
|
+
GestureStateManager,
|
32
|
+
GestureStateManagerType,
|
33
|
+
} from 'react-native-gesture-handler/src/handlers/gestures/gestureStateManager';
|
34
|
+
import { flingGestureHandlerProps } from 'react-native-gesture-handler/src/handlers/FlingGestureHandler';
|
35
|
+
import { forceTouchGestureHandlerProps } from 'react-native-gesture-handler/src/handlers/ForceTouchGestureHandler';
|
36
|
+
import { longPressGestureHandlerProps } from 'react-native-gesture-handler/src/handlers/LongPressGestureHandler';
|
37
|
+
import {
|
38
|
+
panGestureHandlerProps,
|
39
|
+
panGestureHandlerCustomNativeProps,
|
40
|
+
} from 'react-native-gesture-handler/src/handlers/PanGestureHandler';
|
41
|
+
import { tapGestureHandlerProps } from 'react-native-gesture-handler/src/handlers/TapGestureHandler';
|
42
|
+
import { State } from 'react-native-gesture-handler/src/State';
|
43
|
+
import { TouchEventType } from 'react-native-gesture-handler/src/TouchEventType';
|
44
|
+
import { ComposedGesture } from 'react-native-gesture-handler/src/handlers/gestures/gestureComposition';
|
45
|
+
import { ActionType } from 'react-native-gesture-handler/src/ActionType';
|
46
|
+
import {
|
47
|
+
isFabric,
|
48
|
+
isJestEnv,
|
49
|
+
REACT_NATIVE_VERSION,
|
50
|
+
tagMessage,
|
51
|
+
} from 'react-native-gesture-handler/src/utils';
|
52
|
+
import { getShadowNodeFromRef } from 'react-native-gesture-handler/src/getShadowNodeFromRef';
|
53
|
+
import { Platform } from 'react-native';
|
54
|
+
import type RNGestureHandlerModuleWeb from 'react-native-gesture-handler/src/RNGestureHandlerModule.web';
|
55
|
+
import { onGestureHandlerEvent } from 'react-native-gesture-handler/src/handlers/gestures/eventReceiver';
|
56
|
+
import { RNRenderer } from 'react-native-gesture-handler/src/RNRenderer';
|
57
|
+
import { isNewWebImplementationEnabled } from 'react-native-gesture-handler/src/EnableNewWebImplementation';
|
58
|
+
import { nativeViewGestureHandlerProps } from 'react-native-gesture-handler/src/handlers/NativeViewGestureHandler';
|
59
|
+
import GestureHandlerRootViewContext from 'react-native-gesture-handler/src/GestureHandlerRootViewContext';
|
60
|
+
|
61
|
+
declare const global: {
|
62
|
+
isFormsStackingContext: (node: unknown) => boolean | null; // JSI function
|
63
|
+
};
|
64
|
+
|
65
|
+
const ALLOWED_PROPS = [
|
66
|
+
...baseGestureHandlerWithMonitorProps,
|
67
|
+
...tapGestureHandlerProps,
|
68
|
+
...panGestureHandlerProps,
|
69
|
+
...panGestureHandlerCustomNativeProps,
|
70
|
+
...longPressGestureHandlerProps,
|
71
|
+
...forceTouchGestureHandlerProps,
|
72
|
+
...flingGestureHandlerProps,
|
73
|
+
...nativeViewGestureHandlerProps,
|
74
|
+
];
|
75
|
+
|
76
|
+
export type GestureConfigReference = {
|
77
|
+
config: GestureType[];
|
78
|
+
animatedEventHandler: unknown;
|
79
|
+
animatedHandlers: SharedValue<
|
80
|
+
HandlerCallbacks<Record<string, unknown>>[] | null
|
81
|
+
> | null;
|
82
|
+
firstExecution: boolean;
|
83
|
+
useReanimatedHook: boolean;
|
84
|
+
};
|
85
|
+
|
86
|
+
function convertToHandlerTag(ref: GestureRef): number {
|
87
|
+
if (typeof ref === 'number') {
|
88
|
+
return ref;
|
89
|
+
} else if (ref instanceof BaseGesture) {
|
90
|
+
return ref.handlerTag;
|
91
|
+
} else {
|
92
|
+
// @ts-ignore in this case it should be a ref either to gesture object or
|
93
|
+
// a gesture handler component, in both cases handlerTag property exists
|
94
|
+
return ref.current?.handlerTag ?? -1;
|
95
|
+
}
|
96
|
+
}
|
97
|
+
|
98
|
+
function extractValidHandlerTags(interactionGroup: GestureRef[] | undefined) {
|
99
|
+
return (
|
100
|
+
interactionGroup?.map(convertToHandlerTag)?.filter((tag) => tag > 0) ?? []
|
101
|
+
);
|
102
|
+
}
|
103
|
+
|
104
|
+
function dropHandlers(preparedGesture: GestureConfigReference) {
|
105
|
+
for (const handler of preparedGesture.config) {
|
106
|
+
RNGestureHandlerModule.dropGestureHandler(handler.handlerTag);
|
107
|
+
|
108
|
+
unregisterHandler(handler.handlerTag, handler.config.testId);
|
109
|
+
}
|
110
|
+
|
111
|
+
scheduleFlushOperations();
|
112
|
+
}
|
113
|
+
|
114
|
+
function checkGestureCallbacksForWorklets(gesture: GestureType) {
|
115
|
+
// if a gesture is explicitly marked to run on the JS thread there is no need to check
|
116
|
+
// if callbacks are worklets as the user is aware they will be ran on the JS thread
|
117
|
+
if (gesture.config.runOnJS) {
|
118
|
+
return;
|
119
|
+
}
|
120
|
+
|
121
|
+
const areSomeNotWorklets = gesture.handlers.isWorklet.includes(false);
|
122
|
+
const areSomeWorklets = gesture.handlers.isWorklet.includes(true);
|
123
|
+
|
124
|
+
// if some of the callbacks are worklets and some are not, and the gesture is not
|
125
|
+
// explicitly marked with `.runOnJS(true)` show an error
|
126
|
+
if (areSomeNotWorklets && areSomeWorklets) {
|
127
|
+
console.error(
|
128
|
+
tagMessage(
|
129
|
+
`Some of the callbacks in the gesture are worklets and some are not. Either make sure that all calbacks are marked as 'worklet' if you wish to run them on the UI thread or use '.runOnJS(true)' modifier on the gesture explicitly to run all callbacks on the JS thread.`
|
130
|
+
)
|
131
|
+
);
|
132
|
+
}
|
133
|
+
}
|
134
|
+
|
135
|
+
interface WebEventHandler {
|
136
|
+
onGestureHandlerEvent: (event: HandlerStateChangeEvent<unknown>) => void;
|
137
|
+
onGestureHandlerStateChange?: (
|
138
|
+
event: HandlerStateChangeEvent<unknown>
|
139
|
+
) => void;
|
140
|
+
}
|
141
|
+
|
142
|
+
interface AttachHandlersConfig {
|
143
|
+
preparedGesture: GestureConfigReference;
|
144
|
+
gestureConfig: ComposedGesture | GestureType;
|
145
|
+
gesture: GestureType[];
|
146
|
+
viewTag: number;
|
147
|
+
webEventHandlersRef: React.RefObject<WebEventHandler>;
|
148
|
+
mountedRef: React.RefObject<boolean>;
|
149
|
+
}
|
150
|
+
|
151
|
+
function attachHandlers({
|
152
|
+
preparedGesture,
|
153
|
+
gestureConfig,
|
154
|
+
gesture,
|
155
|
+
viewTag,
|
156
|
+
webEventHandlersRef,
|
157
|
+
mountedRef,
|
158
|
+
}: AttachHandlersConfig) {
|
159
|
+
if (!preparedGesture.firstExecution) {
|
160
|
+
gestureConfig.initialize();
|
161
|
+
} else {
|
162
|
+
preparedGesture.firstExecution = false;
|
163
|
+
}
|
164
|
+
|
165
|
+
// use queueMicrotask to extract handlerTags, because all refs should be initialized
|
166
|
+
// when it's ran
|
167
|
+
queueMicrotask(() => {
|
168
|
+
if (!mountedRef.current) {
|
169
|
+
return;
|
170
|
+
}
|
171
|
+
gestureConfig.prepare();
|
172
|
+
});
|
173
|
+
|
174
|
+
for (const handler of gesture) {
|
175
|
+
checkGestureCallbacksForWorklets(handler);
|
176
|
+
RNGestureHandlerModule.createGestureHandler(
|
177
|
+
handler.handlerName,
|
178
|
+
handler.handlerTag,
|
179
|
+
filterConfig(handler.config, ALLOWED_PROPS)
|
180
|
+
);
|
181
|
+
|
182
|
+
registerHandler(handler.handlerTag, handler, handler.config.testId);
|
183
|
+
}
|
184
|
+
|
185
|
+
// use queueMicrotask to extract handlerTags, because all refs should be initialized
|
186
|
+
// when it's ran
|
187
|
+
queueMicrotask(() => {
|
188
|
+
if (!mountedRef.current) {
|
189
|
+
return;
|
190
|
+
}
|
191
|
+
for (const handler of gesture) {
|
192
|
+
let requireToFail: number[] = [];
|
193
|
+
if (handler.config.requireToFail) {
|
194
|
+
requireToFail = extractValidHandlerTags(handler.config.requireToFail);
|
195
|
+
}
|
196
|
+
|
197
|
+
let simultaneousWith: number[] = [];
|
198
|
+
if (handler.config.simultaneousWith) {
|
199
|
+
simultaneousWith = extractValidHandlerTags(
|
200
|
+
handler.config.simultaneousWith
|
201
|
+
);
|
202
|
+
}
|
203
|
+
|
204
|
+
RNGestureHandlerModule.updateGestureHandler(
|
205
|
+
handler.handlerTag,
|
206
|
+
filterConfig(handler.config, ALLOWED_PROPS, {
|
207
|
+
simultaneousHandlers: simultaneousWith,
|
208
|
+
waitFor: requireToFail,
|
209
|
+
})
|
210
|
+
);
|
211
|
+
}
|
212
|
+
|
213
|
+
scheduleFlushOperations();
|
214
|
+
});
|
215
|
+
|
216
|
+
preparedGesture.config = gesture;
|
217
|
+
|
218
|
+
for (const gesture of preparedGesture.config) {
|
219
|
+
const actionType = gesture.shouldUseReanimated
|
220
|
+
? ActionType.REANIMATED_WORKLET
|
221
|
+
: ActionType.JS_FUNCTION_NEW_API;
|
222
|
+
|
223
|
+
if (Platform.OS === 'web') {
|
224
|
+
(
|
225
|
+
RNGestureHandlerModule.attachGestureHandler as typeof RNGestureHandlerModuleWeb.attachGestureHandler
|
226
|
+
)(
|
227
|
+
gesture.handlerTag,
|
228
|
+
viewTag,
|
229
|
+
ActionType.JS_FUNCTION_OLD_API, // ignored on web
|
230
|
+
webEventHandlersRef
|
231
|
+
);
|
232
|
+
} else {
|
233
|
+
RNGestureHandlerModule.attachGestureHandler(
|
234
|
+
gesture.handlerTag,
|
235
|
+
viewTag,
|
236
|
+
actionType
|
237
|
+
);
|
238
|
+
}
|
239
|
+
}
|
240
|
+
|
241
|
+
if (preparedGesture.animatedHandlers) {
|
242
|
+
const isAnimatedGesture = (g: GestureType) => g.shouldUseReanimated;
|
243
|
+
|
244
|
+
preparedGesture.animatedHandlers.value = gesture
|
245
|
+
.filter(isAnimatedGesture)
|
246
|
+
.map((g) => g.handlers) as unknown as HandlerCallbacks<
|
247
|
+
Record<string, unknown>
|
248
|
+
>[];
|
249
|
+
}
|
250
|
+
}
|
251
|
+
|
252
|
+
function updateHandlers(
|
253
|
+
preparedGesture: GestureConfigReference,
|
254
|
+
gestureConfig: ComposedGesture | GestureType,
|
255
|
+
gesture: GestureType[],
|
256
|
+
mountedRef: React.RefObject<boolean>
|
257
|
+
) {
|
258
|
+
gestureConfig.prepare();
|
259
|
+
|
260
|
+
for (let i = 0; i < gesture.length; i++) {
|
261
|
+
const handler = preparedGesture.config[i];
|
262
|
+
checkGestureCallbacksForWorklets(handler);
|
263
|
+
|
264
|
+
// only update handlerTag when it's actually different, it may be the same
|
265
|
+
// if gesture config object is wrapped with useMemo
|
266
|
+
if (gesture[i].handlerTag !== handler.handlerTag) {
|
267
|
+
gesture[i].handlerTag = handler.handlerTag;
|
268
|
+
gesture[i].handlers.handlerTag = handler.handlerTag;
|
269
|
+
}
|
270
|
+
}
|
271
|
+
|
272
|
+
// use queueMicrotask to extract handlerTags, because when it's ran, all refs should be updated
|
273
|
+
// and handlerTags in BaseGesture references should be updated in the loop above (we need to wait
|
274
|
+
// in case of external relations)
|
275
|
+
queueMicrotask(() => {
|
276
|
+
if (!mountedRef.current) {
|
277
|
+
return;
|
278
|
+
}
|
279
|
+
for (let i = 0; i < gesture.length; i++) {
|
280
|
+
const handler = preparedGesture.config[i];
|
281
|
+
|
282
|
+
handler.config = gesture[i].config;
|
283
|
+
handler.handlers = gesture[i].handlers;
|
284
|
+
|
285
|
+
const requireToFail = extractValidHandlerTags(
|
286
|
+
handler.config.requireToFail
|
287
|
+
);
|
288
|
+
|
289
|
+
const simultaneousWith = extractValidHandlerTags(
|
290
|
+
handler.config.simultaneousWith
|
291
|
+
);
|
292
|
+
|
293
|
+
RNGestureHandlerModule.updateGestureHandler(
|
294
|
+
handler.handlerTag,
|
295
|
+
filterConfig(handler.config, ALLOWED_PROPS, {
|
296
|
+
simultaneousHandlers: simultaneousWith,
|
297
|
+
waitFor: requireToFail,
|
298
|
+
})
|
299
|
+
);
|
300
|
+
|
301
|
+
registerHandler(handler.handlerTag, handler, handler.config.testId);
|
302
|
+
}
|
303
|
+
|
304
|
+
if (preparedGesture.animatedHandlers) {
|
305
|
+
const previousHandlersValue =
|
306
|
+
preparedGesture.animatedHandlers.value ?? [];
|
307
|
+
const newHandlersValue = preparedGesture.config
|
308
|
+
.filter((g) => g.shouldUseReanimated) // ignore gestures that shouldn't run on UI
|
309
|
+
.map((g) => g.handlers) as unknown as HandlerCallbacks<
|
310
|
+
Record<string, unknown>
|
311
|
+
>[];
|
312
|
+
|
313
|
+
// if amount of gesture configs changes, we need to update the callbacks in shared value
|
314
|
+
let shouldUpdateSharedValue =
|
315
|
+
previousHandlersValue.length !== newHandlersValue.length;
|
316
|
+
|
317
|
+
if (!shouldUpdateSharedValue) {
|
318
|
+
// if the amount is the same, we need to check if any of the configs inside has changed
|
319
|
+
for (let i = 0; i < newHandlersValue.length; i++) {
|
320
|
+
if (
|
321
|
+
// we can use the `gestureId` prop as it's unique for every config instance
|
322
|
+
newHandlersValue[i].gestureId !== previousHandlersValue[i].gestureId
|
323
|
+
) {
|
324
|
+
shouldUpdateSharedValue = true;
|
325
|
+
break;
|
326
|
+
}
|
327
|
+
}
|
328
|
+
}
|
329
|
+
|
330
|
+
if (shouldUpdateSharedValue) {
|
331
|
+
preparedGesture.animatedHandlers.value = newHandlersValue;
|
332
|
+
}
|
333
|
+
}
|
334
|
+
|
335
|
+
scheduleFlushOperations();
|
336
|
+
});
|
337
|
+
}
|
338
|
+
|
339
|
+
function needsToReattach(
|
340
|
+
preparedGesture: GestureConfigReference,
|
341
|
+
gesture: GestureType[]
|
342
|
+
) {
|
343
|
+
if (gesture.length !== preparedGesture.config.length) {
|
344
|
+
return true;
|
345
|
+
}
|
346
|
+
for (let i = 0; i < gesture.length; i++) {
|
347
|
+
if (
|
348
|
+
gesture[i].handlerName !== preparedGesture.config[i].handlerName ||
|
349
|
+
gesture[i].shouldUseReanimated !==
|
350
|
+
preparedGesture.config[i].shouldUseReanimated
|
351
|
+
) {
|
352
|
+
return true;
|
353
|
+
}
|
354
|
+
}
|
355
|
+
|
356
|
+
return false;
|
357
|
+
}
|
358
|
+
|
359
|
+
function isStateChangeEvent(
|
360
|
+
event: GestureUpdateEvent | GestureStateChangeEvent | GestureTouchEvent
|
361
|
+
): event is GestureStateChangeEvent {
|
362
|
+
'worklet';
|
363
|
+
// @ts-ignore Yes, the oldState prop is missing on GestureTouchEvent, that's the point
|
364
|
+
return event.oldState != null;
|
365
|
+
}
|
366
|
+
|
367
|
+
function isTouchEvent(
|
368
|
+
event: GestureUpdateEvent | GestureStateChangeEvent | GestureTouchEvent
|
369
|
+
): event is GestureTouchEvent {
|
370
|
+
'worklet';
|
371
|
+
return event.eventType != null;
|
372
|
+
}
|
373
|
+
|
374
|
+
function getHandler(
|
375
|
+
type: CALLBACK_TYPE,
|
376
|
+
gesture: HandlerCallbacks<Record<string, unknown>>
|
377
|
+
) {
|
378
|
+
'worklet';
|
379
|
+
switch (type) {
|
380
|
+
case CALLBACK_TYPE.BEGAN:
|
381
|
+
return gesture.onBegin;
|
382
|
+
case CALLBACK_TYPE.START:
|
383
|
+
return gesture.onStart;
|
384
|
+
case CALLBACK_TYPE.UPDATE:
|
385
|
+
return gesture.onUpdate;
|
386
|
+
case CALLBACK_TYPE.CHANGE:
|
387
|
+
return gesture.onChange;
|
388
|
+
case CALLBACK_TYPE.END:
|
389
|
+
return gesture.onEnd;
|
390
|
+
case CALLBACK_TYPE.FINALIZE:
|
391
|
+
return gesture.onFinalize;
|
392
|
+
case CALLBACK_TYPE.TOUCHES_DOWN:
|
393
|
+
return gesture.onTouchesDown;
|
394
|
+
case CALLBACK_TYPE.TOUCHES_MOVE:
|
395
|
+
return gesture.onTouchesMove;
|
396
|
+
case CALLBACK_TYPE.TOUCHES_UP:
|
397
|
+
return gesture.onTouchesUp;
|
398
|
+
case CALLBACK_TYPE.TOUCHES_CANCELLED:
|
399
|
+
return gesture.onTouchesCancelled;
|
400
|
+
}
|
401
|
+
}
|
402
|
+
|
403
|
+
function touchEventTypeToCallbackType(
|
404
|
+
eventType: TouchEventType
|
405
|
+
): CALLBACK_TYPE {
|
406
|
+
'worklet';
|
407
|
+
switch (eventType) {
|
408
|
+
case TouchEventType.TOUCHES_DOWN:
|
409
|
+
return CALLBACK_TYPE.TOUCHES_DOWN;
|
410
|
+
case TouchEventType.TOUCHES_MOVE:
|
411
|
+
return CALLBACK_TYPE.TOUCHES_MOVE;
|
412
|
+
case TouchEventType.TOUCHES_UP:
|
413
|
+
return CALLBACK_TYPE.TOUCHES_UP;
|
414
|
+
case TouchEventType.TOUCHES_CANCELLED:
|
415
|
+
return CALLBACK_TYPE.TOUCHES_CANCELLED;
|
416
|
+
}
|
417
|
+
return CALLBACK_TYPE.UNDEFINED;
|
418
|
+
}
|
419
|
+
|
420
|
+
function runWorklet(
|
421
|
+
type: CALLBACK_TYPE,
|
422
|
+
gesture: HandlerCallbacks<Record<string, unknown>>,
|
423
|
+
event: GestureStateChangeEvent | GestureUpdateEvent | GestureTouchEvent,
|
424
|
+
...args: any[]
|
425
|
+
) {
|
426
|
+
'worklet';
|
427
|
+
const handler = getHandler(type, gesture);
|
428
|
+
if (gesture.isWorklet[type]) {
|
429
|
+
// @ts-ignore Logic below makes sure the correct event is send to the
|
430
|
+
// correct handler.
|
431
|
+
handler?.(event, ...args);
|
432
|
+
} else if (handler) {
|
433
|
+
console.warn(tagMessage('Animated gesture callback must be a worklet'));
|
434
|
+
}
|
435
|
+
}
|
436
|
+
|
437
|
+
function useAnimatedGesture(
|
438
|
+
preparedGesture: GestureConfigReference,
|
439
|
+
needsRebuild: boolean
|
440
|
+
) {
|
441
|
+
if (!Reanimated) {
|
442
|
+
return;
|
443
|
+
}
|
444
|
+
|
445
|
+
// Hooks are called conditionally, but the condition is whether the
|
446
|
+
// react-native-reanimated is installed, which shouldn't change while running
|
447
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks
|
448
|
+
const sharedHandlersCallbacks = Reanimated.useSharedValue<
|
449
|
+
HandlerCallbacks<Record<string, unknown>>[] | null
|
450
|
+
>(null);
|
451
|
+
|
452
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks
|
453
|
+
const lastUpdateEvent = Reanimated.useSharedValue<
|
454
|
+
(GestureUpdateEvent | undefined)[]
|
455
|
+
>([]);
|
456
|
+
|
457
|
+
// not every gesture needs a state controller, init them lazily
|
458
|
+
const stateControllers: GestureStateManagerType[] = [];
|
459
|
+
|
460
|
+
const callback = (
|
461
|
+
event: GestureStateChangeEvent | GestureUpdateEvent | GestureTouchEvent
|
462
|
+
) => {
|
463
|
+
'worklet';
|
464
|
+
|
465
|
+
const currentCallback = sharedHandlersCallbacks.value;
|
466
|
+
if (!currentCallback) {
|
467
|
+
return;
|
468
|
+
}
|
469
|
+
|
470
|
+
for (let i = 0; i < currentCallback.length; i++) {
|
471
|
+
const gesture = currentCallback[i];
|
472
|
+
|
473
|
+
if (event.handlerTag === gesture.handlerTag) {
|
474
|
+
if (isStateChangeEvent(event)) {
|
475
|
+
if (
|
476
|
+
event.oldState === State.UNDETERMINED &&
|
477
|
+
event.state === State.BEGAN
|
478
|
+
) {
|
479
|
+
runWorklet(CALLBACK_TYPE.BEGAN, gesture, event);
|
480
|
+
} else if (
|
481
|
+
(event.oldState === State.BEGAN ||
|
482
|
+
event.oldState === State.UNDETERMINED) &&
|
483
|
+
event.state === State.ACTIVE
|
484
|
+
) {
|
485
|
+
runWorklet(CALLBACK_TYPE.START, gesture, event);
|
486
|
+
lastUpdateEvent.value[gesture.handlerTag] = undefined;
|
487
|
+
} else if (
|
488
|
+
event.oldState !== event.state &&
|
489
|
+
event.state === State.END
|
490
|
+
) {
|
491
|
+
if (event.oldState === State.ACTIVE) {
|
492
|
+
runWorklet(CALLBACK_TYPE.END, gesture, event, true);
|
493
|
+
}
|
494
|
+
runWorklet(CALLBACK_TYPE.FINALIZE, gesture, event, true);
|
495
|
+
} else if (
|
496
|
+
(event.state === State.FAILED || event.state === State.CANCELLED) &&
|
497
|
+
event.state !== event.oldState
|
498
|
+
) {
|
499
|
+
if (event.oldState === State.ACTIVE) {
|
500
|
+
runWorklet(CALLBACK_TYPE.END, gesture, event, false);
|
501
|
+
}
|
502
|
+
runWorklet(CALLBACK_TYPE.FINALIZE, gesture, event, false);
|
503
|
+
}
|
504
|
+
} else if (isTouchEvent(event)) {
|
505
|
+
if (!stateControllers[i]) {
|
506
|
+
stateControllers[i] = GestureStateManager.create(event.handlerTag);
|
507
|
+
}
|
508
|
+
|
509
|
+
if (event.eventType !== TouchEventType.UNDETERMINED) {
|
510
|
+
runWorklet(
|
511
|
+
touchEventTypeToCallbackType(event.eventType),
|
512
|
+
gesture,
|
513
|
+
event,
|
514
|
+
stateControllers[i]
|
515
|
+
);
|
516
|
+
}
|
517
|
+
} else {
|
518
|
+
runWorklet(CALLBACK_TYPE.UPDATE, gesture, event);
|
519
|
+
|
520
|
+
if (gesture.onChange && gesture.changeEventCalculator) {
|
521
|
+
runWorklet(
|
522
|
+
CALLBACK_TYPE.CHANGE,
|
523
|
+
gesture,
|
524
|
+
gesture.changeEventCalculator?.(
|
525
|
+
event,
|
526
|
+
lastUpdateEvent.value[gesture.handlerTag]
|
527
|
+
)
|
528
|
+
);
|
529
|
+
|
530
|
+
lastUpdateEvent.value[gesture.handlerTag] = event;
|
531
|
+
}
|
532
|
+
}
|
533
|
+
}
|
534
|
+
}
|
535
|
+
};
|
536
|
+
|
537
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks
|
538
|
+
const event = Reanimated.useEvent(
|
539
|
+
callback,
|
540
|
+
['onGestureHandlerStateChange', 'onGestureHandlerEvent'],
|
541
|
+
needsRebuild
|
542
|
+
);
|
543
|
+
|
544
|
+
preparedGesture.animatedEventHandler = event;
|
545
|
+
preparedGesture.animatedHandlers = sharedHandlersCallbacks;
|
546
|
+
}
|
547
|
+
|
548
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
549
|
+
function validateDetectorChildren(ref: any) {
|
550
|
+
// finds the first native view under the Wrap component and traverses the fiber tree upwards
|
551
|
+
// to check whether there is more than one native view as a pseudo-direct child of GestureDetector
|
552
|
+
// i.e. this is not ok:
|
553
|
+
// Wrap
|
554
|
+
// |
|
555
|
+
// / \
|
556
|
+
// / \
|
557
|
+
// / \
|
558
|
+
// / \
|
559
|
+
// NativeView NativeView
|
560
|
+
//
|
561
|
+
// but this is fine:
|
562
|
+
// Wrap
|
563
|
+
// |
|
564
|
+
// NativeView
|
565
|
+
// |
|
566
|
+
// / \
|
567
|
+
// / \
|
568
|
+
// / \
|
569
|
+
// / \
|
570
|
+
// NativeView NativeView
|
571
|
+
if (__DEV__ && Platform.OS !== 'web') {
|
572
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
573
|
+
const wrapType =
|
574
|
+
REACT_NATIVE_VERSION.minor > 63 || REACT_NATIVE_VERSION.major > 0
|
575
|
+
? // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
|
576
|
+
ref._reactInternals.elementType
|
577
|
+
: // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
|
578
|
+
ref._reactInternalFiber.elementType;
|
579
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
580
|
+
let instance =
|
581
|
+
RNRenderer.findHostInstance_DEPRECATED(
|
582
|
+
ref
|
583
|
+
)._internalFiberInstanceHandleDEV;
|
584
|
+
|
585
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
|
586
|
+
while (instance && instance.elementType !== wrapType) {
|
587
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
|
588
|
+
if (instance.sibling) {
|
589
|
+
throw new Error(
|
590
|
+
'GestureDetector has more than one native view as its children. This can happen if you are using a custom component that renders multiple views, like React.Fragment. You should wrap content of GestureDetector with a <View> or <Animated.View>.'
|
591
|
+
);
|
592
|
+
}
|
593
|
+
|
594
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access
|
595
|
+
instance = instance.return;
|
596
|
+
}
|
597
|
+
}
|
598
|
+
}
|
599
|
+
|
600
|
+
const applyUserSelectProp = (
|
601
|
+
userSelect: UserSelect,
|
602
|
+
gesture: ComposedGesture | GestureType
|
603
|
+
): void => {
|
604
|
+
for (const g of gesture.toGestureArray()) {
|
605
|
+
g.config.userSelect = userSelect;
|
606
|
+
}
|
607
|
+
};
|
608
|
+
|
609
|
+
interface GestureDetectorProps {
|
610
|
+
gesture: ComposedGesture | GestureType;
|
611
|
+
userSelect?: UserSelect;
|
612
|
+
children?: React.ReactNode;
|
613
|
+
}
|
614
|
+
interface GestureDetectorState {
|
615
|
+
firstRender: boolean;
|
616
|
+
viewRef: React.Component | null;
|
617
|
+
previousViewTag: number;
|
618
|
+
forceReattach: boolean;
|
619
|
+
}
|
620
|
+
export const GestureDetector = (props: GestureDetectorProps) => {
|
621
|
+
const rootViewContext = useContext(GestureHandlerRootViewContext);
|
622
|
+
if (__DEV__ && !rootViewContext && !isJestEnv() && Platform.OS !== 'web' && (Platform.OS as any) !== "harmony") { // RNOH: patch
|
623
|
+
throw new Error(
|
624
|
+
'GestureDetector must be used as a descendant of GestureHandlerRootView. Otherwise the gestures will not be recognized. See https://docs.swmansion.com/react-native-gesture-handler/docs/installation for more details.'
|
625
|
+
);
|
626
|
+
}
|
627
|
+
|
628
|
+
const gestureConfig = props.gesture;
|
629
|
+
|
630
|
+
if (props.userSelect) {
|
631
|
+
applyUserSelectProp(props.userSelect, gestureConfig);
|
632
|
+
}
|
633
|
+
|
634
|
+
const gesture = gestureConfig.toGestureArray();
|
635
|
+
const useReanimatedHook = gesture.some((g) => g.shouldUseReanimated);
|
636
|
+
|
637
|
+
// store state in ref to prevent unnecessary renders
|
638
|
+
const state = useRef<GestureDetectorState>({
|
639
|
+
firstRender: true,
|
640
|
+
viewRef: null,
|
641
|
+
previousViewTag: -1,
|
642
|
+
forceReattach: false,
|
643
|
+
}).current;
|
644
|
+
const mountedRef = useRef(false);
|
645
|
+
const webEventHandlersRef = useRef<WebEventHandler>({
|
646
|
+
onGestureHandlerEvent: (e: HandlerStateChangeEvent<unknown>) => {
|
647
|
+
onGestureHandlerEvent(e.nativeEvent);
|
648
|
+
},
|
649
|
+
onGestureHandlerStateChange: isNewWebImplementationEnabled()
|
650
|
+
? (e: HandlerStateChangeEvent<unknown>) => {
|
651
|
+
onGestureHandlerEvent(e.nativeEvent);
|
652
|
+
}
|
653
|
+
: undefined,
|
654
|
+
});
|
655
|
+
|
656
|
+
const [renderState, setRenderState] = useState(false);
|
657
|
+
function forceRender() {
|
658
|
+
setRenderState(!renderState);
|
659
|
+
}
|
660
|
+
|
661
|
+
const preparedGesture = React.useRef<GestureConfigReference>({
|
662
|
+
config: gesture,
|
663
|
+
animatedEventHandler: null,
|
664
|
+
animatedHandlers: null,
|
665
|
+
firstExecution: true,
|
666
|
+
useReanimatedHook: useReanimatedHook,
|
667
|
+
}).current;
|
668
|
+
|
669
|
+
if (useReanimatedHook !== preparedGesture.useReanimatedHook) {
|
670
|
+
throw new Error(
|
671
|
+
tagMessage(
|
672
|
+
'You cannot change the thread the callbacks are ran on while the app is running'
|
673
|
+
)
|
674
|
+
);
|
675
|
+
}
|
676
|
+
|
677
|
+
function onHandlersUpdate(skipConfigUpdate?: boolean) {
|
678
|
+
// if the underlying view has changed we need to reattach handlers to the new view
|
679
|
+
const viewTag = findNodeHandle(state.viewRef) as number;
|
680
|
+
const forceReattach = viewTag !== state.previousViewTag;
|
681
|
+
|
682
|
+
if (forceReattach || needsToReattach(preparedGesture, gesture)) {
|
683
|
+
validateDetectorChildren(state.viewRef);
|
684
|
+
dropHandlers(preparedGesture);
|
685
|
+
attachHandlers({
|
686
|
+
preparedGesture,
|
687
|
+
gestureConfig,
|
688
|
+
gesture,
|
689
|
+
webEventHandlersRef,
|
690
|
+
viewTag,
|
691
|
+
mountedRef,
|
692
|
+
});
|
693
|
+
|
694
|
+
state.previousViewTag = viewTag;
|
695
|
+
state.forceReattach = forceReattach;
|
696
|
+
if (forceReattach) {
|
697
|
+
forceRender();
|
698
|
+
}
|
699
|
+
} else if (!skipConfigUpdate) {
|
700
|
+
updateHandlers(preparedGesture, gestureConfig, gesture, mountedRef);
|
701
|
+
}
|
702
|
+
}
|
703
|
+
|
704
|
+
// Reanimated event should be rebuilt only when gestures are reattached, otherwise
|
705
|
+
// config update will be enough as all necessary items are stored in shared values anyway
|
706
|
+
const needsToRebuildReanimatedEvent =
|
707
|
+
preparedGesture.firstExecution ||
|
708
|
+
needsToReattach(preparedGesture, gesture) ||
|
709
|
+
state.forceReattach;
|
710
|
+
|
711
|
+
state.forceReattach = false;
|
712
|
+
|
713
|
+
if (preparedGesture.firstExecution) {
|
714
|
+
gestureConfig.initialize();
|
715
|
+
}
|
716
|
+
|
717
|
+
if (useReanimatedHook) {
|
718
|
+
// Whether animatedGesture or gesture is used shouldn't change while the app is running
|
719
|
+
// eslint-disable-next-line react-hooks/rules-of-hooks
|
720
|
+
useAnimatedGesture(preparedGesture, needsToRebuildReanimatedEvent);
|
721
|
+
}
|
722
|
+
|
723
|
+
useEffect(() => {
|
724
|
+
const viewTag = findNodeHandle(state.viewRef) as number;
|
725
|
+
state.firstRender = true;
|
726
|
+
mountedRef.current = true;
|
727
|
+
|
728
|
+
validateDetectorChildren(state.viewRef);
|
729
|
+
|
730
|
+
attachHandlers({
|
731
|
+
preparedGesture,
|
732
|
+
gestureConfig,
|
733
|
+
gesture,
|
734
|
+
webEventHandlersRef,
|
735
|
+
viewTag,
|
736
|
+
mountedRef,
|
737
|
+
});
|
738
|
+
|
739
|
+
return () => {
|
740
|
+
mountedRef.current = false;
|
741
|
+
dropHandlers(preparedGesture);
|
742
|
+
};
|
743
|
+
}, []);
|
744
|
+
|
745
|
+
useEffect(() => {
|
746
|
+
if (!state.firstRender) {
|
747
|
+
onHandlersUpdate();
|
748
|
+
} else {
|
749
|
+
state.firstRender = false;
|
750
|
+
}
|
751
|
+
}, [props]);
|
752
|
+
|
753
|
+
const refFunction = (ref: unknown) => {
|
754
|
+
if (ref !== null) {
|
755
|
+
// @ts-ignore Just setting the view ref
|
756
|
+
state.viewRef = ref;
|
757
|
+
|
758
|
+
// if it's the first render, also set the previousViewTag to prevent reattaching gestures when not needed
|
759
|
+
if (state.previousViewTag === -1) {
|
760
|
+
state.previousViewTag = findNodeHandle(state.viewRef) as number;
|
761
|
+
}
|
762
|
+
|
763
|
+
// pass true as `skipConfigUpdate`, here we only want to trigger the eventual reattaching of handlers
|
764
|
+
// in case the view has changed, while config update would be handled be the `useEffect` above
|
765
|
+
onHandlersUpdate(true);
|
766
|
+
|
767
|
+
if (isFabric()) {
|
768
|
+
const node = getShadowNodeFromRef(ref);
|
769
|
+
if (global.isFormsStackingContext(node) === false) {
|
770
|
+
console.error(
|
771
|
+
tagMessage(
|
772
|
+
'GestureDetector has received a child that may get view-flattened. ' +
|
773
|
+
'\nTo prevent it from misbehaving you need to wrap the child with a `<View collapsable={false}>`.'
|
774
|
+
)
|
775
|
+
);
|
776
|
+
}
|
777
|
+
}
|
778
|
+
}
|
779
|
+
};
|
780
|
+
|
781
|
+
if (useReanimatedHook) {
|
782
|
+
return (
|
783
|
+
<AnimatedWrap
|
784
|
+
ref={refFunction}
|
785
|
+
onGestureHandlerEvent={preparedGesture.animatedEventHandler}>
|
786
|
+
{props.children}
|
787
|
+
</AnimatedWrap>
|
788
|
+
);
|
789
|
+
} else {
|
790
|
+
return <Wrap ref={refFunction}>{props.children}</Wrap>;
|
791
|
+
}
|
792
|
+
};
|
793
|
+
|
794
|
+
class Wrap extends React.Component<{
|
795
|
+
onGestureHandlerEvent?: unknown;
|
796
|
+
// implicit `children` prop has been removed in @types/react^18.0.0
|
797
|
+
children?: React.ReactNode;
|
798
|
+
}> {
|
799
|
+
render() {
|
800
|
+
try {
|
801
|
+
// I don't think that fighting with types over such a simple function is worth it
|
802
|
+
// The only thing it does is add 'collapsable: false' to the child component
|
803
|
+
// to make sure it is in the native view hierarchy so the detector can find
|
804
|
+
// correct viewTag to attach to.
|
805
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
806
|
+
const child: any = React.Children.only(this.props.children);
|
807
|
+
return React.cloneElement(
|
808
|
+
child,
|
809
|
+
{ collapsable: false },
|
810
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
|
811
|
+
child.props.children
|
812
|
+
);
|
813
|
+
} catch (e) {
|
814
|
+
throw new Error(
|
815
|
+
tagMessage(
|
816
|
+
`GestureDetector got more than one view as a child. If you want the gesture to work on multiple views, wrap them with a common parent and attach the gesture to that view.`
|
817
|
+
)
|
818
|
+
);
|
819
|
+
}
|
820
|
+
}
|
821
|
+
}
|
822
|
+
|
823
|
+
const AnimatedWrap = Reanimated?.default?.createAnimatedComponent(Wrap) ?? Wrap;
|