@react-native-oh-tpl/react-native-gesture-handler 2.12.1-0.0.1 → 2.12.6-1
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +1 -62
- 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 +11 -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 +1 -1
- 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 +36 -57
- package/{src/web/tools → harmony/gesture_handler/src/main/ets}/LeastSquareSolver.ts +1 -1
- 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 +13 -14
- 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 +56 -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 +4 -4
- 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 +94 -136
- package/lib/commonjs/components/touchables/GenericTouchable.js.map +1 -1
- package/lib/commonjs/components/touchables/TouchableOpacity.js +32 -51
- 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 +16 -26
- 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 +89 -124
- package/lib/module/components/touchables/GenericTouchable.js.map +1 -1
- package/lib/module/components/touchables/TouchableOpacity.js +27 -41
- 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 +11 -16
- 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 +34 -120
- package/src/RNGestureHandlerModule.ts +4 -48
- package/src/components/GestureButtons.tsx +7 -5
- package/src/components/GestureHandlerButton.tsx +3 -3
- package/src/components/GestureHandlerRootView.tsx +15 -4
- package/src/components/RNGestureHandlerButton.tsx +23 -0
- package/src/components/touchables/GenericTouchable.tsx +7 -7
- package/src/components/touchables/TouchableOpacity.tsx +2 -1
- package/src/components/touchables/TouchableWithoutFeedback.tsx +3 -3
- package/src/components/touchables/index.ts +4 -4
- package/src/handlers/NativeViewGestureHandler.ts +1 -1
- package/src/handlers/PanGestureHandler.ts +4 -2
- package/src/handlers/TapGestureHandler.ts +2 -1
- package/src/handlers/createHandler.tsx +17 -15
- package/src/handlers/createNativeWrapper.tsx +2 -1
- package/src/handlers/gestureHandlerCommon.ts +5 -240
- package/src/handlers/gestures/GestureDetector.tsx +40 -39
- package/src/index.ts +158 -160
- package/src/init.ts +3 -3
- package/DrawerLayout/package.json +0 -6
- package/LICENSE +0 -21
- 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,8 +0,0 @@
|
|
1
|
-
package com.swmansion.gesturehandler.core
|
2
|
-
|
3
|
-
interface GestureHandlerInteractionController {
|
4
|
-
fun shouldWaitForHandlerFailure(handler: GestureHandler<*>, otherHandler: GestureHandler<*>): Boolean
|
5
|
-
fun shouldRequireHandlerToWaitForFailure(handler: GestureHandler<*>, otherHandler: GestureHandler<*>): Boolean
|
6
|
-
fun shouldRecognizeSimultaneously(handler: GestureHandler<*>, otherHandler: GestureHandler<*>): Boolean
|
7
|
-
fun shouldHandlerBeCancelledBy(handler: GestureHandler<*>, otherHandler: GestureHandler<*>): Boolean
|
8
|
-
}
|
package/android/src/main/java/com/swmansion/gesturehandler/core/GestureHandlerOrchestrator.kt
DELETED
@@ -1,671 +0,0 @@
|
|
1
|
-
package com.swmansion.gesturehandler.core
|
2
|
-
|
3
|
-
import android.graphics.Matrix
|
4
|
-
import android.graphics.PointF
|
5
|
-
import android.view.MotionEvent
|
6
|
-
import android.view.View
|
7
|
-
import android.view.ViewGroup
|
8
|
-
import android.widget.EditText
|
9
|
-
import java.util.*
|
10
|
-
|
11
|
-
class GestureHandlerOrchestrator(
|
12
|
-
private val wrapperView: ViewGroup,
|
13
|
-
private val handlerRegistry: GestureHandlerRegistry,
|
14
|
-
private val viewConfigHelper: ViewConfigurationHelper,
|
15
|
-
) {
|
16
|
-
/**
|
17
|
-
* Minimum alpha (value from 0 to 1) that should be set to a view so that it can be treated as a
|
18
|
-
* gesture target. E.g. if set to 0.1 then views that less than 10% opaque will be ignored when
|
19
|
-
* traversing view hierarchy and looking for gesture handlers.
|
20
|
-
*/
|
21
|
-
var minimumAlphaForTraversal = DEFAULT_MIN_ALPHA_FOR_TRAVERSAL
|
22
|
-
private val gestureHandlers = arrayListOf<GestureHandler<*>>()
|
23
|
-
private val awaitingHandlers = arrayListOf<GestureHandler<*>>()
|
24
|
-
private val preparedHandlers = arrayListOf<GestureHandler<*>>()
|
25
|
-
private var isHandlingTouch = false
|
26
|
-
private var handlingChangeSemaphore = 0
|
27
|
-
private var finishedHandlersCleanupScheduled = false
|
28
|
-
private var activationIndex = 0
|
29
|
-
|
30
|
-
/**
|
31
|
-
* Should be called from the view wrapper
|
32
|
-
*/
|
33
|
-
fun onTouchEvent(event: MotionEvent): Boolean {
|
34
|
-
isHandlingTouch = true
|
35
|
-
val action = event.actionMasked
|
36
|
-
if (action == MotionEvent.ACTION_DOWN || action == MotionEvent.ACTION_POINTER_DOWN || action == MotionEvent.ACTION_HOVER_MOVE) {
|
37
|
-
extractGestureHandlers(event)
|
38
|
-
} else if (action == MotionEvent.ACTION_CANCEL) {
|
39
|
-
cancelAll()
|
40
|
-
}
|
41
|
-
deliverEventToGestureHandlers(event)
|
42
|
-
isHandlingTouch = false
|
43
|
-
if (finishedHandlersCleanupScheduled && handlingChangeSemaphore == 0) {
|
44
|
-
cleanupFinishedHandlers()
|
45
|
-
}
|
46
|
-
return true
|
47
|
-
}
|
48
|
-
|
49
|
-
fun getHandlersForView(view: View) = handlerRegistry.getHandlersForView(view)
|
50
|
-
|
51
|
-
private fun scheduleFinishedHandlersCleanup() {
|
52
|
-
if (isHandlingTouch || handlingChangeSemaphore != 0) {
|
53
|
-
finishedHandlersCleanupScheduled = true
|
54
|
-
} else {
|
55
|
-
cleanupFinishedHandlers()
|
56
|
-
}
|
57
|
-
}
|
58
|
-
|
59
|
-
private fun cleanupFinishedHandlers() {
|
60
|
-
for (handler in gestureHandlers.asReversed()) {
|
61
|
-
if (isFinished(handler.state) && !handler.isAwaiting) {
|
62
|
-
handler.reset()
|
63
|
-
handler.apply {
|
64
|
-
isActive = false
|
65
|
-
isAwaiting = false
|
66
|
-
activationIndex = Int.MAX_VALUE
|
67
|
-
}
|
68
|
-
}
|
69
|
-
}
|
70
|
-
|
71
|
-
gestureHandlers.removeAll { isFinished(it.state) && !it.isAwaiting }
|
72
|
-
|
73
|
-
finishedHandlersCleanupScheduled = false
|
74
|
-
}
|
75
|
-
|
76
|
-
private fun hasOtherHandlerToWaitFor(handler: GestureHandler<*>): Boolean {
|
77
|
-
for (otherHandler in gestureHandlers) {
|
78
|
-
if (!isFinished(otherHandler.state) && shouldHandlerWaitForOther(handler, otherHandler)) {
|
79
|
-
return true
|
80
|
-
}
|
81
|
-
}
|
82
|
-
return false
|
83
|
-
}
|
84
|
-
|
85
|
-
private fun tryActivate(handler: GestureHandler<*>) {
|
86
|
-
// see if there is anyone else who we need to wait for
|
87
|
-
if (hasOtherHandlerToWaitFor(handler)) {
|
88
|
-
addAwaitingHandler(handler)
|
89
|
-
} else {
|
90
|
-
// we can activate handler right away
|
91
|
-
makeActive(handler)
|
92
|
-
handler.isAwaiting = false
|
93
|
-
}
|
94
|
-
}
|
95
|
-
|
96
|
-
private fun cleanupAwaitingHandlers() {
|
97
|
-
awaitingHandlers.removeAll { !it.isAwaiting }
|
98
|
-
}
|
99
|
-
|
100
|
-
/*package*/
|
101
|
-
fun onHandlerStateChange(handler: GestureHandler<*>, newState: Int, prevState: Int) {
|
102
|
-
handlingChangeSemaphore += 1
|
103
|
-
if (isFinished(newState)) {
|
104
|
-
// if there were handlers awaiting completion of this handler, we can trigger active state
|
105
|
-
for (otherHandler in awaitingHandlers) {
|
106
|
-
if (shouldHandlerWaitForOther(otherHandler, handler)) {
|
107
|
-
if (newState == GestureHandler.STATE_END) {
|
108
|
-
// gesture has ended, we need to kill the awaiting handler
|
109
|
-
otherHandler.cancel()
|
110
|
-
if (otherHandler.state == GestureHandler.STATE_END) {
|
111
|
-
// Handle edge case, where discrete gestures end immediately after activation thus
|
112
|
-
// their state is set to END and when the gesture they are waiting for activates they
|
113
|
-
// should be cancelled, however `cancel` was never sent as gestures were already in the END state.
|
114
|
-
// Send synthetic BEGAN -> CANCELLED to properly handle JS logic
|
115
|
-
otherHandler.dispatchStateChange(
|
116
|
-
GestureHandler.STATE_CANCELLED,
|
117
|
-
GestureHandler.STATE_BEGAN
|
118
|
-
)
|
119
|
-
}
|
120
|
-
otherHandler.isAwaiting = false
|
121
|
-
} else {
|
122
|
-
// gesture has failed recognition, we may try activating
|
123
|
-
tryActivate(otherHandler)
|
124
|
-
}
|
125
|
-
}
|
126
|
-
}
|
127
|
-
cleanupAwaitingHandlers()
|
128
|
-
}
|
129
|
-
if (newState == GestureHandler.STATE_ACTIVE) {
|
130
|
-
tryActivate(handler)
|
131
|
-
} else if (prevState == GestureHandler.STATE_ACTIVE || prevState == GestureHandler.STATE_END) {
|
132
|
-
if (handler.isActive) {
|
133
|
-
handler.dispatchStateChange(newState, prevState)
|
134
|
-
} else if (prevState == GestureHandler.STATE_ACTIVE && (newState == GestureHandler.STATE_CANCELLED || newState == GestureHandler.STATE_FAILED)) {
|
135
|
-
// Handle edge case where handler awaiting for another one tries to activate but finishes
|
136
|
-
// before the other would not send state change event upon ending. Note that we only want
|
137
|
-
// to do this if the newState is either CANCELLED or FAILED, if it is END we still want to
|
138
|
-
// wait for the other handler to finish as in that case synthetic events will be sent by the
|
139
|
-
// makeActive method.
|
140
|
-
handler.dispatchStateChange(newState, GestureHandler.STATE_BEGAN)
|
141
|
-
}
|
142
|
-
} else if (prevState != GestureHandler.STATE_UNDETERMINED || newState != GestureHandler.STATE_CANCELLED) {
|
143
|
-
// If handler is changing state from UNDETERMINED to CANCELLED, the state change event shouldn't
|
144
|
-
// be sent. Handler hasn't yet began so it may not be initialized which results in crashes.
|
145
|
-
// If it doesn't crash, there may be some weird behavior on JS side, as `onFinalize` will be
|
146
|
-
// called without calling `onBegin` first.
|
147
|
-
handler.dispatchStateChange(newState, prevState)
|
148
|
-
}
|
149
|
-
handlingChangeSemaphore -= 1
|
150
|
-
scheduleFinishedHandlersCleanup()
|
151
|
-
}
|
152
|
-
|
153
|
-
private fun makeActive(handler: GestureHandler<*>) {
|
154
|
-
val currentState = handler.state
|
155
|
-
with(handler) {
|
156
|
-
isAwaiting = false
|
157
|
-
isActive = true
|
158
|
-
shouldResetProgress = true
|
159
|
-
activationIndex = this@GestureHandlerOrchestrator.activationIndex++
|
160
|
-
}
|
161
|
-
|
162
|
-
for (otherHandler in gestureHandlers.asReversed()) {
|
163
|
-
if (shouldHandlerBeCancelledBy(otherHandler, handler)) {
|
164
|
-
otherHandler.cancel()
|
165
|
-
}
|
166
|
-
}
|
167
|
-
|
168
|
-
// Clear all awaiting handlers waiting for the current handler to fail
|
169
|
-
for (otherHandler in awaitingHandlers.reversed()) {
|
170
|
-
if (shouldHandlerBeCancelledBy(otherHandler, handler)) {
|
171
|
-
otherHandler.cancel()
|
172
|
-
otherHandler.isAwaiting = false
|
173
|
-
}
|
174
|
-
}
|
175
|
-
cleanupAwaitingHandlers()
|
176
|
-
|
177
|
-
// Dispatch state change event if handler is no longer in the active state we should also
|
178
|
-
// trigger END state change and UNDETERMINED state change if necessary
|
179
|
-
handler.dispatchStateChange(GestureHandler.STATE_ACTIVE, GestureHandler.STATE_BEGAN)
|
180
|
-
if (currentState != GestureHandler.STATE_ACTIVE) {
|
181
|
-
handler.dispatchStateChange(GestureHandler.STATE_END, GestureHandler.STATE_ACTIVE)
|
182
|
-
if (currentState != GestureHandler.STATE_END) {
|
183
|
-
handler.dispatchStateChange(GestureHandler.STATE_UNDETERMINED, GestureHandler.STATE_END)
|
184
|
-
}
|
185
|
-
}
|
186
|
-
}
|
187
|
-
|
188
|
-
private fun deliverEventToGestureHandlers(event: MotionEvent) {
|
189
|
-
// Copy handlers to "prepared handlers" array, because the list of active handlers can change
|
190
|
-
// as a result of state updates
|
191
|
-
preparedHandlers.clear()
|
192
|
-
preparedHandlers.addAll(gestureHandlers)
|
193
|
-
|
194
|
-
// We want to deliver events to active handlers first in order of their activation (handlers
|
195
|
-
// that activated first will first get event delivered). Otherwise we deliver events in the
|
196
|
-
// order in which handlers has been added ("most direct" children goes first). Therefore we rely
|
197
|
-
// on Arrays.sort providing a stable sort (as children are registered in order in which they
|
198
|
-
// should be tested)
|
199
|
-
preparedHandlers.sortWith(handlersComparator)
|
200
|
-
for (handler in preparedHandlers) {
|
201
|
-
deliverEventToGestureHandler(handler, event)
|
202
|
-
}
|
203
|
-
}
|
204
|
-
|
205
|
-
private fun cancelAll() {
|
206
|
-
for (handler in awaitingHandlers.reversed()) {
|
207
|
-
handler.cancel()
|
208
|
-
}
|
209
|
-
// Copy handlers to "prepared handlers" array, because the list of active handlers can change
|
210
|
-
// as a result of state updates
|
211
|
-
preparedHandlers.clear()
|
212
|
-
preparedHandlers.addAll(gestureHandlers)
|
213
|
-
|
214
|
-
for (handler in gestureHandlers.reversed()) {
|
215
|
-
handler.cancel()
|
216
|
-
}
|
217
|
-
}
|
218
|
-
|
219
|
-
private fun deliverEventToGestureHandler(handler: GestureHandler<*>, sourceEvent: MotionEvent) {
|
220
|
-
if (!isViewAttachedUnderWrapper(handler.view)) {
|
221
|
-
handler.cancel()
|
222
|
-
return
|
223
|
-
}
|
224
|
-
if (!handler.wantEvents()) {
|
225
|
-
return
|
226
|
-
}
|
227
|
-
|
228
|
-
val action = sourceEvent.actionMasked
|
229
|
-
val event = transformEventToViewCoords(handler.view, MotionEvent.obtain(sourceEvent))
|
230
|
-
|
231
|
-
// Touch events are sent before the handler itself has a chance to process them,
|
232
|
-
// mainly because `onTouchesUp` shoul be send befor gesture finishes. This means that
|
233
|
-
// the first `onTouchesDown` event is sent before a gesture begins, activation in
|
234
|
-
// callback for this event causes problems because the handler doesn't have a chance
|
235
|
-
// to initialize itself with starting values of pointer (in pan this causes translation
|
236
|
-
// to be equal to the coordinates of the pointer). The simplest solution is to send
|
237
|
-
// the first `onTouchesDown` event after the handler processes it and changes state
|
238
|
-
// to `BEGAN`.
|
239
|
-
if (handler.needsPointerData && handler.state != 0) {
|
240
|
-
handler.updatePointerData(event)
|
241
|
-
}
|
242
|
-
|
243
|
-
if (!handler.isAwaiting || action != MotionEvent.ACTION_MOVE) {
|
244
|
-
val isFirstEvent = handler.state == 0
|
245
|
-
handler.handle(event, sourceEvent)
|
246
|
-
if (handler.isActive) {
|
247
|
-
// After handler is done waiting for other one to fail its progress should be
|
248
|
-
// reset, otherwise there may be a visible jump in values sent by the handler.
|
249
|
-
// When handler is waiting it's already activated but the `isAwaiting` flag
|
250
|
-
// prevents it from receiving touch stream. When the flag is changed, the
|
251
|
-
// difference between this event and the last one may be large enough to be
|
252
|
-
// visible in interactions based on this gesture. This makes it consistent with
|
253
|
-
// the behavior on iOS.
|
254
|
-
if (handler.shouldResetProgress) {
|
255
|
-
handler.shouldResetProgress = false
|
256
|
-
handler.resetProgress()
|
257
|
-
}
|
258
|
-
handler.dispatchHandlerUpdate(event)
|
259
|
-
}
|
260
|
-
|
261
|
-
if (handler.needsPointerData && isFirstEvent) {
|
262
|
-
handler.updatePointerData(event)
|
263
|
-
}
|
264
|
-
|
265
|
-
// if event was of type UP or POINTER_UP we request handler to stop tracking now that
|
266
|
-
// the event has been dispatched
|
267
|
-
if (action == MotionEvent.ACTION_UP || action == MotionEvent.ACTION_POINTER_UP || action == MotionEvent.ACTION_HOVER_EXIT) {
|
268
|
-
val pointerId = event.getPointerId(event.actionIndex)
|
269
|
-
handler.stopTrackingPointer(pointerId)
|
270
|
-
}
|
271
|
-
}
|
272
|
-
|
273
|
-
event.recycle()
|
274
|
-
}
|
275
|
-
|
276
|
-
/**
|
277
|
-
* isViewAttachedUnderWrapper checks whether all of parents for view related to handler
|
278
|
-
* view are attached. Since there might be an issue rarely observed when view
|
279
|
-
* has been detached and handler's state hasn't been change to canceled, failed or
|
280
|
-
* ended yet. Probably it's a result of some race condition and stopping delivering
|
281
|
-
* for this handler and changing its state to failed of end appear to be good enough solution.
|
282
|
-
*/
|
283
|
-
private fun isViewAttachedUnderWrapper(view: View?): Boolean {
|
284
|
-
if (view == null) {
|
285
|
-
return false
|
286
|
-
}
|
287
|
-
if (view === wrapperView) {
|
288
|
-
return true
|
289
|
-
}
|
290
|
-
var parent = view.parent
|
291
|
-
while (parent != null && parent !== wrapperView) {
|
292
|
-
parent = parent.parent
|
293
|
-
}
|
294
|
-
return parent === wrapperView
|
295
|
-
}
|
296
|
-
|
297
|
-
fun isAnyHandlerActive() = gestureHandlers.any { it.state == GestureHandler.STATE_ACTIVE }
|
298
|
-
|
299
|
-
/**
|
300
|
-
* Transforms an event in the coordinates of wrapperView into the coordinate space of the received view.
|
301
|
-
*
|
302
|
-
* This modifies and returns the same event as it receives
|
303
|
-
*
|
304
|
-
* @param view - view to which coordinate space the event should be transformed
|
305
|
-
* @param event - event to transform
|
306
|
-
*/
|
307
|
-
fun transformEventToViewCoords(view: View?, event: MotionEvent): MotionEvent {
|
308
|
-
if (view == null) {
|
309
|
-
return event
|
310
|
-
}
|
311
|
-
|
312
|
-
val parent = view.parent as? ViewGroup
|
313
|
-
// Events are passed down to the orchestrator by the wrapperView, so they are already in the
|
314
|
-
// relevant coordinate space. We want to stop traversing the tree when we reach it.
|
315
|
-
if (parent != wrapperView) {
|
316
|
-
transformEventToViewCoords(parent, event)
|
317
|
-
}
|
318
|
-
|
319
|
-
if (parent != null) {
|
320
|
-
val localX = event.x + parent.scrollX - view.left
|
321
|
-
val localY = event.y + parent.scrollY - view.top
|
322
|
-
event.setLocation(localX, localY)
|
323
|
-
}
|
324
|
-
|
325
|
-
if (!view.matrix.isIdentity) {
|
326
|
-
view.matrix.invert(inverseMatrix)
|
327
|
-
event.transform(inverseMatrix)
|
328
|
-
}
|
329
|
-
|
330
|
-
return event
|
331
|
-
}
|
332
|
-
|
333
|
-
/**
|
334
|
-
* Transforms a point in the coordinates of wrapperView into the coordinate space of the received view.
|
335
|
-
*
|
336
|
-
* This modifies and returns the same point as it receives
|
337
|
-
*
|
338
|
-
* @param view - view to which coordinate space the point should be transformed
|
339
|
-
* @param point - point to transform
|
340
|
-
*/
|
341
|
-
fun transformPointToViewCoords(view: View?, point: PointF): PointF {
|
342
|
-
if (view == null) {
|
343
|
-
return point
|
344
|
-
}
|
345
|
-
|
346
|
-
val parent = view.parent as? ViewGroup
|
347
|
-
// Events are passed down to the orchestrator by the wrapperView, so they are already in the
|
348
|
-
// relevant coordinate space. We want to stop traversing the tree when we reach it.
|
349
|
-
if (parent != wrapperView) {
|
350
|
-
transformPointToViewCoords(parent, point)
|
351
|
-
}
|
352
|
-
|
353
|
-
if (parent != null) {
|
354
|
-
point.x += parent.scrollX - view.left
|
355
|
-
point.y += parent.scrollY - view.top
|
356
|
-
}
|
357
|
-
|
358
|
-
if (!view.matrix.isIdentity) {
|
359
|
-
view.matrix.invert(inverseMatrix)
|
360
|
-
tempCoords[0] = point.x
|
361
|
-
tempCoords[1] = point.y
|
362
|
-
inverseMatrix.mapPoints(tempCoords)
|
363
|
-
point.x = tempCoords[0]
|
364
|
-
point.y = tempCoords[1]
|
365
|
-
}
|
366
|
-
|
367
|
-
return point
|
368
|
-
}
|
369
|
-
|
370
|
-
private fun addAwaitingHandler(handler: GestureHandler<*>) {
|
371
|
-
if (awaitingHandlers.contains(handler)) {
|
372
|
-
return
|
373
|
-
}
|
374
|
-
|
375
|
-
awaitingHandlers.add(handler)
|
376
|
-
with(handler) {
|
377
|
-
isAwaiting = true
|
378
|
-
activationIndex = this@GestureHandlerOrchestrator.activationIndex++
|
379
|
-
}
|
380
|
-
}
|
381
|
-
|
382
|
-
private fun recordHandlerIfNotPresent(handler: GestureHandler<*>, view: View) {
|
383
|
-
if (gestureHandlers.contains(handler)) {
|
384
|
-
return
|
385
|
-
}
|
386
|
-
|
387
|
-
gestureHandlers.add(handler)
|
388
|
-
handler.isActive = false
|
389
|
-
handler.isAwaiting = false
|
390
|
-
handler.activationIndex = Int.MAX_VALUE
|
391
|
-
handler.prepare(view, this)
|
392
|
-
}
|
393
|
-
|
394
|
-
private fun isViewOverflowingParent(view: View): Boolean {
|
395
|
-
val parent = view.parent as? ViewGroup ?: return false
|
396
|
-
val matrix = view.matrix
|
397
|
-
val localXY = matrixTransformCoords
|
398
|
-
localXY[0] = 0f
|
399
|
-
localXY[1] = 0f
|
400
|
-
matrix.mapPoints(localXY)
|
401
|
-
val left = localXY[0] + view.left
|
402
|
-
val top = localXY[1] + view.top
|
403
|
-
|
404
|
-
return left < 0f || left + view.width > parent.width || top < 0f || top + view.height > parent.height
|
405
|
-
}
|
406
|
-
|
407
|
-
private fun extractAncestorHandlers(view: View, coords: FloatArray, pointerId: Int): Boolean {
|
408
|
-
var found = false
|
409
|
-
var parent = view.parent
|
410
|
-
|
411
|
-
while (parent != null) {
|
412
|
-
if (parent is ViewGroup) {
|
413
|
-
val parentViewGroup: ViewGroup = parent
|
414
|
-
|
415
|
-
handlerRegistry.getHandlersForView(parent)?.let {
|
416
|
-
synchronized(it) {
|
417
|
-
for (handler in it) {
|
418
|
-
if (handler.isEnabled && handler.isWithinBounds(view, coords[0], coords[1])) {
|
419
|
-
found = true
|
420
|
-
recordHandlerIfNotPresent(handler, parentViewGroup)
|
421
|
-
handler.startTrackingPointer(pointerId)
|
422
|
-
}
|
423
|
-
}
|
424
|
-
}
|
425
|
-
}
|
426
|
-
}
|
427
|
-
|
428
|
-
parent = parent.parent
|
429
|
-
}
|
430
|
-
|
431
|
-
return found
|
432
|
-
}
|
433
|
-
|
434
|
-
private fun recordViewHandlersForPointer(view: View, coords: FloatArray, pointerId: Int, event: MotionEvent): Boolean {
|
435
|
-
var found = false
|
436
|
-
handlerRegistry.getHandlersForView(view)?.let {
|
437
|
-
synchronized(it) {
|
438
|
-
for (handler in it) {
|
439
|
-
// skip disabled and out-of-bounds handlers
|
440
|
-
if (!handler.isEnabled || !handler.isWithinBounds(view, coords[0], coords[1])) {
|
441
|
-
continue
|
442
|
-
}
|
443
|
-
|
444
|
-
// we don't want to extract gestures other than hover when processing hover events
|
445
|
-
if (event.action in listOf(MotionEvent.ACTION_HOVER_EXIT, MotionEvent.ACTION_HOVER_ENTER, MotionEvent.ACTION_HOVER_MOVE) && handler !is HoverGestureHandler) {
|
446
|
-
continue
|
447
|
-
}
|
448
|
-
|
449
|
-
recordHandlerIfNotPresent(handler, view)
|
450
|
-
handler.startTrackingPointer(pointerId)
|
451
|
-
found = true
|
452
|
-
}
|
453
|
-
}
|
454
|
-
}
|
455
|
-
|
456
|
-
// if the pointer is inside the view but it overflows its parent, handlers attached to the parent
|
457
|
-
// might not have been extracted (pointer might be in a child, but may be outside parent)
|
458
|
-
if (coords[0] in 0f..view.width.toFloat() && coords[1] in 0f..view.height.toFloat() &&
|
459
|
-
isViewOverflowingParent(view) && extractAncestorHandlers(view, coords, pointerId)
|
460
|
-
) {
|
461
|
-
found = true
|
462
|
-
}
|
463
|
-
|
464
|
-
return found
|
465
|
-
}
|
466
|
-
|
467
|
-
private fun extractGestureHandlers(event: MotionEvent) {
|
468
|
-
val actionIndex = event.actionIndex
|
469
|
-
val pointerId = event.getPointerId(actionIndex)
|
470
|
-
tempCoords[0] = event.getX(actionIndex)
|
471
|
-
tempCoords[1] = event.getY(actionIndex)
|
472
|
-
traverseWithPointerEvents(wrapperView, tempCoords, pointerId, event)
|
473
|
-
extractGestureHandlers(wrapperView, tempCoords, pointerId, event)
|
474
|
-
}
|
475
|
-
|
476
|
-
private fun extractGestureHandlers(viewGroup: ViewGroup, coords: FloatArray, pointerId: Int, event: MotionEvent): Boolean {
|
477
|
-
val childrenCount = viewGroup.childCount
|
478
|
-
for (i in childrenCount - 1 downTo 0) {
|
479
|
-
val child = viewConfigHelper.getChildInDrawingOrderAtIndex(viewGroup, i)
|
480
|
-
if (canReceiveEvents(child)) {
|
481
|
-
val childPoint = tempPoint
|
482
|
-
transformPointToChildViewCoords(coords[0], coords[1], viewGroup, child, childPoint)
|
483
|
-
val restoreX = coords[0]
|
484
|
-
val restoreY = coords[1]
|
485
|
-
coords[0] = childPoint.x
|
486
|
-
coords[1] = childPoint.y
|
487
|
-
var found = false
|
488
|
-
if (!isClipping(child) || isTransformedTouchPointInView(coords[0], coords[1], child)) {
|
489
|
-
// we only consider the view if touch is inside the view bounds or if the view's children
|
490
|
-
// can render outside of the view bounds (overflow visible)
|
491
|
-
found = traverseWithPointerEvents(child, coords, pointerId, event)
|
492
|
-
}
|
493
|
-
coords[0] = restoreX
|
494
|
-
coords[1] = restoreY
|
495
|
-
if (found) {
|
496
|
-
return true
|
497
|
-
}
|
498
|
-
}
|
499
|
-
}
|
500
|
-
return false
|
501
|
-
}
|
502
|
-
|
503
|
-
private fun traverseWithPointerEvents(view: View, coords: FloatArray, pointerId: Int, event: MotionEvent): Boolean =
|
504
|
-
when (viewConfigHelper.getPointerEventsConfigForView(view)) {
|
505
|
-
PointerEventsConfig.NONE -> {
|
506
|
-
// This view and its children can't be the target
|
507
|
-
false
|
508
|
-
}
|
509
|
-
PointerEventsConfig.BOX_ONLY -> {
|
510
|
-
// This view is the target, its children don't matter
|
511
|
-
(
|
512
|
-
recordViewHandlersForPointer(view, coords, pointerId, event) ||
|
513
|
-
shouldHandlerlessViewBecomeTouchTarget(view, coords)
|
514
|
-
)
|
515
|
-
}
|
516
|
-
PointerEventsConfig.BOX_NONE -> {
|
517
|
-
// This view can't be the target, but its children might
|
518
|
-
when (view) {
|
519
|
-
is ViewGroup -> {
|
520
|
-
extractGestureHandlers(view, coords, pointerId, event).also { found ->
|
521
|
-
// A child view is handling touch, also extract handlers attached to this view
|
522
|
-
if (found) {
|
523
|
-
recordViewHandlersForPointer(view, coords, pointerId, event)
|
524
|
-
}
|
525
|
-
}
|
526
|
-
}
|
527
|
-
// When <TextInput> has editable set to `false` getPointerEventsConfigForView returns
|
528
|
-
// `BOX_NONE` as it's `isEnabled` property is false. In this case we still want to extract
|
529
|
-
// handlers attached to the text input, as it makes sense that gestures would work on a
|
530
|
-
// non-editable TextInput.
|
531
|
-
is EditText -> {
|
532
|
-
recordViewHandlersForPointer(view, coords, pointerId, event)
|
533
|
-
}
|
534
|
-
else -> false
|
535
|
-
}
|
536
|
-
}
|
537
|
-
PointerEventsConfig.AUTO -> {
|
538
|
-
// Either this view or one of its children is the target
|
539
|
-
val found = if (view is ViewGroup) {
|
540
|
-
extractGestureHandlers(view, coords, pointerId, event)
|
541
|
-
} else false
|
542
|
-
|
543
|
-
(
|
544
|
-
recordViewHandlersForPointer(view, coords, pointerId, event) ||
|
545
|
-
found || shouldHandlerlessViewBecomeTouchTarget(view, coords)
|
546
|
-
)
|
547
|
-
}
|
548
|
-
}
|
549
|
-
|
550
|
-
private fun canReceiveEvents(view: View) =
|
551
|
-
view.visibility == View.VISIBLE && view.alpha >= minimumAlphaForTraversal
|
552
|
-
|
553
|
-
// if view is not a view group it is clipping, otherwise we check for `getClipChildren` flag to
|
554
|
-
// be turned on and also confirm with the ViewConfigHelper implementation
|
555
|
-
private fun isClipping(view: View) =
|
556
|
-
view !is ViewGroup || viewConfigHelper.isViewClippingChildren(view)
|
557
|
-
|
558
|
-
fun activateNativeHandlersForView(view: View) {
|
559
|
-
handlerRegistry.getHandlersForView(view)?.forEach {
|
560
|
-
if (it !is NativeViewGestureHandler) {
|
561
|
-
return@forEach
|
562
|
-
}
|
563
|
-
this.recordHandlerIfNotPresent(it, view)
|
564
|
-
|
565
|
-
it.withMarkedAsInBounds {
|
566
|
-
it.begin()
|
567
|
-
it.activate()
|
568
|
-
it.end()
|
569
|
-
}
|
570
|
-
}
|
571
|
-
}
|
572
|
-
|
573
|
-
companion object {
|
574
|
-
// The limit doesn't necessarily need to exists, it was just simpler to implement it that way
|
575
|
-
// it is also more allocation-wise efficient to have a fixed limit
|
576
|
-
|
577
|
-
// Be default fully transparent views can receive touch
|
578
|
-
private const val DEFAULT_MIN_ALPHA_FOR_TRAVERSAL = 0f
|
579
|
-
private val tempPoint = PointF()
|
580
|
-
private val matrixTransformCoords = FloatArray(2)
|
581
|
-
private val inverseMatrix = Matrix()
|
582
|
-
private val tempCoords = FloatArray(2)
|
583
|
-
private val handlersComparator = Comparator<GestureHandler<*>?> { a, b ->
|
584
|
-
return@Comparator if (a.isActive && b.isActive || a.isAwaiting && b.isAwaiting) {
|
585
|
-
// both A and B are either active or awaiting activation, in which case we prefer one that
|
586
|
-
// has activated (or turned into "awaiting" state) earlier
|
587
|
-
Integer.signum(b.activationIndex - a.activationIndex)
|
588
|
-
} else if (a.isActive) {
|
589
|
-
-1 // only A is active
|
590
|
-
} else if (b.isActive) {
|
591
|
-
1 // only B is active
|
592
|
-
} else if (a.isAwaiting) {
|
593
|
-
-1 // only A is awaiting, B is inactive
|
594
|
-
} else if (b.isAwaiting) {
|
595
|
-
1 // only B is awaiting, A is inactive
|
596
|
-
} else {
|
597
|
-
0 // both A and B are inactive, stable order matters
|
598
|
-
}
|
599
|
-
}
|
600
|
-
|
601
|
-
private fun shouldHandlerlessViewBecomeTouchTarget(view: View, coords: FloatArray): Boolean {
|
602
|
-
// The following code is to match the iOS behavior where transparent parts of the views can
|
603
|
-
// pass touch events through them allowing sibling nodes to handle them.
|
604
|
-
|
605
|
-
// TODO: this is not an ideal solution as we only consider ViewGroups that has no background set
|
606
|
-
// TODO: ideally we should determine the pixel color under the given coordinates and return
|
607
|
-
// false if the color is transparent
|
608
|
-
val isLeafOrTransparent = view !is ViewGroup || view.getBackground() != null
|
609
|
-
return isLeafOrTransparent && isTransformedTouchPointInView(coords[0], coords[1], view)
|
610
|
-
}
|
611
|
-
|
612
|
-
private fun transformPointToChildViewCoords(
|
613
|
-
x: Float,
|
614
|
-
y: Float,
|
615
|
-
parent: ViewGroup,
|
616
|
-
child: View,
|
617
|
-
outLocalPoint: PointF,
|
618
|
-
) {
|
619
|
-
var localX = x + parent.scrollX - child.left
|
620
|
-
var localY = y + parent.scrollY - child.top
|
621
|
-
val matrix = child.matrix
|
622
|
-
if (!matrix.isIdentity) {
|
623
|
-
val localXY = matrixTransformCoords
|
624
|
-
localXY[0] = localX
|
625
|
-
localXY[1] = localY
|
626
|
-
matrix.invert(inverseMatrix)
|
627
|
-
inverseMatrix.mapPoints(localXY)
|
628
|
-
localX = localXY[0]
|
629
|
-
localY = localXY[1]
|
630
|
-
}
|
631
|
-
outLocalPoint[localX] = localY
|
632
|
-
}
|
633
|
-
|
634
|
-
private fun isTransformedTouchPointInView(x: Float, y: Float, child: View) =
|
635
|
-
x in 0f..child.width.toFloat() && y in 0f..child.height.toFloat()
|
636
|
-
|
637
|
-
private fun shouldHandlerWaitForOther(handler: GestureHandler<*>, other: GestureHandler<*>): Boolean {
|
638
|
-
return handler !== other && (
|
639
|
-
handler.shouldWaitForHandlerFailure(other) ||
|
640
|
-
other.shouldRequireToWaitForFailure(handler)
|
641
|
-
)
|
642
|
-
}
|
643
|
-
|
644
|
-
private fun canRunSimultaneously(a: GestureHandler<*>, b: GestureHandler<*>) =
|
645
|
-
a === b || a.shouldRecognizeSimultaneously(b) || b.shouldRecognizeSimultaneously(a)
|
646
|
-
|
647
|
-
private fun shouldHandlerBeCancelledBy(handler: GestureHandler<*>, other: GestureHandler<*>): Boolean {
|
648
|
-
if (!handler.hasCommonPointers(other)) {
|
649
|
-
// if two handlers share no common pointer one can never trigger cancel for the other
|
650
|
-
return false
|
651
|
-
}
|
652
|
-
if (canRunSimultaneously(handler, other)) {
|
653
|
-
// if handlers are allowed to run simultaneously, when first activates second can still remain
|
654
|
-
// in began state
|
655
|
-
return false
|
656
|
-
}
|
657
|
-
return if (handler !== other &&
|
658
|
-
(handler.isAwaiting || handler.state == GestureHandler.STATE_ACTIVE)
|
659
|
-
) {
|
660
|
-
// in every other case as long as the handler is about to be activated or already in active
|
661
|
-
// state, we delegate the decision to the implementation of GestureHandler#shouldBeCancelledBy
|
662
|
-
handler.shouldBeCancelledBy(other)
|
663
|
-
} else true
|
664
|
-
}
|
665
|
-
|
666
|
-
private fun isFinished(state: Int) =
|
667
|
-
state == GestureHandler.STATE_CANCELLED ||
|
668
|
-
state == GestureHandler.STATE_FAILED ||
|
669
|
-
state == GestureHandler.STATE_END
|
670
|
-
}
|
671
|
-
}
|