This repo is deprecated. All "button" related improvements have been merged into the Android SDK repo. Migration is as simple as updating Maven artifact to latest release. The afterpay-android-button
Maven artifact will no longer be updated or supported.
The Afterpay Android SDK makes it quick and easy to provide an excellent payment experience in your Android app. We provide powerful and customizable UI elements that can be used out-of-the-box to allow your users to shop now and pay later.
Documentation for usage can be found here, including the getting started guide and UI component docs.
Add afterpay-android-button
to your build.gradle
dependencies.
dependencies {
implementation 'com.afterpay:afterpay-android-button:4.3.0'
}
Launch the Afterpay checkout v3 flow by starting the intent provided by the SDK for the given options.
The activity result returns a CheckoutV3Data
with the information required to complete the merchant transaction, as well as the tokens required by Afterpay.updateMerchantReferenceV3|Async
.
class ExampleActivity: Activity {
private companion object {
const val CHECKOUT_WITH_AFTERPAY = 1234
}
override fun onCreate(savedInstanceState: Bundle?) {
// ...
val afterpayCheckoutButton = findViewById<Button>(R.id.button_afterpay)
afterpayCheckoutButton.setOnClickListener {
val options = Afterpay.createCheckoutV3Intent(
requireContext(),
consumer = // `CheckoutV3Consumer` interface
orderTotal = OrderTotal(
total = BigDecimal.ZERO,
shipping = BigDecimal.ZERO,
tax = BigDecimal.ZERO
)
items = // Optional `List<CheckoutV3Item>`
buyNow = command.buyNow // Changes checkout button title from 'Confirm' to 'Buy Now'
)
startActivityForResult(intent, CHECKOUT_WITH_AFTERPAY)
}
}
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
// ...
when (requestCode to resultCode) {
CHECKOUT_WITH_AFTERPAY to AppCompatActivity.RESULT_OK -> {
val intent = checkNotNull(data) {
"Intent should always be populated by the SDK"
}
// `CheckoutV3Data` containing values required
val resultData = checkNotNull(Afterpay.parseCheckoutSuccessResponseV3(intent)) {
"Result data is always associated with a successful V3 Afterpay transaction"
}
findNavController().navigate(
nav_graph.action.to_details_v3,
bundleOf(nav_graph.args.result_data_v3 to resultData)
)
}
CHECKOUT_WITH_AFTERPAY to AppCompatActivity.RESULT_CANCELED -> {
val intent = requireNotNull(data) {
"Intent should always be populated by the SDK"
}
val pair = checkNotNull(Afterpay.parseCheckoutCancellationResponseV3(intent)) {
"A cancelled Afterpay transaction always contains a status, and optionally an `Exception`"
}
TODO("Notify user of checkout cancellation")
}
}
}
}
V3 users can retrieve the confirmation object directly from Afterpay by using Afterpay.fetchMerchantConfigurationV3|Async()
Contributions are welcome! Please read our contributing guidelines.
This project is licensed under the terms of the Apache 2.0 license. See the LICENSE file for more information.