From 2b92fcfb9c63bbeced5bf0340ae2bd1e3ea01f2a Mon Sep 17 00:00:00 2001 From: woutse Date: Wed, 29 Jan 2020 15:20:26 +0100 Subject: [PATCH 1/8] Added kvknummer field for Billink --- Model/Config/Source/showKvkOptions.php | 43 +++++++++++ Model/ConfigProvider.php | 7 +- Model/Paymentmethod/Billink.php | 47 +++++++++++- Model/Paymentmethod/PaymentMethod.php | 8 ++ etc/adminhtml/paymentmethods/billink.xml | 8 ++ .../web/js/view/payment/method-renderer.js | 3 +- .../view/payment/method-renderer/billink.js | 76 +++++++++++++++++++ .../web/template/payment/billink.html | 49 ++++++++++++ 8 files changed, 238 insertions(+), 3 deletions(-) create mode 100644 Model/Config/Source/showKvkOptions.php create mode 100644 view/frontend/web/js/view/payment/method-renderer/billink.js create mode 100644 view/frontend/web/template/payment/billink.html diff --git a/Model/Config/Source/showKvkOptions.php b/Model/Config/Source/showKvkOptions.php new file mode 100644 index 00000000..dd0b7c0d --- /dev/null +++ b/Model/Config/Source/showKvkOptions.php @@ -0,0 +1,43 @@ +toArray(); + + $arrResult = []; + foreach ($arrOptions as $value => $label) { + $arrResult[] = ['value' => $value, 'label' => $label]; + } + return $arrResult; + } + + /** + * Get options in "key-value" format + * + * @return array + */ + public function toArray() + { + return [ + '0' => __('No'), + '1' => __('Yes, but as optional'), + '2' => __('Yes, as required'), + ]; + } + +} diff --git a/Model/ConfigProvider.php b/Model/ConfigProvider.php index 79c1a6f4..dfe1ff3a 100644 --- a/Model/ConfigProvider.php +++ b/Model/ConfigProvider.php @@ -108,7 +108,7 @@ public function getConfig() $config['payment']['instructions'][$code] = $this->getInstructions($code); $config['payment']['banks'][$code] = $this->getBanks($code); $config['payment']['icon'][$code] = $this->getIcon($code); - + $config['payment']['showkvk'][$code] = $this->getKVK($code); } } @@ -132,6 +132,11 @@ protected function getBanks($code) return $this->methods[$code]->getBanks(); } + protected function getKVK($code) + { + return $this->methods[$code]->getKVK(); + } + /** * Get payment method icon * diff --git a/Model/Paymentmethod/Billink.php b/Model/Paymentmethod/Billink.php index 8ccab65a..02bfcb3f 100644 --- a/Model/Paymentmethod/Billink.php +++ b/Model/Paymentmethod/Billink.php @@ -5,8 +5,10 @@ namespace Paynl\Payment\Model\Paymentmethod; +use Paynl\Payment\Model\Config; + /** - * Description of Ideal + * Description of Billink * * @author Andy Pieters */ @@ -18,4 +20,47 @@ protected function getDefaultPaymentOptionId() { return 1672; } + + public function getKVK() + { + return $this->_scopeConfig->getValue('payment/paynl_payment_billink/showkvk', 'store'); + } + + public function assignData(\Magento\Framework\DataObject $data) + { + parent::assignData($data); + + if (is_array($data)) + { + $this->getInfoInstance()->setAdditionalInformation('kvknummer', $data['kvknummer']); + } elseif ($data instanceof \Magento\Framework\DataObject) + { + + $additional_data = $data->getAdditionalData(); + + if (isset($additional_data['kvknummer'])) { + $this->getInfoInstance()->setAdditionalInformation('kvknummer', $additional_data['kvknummer']); + } + + if (isset($additional_data['billink_agree'])) { + $this->getInfoInstance()->setAdditionalInformation('billink_agree', $additional_data['billink_agree']); + } + + } + return $this; + } + + + /** + * @return \Magento\Framework\App\CacheInterface + */ + private function getCache() + { + /** @var \Magento\Framework\ObjectManagerInterface $om */ + $om = \Magento\Framework\App\ObjectManager::getInstance(); + /** @var \Magento\Framework\App\CacheInterface $cache */ + $cache = $om->get('Magento\Framework\App\CacheInterface'); + return $cache; + } + } \ No newline at end of file diff --git a/Model/Paymentmethod/PaymentMethod.php b/Model/Paymentmethod/PaymentMethod.php index 2e541804..411f39b3 100644 --- a/Model/Paymentmethod/PaymentMethod.php +++ b/Model/Paymentmethod/PaymentMethod.php @@ -111,6 +111,11 @@ public function getBanks() return []; } + public function getKVK() + { + return []; + } + public function initialize($paymentAction, $stateObject) { $status = $this->getConfigData('order_status'); @@ -189,6 +194,9 @@ protected function doStartTransaction(Order $order) $additionalData = $order->getPayment()->getAdditionalInformation(); $bankId = null; $expireDate = null; + if (isset($additionalData['kvknummer']) && is_numeric($additionalData['kvknummer'])) { + $kvknummer = $additionalData['kvknummer']; + } if (isset($additionalData['bank_id']) && is_numeric($additionalData['bank_id'])) { $bankId = $additionalData['bank_id']; } diff --git a/etc/adminhtml/paymentmethods/billink.xml b/etc/adminhtml/paymentmethods/billink.xml index f90e19dc..1bbb3234 100644 --- a/etc/adminhtml/paymentmethods/billink.xml +++ b/etc/adminhtml/paymentmethods/billink.xml @@ -9,6 +9,14 @@ Paynl\Payment\Model\Config\Source\Available\Billink payment/paynl_payment_billink/active + + + Paynl\Payment\Model\Config\Source\showKvkOptions + + 1 + + payment/paynl_payment_billink/showkvk + diff --git a/view/frontend/web/js/view/payment/method-renderer.js b/view/frontend/web/js/view/payment/method-renderer.js index 98bec3bf..09d29623 100644 --- a/view/frontend/web/js/view/payment/method-renderer.js +++ b/view/frontend/web/js/view/payment/method-renderer.js @@ -11,12 +11,13 @@ define( var defaultComponent = 'Paynl_Payment/js/view/payment/method-renderer/default'; var idealComponent = 'Paynl_Payment/js/view/payment/method-renderer/ideal'; + var billinkComponent = 'Paynl_Payment/js/view/payment/method-renderer/billink'; var methods = [ {type: 'paynl_payment_afterpay', component: defaultComponent}, {type: 'paynl_payment_alipay', component: defaultComponent}, {type: 'paynl_payment_amex', component: defaultComponent}, - {type: 'paynl_payment_billink', component: defaultComponent}, + {type: 'paynl_payment_billink', component: billinkComponent}, {type: 'paynl_payment_capayable', component: defaultComponent}, {type: 'paynl_payment_capayable_gespreid', component: defaultComponent}, {type: 'paynl_payment_cartasi', component: defaultComponent}, diff --git a/view/frontend/web/js/view/payment/method-renderer/billink.js b/view/frontend/web/js/view/payment/method-renderer/billink.js new file mode 100644 index 00000000..31059d4a --- /dev/null +++ b/view/frontend/web/js/view/payment/method-renderer/billink.js @@ -0,0 +1,76 @@ +/*browser:true*/ +/*global define*/ +define( + [ + 'jquery', + 'Magento_Checkout/js/view/payment/default', + 'mage/url', + 'Magento_Checkout/js/action/place-order' + ], + function ($, Component, url, placeOrderAction) { + 'use strict'; + return Component.extend({ + defaults: { + template: 'Paynl_Payment/payment/billink' + }, + kvknummer: null, + billink_agree: null, + showKVK: function () { + return this.getKVK() > 0; + }, + getKVK: function () { + return window.checkoutConfig.payment.showkvk[this.item.method]; + }, + /** + * Get payment method data + */ + getData: function () { + return { + 'method': this.item.method, + 'po_number': null, + 'additional_data': { + "kvknummer": this.kvknummer, + "billink_agree": this.billink_agree + } + }; + }, + getInstructions: function () { + return window.checkoutConfig.payment.instructions[this.item.method]; + }, + getPaymentIcon: function () { + return window.checkoutConfig.payment.icon[this.item.method]; + }, + placeOrder: function (data, event) { + var placeOrder; + var showingKVK = this.getKVK() == 2; + + if (showingKVK) { + if (this.billink_agree != true) { + alert('Ga eens met de voorwaarden!'); + return false; + } + if (this.kvknummer.length < 8) { + alert('Vul een geldig kvk nummer'); + return false; + } + } + + if (event) { + event.preventDefault(); + } + + this.isPlaceOrderActionAllowed(false); + placeOrder = placeOrderAction(this.getData(), this.redirectAfterPlaceOrder); + + $.when(placeOrder).fail(function () { + this.isPlaceOrderActionAllowed(true); + }.bind(this)).done(this.afterPlaceOrder.bind(this)); + + return true; + }, + afterPlaceOrder: function () { + window.location.replace(url.build('/paynl/checkout/redirect?nocache=' + (new Date().getTime()))); + }, + }); + } +); \ No newline at end of file diff --git a/view/frontend/web/template/payment/billink.html b/view/frontend/web/template/payment/billink.html new file mode 100644 index 00000000..6c4b544f --- /dev/null +++ b/view/frontend/web/template/payment/billink.html @@ -0,0 +1,49 @@ +
+
+ + +
+
+
+ + + + +
+
+ + + +
+

+
+ + + +
+ + betalingsvoorwaarden +
+
+
+
+ +
+
+
+
\ No newline at end of file From a91c649f8b51ba621ffafd67dd3cc643fd1a502b Mon Sep 17 00:00:00 2001 From: woutse Date: Wed, 29 Jan 2020 17:14:58 +0100 Subject: [PATCH 2/8] Dotted the I's and crossed the t's --- Controller/Checkout/Redirect.php | 3 ++- Model/Config.php | 5 +++++ Model/Paymentmethod/PaymentMethod.php | 15 ++++++++++++++- composer.json | 2 +- .../js/view/payment/method-renderer/billink.js | 4 ++-- view/frontend/web/template/payment/billink.html | 4 ++-- 6 files changed, 26 insertions(+), 7 deletions(-) diff --git a/Controller/Checkout/Redirect.php b/Controller/Checkout/Redirect.php index b5a0589c..8a930e5c 100644 --- a/Controller/Checkout/Redirect.php +++ b/Controller/Checkout/Redirect.php @@ -96,11 +96,12 @@ public function execute() $methodInstance = $this->paymentHelper->getMethodInstance($method); if ($methodInstance instanceof \Paynl\Payment\Model\Paymentmethod\Paymentmethod) { + $this->_logger->notice('PAY.: Start new payment for order ' . $order->getId()); $redirectUrl = $methodInstance->startTransaction($order); $this->getResponse()->setNoCacheHeaders(); $this->getResponse()->setRedirect($redirectUrl); } else { - throw new Error('Method is not a paynl payment method'); + throw new Error('PAY.: Method is not a paynl payment method'); } } catch (\Exception $e) { diff --git a/Model/Config.php b/Model/Config.php index c9d76e9e..8ce08c44 100644 --- a/Model/Config.php +++ b/Model/Config.php @@ -24,6 +24,11 @@ public function __construct( $this->store = $store; } + public function getVersion() + { + return '1.5.6'; + } + /** * @param Store $store */ diff --git a/Model/Paymentmethod/PaymentMethod.php b/Model/Paymentmethod/PaymentMethod.php index 411f39b3..757a5822 100644 --- a/Model/Paymentmethod/PaymentMethod.php +++ b/Model/Paymentmethod/PaymentMethod.php @@ -245,6 +245,19 @@ protected function doStartTransaction(Order $order) 'emailAddress' => $arrBillingAddress['email'], ); + if (isset($arrBillingAddress['company']) && !empty($arrBillingAddress['company'])) { + $enduser['company']['name'] = $arrBillingAddress['company']; + $enduser['company']['countryCode'] = $arrBillingAddress['country_id']; + } + + if (isset($kvknummer) && !empty($kvknummer)) { + $enduser['company']['cocNumber'] = $kvknummer; + } + + if (isset($arrBillingAddress['vat_id']) && !empty($arrBillingAddress['vat_id'])) { + $enduser['company']['vatNumber'] = $arrBillingAddress['vat_id']; + } + $invoiceAddress = array( 'initials' => $strBillingFirstName, 'lastName' => $arrBillingAddress['lastname'] @@ -297,7 +310,7 @@ protected function doStartTransaction(Order $order) 'extra3' => $order->getEntityId(), 'exchangeUrl' => $exchangeUrl, 'currency' => $currency, - 'object' => 'magento2 1.5.5', + @ 'object' => 'magento2 ' . $this->paynlConfig->getVersion(), ); if (isset($shippingAddress)) { $data['address'] = $shippingAddress; diff --git a/composer.json b/composer.json index 67fe4f2a..919a3f00 100644 --- a/composer.json +++ b/composer.json @@ -2,7 +2,7 @@ "name": "paynl/magento2-plugin", "description": "Pay.nl Magento2 Payment methods", "type": "magento2-module", - "version": "1.5.5", + "version": "1.5.6", "require": { "magento/module-sales": "100 - 103", "magento/module-payment": "100 - 103", diff --git a/view/frontend/web/js/view/payment/method-renderer/billink.js b/view/frontend/web/js/view/payment/method-renderer/billink.js index 31059d4a..aa974cd8 100644 --- a/view/frontend/web/js/view/payment/method-renderer/billink.js +++ b/view/frontend/web/js/view/payment/method-renderer/billink.js @@ -46,11 +46,11 @@ define( if (showingKVK) { if (this.billink_agree != true) { - alert('Ga eens met de voorwaarden!'); + alert('U dient eerst akkoord te gaan met de betalingsvoorwaarden van Billink.'); return false; } if (this.kvknummer.length < 8) { - alert('Vul een geldig kvk nummer'); + alert('Voer een geldig KVK nummer in.'); return false; } } diff --git a/view/frontend/web/template/payment/billink.html b/view/frontend/web/template/payment/billink.html index 6c4b544f..c941c235 100644 --- a/view/frontend/web/template/payment/billink.html +++ b/view/frontend/web/template/payment/billink.html @@ -22,12 +22,12 @@

- +
- betalingsvoorwaarden + betalingsvoorwaarden
From e7e59b6140bc4a01c2c370c4096485b4c766c167 Mon Sep 17 00:00:00 2001 From: woutse Date: Wed, 29 Jan 2020 22:45:40 +0100 Subject: [PATCH 3/8] Dotted the I's and crossed the t's --- Model/Paymentmethod/PaymentMethod.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Model/Paymentmethod/PaymentMethod.php b/Model/Paymentmethod/PaymentMethod.php index 757a5822..c51cfee4 100644 --- a/Model/Paymentmethod/PaymentMethod.php +++ b/Model/Paymentmethod/PaymentMethod.php @@ -310,7 +310,7 @@ protected function doStartTransaction(Order $order) 'extra3' => $order->getEntityId(), 'exchangeUrl' => $exchangeUrl, 'currency' => $currency, - @ 'object' => 'magento2 ' . $this->paynlConfig->getVersion(), + 'object' => 'magento2 ' . $this->paynlConfig->getVersion(), ); if (isset($shippingAddress)) { $data['address'] = $shippingAddress; From e80e1df0bec7dda27da8c577740170b1a74820af Mon Sep 17 00:00:00 2001 From: woutse Date: Wed, 29 Jan 2020 23:20:55 +0100 Subject: [PATCH 4/8] Dotted the I's and crossed the t's --- view/frontend/web/js/view/payment/method-renderer/billink.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/view/frontend/web/js/view/payment/method-renderer/billink.js b/view/frontend/web/js/view/payment/method-renderer/billink.js index aa974cd8..57d97ff9 100644 --- a/view/frontend/web/js/view/payment/method-renderer/billink.js +++ b/view/frontend/web/js/view/payment/method-renderer/billink.js @@ -49,7 +49,7 @@ define( alert('U dient eerst akkoord te gaan met de betalingsvoorwaarden van Billink.'); return false; } - if (this.kvknummer.length < 8) { + if (this.kvknummer == null || this.kvknummer.length < 8) { alert('Voer een geldig KVK nummer in.'); return false; } From 997a09d19f7db73a4f2836634c38a9b27e5d2c41 Mon Sep 17 00:00:00 2001 From: woutse Date: Thu, 30 Jan 2020 11:48:19 +0100 Subject: [PATCH 5/8] Dotted the I's and crossed the t's --- Model/Paymentmethod/PaymentMethod.php | 3 +++ 1 file changed, 3 insertions(+) diff --git a/Model/Paymentmethod/PaymentMethod.php b/Model/Paymentmethod/PaymentMethod.php index c51cfee4..0ebbb14d 100644 --- a/Model/Paymentmethod/PaymentMethod.php +++ b/Model/Paymentmethod/PaymentMethod.php @@ -270,6 +270,9 @@ protected function doStartTransaction(Order $order) $invoiceAddress['city'] = $arrBillingAddress['city']; $invoiceAddress['country'] = $arrBillingAddress['country_id']; + if (isset($arrShippingAddress['vat_id']) && !empty($arrShippingAddress['vat_id'])) { + $enduser['company']['vatNumber'] = $arrShippingAddress['vat_id']; + } } $arrShippingAddress = $order->getShippingAddress(); From 5dfdf0aad9c70e627a523ba19796cfffdd9669bd Mon Sep 17 00:00:00 2001 From: woutse Date: Sun, 2 Feb 2020 17:02:32 +0100 Subject: [PATCH 6/8] Changed year --- Model/Paymentmethod/Billink.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Model/Paymentmethod/Billink.php b/Model/Paymentmethod/Billink.php index 02bfcb3f..9fd2060b 100644 --- a/Model/Paymentmethod/Billink.php +++ b/Model/Paymentmethod/Billink.php @@ -1,6 +1,6 @@ Date: Sun, 2 Feb 2020 17:04:46 +0100 Subject: [PATCH 7/8] Chanhed http url to https and added comment to setting --- etc/adminhtml/paymentmethods/billink.xml | 1 + view/frontend/web/template/payment/billink.html | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/etc/adminhtml/paymentmethods/billink.xml b/etc/adminhtml/paymentmethods/billink.xml index 1bbb3234..ec8b71fc 100644 --- a/etc/adminhtml/paymentmethods/billink.xml +++ b/etc/adminhtml/paymentmethods/billink.xml @@ -16,6 +16,7 @@ 1 payment/paynl_payment_billink/showkvk + diff --git a/view/frontend/web/template/payment/billink.html b/view/frontend/web/template/payment/billink.html index c941c235..bf984bdd 100644 --- a/view/frontend/web/template/payment/billink.html +++ b/view/frontend/web/template/payment/billink.html @@ -27,7 +27,7 @@
- betalingsvoorwaarden + betalingsvoorwaarden
From 45106a7ab4e0aff605af4f3046370193eaf3b8b3 Mon Sep 17 00:00:00 2001 From: woutse Date: Sun, 2 Feb 2020 17:06:49 +0100 Subject: [PATCH 8/8] Changed year --- Model/Config/Source/showKvkOptions.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Model/Config/Source/showKvkOptions.php b/Model/Config/Source/showKvkOptions.php index dd0b7c0d..038612fa 100644 --- a/Model/Config/Source/showKvkOptions.php +++ b/Model/Config/Source/showKvkOptions.php @@ -1,6 +1,6 @@ __('No'), - '1' => __('Yes, but as optional'), + '1' => __('Yes, as optional'), '2' => __('Yes, as required'), ]; }