diff --git a/modules/ppcp-order-tracking/assets/css/order-edit-page.css b/modules/ppcp-order-tracking/assets/css/order-edit-page.css new file mode 100644 index 000000000..2d8631b4a --- /dev/null +++ b/modules/ppcp-order-tracking/assets/css/order-edit-page.css @@ -0,0 +1 @@ +#ppcp_order-tracking .tracking-info-message{padding-left:20px}#ppcp_order-tracking .error{color:red;font-weight:bold}#ppcp_order-tracking .success{color:green;font-weight:bold}#ppcp_order-tracking input,#ppcp_order-tracking select{width:100%} \ No newline at end of file diff --git a/modules/ppcp-order-tracking/assets/js/order-edit-page-style.js b/modules/ppcp-order-tracking/assets/js/order-edit-page-style.js new file mode 100644 index 000000000..19f5d8548 --- /dev/null +++ b/modules/ppcp-order-tracking/assets/js/order-edit-page-style.js @@ -0,0 +1 @@ +(()=>{"use strict";var __webpack_modules__={705:(__unused_webpack_module,__unused_webpack___webpack_exports__,__webpack_require__)=>{eval('/* unused harmony default export */ var __WEBPACK_DEFAULT_EXPORT__ = (__webpack_require__.p + "css/order-edit-page.css");//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNzA1LmpzIiwibWFwcGluZ3MiOiJBQUFBLHNFQUFlLHFCQUF1Qiw0QkFBNEIiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9wcGNwLW9yZGVyLXRyYWNraW5nLy4vcmVzb3VyY2VzL2Nzcy9vcmRlci1lZGl0LXBhZ2Uuc2Nzcz83YTdmIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWZhdWx0IF9fd2VicGFja19wdWJsaWNfcGF0aF9fICsgXCJjc3Mvb3JkZXItZWRpdC1wYWdlLmNzc1wiOyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///705\n')}},__webpack_require__={};__webpack_require__.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),(()=>{var e;__webpack_require__.g.importScripts&&(e=__webpack_require__.g.location+"");var _=__webpack_require__.g.document;if(!e&&_&&(_.currentScript&&(e=_.currentScript.src),!e)){var r=_.getElementsByTagName("script");r.length&&(e=r[r.length-1].src)}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),__webpack_require__.p=e+"../"})();var __webpack_exports__={};__webpack_modules__[705](0,__webpack_exports__,__webpack_require__)})(); \ No newline at end of file diff --git a/modules/ppcp-order-tracking/assets/js/order-edit-page.js b/modules/ppcp-order-tracking/assets/js/order-edit-page.js new file mode 100644 index 000000000..c9d6e7c8c --- /dev/null +++ b/modules/ppcp-order-tracking/assets/js/order-edit-page.js @@ -0,0 +1 @@ +(()=>{"use strict";var __webpack_modules__={673:()=>{eval("\n;// CONCATENATED MODULE: ../ppcp-button/resources/js/modules/Helper/CheckoutMethodState.js\nconst PaymentMethods = {\n PAYPAL: 'ppcp-gateway',\n CARDS: 'ppcp-credit-card-gateway',\n OXXO: 'ppcp-oxxo-gateway',\n CARD_BUTTON: 'ppcp-card-button-gateway'\n};\nconst ORDER_BUTTON_SELECTOR = '#place_order';\nconst getCurrentPaymentMethod = () => {\n const el = document.querySelector('input[name=\"payment_method\"]:checked');\n\n if (!el) {\n return null;\n }\n\n return el.value;\n};\nconst isSavedCardSelected = () => {\n const savedCardList = document.querySelector('#saved-credit-card');\n return savedCardList && savedCardList.value !== '';\n};\n;// CONCATENATED MODULE: ./resources/js/order-edit-page.js\n\ndocument.addEventListener('DOMContentLoaded', () => {\n const config = PayPalCommerceGatewayOrderTrackingInfo;\n\n if (!typeof PayPalCommerceGatewayOrderTrackingInfo) {\n console.error('trackign cannot be set.');\n return;\n }\n\n const transactionId = document.querySelector('.ppcp-tracking-transaction_id');\n const trackingNumber = document.querySelector('.ppcp-tracking-tracking_number');\n const status = document.querySelector('.ppcp-tracking-status');\n const carrier = document.querySelector('.ppcp-tracking-carrier');\n const orderId = document.querySelector('.ppcp-order_id');\n const submitButton = document.querySelector('.submit_tracking_info');\n submitButton.addEventListener('click', function (event) {\n submitButton.setAttribute('disabled', 'disabled');\n fetch(config.ajax.tracking_info.endpoint, {\n method: 'POST',\n body: JSON.stringify({\n nonce: config.ajax.tracking_info.nonce,\n transaction_id: transactionId ? transactionId.value : null,\n tracking_number: trackingNumber ? trackingNumber.value : null,\n status: status ? status.value : null,\n carrier: carrier ? carrier.value : null,\n order_id: orderId ? orderId.value : null,\n action: submitButton ? submitButton.dataset.action : null\n })\n }).then(function (res) {\n return res.json();\n }).then(function (data) {\n if (!data.success) {\n console.error(data);\n throw Error(data.data.message);\n }\n\n jQuery(\"
\").insertAfter(submitButton);\n setTimeout(() => jQuery('.tracking-info-message').remove(), 3000);\n submitButton.dataset.action = 'update';\n submitButton.textContent = 'update';\n submitButton.removeAttribute('disabled');\n });\n });\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"673.js","mappings":"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","sources":["webpack://ppcp-order-tracking/../ppcp-button/resources/js/modules/Helper/CheckoutMethodState.js?53c1","webpack://ppcp-order-tracking/./resources/js/order-edit-page.js?7eae"],"sourcesContent":["export const PaymentMethods = {\n    PAYPAL: 'ppcp-gateway',\n    CARDS: 'ppcp-credit-card-gateway',\n    OXXO: 'ppcp-oxxo-gateway',\n    CARD_BUTTON: 'ppcp-card-button-gateway',\n};\n\nexport const ORDER_BUTTON_SELECTOR = '#place_order';\n\nexport const getCurrentPaymentMethod = () => {\n    const el = document.querySelector('input[name=\"payment_method\"]:checked');\n    if (!el) {\n        return null;\n    }\n\n    return el.value;\n};\n\nexport const isSavedCardSelected = () => {\n    const savedCardList = document.querySelector('#saved-credit-card');\n    return savedCardList && savedCardList.value !== '';\n};\n","import {PaymentMethods} from \"../../../ppcp-button/resources/js/modules/Helper/CheckoutMethodState\";\n\ndocument.addEventListener(\n    'DOMContentLoaded',\n    () => {\n        const config = PayPalCommerceGatewayOrderTrackingInfo;\n        if (!typeof (PayPalCommerceGatewayOrderTrackingInfo)) {\n            console.error('trackign cannot be set.');\n            return;\n        }\n\n        const transactionId = document.querySelector('.ppcp-tracking-transaction_id');\n        const trackingNumber = document.querySelector('.ppcp-tracking-tracking_number');\n        const status = document.querySelector('.ppcp-tracking-status');\n        const carrier = document.querySelector('.ppcp-tracking-carrier');\n        const orderId = document.querySelector('.ppcp-order_id');\n        const submitButton = document.querySelector('.submit_tracking_info');\n\n        submitButton.addEventListener('click', function (event) {\n            submitButton.setAttribute('disabled', 'disabled');\n            fetch(config.ajax.tracking_info.endpoint, {\n                method: 'POST',\n                body: JSON.stringify({\n                    nonce: config.ajax.tracking_info.nonce,\n                    transaction_id: transactionId ? transactionId.value : null,\n                    tracking_number: trackingNumber ? trackingNumber.value : null,\n                    status: status ? status.value : null,\n                    carrier: carrier ? carrier.value : null,\n                    order_id: orderId ? orderId.value : null,\n                    action: submitButton ? submitButton.dataset.action : null,\n                })\n            }).then(function (res) {\n                return res.json();\n            }).then(function (data) {\n                if (!data.success) {\n                    console.error(data);\n                    throw Error(data.data.message);\n                }\n\n                jQuery( \"<span class='success tracking-info-message'>\" + data.data.message + \"</span>\" ).insertAfter(submitButton);\n                setTimeout(()=> jQuery('.tracking-info-message').remove(),3000);\n\n                submitButton.dataset.action = 'update';\n                submitButton.textContent = 'update';\n                submitButton.removeAttribute('disabled');\n            });\n        })\n    },\n);\n"],"names":["PaymentMethods","PAYPAL","CARDS","OXXO","CARD_BUTTON","ORDER_BUTTON_SELECTOR","getCurrentPaymentMethod","el","document","querySelector","value","isSavedCardSelected","savedCardList","addEventListener","config","PayPalCommerceGatewayOrderTrackingInfo","console","error","transactionId","trackingNumber","status","carrier","orderId","submitButton","event","setAttribute","fetch","ajax","tracking_info","endpoint","method","body","JSON","stringify","nonce","transaction_id","tracking_number","order_id","action","dataset","then","res","json","data","success","Error","message","jQuery","insertAfter","setTimeout","remove","textContent","removeAttribute"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///673\n")}},__webpack_exports__={};__webpack_modules__[673]()})(); \ No newline at end of file diff --git a/modules/ppcp-vaulting/src/VaultingModule.php b/modules/ppcp-vaulting/src/VaultingModule.php index 669e0b9ff..a680d580c 100644 --- a/modules/ppcp-vaulting/src/VaultingModule.php +++ b/modules/ppcp-vaulting/src/VaultingModule.php @@ -197,7 +197,7 @@ class VaultingModule implements ModuleInterface { } if ( $subscription_behavior_when_vault_fails === 'capture_auth' ) { - echo wp_kses_post( '' . __( 'The subscription has been activated but the payment method could not be saved. Please try again with a different payment method to allow automatic renewal payments.', 'woocommerce-paypal-payments' ) . '
' ); + echo wp_kses_post( '' . __( 'The subscription has been activated, but the payment method could not be saved. Please contact the merchant to save a payment method for automatic subscription renewal payments.', 'woocommerce-paypal-payments' ) . '
' ); } } } diff --git a/modules/ppcp-wc-gateway/resources/js/gateway-settings.js b/modules/ppcp-wc-gateway/resources/js/gateway-settings.js index 8e8cfe21b..cf9ee45bd 100644 --- a/modules/ppcp-wc-gateway/resources/js/gateway-settings.js +++ b/modules/ppcp-wc-gateway/resources/js/gateway-settings.js @@ -69,5 +69,9 @@ togglePayLater() vaultingCheckboxes.forEach(node => node.addEventListener('change', togglePayLater)); + + if(PayPalCommerceGatewaySettings.is_subscriptions_plugin_active !== '1') { + document.getElementById('field-subscription_behavior_when_vault_fails').style.display = 'none'; + } } ); diff --git a/modules/ppcp-wc-gateway/services.php b/modules/ppcp-wc-gateway/services.php index 81f259ce7..4c8fa1a37 100644 --- a/modules/ppcp-wc-gateway/services.php +++ b/modules/ppcp-wc-gateway/services.php @@ -869,7 +869,7 @@ return array( 'default' => 'void_auth', 'desc_tip' => true, 'description' => __( 'By default, subscription payments are captured only when saving the payment method was successful. Without a saved payment method, automatic renewal payments are not possible.', 'woocommerce-paypal-payments' ), - 'description_with_tip' => __( 'Determines the capture behavior for subscriptions if saving the payment method failed. This setting only applies when the intent capture is configured.', 'woocommerce-paypal-payments' ), + 'description_with_tip' => __( 'Determines whether authorized payments for subscription orders are captured or voided if there is no saved payment method. This only applies when the intent Capture is used for the subscription order.', 'woocommerce-paypal-payments' ), 'options' => array( 'void_auth' => __( 'Void authorization & fail the order/subscription', 'woocommerce-paypal-payments' ), 'capture_auth' => __( 'Capture authorized payment & set subscription to Manual Renewal', 'woocommerce-paypal-payments' ), @@ -2368,7 +2368,11 @@ return array( }, 'button.helper.vaulting-label' => static function ( ContainerInterface $container ): string { - $vaulting_label = __( 'Enable saved cards and subscription features on your store.', 'woocommerce-paypal-payments' ); + $vaulting_label = sprintf( + __( 'Enable saved cards, PayPal accounts, and subscription features on your store. Payment methods are saved in the secure %1$sPayPal Vault%2$s.', 'woocommerce-paypal-payments' ), + '', + '' + ); if ( ! $container->get( 'wcgateway.helper.vaulting-scope' ) ) { $vaulting_label .= sprintf( @@ -2383,7 +2387,20 @@ return array( } $vaulting_label .= ''; - $vaulting_label .= __( 'This will disable all Pay Later messaging on your site.', 'woocommerce-paypal-payments' ); + $vaulting_label .= sprintf( + // translators: %1$s, %2$s, %3$s and %4$s are the opening and closing of HTML tag. + __( 'This will disable all %1$sPay Later%2$s features and %3$sAlternative Payment Methods%4$s on your site.', 'woocommerce-paypal-payments' ), + '', + '', + '', + '' + ); $vaulting_label .= '
'; return $vaulting_label; diff --git a/modules/ppcp-wc-gateway/src/Assets/SettingsPageAssets.php b/modules/ppcp-wc-gateway/src/Assets/SettingsPageAssets.php index 7a61aee9d..5926580ff 100644 --- a/modules/ppcp-wc-gateway/src/Assets/SettingsPageAssets.php +++ b/modules/ppcp-wc-gateway/src/Assets/SettingsPageAssets.php @@ -9,7 +9,7 @@ declare(strict_types=1); namespace WooCommerce\PayPalCommerce\WcGateway\Assets; -use WooCommerce\PayPalCommerce\ApiClient\Exception\RuntimeException; +use WooCommerce\PayPalCommerce\Subscription\Helper\SubscriptionHelper; /** * Class SettingsPageAssets @@ -30,15 +30,24 @@ class SettingsPageAssets { */ private $version; + /** + * The subscription helper. + * + * @var SubscriptionHelper + */ + protected $subscription_helper; + /** * Assets constructor. * - * @param string $module_url The url of this module. - * @param string $version The assets version. + * @param string $module_url The url of this module. + * @param string $version The assets version. + * @param SubscriptionHelper $subscription_helper The subscription helper. */ - public function __construct( string $module_url, string $version ) { - $this->module_url = $module_url; - $this->version = $version; + public function __construct( string $module_url, string $version, SubscriptionHelper $subscription_helper ) { + $this->module_url = $module_url; + $this->version = $version; + $this->subscription_helper = $subscription_helper; } /** @@ -96,5 +105,14 @@ class SettingsPageAssets { $this->version, true ); + + // Intent is configured with Authorize and Capture Virtual-Only Orders is not set. + wp_localize_script( + 'ppcp-gateway-settings', + 'PayPalCommerceGatewaySettings', + array( + 'is_subscriptions_plugin_active' => $this->subscription_helper->plugin_is_active(), + ) + ); } } diff --git a/modules/ppcp-wc-gateway/src/WCGatewayModule.php b/modules/ppcp-wc-gateway/src/WCGatewayModule.php index b6a30b4d1..bc9c73f7c 100644 --- a/modules/ppcp-wc-gateway/src/WCGatewayModule.php +++ b/modules/ppcp-wc-gateway/src/WCGatewayModule.php @@ -148,7 +148,8 @@ class WCGatewayModule implements ModuleInterface { if ( $c->has( 'wcgateway.url' ) ) { $assets = new SettingsPageAssets( $c->get( 'wcgateway.url' ), - $c->get( 'ppcp.asset-version' ) + $c->get( 'ppcp.asset-version' ), + $c->get( 'subscription.helper' ) ); $assets->register_assets(); }