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, { userCancel: true }) reject(new InvoiceCanceledError(updatedInv)) } resolve(inv) } showModal(onClose => 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 }