An Expo module for integrating Datatrans Payment Service Provider (PSP) into your Expo applications.
expo-datatrans
provides a seamless native bridge to implement Datatrans payment solutions in Expo-powered mobile
applications.
Datatrans is one of the leading Swiss Payment Service Provider (PSP), offering secure and reliable payment processing services.
Install the module using Expo CLI:
bunx expo install expo-datatrans
- Seamless integration with the Datatrans payment gateway
- Native implementation for iOS and Android
- TypeScript support with included type definitions
- Built specifically for the Expo ecosystem
Import the module into your JavaScript/TypeScript code:
import ExpoDatatrans from 'expo-datatrans';
Example: Processing a Payment
import ExpoDatatrans, {Options, PaymentMethodType, TransactionResult} from 'expo-datatrans';
import {Button, View} from 'react-native';
export default function Index() {
const handleTransaction = async () => {
try {
const options: Options = {
aliasPaymentMethods: [
{
alias: '...',
ccNumber: '...',
expiryMonth: 12,
expiryYear: 2024,
paymentMethod: PaymentMethodType.VISA,
},
],
isTesting: true,
isUseCertificatePinning: false,
appCallbackScheme: 'myapp',
googlePayConfig: {
merchantId: 'YOUR_GOOGLE_MERCHANT_ID',
supportedNetworks: [PaymentMethodType.MASTERCARD, PaymentMethodType.VISA],
},
samsungPayConfig: {
merchantId: 'YOUR_SAMSUNG_MERCHANT_ID',
supportedNetworks: [PaymentMethodType.MASTERCARD, PaymentMethodType.VISA],
},
applePayConfig: {
merchantId: 'YOUR_APPLE_MERCHANT_ID',
supportedNetworks: [PaymentMethodType.MASTERCARD, PaymentMethodType.VISA],
},
};
const result: TransactionResult = await ExpoDatatrans.transaction('mobileToken123', options);
if (result.type === 'success') {
console.log('✅ Transaction Success:', result);
}
} catch (error) {
console.error('❌ Transaction Error:', error);
}
};
return (
<View>
<Button title="Start Payment" onPress={handleTransaction} />
</View>
)
}
- Written in TypeScript to provide a smooth development experience with full type safety.
- Includes robust support for both iOS and Android platforms.
- Supports alias-based payment methods and additional customization options.
Type Definitions
The following key types are included for ease of integration:
This project is licensed under the MIT License.
Contributions are welcome! Feel free to submit issues, feature requests, or pull requests on the GitHub repository.