3.3.3 • Published 9 months ago
@frknltrk/react-native-swipeable-deck v3.3.3
@frknltrk/react-native-swipeable-deck
A swipeable card deck component for React Native, perfect for creating game-like experiences with swipe gestures.
Features
- Support for swiping left and right
- Animated transitions for card scaling and movement
- Customizable swipe actions (e.g., disable left or right swipes)
- Easy integration with iOS and Android platforms
- Supports custom card rendering for maximum flexibility
Installation
Install the package using npm or yarn:
$ npm install @frknltrk/react-native-swipeable-deck
Or using yarn:
$ yarn add @frknltrk/react-native-swipeable-deck
Make sure you also have the following peer dependencies installed:
$ npm install react-native-gesture-handler react-native-reanimated
Basic Usage
Here’s a simple example of how to use the SwipeableDeck
component:
import React, { useState } from 'react';
import { Text, View } from 'react-native';
import SwipeableDeck from '@frknltrk/react-native-swipeable-deck';
const data = [
{ id: '1', text: 'Card 1' },
{ id: '2', text: 'Card 2' },
{ id: '3', text: 'Card 3' },
];
const App = () => {
const [currentIndex, setCurrentIndex] = useState(0);
const renderCard = (item) => (
<View style={{ padding: 20, backgroundColor: 'lightblue' }}>
<Text>{item.text}</Text>
</View>
);
return (
<SwipeableDeck
currentIndex={currentIndex}
setCurrentIndex={setCurrentIndex}
data={data}
renderCard={renderCard}
/>
);
};
export default App;
Props
Prop | Type | Description | Default |
---|---|---|---|
currentIndex | number | Index of the current card to be displayed. | 0 |
setCurrentIndex | (index: number) => void | Callback to update the current card index. | |
data | T[] | Array of data items for the deck. | [] |
renderCard | (item: T) => React.ReactNode | Function to render each card. | |
swipeLeftDisabled | boolean | Disables left swipe when set to true. | false |
swipeRightDisabled | boolean | Disables right swipe when set to true. | false |
backwardMoveDisabled | boolean | Disables backward movement (going to the previous card). | false |
actionsReversed | boolean | Reverses the swipe actions (left for next, right for previous). | false |
Example with Swipe Restrictions
<SwipeableDeck
currentIndex={currentIndex}
setCurrentIndex={setCurrentIndex}
data={data}
renderCard={renderCard}
swipeLeftDisabled={true} // Disable left swipe
swipeRightDisabled={false} // Allow right swipe
/>
Development
If you want to contribute or modify the package, you can run the example app:
$ npm run bootstrap
$ npm run example
To Do
- clamping
- trigger swipe animations through buttons
- add props: swipeLeftDisabled, swipeRightDisabled
- add props: backwardMoveDisabled, actionsReversed
Scripts
Command | Description |
---|---|
npm run test | Run tests using Jest |
npm run lint | Lint your code using ESLint |
npm run release | Create a new release using release-it |
License
This project is licensed under the MIT License. See the LICENSE file for more details.
Contributing
Feel free to submit issues and pull requests! Contributions are welcome.
Bugs & Feedback
If you encounter any issues or have suggestions for improvements, please open an issue on the GitHub Issues page.
Author
@frknltrk - Furkan Unluturk, also thanks to @aliefee for his contributions.