react-native-gesture-handler 2.26.0 → 2.27.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +69 -0
- package/android/src/main/jni/CMakeLists.txt +7 -26
- package/lib/commonjs/components/Pressable/Pressable.js +139 -188
- package/lib/commonjs/components/Pressable/Pressable.js.map +1 -1
- package/lib/commonjs/components/Pressable/StateMachine.js +38 -0
- package/lib/commonjs/components/Pressable/StateMachine.js.map +1 -0
- package/lib/commonjs/components/Pressable/stateDefinitions.js +88 -0
- package/lib/commonjs/components/Pressable/stateDefinitions.js.map +1 -0
- package/lib/commonjs/components/Pressable/utils.js +1 -1
- package/lib/commonjs/components/Pressable/utils.js.map +1 -1
- package/lib/commonjs/handlers/gestures/forceTouchGesture.js +12 -0
- package/lib/commonjs/handlers/gestures/forceTouchGesture.js.map +1 -1
- package/lib/commonjs/handlers/gestures/gestureObjects.js +3 -1
- package/lib/commonjs/handlers/gestures/gestureObjects.js.map +1 -1
- package/lib/commonjs/web/detectors/RotationGestureDetector.js +3 -0
- package/lib/commonjs/web/detectors/RotationGestureDetector.js.map +1 -1
- package/lib/commonjs/web/handlers/FlingGestureHandler.js +3 -0
- package/lib/commonjs/web/handlers/FlingGestureHandler.js.map +1 -1
- package/lib/commonjs/web/handlers/GestureHandler.js +6 -6
- package/lib/commonjs/web/handlers/GestureHandler.js.map +1 -1
- package/lib/commonjs/web/handlers/PanGestureHandler.js +24 -33
- package/lib/commonjs/web/handlers/PanGestureHandler.js.map +1 -1
- package/lib/commonjs/web/handlers/TapGestureHandler.js +15 -17
- package/lib/commonjs/web/handlers/TapGestureHandler.js.map +1 -1
- package/lib/commonjs/web/tools/GestureHandlerOrchestrator.js +1 -1
- package/lib/commonjs/web/tools/GestureHandlerOrchestrator.js.map +1 -1
- package/lib/commonjs/web/tools/PointerEventManager.js +1 -1
- package/lib/commonjs/web/tools/PointerEventManager.js.map +1 -1
- package/lib/commonjs/web/tools/PointerTracker.js +12 -11
- package/lib/commonjs/web/tools/PointerTracker.js.map +1 -1
- package/lib/commonjs/web/tools/Vector.js +1 -1
- package/lib/commonjs/web/tools/Vector.js.map +1 -1
- package/lib/module/components/Pressable/Pressable.js +141 -190
- package/lib/module/components/Pressable/Pressable.js.map +1 -1
- package/lib/module/components/Pressable/StateMachine.js +34 -0
- package/lib/module/components/Pressable/StateMachine.js.map +1 -0
- package/lib/module/components/Pressable/stateDefinitions.js +83 -0
- package/lib/module/components/Pressable/stateDefinitions.js.map +1 -0
- package/lib/module/components/Pressable/utils.js +1 -1
- package/lib/module/components/Pressable/utils.js.map +1 -1
- package/lib/module/handlers/gestures/forceTouchGesture.js +13 -0
- package/lib/module/handlers/gestures/forceTouchGesture.js.map +1 -1
- package/lib/module/handlers/gestures/gestureObjects.js +3 -1
- package/lib/module/handlers/gestures/gestureObjects.js.map +1 -1
- package/lib/module/web/detectors/RotationGestureDetector.js +3 -0
- package/lib/module/web/detectors/RotationGestureDetector.js.map +1 -1
- package/lib/module/web/handlers/FlingGestureHandler.js +3 -0
- package/lib/module/web/handlers/FlingGestureHandler.js.map +1 -1
- package/lib/module/web/handlers/GestureHandler.js +6 -6
- package/lib/module/web/handlers/GestureHandler.js.map +1 -1
- package/lib/module/web/handlers/PanGestureHandler.js +24 -33
- package/lib/module/web/handlers/PanGestureHandler.js.map +1 -1
- package/lib/module/web/handlers/TapGestureHandler.js +15 -17
- package/lib/module/web/handlers/TapGestureHandler.js.map +1 -1
- package/lib/module/web/tools/GestureHandlerOrchestrator.js +1 -1
- package/lib/module/web/tools/GestureHandlerOrchestrator.js.map +1 -1
- package/lib/module/web/tools/PointerEventManager.js +1 -1
- package/lib/module/web/tools/PointerEventManager.js.map +1 -1
- package/lib/module/web/tools/PointerTracker.js +12 -11
- package/lib/module/web/tools/PointerTracker.js.map +1 -1
- package/lib/module/web/tools/Vector.js +1 -1
- package/lib/module/web/tools/Vector.js.map +1 -1
- package/lib/typescript/ActionType.d.ts +0 -1
- package/lib/typescript/ActionType.js +6 -0
- package/lib/typescript/Directions.d.ts +0 -1
- package/lib/typescript/Directions.js +18 -0
- package/lib/typescript/EnableNewWebImplementation.d.ts +0 -1
- package/lib/typescript/EnableNewWebImplementation.js +30 -0
- package/lib/typescript/GestureHandlerRootViewContext.d.ts +0 -1
- package/lib/typescript/GestureHandlerRootViewContext.js +2 -0
- package/lib/typescript/PlatformConstants.d.ts +0 -1
- package/lib/typescript/PlatformConstants.js +3 -0
- package/lib/typescript/PlatformConstants.web.d.ts +0 -1
- package/lib/typescript/PlatformConstants.web.js +5 -0
- package/lib/typescript/PointerType.d.ts +0 -1
- package/lib/typescript/PointerType.js +8 -0
- package/lib/typescript/RNGestureHandlerModule.d.ts +0 -1
- package/lib/typescript/RNGestureHandlerModule.js +4 -0
- package/lib/typescript/RNGestureHandlerModule.web.d.ts +0 -1
- package/lib/typescript/RNGestureHandlerModule.web.js +92 -0
- package/lib/typescript/RNGestureHandlerModule.windows.d.ts +0 -1
- package/lib/typescript/RNGestureHandlerModule.windows.js +47 -0
- package/lib/typescript/RNRenderer.d.ts +0 -1
- package/lib/typescript/RNRenderer.js +3 -0
- package/lib/typescript/RNRenderer.web.d.ts +0 -1
- package/lib/typescript/RNRenderer.web.js +3 -0
- package/lib/typescript/State.d.ts +0 -1
- package/lib/typescript/State.js +9 -0
- package/lib/typescript/TouchEventType.d.ts +0 -1
- package/lib/typescript/TouchEventType.js +7 -0
- package/lib/typescript/components/DrawerLayout.d.ts +0 -1
- package/lib/typescript/components/DrawerLayout.js +417 -0
- package/lib/typescript/components/GestureButtons.d.ts +0 -1
- package/lib/typescript/components/GestureButtons.js +165 -0
- package/lib/typescript/components/GestureButtonsProps.d.ts +0 -1
- package/lib/typescript/components/GestureButtonsProps.js +1 -0
- package/lib/typescript/components/GestureComponents.d.ts +0 -1
- package/lib/typescript/components/GestureComponents.js +67 -0
- package/lib/typescript/components/GestureComponents.web.d.ts +0 -1
- package/lib/typescript/components/GestureComponents.web.js +21 -0
- package/lib/typescript/components/GestureHandlerButton.d.ts +0 -1
- package/lib/typescript/components/GestureHandlerButton.js +2 -0
- package/lib/typescript/components/GestureHandlerButton.web.d.ts +0 -1
- package/lib/typescript/components/GestureHandlerButton.web.js +3 -0
- package/lib/typescript/components/GestureHandlerRootView.android.d.ts +0 -1
- package/lib/typescript/components/GestureHandlerRootView.android.js +17 -0
- package/lib/typescript/components/GestureHandlerRootView.d.ts +0 -1
- package/lib/typescript/components/GestureHandlerRootView.js +16 -0
- package/lib/typescript/components/GestureHandlerRootView.web.d.ts +0 -1
- package/lib/typescript/components/GestureHandlerRootView.web.js +11 -0
- package/lib/typescript/components/Pressable/Pressable.d.ts +1 -3
- package/lib/typescript/components/Pressable/Pressable.d.ts.map +1 -1
- package/lib/typescript/components/Pressable/Pressable.js +231 -0
- package/lib/typescript/components/Pressable/PressableProps.d.ts +15 -2
- package/lib/typescript/components/Pressable/PressableProps.d.ts.map +1 -1
- package/lib/typescript/components/Pressable/PressableProps.js +1 -0
- package/lib/typescript/components/Pressable/StateMachine.d.ts +14 -0
- package/lib/typescript/components/Pressable/StateMachine.d.ts.map +1 -0
- package/lib/typescript/components/Pressable/StateMachine.js +34 -0
- package/lib/typescript/components/Pressable/index.d.ts +0 -1
- package/lib/typescript/components/Pressable/index.js +1 -0
- package/lib/typescript/components/Pressable/stateDefinitions.d.ts +9 -0
- package/lib/typescript/components/Pressable/stateDefinitions.d.ts.map +1 -0
- package/lib/typescript/components/Pressable/stateDefinitions.js +104 -0
- package/lib/typescript/components/Pressable/utils.d.ts +3 -7
- package/lib/typescript/components/Pressable/utils.d.ts.map +1 -1
- package/lib/typescript/components/Pressable/utils.js +80 -0
- package/lib/typescript/components/ReanimatedDrawerLayout.d.ts +0 -1
- package/lib/typescript/components/ReanimatedDrawerLayout.js +364 -0
- package/lib/typescript/components/ReanimatedSwipeable.d.ts +0 -1
- package/lib/typescript/components/ReanimatedSwipeable.js +400 -0
- package/lib/typescript/components/Swipeable.d.ts +0 -1
- package/lib/typescript/components/Swipeable.js +287 -0
- package/lib/typescript/components/Text.d.ts +0 -1
- package/lib/typescript/components/Text.js +38 -0
- package/lib/typescript/components/gestureHandlerRootHOC.d.ts +0 -1
- package/lib/typescript/components/gestureHandlerRootHOC.js +18 -0
- package/lib/typescript/components/touchables/ExtraButtonProps.d.ts +0 -1
- package/lib/typescript/components/touchables/ExtraButtonProps.js +1 -0
- package/lib/typescript/components/touchables/GenericTouchable.d.ts +0 -1
- package/lib/typescript/components/touchables/GenericTouchable.js +221 -0
- package/lib/typescript/components/touchables/GenericTouchableProps.d.ts +0 -1
- package/lib/typescript/components/touchables/GenericTouchableProps.js +1 -0
- package/lib/typescript/components/touchables/TouchableHighlight.d.ts +0 -1
- package/lib/typescript/components/touchables/TouchableHighlight.js +75 -0
- package/lib/typescript/components/touchables/TouchableNativeFeedback.android.d.ts +0 -1
- package/lib/typescript/components/touchables/TouchableNativeFeedback.android.js +65 -0
- package/lib/typescript/components/touchables/TouchableNativeFeedback.d.ts +0 -1
- package/lib/typescript/components/touchables/TouchableNativeFeedback.js +6 -0
- package/lib/typescript/components/touchables/TouchableNativeFeedbackProps.d.ts +0 -1
- package/lib/typescript/components/touchables/TouchableNativeFeedbackProps.js +1 -0
- package/lib/typescript/components/touchables/TouchableOpacity.d.ts +0 -1
- package/lib/typescript/components/touchables/TouchableOpacity.js +51 -0
- package/lib/typescript/components/touchables/TouchableWithoutFeedback.d.ts +0 -1
- package/lib/typescript/components/touchables/TouchableWithoutFeedback.js +10 -0
- package/lib/typescript/components/touchables/index.d.ts +0 -1
- package/lib/typescript/components/touchables/index.js +4 -0
- package/lib/typescript/components/utils.d.ts +0 -1
- package/lib/typescript/components/utils.js +11 -0
- package/lib/typescript/findNodeHandle.d.ts +0 -1
- package/lib/typescript/findNodeHandle.js +2 -0
- package/lib/typescript/findNodeHandle.web.d.ts +0 -1
- package/lib/typescript/findNodeHandle.web.js +31 -0
- package/lib/typescript/getShadowNodeFromRef.d.ts +0 -1
- package/lib/typescript/getShadowNodeFromRef.js +45 -0
- package/lib/typescript/getShadowNodeFromRef.web.d.ts +0 -1
- package/lib/typescript/getShadowNodeFromRef.web.js +7 -0
- package/lib/typescript/ghQueueMicrotask.d.ts +0 -1
- package/lib/typescript/ghQueueMicrotask.js +7 -0
- package/lib/typescript/handlers/FlingGestureHandler.d.ts +0 -1
- package/lib/typescript/handlers/FlingGestureHandler.js +19 -0
- package/lib/typescript/handlers/ForceTouchGestureHandler.d.ts +0 -1
- package/lib/typescript/handlers/ForceTouchGestureHandler.js +37 -0
- package/lib/typescript/handlers/GestureHandlerEventPayload.d.ts +3 -1
- package/lib/typescript/handlers/GestureHandlerEventPayload.d.ts.map +1 -1
- package/lib/typescript/handlers/GestureHandlerEventPayload.js +1 -0
- package/lib/typescript/handlers/LongPressGestureHandler.d.ts +0 -1
- package/lib/typescript/handlers/LongPressGestureHandler.js +22 -0
- package/lib/typescript/handlers/NativeViewGestureHandler.d.ts +0 -1
- package/lib/typescript/handlers/NativeViewGestureHandler.js +20 -0
- package/lib/typescript/handlers/PanGestureHandler.d.ts +0 -1
- package/lib/typescript/handlers/PanGestureHandler.js +128 -0
- package/lib/typescript/handlers/PinchGestureHandler.d.ts +0 -1
- package/lib/typescript/handlers/PinchGestureHandler.js +12 -0
- package/lib/typescript/handlers/PressabilityDebugView.d.ts +0 -1
- package/lib/typescript/handlers/PressabilityDebugView.js +2 -0
- package/lib/typescript/handlers/PressabilityDebugView.web.d.ts +0 -1
- package/lib/typescript/handlers/PressabilityDebugView.web.js +4 -0
- package/lib/typescript/handlers/RotationGestureHandler.d.ts +0 -1
- package/lib/typescript/handlers/RotationGestureHandler.js +12 -0
- package/lib/typescript/handlers/TapGestureHandler.d.ts +0 -1
- package/lib/typescript/handlers/TapGestureHandler.js +26 -0
- package/lib/typescript/handlers/createHandler.d.ts +0 -1
- package/lib/typescript/handlers/createHandler.js +375 -0
- package/lib/typescript/handlers/createNativeWrapper.d.ts +0 -1
- package/lib/typescript/handlers/createNativeWrapper.js +67 -0
- package/lib/typescript/handlers/customDirectEventTypes.d.ts +0 -1
- package/lib/typescript/handlers/customDirectEventTypes.js +2 -0
- package/lib/typescript/handlers/customDirectEventTypes.web.d.ts +0 -1
- package/lib/typescript/handlers/customDirectEventTypes.web.js +4 -0
- package/lib/typescript/handlers/gestureHandlerCommon.d.ts +0 -1
- package/lib/typescript/handlers/gestureHandlerCommon.js +42 -0
- package/lib/typescript/handlers/gestureHandlerTypesCompat.d.ts +9 -1
- package/lib/typescript/handlers/gestureHandlerTypesCompat.d.ts.map +1 -1
- package/lib/typescript/handlers/gestureHandlerTypesCompat.js +1 -0
- package/lib/typescript/handlers/gestures/GestureDetector/Wrap.d.ts +0 -1
- package/lib/typescript/handlers/gestures/GestureDetector/Wrap.js +22 -0
- package/lib/typescript/handlers/gestures/GestureDetector/Wrap.web.d.ts +0 -1
- package/lib/typescript/handlers/gestures/GestureDetector/Wrap.web.js +24 -0
- package/lib/typescript/handlers/gestures/GestureDetector/attachHandlers.d.ts +0 -1
- package/lib/typescript/handlers/gestures/GestureDetector/attachHandlers.js +55 -0
- package/lib/typescript/handlers/gestures/GestureDetector/dropHandlers.d.ts +0 -1
- package/lib/typescript/handlers/gestures/GestureDetector/dropHandlers.js +12 -0
- package/lib/typescript/handlers/gestures/GestureDetector/index.d.ts +0 -1
- package/lib/typescript/handlers/gestures/GestureDetector/index.js +114 -0
- package/lib/typescript/handlers/gestures/GestureDetector/needsToReattach.d.ts +0 -1
- package/lib/typescript/handlers/gestures/GestureDetector/needsToReattach.js +18 -0
- package/lib/typescript/handlers/gestures/GestureDetector/types.d.ts +0 -1
- package/lib/typescript/handlers/gestures/GestureDetector/types.js +1 -0
- package/lib/typescript/handlers/gestures/GestureDetector/updateHandlers.d.ts +0 -1
- package/lib/typescript/handlers/gestures/GestureDetector/updateHandlers.js +54 -0
- package/lib/typescript/handlers/gestures/GestureDetector/useAnimatedGesture.d.ts +0 -1
- package/lib/typescript/handlers/gestures/GestureDetector/useAnimatedGesture.js +137 -0
- package/lib/typescript/handlers/gestures/GestureDetector/useDetectorUpdater.d.ts +0 -1
- package/lib/typescript/handlers/gestures/GestureDetector/useDetectorUpdater.js +48 -0
- package/lib/typescript/handlers/gestures/GestureDetector/useMountReactions.d.ts +0 -1
- package/lib/typescript/handlers/gestures/GestureDetector/useMountReactions.js +35 -0
- package/lib/typescript/handlers/gestures/GestureDetector/useViewRefHandler.d.ts +0 -1
- package/lib/typescript/handlers/gestures/GestureDetector/useViewRefHandler.js +32 -0
- package/lib/typescript/handlers/gestures/GestureDetector/utils.d.ts +0 -1
- package/lib/typescript/handlers/gestures/GestureDetector/utils.js +140 -0
- package/lib/typescript/handlers/gestures/eventReceiver.d.ts +0 -1
- package/lib/typescript/handlers/gestures/eventReceiver.js +105 -0
- package/lib/typescript/handlers/gestures/flingGesture.d.ts +0 -1
- package/lib/typescript/handlers/gestures/flingGesture.js +27 -0
- package/lib/typescript/handlers/gestures/forceTouchGesture.d.ts +9 -1
- package/lib/typescript/handlers/gestures/forceTouchGesture.d.ts.map +1 -1
- package/lib/typescript/handlers/gestures/forceTouchGesture.js +57 -0
- package/lib/typescript/handlers/gestures/gesture.d.ts +0 -1
- package/lib/typescript/handlers/gestures/gesture.js +303 -0
- package/lib/typescript/handlers/gestures/gestureComposition.d.ts +0 -1
- package/lib/typescript/handlers/gestures/gestureComposition.js +78 -0
- package/lib/typescript/handlers/gestures/gestureObjects.d.ts +3 -2
- package/lib/typescript/handlers/gestures/gestureObjects.d.ts.map +1 -1
- package/lib/typescript/handlers/gestures/gestureObjects.js +125 -0
- package/lib/typescript/handlers/gestures/gestureStateManager.d.ts +0 -1
- package/lib/typescript/handlers/gestures/gestureStateManager.js +60 -0
- package/lib/typescript/handlers/gestures/gestureStateManager.web.d.ts +0 -1
- package/lib/typescript/handlers/gestures/gestureStateManager.web.js +19 -0
- package/lib/typescript/handlers/gestures/hoverGesture.d.ts +0 -1
- package/lib/typescript/handlers/gestures/hoverGesture.js +45 -0
- package/lib/typescript/handlers/gestures/longPressGesture.d.ts +0 -1
- package/lib/typescript/handlers/gestures/longPressGesture.js +35 -0
- package/lib/typescript/handlers/gestures/manualGesture.d.ts +0 -1
- package/lib/typescript/handlers/gestures/manualGesture.js +16 -0
- package/lib/typescript/handlers/gestures/nativeGesture.d.ts +0 -1
- package/lib/typescript/handlers/gestures/nativeGesture.js +24 -0
- package/lib/typescript/handlers/gestures/panGesture.d.ts +0 -1
- package/lib/typescript/handlers/gestures/panGesture.js +181 -0
- package/lib/typescript/handlers/gestures/pinchGesture.d.ts +0 -1
- package/lib/typescript/handlers/gestures/pinchGesture.js +27 -0
- package/lib/typescript/handlers/gestures/reanimatedWrapper.d.ts +0 -1
- package/lib/typescript/handlers/gestures/reanimatedWrapper.js +23 -0
- package/lib/typescript/handlers/gestures/rotationGesture.d.ts +0 -1
- package/lib/typescript/handlers/gestures/rotationGesture.js +27 -0
- package/lib/typescript/handlers/gestures/tapGesture.d.ts +0 -1
- package/lib/typescript/handlers/gestures/tapGesture.js +72 -0
- package/lib/typescript/handlers/getNextHandlerTag.d.ts +0 -1
- package/lib/typescript/handlers/getNextHandlerTag.js +4 -0
- package/lib/typescript/handlers/handlersRegistry.d.ts +0 -1
- package/lib/typescript/handlers/handlersRegistry.js +36 -0
- package/lib/typescript/handlers/utils.d.ts +0 -1
- package/lib/typescript/handlers/utils.js +58 -0
- package/lib/typescript/index.d.ts +0 -1
- package/lib/typescript/index.js +28 -0
- package/lib/typescript/init.d.ts +0 -1
- package/lib/typescript/init.js +15 -0
- package/lib/typescript/jestUtils/index.d.ts +0 -1
- package/lib/typescript/jestUtils/index.js +1 -0
- package/lib/typescript/jestUtils/jestUtils.d.ts +0 -1
- package/lib/typescript/jestUtils/jestUtils.js +290 -0
- package/lib/typescript/mocks.d.ts +0 -1
- package/lib/typescript/mocks.js +59 -0
- package/lib/typescript/mountRegistry.d.ts +0 -1
- package/lib/typescript/mountRegistry.js +29 -0
- package/lib/typescript/specs/NativeRNGestureHandlerModule.d.ts +0 -1
- package/lib/typescript/specs/NativeRNGestureHandlerModule.js +2 -0
- package/lib/typescript/specs/RNGestureHandlerButtonNativeComponent.d.ts +0 -1
- package/lib/typescript/specs/RNGestureHandlerButtonNativeComponent.js +2 -0
- package/lib/typescript/specs/RNGestureHandlerRootViewNativeComponent.d.ts +0 -1
- package/lib/typescript/specs/RNGestureHandlerRootViewNativeComponent.js +2 -0
- package/lib/typescript/typeUtils.d.ts +0 -1
- package/lib/typescript/typeUtils.js +1 -0
- package/lib/typescript/utils.d.ts +0 -1
- package/lib/typescript/utils.js +80 -0
- package/lib/typescript/web/Gestures.d.ts +0 -1
- package/lib/typescript/web/Gestures.js +38 -0
- package/lib/typescript/web/constants.d.ts +0 -1
- package/lib/typescript/web/constants.js +2 -0
- package/lib/typescript/web/detectors/RotationGestureDetector.d.ts +0 -1
- package/lib/typescript/web/detectors/RotationGestureDetector.d.ts.map +1 -1
- package/lib/typescript/web/detectors/RotationGestureDetector.js +122 -0
- package/lib/typescript/web/detectors/ScaleGestureDetector.d.ts +0 -1
- package/lib/typescript/web/detectors/ScaleGestureDetector.js +117 -0
- package/lib/typescript/web/handlers/FlingGestureHandler.d.ts +0 -1
- package/lib/typescript/web/handlers/FlingGestureHandler.d.ts.map +1 -1
- package/lib/typescript/web/handlers/FlingGestureHandler.js +133 -0
- package/lib/typescript/web/handlers/GestureHandler.d.ts +0 -1
- package/lib/typescript/web/handlers/GestureHandler.d.ts.map +1 -1
- package/lib/typescript/web/handlers/GestureHandler.js +656 -0
- package/lib/typescript/web/handlers/HoverGestureHandler.d.ts +0 -1
- package/lib/typescript/web/handlers/HoverGestureHandler.js +37 -0
- package/lib/typescript/web/handlers/IGestureHandler.d.ts +0 -1
- package/lib/typescript/web/handlers/IGestureHandler.js +1 -0
- package/lib/typescript/web/handlers/LongPressGestureHandler.d.ts +0 -1
- package/lib/typescript/web/handlers/LongPressGestureHandler.js +136 -0
- package/lib/typescript/web/handlers/ManualGestureHandler.d.ts +0 -1
- package/lib/typescript/web/handlers/ManualGestureHandler.js +29 -0
- package/lib/typescript/web/handlers/NativeViewGestureHandler.d.ts +0 -1
- package/lib/typescript/web/handlers/NativeViewGestureHandler.js +133 -0
- package/lib/typescript/web/handlers/PanGestureHandler.d.ts +2 -1
- package/lib/typescript/web/handlers/PanGestureHandler.d.ts.map +1 -1
- package/lib/typescript/web/handlers/PanGestureHandler.js +420 -0
- package/lib/typescript/web/handlers/PinchGestureHandler.d.ts +0 -1
- package/lib/typescript/web/handlers/PinchGestureHandler.js +117 -0
- package/lib/typescript/web/handlers/RotationGestureHandler.d.ts +0 -1
- package/lib/typescript/web/handlers/RotationGestureHandler.js +122 -0
- package/lib/typescript/web/handlers/TapGestureHandler.d.ts +1 -1
- package/lib/typescript/web/handlers/TapGestureHandler.d.ts.map +1 -1
- package/lib/typescript/web/handlers/TapGestureHandler.js +202 -0
- package/lib/typescript/web/interfaces.d.ts +0 -1
- package/lib/typescript/web/interfaces.js +25 -0
- package/lib/typescript/web/tools/CircularBuffer.d.ts +0 -1
- package/lib/typescript/web/tools/CircularBuffer.js +37 -0
- package/lib/typescript/web/tools/EventManager.d.ts +0 -1
- package/lib/typescript/web/tools/EventManager.js +85 -0
- package/lib/typescript/web/tools/GestureHandlerDelegate.d.ts +0 -1
- package/lib/typescript/web/tools/GestureHandlerDelegate.js +1 -0
- package/lib/typescript/web/tools/GestureHandlerOrchestrator.d.ts +0 -1
- package/lib/typescript/web/tools/GestureHandlerOrchestrator.d.ts.map +1 -1
- package/lib/typescript/web/tools/GestureHandlerOrchestrator.js +273 -0
- package/lib/typescript/web/tools/GestureHandlerWebDelegate.d.ts +0 -1
- package/lib/typescript/web/tools/GestureHandlerWebDelegate.js +169 -0
- package/lib/typescript/web/tools/InteractionManager.d.ts +0 -1
- package/lib/typescript/web/tools/InteractionManager.js +91 -0
- package/lib/typescript/web/tools/KeyboardEventManager.d.ts +0 -1
- package/lib/typescript/web/tools/KeyboardEventManager.js +73 -0
- package/lib/typescript/web/tools/LeastSquareSolver.d.ts +0 -1
- package/lib/typescript/web/tools/LeastSquareSolver.js +147 -0
- package/lib/typescript/web/tools/NodeManager.d.ts +0 -1
- package/lib/typescript/web/tools/NodeManager.js +28 -0
- package/lib/typescript/web/tools/PointerEventManager.d.ts +0 -1
- package/lib/typescript/web/tools/PointerEventManager.js +179 -0
- package/lib/typescript/web/tools/PointerTracker.d.ts +3 -4
- package/lib/typescript/web/tools/PointerTracker.d.ts.map +1 -1
- package/lib/typescript/web/tools/PointerTracker.js +161 -0
- package/lib/typescript/web/tools/Vector.d.ts +1 -2
- package/lib/typescript/web/tools/Vector.js +43 -0
- package/lib/typescript/web/tools/VelocityTracker.d.ts +0 -1
- package/lib/typescript/web/tools/VelocityTracker.js +76 -0
- package/lib/typescript/web/tools/WheelEventManager.d.ts +0 -1
- package/lib/typescript/web/tools/WheelEventManager.js +40 -0
- package/lib/typescript/web/utils.d.ts +0 -1
- package/lib/typescript/web/utils.js +233 -0
- package/lib/typescript/web_hammer/DiscreteGestureHandler.d.ts +0 -1
- package/lib/typescript/web_hammer/DiscreteGestureHandler.js +48 -0
- package/lib/typescript/web_hammer/DraggingGestureHandler.d.ts +0 -1
- package/lib/typescript/web_hammer/DraggingGestureHandler.js +25 -0
- package/lib/typescript/web_hammer/Errors.d.ts +0 -1
- package/lib/typescript/web_hammer/Errors.js +5 -0
- package/lib/typescript/web_hammer/FlingGestureHandler.d.ts +0 -1
- package/lib/typescript/web_hammer/FlingGestureHandler.js +119 -0
- package/lib/typescript/web_hammer/GestureHandler.d.ts +0 -1
- package/lib/typescript/web_hammer/GestureHandler.js +469 -0
- package/lib/typescript/web_hammer/IndiscreteGestureHandler.d.ts +0 -1
- package/lib/typescript/web_hammer/IndiscreteGestureHandler.js +26 -0
- package/lib/typescript/web_hammer/LongPressGestureHandler.d.ts +0 -1
- package/lib/typescript/web_hammer/LongPressGestureHandler.js +46 -0
- package/lib/typescript/web_hammer/NativeViewGestureHandler.d.ts +0 -1
- package/lib/typescript/web_hammer/NativeViewGestureHandler.js +40 -0
- package/lib/typescript/web_hammer/NodeManager.d.ts +0 -1
- package/lib/typescript/web_hammer/NodeManager.js +28 -0
- package/lib/typescript/web_hammer/PanGestureHandler.d.ts +0 -1
- package/lib/typescript/web_hammer/PanGestureHandler.js +151 -0
- package/lib/typescript/web_hammer/PinchGestureHandler.d.ts +0 -1
- package/lib/typescript/web_hammer/PinchGestureHandler.js +19 -0
- package/lib/typescript/web_hammer/PressGestureHandler.d.ts +0 -1
- package/lib/typescript/web_hammer/PressGestureHandler.js +133 -0
- package/lib/typescript/web_hammer/RotationGestureHandler.d.ts +0 -1
- package/lib/typescript/web_hammer/RotationGestureHandler.js +20 -0
- package/lib/typescript/web_hammer/TapGestureHandler.d.ts +0 -1
- package/lib/typescript/web_hammer/TapGestureHandler.js +142 -0
- package/lib/typescript/web_hammer/constants.d.ts +0 -1
- package/lib/typescript/web_hammer/constants.js +42 -0
- package/lib/typescript/web_hammer/utils.d.ts +0 -1
- package/lib/typescript/web_hammer/utils.js +15 -0
- package/package.json +4 -2
- package/src/components/Pressable/Pressable.tsx +357 -445
- package/src/components/Pressable/PressableProps.tsx +15 -0
- package/src/components/Pressable/StateMachine.tsx +49 -0
- package/src/components/Pressable/stateDefinitions.ts +125 -0
- package/src/components/Pressable/utils.ts +11 -7
- package/src/handlers/GestureHandlerEventPayload.ts +3 -0
- package/src/handlers/gestureHandlerTypesCompat.ts +9 -0
- package/src/handlers/gestures/forceTouchGesture.ts +9 -0
- package/src/handlers/gestures/gestureObjects.ts +3 -1
- package/src/web/detectors/RotationGestureDetector.ts +4 -0
- package/src/web/handlers/FlingGestureHandler.ts +4 -0
- package/src/web/handlers/GestureHandler.ts +9 -3
- package/src/web/handlers/PanGestureHandler.ts +25 -36
- package/src/web/handlers/TapGestureHandler.ts +14 -19
- package/src/web/tools/GestureHandlerOrchestrator.ts +1 -0
- package/src/web/tools/PointerEventManager.ts +1 -1
- package/src/web/tools/PointerTracker.ts +17 -15
- package/src/web/tools/Vector.ts +1 -1
@@ -0,0 +1,202 @@
|
|
1
|
+
import { State } from '../../State';
|
2
|
+
import { EventTypes } from '../interfaces';
|
3
|
+
import GestureHandler from './GestureHandler';
|
4
|
+
const DEFAULT_MAX_DURATION_MS = 500;
|
5
|
+
const DEFAULT_MAX_DELAY_MS = 500;
|
6
|
+
const DEFAULT_NUMBER_OF_TAPS = 1;
|
7
|
+
const DEFAULT_MIN_NUMBER_OF_POINTERS = 1;
|
8
|
+
export default class TapGestureHandler extends GestureHandler {
|
9
|
+
maxDeltaX = Number.MIN_SAFE_INTEGER;
|
10
|
+
maxDeltaY = Number.MIN_SAFE_INTEGER;
|
11
|
+
maxDistSq = Number.MIN_SAFE_INTEGER;
|
12
|
+
maxDurationMs = DEFAULT_MAX_DURATION_MS;
|
13
|
+
maxDelayMs = DEFAULT_MAX_DELAY_MS;
|
14
|
+
numberOfTaps = DEFAULT_NUMBER_OF_TAPS;
|
15
|
+
minNumberOfPointers = DEFAULT_MIN_NUMBER_OF_POINTERS;
|
16
|
+
currentMaxNumberOfPointers = 1;
|
17
|
+
startX = 0;
|
18
|
+
startY = 0;
|
19
|
+
offsetX = 0;
|
20
|
+
offsetY = 0;
|
21
|
+
lastX = 0;
|
22
|
+
lastY = 0;
|
23
|
+
waitTimeout;
|
24
|
+
delayTimeout;
|
25
|
+
tapsSoFar = 0;
|
26
|
+
updateGestureConfig({ enabled = true, ...props }) {
|
27
|
+
super.updateGestureConfig({ enabled: enabled, ...props });
|
28
|
+
if (this.config.numberOfTaps !== undefined) {
|
29
|
+
this.numberOfTaps = this.config.numberOfTaps;
|
30
|
+
}
|
31
|
+
if (this.config.maxDurationMs !== undefined) {
|
32
|
+
this.maxDurationMs = this.config.maxDurationMs;
|
33
|
+
}
|
34
|
+
if (this.config.maxDelayMs !== undefined) {
|
35
|
+
this.maxDelayMs = this.config.maxDelayMs;
|
36
|
+
}
|
37
|
+
if (this.config.maxDeltaX !== undefined) {
|
38
|
+
this.maxDeltaX = this.config.maxDeltaX;
|
39
|
+
}
|
40
|
+
if (this.config.maxDeltaY !== undefined) {
|
41
|
+
this.maxDeltaY = this.config.maxDeltaY;
|
42
|
+
}
|
43
|
+
if (this.config.maxDist !== undefined) {
|
44
|
+
this.maxDistSq = this.config.maxDist * this.config.maxDist;
|
45
|
+
}
|
46
|
+
if (this.config.minPointers !== undefined) {
|
47
|
+
this.minNumberOfPointers = this.config.minPointers;
|
48
|
+
}
|
49
|
+
}
|
50
|
+
resetConfig() {
|
51
|
+
super.resetConfig();
|
52
|
+
this.maxDeltaX = Number.MIN_SAFE_INTEGER;
|
53
|
+
this.maxDeltaY = Number.MIN_SAFE_INTEGER;
|
54
|
+
this.maxDistSq = Number.MIN_SAFE_INTEGER;
|
55
|
+
this.maxDurationMs = DEFAULT_MAX_DURATION_MS;
|
56
|
+
this.maxDelayMs = DEFAULT_MAX_DELAY_MS;
|
57
|
+
this.numberOfTaps = DEFAULT_NUMBER_OF_TAPS;
|
58
|
+
this.minNumberOfPointers = DEFAULT_MIN_NUMBER_OF_POINTERS;
|
59
|
+
}
|
60
|
+
clearTimeouts() {
|
61
|
+
clearTimeout(this.waitTimeout);
|
62
|
+
clearTimeout(this.delayTimeout);
|
63
|
+
}
|
64
|
+
startTap() {
|
65
|
+
this.clearTimeouts();
|
66
|
+
this.waitTimeout = setTimeout(() => this.fail(), this.maxDurationMs);
|
67
|
+
}
|
68
|
+
endTap() {
|
69
|
+
this.clearTimeouts();
|
70
|
+
if (++this.tapsSoFar === this.numberOfTaps &&
|
71
|
+
this.currentMaxNumberOfPointers >= this.minNumberOfPointers) {
|
72
|
+
this.activate();
|
73
|
+
}
|
74
|
+
else {
|
75
|
+
this.delayTimeout = setTimeout(() => this.fail(), this.maxDelayMs);
|
76
|
+
}
|
77
|
+
}
|
78
|
+
updateLastCoords() {
|
79
|
+
const { x, y } = this.tracker.getAbsoluteCoordsAverage();
|
80
|
+
this.lastX = x;
|
81
|
+
this.lastY = y;
|
82
|
+
}
|
83
|
+
// Handling Events
|
84
|
+
onPointerDown(event) {
|
85
|
+
if (!this.isButtonInConfig(event.button)) {
|
86
|
+
return;
|
87
|
+
}
|
88
|
+
this.tracker.addToTracker(event);
|
89
|
+
super.onPointerDown(event);
|
90
|
+
this.trySettingPosition(event);
|
91
|
+
this.startX = event.x;
|
92
|
+
this.startY = event.y;
|
93
|
+
this.lastX = event.x;
|
94
|
+
this.lastY = event.y;
|
95
|
+
this.updateState(event);
|
96
|
+
this.tryToSendTouchEvent(event);
|
97
|
+
}
|
98
|
+
onPointerAdd(event) {
|
99
|
+
super.onPointerAdd(event);
|
100
|
+
this.tracker.addToTracker(event);
|
101
|
+
this.trySettingPosition(event);
|
102
|
+
this.offsetX += this.lastX - this.startX;
|
103
|
+
this.offsetY += this.lastY - this.startY;
|
104
|
+
this.updateLastCoords();
|
105
|
+
this.startX = this.lastX;
|
106
|
+
this.startY = this.lastY;
|
107
|
+
this.updateState(event);
|
108
|
+
}
|
109
|
+
onPointerUp(event) {
|
110
|
+
super.onPointerUp(event);
|
111
|
+
this.updateLastCoords();
|
112
|
+
this.tracker.removeFromTracker(event.pointerId);
|
113
|
+
this.updateState(event);
|
114
|
+
}
|
115
|
+
onPointerRemove(event) {
|
116
|
+
super.onPointerRemove(event);
|
117
|
+
this.tracker.removeFromTracker(event.pointerId);
|
118
|
+
this.offsetX += this.lastX - this.startX;
|
119
|
+
this.offsetY += this.lastY = this.startY;
|
120
|
+
this.updateLastCoords();
|
121
|
+
this.startX = this.lastX;
|
122
|
+
this.startY = this.lastY;
|
123
|
+
this.updateState(event);
|
124
|
+
}
|
125
|
+
onPointerMove(event) {
|
126
|
+
this.trySettingPosition(event);
|
127
|
+
this.tracker.track(event);
|
128
|
+
this.updateLastCoords();
|
129
|
+
this.updateState(event);
|
130
|
+
super.onPointerMove(event);
|
131
|
+
}
|
132
|
+
onPointerOutOfBounds(event) {
|
133
|
+
this.trySettingPosition(event);
|
134
|
+
this.tracker.track(event);
|
135
|
+
this.updateLastCoords();
|
136
|
+
this.updateState(event);
|
137
|
+
super.onPointerOutOfBounds(event);
|
138
|
+
}
|
139
|
+
updateState(event) {
|
140
|
+
if (this.currentMaxNumberOfPointers < this.tracker.trackedPointersCount) {
|
141
|
+
this.currentMaxNumberOfPointers = this.tracker.trackedPointersCount;
|
142
|
+
}
|
143
|
+
if (this.shouldFail()) {
|
144
|
+
this.fail();
|
145
|
+
return;
|
146
|
+
}
|
147
|
+
switch (this.state) {
|
148
|
+
case State.UNDETERMINED:
|
149
|
+
if (event.eventType === EventTypes.DOWN) {
|
150
|
+
this.begin();
|
151
|
+
}
|
152
|
+
this.startTap();
|
153
|
+
break;
|
154
|
+
case State.BEGAN:
|
155
|
+
if (event.eventType === EventTypes.UP) {
|
156
|
+
this.endTap();
|
157
|
+
}
|
158
|
+
if (event.eventType === EventTypes.DOWN) {
|
159
|
+
this.startTap();
|
160
|
+
}
|
161
|
+
break;
|
162
|
+
default:
|
163
|
+
break;
|
164
|
+
}
|
165
|
+
}
|
166
|
+
trySettingPosition(event) {
|
167
|
+
if (this.state !== State.UNDETERMINED) {
|
168
|
+
return;
|
169
|
+
}
|
170
|
+
this.offsetX = 0;
|
171
|
+
this.offsetY = 0;
|
172
|
+
this.startX = event.x;
|
173
|
+
this.startY = event.y;
|
174
|
+
}
|
175
|
+
shouldFail() {
|
176
|
+
const dx = this.lastX - this.startX + this.offsetX;
|
177
|
+
if (this.maxDeltaX !== Number.MIN_SAFE_INTEGER &&
|
178
|
+
Math.abs(dx) > this.maxDeltaX) {
|
179
|
+
return true;
|
180
|
+
}
|
181
|
+
const dy = this.lastY - this.startY + this.offsetY;
|
182
|
+
if (this.maxDeltaY !== Number.MIN_SAFE_INTEGER &&
|
183
|
+
Math.abs(dy) > this.maxDeltaY) {
|
184
|
+
return true;
|
185
|
+
}
|
186
|
+
const distSq = dy * dy + dx * dx;
|
187
|
+
return (this.maxDistSq !== Number.MIN_SAFE_INTEGER && distSq > this.maxDistSq);
|
188
|
+
}
|
189
|
+
activate() {
|
190
|
+
super.activate();
|
191
|
+
this.end();
|
192
|
+
}
|
193
|
+
onCancel() {
|
194
|
+
this.resetProgress();
|
195
|
+
this.clearTimeouts();
|
196
|
+
}
|
197
|
+
resetProgress() {
|
198
|
+
this.clearTimeouts();
|
199
|
+
this.tapsSoFar = 0;
|
200
|
+
this.currentMaxNumberOfPointers = 0;
|
201
|
+
}
|
202
|
+
}
|
@@ -0,0 +1,25 @@
|
|
1
|
+
export var EventTypes;
|
2
|
+
(function (EventTypes) {
|
3
|
+
EventTypes[EventTypes["DOWN"] = 0] = "DOWN";
|
4
|
+
EventTypes[EventTypes["ADDITIONAL_POINTER_DOWN"] = 1] = "ADDITIONAL_POINTER_DOWN";
|
5
|
+
EventTypes[EventTypes["UP"] = 2] = "UP";
|
6
|
+
EventTypes[EventTypes["ADDITIONAL_POINTER_UP"] = 3] = "ADDITIONAL_POINTER_UP";
|
7
|
+
EventTypes[EventTypes["MOVE"] = 4] = "MOVE";
|
8
|
+
EventTypes[EventTypes["ENTER"] = 5] = "ENTER";
|
9
|
+
EventTypes[EventTypes["LEAVE"] = 6] = "LEAVE";
|
10
|
+
EventTypes[EventTypes["CANCEL"] = 7] = "CANCEL";
|
11
|
+
})(EventTypes || (EventTypes = {}));
|
12
|
+
export var TouchEventType;
|
13
|
+
(function (TouchEventType) {
|
14
|
+
TouchEventType[TouchEventType["UNDETERMINED"] = 0] = "UNDETERMINED";
|
15
|
+
TouchEventType[TouchEventType["DOWN"] = 1] = "DOWN";
|
16
|
+
TouchEventType[TouchEventType["MOVE"] = 2] = "MOVE";
|
17
|
+
TouchEventType[TouchEventType["UP"] = 3] = "UP";
|
18
|
+
TouchEventType[TouchEventType["CANCELLED"] = 4] = "CANCELLED";
|
19
|
+
})(TouchEventType || (TouchEventType = {}));
|
20
|
+
export var WheelDevice;
|
21
|
+
(function (WheelDevice) {
|
22
|
+
WheelDevice[WheelDevice["UNDETERMINED"] = 0] = "UNDETERMINED";
|
23
|
+
WheelDevice[WheelDevice["MOUSE"] = 1] = "MOUSE";
|
24
|
+
WheelDevice[WheelDevice["TOUCHPAD"] = 2] = "TOUCHPAD";
|
25
|
+
})(WheelDevice || (WheelDevice = {}));
|
@@ -0,0 +1,37 @@
|
|
1
|
+
export default class CircularBuffer {
|
2
|
+
capacity;
|
3
|
+
buffer;
|
4
|
+
index;
|
5
|
+
_size;
|
6
|
+
constructor(size) {
|
7
|
+
this.capacity = size;
|
8
|
+
this.buffer = new Array(size);
|
9
|
+
this.index = 0;
|
10
|
+
this._size = 0;
|
11
|
+
}
|
12
|
+
push(element) {
|
13
|
+
this.buffer[this.index] = element;
|
14
|
+
this.index = (this.index + 1) % this.capacity;
|
15
|
+
this._size = Math.min(this.size + 1, this.capacity);
|
16
|
+
}
|
17
|
+
get(at) {
|
18
|
+
if (this._size === this.capacity) {
|
19
|
+
let index = (this.index + at) % this.capacity;
|
20
|
+
if (index < 0) {
|
21
|
+
index += this.capacity;
|
22
|
+
}
|
23
|
+
return this.buffer[index];
|
24
|
+
}
|
25
|
+
else {
|
26
|
+
return this.buffer[at];
|
27
|
+
}
|
28
|
+
}
|
29
|
+
clear() {
|
30
|
+
this.buffer = new Array(this.capacity);
|
31
|
+
this.index = 0;
|
32
|
+
this._size = 0;
|
33
|
+
}
|
34
|
+
get size() {
|
35
|
+
return this._size;
|
36
|
+
}
|
37
|
+
}
|
@@ -0,0 +1,85 @@
|
|
1
|
+
export default class EventManager {
|
2
|
+
view;
|
3
|
+
pointersInBounds = [];
|
4
|
+
activePointersCounter;
|
5
|
+
constructor(view) {
|
6
|
+
this.view = view;
|
7
|
+
this.activePointersCounter = 0;
|
8
|
+
}
|
9
|
+
onPointerDown(_event) { }
|
10
|
+
onPointerAdd(_event) { }
|
11
|
+
onPointerUp(_event) { }
|
12
|
+
onPointerRemove(_event) { }
|
13
|
+
onPointerMove(_event) { }
|
14
|
+
onPointerLeave(_event) { } // Called only when pointer is pressed (or touching)
|
15
|
+
onPointerEnter(_event) { } // Called only when pointer is pressed (or touching)
|
16
|
+
onPointerCancel(_event) {
|
17
|
+
// When pointer cancel is triggered and there are more pointers on the view, only one pointer is cancelled
|
18
|
+
// Because we want all pointers to be cancelled by that event, we are doing it manually by reseting handler and changing activePointersCounter to 0
|
19
|
+
// Events that correspond to removing the pointer (pointerup, touchend) have condition, that they don't perform any action when activePointersCounter
|
20
|
+
// is equal to 0. This prevents counter from going to negative values, when pointers are removed from view after one of them has been cancelled
|
21
|
+
}
|
22
|
+
onPointerOutOfBounds(_event) { }
|
23
|
+
onPointerMoveOver(_event) { }
|
24
|
+
onPointerMoveOut(_event) { }
|
25
|
+
onWheel(_event) { }
|
26
|
+
setOnPointerDown(callback) {
|
27
|
+
this.onPointerDown = callback;
|
28
|
+
}
|
29
|
+
setOnPointerAdd(callback) {
|
30
|
+
this.onPointerAdd = callback;
|
31
|
+
}
|
32
|
+
setOnPointerUp(callback) {
|
33
|
+
this.onPointerUp = callback;
|
34
|
+
}
|
35
|
+
setOnPointerRemove(callback) {
|
36
|
+
this.onPointerRemove = callback;
|
37
|
+
}
|
38
|
+
setOnPointerMove(callback) {
|
39
|
+
this.onPointerMove = callback;
|
40
|
+
}
|
41
|
+
setOnPointerLeave(callback) {
|
42
|
+
this.onPointerLeave = callback;
|
43
|
+
}
|
44
|
+
setOnPointerEnter(callback) {
|
45
|
+
this.onPointerEnter = callback;
|
46
|
+
}
|
47
|
+
setOnPointerCancel(callback) {
|
48
|
+
this.onPointerCancel = callback;
|
49
|
+
}
|
50
|
+
setOnPointerOutOfBounds(callback) {
|
51
|
+
this.onPointerOutOfBounds = callback;
|
52
|
+
}
|
53
|
+
setOnPointerMoveOver(callback) {
|
54
|
+
this.onPointerMoveOver = callback;
|
55
|
+
}
|
56
|
+
setOnPointerMoveOut(callback) {
|
57
|
+
this.onPointerMoveOut = callback;
|
58
|
+
}
|
59
|
+
setOnWheel(callback) {
|
60
|
+
this.onWheel = callback;
|
61
|
+
}
|
62
|
+
markAsInBounds(pointerId) {
|
63
|
+
if (this.pointersInBounds.indexOf(pointerId) >= 0) {
|
64
|
+
return;
|
65
|
+
}
|
66
|
+
this.pointersInBounds.push(pointerId);
|
67
|
+
}
|
68
|
+
markAsOutOfBounds(pointerId) {
|
69
|
+
const index = this.pointersInBounds.indexOf(pointerId);
|
70
|
+
if (index < 0) {
|
71
|
+
return;
|
72
|
+
}
|
73
|
+
this.pointersInBounds.splice(index, 1);
|
74
|
+
}
|
75
|
+
resetManager() {
|
76
|
+
// Reseting activePointersCounter is necessary to make gestures such as pinch work properly
|
77
|
+
// There are gestures that end when there is still one active pointer (like pinch/rotation)
|
78
|
+
// When these gestures end, they are reset, but they still receive events from pointer that is active
|
79
|
+
// This causes trouble, since only onPointerDown registers gesture in orchestrator, and while gestures receive
|
80
|
+
// Events from active pointer after they finished, next pointerdown event will be registered as additional pointer, not the first one
|
81
|
+
// This casues trouble like gestures getting stuck in END state, even though they should have gone to UNDETERMINED
|
82
|
+
this.activePointersCounter = 0;
|
83
|
+
this.pointersInBounds = [];
|
84
|
+
}
|
85
|
+
}
|
@@ -0,0 +1 @@
|
|
1
|
+
export {};
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"GestureHandlerOrchestrator.d.ts","sourceRoot":"","sources":["../../../../src/web/tools/GestureHandlerOrchestrator.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAEpC,OAAO,KAAK,eAAe,MAAM,6BAA6B,CAAC;AAG/D,MAAM,CAAC,OAAO,OAAO,0BAA0B;IAC7C,OAAO,CAAC,MAAM,CAAC,SAAS,CAA6B;IAErD,OAAO,CAAC,eAAe,CAAyB;IAChD,OAAO,CAAC,gBAAgB,CAAyB;IACjD,OAAO,CAAC,oBAAoB,CAA0B;IAEtD,OAAO,CAAC,uBAAuB,CAAK;IACpC,OAAO,CAAC,eAAe,CAAK;IAI5B,OAAO;IAEP,OAAO,CAAC,+BAA+B;IAMvC,OAAO,CAAC,YAAY;IAOb,6BAA6B,CAAC,OAAO,EAAE,eAAe,GAAG,IAAI;IAcpE,OAAO,CAAC,uBAAuB;IAiB/B,OAAO,CAAC,wBAAwB;IAWhC,OAAO,CAAC,kCAAkC;IAa1C,OAAO,CAAC,WAAW;IAgCnB,OAAO,CAAC,cAAc;IAQtB,OAAO,CAAC,uBAAuB;IAoBxB,oBAAoB,CACzB,OAAO,EAAE,eAAe,EACxB,QAAQ,EAAE,KAAK,EACf,QAAQ,EAAE,KAAK,EACf,cAAc,CAAC,EAAE,OAAO,GACvB,IAAI;IA8DP,OAAO,CAAC,UAAU;IAuClB,OAAO,CAAC,kBAAkB;IAYnB,yBAAyB,CAAC,OAAO,EAAE,eAAe,GAAG,IAAI;IAYhE,OAAO,CAAC,yBAAyB;IAWjC,OAAO,CAAC,oBAAoB;IAW5B,OAAO,CAAC,0BAA0B;IAyBlC,OAAO,CAAC,YAAY;
|
1
|
+
{"version":3,"file":"GestureHandlerOrchestrator.d.ts","sourceRoot":"","sources":["../../../../src/web/tools/GestureHandlerOrchestrator.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAEpC,OAAO,KAAK,eAAe,MAAM,6BAA6B,CAAC;AAG/D,MAAM,CAAC,OAAO,OAAO,0BAA0B;IAC7C,OAAO,CAAC,MAAM,CAAC,SAAS,CAA6B;IAErD,OAAO,CAAC,eAAe,CAAyB;IAChD,OAAO,CAAC,gBAAgB,CAAyB;IACjD,OAAO,CAAC,oBAAoB,CAA0B;IAEtD,OAAO,CAAC,uBAAuB,CAAK;IACpC,OAAO,CAAC,eAAe,CAAK;IAI5B,OAAO;IAEP,OAAO,CAAC,+BAA+B;IAMvC,OAAO,CAAC,YAAY;IAOb,6BAA6B,CAAC,OAAO,EAAE,eAAe,GAAG,IAAI;IAcpE,OAAO,CAAC,uBAAuB;IAiB/B,OAAO,CAAC,wBAAwB;IAWhC,OAAO,CAAC,kCAAkC;IAa1C,OAAO,CAAC,WAAW;IAgCnB,OAAO,CAAC,cAAc;IAQtB,OAAO,CAAC,uBAAuB;IAoBxB,oBAAoB,CACzB,OAAO,EAAE,eAAe,EACxB,QAAQ,EAAE,KAAK,EACf,QAAQ,EAAE,KAAK,EACf,cAAc,CAAC,EAAE,OAAO,GACvB,IAAI;IA8DP,OAAO,CAAC,UAAU;IAuClB,OAAO,CAAC,kBAAkB;IAYnB,yBAAyB,CAAC,OAAO,EAAE,eAAe,GAAG,IAAI;IAYhE,OAAO,CAAC,yBAAyB;IAWjC,OAAO,CAAC,oBAAoB;IAW5B,OAAO,CAAC,0BAA0B;IAyBlC,OAAO,CAAC,YAAY;IAuBpB,OAAO,CAAC,UAAU;IAYX,yBAAyB,CAAC,cAAc,EAAE,eAAe,GAAG,IAAI;IAwBvE,WAAkB,QAAQ,IAAI,0BAA0B,CAMvD;CACF"}
|
@@ -0,0 +1,273 @@
|
|
1
|
+
import { PointerType } from '../../PointerType';
|
2
|
+
import { State } from '../../State';
|
3
|
+
import PointerTracker from './PointerTracker';
|
4
|
+
export default class GestureHandlerOrchestrator {
|
5
|
+
static _instance;
|
6
|
+
gestureHandlers = [];
|
7
|
+
awaitingHandlers = [];
|
8
|
+
awaitingHandlersTags = new Set();
|
9
|
+
handlingChangeSemaphore = 0;
|
10
|
+
activationIndex = 0;
|
11
|
+
// Private beacuse of Singleton
|
12
|
+
// eslint-disable-next-line no-useless-constructor, @typescript-eslint/no-empty-function
|
13
|
+
constructor() { }
|
14
|
+
scheduleFinishedHandlersCleanup() {
|
15
|
+
if (this.handlingChangeSemaphore === 0) {
|
16
|
+
this.cleanupFinishedHandlers();
|
17
|
+
}
|
18
|
+
}
|
19
|
+
cleanHandler(handler) {
|
20
|
+
handler.reset();
|
21
|
+
handler.active = false;
|
22
|
+
handler.awaiting = false;
|
23
|
+
handler.activationIndex = Number.MAX_VALUE;
|
24
|
+
}
|
25
|
+
removeHandlerFromOrchestrator(handler) {
|
26
|
+
const indexInGestureHandlers = this.gestureHandlers.indexOf(handler);
|
27
|
+
const indexInAwaitingHandlers = this.awaitingHandlers.indexOf(handler);
|
28
|
+
if (indexInGestureHandlers >= 0) {
|
29
|
+
this.gestureHandlers.splice(indexInGestureHandlers, 1);
|
30
|
+
}
|
31
|
+
if (indexInAwaitingHandlers >= 0) {
|
32
|
+
this.awaitingHandlers.splice(indexInAwaitingHandlers, 1);
|
33
|
+
this.awaitingHandlersTags.delete(handler.handlerTag);
|
34
|
+
}
|
35
|
+
}
|
36
|
+
cleanupFinishedHandlers() {
|
37
|
+
const handlersToRemove = new Set();
|
38
|
+
for (let i = this.gestureHandlers.length - 1; i >= 0; --i) {
|
39
|
+
const handler = this.gestureHandlers[i];
|
40
|
+
if (this.isFinished(handler.state) && !handler.awaiting) {
|
41
|
+
this.cleanHandler(handler);
|
42
|
+
handlersToRemove.add(handler);
|
43
|
+
}
|
44
|
+
}
|
45
|
+
this.gestureHandlers = this.gestureHandlers.filter((handler) => !handlersToRemove.has(handler));
|
46
|
+
}
|
47
|
+
hasOtherHandlerToWaitFor(handler) {
|
48
|
+
const hasToWaitFor = (otherHandler) => {
|
49
|
+
return (!this.isFinished(otherHandler.state) &&
|
50
|
+
this.shouldHandlerWaitForOther(handler, otherHandler));
|
51
|
+
};
|
52
|
+
return this.gestureHandlers.some(hasToWaitFor);
|
53
|
+
}
|
54
|
+
shouldBeCancelledByFinishedHandler(handler) {
|
55
|
+
const shouldBeCancelled = (otherHandler) => {
|
56
|
+
return (this.shouldHandlerWaitForOther(handler, otherHandler) &&
|
57
|
+
otherHandler.state === State.END);
|
58
|
+
};
|
59
|
+
return this.gestureHandlers.some(shouldBeCancelled);
|
60
|
+
}
|
61
|
+
tryActivate(handler) {
|
62
|
+
if (this.shouldBeCancelledByFinishedHandler(handler)) {
|
63
|
+
handler.cancel();
|
64
|
+
return;
|
65
|
+
}
|
66
|
+
if (this.hasOtherHandlerToWaitFor(handler)) {
|
67
|
+
this.addAwaitingHandler(handler);
|
68
|
+
return;
|
69
|
+
}
|
70
|
+
const handlerState = handler.state;
|
71
|
+
if (handlerState === State.CANCELLED || handlerState === State.FAILED) {
|
72
|
+
return;
|
73
|
+
}
|
74
|
+
if (this.shouldActivate(handler)) {
|
75
|
+
this.makeActive(handler);
|
76
|
+
return;
|
77
|
+
}
|
78
|
+
if (handlerState === State.ACTIVE) {
|
79
|
+
handler.fail();
|
80
|
+
return;
|
81
|
+
}
|
82
|
+
if (handlerState === State.BEGAN) {
|
83
|
+
handler.cancel();
|
84
|
+
}
|
85
|
+
}
|
86
|
+
shouldActivate(handler) {
|
87
|
+
const shouldBeCancelledBy = (otherHandler) => {
|
88
|
+
return this.shouldHandlerBeCancelledBy(handler, otherHandler);
|
89
|
+
};
|
90
|
+
return !this.gestureHandlers.some(shouldBeCancelledBy);
|
91
|
+
}
|
92
|
+
cleanupAwaitingHandlers(handler) {
|
93
|
+
const shouldWait = (otherHandler) => {
|
94
|
+
return (!otherHandler.awaiting &&
|
95
|
+
this.shouldHandlerWaitForOther(otherHandler, handler));
|
96
|
+
};
|
97
|
+
for (const otherHandler of this.awaitingHandlers) {
|
98
|
+
if (shouldWait(otherHandler)) {
|
99
|
+
this.cleanHandler(otherHandler);
|
100
|
+
this.awaitingHandlersTags.delete(otherHandler.handlerTag);
|
101
|
+
}
|
102
|
+
}
|
103
|
+
this.awaitingHandlers = this.awaitingHandlers.filter((otherHandler) => this.awaitingHandlersTags.has(otherHandler.handlerTag));
|
104
|
+
}
|
105
|
+
onHandlerStateChange(handler, newState, oldState, sendIfDisabled) {
|
106
|
+
if (!handler.enabled && !sendIfDisabled) {
|
107
|
+
return;
|
108
|
+
}
|
109
|
+
this.handlingChangeSemaphore += 1;
|
110
|
+
if (this.isFinished(newState)) {
|
111
|
+
for (const otherHandler of this.awaitingHandlers) {
|
112
|
+
if (!this.shouldHandlerWaitForOther(otherHandler, handler) ||
|
113
|
+
!this.awaitingHandlersTags.has(otherHandler.handlerTag)) {
|
114
|
+
continue;
|
115
|
+
}
|
116
|
+
if (newState !== State.END) {
|
117
|
+
this.tryActivate(otherHandler);
|
118
|
+
continue;
|
119
|
+
}
|
120
|
+
otherHandler.cancel();
|
121
|
+
if (otherHandler.state === State.END) {
|
122
|
+
// Handle edge case, where discrete gestures end immediately after activation thus
|
123
|
+
// their state is set to END and when the gesture they are waiting for activates they
|
124
|
+
// should be cancelled, however `cancel` was never sent as gestures were already in the END state.
|
125
|
+
// Send synthetic BEGAN -> CANCELLED to properly handle JS logic
|
126
|
+
otherHandler.sendEvent(State.CANCELLED, State.BEGAN);
|
127
|
+
}
|
128
|
+
otherHandler.awaiting = false;
|
129
|
+
}
|
130
|
+
}
|
131
|
+
if (newState === State.ACTIVE) {
|
132
|
+
this.tryActivate(handler);
|
133
|
+
}
|
134
|
+
else if (oldState === State.ACTIVE || oldState === State.END) {
|
135
|
+
if (handler.active) {
|
136
|
+
handler.sendEvent(newState, oldState);
|
137
|
+
}
|
138
|
+
else if (oldState === State.ACTIVE &&
|
139
|
+
(newState === State.CANCELLED || newState === State.FAILED)) {
|
140
|
+
handler.sendEvent(newState, State.BEGAN);
|
141
|
+
}
|
142
|
+
}
|
143
|
+
else if (oldState !== State.UNDETERMINED ||
|
144
|
+
newState !== State.CANCELLED) {
|
145
|
+
handler.sendEvent(newState, oldState);
|
146
|
+
}
|
147
|
+
this.handlingChangeSemaphore -= 1;
|
148
|
+
this.scheduleFinishedHandlersCleanup();
|
149
|
+
if (!this.awaitingHandlers.includes(handler)) {
|
150
|
+
this.cleanupAwaitingHandlers(handler);
|
151
|
+
}
|
152
|
+
}
|
153
|
+
makeActive(handler) {
|
154
|
+
const currentState = handler.state;
|
155
|
+
handler.active = true;
|
156
|
+
handler.shouldResetProgress = true;
|
157
|
+
handler.activationIndex = this.activationIndex++;
|
158
|
+
for (let i = this.gestureHandlers.length - 1; i >= 0; --i) {
|
159
|
+
if (this.shouldHandlerBeCancelledBy(this.gestureHandlers[i], handler)) {
|
160
|
+
this.gestureHandlers[i].cancel();
|
161
|
+
}
|
162
|
+
}
|
163
|
+
for (const otherHandler of this.awaitingHandlers) {
|
164
|
+
if (this.shouldHandlerBeCancelledBy(otherHandler, handler)) {
|
165
|
+
otherHandler.awaiting = false;
|
166
|
+
}
|
167
|
+
}
|
168
|
+
handler.sendEvent(State.ACTIVE, State.BEGAN);
|
169
|
+
if (currentState !== State.ACTIVE) {
|
170
|
+
handler.sendEvent(State.END, State.ACTIVE);
|
171
|
+
if (currentState !== State.END) {
|
172
|
+
handler.sendEvent(State.UNDETERMINED, State.END);
|
173
|
+
}
|
174
|
+
}
|
175
|
+
if (!handler.awaiting) {
|
176
|
+
return;
|
177
|
+
}
|
178
|
+
handler.awaiting = false;
|
179
|
+
this.awaitingHandlers = this.awaitingHandlers.filter((otherHandler) => otherHandler !== handler);
|
180
|
+
}
|
181
|
+
addAwaitingHandler(handler) {
|
182
|
+
if (this.awaitingHandlers.includes(handler)) {
|
183
|
+
return;
|
184
|
+
}
|
185
|
+
this.awaitingHandlers.push(handler);
|
186
|
+
this.awaitingHandlersTags.add(handler.handlerTag);
|
187
|
+
handler.awaiting = true;
|
188
|
+
handler.activationIndex = this.activationIndex++;
|
189
|
+
}
|
190
|
+
recordHandlerIfNotPresent(handler) {
|
191
|
+
if (this.gestureHandlers.includes(handler)) {
|
192
|
+
return;
|
193
|
+
}
|
194
|
+
this.gestureHandlers.push(handler);
|
195
|
+
handler.active = false;
|
196
|
+
handler.awaiting = false;
|
197
|
+
handler.activationIndex = Number.MAX_SAFE_INTEGER;
|
198
|
+
}
|
199
|
+
shouldHandlerWaitForOther(handler, otherHandler) {
|
200
|
+
return (handler !== otherHandler &&
|
201
|
+
(handler.shouldWaitForHandlerFailure(otherHandler) ||
|
202
|
+
otherHandler.shouldRequireToWaitForFailure(handler)));
|
203
|
+
}
|
204
|
+
canRunSimultaneously(gh1, gh2) {
|
205
|
+
return (gh1 === gh2 ||
|
206
|
+
gh1.shouldRecognizeSimultaneously(gh2) ||
|
207
|
+
gh2.shouldRecognizeSimultaneously(gh1));
|
208
|
+
}
|
209
|
+
shouldHandlerBeCancelledBy(handler, otherHandler) {
|
210
|
+
if (this.canRunSimultaneously(handler, otherHandler)) {
|
211
|
+
return false;
|
212
|
+
}
|
213
|
+
if (handler.awaiting || handler.state === State.ACTIVE) {
|
214
|
+
return handler.shouldBeCancelledByOther(otherHandler);
|
215
|
+
}
|
216
|
+
const handlerPointers = handler.getTrackedPointersID();
|
217
|
+
const otherPointers = otherHandler.getTrackedPointersID();
|
218
|
+
if (!PointerTracker.shareCommonPointers(handlerPointers, otherPointers) &&
|
219
|
+
handler.delegate.view !== otherHandler.delegate.view) {
|
220
|
+
return this.checkOverlap(handler, otherHandler);
|
221
|
+
}
|
222
|
+
return true;
|
223
|
+
}
|
224
|
+
checkOverlap(handler, otherHandler) {
|
225
|
+
// If handlers don't have common pointers, default return value is false.
|
226
|
+
// However, if at least on pointer overlaps with both handlers, we return true
|
227
|
+
// This solves issue in overlapping parents example
|
228
|
+
// TODO: Find better way to handle that issue, for example by activation order and handler cancelling
|
229
|
+
const isPointerWithinBothBounds = (pointer) => {
|
230
|
+
const point = handler.tracker.getLastAbsoluteCoords(pointer);
|
231
|
+
return (point &&
|
232
|
+
handler.delegate.isPointerInBounds(point) &&
|
233
|
+
otherHandler.delegate.isPointerInBounds(point));
|
234
|
+
};
|
235
|
+
return handler.getTrackedPointersID().some(isPointerWithinBothBounds);
|
236
|
+
}
|
237
|
+
isFinished(state) {
|
238
|
+
return (state === State.END || state === State.FAILED || state === State.CANCELLED);
|
239
|
+
}
|
240
|
+
// This function is called when handler receives touchdown event
|
241
|
+
// If handler is using mouse or pen as a pointer and any handler receives touch event,
|
242
|
+
// mouse/pen event dissappears - it doesn't send onPointerCancel nor onPointerUp (and others)
|
243
|
+
// This became a problem because handler was left at active state without any signal to end or fail
|
244
|
+
// To handle this, when new touch event is received, we loop through active handlers and check which type of
|
245
|
+
// pointer they're using. If there are any handler with mouse/pen as a pointer, we cancel them
|
246
|
+
cancelMouseAndPenGestures(currentHandler) {
|
247
|
+
this.gestureHandlers.forEach((handler) => {
|
248
|
+
if (handler.pointerType !== PointerType.MOUSE &&
|
249
|
+
handler.pointerType !== PointerType.STYLUS) {
|
250
|
+
return;
|
251
|
+
}
|
252
|
+
if (handler !== currentHandler) {
|
253
|
+
handler.cancel();
|
254
|
+
}
|
255
|
+
else {
|
256
|
+
// Handler that received touch event should have its pointer tracker reset
|
257
|
+
// This allows handler to smoothly change from mouse/pen to touch
|
258
|
+
// The drawback is, that when we try to use mouse/pen one more time, it doesn't send onPointerDown at the first time
|
259
|
+
// so it is required to click two times to get handler to work
|
260
|
+
//
|
261
|
+
// However, handler will receive manually created onPointerEnter that is triggered in EventManager in onPointerMove method.
|
262
|
+
// There may be possibility to use that fact to make handler respond properly to first mouse click
|
263
|
+
handler.tracker.resetTracker();
|
264
|
+
}
|
265
|
+
});
|
266
|
+
}
|
267
|
+
static get instance() {
|
268
|
+
if (!GestureHandlerOrchestrator._instance) {
|
269
|
+
GestureHandlerOrchestrator._instance = new GestureHandlerOrchestrator();
|
270
|
+
}
|
271
|
+
return GestureHandlerOrchestrator._instance;
|
272
|
+
}
|
273
|
+
}
|