From e09e312b4abbccc38909811c9292b9c86a2286b0 Mon Sep 17 00:00:00 2001 From: carmenmaymo Date: Thu, 27 Jul 2023 16:32:19 +0200 Subject: [PATCH] Not load assets if not enabled at mollie P-192 --- src/Assets/AssetsModule.php | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/src/Assets/AssetsModule.php b/src/Assets/AssetsModule.php index 40790da0..97bfe1e7 100644 --- a/src/Assets/AssetsModule.php +++ b/src/Assets/AssetsModule.php @@ -315,26 +315,30 @@ public function registerBlockScripts(string $pluginUrl, string $pluginPath): voi /** * Enqueue Frontend only scripts * + * @param $container Container * @return void */ - public function enqueueFrontendScripts() + public function enqueueFrontendScripts($container) { if (is_admin() || !mollieWooCommerceIsCheckoutContext()) { return; } wp_enqueue_style('mollie-gateway-icons'); $isBillieEnabled = mollieWooCommerceIsGatewayEnabled('mollie_wc_gateway_billie_settings', 'enabled'); - if ($isBillieEnabled) { + $allMethodsEnabledAtMollie = $container->get('gateway.paymentMethodsEnabledAtMollie'); + $isBillieEnabledAtMollie = in_array('billie', $allMethodsEnabledAtMollie, true); + if ($isBillieEnabled && $isBillieEnabledAtMollie) { wp_enqueue_script('mollie-billie-classic-handles'); } $isIn3Enabled = mollieWooCommerceIsGatewayEnabled('mollie_wc_gateway_in3_settings', 'enabled'); - if ($isIn3Enabled) { + $isIn3EnabledAtMollie = in_array('in3', $allMethodsEnabledAtMollie, true); + if ($isIn3Enabled && $isIn3EnabledAtMollie) { wp_enqueue_script('mollie-in3-classic-handles'); } $applePayGatewayEnabled = mollieWooCommerceIsGatewayEnabled('mollie_wc_gateway_applepay_settings', 'enabled'); - - if (!$applePayGatewayEnabled) { + $isAppleEnabledAtMollie = in_array('applepay', $allMethodsEnabledAtMollie, true); + if (!$applePayGatewayEnabled || !$isAppleEnabledAtMollie) { return; } wp_enqueue_style('unabledButton'); @@ -640,7 +644,10 @@ function () use ($container, $hasBlocksEnabled, $settingsHelper, $pluginUrl, $pl self::registerFrontendScripts($pluginUrl, $pluginPath); // Enqueue Scripts - add_action('wp_enqueue_scripts', [$this, 'enqueueFrontendScripts']); + add_action('wp_enqueue_scripts', function () use ($container) { + $this->enqueueFrontendScripts($container); + + }); add_action('wp_enqueue_scripts', function () use ($settingsHelper) { $this->enqueueComponentsAssets($settingsHelper); });