From 69f920a8bad1828942672daf4b011ec365de0d4b Mon Sep 17 00:00:00 2001 From: Glauber Silva Date: Wed, 19 Jun 2024 12:17:39 -0300 Subject: [PATCH] Hot Fix: don't prevent PayPal donations from getting finished when there is no Billing Address block in the form (#7416) Co-authored-by: Jon Waldstein --- give.php | 4 +- readme.txt | 5 ++- .../PayPalCommerce/payPalCommerceGateway.tsx | 42 +++++++++++++------ 3 files changed, 35 insertions(+), 16 deletions(-) diff --git a/give.php b/give.php index 3733cfd64a..cb8be54031 100644 --- a/give.php +++ b/give.php @@ -6,7 +6,7 @@ * Description: The most robust, flexible, and intuitive way to accept donations on WordPress. * Author: GiveWP * Author URI: https://givewp.com/ - * Version: 3.12.2 + * Version: 3.12.3 * Requires at least: 6.3 * Requires PHP: 7.2 * Text Domain: give @@ -404,7 +404,7 @@ private function setup_constants() { // Plugin version. if (!defined('GIVE_VERSION')) { - define('GIVE_VERSION', '3.12.2'); + define('GIVE_VERSION', '3.12.3'); } // Plugin Root File. diff --git a/readme.txt b/readme.txt index c8c3000fee..0f41a209e8 100644 --- a/readme.txt +++ b/readme.txt @@ -5,7 +5,7 @@ Tags: donation, donate, recurring donations, fundraising, crowdfunding Requires at least: 6.3 Tested up to: 6.5 Requires PHP: 7.2 -Stable tag: 3.12.2 +Stable tag: 3.12.3 License: GPLv3 License URI: http://www.gnu.org/licenses/gpl-3.0.html @@ -262,6 +262,9 @@ The 2% fee on Stripe donations only applies to donations taken via our free Stri 10. Use almost any payment gateway integration with GiveWP through our add-ons or by creating your own add-on. == Changelog == += 3.12.3: June 19th, 2024 = +* Fix: Resolved an issue where PayPal was not processing donations due to missing billing address fields + = 3.12.2: June 11th, 2024 = * Fix: Resolved an issue where only the donation amount was sent to PayPal, ignoring event ticket values for one-time donations. * Fix: Resolved an issue where donations were processed on PayPal but not recorded in GiveWP due to missing city, state, and zip fields. diff --git a/src/PaymentGateways/Gateways/PayPalCommerce/payPalCommerceGateway.tsx b/src/PaymentGateways/Gateways/PayPalCommerce/payPalCommerceGateway.tsx index b37bc27fb2..78925299e5 100644 --- a/src/PaymentGateways/Gateways/PayPalCommerce/payPalCommerceGateway.tsx +++ b/src/PaymentGateways/Gateways/PayPalCommerce/payPalCommerceGateway.tsx @@ -402,21 +402,37 @@ import {PayPalSubscriber} from './types'; * when the donation is already created on the PayPal side. This way, we need the conditions below to check it earlier * and prevent the donation creation on the PayPal side if the required billing address fields are missing. */ - if (city.length === 0 && isCityRequired()) { - setError('city', {type: 'custom', message: getRequiredValidationMessage()}, {shouldFocus: true}); - return actions.reject(); - } + if (country) { + if (city.length === 0 && isCityRequired()) { + setError( + 'city', + { + type: 'custom', + message: getRequiredValidationMessage(), + }, + {shouldFocus: true} + ); + return actions.reject(); + } - if (state.length === 0 && isStateRequired()) { - setError('state', {type: 'custom', message: getRequiredValidationMessage()}, {shouldFocus: true}); - // As the state is a hidden field we need to use this workaround because the "shouldFocus" option does not work in hidden fields. - document.querySelector('.givewp-fields-select-state').scrollIntoView({behavior: 'smooth'}); - return actions.reject(); - } + if (state.length === 0 && isStateRequired()) { + setError( + 'state', + { + type: 'custom', + message: getRequiredValidationMessage(), + }, + {shouldFocus: true} + ); + // As the state is a hidden field we need to use this workaround because the "shouldFocus" option does not work in hidden fields. + document.querySelector('.givewp-fields-select-state').scrollIntoView({behavior: 'smooth'}); + return actions.reject(); + } - if (postalCode.length === 0 && isZipRequired()) { - setError('zip', {type: 'custom', message: getRequiredValidationMessage()}, {shouldFocus: true}); - return actions.reject(); + if (postalCode.length === 0 && isZipRequired()) { + setError('zip', {type: 'custom', message: getRequiredValidationMessage()}, {shouldFocus: true}); + return actions.reject(); + } } orderCreated = true;