diff --git a/Model/MethodListPlugin.php b/Model/MethodListPlugin.php index 7c9e412..ac7a93f 100644 --- a/Model/MethodListPlugin.php +++ b/Model/MethodListPlugin.php @@ -6,6 +6,7 @@ use Magento\Payment\Helper\Data; use Magento\Payment\Model\MethodInterface; use Magento\Payment\Model\MethodList; +use Magento\Quote\Api\Data\CartInterface; use Magento\Store\Model\ScopeInterface; use Magento\Store\Model\StoreManagerInterface; use tpaycom\magento2basic\Api\TpayInterface; @@ -27,12 +28,20 @@ class MethodListPlugin /** @var StoreManagerInterface */ private $storeManager; - public function __construct(Data $data, ScopeConfigInterface $scopeConfig, OnsiteChannels $onsiteChannels, StoreManagerInterface $storeManager) + /** @var Tpay */ + private $tpay; + + /** @var CartInterface */ + private $cartInterface; + + public function __construct(Data $data, ScopeConfigInterface $scopeConfig, OnsiteChannels $onsiteChannels, StoreManagerInterface $storeManager, Tpay $tpay, CartInterface $cartInterface) { $this->data = $data; $this->scopeConfig = $scopeConfig; $this->onsiteChannels = $onsiteChannels; $this->storeManager = $storeManager; + $this->tpay = $tpay; + $this->cartInterface = $cartInterface; } public function afterGetAvailableMethods(MethodList $compiled, $result) @@ -40,6 +49,10 @@ public function afterGetAvailableMethods(MethodList $compiled, $result) $onsiteChannels = $this->scopeConfig->getValue(self::CONFIG_PATH, ScopeInterface::SCOPE_STORE); $channels = $onsiteChannels ? explode(',', $onsiteChannels) : []; + if (!$this->tpay->isAvailable($this->cartInterface)) { + return $result; + } + $result[] = $this->getMethodInstance('tpay.com - Płatność kartą', 'tpaycom_magento2basic_cards'); $result = $this->filterResult($result);