stacker.news/pages/withdrawals/[id].js

105 lines
3.0 KiB
JavaScript
Raw Normal View History

2021-05-13 01:51:37 +00:00
import { useQuery } from '@apollo/client'
import { CenterLayout } from '../../components/layout'
2021-05-13 13:28:38 +00:00
import { CopyInput, Input, InputSkeleton } from '../../components/form'
import InputGroup from 'react-bootstrap/InputGroup'
import InvoiceStatus from '../../components/invoice-status'
2021-10-26 20:49:37 +00:00
import { useRouter } from 'next/router'
import { WITHDRAWL } from '../../fragments/wallet'
import Link from 'next/link'
import { SSR } from '../../lib/constants'
import { numWithUnits } from '../../lib/format'
import Bolt11Info from '../../components/bolt11-info'
2021-05-13 01:51:37 +00:00
2021-10-26 20:49:37 +00:00
export default function Withdrawl () {
2021-05-13 01:51:37 +00:00
return (
<CenterLayout>
2021-10-26 20:49:37 +00:00
<LoadWithdrawl />
</CenterLayout>
2021-05-13 01:51:37 +00:00
)
}
2021-05-13 21:19:51 +00:00
export function WithdrawlSkeleton ({ status }) {
return (
<>
<div className='w-100'>
<InputSkeleton label='invoice' />
</div>
<div className='w-100'>
<InputSkeleton label='max fee' />
</div>
<InvoiceStatus status={status} />
</>
)
}
2021-10-26 20:49:37 +00:00
function LoadWithdrawl () {
const router = useRouter()
const { loading, error, data } = useQuery(WITHDRAWL, SSR
? {}
: {
variables: { id: router.query.id },
pollInterval: 1000,
nextFetchPolicy: 'cache-and-network'
})
2021-05-13 01:51:37 +00:00
if (error) return <div>error</div>
if (!data || loading) {
2021-05-13 21:19:51 +00:00
return <WithdrawlSkeleton status='loading' />
}
const TryMaxFee = () =>
<Link href='/wallet?type=withdraw' className='text-reset text-underline'>
2023-07-24 18:35:05 +00:00
<small className='ms-3'>try increasing max fee</small>
</Link>
2021-05-13 21:19:51 +00:00
let status = 'pending'
let variant = 'default'
switch (data.withdrawl.status) {
case 'CONFIRMED':
status = `sent ${numWithUnits(data.withdrawl.satsPaid, { abbreviate: false })} with ${numWithUnits(data.withdrawl.satsFeePaid, { abbreviate: false })} in routing fees`
2021-05-13 21:19:51 +00:00
variant = 'confirmed'
break
case 'INSUFFICIENT_BALANCE':
2023-07-24 18:35:05 +00:00
status = <>insufficient balance <small className='ms-3'>contact keyan!</small></>
2021-05-13 21:19:51 +00:00
variant = 'failed'
break
case 'INVALID_PAYMENT':
status = 'invalid invoice'
variant = 'failed'
break
case 'PATHFINDING_TIMEOUT':
status = <>timed out finding route <TryMaxFee /></>
2021-05-13 21:19:51 +00:00
variant = 'failed'
break
case 'ROUTE_NOT_FOUND':
status = <>no route <TryMaxFee /></>
2021-05-13 21:19:51 +00:00
variant = 'failed'
break
2022-01-05 20:37:34 +00:00
case 'UNKNOWN_FAILURE':
status = <>unknown error</>
variant = 'failed'
break
2021-05-13 21:19:51 +00:00
default:
break
2021-05-13 01:51:37 +00:00
}
2021-05-13 13:28:38 +00:00
return (
<>
<div className='w-100'>
<CopyInput
label='invoice' type='text'
2022-08-18 18:15:24 +00:00
placeholder={data.withdrawl.bolt11} readOnly noForm
2021-05-13 13:28:38 +00:00
/>
</div>
<div className='w-100'>
<Input
label='max fee' type='text'
2022-08-18 18:15:24 +00:00
placeholder={data.withdrawl.satsFeePaying} readOnly noForm
2021-05-13 21:19:51 +00:00
append={<InputGroup.Text className='text-monospace'>sats</InputGroup.Text>}
2021-05-13 13:28:38 +00:00
/>
</div>
2021-05-13 21:19:51 +00:00
<InvoiceStatus variant={variant} status={status} />
<Bolt11Info bolt11={data.withdrawl.bolt11} />
2021-05-13 13:28:38 +00:00
</>
)
2021-05-13 01:51:37 +00:00
}