From 001fe2b11d0b4ebcb28767a232a3664af67a96ea Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Frankiewicz?= Date: Fri, 2 Jun 2023 15:10:22 +0200 Subject: [PATCH] fixes 'empty' hook calling by p24 --- src/Hook/Event/Browser/PurchaseHook.php | 37 +++++++++++++------------ 1 file changed, 19 insertions(+), 18 deletions(-) diff --git a/src/Hook/Event/Browser/PurchaseHook.php b/src/Hook/Event/Browser/PurchaseHook.php index cec571b..30bf0b8 100644 --- a/src/Hook/Event/Browser/PurchaseHook.php +++ b/src/Hook/Event/Browser/PurchaseHook.php @@ -9,20 +9,22 @@ class PurchaseHook extends AbstractHook { - private $eventFired = false; - /** @var array */ public const HOOKS = [ Hooks::DISPLAY_ORDER_CONFIRMATION => [ 'addDataElementInOrderConfirmationPage', ], - Hooks::DISPLAY_BEFORE_BODY_CLOSING_TAG => [ + Hooks::DISPLAY_AFTER_BODY_OPENING_TAG => [ 'p24Compatibility', ], ]; public function addDataElementInOrderConfirmationPage(array $data): string { + if (true === $this->isP24ConfirmationPage()) { + return ''; + } + /** @var PrestaShopOrder $orderObject */ $orderObject = $data['order']; @@ -31,15 +33,7 @@ public function addDataElementInOrderConfirmationPage(array $data): string public function p24Compatibility(array $data): string { - $controller = $this->getContext()->controller; - - if (null === $controller) { - return ''; - } - - $controllerClass = get_class($controller); - - if ('Przelewy24paymentConfirmationModuleFrontController' !== $controllerClass) { + if (false === $this->isP24ConfirmationPage()) { return ''; } @@ -56,19 +50,26 @@ public function p24Compatibility(array $data): string private function handlePurchaseEvent(PrestaShopOrder $order): string { - if (true === $this->eventFired) { - return ''; - } - $orderModel = Order::fromOrderObject($order); $this->getContext()->smarty->assign('tc_order', $orderModel->toArray()); - $this->eventFired = true; - return $this->module->display( \TagConciergeFree::MODULE_FILE, 'views/templates/hooks/purchase/display_order_confirmation.tpl' ); } + + private function isP24ConfirmationPage(): bool + { + $controller = $this->getContext()->controller; + + if (null === $controller) { + return false; + } + + $controllerClass = get_class($controller); + + return 'przelewy24paymentconfirmationmodulefrontcontroller' === strtolower($controllerClass); + } }