You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I am testing official 1.7.0 Demo application and there is a bug with PayPalWebCheckoutClient. In a specific scenario, when you cancel the payment flow (by closing the webview) it will not inform the app about the cancellation (PayPalWebCheckoutListener#onPayPalWebCanceled). Please check the steps for reproduction.
I noticed that you are using an old version of Browser Switch dependency 2.3.1 so it is possible that migrating to a later version could possibly fix this bug.
Possible bug in Browser Switch library?:
I noticed in BrowserSwichClient is this logic which resets intent in case when the payment was successful:
And here is the probematic condition when intent is actually null (when you do first successful payment and then do the same but instead of checkout you cancel the webview) .
To reproduce
Open official Demo app
Open PayPal Web -> Authorize -> Create order -> PAYPAL -> Start checkout
Do the payment. After that you will see correct state CHECKOUT COMPLETE
Return back to main screen in Demo app.
Repeat step 2.
Don't do the payment, just press "X" to cancel the payment WebView.
BUG: You will not receive onPayPalWebCanceled(...) in this scenario. Demo app is stuck in infinite loading state. See picture below:
Expected behavior
PayPal SDK must correctly trigger onPayPalWebCanceled(...) in all scenarios.
Screenshots
No response
The text was updated successfully, but these errors were encountered:
Hi @yuraj11 thank you for using the PayPal SDK for Android. Unfortunately, this is by design. The Chrome Custom Tabs API historically didn't have a hook for the close button. The canceled event is only sent when a user explicitly cancels by clicking a "Cancel" link in the PayPal web app.
I am noticing though that this may now be possible using engagement signals. Is this something high priority for your use case? We've also considered implementing a catch-all NoResult result type in v2 of our SDK when the application comes into the foreground without a successful deep link, because we can't infer the intent of the user with 100% accuracy.
Hi, thanks for the response. Our application shows full-screen loading state until we receive result in listener from the PayPal SDK. I will do a workaround for now, so it's not a high priority.
PayPal Android SDK Version
1.7.0
Environment
Sandbox
Android Version & Device
Nexus 6 API 34 Emulator
PayPal dependencies
1.7.0 official demo project dependencies
Describe the bug
I am testing official 1.7.0 Demo application and there is a bug with
PayPalWebCheckoutClient
. In a specific scenario, when you cancel the payment flow (by closing the webview) it will not inform the app about the cancellation (PayPalWebCheckoutListener#onPayPalWebCanceled
). Please check the steps for reproduction.I noticed that you are using an old version of Browser Switch dependency 2.3.1 so it is possible that migrating to a later version could possibly fix this bug.
Possible bug in Browser Switch library?:
I noticed in
BrowserSwichClient
is this logic which resets intent in case when the payment was successful:And here is the probematic condition when
intent
is actuallynull
(when you do first successful payment and then do the same but instead of checkout you cancel the webview) .To reproduce
onPayPalWebCanceled(...)
in this scenario. Demo app is stuck in infinite loading state. See picture below:Expected behavior
PayPal SDK must correctly trigger
onPayPalWebCanceled(...)
in all scenarios.Screenshots
No response
The text was updated successfully, but these errors were encountered: