Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/halilb/rn-credit-card
https://github.com/halilb/rn-credit-card
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/halilb/rn-credit-card
- Owner: halilb
- License: mit
- Created: 2021-01-02T20:27:44.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2022-12-07T06:38:09.000Z (almost 2 years ago)
- Last Synced: 2024-07-20T12:05:09.094Z (2 months ago)
- Language: TypeScript
- Size: 7.07 MB
- Stars: 232
- Watchers: 11
- Forks: 66
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# React Native Credit Card
This is a fully functional and animated credit card form library, and it's ready to use 🚀
![horizontal demo](./assets/card-form-first-low.gif)
---
## Features
- Works on iOS and Android.
- Validations.
- Card icon animation with `Lottie`.
- Card flip animation with [react-native-card-flip](https://github.com/lhandel/react-native-card-flip).
- Possible to access all `react-hook-form` methods.
- TypeScript code base.
- Works on `Expo`.## Blog Post
This repository also contains my initial work of building a simple react native form with `react-hook-form` without any fancy animations. You may read it on my blog: [React Native Form Management Tutorial](https://bilir.me/blog/react-native-form-management-tutorial).
## Installation
Install the library first:
```
npm install rn-credit-card
// OR
yarn add rn-credit-card
```Install `react-hook-form`:
```
npm install react-hook-form
// OR
yarn add react-hook-form
```**Note**: The latest version of this project works with `react-hook-form` version `>7.0.0`. Stick with the version `0.2.0` if you'd like to use it with `react-hook-form: <7.0.0`:
```
npm install [email protected]
```You also need to install `lottie-react-native` if you want to display card icon animations. Please note that this is optional, and the library will display simple card icons if `Lottie` is not present:
```
npm install lottie-react-native
// OR
yarn add lottie-react-native
```If you'd like to use the library on Android, make sure you're using a `lottie-react-native` version greater than `3.0.0`. The animations are not working on `2.x.x` versions.
Additional steps might be needed depending on your platform. Please check [lottie-react-native documentation](https://github.com/lottie-react-native/lottie-react-native#installing-react-native--0600).
### Configuring Fonts
The library uses [Roboto Mono](https://fonts.google.com/specimen/Roboto+Mono) font by default. If you'd like to keep it that way, you need to import `RobotoMono_400Regular` and `RobotoMono_700Bold` fonts to your project. Please see [Expo](https://docs.expo.io/versions/latest/sdk/font/) or [this dev.to post](https://dev.to/aneeqakhan/add-custom-fonts-in-react-native-0-63-for-ios-and-android-3a9e) for more information.
You may also use custom fonts with this library. Please see [#fonts](#fonts) section.
## Usage
You need to create a `react-hook-form` and pass it down to the `CreditCardForm` through `FormProvider` context. This structure helps you accessing every propery and method of the form so you can build some features on top of the library.
The library is written in TypeScript, and types are also available out of the box. You may use `FormModel` to type your form.
Here is a fully functional example with `KeyboardAvodingView`, which manages the scroll position when keyboard is open.
```tsx
import React from 'react'
import { FormProvider, useForm } from 'react-hook-form'
import {
Alert,
StyleSheet,
KeyboardAvoidingView,
Platform,
SafeAreaView,
} from 'react-native'
import LottieView from 'lottie-react-native'
import CreditCardForm, { Button, FormModel } from 'rn-credit-card'const App: React.FC = () => {
const formMethods = useForm({
// to trigger the validation on the blur event
mode: 'onBlur',
defaultValues: {
holderName: '',
cardNumber: '',
expiration: '',
cvv: '',
},
})
const { handleSubmit, formState } = formMethodsfunction onSubmit(model: FormModel) {
Alert.alert('Success: ' + JSON.stringify(model, null, 2))
}return (
{formState.isValid && (
)}
)
}const styles = StyleSheet.create({
container: {
flex: 1,
},
avoider: {
flex: 1,
padding: 36,
},
button: {
margin: 36,
marginTop: 0,
},
})export default App
```If you are not using TypeScipt on your project, simply remove `FormModel` references from the example above.
## Available Props
### LottieView
This prop takes the default exported value of `lottie-react-native` library. This is optional because `Lottie` might require additional configuration steps. The library will display simple png card icons if this prop is not provided.
Please remember you need a `lottie-react-native` version greater than `3.x.x` to make it work on Android.
| type | default | required | platform |
| ---- | --------- | -------- | ----------- |
| any | undefined | NO | iOS/Android |Example:
```tsx
import LottieView from 'lottie-react-native'
;
```### horizontalStart
This makes the form start with a horizontal scroll. This is the default behaviour.
This feature is not working on Android due to a weird problem happening when the `ScrollView` is switched from `horizontal`.
| type | default | required | platform |
| ------- | ------- | -------- | -------- |
| boolean | true | NO | iOS only |This is the outcome when `horizontalStart` is `false`:
![vertical](./assets/card-form-second-low.gif)
### formOnly
When true, it hides the card view and displays the credit card form only.
| type | default | required | platform |
| ------- | ------- | -------- | ----------- |
| boolean | false | NO | iOS/Android |### backgroundImage
You may use this prop to replace the background image of the card preview.
| type | default | required | platform |
| --------------- | --------- | -------- | ----------- |
| React.ReactNode | undefined | NO | iOS/Android |Example:
```tsx
}
/>
```### fonts
`fonts` props take an object with two fields:
| field | type | default | required |
| ------------- | ------ | --------------------- | -------- |
| fonts.regular | string | RobotoMono_400Regular | NO |
| fonts.bold | string | RobotoMono_700Bold | NO |Please note that you should use a [Monospaced font](https://en.wikipedia.org/wiki/Monospaced_font) for the best user experience. The fixed width helps maintaining the same card number width while the user types.
Example:
```tsx
```
### inputColors
You may modify the `TextInput` colors using this. It's an object with three optional fields:
| field | type | default | required |
| ------- | ------ | ------- | -------- |
| focused | string | #080F9C | NO |
| errored | string | #B00020 | NO |
| regular | string | #B9C4CA | NO |Example:
```tsx
```
### translations
An optional object that takes a string for each displayed text on the library. You may use it to modify any or all of those displayed texts.
| type | default | required | platform |
| ------------ | --------- | -------- | ----------- |
| Translations | undefined | NO | iOS/Android |Example:
```tsx
```
### overrides
This props might be used to override some component styles within the library. All fields are optional.
| field | type |
| ----------------- | ---------------------- |
| cardPreview | ViewStyle or TextStyle |
| labelText | TextStyle |
| cardHolderPreview | TextStyle |
| expirationPreview | ViewStyle or TextStyle |
| outline | ViewStyle |
| input | ViewStyle |
| labelContainer | ViewStyle |
| inputLabel | TextStyle |
| errorText | TextStyle |### requiresName
An optional prop that allows you to hide the cardholder Name from both the form and the card view.
When false, it hides the CardHolder Name field.| type | default | required | platform |
| ------------ | --------- | -------- | ----------- |
| boolean | true | NO | iOS/Android |Example
```tsx```
## Credits
- The design is from [Pawel Szymankiewicz](https://dribbble.com/shots/6440077-Add-a-New-Credit-Card-alternate-flow).
- Card icon animations are from [Tim John](https://lottiefiles.com/timjohn).## Licence
[MIT](http://opensource.org/licenses/mit-license.html)