How to create Tinder Cards in ReactJs
The app has created a sensation using its card and swipe functionality. Many of us try to create tinder cards and swipe effects and end up writing a lot of code. This problem is solved by ReactJs (one of the most popular library trending now).
In this article, we will work with the react package which allows us to create tinder cards with swipe functionality
Command to install package is:
npm install react-tinder-card
Let's start by creating a react app
npx create-react-app tinder-cards
cd tinder-cards
npm install react-tinder-card
npm start
Once the react app is up and running, we can create a data file to be rendered in tinder cards.
data.js
Now create tinder cards in the app.js file
if we break down the code:
First, we have to import a tinder card.
Now we can create a TinderCard component that contains props to be passed
- className: Default prop which every component has.
- preventSwipe : As Tinder Card provides swipe functionality in all four directions (left, right, up, down). If we want to block any direction we can just pass the array in these props. As we have passed [‘up’,’ down’] which restricts the swipe in these two directions. It's an optional parameter
- onSwipe : A callback function that will be executed when the card is swiped. It passes the direction in which the card was swiped in the argument. It is also an optional parameter. As in the above code swiped() is called on swiped and direction is passed in an argument which is then printed in console log as in output screen below.
- onCardLeftScreen: A callback function executed which is executed when the card has left the screen. As in the above code leftScreen() is called on which card has left the screen and temporary output is printed in the console log
- In the End, elements are rendered in Tinder Card on which this functionality is to be applied.
Creating Tinder Cards based on data.js
Now we will import data using the useEffect() hook and will create Tinder Cards accordingly.
Apart from static data, dynamic data from the database can also be fetched in useEffect() hook.
Code Breakdown:
- useEffect hook is called at first and the state is updated with data fetched from the data.js file. Here data can be fetched from API also.
- Here the preventSwipe is commented so Tinder Card can be swiped in all directions.
- onSwipe: swiped function is called on a swipe of Tinder Card and direction is checked(left or right) and based on that it is checked whether the user liked the image or not and basis on that different states are updated using useState hook.
Conclusion
The simple React package allows us to create real-world functionality.
The two callback function allows us to write business logic about what should be done on different swipe direction.
Source code of this project can be found on this GitHub link