react-native-swipeable icon indicating copy to clipboard operation
react-native-swipeable copied to clipboard

Does recenter() work with RN 0.49?

Open quangas opened this issue 8 years ago • 10 comments

I cannot for some reason get the recenter() to fire or do anything.

this.swipeable = null;

const rightButtons = [<TouchableOpacity onPress={() => this.swipeable.recenter()}><Text>Recenter Me</Text></TouchableOpacity>]

<Swipeable onRef={ref => this.swipeable = ref} rightButtons={rightButtons}> ... <Swipeable/>

Any ideas why this would not work? Does onRef actually work with RN0.49? Anyone on RN0.49 that has this Swipeable recenter() working?

quangas avatar Oct 18 '17 02:10 quangas

Did you get it working? @quangas otherwise, make sure you're declaring rightButtons inside the same class as your <Swipeable /> is in.

albinekb avatar Jan 08 '18 19:01 albinekb

Yes , recenter not working. How to recenter. can any body help ?

` swipeable = null;

recenter = () => {
    this.swipeable.recenter();
}

render() {
    return (
        (this.props.user.name.toLowerCase().includes(this.props.search) || this.props.user.number.includes(this.props.search)) ?
            <View>
                <Swipeable leftActionActivationDistance={30} leftButtonWidth={30} onLeftActionRelease={() => { console.log('call'); this.recenter() }} rightActionActivationDistance={30} rightButtonWidth={30} onRightActionRelease={() => { console.log('message'); }} onRef={ref => this.swipeable = ref} leftContent={leftContent} rightButtons={rightButtons}>
                    <View style={styles.container}>
                        {
                            (this.props.user.avatar) ?
                                <Image
                                    source={{ uri: this.props.user.avatar }}
                                    style={styles.photo}
                                /> :
                                <Image source={{ uri: '' }} style={styles.photo} />
                        }
                        <Text style={styles.text}>
                            {this.props.user.name}
                        </Text>
                    </View>
                </Swipeable>
                <Seperator />
            </View>
            :
            <View></View>
    );
}

}`

memePushpendu avatar Apr 22 '18 11:04 memePushpendu

Any updates on this? I'm currently using RN .55.3 and can't get recenter() to work. As I understand it- if I have a row of rightbuttons open on swipe, this.swipeable.recenter() is what will ultimately get it to close onPress. Is there another way of getting the swipe row to close on press?

JsonLitz avatar Oct 31 '18 20:10 JsonLitz

Also looking for a solution. Swipeable is neither recognized nor does recenter do anything.

Did either of you figure it out? @JsonLitz @quangas

nsbruce avatar Dec 06 '18 16:12 nsbruce

@nsbruce - did you solve the issue? or any workaround?

jifromz09 avatar Jan 11 '19 09:01 jifromz09

I would recommend to switch to https://kmagiera.github.io/react-native-gesture-handler/docs/component-swipeable.html it's more modern approach to touch interactions with RN. @jifromz09 @nsbruce

albinekb avatar Jan 11 '19 12:01 albinekb

@jifromz09 I ended up using native-bases SwipeRow which met my needs. I never got this swipeable working.

nsbruce avatar Jan 11 '19 18:01 nsbruce

@nsbruce Does native-base support recenter? And what are the methods it supports?

Yandamuri avatar Jan 19 '19 09:01 Yandamuri

@Yandamuri This is how I handled closing rows.

https://stackoverflow.com/questions/49630494/closing-swiperow-inside-flatlist-using-native-base

nsbruce avatar Jan 23 '19 17:01 nsbruce

@nsbruce Great!. This example gave idea to solve my problem. Thank you so much.

Yandamuri avatar Jan 24 '19 05:01 Yandamuri