2024-01-07 11:00:24 -06:00
|
|
|
import { InputGroup } from 'react-bootstrap'
|
|
|
|
import { getGetServerSideProps } from '../../../api/ssrApollo'
|
|
|
|
import { Form, Input } from '../../../components/form'
|
|
|
|
import { CenterLayout } from '../../../components/layout'
|
|
|
|
import { useMe } from '../../../components/me'
|
|
|
|
import { WalletButtonBar, WalletCard } from '../../../components/wallet-card'
|
|
|
|
import { useMutation } from '@apollo/client'
|
|
|
|
import { REMOVE_AUTOWITHDRAW, SET_AUTOWITHDRAW } from '../../../fragments/users'
|
|
|
|
import { useToast } from '../../../components/toast'
|
2024-01-13 01:09:50 +01:00
|
|
|
import { lnAddrAutowithdrawSchema, isNumber } from '../../../lib/validate'
|
2024-01-07 11:00:24 -06:00
|
|
|
import { useRouter } from 'next/router'
|
|
|
|
import { useEffect, useState } from 'react'
|
2024-01-13 11:28:14 -06:00
|
|
|
import { numWithUnits } from '../../../lib/format'
|
2024-01-07 11:00:24 -06:00
|
|
|
|
|
|
|
export const getServerSideProps = getGetServerSideProps({ authRequired: true })
|
|
|
|
|
|
|
|
function useAutoWithdrawEnabled () {
|
|
|
|
const me = useMe()
|
2024-01-13 01:09:50 +01:00
|
|
|
return me?.privates?.lnAddr && isNumber(me?.privates?.autoWithdrawThreshold) && isNumber(me?.privates?.autoWithdrawMaxFeePercent)
|
2024-01-07 11:00:24 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
export default function LightningAddress () {
|
|
|
|
const me = useMe()
|
|
|
|
const toaster = useToast()
|
|
|
|
const router = useRouter()
|
|
|
|
const [setAutoWithdraw] = useMutation(SET_AUTOWITHDRAW)
|
|
|
|
const enabled = useAutoWithdrawEnabled()
|
|
|
|
const [removeAutoWithdraw] = useMutation(REMOVE_AUTOWITHDRAW)
|
2024-01-13 01:09:50 +01:00
|
|
|
const autoWithdrawThreshold = isNumber(me?.privates?.autoWithdrawThreshold) ? me?.privates?.autoWithdrawThreshold : 10000
|
2024-01-07 11:00:24 -06:00
|
|
|
const [sendThreshold, setSendThreshold] = useState(Math.max(Math.floor(autoWithdrawThreshold / 10), 1))
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
setSendThreshold(Math.max(Math.floor(me?.privates?.autoWithdrawThreshold / 10), 1))
|
|
|
|
}, [autoWithdrawThreshold])
|
|
|
|
|
|
|
|
return (
|
|
|
|
<CenterLayout>
|
|
|
|
<h2 className='pb-2'>lightning address</h2>
|
2024-01-13 11:28:14 -06:00
|
|
|
<h6 className='text-muted text-center pb-3'>autowithdraw to a lightning address to maintain desired balance</h6>
|
2024-01-07 11:00:24 -06:00
|
|
|
<Form
|
|
|
|
initial={{
|
|
|
|
lnAddr: me?.privates?.lnAddr || '',
|
2024-01-13 01:09:50 +01:00
|
|
|
autoWithdrawThreshold,
|
|
|
|
autoWithdrawMaxFeePercent: isNumber(me?.privates?.autoWithdrawMaxFeePercent) ? me?.privates?.autoWithdrawMaxFeePercent : 1
|
2024-01-07 11:00:24 -06:00
|
|
|
}}
|
2024-01-12 09:37:50 -06:00
|
|
|
schema={lnAddrAutowithdrawSchema({ me })}
|
2024-01-07 11:00:24 -06:00
|
|
|
onSubmit={async ({ autoWithdrawThreshold, autoWithdrawMaxFeePercent, ...values }) => {
|
|
|
|
try {
|
|
|
|
await setAutoWithdraw({
|
|
|
|
variables: {
|
|
|
|
lnAddr: values.lnAddr,
|
|
|
|
autoWithdrawThreshold: Number(autoWithdrawThreshold),
|
|
|
|
autoWithdrawMaxFeePercent: Number(autoWithdrawMaxFeePercent)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
toaster.success('saved settings')
|
|
|
|
router.push('/settings/wallets')
|
|
|
|
} catch (err) {
|
|
|
|
console.error(err)
|
|
|
|
toaster.danger('failed to attach:' + err.message || err.toString?.())
|
|
|
|
}
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<Input
|
|
|
|
label='lightning address'
|
|
|
|
name='lnAddr'
|
|
|
|
required
|
|
|
|
autoFocus
|
|
|
|
/>
|
|
|
|
<Input
|
2024-01-12 23:45:38 -06:00
|
|
|
label='desired balance'
|
2024-01-07 11:00:24 -06:00
|
|
|
name='autoWithdrawThreshold'
|
|
|
|
onChange={(formik, e) => {
|
|
|
|
const value = e.target.value
|
|
|
|
setSendThreshold(Math.max(Math.floor(value / 10), 1))
|
|
|
|
}}
|
2024-01-13 11:28:14 -06:00
|
|
|
hint={isNumber(sendThreshold) ? `note: attempts to keep your balance within ${numWithUnits(sendThreshold)} of this amount` : undefined}
|
2024-01-07 11:00:24 -06:00
|
|
|
append={<InputGroup.Text className='text-monospace'>sats</InputGroup.Text>}
|
|
|
|
/>
|
|
|
|
<Input
|
|
|
|
label='max fee'
|
|
|
|
name='autoWithdrawMaxFeePercent'
|
|
|
|
hint='max fee as percent of withdrawal amount'
|
|
|
|
append={<InputGroup.Text>%</InputGroup.Text>}
|
|
|
|
/>
|
|
|
|
<WalletButtonBar
|
|
|
|
enabled={enabled} onDelete={async () => {
|
|
|
|
try {
|
|
|
|
await removeAutoWithdraw()
|
|
|
|
toaster.success('saved settings')
|
|
|
|
router.push('/settings/wallets')
|
|
|
|
} catch (err) {
|
|
|
|
console.error(err)
|
|
|
|
toaster.danger('failed to unattach:' + err.message || err.toString?.())
|
|
|
|
}
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</Form>
|
|
|
|
</CenterLayout>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
export function LightningAddressWalletCard () {
|
|
|
|
const enabled = useAutoWithdrawEnabled()
|
|
|
|
|
|
|
|
return (
|
|
|
|
<WalletCard
|
|
|
|
title='lightning address'
|
|
|
|
badges={['receive only', 'non-custodialish']}
|
|
|
|
provider='lightning-address'
|
|
|
|
enabled={enabled}
|
|
|
|
/>
|
|
|
|
)
|
|
|
|
}
|