Saltar al contenido principal

Componentes Vue

Usa @monei-js/vue-components para añadir componentes de pago de MONEI a tu aplicación Vue 3. Cada componente es un componente Vue nativo con props tipadas y submit() mediante template ref.

Instalación

npm install @monei-js/vue-components @monei-js/components

Requiere Vue 3.3 o posterior.

Componentes

ComponenteDescripción
CardInputEntrada de tarjeta segura (iframe) con submit()
BizumBotón de Bizum + modal de verificación por teléfono
PayPalBotón de checkout de PayPal
PaymentRequestBotón de Apple Pay / Google Pay

Card Input

El componente Card Input recopila el número de tarjeta, la fecha de caducidad y el CVC en un único iframe seguro. Usa un template ref para llamar a submit() y obtener un token de pago.

<template>
<div>
<CardInput ref="cardInput" :payment-id="paymentId" :on-change="handleChange" />
<button @click="handleSubmit">Pay</button>
<p v-if="error">{{ error }}</p>
</div>
</template>

<script setup lang="ts">
import {ref} from 'vue';
import {CardInput, confirmPayment} from '@monei-js/vue-components';

const props = defineProps<{paymentId: string}>();
const cardInput = ref<InstanceType<typeof CardInput>>();
const error = ref('');

function handleChange(event: {error?: string}) {
error.value = event.error ?? '';
}

async function handleSubmit() {
const result = await cardInput.value!.submit();
if (result.error) {
error.value = result.error;
return;
}
await confirmPayment({paymentId: props.paymentId, paymentToken: result.token});
}
</script>

Consulta la Referencia de la API para ver todas las props de CardInput (estilo, placeholders, mensajes de error, callbacks de eventos).

Bizum

El componente Bizum muestra un botón de pago Bizum. Cuando el cliente hace clic, se abre un modal de verificación por teléfono para completar el pago.

<template>
<Bizum :payment-id="paymentId" :on-submit="handleSubmit" :on-error="handleError" />
</template>

<script setup lang="ts">
import {Bizum, confirmPayment} from '@monei-js/vue-components';

const props = defineProps<{paymentId: string}>();

async function handleSubmit(result: {token?: string}) {
if (result.token) {
await confirmPayment({paymentId: props.paymentId, paymentToken: result.token});
}
}

function handleError(error: string) {
console.error(error);
}
</script>

PayPal

El componente PayPal muestra un botón de checkout de PayPal. Cuando el cliente aprueba, recibes un token para confirmar el pago.

<template>
<PayPal :payment-id="paymentId" :on-submit="handleSubmit" :on-error="handleError" />
</template>

<script setup lang="ts">
import {PayPal, confirmPayment} from '@monei-js/vue-components';

const props = defineProps<{paymentId: string}>();

async function handleSubmit(result: {token?: string}) {
if (result.token) {
await confirmPayment({paymentId: props.paymentId, paymentToken: result.token});
}
}

function handleError(error: string) {
console.error(error);
}
</script>

PaymentRequest (Apple Pay / Google Pay)

El componente PaymentRequest muestra un botón de Apple Pay o Google Pay según el navegador y el dispositivo del cliente.

nota

Apple Pay requiere verificación de dominio tanto en desarrollo como en producción.

<template>
<PaymentRequest :payment-id="paymentId" :on-submit="handleSubmit" :on-error="handleError" />
</template>

<script setup lang="ts">
import {PaymentRequest, confirmPayment} from '@monei-js/vue-components';

const props = defineProps<{paymentId: string}>();

async function handleSubmit(result: {token?: string}) {
if (result.token) {
await confirmPayment({paymentId: props.paymentId, paymentToken: result.token});
}
}

function handleError(error: string) {
console.error(error);
}
</script>

Llamar a confirmPayment() sin un paymentToken abre el Modal de pago de MONEI — un checkout completo en la página donde el cliente puede seleccionar un método de pago y completar el pago.

<template>
<button @click="handleClick">Pay</button>
</template>

<script setup lang="ts">
import {confirmPayment} from '@monei-js/vue-components';

const props = defineProps<{paymentId: string}>();

async function handleClick() {
const result = await confirmPayment({paymentId: props.paymentId});
// Payment completed — check result.status
console.log(result);
}
</script>
important

Apple Pay no está disponible en el Modal de pago. Usa el componente PaymentRequest en su lugar.

Consulta Usar el Modal de pago para la guía de integración completa.

Próximos pasos