import { useEffect } from 'react' import { numWithUnits } from '@/lib/format' import AccordianItem from './accordian-item' import Qr, { QrSkeleton } from './qr' import { CompactLongCountdown } from './countdown' import PayerData from './payer-data' import Bolt11Info from './bolt11-info' import { useQuery } from '@apollo/client' import { INVOICE } from '@/fragments/wallet' import { FAST_POLL_INTERVAL, SSR } from '@/lib/constants' import { NoAttachedWalletError } from '@/wallets/errors' import ItemJob from './item-job' import Item from './item' import { CommentFlat } from './comment' import classNames from 'classnames' import Moon from '@/svgs/moon-fill.svg' import { Badge } from 'react-bootstrap' import styles from './invoice.module.css' export default function Invoice ({ id, query = INVOICE, modal, onPayment, onExpired, onCanceled, info, successVerb = 'deposited', heldVerb = 'settling', walletError, poll, waitFor, ...props }) { const { data, error } = useQuery(query, SSR ? {} : { pollInterval: FAST_POLL_INTERVAL, variables: { id }, nextFetchPolicy: 'cache-and-network', skip: !poll }) const invoice = data?.invoice const expired = invoice?.cancelledAt && new Date(invoice.expiresAt) < new Date(invoice.cancelledAt) useEffect(() => { if (!invoice) { return } if (waitFor?.(invoice)) { onPayment?.(invoice) } if (expired) { onExpired?.(invoice) } else if (invoice.cancelled || invoice.actionError) { onCanceled?.(invoice) } }, [invoice, expired, onExpired, onCanceled, onPayment]) if (error) { return
{walletError.message}
{JSON.stringify(nostr, null, 2)}
}
/>
: null}