From 7a7124e62f30d3012b0f8ac50940fa9da5bcc2b5 Mon Sep 17 00:00:00 2001 From: saperi22 <104481964+saperi22@users.noreply.github.com> Date: Tue, 29 Oct 2024 14:05:47 -0700 Subject: [PATCH] Update API where getParcelableExtra method is used (#1197) * Update API where getParcelableExtra method is used * update CHANGELOG.md --- CHANGELOG.md | 2 ++ .../api/sharedutils/IntentExtensions.kt | 13 ++++++++----- 2 files changed, 10 insertions(+), 5 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index a805edfe62..490a577d08 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,8 @@ ## unreleased +* GooglePay + * Fix a crash being caused on API 33 devices. It is recommended that merchants not use 5.1.0 for GooglePay. * Shopper Insights (BETA) * For analytics, send `experiment` as a parameter to `getRecommendedPaymentMethods` method * For analytics, send `experiment` and `paymentMethodsDisplayed` analytic metrics to FPTI via the button presented event methods diff --git a/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/IntentExtensions.kt b/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/IntentExtensions.kt index 6da2cfd204..b5ab72b862 100644 --- a/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/IntentExtensions.kt +++ b/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/IntentExtensions.kt @@ -10,24 +10,27 @@ import java.io.Serializable @RestrictTo(RestrictTo.Scope.LIBRARY_GROUP) object IntentExtensions { - + /** Although the newer getParcelableExtra(key, T::class.java) was introduced in Tiramisu (API 33), + * there seems to be an issue that throws NPE. See: https://issuetracker.google.com/issues/240585930#comment6 + * Suggestion is to use the older APIs for Tiramisu (API 33) instead. + */ inline fun Intent.parcelable(key: String): T? = when { - SDK_INT >= Build.VERSION_CODES.TIRAMISU -> getParcelableExtra(key, T::class.java) + SDK_INT >= Build.VERSION_CODES.UPSIDE_DOWN_CAKE -> getParcelableExtra(key, T::class.java) else -> @Suppress("DEPRECATION") getParcelableExtra(key) as? T } inline fun Bundle.parcelable(key: String): T? = when { - SDK_INT >= Build.VERSION_CODES.TIRAMISU -> getParcelable(key, T::class.java) + SDK_INT >= Build.VERSION_CODES.UPSIDE_DOWN_CAKE -> getParcelable(key, T::class.java) else -> @Suppress("DEPRECATION") getParcelable(key) as? T } inline fun Intent.serializable(key: String): T? = when { - SDK_INT >= Build.VERSION_CODES.TIRAMISU -> getSerializableExtra(key, T::class.java) + SDK_INT >= Build.VERSION_CODES.UPSIDE_DOWN_CAKE -> getSerializableExtra(key, T::class.java) else -> @Suppress("DEPRECATION") getSerializableExtra(key) as? T } inline fun Bundle.serializable(key: String): T? = when { - SDK_INT >= Build.VERSION_CODES.TIRAMISU -> getSerializable(key, T::class.java) + SDK_INT >= Build.VERSION_CODES.UPSIDE_DOWN_CAKE -> getSerializable(key, T::class.java) else -> @Suppress("DEPRECATION") getSerializable(key) as? T } }