'use client'; import React, { FC, useEffect, useState } from 'react'; import type { StripeError } from '@stripe/stripe-js'; import { useStripe, useElements, PaymentElement, Elements, } from '@stripe/react-stripe-js'; import { Form, Button, message } from 'antd'; import getStripe from '../../utils/get-stripe'; import { createPaymentIntent} from '../../actions/stripe'; import { Payment } from '../../types/payment'; import { i18nText } from '../../i18nKeys'; import { WithError } from '../view/WithError'; type PaymentFormProps = { amount: number, sessionId?: string, locale: string } type PaymentInfo = 'initial' | 'error' | 'processing' | 'requires_payment_method' | 'requires_confirmation' | 'requires_action' | 'succeeded'; const PaymentStatus = ({ status }: { status?: PaymentInfo }) => { switch (status) { case 'processing': case 'requires_payment_method': case 'requires_confirmation': return

Processing...

; case 'requires_action': return

Authenticating...

; case 'succeeded': return

Payment Succeeded

; default: return null; } }; export const CheckoutForm: FC = ({ amount, sessionId, locale }) => { const [form] = Form.useForm(); const formAmount = Form.useWatch('amount', form); const [paymentType, setPaymentType] = useState(''); const [payment, setPayment] = useState<{ status: PaymentInfo }>({ status: 'initial' }); const [errorData, setErrorData] = useState(); const stripe = useStripe(); const elements = useElements(); useEffect(() => { elements?.update({ amount: formAmount * 100 }); }, [formAmount]); const onSubmit = async () => { try { if (!elements || !stripe) return; setErrorData(undefined); setPayment({ status: "processing" }); const { error: submitError } = await elements.submit(); if (submitError) { if (submitError.message) { message.error(submitError.message); } return; } const { client_secret: clientSecret } = await createPaymentIntent( { amount, sessionId } ); const { error: confirmError } = await stripe!.confirmPayment({ elements, clientSecret, confirmParams: { return_url: window.location.href, payment_method_data: { allow_redisplay: 'limited', // billing_details: { // name: input.cardholderName, // }, }, }, }); if (confirmError) { setErrorData({ title: i18nText('errorPayment', locale), message: confirmError.message ?? 'An unknown error occurred' }); } } catch (err) { const { message } = err as StripeError; setErrorData({ title: i18nText('errorPayment', locale), message: message ?? 'An unknown error occurred' }); } }; return (
{ setPaymentType(e.value.type); }} />
); } export const StripeElementsForm: FC = ({ amount, sessionId, locale }) => { return ( ); };