React Native wrapper for the Stripe Terminal SDK. (iOS & Android compatible!)
First, follow all Stripe instructions under "Install the iOS SDK" and/or "Install the Android SDK" (depending on your platform). Then:
$ npm install git+https://github.com/theopolisme/react-native-stripe-terminal.git --save
$ react-native link react-native-stripe-terminal
- In XCode, in the project navigator, right click
Libraries
➜Add Files to [your project's name]
- Go to
node_modules
➜react-native-stripe-terminal
and addRNStripeTerminal.xcodeproj
- In XCode, in the project navigator, select your project. Add
libRNStripeTerminal.a
to your project'sBuild Phases
➜Link Binary With Libraries
- Run your project (
Cmd+R
)
- Open up
android/app/src/main/java/[...]/MainApplication.java
- Add
import com.reactlibrary.RNStripeTerminalPackage;
to the imports at the top of the file - Add
new RNStripeTerminalPackage()
to the list returned by thegetPackages()
method
- Append the following lines to
android/settings.gradle
:include ':react-native-stripe-terminal' project(':react-native-stripe-terminal').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-stripe-terminal/android')
- Insert the following lines inside the dependencies block in
android/app/build.gradle
:compile project(':react-native-stripe-terminal')
The StripeTerminal
object is a singleton. You must first call StripeTerminal.initialize
and provide a function to fetch the connection token (see Stripe docs).
import StripeTerminal from 'react-native-stripe-terminal';
// First, initialize the SDK
StripeTerminal.initialize({
fetchConnectionToken: () => {
return fetch('https://your.endpoint/terminal', { method: 'POST' })
.then(resp => resp.json())
.then(data => data.secret);
}
});
// Add a listener to handle when readers are discovered.
// You could display the readers to the user to select, or just
// auto-connect to the first available reader.
StripeTerminal.addReadersDiscoveredListener(readers => {
if (readers.length) {
StripeTerminal.connectReader(readers[0].serialNumber)
.then(() => {
// reader is connected
// now safe to call `StripeTerminal.createPaymentIntent`
});
}
});
// When you're ready, scan for readers
StripeTerminal.discoverReaders(
StripeTerminal.DeviceTypeChipper2X,
StripeTerminal.DiscoveryMethodBluetoothProximity);
// After a reader is connected, create a payment intent.
//
// Note: In `react-native-stripe-terminal`, `createPayment`
// abstracts `createPaymentIntent`, collectPaymentMethod`, and
// `confirmPaymentIntent` into a single method. If any of them fail,
// the Promise will be rejected. A resolved promise means that the
// payment was authorized & posted to Stripe and awaits capture.
StripeTerminal.createPayment({ amount: 1200, currency: "usd" })
.then(intent => {
console.log('Payment intent created', intent);
})
.catch(error => {
console.log(error);
});
// You can use the following listeners to update your interface with
// instructions for the user.
const waitingListener = StripeTerminal.addDidBeginWaitingForReaderInputListener(text => {
// `text` is a string of instructions, like "Swipe / Tap / Dip".
this.setState({ displayText: text });
});
const inputListener = StripeTerminal.addDidRequestReaderInputPrompt(text => {
// `text` is a prompt like "Retry Card".
this.setState({ displayText: text });
});
// Make sure you remove the listeners when you're done
// (e.g. in componentWillUnmount).
waitingListener.remove();
inputListener.remove();
If you're running React Native ^0.59 / React ^16.8.0, you can use Hooks to seamlessly integrate Stripe Terminal into your React Native application.
import StripeTerminal, { useStripeTerminal, useStripeTerminalCreatePayment } from 'react-native-stripe-terminal';
// Somewhere early in your application...
StripeTerminal.initialize({
fetchConnectionToken: () => {
return fetch('https://your.endpoint/terminal', { method: 'POST' })
.then(resp => resp.json())
.then(data => data.secret);
}
});
// Then, inside your components...
function PaymentScreen() {
const {
connectionStatus,
connectedReader,
paymentStatus,
cardInserted,
readerInputOptions,
readerInputPrompt
} = useStripeTerminalState();
}
// And when you're finally read to *collect* a payment...
function CollectPaymentScreen() {
const {
connectionStatus,
connectedReader,
paymentStatus,
cardInserted,
readerInputOptions,
readerInputPrompt
} = useStripeTerminalCreatePayment({
amount: 123,
description: "Test payment",
onSuccess: result => {
Alert.alert("Payment received", JSON.stringify(result));
},
onFailure: err => {
Alert.alert("Failed to create payment", JSON.stringify(err));
}
});
}