@react-native-oh-tpl/react-native-gesture-handler 2.12.1-0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- package/DrawerLayout/package.json +6 -0
- package/LICENSE +21 -0
- package/README.md +62 -0
- package/RNGestureHandler.podspec +44 -0
- package/Swipeable/package.json +6 -0
- package/android/build.gradle +209 -0
- package/android/common/src/main/java/com/swmansion/common/GestureHandlerStateManager.kt +5 -0
- package/android/fabric/src/main/java/com/swmansion/gesturehandler/RNGestureHandlerComponentsRegistry.java +29 -0
- package/android/fabric/src/main/java/com/swmansion/gesturehandler/ReactContextExtensions.kt +12 -0
- package/android/gradle.properties +19 -0
- package/android/noreanimated/src/main/java/com/swmansion/gesturehandler/ReanimatedEventDispatcher.kt +10 -0
- package/android/paper/src/main/java/com/facebook/react/viewmanagers/RNGestureHandlerButtonManagerDelegate.java +50 -0
- package/android/paper/src/main/java/com/facebook/react/viewmanagers/RNGestureHandlerButtonManagerInterface.java +23 -0
- package/android/paper/src/main/java/com/facebook/react/viewmanagers/RNGestureHandlerRootViewManagerDelegate.java +25 -0
- package/android/paper/src/main/java/com/facebook/react/viewmanagers/RNGestureHandlerRootViewManagerInterface.java +16 -0
- package/android/paper/src/main/java/com/swmansion/gesturehandler/ReactContextExtensions.kt +13 -0
- package/android/reanimated/src/main/java/com/swmansion/gesturehandler/ReanimatedEventDispatcher.kt +17 -0
- package/android/src/main/AndroidManifest.xml +3 -0
- package/android/src/main/java/com/swmansion/gesturehandler/RNGestureHandlerPackage.kt +21 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/FlingGestureHandler.kt +100 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/GestureHandler.kt +807 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/GestureHandlerInteractionController.kt +8 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/GestureHandlerOrchestrator.kt +671 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/GestureHandlerRegistry.kt +8 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/GestureUtils.kt +47 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/HoverGestureHandler.kt +120 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/LongPressGestureHandler.kt +100 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/ManualGestureHandler.kt +11 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/NativeViewGestureHandler.kt +257 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/OnTouchEventListener.kt +9 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/PanGestureHandler.kt +322 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/PinchGestureHandler.kt +103 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/PointerEventsConfig.kt +23 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/RotationGestureDetector.kt +125 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/RotationGestureHandler.kt +93 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/ScaleGestureDetector.java +558 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/TapGestureHandler.kt +168 -0
- package/android/src/main/java/com/swmansion/gesturehandler/core/ViewConfigurationHelper.kt +10 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/Extensions.kt +16 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerButtonViewManager.kt +423 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerEnabledRootView.kt +15 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerEvent.kt +75 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerInteractionManager.kt +74 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerModule.kt +702 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRegistry.kt +100 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootHelper.kt +142 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootInterface.kt +5 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootView.kt +78 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerRootViewManager.kt +51 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerStateChangeEvent.kt +78 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNGestureHandlerTouchEvent.kt +69 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/RNViewConfigurationHelper.kt +51 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/FlingGestureHandlerEventDataBuilder.kt +30 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/GestureHandlerEventDataBuilder.kt +22 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/HoverGestureHandlerEventDataBuilder.kt +30 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/LongPressGestureHandlerEventDataBuilder.kt +33 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/ManualGestureHandlerEventDataBuilder.kt +5 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/NativeGestureHandlerEventDataBuilder.kt +18 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/PanGestureHandlerEventDataBuilder.kt +42 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/PinchGestureHandlerEventDataBuilder.kt +30 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/RotationGestureHandlerEventDataBuilder.kt +30 -0
- package/android/src/main/java/com/swmansion/gesturehandler/react/eventbuilders/TapGestureHandlerEventDataBuilder.kt +30 -0
- package/android/src/main/jni/CMakeLists.txt +37 -0
- package/android/src/main/jni/cpp-adapter.cpp +44 -0
- package/ios/Handlers/RNFlingHandler.h +4 -0
- package/ios/Handlers/RNFlingHandler.m +152 -0
- package/ios/Handlers/RNForceTouchHandler.h +4 -0
- package/ios/Handlers/RNForceTouchHandler.m +175 -0
- package/ios/Handlers/RNHoverHandler.h +12 -0
- package/ios/Handlers/RNHoverHandler.m +153 -0
- package/ios/Handlers/RNLongPressHandler.h +12 -0
- package/ios/Handlers/RNLongPressHandler.m +183 -0
- package/ios/Handlers/RNManualHandler.h +4 -0
- package/ios/Handlers/RNManualHandler.m +88 -0
- package/ios/Handlers/RNNativeViewHandler.h +15 -0
- package/ios/Handlers/RNNativeViewHandler.mm +193 -0
- package/ios/Handlers/RNPanHandler.h +12 -0
- package/ios/Handlers/RNPanHandler.m +331 -0
- package/ios/Handlers/RNPinchHandler.h +12 -0
- package/ios/Handlers/RNPinchHandler.m +95 -0
- package/ios/Handlers/RNRotationHandler.h +12 -0
- package/ios/Handlers/RNRotationHandler.m +93 -0
- package/ios/Handlers/RNTapHandler.h +12 -0
- package/ios/Handlers/RNTapHandler.m +265 -0
- package/ios/RNGHTouchEventType.h +9 -0
- package/ios/RNGestureHandler.h +90 -0
- package/ios/RNGestureHandler.m +493 -0
- package/ios/RNGestureHandler.xcodeproj/project.pbxproj +690 -0
- package/ios/RNGestureHandler.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +8 -0
- package/ios/RNGestureHandlerActionType.h +10 -0
- package/ios/RNGestureHandlerButton.h +19 -0
- package/ios/RNGestureHandlerButton.m +77 -0
- package/ios/RNGestureHandlerButtonComponentView.h +17 -0
- package/ios/RNGestureHandlerButtonComponentView.mm +64 -0
- package/ios/RNGestureHandlerButtonManager.h +5 -0
- package/ios/RNGestureHandlerButtonManager.m +34 -0
- package/ios/RNGestureHandlerDirection.h +8 -0
- package/ios/RNGestureHandlerEvents.h +65 -0
- package/ios/RNGestureHandlerEvents.m +260 -0
- package/ios/RNGestureHandlerManager.h +35 -0
- package/ios/RNGestureHandlerManager.mm +367 -0
- package/ios/RNGestureHandlerModule.h +7 -0
- package/ios/RNGestureHandlerModule.mm +320 -0
- package/ios/RNGestureHandlerPointerTracker.h +25 -0
- package/ios/RNGestureHandlerPointerTracker.m +243 -0
- package/ios/RNGestureHandlerRegistry.h +21 -0
- package/ios/RNGestureHandlerRegistry.m +63 -0
- package/ios/RNGestureHandlerRootViewComponentView.mm +21 -0
- package/ios/RNGestureHandlerState.h +10 -0
- package/ios/RNGestureHandlerStateManager.h +5 -0
- package/ios/RNManualActivationRecognizer.h +10 -0
- package/ios/RNManualActivationRecognizer.m +88 -0
- package/ios/RNRootViewGestureRecognizer.h +17 -0
- package/ios/RNRootViewGestureRecognizer.m +106 -0
- package/jest-utils/package.json +6 -0
- package/jestSetup.js +7 -0
- package/lib/commonjs/ActionType.js +15 -0
- package/lib/commonjs/ActionType.js.map +1 -0
- package/lib/commonjs/Directions.js +15 -0
- package/lib/commonjs/Directions.js.map +1 -0
- package/lib/commonjs/EnableNewWebImplementation.js +35 -0
- package/lib/commonjs/EnableNewWebImplementation.js.map +1 -0
- package/lib/commonjs/GestureHandlerRootViewContext.js +15 -0
- package/lib/commonjs/GestureHandlerRootViewContext.js.map +1 -0
- package/lib/commonjs/PlatformConstants.js +15 -0
- package/lib/commonjs/PlatformConstants.js.map +1 -0
- package/lib/commonjs/PlatformConstants.web.js +14 -0
- package/lib/commonjs/PlatformConstants.web.js.map +1 -0
- package/lib/commonjs/RNGestureHandlerModule.js +29 -0
- package/lib/commonjs/RNGestureHandlerModule.js.map +1 -0
- package/lib/commonjs/RNGestureHandlerModule.macos.js +149 -0
- package/lib/commonjs/RNGestureHandlerModule.macos.js.map +1 -0
- package/lib/commonjs/RNGestureHandlerModule.web.js +163 -0
- package/lib/commonjs/RNGestureHandlerModule.web.js.map +1 -0
- package/lib/commonjs/RNGestureHandlerModule.windows.js +158 -0
- package/lib/commonjs/RNGestureHandlerModule.windows.js.map +1 -0
- package/lib/commonjs/RNRenderer.js +16 -0
- package/lib/commonjs/RNRenderer.js.map +1 -0
- package/lib/commonjs/RNRenderer.web.js +11 -0
- package/lib/commonjs/RNRenderer.web.js.map +1 -0
- package/lib/commonjs/State.js +18 -0
- package/lib/commonjs/State.js.map +1 -0
- package/lib/commonjs/TouchEventType.js +16 -0
- package/lib/commonjs/TouchEventType.js.map +1 -0
- package/lib/commonjs/components/DrawerLayout.js +566 -0
- package/lib/commonjs/components/DrawerLayout.js.map +1 -0
- package/lib/commonjs/components/GestureButtons.js +240 -0
- package/lib/commonjs/components/GestureButtons.js.map +1 -0
- package/lib/commonjs/components/GestureComponents.js +115 -0
- package/lib/commonjs/components/GestureComponents.js.map +1 -0
- package/lib/commonjs/components/GestureComponents.web.js +52 -0
- package/lib/commonjs/components/GestureComponents.web.js.map +1 -0
- package/lib/commonjs/components/GestureHandlerButton.js +14 -0
- package/lib/commonjs/components/GestureHandlerButton.js.map +1 -0
- package/lib/commonjs/components/GestureHandlerButton.web.js +24 -0
- package/lib/commonjs/components/GestureHandlerButton.web.js.map +1 -0
- package/lib/commonjs/components/GestureHandlerRootView.android.js +31 -0
- package/lib/commonjs/components/GestureHandlerRootView.android.js.map +1 -0
- package/lib/commonjs/components/GestureHandlerRootView.js +31 -0
- package/lib/commonjs/components/GestureHandlerRootView.js.map +1 -0
- package/lib/commonjs/components/GestureHandlerRootView.web.js +25 -0
- package/lib/commonjs/components/GestureHandlerRootView.web.js.map +1 -0
- package/lib/commonjs/components/Swipeable.js +408 -0
- package/lib/commonjs/components/Swipeable.js.map +1 -0
- package/lib/commonjs/components/gestureHandlerRootHOC.js +40 -0
- package/lib/commonjs/components/gestureHandlerRootHOC.js.map +1 -0
- package/lib/commonjs/components/touchables/GenericTouchable.js +289 -0
- package/lib/commonjs/components/touchables/GenericTouchable.js.map +1 -0
- package/lib/commonjs/components/touchables/TouchableHighlight.js +109 -0
- package/lib/commonjs/components/touchables/TouchableHighlight.js.map +1 -0
- package/lib/commonjs/components/touchables/TouchableNativeFeedback.android.js +100 -0
- package/lib/commonjs/components/touchables/TouchableNativeFeedback.android.js.map +1 -0
- package/lib/commonjs/components/touchables/TouchableNativeFeedback.js +12 -0
- package/lib/commonjs/components/touchables/TouchableNativeFeedback.js.map +1 -0
- package/lib/commonjs/components/touchables/TouchableOpacity.js +77 -0
- package/lib/commonjs/components/touchables/TouchableOpacity.js.map +1 -0
- package/lib/commonjs/components/touchables/TouchableWithoutFeedback.js +26 -0
- package/lib/commonjs/components/touchables/TouchableWithoutFeedback.js.map +1 -0
- package/lib/commonjs/components/touchables/index.js +40 -0
- package/lib/commonjs/components/touchables/index.js.map +1 -0
- package/lib/commonjs/getReactNativeVersion.js +22 -0
- package/lib/commonjs/getReactNativeVersion.js.map +1 -0
- package/lib/commonjs/getReactNativeVersion.web.js +11 -0
- package/lib/commonjs/getReactNativeVersion.web.js.map +1 -0
- package/lib/commonjs/getShadowNodeFromRef.js +27 -0
- package/lib/commonjs/getShadowNodeFromRef.js.map +1 -0
- package/lib/commonjs/getShadowNodeFromRef.web.js +15 -0
- package/lib/commonjs/getShadowNodeFromRef.web.js.map +1 -0
- package/lib/commonjs/ghQueueMicrotask.js +12 -0
- package/lib/commonjs/ghQueueMicrotask.js.map +1 -0
- package/lib/commonjs/handlers/FlingGestureHandler.js +25 -0
- package/lib/commonjs/handlers/FlingGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/ForceTouchGestureHandler.js +49 -0
- package/lib/commonjs/handlers/ForceTouchGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/LongPressGestureHandler.js +27 -0
- package/lib/commonjs/handlers/LongPressGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/NativeViewGestureHandler.js +27 -0
- package/lib/commonjs/handlers/NativeViewGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/PanGestureHandler.js +123 -0
- package/lib/commonjs/handlers/PanGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/PinchGestureHandler.js +23 -0
- package/lib/commonjs/handlers/PinchGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/PressabilityDebugView.js +14 -0
- package/lib/commonjs/handlers/PressabilityDebugView.js.map +1 -0
- package/lib/commonjs/handlers/PressabilityDebugView.web.js +12 -0
- package/lib/commonjs/handlers/PressabilityDebugView.web.js.map +1 -0
- package/lib/commonjs/handlers/RotationGestureHandler.js +23 -0
- package/lib/commonjs/handlers/RotationGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/TapGestureHandler.js +27 -0
- package/lib/commonjs/handlers/TapGestureHandler.js.map +1 -0
- package/lib/commonjs/handlers/createHandler.js +464 -0
- package/lib/commonjs/handlers/createHandler.js.map +1 -0
- package/lib/commonjs/handlers/createNativeWrapper.js +74 -0
- package/lib/commonjs/handlers/createNativeWrapper.js.map +1 -0
- package/lib/commonjs/handlers/gestureHandlerCommon.js +103 -0
- package/lib/commonjs/handlers/gestureHandlerCommon.js.map +1 -0
- package/lib/commonjs/handlers/gestureHandlerTypesCompat.js +6 -0
- package/lib/commonjs/handlers/gestureHandlerTypesCompat.js.map +1 -0
- package/lib/commonjs/handlers/gestures/GestureDetector.js +669 -0
- package/lib/commonjs/handlers/gestures/GestureDetector.js.map +1 -0
- package/lib/commonjs/handlers/gestures/eventReceiver.js +147 -0
- package/lib/commonjs/handlers/gestures/eventReceiver.js.map +1 -0
- package/lib/commonjs/handlers/gestures/flingGesture.js +34 -0
- package/lib/commonjs/handlers/gestures/flingGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/forceTouchGesture.js +65 -0
- package/lib/commonjs/handlers/gestures/forceTouchGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/gesture.js +241 -0
- package/lib/commonjs/handlers/gestures/gesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/gestureComposition.js +105 -0
- package/lib/commonjs/handlers/gestures/gestureComposition.js.map +1 -0
- package/lib/commonjs/handlers/gestures/gestureObjects.js +90 -0
- package/lib/commonjs/handlers/gestures/gestureObjects.js.map +1 -0
- package/lib/commonjs/handlers/gestures/gestureStateManager.js +65 -0
- package/lib/commonjs/handlers/gestures/gestureStateManager.js.map +1 -0
- package/lib/commonjs/handlers/gestures/gestureStateManager.web.js +32 -0
- package/lib/commonjs/handlers/gestures/gestureStateManager.web.js.map +1 -0
- package/lib/commonjs/handlers/gestures/hoverGesture.js +74 -0
- package/lib/commonjs/handlers/gestures/hoverGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/longPressGesture.js +35 -0
- package/lib/commonjs/handlers/gestures/longPressGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/manualGesture.js +31 -0
- package/lib/commonjs/handlers/gestures/manualGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/nativeGesture.js +34 -0
- package/lib/commonjs/handlers/gestures/nativeGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/panGesture.js +149 -0
- package/lib/commonjs/handlers/gestures/panGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/pinchGesture.js +45 -0
- package/lib/commonjs/handlers/gestures/pinchGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/reanimatedWrapper.js +37 -0
- package/lib/commonjs/handlers/gestures/reanimatedWrapper.js.map +1 -0
- package/lib/commonjs/handlers/gestures/rotationGesture.js +45 -0
- package/lib/commonjs/handlers/gestures/rotationGesture.js.map +1 -0
- package/lib/commonjs/handlers/gestures/tapGesture.js +60 -0
- package/lib/commonjs/handlers/gestures/tapGesture.js.map +1 -0
- package/lib/commonjs/handlers/handlersRegistry.js +67 -0
- package/lib/commonjs/handlers/handlersRegistry.js.map +1 -0
- package/lib/commonjs/index.js +266 -0
- package/lib/commonjs/index.js.map +1 -0
- package/lib/commonjs/init.js +32 -0
- package/lib/commonjs/init.js.map +1 -0
- package/lib/commonjs/jestUtils/index.js +20 -0
- package/lib/commonjs/jestUtils/index.js.map +1 -0
- package/lib/commonjs/jestUtils/jestUtils.js +375 -0
- package/lib/commonjs/jestUtils/jestUtils.js.map +1 -0
- package/lib/commonjs/mocks.js +66 -0
- package/lib/commonjs/mocks.js.map +1 -0
- package/lib/commonjs/specs/RNGestureHandlerButtonNativeComponent.js +15 -0
- package/lib/commonjs/specs/RNGestureHandlerButtonNativeComponent.js.map +1 -0
- package/lib/commonjs/specs/RNGestureHandlerRootViewNativeComponent.js +15 -0
- package/lib/commonjs/specs/RNGestureHandlerRootViewNativeComponent.js.map +1 -0
- package/lib/commonjs/typeUtils.js +2 -0
- package/lib/commonjs/typeUtils.js.map +1 -0
- package/lib/commonjs/utils.js +63 -0
- package/lib/commonjs/utils.js.map +1 -0
- package/lib/commonjs/web/constants.js +16 -0
- package/lib/commonjs/web/constants.js.map +1 -0
- package/lib/commonjs/web/detectors/RotationGestureDetector.js +165 -0
- package/lib/commonjs/web/detectors/RotationGestureDetector.js.map +1 -0
- package/lib/commonjs/web/detectors/ScaleGestureDetector.js +156 -0
- package/lib/commonjs/web/detectors/ScaleGestureDetector.js.map +1 -0
- package/lib/commonjs/web/handlers/FlingGestureHandler.js +167 -0
- package/lib/commonjs/web/handlers/FlingGestureHandler.js.map +1 -0
- package/lib/commonjs/web/handlers/GestureHandler.js +794 -0
- package/lib/commonjs/web/handlers/GestureHandler.js.map +1 -0
- package/lib/commonjs/web/handlers/HoverGestureHandler.js +62 -0
- package/lib/commonjs/web/handlers/HoverGestureHandler.js.map +1 -0
- package/lib/commonjs/web/handlers/LongPressGestureHandler.js +151 -0
- package/lib/commonjs/web/handlers/LongPressGestureHandler.js.map +1 -0
- package/lib/commonjs/web/handlers/ManualGestureHandler.js +61 -0
- package/lib/commonjs/web/handlers/ManualGestureHandler.js.map +1 -0
- package/lib/commonjs/web/handlers/NativeViewGestureHandler.js +178 -0
- package/lib/commonjs/web/handlers/NativeViewGestureHandler.js.map +1 -0
- package/lib/commonjs/web/handlers/PanGestureHandler.js +448 -0
- package/lib/commonjs/web/handlers/PanGestureHandler.js.map +1 -0
- package/lib/commonjs/web/handlers/PinchGestureHandler.js +174 -0
- package/lib/commonjs/web/handlers/PinchGestureHandler.js.map +1 -0
- package/lib/commonjs/web/handlers/RotationGestureHandler.js +186 -0
- package/lib/commonjs/web/handlers/RotationGestureHandler.js.map +1 -0
- package/lib/commonjs/web/handlers/TapGestureHandler.js +280 -0
- package/lib/commonjs/web/handlers/TapGestureHandler.js.map +1 -0
- package/lib/commonjs/web/interfaces.js +55 -0
- package/lib/commonjs/web/interfaces.js.map +1 -0
- package/lib/commonjs/web/tools/CircularBuffer.js +59 -0
- package/lib/commonjs/web/tools/CircularBuffer.js.map +1 -0
- package/lib/commonjs/web/tools/EventManager.js +127 -0
- package/lib/commonjs/web/tools/EventManager.js.map +1 -0
- package/lib/commonjs/web/tools/GestureHandlerDelegate.js +6 -0
- package/lib/commonjs/web/tools/GestureHandlerDelegate.js.map +1 -0
- package/lib/commonjs/web/tools/GestureHandlerOrchestrator.js +349 -0
- package/lib/commonjs/web/tools/GestureHandlerOrchestrator.js.map +1 -0
- package/lib/commonjs/web/tools/GestureHandlerWebDelegate.js +118 -0
- package/lib/commonjs/web/tools/GestureHandlerWebDelegate.js.map +1 -0
- package/lib/commonjs/web/tools/InteractionManager.js +114 -0
- package/lib/commonjs/web/tools/InteractionManager.js.map +1 -0
- package/lib/commonjs/web/tools/LeastSquareSolver.js +204 -0
- package/lib/commonjs/web/tools/LeastSquareSolver.js.map +1 -0
- package/lib/commonjs/web/tools/NodeManager.js +48 -0
- package/lib/commonjs/web/tools/NodeManager.js.map +1 -0
- package/lib/commonjs/web/tools/PointerEventManager.js +198 -0
- package/lib/commonjs/web/tools/PointerEventManager.js.map +1 -0
- package/lib/commonjs/web/tools/PointerTracker.js +226 -0
- package/lib/commonjs/web/tools/PointerTracker.js.map +1 -0
- package/lib/commonjs/web/tools/TouchEventManager.js +138 -0
- package/lib/commonjs/web/tools/TouchEventManager.js.map +1 -0
- package/lib/commonjs/web/tools/VelocityTracker.js +111 -0
- package/lib/commonjs/web/tools/VelocityTracker.js.map +1 -0
- package/lib/commonjs/web/utils.js +15 -0
- package/lib/commonjs/web/utils.js.map +1 -0
- package/lib/commonjs/web_hammer/DiscreteGestureHandler.js +105 -0
- package/lib/commonjs/web_hammer/DiscreteGestureHandler.js.map +1 -0
- package/lib/commonjs/web_hammer/DraggingGestureHandler.js +53 -0
- package/lib/commonjs/web_hammer/DraggingGestureHandler.js.map +1 -0
- package/lib/commonjs/web_hammer/Errors.js +16 -0
- package/lib/commonjs/web_hammer/Errors.js.map +1 -0
- package/lib/commonjs/web_hammer/FlingGestureHandler.js +170 -0
- package/lib/commonjs/web_hammer/FlingGestureHandler.js.map +1 -0
- package/lib/commonjs/web_hammer/GestureHandler.js +579 -0
- package/lib/commonjs/web_hammer/GestureHandler.js.map +1 -0
- package/lib/commonjs/web_hammer/IndiscreteGestureHandler.js +54 -0
- package/lib/commonjs/web_hammer/IndiscreteGestureHandler.js.map +1 -0
- package/lib/commonjs/web_hammer/LongPressGestureHandler.js +71 -0
- package/lib/commonjs/web_hammer/LongPressGestureHandler.js.map +1 -0
- package/lib/commonjs/web_hammer/NativeViewGestureHandler.js +66 -0
- package/lib/commonjs/web_hammer/NativeViewGestureHandler.js.map +1 -0
- package/lib/commonjs/web_hammer/NodeManager.js +46 -0
- package/lib/commonjs/web_hammer/NodeManager.js.map +1 -0
- package/lib/commonjs/web_hammer/PanGestureHandler.js +208 -0
- package/lib/commonjs/web_hammer/PanGestureHandler.js.map +1 -0
- package/lib/commonjs/web_hammer/PinchGestureHandler.js +40 -0
- package/lib/commonjs/web_hammer/PinchGestureHandler.js.map +1 -0
- package/lib/commonjs/web_hammer/PressGestureHandler.js +188 -0
- package/lib/commonjs/web_hammer/PressGestureHandler.js.map +1 -0
- package/lib/commonjs/web_hammer/RotationGestureHandler.js +44 -0
- package/lib/commonjs/web_hammer/RotationGestureHandler.js.map +1 -0
- package/lib/commonjs/web_hammer/TapGestureHandler.js +192 -0
- package/lib/commonjs/web_hammer/TapGestureHandler.js.map +1 -0
- package/lib/commonjs/web_hammer/constants.js +64 -0
- package/lib/commonjs/web_hammer/constants.js.map +1 -0
- package/lib/commonjs/web_hammer/utils.js +42 -0
- package/lib/commonjs/web_hammer/utils.js.map +1 -0
- package/lib/module/ActionType.js +7 -0
- package/lib/module/ActionType.js.map +1 -0
- package/lib/module/Directions.js +7 -0
- package/lib/module/Directions.js.map +1 -0
- package/lib/module/EnableNewWebImplementation.js +22 -0
- package/lib/module/EnableNewWebImplementation.js.map +1 -0
- package/lib/module/GestureHandlerRootViewContext.js +3 -0
- package/lib/module/GestureHandlerRootViewContext.js.map +1 -0
- package/lib/module/PlatformConstants.js +5 -0
- package/lib/module/PlatformConstants.js.map +1 -0
- package/lib/module/PlatformConstants.web.js +7 -0
- package/lib/module/PlatformConstants.web.js.map +1 -0
- package/lib/module/RNGestureHandlerModule.js +19 -0
- package/lib/module/RNGestureHandlerModule.js.map +1 -0
- package/lib/module/RNGestureHandlerModule.macos.js +110 -0
- package/lib/module/RNGestureHandlerModule.macos.js.map +1 -0
- package/lib/module/RNGestureHandlerModule.web.js +122 -0
- package/lib/module/RNGestureHandlerModule.web.js.map +1 -0
- package/lib/module/RNGestureHandlerModule.windows.js +118 -0
- package/lib/module/RNGestureHandlerModule.windows.js.map +1 -0
- package/lib/module/RNRenderer.js +4 -0
- package/lib/module/RNRenderer.js.map +1 -0
- package/lib/module/RNRenderer.web.js +4 -0
- package/lib/module/RNRenderer.web.js.map +1 -0
- package/lib/module/State.js +10 -0
- package/lib/module/State.js.map +1 -0
- package/lib/module/TouchEventType.js +8 -0
- package/lib/module/TouchEventType.js.map +1 -0
- package/lib/module/components/DrawerLayout.js +551 -0
- package/lib/module/components/DrawerLayout.js.map +1 -0
- package/lib/module/components/GestureButtons.js +206 -0
- package/lib/module/components/GestureButtons.js.map +1 -0
- package/lib/module/components/GestureComponents.js +90 -0
- package/lib/module/components/GestureComponents.js.map +1 -0
- package/lib/module/components/GestureComponents.web.js +28 -0
- package/lib/module/components/GestureComponents.web.js.map +1 -0
- package/lib/module/components/GestureHandlerButton.js +3 -0
- package/lib/module/components/GestureHandlerButton.js.map +1 -0
- package/lib/module/components/GestureHandlerButton.web.js +9 -0
- package/lib/module/components/GestureHandlerButton.web.js.map +1 -0
- package/lib/module/components/GestureHandlerRootView.android.js +14 -0
- package/lib/module/components/GestureHandlerRootView.android.js.map +1 -0
- package/lib/module/components/GestureHandlerRootView.js +14 -0
- package/lib/module/components/GestureHandlerRootView.js.map +1 -0
- package/lib/module/components/GestureHandlerRootView.web.js +9 -0
- package/lib/module/components/GestureHandlerRootView.web.js.map +1 -0
- package/lib/module/components/Swipeable.js +390 -0
- package/lib/module/components/Swipeable.js.map +1 -0
- package/lib/module/components/gestureHandlerRootHOC.js +22 -0
- package/lib/module/components/gestureHandlerRootHOC.js.map +1 -0
- package/lib/module/components/touchables/GenericTouchable.js +273 -0
- package/lib/module/components/touchables/GenericTouchable.js.map +1 -0
- package/lib/module/components/touchables/TouchableHighlight.js +95 -0
- package/lib/module/components/touchables/TouchableHighlight.js.map +1 -0
- package/lib/module/components/touchables/TouchableNativeFeedback.android.js +84 -0
- package/lib/module/components/touchables/TouchableNativeFeedback.android.js.map +1 -0
- package/lib/module/components/touchables/TouchableNativeFeedback.js +3 -0
- package/lib/module/components/touchables/TouchableNativeFeedback.js.map +1 -0
- package/lib/module/components/touchables/TouchableOpacity.js +63 -0
- package/lib/module/components/touchables/TouchableOpacity.js.map +1 -0
- package/lib/module/components/touchables/TouchableWithoutFeedback.js +10 -0
- package/lib/module/components/touchables/TouchableWithoutFeedback.js.map +1 -0
- package/lib/module/components/touchables/index.js +5 -0
- package/lib/module/components/touchables/index.js.map +1 -0
- package/lib/module/getReactNativeVersion.js +10 -0
- package/lib/module/getReactNativeVersion.js.map +1 -0
- package/lib/module/getReactNativeVersion.web.js +4 -0
- package/lib/module/getReactNativeVersion.web.js.map +1 -0
- package/lib/module/getShadowNodeFromRef.js +20 -0
- package/lib/module/getShadowNodeFromRef.js.map +1 -0
- package/lib/module/getShadowNodeFromRef.web.js +8 -0
- package/lib/module/getShadowNodeFromRef.web.js.map +1 -0
- package/lib/module/ghQueueMicrotask.js +5 -0
- package/lib/module/ghQueueMicrotask.js.map +1 -0
- package/lib/module/handlers/FlingGestureHandler.js +11 -0
- package/lib/module/handlers/FlingGestureHandler.js.map +1 -0
- package/lib/module/handlers/ForceTouchGestureHandler.js +31 -0
- package/lib/module/handlers/ForceTouchGestureHandler.js.map +1 -0
- package/lib/module/handlers/LongPressGestureHandler.js +13 -0
- package/lib/module/handlers/LongPressGestureHandler.js.map +1 -0
- package/lib/module/handlers/NativeViewGestureHandler.js +12 -0
- package/lib/module/handlers/NativeViewGestureHandler.js.map +1 -0
- package/lib/module/handlers/PanGestureHandler.js +107 -0
- package/lib/module/handlers/PanGestureHandler.js.map +1 -0
- package/lib/module/handlers/PinchGestureHandler.js +10 -0
- package/lib/module/handlers/PinchGestureHandler.js.map +1 -0
- package/lib/module/handlers/PressabilityDebugView.js +3 -0
- package/lib/module/handlers/PressabilityDebugView.js.map +1 -0
- package/lib/module/handlers/PressabilityDebugView.web.js +5 -0
- package/lib/module/handlers/PressabilityDebugView.web.js.map +1 -0
- package/lib/module/handlers/RotationGestureHandler.js +10 -0
- package/lib/module/handlers/RotationGestureHandler.js.map +1 -0
- package/lib/module/handlers/TapGestureHandler.js +13 -0
- package/lib/module/handlers/TapGestureHandler.js.map +1 -0
- package/lib/module/handlers/createHandler.js +433 -0
- package/lib/module/handlers/createHandler.js.map +1 -0
- package/lib/module/handlers/createNativeWrapper.js +62 -0
- package/lib/module/handlers/createNativeWrapper.js.map +1 -0
- package/lib/module/handlers/gestureHandlerCommon.js +81 -0
- package/lib/module/handlers/gestureHandlerCommon.js.map +1 -0
- package/lib/module/handlers/gestureHandlerTypesCompat.js +2 -0
- package/lib/module/handlers/gestureHandlerTypesCompat.js.map +1 -0
- package/lib/module/handlers/gestures/GestureDetector.js +619 -0
- package/lib/module/handlers/gestures/GestureDetector.js.map +1 -0
- package/lib/module/handlers/gestures/eventReceiver.js +131 -0
- package/lib/module/handlers/gestures/eventReceiver.js.map +1 -0
- package/lib/module/handlers/gestures/flingGesture.js +24 -0
- package/lib/module/handlers/gestures/flingGesture.js.map +1 -0
- package/lib/module/handlers/gestures/forceTouchGesture.js +56 -0
- package/lib/module/handlers/gestures/forceTouchGesture.js.map +1 -0
- package/lib/module/handlers/gestures/gesture.js +222 -0
- package/lib/module/handlers/gestures/gesture.js.map +1 -0
- package/lib/module/handlers/gestures/gestureComposition.js +90 -0
- package/lib/module/handlers/gestures/gestureComposition.js.map +1 -0
- package/lib/module/handlers/gestures/gestureObjects.js +71 -0
- package/lib/module/handlers/gestures/gestureObjects.js.map +1 -0
- package/lib/module/handlers/gestures/gestureStateManager.js +54 -0
- package/lib/module/handlers/gestures/gestureStateManager.js.map +1 -0
- package/lib/module/handlers/gestures/gestureStateManager.web.js +21 -0
- package/lib/module/handlers/gestures/gestureStateManager.web.js.map +1 -0
- package/lib/module/handlers/gestures/hoverGesture.js +62 -0
- package/lib/module/handlers/gestures/hoverGesture.js.map +1 -0
- package/lib/module/handlers/gestures/longPressGesture.js +25 -0
- package/lib/module/handlers/gestures/longPressGesture.js.map +1 -0
- package/lib/module/handlers/gestures/manualGesture.js +22 -0
- package/lib/module/handlers/gestures/manualGesture.js.map +1 -0
- package/lib/module/handlers/gestures/nativeGesture.js +24 -0
- package/lib/module/handlers/gestures/nativeGesture.js.map +1 -0
- package/lib/module/handlers/gestures/panGesture.js +140 -0
- package/lib/module/handlers/gestures/panGesture.js.map +1 -0
- package/lib/module/handlers/gestures/pinchGesture.js +36 -0
- package/lib/module/handlers/gestures/pinchGesture.js.map +1 -0
- package/lib/module/handlers/gestures/reanimatedWrapper.js +30 -0
- package/lib/module/handlers/gestures/reanimatedWrapper.js.map +1 -0
- package/lib/module/handlers/gestures/rotationGesture.js +36 -0
- package/lib/module/handlers/gestures/rotationGesture.js.map +1 -0
- package/lib/module/handlers/gestures/tapGesture.js +50 -0
- package/lib/module/handlers/gestures/tapGesture.js.map +1 -0
- package/lib/module/handlers/handlersRegistry.js +44 -0
- package/lib/module/handlers/handlersRegistry.js.map +1 -0
- package/lib/module/index.js +25 -0
- package/lib/module/index.js.map +1 -0
- package/lib/module/init.js +16 -0
- package/lib/module/init.js.map +1 -0
- package/lib/module/jestUtils/index.js +2 -0
- package/lib/module/jestUtils/index.js.map +1 -0
- package/lib/module/jestUtils/jestUtils.js +350 -0
- package/lib/module/jestUtils/jestUtils.js.map +1 -0
- package/lib/module/mocks.js +56 -0
- package/lib/module/mocks.js.map +1 -0
- package/lib/module/specs/RNGestureHandlerButtonNativeComponent.js +3 -0
- package/lib/module/specs/RNGestureHandlerButtonNativeComponent.js.map +1 -0
- package/lib/module/specs/RNGestureHandlerRootViewNativeComponent.js +3 -0
- package/lib/module/specs/RNGestureHandlerRootViewNativeComponent.js.map +1 -0
- package/lib/module/typeUtils.js +2 -0
- package/lib/module/typeUtils.js.map +1 -0
- package/lib/module/utils.js +44 -0
- package/lib/module/utils.js.map +1 -0
- package/lib/module/web/constants.js +8 -0
- package/lib/module/web/constants.js.map +1 -0
- package/lib/module/web/detectors/RotationGestureDetector.js +155 -0
- package/lib/module/web/detectors/RotationGestureDetector.js.map +1 -0
- package/lib/module/web/detectors/ScaleGestureDetector.js +145 -0
- package/lib/module/web/detectors/ScaleGestureDetector.js.map +1 -0
- package/lib/module/web/handlers/FlingGestureHandler.js +152 -0
- package/lib/module/web/handlers/FlingGestureHandler.js.map +1 -0
- package/lib/module/web/handlers/GestureHandler.js +776 -0
- package/lib/module/web/handlers/GestureHandler.js.map +1 -0
- package/lib/module/web/handlers/HoverGestureHandler.js +47 -0
- package/lib/module/web/handlers/HoverGestureHandler.js.map +1 -0
- package/lib/module/web/handlers/LongPressGestureHandler.js +136 -0
- package/lib/module/web/handlers/LongPressGestureHandler.js.map +1 -0
- package/lib/module/web/handlers/ManualGestureHandler.js +49 -0
- package/lib/module/web/handlers/ManualGestureHandler.js.map +1 -0
- package/lib/module/web/handlers/NativeViewGestureHandler.js +163 -0
- package/lib/module/web/handlers/NativeViewGestureHandler.js.map +1 -0
- package/lib/module/web/handlers/PanGestureHandler.js +433 -0
- package/lib/module/web/handlers/PanGestureHandler.js.map +1 -0
- package/lib/module/web/handlers/PinchGestureHandler.js +159 -0
- package/lib/module/web/handlers/PinchGestureHandler.js.map +1 -0
- package/lib/module/web/handlers/RotationGestureHandler.js +171 -0
- package/lib/module/web/handlers/RotationGestureHandler.js.map +1 -0
- package/lib/module/web/handlers/TapGestureHandler.js +265 -0
- package/lib/module/web/handlers/TapGestureHandler.js.map +1 -0
- package/lib/module/web/interfaces.js +45 -0
- package/lib/module/web/interfaces.js.map +1 -0
- package/lib/module/web/tools/CircularBuffer.js +50 -0
- package/lib/module/web/tools/CircularBuffer.js.map +1 -0
- package/lib/module/web/tools/EventManager.js +118 -0
- package/lib/module/web/tools/EventManager.js.map +1 -0
- package/lib/module/web/tools/GestureHandlerDelegate.js +2 -0
- package/lib/module/web/tools/GestureHandlerDelegate.js.map +1 -0
- package/lib/module/web/tools/GestureHandlerOrchestrator.js +335 -0
- package/lib/module/web/tools/GestureHandlerOrchestrator.js.map +1 -0
- package/lib/module/web/tools/GestureHandlerWebDelegate.js +102 -0
- package/lib/module/web/tools/GestureHandlerWebDelegate.js.map +1 -0
- package/lib/module/web/tools/InteractionManager.js +105 -0
- package/lib/module/web/tools/InteractionManager.js.map +1 -0
- package/lib/module/web/tools/LeastSquareSolver.js +195 -0
- package/lib/module/web/tools/LeastSquareSolver.js.map +1 -0
- package/lib/module/web/tools/NodeManager.js +39 -0
- package/lib/module/web/tools/NodeManager.js.map +1 -0
- package/lib/module/web/tools/PointerEventManager.js +184 -0
- package/lib/module/web/tools/PointerEventManager.js.map +1 -0
- package/lib/module/web/tools/PointerTracker.js +213 -0
- package/lib/module/web/tools/PointerTracker.js.map +1 -0
- package/lib/module/web/tools/TouchEventManager.js +124 -0
- package/lib/module/web/tools/TouchEventManager.js.map +1 -0
- package/lib/module/web/tools/VelocityTracker.js +98 -0
- package/lib/module/web/tools/VelocityTracker.js.map +1 -0
- package/lib/module/web/utils.js +8 -0
- package/lib/module/web/utils.js.map +1 -0
- package/lib/module/web_hammer/DiscreteGestureHandler.js +94 -0
- package/lib/module/web_hammer/DiscreteGestureHandler.js.map +1 -0
- package/lib/module/web_hammer/DraggingGestureHandler.js +40 -0
- package/lib/module/web_hammer/DraggingGestureHandler.js.map +1 -0
- package/lib/module/web_hammer/Errors.js +7 -0
- package/lib/module/web_hammer/Errors.js.map +1 -0
- package/lib/module/web_hammer/FlingGestureHandler.js +156 -0
- package/lib/module/web_hammer/FlingGestureHandler.js.map +1 -0
- package/lib/module/web_hammer/GestureHandler.js +563 -0
- package/lib/module/web_hammer/GestureHandler.js.map +1 -0
- package/lib/module/web_hammer/IndiscreteGestureHandler.js +44 -0
- package/lib/module/web_hammer/IndiscreteGestureHandler.js.map +1 -0
- package/lib/module/web_hammer/LongPressGestureHandler.js +58 -0
- package/lib/module/web_hammer/LongPressGestureHandler.js.map +1 -0
- package/lib/module/web_hammer/NativeViewGestureHandler.js +49 -0
- package/lib/module/web_hammer/NativeViewGestureHandler.js.map +1 -0
- package/lib/module/web_hammer/NodeManager.js +33 -0
- package/lib/module/web_hammer/NodeManager.js.map +1 -0
- package/lib/module/web_hammer/PanGestureHandler.js +194 -0
- package/lib/module/web_hammer/PanGestureHandler.js.map +1 -0
- package/lib/module/web_hammer/PinchGestureHandler.js +29 -0
- package/lib/module/web_hammer/PinchGestureHandler.js.map +1 -0
- package/lib/module/web_hammer/PressGestureHandler.js +174 -0
- package/lib/module/web_hammer/PressGestureHandler.js.map +1 -0
- package/lib/module/web_hammer/RotationGestureHandler.js +32 -0
- package/lib/module/web_hammer/RotationGestureHandler.js.map +1 -0
- package/lib/module/web_hammer/TapGestureHandler.js +180 -0
- package/lib/module/web_hammer/TapGestureHandler.js.map +1 -0
- package/lib/module/web_hammer/constants.js +43 -0
- package/lib/module/web_hammer/constants.js.map +1 -0
- package/lib/module/web_hammer/utils.js +19 -0
- package/lib/module/web_hammer/utils.js.map +1 -0
- package/lib/typescript/ActionType.d.ts +7 -0
- package/lib/typescript/Directions.d.ts +7 -0
- package/lib/typescript/EnableNewWebImplementation.d.ts +3 -0
- package/lib/typescript/GestureHandlerRootViewContext.d.ts +3 -0
- package/lib/typescript/PlatformConstants.d.ts +5 -0
- package/lib/typescript/PlatformConstants.web.d.ts +4 -0
- package/lib/typescript/RNGestureHandlerModule.d.ts +13 -0
- package/lib/typescript/RNGestureHandlerModule.macos.d.ts +47 -0
- package/lib/typescript/RNGestureHandlerModule.web.d.ts +50 -0
- package/lib/typescript/RNGestureHandlerModule.windows.d.ts +48 -0
- package/lib/typescript/RNRenderer.d.ts +1 -0
- package/lib/typescript/RNRenderer.web.d.ts +3 -0
- package/lib/typescript/State.d.ts +9 -0
- package/lib/typescript/TouchEventType.d.ts +8 -0
- package/lib/typescript/components/DrawerLayout.d.ts +148 -0
- package/lib/typescript/components/GestureButtons.d.ts +121 -0
- package/lib/typescript/components/GestureComponents.d.ts +22 -0
- package/lib/typescript/components/GestureComponents.web.d.ts +8 -0
- package/lib/typescript/components/GestureHandlerButton.d.ts +4 -0
- package/lib/typescript/components/GestureHandlerButton.web.d.ts +4 -0
- package/lib/typescript/components/GestureHandlerRootView.android.d.ts +6 -0
- package/lib/typescript/components/GestureHandlerRootView.d.ts +6 -0
- package/lib/typescript/components/GestureHandlerRootView.web.d.ts +6 -0
- package/lib/typescript/components/Swipeable.d.ts +178 -0
- package/lib/typescript/components/gestureHandlerRootHOC.d.ts +3 -0
- package/lib/typescript/components/touchables/GenericTouchable.d.ts +68 -0
- package/lib/typescript/components/touchables/TouchableHighlight.d.ts +36 -0
- package/lib/typescript/components/touchables/TouchableNativeFeedback.android.d.ts +45 -0
- package/lib/typescript/components/touchables/TouchableNativeFeedback.d.ts +2 -0
- package/lib/typescript/components/touchables/TouchableOpacity.d.ts +25 -0
- package/lib/typescript/components/touchables/TouchableWithoutFeedback.d.ts +7 -0
- package/lib/typescript/components/touchables/index.d.ts +7 -0
- package/lib/typescript/getReactNativeVersion.d.ts +4 -0
- package/lib/typescript/getReactNativeVersion.web.d.ts +1 -0
- package/lib/typescript/getShadowNodeFromRef.d.ts +1 -0
- package/lib/typescript/getShadowNodeFromRef.web.d.ts +1 -0
- package/lib/typescript/ghQueueMicrotask.d.ts +1 -0
- package/lib/typescript/handlers/FlingGestureHandler.d.ts +34 -0
- package/lib/typescript/handlers/ForceTouchGestureHandler.d.ts +44 -0
- package/lib/typescript/handlers/LongPressGestureHandler.d.ts +56 -0
- package/lib/typescript/handlers/NativeViewGestureHandler.d.ts +28 -0
- package/lib/typescript/handlers/PanGestureHandler.d.ts +139 -0
- package/lib/typescript/handlers/PinchGestureHandler.d.ts +29 -0
- package/lib/typescript/handlers/PressabilityDebugView.d.ts +1 -0
- package/lib/typescript/handlers/PressabilityDebugView.web.d.ts +1 -0
- package/lib/typescript/handlers/RotationGestureHandler.d.ts +29 -0
- package/lib/typescript/handlers/TapGestureHandler.d.ts +57 -0
- package/lib/typescript/handlers/createHandler.d.ts +11 -0
- package/lib/typescript/handlers/createNativeWrapper.d.ts +3 -0
- package/lib/typescript/handlers/gestureHandlerCommon.d.ts +68 -0
- package/lib/typescript/handlers/gestureHandlerTypesCompat.d.ts +42 -0
- package/lib/typescript/handlers/gestures/GestureDetector.d.ts +19 -0
- package/lib/typescript/handlers/gestures/eventReceiver.d.ts +4 -0
- package/lib/typescript/handlers/gestures/flingGesture.d.ts +9 -0
- package/lib/typescript/handlers/gestures/forceTouchGesture.d.ts +15 -0
- package/lib/typescript/handlers/gestures/gesture.d.ts +110 -0
- package/lib/typescript/handlers/gestures/gestureComposition.d.ts +21 -0
- package/lib/typescript/handlers/gestures/gestureObjects.d.ts +41 -0
- package/lib/typescript/handlers/gestures/gestureStateManager.d.ts +9 -0
- package/lib/typescript/handlers/gestures/gestureStateManager.web.d.ts +4 -0
- package/lib/typescript/handlers/gestures/hoverGesture.d.ts +32 -0
- package/lib/typescript/handlers/gestures/longPressGesture.d.ts +9 -0
- package/lib/typescript/handlers/gestures/manualGesture.d.ts +7 -0
- package/lib/typescript/handlers/gestures/nativeGesture.d.ts +9 -0
- package/lib/typescript/handlers/gestures/panGesture.d.ts +26 -0
- package/lib/typescript/handlers/gestures/pinchGesture.d.ts +11 -0
- package/lib/typescript/handlers/gestures/reanimatedWrapper.d.ts +14 -0
- package/lib/typescript/handlers/gestures/rotationGesture.d.ts +12 -0
- package/lib/typescript/handlers/gestures/tapGesture.d.ts +14 -0
- package/lib/typescript/handlers/handlersRegistry.d.ts +14 -0
- package/lib/typescript/index.d.ts +52 -0
- package/lib/typescript/init.d.ts +2 -0
- package/lib/typescript/jestUtils/index.d.ts +1 -0
- package/lib/typescript/jestUtils/jestUtils.d.ts +28 -0
- package/lib/typescript/mocks.d.ts +44 -0
- package/lib/typescript/specs/RNGestureHandlerButtonNativeComponent.d.ts +14 -0
- package/lib/typescript/specs/RNGestureHandlerRootViewNativeComponent.d.ts +6 -0
- package/lib/typescript/typeUtils.d.ts +1 -0
- package/lib/typescript/utils.d.ts +8 -0
- package/lib/typescript/web/constants.d.ts +7 -0
- package/lib/typescript/web/detectors/RotationGestureDetector.d.ts +30 -0
- package/lib/typescript/web/detectors/ScaleGestureDetector.d.ts +29 -0
- package/lib/typescript/web/handlers/FlingGestureHandler.d.ts +27 -0
- package/lib/typescript/web/handlers/GestureHandler.d.ts +90 -0
- package/lib/typescript/web/handlers/HoverGestureHandler.d.ts +10 -0
- package/lib/typescript/web/handlers/LongPressGestureHandler.d.ts +26 -0
- package/lib/typescript/web/handlers/ManualGestureHandler.d.ts +12 -0
- package/lib/typescript/web/handlers/NativeViewGestureHandler.d.ts +24 -0
- package/lib/typescript/web/handlers/PanGestureHandler.d.ts +55 -0
- package/lib/typescript/web/handlers/PinchGestureHandler.d.ts +28 -0
- package/lib/typescript/web/handlers/RotationGestureHandler.d.ts +29 -0
- package/lib/typescript/web/handlers/TapGestureHandler.d.ts +39 -0
- package/lib/typescript/web/interfaces.d.ts +141 -0
- package/lib/typescript/web/tools/CircularBuffer.d.ts +11 -0
- package/lib/typescript/web/tools/EventManager.d.ts +34 -0
- package/lib/typescript/web/tools/GestureHandlerDelegate.d.ts +22 -0
- package/lib/typescript/web/tools/GestureHandlerOrchestrator.d.ts +29 -0
- package/lib/typescript/web/tools/GestureHandlerWebDelegate.d.ts +21 -0
- package/lib/typescript/web/tools/InteractionManager.d.ts +17 -0
- package/lib/typescript/web/tools/LeastSquareSolver.d.ts +12 -0
- package/lib/typescript/web/tools/NodeManager.d.ts +11 -0
- package/lib/typescript/web/tools/PointerEventManager.d.ts +8 -0
- package/lib/typescript/web/tools/PointerTracker.d.ts +53 -0
- package/lib/typescript/web/tools/TouchEventManager.d.ts +6 -0
- package/lib/typescript/web/tools/VelocityTracker.d.ts +13 -0
- package/lib/typescript/web/utils.d.ts +4 -0
- package/lib/typescript/web_hammer/DiscreteGestureHandler.d.ts +20 -0
- package/lib/typescript/web_hammer/DraggingGestureHandler.d.ts +15 -0
- package/lib/typescript/web_hammer/Errors.d.ts +3 -0
- package/lib/typescript/web_hammer/FlingGestureHandler.d.ts +43 -0
- package/lib/typescript/web_hammer/GestureHandler.d.ts +145 -0
- package/lib/typescript/web_hammer/IndiscreteGestureHandler.d.ts +40 -0
- package/lib/typescript/web_hammer/LongPressGestureHandler.d.ts +38 -0
- package/lib/typescript/web_hammer/NativeViewGestureHandler.d.ts +7 -0
- package/lib/typescript/web_hammer/NodeManager.d.ts +8 -0
- package/lib/typescript/web_hammer/PanGestureHandler.d.ts +56 -0
- package/lib/typescript/web_hammer/PinchGestureHandler.d.ts +13 -0
- package/lib/typescript/web_hammer/PressGestureHandler.d.ts +83 -0
- package/lib/typescript/web_hammer/RotationGestureHandler.d.ts +13 -0
- package/lib/typescript/web_hammer/TapGestureHandler.d.ts +57 -0
- package/lib/typescript/web_hammer/constants.d.ts +39 -0
- package/lib/typescript/web_hammer/utils.d.ts +9 -0
- package/package.json +156 -0
- package/src/ActionType.ts +9 -0
- package/src/Directions.ts +9 -0
- package/src/EnableNewWebImplementation.ts +35 -0
- package/src/GestureHandlerRootViewContext.ts +3 -0
- package/src/PlatformConstants.ts +8 -0
- package/src/PlatformConstants.web.ts +5 -0
- package/src/RNGestureHandlerModule.macos.ts +133 -0
- package/src/RNGestureHandlerModule.ts +50 -0
- package/src/RNGestureHandlerModule.web.ts +146 -0
- package/src/RNGestureHandlerModule.windows.ts +144 -0
- package/src/RNRenderer.ts +3 -0
- package/src/RNRenderer.web.ts +3 -0
- package/src/State.ts +13 -0
- package/src/TouchEventType.ts +10 -0
- package/src/components/DrawerLayout.tsx +743 -0
- package/src/components/GestureButtons.tsx +332 -0
- package/src/components/GestureComponents.tsx +148 -0
- package/src/components/GestureComponents.web.tsx +41 -0
- package/src/components/GestureHandlerButton.tsx +5 -0
- package/src/components/GestureHandlerButton.web.tsx +6 -0
- package/src/components/GestureHandlerRootView.android.tsx +24 -0
- package/src/components/GestureHandlerRootView.tsx +23 -0
- package/src/components/GestureHandlerRootView.web.tsx +17 -0
- package/src/components/Swipeable.tsx +584 -0
- package/src/components/gestureHandlerRootHOC.tsx +32 -0
- package/src/components/touchables/GenericTouchable.tsx +301 -0
- package/src/components/touchables/TouchableHighlight.tsx +115 -0
- package/src/components/touchables/TouchableNativeFeedback.android.tsx +91 -0
- package/src/components/touchables/TouchableNativeFeedback.tsx +3 -0
- package/src/components/touchables/TouchableOpacity.tsx +75 -0
- package/src/components/touchables/TouchableWithoutFeedback.tsx +14 -0
- package/src/components/touchables/index.ts +7 -0
- package/src/getReactNativeVersion.ts +11 -0
- package/src/getReactNativeVersion.web.ts +3 -0
- package/src/getShadowNodeFromRef.ts +22 -0
- package/src/getShadowNodeFromRef.web.ts +7 -0
- package/src/ghQueueMicrotask.ts +5 -0
- package/src/handlers/FlingGestureHandler.ts +59 -0
- package/src/handlers/ForceTouchGestureHandler.ts +90 -0
- package/src/handlers/LongPressGestureHandler.ts +88 -0
- package/src/handlers/NativeViewGestureHandler.ts +55 -0
- package/src/handlers/PanGestureHandler.ts +325 -0
- package/src/handlers/PinchGestureHandler.ts +48 -0
- package/src/handlers/PressabilityDebugView.tsx +2 -0
- package/src/handlers/PressabilityDebugView.web.tsx +4 -0
- package/src/handlers/RotationGestureHandler.ts +48 -0
- package/src/handlers/TapGestureHandler.ts +94 -0
- package/src/handlers/createHandler.tsx +533 -0
- package/src/handlers/createNativeWrapper.tsx +80 -0
- package/src/handlers/gestureHandlerCommon.ts +250 -0
- package/src/handlers/gestureHandlerTypesCompat.ts +106 -0
- package/src/handlers/gestures/GestureDetector.tsx +822 -0
- package/src/handlers/gestures/eventReceiver.ts +155 -0
- package/src/handlers/gestures/flingGesture.ts +27 -0
- package/src/handlers/gestures/forceTouchGesture.ts +74 -0
- package/src/handlers/gestures/gesture.ts +349 -0
- package/src/handlers/gestures/gestureComposition.ts +122 -0
- package/src/handlers/gestures/gestureObjects.ts +84 -0
- package/src/handlers/gestures/gestureStateManager.ts +62 -0
- package/src/handlers/gestures/gestureStateManager.web.ts +24 -0
- package/src/handlers/gestures/hoverGesture.ts +83 -0
- package/src/handlers/gestures/longPressGesture.ts +28 -0
- package/src/handlers/gestures/manualGesture.ts +31 -0
- package/src/handlers/gestures/nativeGesture.ts +27 -0
- package/src/handlers/gestures/panGesture.ts +152 -0
- package/src/handlers/gestures/pinchGesture.ts +51 -0
- package/src/handlers/gestures/reanimatedWrapper.ts +56 -0
- package/src/handlers/gestures/rotationGesture.ts +51 -0
- package/src/handlers/gestures/tapGesture.ts +53 -0
- package/src/handlers/handlersRegistry.ts +60 -0
- package/src/index.ts +174 -0
- package/src/init.ts +18 -0
- package/src/jestUtils/index.ts +1 -0
- package/src/jestUtils/jestUtils.ts +505 -0
- package/src/mocks.ts +67 -0
- package/src/specs/RNGestureHandlerButtonNativeComponent.ts +18 -0
- package/src/specs/RNGestureHandlerRootViewNativeComponent.ts +6 -0
- package/src/typeUtils.ts +1 -0
- package/src/utils.ts +54 -0
- package/src/web/constants.ts +8 -0
- package/src/web/detectors/RotationGestureDetector.ts +168 -0
- package/src/web/detectors/ScaleGestureDetector.ts +172 -0
- package/src/web/handlers/FlingGestureHandler.ts +161 -0
- package/src/web/handlers/GestureHandler.ts +849 -0
- package/src/web/handlers/HoverGestureHandler.ts +43 -0
- package/src/web/handlers/LongPressGestureHandler.ts +125 -0
- package/src/web/handlers/ManualGestureHandler.ts +43 -0
- package/src/web/handlers/NativeViewGestureHandler.ts +167 -0
- package/src/web/handlers/PanGestureHandler.ts +485 -0
- package/src/web/handlers/PinchGestureHandler.ts +158 -0
- package/src/web/handlers/RotationGestureHandler.ts +172 -0
- package/src/web/handlers/TapGestureHandler.ts +273 -0
- package/src/web/interfaces.ts +167 -0
- package/src/web/tools/CircularBuffer.ts +42 -0
- package/src/web/tools/EventManager.ts +104 -0
- package/src/web/tools/GestureHandlerDelegate.ts +23 -0
- package/src/web/tools/GestureHandlerOrchestrator.ts +389 -0
- package/src/web/tools/GestureHandlerWebDelegate.ts +115 -0
- package/src/web/tools/InteractionManager.ts +130 -0
- package/src/web/tools/LeastSquareSolver.ts +182 -0
- package/src/web/tools/NodeManager.ts +43 -0
- package/src/web/tools/PointerEventManager.ts +202 -0
- package/src/web/tools/PointerTracker.ts +240 -0
- package/src/web/tools/TouchEventManager.ts +167 -0
- package/src/web/tools/VelocityTracker.ts +98 -0
- package/src/web/utils.ts +8 -0
- package/src/web_hammer/DiscreteGestureHandler.ts +82 -0
- package/src/web_hammer/DraggingGestureHandler.ts +34 -0
- package/src/web_hammer/Errors.ts +7 -0
- package/src/web_hammer/FlingGestureHandler.ts +134 -0
- package/src/web_hammer/GestureHandler.ts +599 -0
- package/src/web_hammer/IndiscreteGestureHandler.ts +33 -0
- package/src/web_hammer/LongPressGestureHandler.ts +56 -0
- package/src/web_hammer/NativeViewGestureHandler.ts +47 -0
- package/src/web_hammer/NodeManager.ts +42 -0
- package/src/web_hammer/PanGestureHandler.ts +226 -0
- package/src/web_hammer/PinchGestureHandler.ts +25 -0
- package/src/web_hammer/PressGestureHandler.ts +167 -0
- package/src/web_hammer/RotationGestureHandler.ts +25 -0
- package/src/web_hammer/TapGestureHandler.ts +172 -0
- package/src/web_hammer/constants.ts +48 -0
- package/src/web_hammer/utils.ts +24 -0
@@ -0,0 +1,8 @@
|
|
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
|
+
}
|
@@ -0,0 +1,671 @@
|
|
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
|
+
}
|