about summary refs log tree commit diff
path: root/patches/react-native-drawer-layout+4.1.10.patch
blob: d4c0731f5e83e499b34760c3e25aa4bd0701ca21 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
diff --git a/node_modules/react-native-drawer-layout/lib/module/views/Drawer.native.js b/node_modules/react-native-drawer-layout/lib/module/views/Drawer.native.js
index efa71f9..a23c624 100644
--- a/node_modules/react-native-drawer-layout/lib/module/views/Drawer.native.js
+++ b/node_modules/react-native-drawer-layout/lib/module/views/Drawer.native.js
@@ -124,15 +124,21 @@ export function Drawer({
     }
     onTransitionEnd?.(!open);
   });
+  const animatingTo = useSharedValue(null)
   const toggleDrawer = React.useCallback((open, velocity) => {
     'worklet';
 
+    if (animatingTo.value === (open ? 'open' : 'close')) {
+      return;
+    }
+
     const translateX = getDrawerTranslationX(open);
     if (velocity === undefined) {
       runOnJS(onAnimationStart)(open);
     }
     touchStartX.value = 0;
     touchX.value = 0;
+    animatingTo.value = open ? 'open' : 'close';
     translationX.value = withSpring(translateX, {
       velocity,
       stiffness: 1000,
@@ -142,7 +148,10 @@ export function Drawer({
       restDisplacementThreshold: 0.01,
       restSpeedThreshold: 0.01,
       reduceMotion: ReduceMotion.Never
-    }, finished => runOnJS(onAnimationEnd)(open, finished));
+    }, finished => {
+      animatingTo.value = null;
+      runOnJS(onAnimationEnd)(open, finished)
+    });
     if (open) {
       runOnJS(onOpen)();
     } else {