🇺🇦 Stand with Ukraine against the Russian invasion. If you want to help, consider donating to Come Back Alive or United24.
An Expo module wrapping Apple's ProximityReaderDiscovery API to present Tap to Pay on iPhone education screens.
iOS 18.0+ only.
Before using this module, you must complete Apple's Tap to Pay setup. Without these steps, the app will not compile or will crash at runtime with a sandbox restriction error.
- Follow the Tap to Pay on iPhone program guide to request access and configure your developer account.
- Read the Human Interface Guidelines for Tap to Pay on iPhone to ensure your integration meets Apple's design requirements.
- Add the entitlement
com.apple.developer.proximity-reader.payment.acceptanceto your app (see Integration below). - Enable the Tap to Pay on iPhone capability on your App ID in Certificates, Identifiers & Profiles and regenerate your provisioning profile.
The Tap to Pay on iPhone entitlement runs in sandbox mode by default, which is sufficient for development.
For TestFlight and App Store distribution, you must:
- Request production mode access from Apple through the Tap to Pay on iPhone program.
- Complete Apple's deployment checklist for Tap to Pay production here : checklist.
- Ensure your provisioning profiles are configured for production entitlements.
Without production access, ProximityReaderDiscovery will throw errors in TestFlight builds.
npx expo install @nitrique/rn-proximity-reader-discoveryimport { presentTapToPayEducation } from "@nitrique/rn-proximity-reader-discovery";
try {
await presentTapToPayEducation();
} catch (error) {
// Handle errors (iOS < 18.0, missing entitlement, etc.)
console.error(error);
}npx expo install @nitrique/rn-proximity-reader-discoveryIn your app.json (or app.config.js):
{
"expo": {
"ios": {
"entitlements": {
"com.apple.developer.proximity-reader.payment.acceptance": true
},
"infoPlist": {
"CFBundleLocalizations": [
"en", "fr", "de", "es", "it", "pt", "ja", "ko",
"zh-Hans", "zh-Hant", "ar", "nl", "pl", "sv",
"da", "fi", "nb", "th", "vi", "id", "tr", "ru"
]
}
}
}
}The CFBundleLocalizations array tells iOS which languages your app supports. Apple's education screens are localized automatically but will only display in the device's language if it is listed here. Add all languages relevant to your user base.
Since this module includes native code, you need a native rebuild:
npx expo prebuild --clean
npx expo run:iosimport { presentTapToPayEducation } from "@nitrique/rn-proximity-reader-discovery";
import { Alert, Button } from "react-native";
function TapToPaySetup() {
const handleEducation = async () => {
try {
await presentTapToPayEducation();
} catch (error: any) {
Alert.alert("Error", error.message);
}
};
return <Button title="Learn about Tap to Pay" onPress={handleEducation} />;
}Presents Apple's system-provided education sheet explaining how to accept contactless payments using Tap to Pay on iPhone.
- Returns:
Promise<void>— resolves when the user dismisses the sheet. - Throws: if iOS < 18.0, the entitlement is missing, or the content cannot be displayed.
Need help integrating Tap to Pay on iPhone into your React Native app, or looking for expert mobile development? Visit nitrique.fr for consulting and development services.
MIT