Currently in beta please contact to get early access
Use this guide to integrate hyper SDK to your React Native app. You can use the following Demo App as a reference with your PaySwitcher credentials to test the setup.
Before following these steps, please configure your payment methods.
Add an endpoint on your server that creates a Payment. Creating a Payment helps to establish the intent of the customer to start a payment. It also helps to track the customer’s payment lifecycle, keeping track of failed payment attempts and ensuring the customer is only charged once. Return the client_secret obtained in the response to securely complete the payment on the client.
// Create a Payment with the order amount and currency
app.post("/create-payment", async (req, res) => {
try {
const paymentIntent = await hyper.paymentIntents.create({
currency: "USD",
amount: 100,
});
// Send publishable key and PaymentIntent details to client
res.send({
clientSecret: paymentIntent.client_secret,
});
} catch (err) {
return res.status(400).send({
error: {
message: err.message,
},
});
}
});
2. Build checkout page on the client
2.1 Install the react-native-payswitcher libraries
In the Android Folder inside settings.gradle file add the following line
include(":react-native-code-push");
project(":react-native-code-push").projectDir = new File(
rootProject.projectDir,
"../node_modules/react-native-code-push/android/app"
);
2.5 Add HyperProvider to your React Native app
Use HyperProvider to ensure that you stay PCI compliant by sending payment details directly to PaySwitcher server.
import { HyperProvider } from "@payswitcher/react-native-payswitcher";
2.6 Use HyperProvider
To initialize PaySwitcher in your React Native app, wrap your payment screen with the HyperProvider component. Only the API publishable key in publishableKey is required. The following example shows how to initialize PaySwitcher using the HyperProvider component.
import { HyperProvider } from "@payswitcher/react-native-payswitcher ";
function App() {
return (
<HyperProvider publishableKey="YOUR_PUBLISHABLE_KEY">
// Your app code here
</HyperProvider>
);
}
3. Complete the checkout on the client
3.1 import useHyper to your checkout page
In the checkout of your app, import useHyper() hook
import { useHyper } from "@payswitcher/react-native-payswitcher";
3.2 Fetch the PaymentIntent client Secret
Make a network request to the backend endpoint you created in the previous step. The clientSecret returned by your endpoint is used to complete the payment.
To display the Payment Sheet, integrate a "Pay Now" button within the checkout page, which, when clicked, invokes the presentPaymentSheet() function. This function will return an asynchronous payment response with various payment status.
const openPaymentSheet = async () => {
const status = await presentPaymentSheet(paymentSession);
console.log("presentPaymentSheet response: ", status);
const { error, paymentOption } = status;
if (error) {
switch (error.code) {
case "cancelled":
Alert.alert("cancelled", `PaymentSheet was closed`);
break;
case "failed":
Alert.alert("failed", `Payment failed`);
break;
default:
Alert.alert("status not captured", "Please check the integration");
break;
}
Alert.alert(`Error code: ${error.code}`, error.message);
} else if (paymentOption) {
switch (paymentOption.label) {
case "succeeded":
Alert.alert("succeeded", `Your order is succeeded`);
break;
case "requires_capture":
Alert.alert("requires_capture", `Your order is requires_capture`);
break;
default:
Alert.alert("status not captured", "Please check the integration");
break;
}
} else {
Alert.alert("Something went wrong", "Please check the integration");
}
};
return (
<Screen>
<Button variant="primary" title="Checkout" onPress={openPaymentSheet} />
</Screen>
);
Congratulations! Now that you have integrated the payment sheet
Before creating a payment, import the hyper dependencies and initialize it with your API key. Get your API key from .