2024-12-05 14:52:32 +00:00
|
|
|
import { useCallback } from 'react'
|
|
|
|
import Invoice from '@/components/invoice'
|
|
|
|
import { InvoiceCanceledError, InvoiceExpiredError } from '@/wallets/errors'
|
|
|
|
import { useShowModal } from '@/components/modal'
|
|
|
|
import useInvoice from '@/components/use-invoice'
|
|
|
|
|
|
|
|
export default function useQrPayment () {
|
|
|
|
const invoice = useInvoice()
|
|
|
|
const showModal = useShowModal()
|
|
|
|
|
|
|
|
const waitForQrPayment = useCallback(async (inv, walletError,
|
|
|
|
{
|
|
|
|
keepOpen = true,
|
|
|
|
cancelOnClose = true,
|
|
|
|
persistOnNavigate = false,
|
|
|
|
waitFor = inv => inv?.satsReceived > 0
|
|
|
|
} = {}
|
|
|
|
) => {
|
|
|
|
return await new Promise((resolve, reject) => {
|
|
|
|
let paid
|
|
|
|
const cancelAndReject = async (onClose) => {
|
|
|
|
if (!paid && cancelOnClose) {
|
2025-01-02 17:53:05 +00:00
|
|
|
const updatedInv = await invoice.cancel(inv, { userCancel: true })
|
2024-12-05 14:52:32 +00:00
|
|
|
reject(new InvoiceCanceledError(updatedInv))
|
|
|
|
}
|
|
|
|
resolve(inv)
|
|
|
|
}
|
|
|
|
showModal(onClose =>
|
|
|
|
<Invoice
|
|
|
|
id={inv.id}
|
|
|
|
modal
|
|
|
|
description
|
|
|
|
status='loading'
|
|
|
|
successVerb='received'
|
|
|
|
walletError={walletError}
|
|
|
|
waitFor={waitFor}
|
|
|
|
onExpired={inv => reject(new InvoiceExpiredError(inv))}
|
|
|
|
onCanceled={inv => { onClose(); reject(new InvoiceCanceledError(inv, inv?.actionError)) }}
|
|
|
|
onPayment={(inv) => { paid = true; onClose(); resolve(inv) }}
|
|
|
|
poll
|
|
|
|
/>,
|
|
|
|
{ keepOpen, persistOnNavigate, onClose: cancelAndReject })
|
|
|
|
})
|
|
|
|
}, [invoice])
|
|
|
|
|
|
|
|
return waitForQrPayment
|
|
|
|
}
|