import { useQuery, useMutation } from '@apollo/client' import { CenterLayout } from '@/components/layout' import { CopyInput, Input, InputSkeleton } from '@/components/form' import InputGroup from 'react-bootstrap/InputGroup' import InvoiceStatus from '@/components/invoice-status' import { useRouter } from 'next/router' import { WITHDRAWL } from '@/fragments/wallet' import Link from 'next/link' import { SSR, INVOICE_RETENTION_DAYS, FAST_POLL_INTERVAL } from '@/lib/constants' import { numWithUnits } from '@/lib/format' import Bolt11Info from '@/components/bolt11-info' import { datePivot, timeLeft } from '@/lib/time' import { useMe } from '@/components/me' import { useToast } from '@/components/toast' import { gql } from 'graphql-tag' import { useShowModal } from '@/components/modal' import { DeleteConfirm } from '@/components/delete' import { getGetServerSideProps } from '@/api/ssrApollo' import { Badge } from 'react-bootstrap' import styles from '@/components/invoice.module.css' // force SSR to include CSP nonces export const getServerSideProps = getGetServerSideProps({ query: null }) export default function Withdrawl () { return ( ) } export function WithdrawlSkeleton ({ status }) { return ( <>
) } function LoadWithdrawl () { const router = useRouter() const { loading, error, data } = useQuery(WITHDRAWL, SSR ? {} : { variables: { id: router.query.id }, pollInterval: FAST_POLL_INTERVAL, nextFetchPolicy: 'cache-and-network' }) if (error) return
error
if (!data || loading) { return } const TryMaxFee = () => try increasing max fee let status = 'pending' let variant = 'default' switch (data.withdrawl.status) { case 'CONFIRMED': if (data.withdrawl.forwardedActionType) { status = <>{`forwarded ${numWithUnits(data.withdrawl.satsPaid, { abbreviate: false })}`} p2p } else { status = `sent ${numWithUnits(data.withdrawl.satsPaid, { abbreviate: false })} with ${numWithUnits(data.withdrawl.satsFeePaid, { abbreviate: false })} in routing fees` } variant = 'confirmed' break case 'INSUFFICIENT_BALANCE': status = <>insufficient balance contact keyan! variant = 'failed' break case 'INVALID_PAYMENT': status = 'invalid invoice' variant = 'failed' break case 'PATHFINDING_TIMEOUT': status = <>timed out finding route variant = 'failed' break case 'ROUTE_NOT_FOUND': status = <>no route variant = 'failed' break case 'UNKNOWN_FAILURE': status = <>unknown error variant = 'failed' break default: break } return ( <>
sats} />
) } function PrivacyOption ({ wd }) { if (!wd.bolt11) return const { me } = useMe() const keepUntil = datePivot(new Date(wd.createdAt), { days: INVOICE_RETENTION_DAYS }) const oldEnough = new Date() >= keepUntil if (!oldEnough) { return ( {`this invoice ${me.privates?.autoDropBolt11s ? 'will be auto-deleted' : 'can be deleted'} in ${timeLeft(keepUntil)}`} ) } const showModal = useShowModal() const toaster = useToast() const [dropBolt11] = useMutation( gql` mutation dropBolt11($id: ID!) { dropBolt11(id: $id) { id } }`, { update (cache) { cache.modify({ id: `Withdrawl:${wd.id}`, fields: { bolt11: () => null, hash: () => null } }) } }) return ( { showModal(onClose => { return ( { if (me) { try { await dropBolt11({ variables: { id: wd.id } }) } catch (err) { toaster.danger('unable to delete invoice: ' + err.message || err.toString?.()) throw err } finally { onClose() } } }} /> ) }) }} >delete invoice ) }