:::
Vue components for Mollie Payments (Nuxt module) โ
Features โ
- โฐ ย
useMollie
&useMollieCreditCard
composable function - ๐ ย
MollieCreditCardComponent.vue
component to use in a Vue project - ๐ฒ ย
ShopwareFrontendsCreditCard.vue
component to use in a Nuxt Shopware Powered project
Requirements โ
- Frontend side: any Nuxt 3 project, or a project with Shopware Frontends registered and running (you can use one of the Nuxt templates provided in shopware/frontends GitHub Project
- Backend side: Mollie Payments App for Shopware installed on your environment (See how to setup it locally)
Setup โ
Backend: Shopware 6 admin panel โ
Install the Mollie Payments in your Shopware 6 instance and set it up
Frontend: Nuxt 3 project โ
Install the dependencies
run
pnpm i
command.Configure Mollie module in
runtimeConfig > public
section of nuxt.config.ts
js
// ./nuxt.config.ts
mollie: {
defaultLocale: "en_US", // fallback locale
profileId: "pfl_E5EmGZ98YT", // from Mollie's dashboard
testMode: true,
},
Use Credit Card components โ
- For Shopware Frontends aware projects (with
@shopware/nuxt-module
enabled)
html
<script setup lang="ts">
import { useCheckout } from "@shopware/composables/dist";
const { selectedPaymentMethod } = useCheckout();
// the name may vary, so first, please check what comes from API
const showMollieCreditCardComponent = computed(
() =>
selectedPaymentMethod.value?.shortName ===
"mollie_payments_app_mollie_creditcard",
);
</script>
<template>
<!-- show credit card component conditionally -->
<ShopwareFrontendsCreditCard :v-if="showMollieCreditCardComponent" />
</template>
In this case, by clicking a submit / save button under the credit card form, there will be an additional request made to the mollie's endpoint in your Shopware 6 instance.
- For plain Nuxt 3 project
html
<MollieCreditCardComponent />
Events and properties โ
Control credit card form and react on events using events and properties:
ts
const props = defineProps<{
locale?: MollieLocale;
submitButtonLabel?: string;
submitDisabled?: boolean;
}>();
const emits = defineEmits<{
(e: "submit", token: string | undefined): void;
(e: "error", error: string | undefined): void;
}>();
Example:
html
<ShopwareFrontendsCreditCard
submit-button-label="Save"
locale="en_US"
:submit-disabled="!!CreditCardToken"
@submit="
(token) => {
CreditCardToken = `${token} โ๏ธ`;
CreditCardError = null;
}
"
@error="
(message) => {
CreditCardError = `${message} โ`;
}
"
/>
Development โ
Run a playground project with configured Mollie module from current dir.
bash
# Run a playground (nuxt 3) project in dev mode
pnpm dev
Auto-generated
This page is generated from an external markdown file. In case of any issues or dead links, please visit the source file.