Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
A
Adyen Magento2
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Shared Libs
Adyen Magento2
Commits
506825ca
Commit
506825ca
authored
Jul 21, 2017
by
Rik ter Beek
Committed by
GitHub
Jul 21, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #144 from Adyen/develop-rik
Develop rik
parents
4737c28a
cea55f4b
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
139 additions
and
34 deletions
+139
-34
Block/Redirect/Redirect.php
Block/Redirect/Redirect.php
+104
-23
Observer/AdyenHppDataAssignObserver.php
Observer/AdyenHppDataAssignObserver.php
+3
-1
view/frontend/requirejs-config.js
view/frontend/requirejs-config.js
+2
-1
view/frontend/web/js/view/payment/method-renderer/adyen-hpp-method.js
...d/web/js/view/payment/method-renderer/adyen-hpp-method.js
+16
-9
view/frontend/web/template/payment/hpp-form.html
view/frontend/web/template/payment/hpp-form.html
+14
-0
No files found.
Block/Redirect/Redirect.php
View file @
506825ca
...
...
@@ -58,6 +58,13 @@ class Redirect extends \Magento\Payment\Block\Form
*/
protected
$_adyenLogger
;
/**
* @var \Magento\Tax\Model\Config
*/
protected
$_taxConfig
;
protected
$_taxCalculation
;
/**
* Redirect constructor.
*
...
...
@@ -74,7 +81,9 @@ class Redirect extends \Magento\Payment\Block\Form
\Magento\Checkout\Model\Session
$checkoutSession
,
\Adyen\Payment\Helper\Data
$adyenHelper
,
\Magento\Framework\Locale\ResolverInterface
$resolver
,
\Adyen\Payment\Logger\AdyenLogger
$adyenLogger
\Adyen\Payment\Logger\AdyenLogger
$adyenLogger
,
\Magento\Tax\Model\Config
$taxConfig
,
\Magento\Tax\Model\Calculation
$taxCalculation
)
{
$this
->
_orderFactory
=
$orderFactory
;
$this
->
_checkoutSession
=
$checkoutSession
;
...
...
@@ -88,6 +97,8 @@ class Redirect extends \Magento\Payment\Block\Form
$incrementId
=
$this
->
_getCheckout
()
->
getLastRealOrderId
();
$this
->
_order
=
$this
->
_orderFactory
->
create
()
->
loadByIncrementId
(
$incrementId
);
}
$this
->
_taxConfig
=
$taxConfig
;
$this
->
_taxCalculation
=
$taxCalculation
;
}
...
...
@@ -286,9 +297,13 @@ class Redirect extends \Magento\Payment\Block\Form
$formFields
[
'deliveryAddressType'
]
=
"1"
;
// make setting to make this optional
$
ady
Fields
[
'shopperType'
]
=
"1"
;
$
form
Fields
[
'shopperType'
]
=
"1"
;
}
if
(
$this
->
_order
->
getPayment
()
->
getAdditionalInformation
(
"df_value"
)
!=
""
)
{
$formFields
[
'dfValue'
]
=
$this
->
_order
->
getPayment
()
->
getAdditionalInformation
(
"df_value"
);
}
// Sort the array by key using SORT_STRING order
ksort
(
$formFields
,
SORT_STRING
);
...
...
@@ -306,6 +321,10 @@ class Redirect extends \Magento\Payment\Block\Form
}
catch
(
Exception
$e
)
{
// do nothing for now
}
// echo "GENDER" . $this->_order->getCustomerGender();
//
// print_r($formFields);die();
return
$formFields
;
}
...
...
@@ -430,15 +449,11 @@ class Redirect extends \Magento\Payment\Block\Form
foreach
(
$this
->
_order
->
getAllVisibleItems
()
as
$item
)
{
++
$count
;
$linename
=
"line"
.
$count
;
$formFields
[
'openinvoicedata.'
.
$linename
.
'.currencyCode'
]
=
$currency
;
$formFields
[
'openinvoicedata.'
.
$linename
.
'.description'
]
=
str_replace
(
"
\n
"
,
''
,
trim
(
$item
->
getName
()));
$formFields
[
'openinvoicedata.'
.
$linename
.
'.itemAmount'
]
=
$this
->
_adyenHelper
->
formatAmount
(
$item
->
getPrice
(),
$currency
);
$formFields
[
'openinvoicedata.'
.
$linename
.
'.itemVatAmount'
]
=
$description
=
str_replace
(
"
\n
"
,
''
,
trim
(
$item
->
getName
()));
$itemAmount
=
$this
->
_adyenHelper
->
formatAmount
(
$item
->
getPrice
(),
$currency
);
$itemVatAmount
=
(
$item
->
getTaxAmount
()
>
0
&&
$item
->
getPriceInclTax
()
>
0
)
?
$this
->
_adyenHelper
->
formatAmount
(
$item
->
getPriceInclTax
(),
...
...
@@ -447,23 +462,57 @@ class Redirect extends \Magento\Payment\Block\Form
$item
->
getPrice
(),
$currency
)
:
$this
->
_adyenHelper
->
formatAmount
(
$item
->
getTaxAmount
(),
$currency
);
// Calculate vat percentage
$percentageMinorUnits
=
$this
->
_adyenHelper
->
getMinorUnitTaxPercent
(
$item
->
getTaxPercent
());
$formFields
[
'openinvoicedata.'
.
$linename
.
'.itemVatPercentage'
]
=
$percentageMinorUnits
;
$formFields
[
'openinvoicedata.'
.
$linename
.
'.numberOfItems'
]
=
(
int
)
$item
->
getQtyOrdered
();
$itemVatPercentage
=
$this
->
_adyenHelper
->
getMinorUnitTaxPercent
(
$item
->
getTaxPercent
());
if
(
$this
->
_adyenHelper
->
isVatCategoryHigh
(
$this
->
_order
->
getPayment
()
->
getAdditionalInformation
(
\Adyen\Payment\Observer\AdyenHppDataAssignObserver
::
BRAND_CODE
)))
{
$formFields
[
'openinvoicedata.'
.
$linename
.
'.vatCategory'
]
=
"High"
;
}
else
{
$formFields
[
'openinvoicedata.'
.
$linename
.
'.vatCategory'
]
=
"None"
;
}
$numberOfItems
=
(
int
)
$item
->
getQtyOrdered
();
if
(
$item
->
getSku
()
!=
""
)
{
$
formFields
[
'openinvoicedata.'
.
$linename
.
'.itemId'
]
=
$item
->
getSku
(
);
}
$formFields
=
$this
->
setOpenInvoiceLineData
(
$formFields
,
$count
,
$currency
,
$description
,
$itemAmount
,
$
itemVatAmount
,
$itemVatPercentage
,
$numberOfItems
);
}
// Discount cost
if
(
$this
->
_order
->
getDiscountAmount
()
>
0
||
$this
->
_order
->
getDiscountAmount
()
<
0
)
{
++
$count
;
$description
=
__
(
'Total Discount'
);
$itemAmount
=
$this
->
_adyenHelper
->
formatAmount
(
$this
->
_order
->
getDiscountAmount
(),
$currency
);
$itemVatAmount
=
"0"
;
$itemVatPercentage
=
"0"
;
$numberOfItems
=
1
;
$formFields
=
$this
->
setOpenInvoiceLineData
(
$formFields
,
$count
,
$currency
,
$description
,
$itemAmount
,
$itemVatAmount
,
$itemVatPercentage
,
$numberOfItems
);
}
// Shipping cost
if
(
$this
->
_order
->
getShippingAmount
()
>
0
||
$this
->
_order
->
getShippingTaxAmount
()
>
0
)
{
++
$count
;
$description
=
$this
->
_order
->
getShippingDescription
();
$itemAmount
=
$this
->
_adyenHelper
->
formatAmount
(
$this
->
_order
->
getShippingAmount
(),
$currency
);
$itemVatAmount
=
$this
->
_adyenHelper
->
formatAmount
(
$this
->
_order
->
getShippingTaxAmount
(),
$currency
);
// Create RateRequest to calculate the Tax class rate for the shipping method
$rateRequest
=
$this
->
_taxCalculation
->
getRateRequest
(
$this
->
_order
->
getShippingAddress
(),
$this
->
_order
->
getBillingAddress
(),
null
,
$this
->
_order
->
getStoreId
(),
$this
->
_order
->
getCustomerId
()
);
$taxClassId
=
$this
->
_taxConfig
->
getShippingTaxClass
(
$this
->
_order
->
getStoreId
());
$rateRequest
->
setProductClassId
(
$taxClassId
);
$rate
=
$this
->
_taxCalculation
->
getRate
(
$rateRequest
);
$itemVatPercentage
=
$this
->
_adyenHelper
->
getMinorUnitTaxPercent
(
$rate
);
$numberOfItems
=
1
;
$formFields
=
$this
->
setOpenInvoiceLineData
(
$formFields
,
$count
,
$currency
,
$description
,
$itemAmount
,
$itemVatAmount
,
$itemVatPercentage
,
$numberOfItems
);
}
$formFields
[
'openinvoicedata.refundDescription'
]
=
"Refund / Correction for "
.
$formFields
[
'merchantReference'
];
...
...
@@ -472,6 +521,38 @@ class Redirect extends \Magento\Payment\Block\Form
return
$formFields
;
}
/**
* Set the openinvoice line
*
* @param $count
* @param $currencyCode
* @param $description
* @param $itemAmount
* @param $itemVatAmount
* @param $itemVatPercentage
* @param $numberOfItems
*/
protected
function
setOpenInvoiceLineData
(
$formFields
,
$count
,
$currencyCode
,
$description
,
$itemAmount
,
$itemVatAmount
,
$itemVatPercentage
,
$numberOfItems
)
{
$linename
=
"line"
.
$count
;
$formFields
[
'openinvoicedata.'
.
$linename
.
'.currencyCode'
]
=
$currencyCode
;
$formFields
[
'openinvoicedata.'
.
$linename
.
'.description'
]
=
$description
;
$formFields
[
'openinvoicedata.'
.
$linename
.
'.itemAmount'
]
=
$itemAmount
;
$formFields
[
'openinvoicedata.'
.
$linename
.
'.itemVatAmount'
]
=
$itemVatAmount
;
$formFields
[
'openinvoicedata.'
.
$linename
.
'.itemVatPercentage'
]
=
$itemVatPercentage
;
$formFields
[
'openinvoicedata.'
.
$linename
.
'.numberOfItems'
]
=
$numberOfItems
;
if
(
$this
->
_adyenHelper
->
isVatCategoryHigh
(
$this
->
_order
->
getPayment
()
->
getAdditionalInformation
(
\Adyen\Payment\Observer\AdyenHppDataAssignObserver
::
BRAND_CODE
)))
{
$formFields
[
'openinvoicedata.'
.
$linename
.
'.vatCategory'
]
=
"High"
;
}
else
{
$formFields
[
'openinvoicedata.'
.
$linename
.
'.vatCategory'
]
=
"None"
;
}
return
$formFields
;
}
/**
* @param $genderId
* @return string
...
...
Observer/AdyenHppDataAssignObserver.php
View file @
506825ca
...
...
@@ -36,6 +36,7 @@ class AdyenHppDataAssignObserver extends AbstractDataAssignObserver
const
GENDER
=
'gender'
;
const
DOB
=
'dob'
;
const
TELEPHONE
=
'telephone'
;
const
DF_VALUE
=
'df_value'
;
/**
...
...
@@ -46,7 +47,8 @@ class AdyenHppDataAssignObserver extends AbstractDataAssignObserver
self
::
ISSUER_ID
,
self
::
GENDER
,
self
::
DOB
,
self
::
TELEPHONE
self
::
TELEPHONE
,
self
::
DF_VALUE
];
/**
...
...
view/frontend/requirejs-config.js
View file @
506825ca
...
...
@@ -6,7 +6,8 @@
/*global alert*/
var
config
=
{
paths
:
{
'
adyen/encrypt
'
:
'
Adyen_Payment/js/view/payment/adyen.encrypt.min
'
'
adyen/encrypt
'
:
'
Adyen_Payment/js/view/payment/adyen.encrypt.min
'
,
'
adyen/df
'
:
'
https://live.adyen.com/hpp/js/df
'
},
config
:
{
mixins
:
{
...
...
view/frontend/web/js/view/payment/method-renderer/adyen-hpp-method.js
View file @
506825ca
...
...
@@ -35,12 +35,14 @@ define(
'
Magento_Checkout/js/model/url-builder
'
,
'
Adyen_Payment/js/model/adyen-payment-service
'
,
'
Magento_Customer/js/model/customer
'
,
'
Magento_Checkout/js/model/full-screen-loader
'
'
Magento_Checkout/js/model/full-screen-loader
'
,
'
adyen/df
'
],
function
(
ko
,
$
,
Component
,
setPaymentMethodAction
,
selectPaymentMethodAction
,
quote
,
checkoutData
,
additionalValidators
,
storage
,
urlBuilder
,
adyenPaymentService
,
customer
,
fullScreenLoader
)
{
function
(
ko
,
$
,
Component
,
setPaymentMethodAction
,
selectPaymentMethodAction
,
quote
,
checkoutData
,
additionalValidators
,
storage
,
urlBuilder
,
adyenPaymentService
,
customer
,
fullScreenLoader
,
deviceFingerprint
)
{
'
use strict
'
;
var
brandCode
=
ko
.
observable
(
null
);
var
paymentMethod
=
ko
.
observable
(
null
);
var
dfValue
=
ko
.
observable
(
null
);
return
Component
.
extend
({
self
:
this
,
...
...
@@ -55,7 +57,8 @@ define(
'
issuerId
'
,
'
gender
'
,
'
dob
'
,
'
telephone
'
'
telephone
'
,
'
dfValue
'
]);
return
this
;
},
...
...
@@ -89,6 +92,12 @@ define(
).
done
(
function
(
response
)
{
adyenPaymentService
.
setPaymentMethods
(
response
);
// set device fingerprint value
dfSet
(
'
dfValue
'
,
0
);
// propagate this manually to knockoutjs otherwise it would not work
dfValue
(
$
(
'
#dfValue
'
).
val
());
fullScreenLoader
.
stopLoader
();
}
).
fail
(
function
(
error
)
{
...
...
@@ -114,7 +123,6 @@ define(
return
self
.
validate
();
}
if
(
value
.
brandCode
==
"
ideal
"
)
{
result
.
issuerIds
=
value
.
issuers
;
result
.
issuerId
=
ko
.
observable
(
null
);
...
...
@@ -155,17 +163,16 @@ define(
if
(
this
.
validate
()
&&
additionalValidators
.
validate
())
{
var
data
=
{};
data
.
method
=
self
.
method
;
data
.
po_number
=
null
;
var
additionalData
=
{};
additionalData
.
brand_code
=
self
.
value
;
additionalData
.
df_value
=
dfValue
();
if
(
brandCode
()
==
"
ideal
"
)
{
additionalData
.
issuer_id
=
this
.
issuerId
();
}
else
if
(
brandCode
()
==
"
klarna
"
)
{
}
else
if
(
self
.
isPaymentMethodOpenInvoiceMethod
()
)
{
additionalData
.
gender
=
this
.
gender
();
additionalData
.
dob
=
this
.
dob
();
additionalData
.
telephone
=
this
.
telephone
();
...
...
@@ -187,7 +194,7 @@ define(
"
method
"
:
self
.
method
,
"
po_number
"
:
null
,
"
additional_data
"
:
{
brand_code
:
self
.
value
,
brand_code
:
self
.
value
}
};
...
...
@@ -205,7 +212,7 @@ define(
isBrandCodeChecked
:
ko
.
computed
(
function
()
{
if
(
!
quote
.
paymentMethod
())
{
return
null
;
return
null
;
}
if
(
quote
.
paymentMethod
().
method
==
paymentMethod
())
{
...
...
view/frontend/web/template/payment/hpp-form.html
View file @
506825ca
...
...
@@ -153,6 +153,20 @@
<!--/ko-->
<!--/ko-->
<input
type=
"hidden"
id=
"dfValue"
name=
"payment[dfValue]"
/>
<script>
require
([
"
domReady!
"
],
function
(){
// dfDo("dfValue");
dfSet
(
'
dfValue
'
,
0
);
});
</script>
<!-- ko if: (isPaymentMethodSelectionOnAdyen()) -->
<div
class=
"payment-method"
data-bind=
"css: {'_active': (getCode() == isChecked())}"
>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment