MultiSafepay Payments API integration for Vue Storefront with Magento 2.
MultiSafepay is a collecting payment service provider which means we take care of the agreements, technical details, and payment collection for each payment method. You can start selling online today and manage all your transactions from one place.
Order status page after the customer has successfullly paid.
To use this module, you need a MultiSafepay account, or create a test account.
To install this module in Vue Storefront, follow these steps:
-
Make sure you meet the requirements for your Magento 2 installation, and then follow the installation steps in the README file.
-
Add the Vue Storefront API extension we created for the MultiSafepay Payments API, and then follow the installation steps in the README file.
-
To integrate this module into Vue Storefront, clone this git repository from within your vue-storefront root folder:
git clone [email protected]:MultiSafepay/vsf-payment-multisafepay.git src/modules/vsf-payment-multisafepay
-
Open
src/modules/client.ts
-
Add:
...
import { MultiSafePayPaymentModule } from './vsf-payment-multisafepay'
- Make sure you also register the module in registerClientModules:
registerModule(MultiSafePayPaymentModule);
- Add the config properties in
config/local.json
"paymentService": {
"endpoint": "http://localhost:8080/api/ext/vsf-multisafepay-service-api"
},
- Make sure you set the correct location to your API and the routes to the CMS pages in case of an error or an invalid payment status check.
We used the default Vue Storefront theme. If using your own theme, make the following changes. We created isolated components to separate the logic from VSF core you also to make a few small changes on the core.
- Copy and paste the checkout page as we change one v-show condition of the thank you page to v-if
<thank-you-page v-if="isThankYouPage" />
- As we redirect to the MultiSafepay gateweay after placing the order, VSF shows the default thank you page so copy and paste the file to add a notification on the created method.
created(){
this.$bus.$emit('notification-progress-start', [this.$t('Redirecting to MultiSafepay'), '...'].join(''))
},
- To display Multisafepay payment methods, add the
PaymentMethods
component into thePayment checkout component
in one of the following two ways:
- Copy and paste the Payment Component from this module to your default theme:
Or
- Remove the following code from the Payment Component (core/blocks/Checkout/Payment.vue):
<div v-for="(method, index) in paymentMethods" :key="index" class="col-md-6">
<label class="radioStyled">
{{ method.title ? method.title : method.name }}
<input
type="radio"
:value="method.code"
name="payment-method"
v-model="payment.paymentMethod"
@change="$v.payment.paymentMethod.$touch(); changePaymentMethod();"
/>
<span class="checkmark" />
</label>
</div>
And adding the following:
<payment-methods
:payment-methods="this.paymentMethods"
:payment="this.payment"
:validate="$v.payment"
:change-payment-method="changePaymentMethod"
></payment-methods>
- Import the component and add it to the component section:
import PaymentMethods from "src/modules/vsf-payment-multisafepay/components/PaymentMethods";
To enable payment methods in your Vue Storefront checkout, follow these steps:
- In your MultiSafepay account, enable the payment method. See the relevant payment method page.
- In your Magento 2 backend, in the MultiSafepay Payments for Magento 2 module, enable the payment method.
- Add the payment method to the
payment_methods_mapping
property in theorder property
config.
Example:
...
"orders": {
"payment_methods_mapping": {
"MAESTRO": "maestro",
"BANKTRANS": "banktrans",
"DIRECTBANK": "directbank",
"GIROPAY": "giropay",
"MISTERCASH": "mistercash",
"EPS": "eps",
"IDEAL": "ideal",
"TRUSTLY": "trustly",
"MASTERCARD": "mastercard",
"VISA": "visa"
},
}
To display the logo of each payment method, copy and paste the following code below payment_methods_mapping_img
:
"payment_methods_mapping_img": {
"MAESTRO": "maestro",
"BANKTRANS": "banktransfer",
"DIRECTBANK": "sofortbank",
"GIROPAY": "giropay",
"MISTERCASH": "mistercash",
"EPS": "eps",
"IDEAL": "ideal",
"TRUSTLY": "trustly",
"MASTERCARD": "master",
"VISA": "visa"
},
It's not yet possible to pay for orders placed when the user is offline.
For support or questions, create an issue in this repository or email the Integration Team at [email protected]
Thanks to Lakefields as this project is based on their integration. ❤️
Are you a developer interested in working at MultiSafepay? Check out our job openings and feel free to get in touch.