48 lines
1.5 KiB
JavaScript
48 lines
1.5 KiB
JavaScript
|
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) {
|
||
|
const updatedInv = await invoice.cancel(inv).catch(console.error)
|
||
|
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
|
||
|
}
|