Skip to content

pedrorosarioo/react-native-tinder-swipe

Repository files navigation

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.



Features

  • 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

Setup

This library is not available on npm or yarn yet, it isn't even done, test it with the following steps:

Step 1: Installing the project

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

Step 2: Running the project

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

Usage

A complete example

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;
    };
}

Available props

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

Methods

push( CardInfo[] ):

Insert new values on the bottom of the stack.

Example:

  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
  />

pop( liked?: boolean ):

Removes the card on top of stack. If liked, it will swipe right, otherwise, it will swipe left.

Example:

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! :)

Acknowledgements

Thanks for the visit!

Pull requests, feedbacks and suggestions are welcome!

License

MIT License. © Pedro Rosário

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published