Swipe cards simulating Tinder interface
The goal of react-native-tinder-swipe is that you also can set custom components to be rendered as card's content.
- Smooth enter/exit animations
- Set or hide custom positive/negative labels
- Tracking of swipe left, swipe right and not swipe events
- Allow to block X or Y translations
- Allows set custom components as card content and labels
- Swipeable
This library is not available on npm or yarn yet, it isn't even done, test it with the following steps:
Clone the repository:
git clone https://github.com/pedrorosarioo/react-native-tinder-swipe.git
Move to repository folder and run:
npm install
or
yarn install
First you're gonna have to open your virtual device or connect your phone on the computer. Then go back to the terminal, open the project's folder and run:
Case iOS device: react-native run-ios
Case Android device: react-native run-android
The following example consists in the App.tsx component, wich renders only the TinderSwipe component. The TinderSwipe component, until now, have just one required property: data. It's a payload used for it renders the cards.
import React, {Component} from 'react';
import { StyleSheet,View } from 'react-native';
import TinderSwipe from './src';
import mock from './src/assets/mock';
interface Props {}
export default class App extends Component<Props> {
public render() {
return (
<View style={styles.container}>
<TinderSwipe data={mock} />
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
justifyContent: 'space-between',
alignItems: 'center',
},
});
The property data expects an array of CardInfo type:
export interface CardInfo {
name: string;
profileImage: ImageSourcePropType;
age: number;
custom?: {
mainComponent: () => React.ReactNode;
positiveLabelComponent: () => React.ReactNode;
negativeLabelComponent: () => React.ReactNode;
};
}
Name | Type | Default | Description |
---|---|---|---|
data | CardInfo[] | [] | Payload that TinderSwipe expects. If it has custom attribute, so it will render your custom component even if it have the default attributes |
onSwipeLeft | (CardInfo) => void | --- | Event that is fired when user swipes to left a card |
onSwipeRight | (CardInfo) => void | --- | Event that is fired when user swipes to right a card |
onNotSwipe | (CardInfo) => void | --- | Event that is fired when user return a card for it's default position |
onSwipeHasDone | (CardInfo) => void | --- | Event that is fired when swipe animation ends |
blockX | bool | false | Block moves that translate the card horizontaly |
blockY | bool | false | Block moves that translate the card vertically |
blockZ | bool | false | Block card rotation |
disableSwipe | bool | false | Block all moves removing the panHandlers |
push( CardInfo[] ):
Insert new values on the bottom of the stack.
private _onPush = () => {
this.setState({index: this.state.index+1});
if (this.state.index < 40) {
this._tinderSwipe!.push([
{
name: `PUSHED CARD ${this.state.index}`,
age: 25, profileImage: require('./src/assets/image1.jpg')
},
{
name: `PUSHED CARD ${this.state.index}`,
age: 25, profileImage: require('./src/assets/image1.jpg')
}
]);
}
}
Get tinderSwipe reference and use onPush function in an event (onSwipeLeft in this case):
<TinderSwipe
ref={(ref) => this._tinderSwipe = ref}
data={this._data}
onSwipeLeft={() => this._onPush()}
blockY
/>
Removes the card on top of stack. If liked, it will swipe right, otherwise, it will swipe left.
Get TinderSwipe ref:
<TinderSwipe
ref={(ref) => this._tinderSwipe = ref}
data={this._data}
/>
Then use pop method to create buttons that controlls swipe right and swipe left:
<TouchableOpacity onPress={() => this._tinderSwipe!.pop()}>
<Text>SWIPE LEFT</Text>
</TouchableOpacity>
<TouchableOpacity onPress={() => this._tinderSwipe!.pop(true)}>
<Text>SWIPE RIGHT</Text>
</TouchableOpacity>
OBS: As soon as possible tinderSwipe gonna stop being a class component to use react hooks. PR's are welcome! :)
Thanks for the visit!
Pull requests, feedbacks and suggestions are welcome!
MIT License. © Pedro Rosário