@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,743 @@
|
|
1
|
+
// This component is based on RN's DrawerLayoutAndroid API
|
2
|
+
//
|
3
|
+
// It perhaps deserves to be put in a separate repo, but since it relies on
|
4
|
+
// react-native-gesture-handler library which isn't very popular at the moment I
|
5
|
+
// decided to keep it here for the time being. It will allow us to move faster
|
6
|
+
// and fix issues that may arise in gesture handler library that could be found
|
7
|
+
// when using the drawer component
|
8
|
+
|
9
|
+
import * as React from 'react';
|
10
|
+
import { Component } from 'react';
|
11
|
+
import invariant from 'invariant';
|
12
|
+
import {
|
13
|
+
Animated,
|
14
|
+
StyleSheet,
|
15
|
+
View,
|
16
|
+
Keyboard,
|
17
|
+
StatusBar,
|
18
|
+
I18nManager,
|
19
|
+
StatusBarAnimation,
|
20
|
+
StyleProp,
|
21
|
+
ViewStyle,
|
22
|
+
LayoutChangeEvent,
|
23
|
+
NativeSyntheticEvent,
|
24
|
+
} from 'react-native';
|
25
|
+
|
26
|
+
import {
|
27
|
+
GestureEvent,
|
28
|
+
HandlerStateChangeEvent,
|
29
|
+
UserSelect,
|
30
|
+
ActiveCursor,
|
31
|
+
} from '../handlers/gestureHandlerCommon';
|
32
|
+
import {
|
33
|
+
PanGestureHandler,
|
34
|
+
PanGestureHandlerEventPayload,
|
35
|
+
} from '../handlers/PanGestureHandler';
|
36
|
+
import {
|
37
|
+
TapGestureHandler,
|
38
|
+
TapGestureHandlerEventPayload,
|
39
|
+
} from '../handlers/TapGestureHandler';
|
40
|
+
import { State } from '../State';
|
41
|
+
|
42
|
+
const DRAG_TOSS = 0.05;
|
43
|
+
|
44
|
+
const IDLE: DrawerState = 'Idle';
|
45
|
+
const DRAGGING: DrawerState = 'Dragging';
|
46
|
+
const SETTLING: DrawerState = 'Settling';
|
47
|
+
|
48
|
+
export type DrawerPosition = 'left' | 'right';
|
49
|
+
|
50
|
+
export type DrawerState = 'Idle' | 'Dragging' | 'Settling';
|
51
|
+
|
52
|
+
export type DrawerType = 'front' | 'back' | 'slide';
|
53
|
+
|
54
|
+
export type DrawerLockMode = 'unlocked' | 'locked-closed' | 'locked-open';
|
55
|
+
|
56
|
+
export type DrawerKeyboardDismissMode = 'none' | 'on-drag';
|
57
|
+
|
58
|
+
// Animated.AnimatedInterpolation has been converted to a generic type
|
59
|
+
// in @types/react-native 0.70. This way we can maintain compatibility
|
60
|
+
// with all versions of @types/react-native`
|
61
|
+
type AnimatedInterpolation = ReturnType<Animated.Value['interpolate']>;
|
62
|
+
export interface DrawerLayoutProps {
|
63
|
+
/**
|
64
|
+
* This attribute is present in the standard implementation already and is one
|
65
|
+
* of the required params. Gesture handler version of DrawerLayout make it
|
66
|
+
* possible for the function passed as `renderNavigationView` to take an
|
67
|
+
* Animated value as a parameter that indicates the progress of drawer
|
68
|
+
* opening/closing animation (progress value is 0 when closed and 1 when
|
69
|
+
* opened). This can be used by the drawer component to animated its children
|
70
|
+
* while the drawer is opening or closing.
|
71
|
+
*/
|
72
|
+
renderNavigationView: (
|
73
|
+
progressAnimatedValue: Animated.Value
|
74
|
+
) => React.ReactNode;
|
75
|
+
|
76
|
+
drawerPosition?: DrawerPosition;
|
77
|
+
|
78
|
+
drawerWidth?: number;
|
79
|
+
|
80
|
+
drawerBackgroundColor?: string;
|
81
|
+
|
82
|
+
drawerLockMode?: DrawerLockMode;
|
83
|
+
|
84
|
+
keyboardDismissMode?: DrawerKeyboardDismissMode;
|
85
|
+
|
86
|
+
/**
|
87
|
+
* Called when the drawer is closed.
|
88
|
+
*/
|
89
|
+
onDrawerClose?: () => void;
|
90
|
+
|
91
|
+
/**
|
92
|
+
* Called when the drawer is opened.
|
93
|
+
*/
|
94
|
+
onDrawerOpen?: () => void;
|
95
|
+
|
96
|
+
/**
|
97
|
+
* Called when the status of the drawer changes.
|
98
|
+
*/
|
99
|
+
onDrawerStateChanged?: (
|
100
|
+
newState: DrawerState,
|
101
|
+
drawerWillShow: boolean
|
102
|
+
) => void;
|
103
|
+
useNativeAnimations?: boolean;
|
104
|
+
|
105
|
+
drawerType?: DrawerType;
|
106
|
+
|
107
|
+
/**
|
108
|
+
* Defines how far from the edge of the content view the gesture should
|
109
|
+
* activate.
|
110
|
+
*/
|
111
|
+
edgeWidth?: number;
|
112
|
+
|
113
|
+
minSwipeDistance?: number;
|
114
|
+
|
115
|
+
/**
|
116
|
+
* When set to true Drawer component will use
|
117
|
+
* {@link https://reactnative.dev/docs/statusbar StatusBar} API to hide the OS
|
118
|
+
* status bar whenever the drawer is pulled or when its in an "open" state.
|
119
|
+
*/
|
120
|
+
hideStatusBar?: boolean;
|
121
|
+
|
122
|
+
/**
|
123
|
+
* @default 'slide'
|
124
|
+
*
|
125
|
+
* Can be used when hideStatusBar is set to true and will select the animation
|
126
|
+
* used for hiding/showing the status bar. See
|
127
|
+
* {@link https://reactnative.dev/docs/statusbar StatusBar} documentation for
|
128
|
+
* more details
|
129
|
+
*/
|
130
|
+
statusBarAnimation?: StatusBarAnimation;
|
131
|
+
|
132
|
+
/**
|
133
|
+
* @default black
|
134
|
+
*
|
135
|
+
* Color of a semi-transparent overlay to be displayed on top of the content
|
136
|
+
* view when drawer gets open. A solid color should be used as the opacity is
|
137
|
+
* added by the Drawer itself and the opacity of the overlay is animated (from
|
138
|
+
* 0% to 70%).
|
139
|
+
*/
|
140
|
+
overlayColor?: string;
|
141
|
+
|
142
|
+
contentContainerStyle?: StyleProp<ViewStyle>;
|
143
|
+
|
144
|
+
drawerContainerStyle?: StyleProp<ViewStyle>;
|
145
|
+
|
146
|
+
/**
|
147
|
+
* Enables two-finger gestures on supported devices, for example iPads with
|
148
|
+
* trackpads. If not enabled the gesture will require click + drag, with
|
149
|
+
* `enableTrackpadTwoFingerGesture` swiping with two fingers will also trigger
|
150
|
+
* the gesture.
|
151
|
+
*/
|
152
|
+
enableTrackpadTwoFingerGesture?: boolean;
|
153
|
+
|
154
|
+
onDrawerSlide?: (position: number) => void;
|
155
|
+
|
156
|
+
onGestureRef?: (ref: PanGestureHandler) => void;
|
157
|
+
|
158
|
+
// implicit `children` prop has been removed in @types/react^18.0.0
|
159
|
+
children?:
|
160
|
+
| React.ReactNode
|
161
|
+
| ((openValue?: AnimatedInterpolation) => React.ReactNode);
|
162
|
+
|
163
|
+
/**
|
164
|
+
* @default 'none'
|
165
|
+
* Defines which userSelect property should be used.
|
166
|
+
* Values: 'none'|'text'|'auto'
|
167
|
+
*/
|
168
|
+
userSelect?: UserSelect;
|
169
|
+
|
170
|
+
/**
|
171
|
+
* @default 'auto'
|
172
|
+
* Defines which cursor property should be used when gesture activates.
|
173
|
+
* Values: see CSS cursor values
|
174
|
+
*/
|
175
|
+
activeCursor?: ActiveCursor;
|
176
|
+
}
|
177
|
+
|
178
|
+
export type DrawerLayoutState = {
|
179
|
+
dragX: Animated.Value;
|
180
|
+
touchX: Animated.Value;
|
181
|
+
drawerTranslation: Animated.Value;
|
182
|
+
containerWidth: number;
|
183
|
+
drawerState: DrawerState;
|
184
|
+
drawerOpened: boolean;
|
185
|
+
};
|
186
|
+
|
187
|
+
export type DrawerMovementOption = {
|
188
|
+
velocity?: number;
|
189
|
+
speed?: number;
|
190
|
+
};
|
191
|
+
export default class DrawerLayout extends Component<
|
192
|
+
DrawerLayoutProps,
|
193
|
+
DrawerLayoutState
|
194
|
+
> {
|
195
|
+
static defaultProps = {
|
196
|
+
drawerWidth: 200,
|
197
|
+
drawerPosition: 'left',
|
198
|
+
useNativeAnimations: true,
|
199
|
+
drawerType: 'front',
|
200
|
+
edgeWidth: 20,
|
201
|
+
minSwipeDistance: 3,
|
202
|
+
overlayColor: 'rgba(0, 0, 0, 0.7)',
|
203
|
+
drawerLockMode: 'unlocked',
|
204
|
+
enableTrackpadTwoFingerGesture: false,
|
205
|
+
};
|
206
|
+
|
207
|
+
constructor(props: DrawerLayoutProps) {
|
208
|
+
super(props);
|
209
|
+
|
210
|
+
const dragX = new Animated.Value(0);
|
211
|
+
const touchX = new Animated.Value(0);
|
212
|
+
const drawerTranslation = new Animated.Value(0);
|
213
|
+
|
214
|
+
this.state = {
|
215
|
+
dragX,
|
216
|
+
touchX,
|
217
|
+
drawerTranslation,
|
218
|
+
containerWidth: 0,
|
219
|
+
drawerState: IDLE,
|
220
|
+
drawerOpened: false,
|
221
|
+
};
|
222
|
+
|
223
|
+
this.updateAnimatedEvent(props, this.state);
|
224
|
+
}
|
225
|
+
|
226
|
+
shouldComponentUpdate(props: DrawerLayoutProps, state: DrawerLayoutState) {
|
227
|
+
if (
|
228
|
+
this.props.drawerPosition !== props.drawerPosition ||
|
229
|
+
this.props.drawerWidth !== props.drawerWidth ||
|
230
|
+
this.props.drawerType !== props.drawerType ||
|
231
|
+
this.state.containerWidth !== state.containerWidth
|
232
|
+
) {
|
233
|
+
this.updateAnimatedEvent(props, state);
|
234
|
+
}
|
235
|
+
|
236
|
+
return true;
|
237
|
+
}
|
238
|
+
|
239
|
+
private openValue?: AnimatedInterpolation;
|
240
|
+
private onGestureEvent?: (
|
241
|
+
event: GestureEvent<PanGestureHandlerEventPayload>
|
242
|
+
) => void;
|
243
|
+
private accessibilityIsModalView = React.createRef<View>();
|
244
|
+
private pointerEventsView = React.createRef<View>();
|
245
|
+
private panGestureHandler = React.createRef<PanGestureHandler | null>();
|
246
|
+
private drawerShown = false;
|
247
|
+
|
248
|
+
static positions = {
|
249
|
+
Left: 'left',
|
250
|
+
Right: 'right',
|
251
|
+
};
|
252
|
+
|
253
|
+
private updateAnimatedEvent = (
|
254
|
+
props: DrawerLayoutProps,
|
255
|
+
state: DrawerLayoutState
|
256
|
+
) => {
|
257
|
+
// Event definition is based on
|
258
|
+
const { drawerPosition, drawerWidth, drawerType } = props;
|
259
|
+
const {
|
260
|
+
dragX: dragXValue,
|
261
|
+
touchX: touchXValue,
|
262
|
+
drawerTranslation,
|
263
|
+
containerWidth,
|
264
|
+
} = state;
|
265
|
+
|
266
|
+
let dragX = dragXValue;
|
267
|
+
let touchX = touchXValue;
|
268
|
+
|
269
|
+
if (drawerPosition !== 'left') {
|
270
|
+
// Most of the code is written in a way to handle left-side drawer. In
|
271
|
+
// order to handle right-side drawer the only thing we need to do is to
|
272
|
+
// reverse events coming from gesture handler in a way they emulate
|
273
|
+
// left-side drawer gestures. E.g. dragX is simply -dragX, and touchX is
|
274
|
+
// calulcated by subtracing real touchX from the width of the container
|
275
|
+
// (such that when touch happens at the right edge the value is simply 0)
|
276
|
+
dragX = Animated.multiply(
|
277
|
+
new Animated.Value(-1),
|
278
|
+
dragXValue
|
279
|
+
) as Animated.Value; // TODO(TS): (for all "as" in this file) make sure we can map this
|
280
|
+
touchX = Animated.add(
|
281
|
+
new Animated.Value(containerWidth),
|
282
|
+
Animated.multiply(new Animated.Value(-1), touchXValue)
|
283
|
+
) as Animated.Value; // TODO(TS): make sure we can map this;
|
284
|
+
touchXValue.setValue(containerWidth);
|
285
|
+
} else {
|
286
|
+
touchXValue.setValue(0);
|
287
|
+
}
|
288
|
+
|
289
|
+
// While closing the drawer when user starts gesture outside of its area (in greyed
|
290
|
+
// out part of the window), we want the drawer to follow only once finger reaches the
|
291
|
+
// edge of the drawer.
|
292
|
+
// E.g. on the diagram below drawer is illustrate by X signs and the greyed out area by
|
293
|
+
// dots. The touch gesture starts at '*' and moves left, touch path is indicated by
|
294
|
+
// an arrow pointing left
|
295
|
+
// 1) +---------------+ 2) +---------------+ 3) +---------------+ 4) +---------------+
|
296
|
+
// |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|
|
297
|
+
// |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|
|
298
|
+
// |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|
|
299
|
+
// |XXXXXXXX|......| |XXXXXXXX|.<-*..| |XXXXXXXX|<--*..| |XXXXX|<-----*..|
|
300
|
+
// |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|
|
301
|
+
// |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|
|
302
|
+
// |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|
|
303
|
+
// +---------------+ +---------------+ +---------------+ +---------------+
|
304
|
+
//
|
305
|
+
// For the above to work properly we define animated value that will keep
|
306
|
+
// start position of the gesture. Then we use that value to calculate how
|
307
|
+
// much we need to subtract from the dragX. If the gesture started on the
|
308
|
+
// greyed out area we take the distance from the edge of the drawer to the
|
309
|
+
// start position. Otherwise we don't subtract at all and the drawer be
|
310
|
+
// pulled back as soon as you start the pan.
|
311
|
+
//
|
312
|
+
// This is used only when drawerType is "front"
|
313
|
+
//
|
314
|
+
let translationX = dragX;
|
315
|
+
if (drawerType === 'front') {
|
316
|
+
const startPositionX = Animated.add(
|
317
|
+
touchX,
|
318
|
+
Animated.multiply(new Animated.Value(-1), dragX)
|
319
|
+
);
|
320
|
+
|
321
|
+
const dragOffsetFromOnStartPosition = startPositionX.interpolate({
|
322
|
+
inputRange: [drawerWidth! - 1, drawerWidth!, drawerWidth! + 1],
|
323
|
+
outputRange: [0, 0, 1],
|
324
|
+
});
|
325
|
+
translationX = Animated.add(
|
326
|
+
dragX,
|
327
|
+
dragOffsetFromOnStartPosition
|
328
|
+
) as Animated.Value; // TODO: as above
|
329
|
+
}
|
330
|
+
|
331
|
+
this.openValue = Animated.add(translationX, drawerTranslation).interpolate({
|
332
|
+
inputRange: [0, drawerWidth!],
|
333
|
+
outputRange: [0, 1],
|
334
|
+
extrapolate: 'clamp',
|
335
|
+
});
|
336
|
+
|
337
|
+
const gestureOptions: {
|
338
|
+
useNativeDriver: boolean;
|
339
|
+
// TODO: make sure it is correct
|
340
|
+
listener?: (
|
341
|
+
ev: NativeSyntheticEvent<PanGestureHandlerEventPayload>
|
342
|
+
) => void;
|
343
|
+
} = {
|
344
|
+
useNativeDriver: props.useNativeAnimations!,
|
345
|
+
};
|
346
|
+
|
347
|
+
if (this.props.onDrawerSlide) {
|
348
|
+
gestureOptions.listener = (ev) => {
|
349
|
+
const translationX = Math.floor(Math.abs(ev.nativeEvent.translationX));
|
350
|
+
const position = translationX / this.state.containerWidth;
|
351
|
+
|
352
|
+
this.props.onDrawerSlide?.(position);
|
353
|
+
};
|
354
|
+
}
|
355
|
+
|
356
|
+
this.onGestureEvent = Animated.event(
|
357
|
+
[{ nativeEvent: { translationX: dragXValue, x: touchXValue } }],
|
358
|
+
gestureOptions
|
359
|
+
);
|
360
|
+
};
|
361
|
+
|
362
|
+
private handleContainerLayout = ({ nativeEvent }: LayoutChangeEvent) => {
|
363
|
+
this.setState({ containerWidth: nativeEvent.layout.width });
|
364
|
+
};
|
365
|
+
|
366
|
+
private emitStateChanged = (
|
367
|
+
newState: DrawerState,
|
368
|
+
drawerWillShow: boolean
|
369
|
+
) => {
|
370
|
+
this.props.onDrawerStateChanged?.(newState, drawerWillShow);
|
371
|
+
};
|
372
|
+
|
373
|
+
private openingHandlerStateChange = ({
|
374
|
+
nativeEvent,
|
375
|
+
}: HandlerStateChangeEvent<PanGestureHandlerEventPayload>) => {
|
376
|
+
if (nativeEvent.oldState === State.ACTIVE) {
|
377
|
+
this.handleRelease({ nativeEvent });
|
378
|
+
} else if (nativeEvent.state === State.ACTIVE) {
|
379
|
+
this.emitStateChanged(DRAGGING, false);
|
380
|
+
this.setState({ drawerState: DRAGGING });
|
381
|
+
if (this.props.keyboardDismissMode === 'on-drag') {
|
382
|
+
Keyboard.dismiss();
|
383
|
+
}
|
384
|
+
if (this.props.hideStatusBar) {
|
385
|
+
StatusBar.setHidden(true, this.props.statusBarAnimation || 'slide');
|
386
|
+
}
|
387
|
+
}
|
388
|
+
};
|
389
|
+
|
390
|
+
private onTapHandlerStateChange = ({
|
391
|
+
nativeEvent,
|
392
|
+
}: HandlerStateChangeEvent<TapGestureHandlerEventPayload>) => {
|
393
|
+
if (
|
394
|
+
this.drawerShown &&
|
395
|
+
nativeEvent.oldState === State.ACTIVE &&
|
396
|
+
this.props.drawerLockMode !== 'locked-open'
|
397
|
+
) {
|
398
|
+
this.closeDrawer();
|
399
|
+
}
|
400
|
+
};
|
401
|
+
|
402
|
+
private handleRelease = ({
|
403
|
+
nativeEvent,
|
404
|
+
}: HandlerStateChangeEvent<PanGestureHandlerEventPayload>) => {
|
405
|
+
const { drawerWidth, drawerPosition, drawerType } = this.props;
|
406
|
+
const { containerWidth } = this.state;
|
407
|
+
let { translationX: dragX, velocityX, x: touchX } = nativeEvent;
|
408
|
+
|
409
|
+
if (drawerPosition !== 'left') {
|
410
|
+
// See description in _updateAnimatedEvent about why events are flipped
|
411
|
+
// for right-side drawer
|
412
|
+
dragX = -dragX;
|
413
|
+
touchX = containerWidth - touchX;
|
414
|
+
velocityX = -velocityX;
|
415
|
+
}
|
416
|
+
|
417
|
+
const gestureStartX = touchX - dragX;
|
418
|
+
let dragOffsetBasedOnStart = 0;
|
419
|
+
|
420
|
+
if (drawerType === 'front') {
|
421
|
+
dragOffsetBasedOnStart =
|
422
|
+
gestureStartX > drawerWidth! ? gestureStartX - drawerWidth! : 0;
|
423
|
+
}
|
424
|
+
|
425
|
+
const startOffsetX =
|
426
|
+
dragX + dragOffsetBasedOnStart + (this.drawerShown ? drawerWidth! : 0);
|
427
|
+
const projOffsetX = startOffsetX + DRAG_TOSS * velocityX;
|
428
|
+
|
429
|
+
const shouldOpen = projOffsetX > drawerWidth! / 2;
|
430
|
+
|
431
|
+
if (shouldOpen) {
|
432
|
+
this.animateDrawer(startOffsetX, drawerWidth!, velocityX);
|
433
|
+
} else {
|
434
|
+
this.animateDrawer(startOffsetX, 0, velocityX);
|
435
|
+
}
|
436
|
+
};
|
437
|
+
|
438
|
+
private updateShowing = (showing: boolean) => {
|
439
|
+
this.drawerShown = showing;
|
440
|
+
this.accessibilityIsModalView.current?.setNativeProps({
|
441
|
+
accessibilityViewIsModal: showing,
|
442
|
+
});
|
443
|
+
this.pointerEventsView.current?.setNativeProps({
|
444
|
+
pointerEvents: showing ? 'auto' : 'none',
|
445
|
+
});
|
446
|
+
const { drawerPosition, minSwipeDistance, edgeWidth } = this.props;
|
447
|
+
const fromLeft = drawerPosition === 'left';
|
448
|
+
// gestureOrientation is 1 if the expected gesture is from left to right and
|
449
|
+
// -1 otherwise e.g. when drawer is on the left and is closed we expect left
|
450
|
+
// to right gesture, thus orientation will be 1.
|
451
|
+
const gestureOrientation =
|
452
|
+
(fromLeft ? 1 : -1) * (this.drawerShown ? -1 : 1);
|
453
|
+
// When drawer is closed we want the hitSlop to be horizontally shorter than
|
454
|
+
// the container size by the value of SLOP. This will make it only activate
|
455
|
+
// when gesture happens not further than SLOP away from the edge
|
456
|
+
const hitSlop = fromLeft
|
457
|
+
? { left: 0, width: showing ? undefined : edgeWidth }
|
458
|
+
: { right: 0, width: showing ? undefined : edgeWidth };
|
459
|
+
// @ts-ignore internal API, maybe could be fixed in handler types
|
460
|
+
this.panGestureHandler.current?.setNativeProps({
|
461
|
+
hitSlop,
|
462
|
+
activeOffsetX: gestureOrientation * minSwipeDistance!,
|
463
|
+
});
|
464
|
+
};
|
465
|
+
|
466
|
+
private animateDrawer = (
|
467
|
+
fromValue: number | null | undefined,
|
468
|
+
toValue: number,
|
469
|
+
velocity: number,
|
470
|
+
speed?: number
|
471
|
+
) => {
|
472
|
+
this.state.dragX.setValue(0);
|
473
|
+
this.state.touchX.setValue(
|
474
|
+
this.props.drawerPosition === 'left' ? 0 : this.state.containerWidth
|
475
|
+
);
|
476
|
+
|
477
|
+
if (fromValue != null) {
|
478
|
+
let nextFramePosition = fromValue;
|
479
|
+
if (this.props.useNativeAnimations) {
|
480
|
+
// When using native driver, we predict the next position of the
|
481
|
+
// animation because it takes one frame of a roundtrip to pass RELEASE
|
482
|
+
// event from native driver to JS before we can start animating. Without
|
483
|
+
// it, it is more noticable that the frame is dropped.
|
484
|
+
if (fromValue < toValue && velocity > 0) {
|
485
|
+
nextFramePosition = Math.min(fromValue + velocity / 60.0, toValue);
|
486
|
+
} else if (fromValue > toValue && velocity < 0) {
|
487
|
+
nextFramePosition = Math.max(fromValue + velocity / 60.0, toValue);
|
488
|
+
}
|
489
|
+
}
|
490
|
+
this.state.drawerTranslation.setValue(nextFramePosition);
|
491
|
+
}
|
492
|
+
|
493
|
+
const willShow = toValue !== 0;
|
494
|
+
this.updateShowing(willShow);
|
495
|
+
this.emitStateChanged(SETTLING, willShow);
|
496
|
+
this.setState({ drawerState: SETTLING });
|
497
|
+
if (this.props.hideStatusBar) {
|
498
|
+
StatusBar.setHidden(willShow, this.props.statusBarAnimation || 'slide');
|
499
|
+
}
|
500
|
+
Animated.spring(this.state.drawerTranslation, {
|
501
|
+
velocity,
|
502
|
+
bounciness: 0,
|
503
|
+
toValue,
|
504
|
+
useNativeDriver: this.props.useNativeAnimations!,
|
505
|
+
speed: speed ?? undefined,
|
506
|
+
}).start(({ finished }) => {
|
507
|
+
if (finished) {
|
508
|
+
this.emitStateChanged(IDLE, willShow);
|
509
|
+
this.setState({ drawerOpened: willShow });
|
510
|
+
if (this.state.drawerState !== DRAGGING) {
|
511
|
+
// it's possilbe that user started drag while the drawer
|
512
|
+
// was settling, don't override state in this case
|
513
|
+
this.setState({ drawerState: IDLE });
|
514
|
+
}
|
515
|
+
if (willShow) {
|
516
|
+
this.props.onDrawerOpen?.();
|
517
|
+
} else {
|
518
|
+
this.props.onDrawerClose?.();
|
519
|
+
}
|
520
|
+
}
|
521
|
+
});
|
522
|
+
};
|
523
|
+
|
524
|
+
openDrawer = (options: DrawerMovementOption = {}) => {
|
525
|
+
this.animateDrawer(
|
526
|
+
// TODO: decide if it should be null or undefined is the proper value
|
527
|
+
undefined,
|
528
|
+
this.props.drawerWidth!,
|
529
|
+
options.velocity ? options.velocity : 0,
|
530
|
+
options.speed
|
531
|
+
);
|
532
|
+
|
533
|
+
// We need to force the update, otherwise the overlay is not rerendered and
|
534
|
+
// it would not be clickable
|
535
|
+
this.forceUpdate();
|
536
|
+
};
|
537
|
+
|
538
|
+
closeDrawer = (options: DrawerMovementOption = {}) => {
|
539
|
+
// TODO: decide if it should be null or undefined is the proper value
|
540
|
+
this.animateDrawer(
|
541
|
+
undefined,
|
542
|
+
0,
|
543
|
+
options.velocity ? options.velocity : 0,
|
544
|
+
options.speed
|
545
|
+
);
|
546
|
+
|
547
|
+
// We need to force the update, otherwise the overlay is not rerendered and
|
548
|
+
// it would be still clickable
|
549
|
+
this.forceUpdate();
|
550
|
+
};
|
551
|
+
|
552
|
+
private renderOverlay = () => {
|
553
|
+
/* Overlay styles */
|
554
|
+
invariant(this.openValue, 'should be set');
|
555
|
+
let overlayOpacity;
|
556
|
+
|
557
|
+
if (this.state.drawerState !== IDLE) {
|
558
|
+
overlayOpacity = this.openValue;
|
559
|
+
} else {
|
560
|
+
overlayOpacity = this.state.drawerOpened ? 1 : 0;
|
561
|
+
}
|
562
|
+
|
563
|
+
const dynamicOverlayStyles = {
|
564
|
+
opacity: overlayOpacity,
|
565
|
+
backgroundColor: this.props.overlayColor,
|
566
|
+
};
|
567
|
+
|
568
|
+
return (
|
569
|
+
<TapGestureHandler onHandlerStateChange={this.onTapHandlerStateChange}>
|
570
|
+
<Animated.View
|
571
|
+
pointerEvents={this.drawerShown ? 'auto' : 'none'}
|
572
|
+
ref={this.pointerEventsView}
|
573
|
+
style={[styles.overlay, dynamicOverlayStyles]}
|
574
|
+
/>
|
575
|
+
</TapGestureHandler>
|
576
|
+
);
|
577
|
+
};
|
578
|
+
|
579
|
+
private renderDrawer = () => {
|
580
|
+
const {
|
581
|
+
drawerBackgroundColor,
|
582
|
+
drawerWidth,
|
583
|
+
drawerPosition,
|
584
|
+
drawerType,
|
585
|
+
drawerContainerStyle,
|
586
|
+
contentContainerStyle,
|
587
|
+
} = this.props;
|
588
|
+
|
589
|
+
const fromLeft = drawerPosition === 'left';
|
590
|
+
const drawerSlide = drawerType !== 'back';
|
591
|
+
const containerSlide = drawerType !== 'front';
|
592
|
+
|
593
|
+
// we rely on row and row-reverse flex directions to position the drawer
|
594
|
+
// properly. Apparently for RTL these are flipped which requires us to use
|
595
|
+
// the opposite setting for the drawer to appear from left or right
|
596
|
+
// according to the drawerPosition prop
|
597
|
+
const reverseContentDirection = I18nManager.isRTL ? fromLeft : !fromLeft;
|
598
|
+
|
599
|
+
const dynamicDrawerStyles = {
|
600
|
+
backgroundColor: drawerBackgroundColor,
|
601
|
+
width: drawerWidth,
|
602
|
+
};
|
603
|
+
const openValue = this.openValue;
|
604
|
+
invariant(openValue, 'should be set');
|
605
|
+
|
606
|
+
let containerStyles;
|
607
|
+
if (containerSlide) {
|
608
|
+
const containerTranslateX = openValue.interpolate({
|
609
|
+
inputRange: [0, 1],
|
610
|
+
outputRange: fromLeft ? [0, drawerWidth!] : [0, -drawerWidth!],
|
611
|
+
extrapolate: 'clamp',
|
612
|
+
});
|
613
|
+
containerStyles = {
|
614
|
+
transform: [{ translateX: containerTranslateX }],
|
615
|
+
};
|
616
|
+
}
|
617
|
+
|
618
|
+
let drawerTranslateX: number | AnimatedInterpolation = 0;
|
619
|
+
if (drawerSlide) {
|
620
|
+
const closedDrawerOffset = fromLeft ? -drawerWidth! : drawerWidth!;
|
621
|
+
if (this.state.drawerState !== IDLE) {
|
622
|
+
drawerTranslateX = openValue.interpolate({
|
623
|
+
inputRange: [0, 1],
|
624
|
+
outputRange: [closedDrawerOffset, 0],
|
625
|
+
extrapolate: 'clamp',
|
626
|
+
});
|
627
|
+
} else {
|
628
|
+
drawerTranslateX = this.state.drawerOpened ? 0 : closedDrawerOffset;
|
629
|
+
}
|
630
|
+
}
|
631
|
+
const drawerStyles: {
|
632
|
+
transform: { translateX: number | AnimatedInterpolation }[];
|
633
|
+
flexDirection: 'row-reverse' | 'row';
|
634
|
+
} = {
|
635
|
+
transform: [{ translateX: drawerTranslateX }],
|
636
|
+
flexDirection: reverseContentDirection ? 'row-reverse' : 'row',
|
637
|
+
};
|
638
|
+
|
639
|
+
return (
|
640
|
+
<Animated.View style={styles.main} onLayout={this.handleContainerLayout}>
|
641
|
+
<Animated.View
|
642
|
+
style={[
|
643
|
+
drawerType === 'front'
|
644
|
+
? styles.containerOnBack
|
645
|
+
: styles.containerInFront,
|
646
|
+
containerStyles,
|
647
|
+
contentContainerStyle,
|
648
|
+
]}
|
649
|
+
importantForAccessibility={
|
650
|
+
this.drawerShown ? 'no-hide-descendants' : 'yes'
|
651
|
+
}>
|
652
|
+
{typeof this.props.children === 'function'
|
653
|
+
? this.props.children(this.openValue)
|
654
|
+
: this.props.children}
|
655
|
+
{this.renderOverlay()}
|
656
|
+
</Animated.View>
|
657
|
+
<Animated.View
|
658
|
+
pointerEvents="box-none"
|
659
|
+
ref={this.accessibilityIsModalView}
|
660
|
+
accessibilityViewIsModal={this.drawerShown}
|
661
|
+
style={[styles.drawerContainer, drawerStyles, drawerContainerStyle]}>
|
662
|
+
<View style={dynamicDrawerStyles}>
|
663
|
+
{this.props.renderNavigationView(this.openValue as Animated.Value)}
|
664
|
+
</View>
|
665
|
+
</Animated.View>
|
666
|
+
</Animated.View>
|
667
|
+
);
|
668
|
+
};
|
669
|
+
|
670
|
+
private setPanGestureRef = (ref: PanGestureHandler) => {
|
671
|
+
// TODO(TS): make sure it is OK taken from
|
672
|
+
// https://github.com/DefinitelyTyped/DefinitelyTyped/issues/31065#issuecomment-596081842
|
673
|
+
(
|
674
|
+
this.panGestureHandler as React.MutableRefObject<PanGestureHandler>
|
675
|
+
).current = ref;
|
676
|
+
this.props.onGestureRef?.(ref);
|
677
|
+
};
|
678
|
+
|
679
|
+
render() {
|
680
|
+
const { drawerPosition, drawerLockMode, edgeWidth, minSwipeDistance } =
|
681
|
+
this.props;
|
682
|
+
|
683
|
+
const fromLeft = drawerPosition === 'left';
|
684
|
+
|
685
|
+
// gestureOrientation is 1 if the expected gesture is from left to right and
|
686
|
+
// -1 otherwise e.g. when drawer is on the left and is closed we expect left
|
687
|
+
// to right gesture, thus orientation will be 1.
|
688
|
+
const gestureOrientation =
|
689
|
+
(fromLeft ? 1 : -1) * (this.drawerShown ? -1 : 1);
|
690
|
+
|
691
|
+
// When drawer is closed we want the hitSlop to be horizontally shorter than
|
692
|
+
// the container size by the value of SLOP. This will make it only activate
|
693
|
+
// when gesture happens not further than SLOP away from the edge
|
694
|
+
const hitSlop = fromLeft
|
695
|
+
? { left: 0, width: this.drawerShown ? undefined : edgeWidth }
|
696
|
+
: { right: 0, width: this.drawerShown ? undefined : edgeWidth };
|
697
|
+
|
698
|
+
return (
|
699
|
+
<PanGestureHandler
|
700
|
+
// @ts-ignore could be fixed in handler types
|
701
|
+
userSelect={this.props.userSelect}
|
702
|
+
activeCursor={this.props.activeCursor}
|
703
|
+
ref={this.setPanGestureRef}
|
704
|
+
hitSlop={hitSlop}
|
705
|
+
activeOffsetX={gestureOrientation * minSwipeDistance!}
|
706
|
+
failOffsetY={[-15, 15]}
|
707
|
+
onGestureEvent={this.onGestureEvent}
|
708
|
+
onHandlerStateChange={this.openingHandlerStateChange}
|
709
|
+
enableTrackpadTwoFingerGesture={
|
710
|
+
this.props.enableTrackpadTwoFingerGesture
|
711
|
+
}
|
712
|
+
enabled={
|
713
|
+
drawerLockMode !== 'locked-closed' && drawerLockMode !== 'locked-open'
|
714
|
+
}>
|
715
|
+
{this.renderDrawer()}
|
716
|
+
</PanGestureHandler>
|
717
|
+
);
|
718
|
+
}
|
719
|
+
}
|
720
|
+
|
721
|
+
const styles = StyleSheet.create({
|
722
|
+
drawerContainer: {
|
723
|
+
...StyleSheet.absoluteFillObject,
|
724
|
+
zIndex: 1001,
|
725
|
+
flexDirection: 'row',
|
726
|
+
},
|
727
|
+
containerInFront: {
|
728
|
+
...StyleSheet.absoluteFillObject,
|
729
|
+
zIndex: 1002,
|
730
|
+
},
|
731
|
+
containerOnBack: {
|
732
|
+
...StyleSheet.absoluteFillObject,
|
733
|
+
},
|
734
|
+
main: {
|
735
|
+
flex: 1,
|
736
|
+
zIndex: 0,
|
737
|
+
overflow: 'hidden',
|
738
|
+
},
|
739
|
+
overlay: {
|
740
|
+
...StyleSheet.absoluteFillObject,
|
741
|
+
zIndex: 1000,
|
742
|
+
},
|
743
|
+
});
|