- Android minimum SDK 16
// project gradle file
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
// module gradle file
dependencies {
implementation 'com.android.support:design:27.1.1'
implementation 'com.google.code.gson:gson:2.8.5'
implementation 'com.android.volley:volley:1.1.0'
implementation 'com.github.checkout:frames-android:v2.0.6'
}
You can find more about the installation here
Please keep in mind that the Jitpack repository should to be added to the project gradle file while the dependency should be added in the module gradle file. (see more about gradle files)
Step1 Add the module to your XML layout.
<com.checkout.android_sdk.PaymentForm
android:id="@+id/checkout_card_form"
android:layout_width="match_parent"
android:layout_height="match_parent"
/>
Step2 Include the module in your class.
private PaymentForm mPaymentForm; // include the payment form
Step3 Create a callback for the Payment Form.
PaymentFormCallback mFormListener = new PaymentFormCallback() {
@Override
public void onFormSubmit() {
// form submit initiated; you can potentially display a loader
}
@Override
public void onTokenGenerated(CardTokenisationResponse response) {
// your token is here
mPaymentForm.clearForm(); // this clears the Payment Form
}
@Override
public void onError(CardTokenisationFail response) {
// token request error
}
@Override
public void onNetworkError(VolleyError error) {
// network error
}
@Override
public void onBackPressed() {
// the user decided to leave the payment page
mPaymentForm.clearForm(); // this clears the Payment Form
}
};
Step4 Initialise the module
// initialise the payment from
mPaymentForm = findViewById(R.id.checkout_card_form);
mPaymentForm
.setSubmitListener(mSubmitListener) // set the callback
.setEnvironment(Environment.SANDBOX) // set the environemnt
.setKey("pk_xxx"); // set your public key
Step1 Include the module in your class.
private CheckoutAPIClient mCheckoutAPIClient; // include the module
Step2 Create a callback.
CheckoutAPIClient.OnTokenGenerated mTokenListener = new CheckoutAPIClient.OnTokenGenerated() {
@Override
public void onTokenGenerated(CardTokenisationResponse token) {
// your token
}
@Override
public void onError(CardTokenisationFail error) {
// your error
}
@Override
public void onNetworkError(VolleyError error) {
// your network error
}
};
Step3 Initialise the module and pass the card details.
mCheckoutAPIClient = new CheckoutAPIClient(
this, // context
"pk_XXXXX", // your public key
Environment.SANDBOX // the environment
);
mCheckoutAPIClient.setTokenListener(mTokenListener); // pass the callback
// Pass the paylod and generate the token
mCheckoutAPIClient.generateToken(
new CardTokenisationRequest(
"4242424242424242",
"name",
"06",
"25",
"100",
new BillingModel(
"address line 1",
"address line 2",
"postcode",
"UK",
"city",
"state",
new PhoneModel(
"+44",
"07123456789"
)
)
)
);
The module extends a Frame Layout so you can use XML attributes like:
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@colors/your_color"
Moreover, the module inherits the Theme.AppCompat.Light.DarkActionBar style so if you want to customise the look of the payment form you can define you own style and theme the module with it:
<style name="YourCustomTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<!-- TOOLBAR COLOR. -->
<item name="colorPrimary">#000000</item>
<!--FIELDS HIGHLIGHT COLOR-->
<item name="colorAccent">#000000</item>
<!--PAY/DONE BUTTON COLOR-->
<item name="colorButtonNormal">#000000</item>
<!--HELPER LABELS AND UNSELECTED FIELD COLOR-->
<item name="colorControlNormal">#000000</item>
<!--FONT FAMILY-->
<item name="android:fontFamily">@font/myFont</item>
</style>
...
<com.example.android_sdk.PaymentForm
android:id="@+id/checkout_card_form"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:theme="@style/YourCustomTheme"/>
If you would like to customise the helper labels of the payment form fields you can use the following method:
mPaymentForm
...
.setAcceptedCardsLabel("We accept this card types")
.setCardHolderLabel("Name on Card")
.setCardLabel("Card Number")
.setDateLabel("Expiration Datee")
.setCvvLabel("Security Code")
.setAddress1Label("Address 1")
.setAddress2Label("Address 2")
.setTownLabel("City")
.setStateLabel("State")
.setPostcodeLabel("Zip Code")
.setPhoneLabel("Phone No.")
If you would like to allow users to input their billing details when completing the payment form, you can simply use the following method:
mPaymentForm
...
.includeBilling(true); // false value will hide the option
If you want to display a limited array of accepted card types you can select them in the following way:
mPaymentForm
...
.setAcceptedCard(new Cards[]{VISA, MASTERCARD});
If you target a specific region, and would like to set a default country for the billing details you can use the following:
mPaymentForm = findViewById(R.id.checkout_card_form);
mPaymentForm
...
.setDefaultBillingCountry(Locale.UK) // the parameter needs to be a Locale country object
If you collected the customer name and you would like to pre-populate it in the billing details, you can use the following:
mPaymentForm = findViewById(R.id.checkout_card_form);
mPaymentForm
...
.injectCardHolderName("John Smith")
If you collected the address details from the customer prior to the payment page, you can inject the details, to avoid the customer re-entering them:
mPaymentForm = findViewById(R.id.checkout_card_form);
mPaymentForm
...
.injectBilling(
new BillingModel(
"1 address",
"2 address",
"POST CODE",
"GB",
"City",
"State",
new PhoneModel(
"+44",
"07123456789"
)
)
);
If you want to customise the buttons in the Payment From you have the following options :
mPaymentForm = findViewById(R.id.checkout_card_form);
mPaymentForm
...
.setPayButtonText("Pay Now") // Pay button text; dafault "Pay"
.setDoneButtonText("Save") // Done button text on the billing address page; dafault "Done"
.setClearButtonText("Clear") // Clear button text on the billing address page; dafault "Clear"
.setPayButtonLayout(params) // LayoutParams for the Pay button
.setDoneButtonLayout(params) // LayoutParams for the Done button
.setClearButtonLayout(params) // LayoutParams for the Clear button
The module allows you to handle 3DSecure URLs within your mobile app. Here are the steps:
When you send a 3D secure charge request from your server you will get back a 3D Secure URL. You can then pass the 3D Secure URL to the module, to handle the verification.
Step1 Create a callback.
PaymentForm.On3DSFinished m3DSecureListener =
new PaymentForm.On3DSFinished() {
@Override
public void onSuccess(String token) {
// success
}
@Override
public void onError(String errorMessage) {
// fail
}
};
Step2 Pass the callback to the module and handle 3D Secure
mPaymentForm = findViewById(R.id.checkout_card_form);
mPaymentForm.set3DSListener(m3DSecureListener); // pass the callback
mPaymentForm.handle3DS(
"https://sandbox.checkout.com/api2/v2/3ds/acs/687805", // the 3D Secure URL
"http://example.com/success", // the Redirection URL
"http://example.com/fail" // the Redirection Fail URL
);
Keep in mind that the Redirection and Redirection Fail URLs are set in the Checkout Hub, but they can be overwritten in the charge request sent from your server. It is important to provide the correct URLs to ensure a successful payment flow.
The module allows you to handle a Google Pay token payload and retrieve a token, that can be used to create a charge from your backend.
Step1 Create a callback.
CheckoutAPIClient.OnGooglePayTokenGenerated mGooglePayListener =
new CheckoutAPIClient.OnGooglePayTokenGenerated() {
@Override
public void onTokenGenerated(GooglePayTokenisationResponse response) {
// success
}
@Override
public void onError(GooglePayTokenisationFail error) {
// fail
}
@Override
public void onNetworkError(VolleyError error) {
// your network error
}
};
Step2 Pass the callback to the module and generate the token
mCheckoutAPIClient = new CheckoutAPIClient(
context, // activity context
"pk_XXXXX", // your public key
Environment.SANDBOX // the environment
);
mCheckoutAPIClient.setGooglePayListener(mGooglePayListener); // pass the callback
mCheckoutAPIClient.generateGooglePayToken(payload); // the payload is the JSON string generated by GooglePay
When dealing with actions like generating a card token the callback will include the following objects.
For success -> CardTokenisationResponse
With the following getters:
response.getId(); // the card token
response.getLiveMode(); // environment mode
response.getCreated(); // timestamp of creation
response.getUsed(); // show usage
response.getCard(); // card object containing card information and billing details
For error -> CardTokenisationResponse
With the following getters:
error.getEventId(); // a unique identifier for the event
error.getMessage(); // the error message
error.getErrorCode(); // the error code
error.getErrorMessageCodes(); // an array or strings with all error codes
error.getErrors(); // an array or strings with all error messages
When dealing with actions like generating a token for a Google Pay payload the callback will include the following objects.
For success -> GooglePayTokenisationResponse
With the following getters:
response.getToken(); // the token
response.getExpiration(); // the token exiration
response.getType(); // the token type
For error -> GooglePayTokenisationFail
With the following getters:
error.getRequestId(); // a unique identifier for the request
error.getErrorType(); // the error type
error.getErrorCodes(); // an array of strings with all the error codes
frames-android is released under the MIT license.