-
-
Notifications
You must be signed in to change notification settings - Fork 987
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Swipeable renderLeftActions button not firing #3223
Comments
Hey! 👋 The issue doesn't seem to contain a minimal reproduction. Could you provide a snack or a link to a GitHub repository under your username that reproduces the problem? |
|
Hi, could you clarify the repro you used to test this issue? |
@latekvo thanks for your comment, I figured out I pasted the wrong code version, but I already updated it. I used RN's TouchOpacity, also tested it with |
I have the same issue, but surprisingly it works in Android, but doesn't work in iOS. |
This is likely an issue with |
if you are bumped into this issue but need solve it quickly, use the old Swipeable instead as a temporary solution. |
+1 |
The issue still persists for me with the same example:
|
@lukachi Do you think I should reopen this issue? Could you share more details, setup, devices where you're testing it, code or screenshots? |
+1 We are also heaving the same issue |
hi @erie-e9 package.json deps:
snippet: export default function Chats() {
const insets = useSafeAreaInsets()
const bottomBarOffset = useBottomBarOffset()
const { data: fakeUsers } = useLoading([], () => getFakeUser(24), {
loadOnMount: true,
})
return (
<UiScreenScrollable>
<View
style={{
paddingTop: insets.top,
paddingBottom: bottomBarOffset,
}}
className='flex flex-1'
>
<View className='flex flex-1'>
<FlashList
data={fakeUsers}
estimatedItemSize={75}
renderItem={({ item, index }) => (
// TODO: replace by Reanimated Swipeable once it's stable and fixed left actions
<Swipeable
friction={2}
enableTrackpadTwoFingerGesture
rightThreshold={40}
leftThreshold={40}
renderLeftActions={() => (
<View className='flex h-full flex-row items-center'>
<TouchableOpacity
className='flex min-w-[60] items-center justify-center self-stretch bg-textSecondary'
onPress={() => console.log('delete')}
>
<UiIcon customIcon='message' size={24} className='text-baseWhite' />
</TouchableOpacity>
<TouchableOpacity
className='flex min-w-[60] items-center justify-center self-stretch bg-successDark'
onPress={() => console.log('delete')}
>
<UiIcon
libIcon='FontAwesome'
name='bookmark'
size={24}
className='text-baseWhite'
/>
</TouchableOpacity>
</View>
)}
renderRightActions={() => (
<View className='flex h-full flex-row items-center'>
<TouchableOpacity
className='flex min-w-[60] items-center justify-center self-stretch bg-warningMain'
onPress={() => console.log('delete')}
>
<UiIcon
libIcon='FontAwesome'
name='volume-off'
size={24}
className='text-baseWhite'
/>
</TouchableOpacity>
<TouchableOpacity
className='flex min-w-[60] items-center justify-center self-stretch bg-errorMain'
onPress={() => console.log('delete')}
>
<UiIcon
libIcon='FontAwesome'
name='trash'
size={24}
className='text-baseWhite'
/>
</TouchableOpacity>
<TouchableOpacity
className='flex min-w-[60] items-center justify-center self-stretch bg-textSecondary'
onPress={() => console.log('delete')}
>
<UiIcon
libIcon='FontAwesome'
name='archive'
size={24}
className='text-baseWhite'
/>
</TouchableOpacity>
</View>
)}
>
<ListItem
key={index}
title={item.name.first}
text='lorem ipsum dolor sit amet concestetur'
updatedAt={item.registered.date}
avatarUri={item.picture.thumbnail}
newMsgAmount={index % 2 === 0 ? 1 : undefined}
isRead={index % 2 !== 0}
className={cn(
'bg-backgroundPrimary',
index !== fakeUsers.length - 1 && 'border-b border-borderPrimary',
)}
/>
</Swipeable>
)}
/>
</View>
</View>
</UiScreenScrollable>
)
} so, the current state is - if we use deprecated Swipeable - left action works. |
Any updates on this? also experiencing this on IOS. |
Having the same issue on iOS too. Any updates? |
I'm also having the same issue in |
You should be able to fix this issue by using Gesture Handler's Here's an example of how you might use Collapsed test codeimport React from 'react';
import { View, Text } from 'react-native';
import { Gesture, GestureDetector } from 'react-native-gesture-handler';
import Swipeable from 'react-native-gesture-handler/ReanimatedSwipeable';
export default function Example() {
const leftTap = Gesture.Tap().onStart(() => console.log('tap left'));
const rightTap = Gesture.Tap().onStart(() => console.log('tap right'));
const centerTap = Gesture.Tap().onStart(() => console.log('tap center'));
const innerTap = Gesture.Tap().onStart(() => console.log('tap inner'));
return (
<View style={{ flex: 1, marginTop: 200, backgroundColor: 'red' }}>
<Swipeable
onSwipeableOpen={(dir) => {
console.log('open', dir);
}}
onSwipeableClose={(dir) => {
console.log('close', dir);
}}
leftThreshold={50}
rightThreshold={50}
renderLeftActions={() => {
return (
<GestureDetector gesture={leftTap}>
<View
style={{ height: 80, width: 80, backgroundColor: 'yellow' }}>
<Text>Left</Text>
</View>
</GestureDetector>
);
}}
renderRightActions={() => {
return (
<GestureDetector gesture={rightTap}>
<View
style={{ height: 80, width: 80, backgroundColor: 'magenta' }}>
<Text>Right</Text>
</View>
</GestureDetector>
);
}}>
<GestureDetector gesture={centerTap}>
<View
style={{
width: '100%',
height: 80,
backgroundColor: 'blue',
}}>
<GestureDetector gesture={innerTap}>
<View
style={{
width: 80,
height: 80,
backgroundColor: 'white',
alignSelf: 'center',
}}
/>
</GestureDetector>
</View>
</GestureDetector>
</Swipeable>
</View>
);
} If you really have to use the |
It's still failing with v2.22.0 I just tested with @latekvo's suggest but no success |
Description
Trying with simple example, I faced next issue, I can't trigger onPress action on renderLeftActions, only renderRightActions works fine. Even if I momentarily swap the body of both, the problem persists.
This is working fine in v2.20.2, but something crashes in 2.21.0, 2.21.1 and 2.21.2.
Video.
Simulator.Screen.Recording.-.iPhone.16.Pro.-.2024-11-18.at.13.35.23.mp4
Steps to reproduce
Snack or a link to a repository
https://snack.expo.io/
Gesture Handler version
2.21.0, 2.21.1 and 2.21.2
React Native version
0.76.2
Platforms
iOS
JavaScript runtime
None
Workflow
React Native (without Expo)
Architecture
Fabric (New Architecture)
Build type
Debug mode
Device
iOS simulator
Device model
iPhone 16 Pro simulator
Acknowledgements
Yes
The text was updated successfully, but these errors were encountered: