Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[ECP-8486][ECP-8595] Grand total without tax reported to GPay, Apple Pay #37

Open
brain-effect opened this issue Jul 4, 2023 · 7 comments
Assignees
Labels
Bug report Indicates that issue has been marked as a possible bug

Comments

@brain-effect
Copy link

brain-effect commented Jul 4, 2023

Describe the bug
Magento 2.4.4-p4 + Adyen Express Checkout 1.1.2 + Adyen Payment 8.19.0. Adyen in Test mode.
The grand total without the tax included is reported to GPay and Apple Pay as the final amount. The final amount reported to Adyen, however, will be the grand total with tax, which will (most likely?) cause errors in live system.

To Reproduce
Steps to reproduce the behavior:

  1. Enable express method buttons, for example in minicart.
  2. Add any taxable product to cart.
  3. Click on GPay or Apple Pay express buttons.
  4. The grand total without tax is reported to GPay and Apple Pay as the final amount.

Expected behavior
The grand total with tax included should be reported to GPay and Apple Pay as the final amount.

Screenshots
Screenshot 2023-07-03 at 1 42 41 PM

Desktop (please complete the following information):

  • Any OS
  • Any browser

Smartphone (please complete the following information):

  • Any Device
  • Any OS
  • Any Browser
  • Any Version

Additional context
Probably related to magento/magento2#34649

@candemiralp candemiralp self-assigned this Aug 29, 2023
@candemiralp candemiralp changed the title Grand total without tax reported to GPay, Apple Pay [ECP-8486][ECP-8595] Grand total without tax reported to GPay, Apple Pay Aug 29, 2023
@candemiralp
Copy link
Member

Hello @brain-effect,

Thank you for raising this issue. We've created a PR for Apple Pay tax calculation on express payment here. We are currently working on Google Pay fix.

Best Regards,
Can

@candemiralp candemiralp added the Bug report Indicates that issue has been marked as a possible bug label Aug 29, 2023
@smiroshnyk
Copy link

Hello.
It still doesn't work even for Apple Pay.

photo_2023-09-11 15 55 37
image

You changed it in one place, but you set grant_total in 4 places.

The steps to reproduce are the same as in this issue description.

@joselopr
Copy link

@candemiralp

@candemiralp
Copy link
Member

Hello @joselopr,

Thank you mentioning the consequent issues related to Apple Pay express and apologies for the late response. We will test Apple Pay tax issue once again. Let me update you soon.

Best Regards,
Can

@dimitriBouteille
Copy link
Contributor

Hi @candemiralp @raoulritter Why in version 1.2.0 the fix is not visible ?

In 1.1.3 :

applePayShippingContactUpdate.newTotal = {
    label: $t('Grand Total'),
    amount: (response.grand_total + response.tax_amount).toString()
};

In 1.2.0 :

applePayShippingContactUpdate.newTotal = {
    label: this.getMerchantName(),
    amount: (response.grand_total).toString()
};

I have this error when I try to place order with version 1.2.0

{
   "status" : 422,
   "errorCode" : "5_001",
   "message" : "ApplePay token amount-mismatch",
   "errorType" : "validation",
   "pspReference" : "R3TB5Q4HKJHKGK82"
}

It's possible to fix this issue quickly ? ❤️

@bitumin
Copy link

bitumin commented Jan 7, 2025

In case it helps anyone, these are the patches I currently use (Magento 2.4.4 + Adyen 9.12.2 + Adyen ExpressCheckout 2.4.1). Be advised that using base grand total instead of grand total might NOT be a good replacement in shops with multiple currencies (feel free to find a better alternative for those).

ApplePay Button

diff --git a/vendor/adyen/adyen-magento2-expresscheckout/view/frontend/web/js/applepay/button.js b/vendor/adyen/adyen-magento2-expresscheckout/view/frontend/web/js/applepay/button.js
--- a/vendor/adyen/adyen-magento2-expresscheckout/view/frontend/web/js/applepay/button.js
+++ b/vendor/adyen/adyen-magento2-expresscheckout/view/frontend/web/js/applepay/button.js
@@ -418,7 +418,7 @@
                 applePayShippingMethodUpdate.newTotal = {
                     type: 'final',
                     label: this.getMerchantName(),
-                    amount: (response.grand_total).toString()
+                    amount: (response.base_grand_total).toString()
                 };

                 // If the shipping methods is an array pass all methods to Apple Pay to show in payment window.

GooglePay Button

diff --git a/vendor/adyen/adyen-magento2-expresscheckout/view/frontend/web/js/googlepay/button.js b/vendor/adyen/adyen-magento2-expresscheckout/view/frontend/web/js/googlepay/button.js
--- a/vendor/adyen/adyen-magento2-expresscheckout/view/frontend/web/js/googlepay/button.js
+++ b/vendor/adyen/adyen-magento2-expresscheckout/view/frontend/web/js/googlepay/button.js
@@ -405,7 +405,7 @@
                                         ],
                                         currencyCode: totals.quote_currency_code,
                                         totalPriceStatus: 'FINAL',
-                                        totalPrice: (totals.grand_total).toString(),
+                                        totalPrice: (totals.base_grand_total).toString(),
                                         totalPriceLabel: 'Total',
                                         countryCode: configModel().getConfig().countryCode
                                     }

@bitumin
Copy link

bitumin commented Jan 8, 2025

FYI Magento has a fix for this for >= 2.4.6 apparently, the relevant commits are these:

magento/magento2@ff39d2a

magento/magento2@67f6f46

It should be easy to create a patch for 2.4.4 and 2.4.5 with those changes in CartTotalRepository.php and grand-total.js, and in that case there is no need to patch the adyen express module (I have not tested it yet, though).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug report Indicates that issue has been marked as a possible bug
Projects
None yet
Development

No branches or pull requests

6 participants