129 lines
4.5 KiB
JavaScript
129 lines
4.5 KiB
JavaScript
import Table from 'react-bootstrap/Table'
|
|
import ActionTooltip from './action-tooltip'
|
|
import Info from './info'
|
|
import styles from './fee-button.module.css'
|
|
import { gql, useQuery } from '@apollo/client'
|
|
import { useFormikContext } from 'formik'
|
|
import { useMe } from './me'
|
|
import { ANON_COMMENT_FEE, ANON_POST_FEE } from '../lib/constants'
|
|
import { useEffect } from 'react'
|
|
|
|
function Receipt ({ cost, repetition, hasImgLink, baseFee, parentId, boost }) {
|
|
return (
|
|
<Table className={styles.receipt} borderless size='sm'>
|
|
<tbody>
|
|
<tr>
|
|
<td>{baseFee} sats</td>
|
|
<td align='right' className='font-weight-light'>{parentId ? 'reply' : 'post'} fee</td>
|
|
</tr>
|
|
{hasImgLink &&
|
|
<tr>
|
|
<td>x 10</td>
|
|
<td align='right' className='font-weight-light'>image/link fee</td>
|
|
</tr>}
|
|
{repetition > 0 &&
|
|
<tr>
|
|
<td>x 10<sup>{repetition}</sup></td>
|
|
<td className='font-weight-light' align='right'>{repetition} {parentId ? 'repeat or self replies' : 'posts'} in 10m</td>
|
|
</tr>}
|
|
{boost > 0 &&
|
|
<tr>
|
|
<td>+ {boost} sats</td>
|
|
<td className='font-weight-light' align='right'>boost</td>
|
|
</tr>}
|
|
</tbody>
|
|
<tfoot>
|
|
<tr>
|
|
<td className='fw-bold'>{cost} sats</td>
|
|
<td align='right' className='font-weight-light'>total fee</td>
|
|
</tr>
|
|
</tfoot>
|
|
</Table>
|
|
)
|
|
}
|
|
|
|
export default function FeeButton ({ parentId, hasImgLink, baseFee, ChildButton, variant, text, alwaysShow, disabled }) {
|
|
const me = useMe()
|
|
baseFee = me ? baseFee : (parentId ? ANON_COMMENT_FEE : ANON_POST_FEE)
|
|
const query = parentId
|
|
? gql`{ itemRepetition(parentId: "${parentId}") }`
|
|
: gql`{ itemRepetition }`
|
|
const { data } = useQuery(query, { pollInterval: 1000, nextFetchPolicy: 'cache-and-network' })
|
|
const repetition = me ? data?.itemRepetition || 0 : 0
|
|
const formik = useFormikContext()
|
|
const boost = Number(formik?.values?.boost) || 0
|
|
const cost = baseFee * (hasImgLink ? 10 : 1) * Math.pow(10, repetition) + Number(boost)
|
|
|
|
useEffect(() => {
|
|
formik.setFieldValue('cost', cost)
|
|
}, [cost])
|
|
|
|
const show = alwaysShow || !formik?.isSubmitting
|
|
return (
|
|
<div className='d-flex align-items-center'>
|
|
<ActionTooltip overlayText={`${cost} sats`}>
|
|
<ChildButton variant={variant} disabled={disabled}>{text}{cost > baseFee && show && <small> {cost} sats</small>}</ChildButton>
|
|
</ActionTooltip>
|
|
{cost > baseFee && show &&
|
|
<Info>
|
|
<Receipt baseFee={baseFee} hasImgLink={hasImgLink} repetition={repetition} cost={cost} parentId={parentId} boost={boost} />
|
|
</Info>}
|
|
</div>
|
|
)
|
|
}
|
|
|
|
function EditReceipt ({ cost, paidSats, addImgLink, boost, parentId }) {
|
|
return (
|
|
<Table className={styles.receipt} borderless size='sm'>
|
|
<tbody>
|
|
{addImgLink &&
|
|
<>
|
|
<tr>
|
|
<td>{paidSats} sats</td>
|
|
<td align='right' className='font-weight-light'>{parentId ? 'reply' : 'post'} fee</td>
|
|
</tr>
|
|
<tr>
|
|
<td>x 10</td>
|
|
<td align='right' className='font-weight-light'>image/link fee</td>
|
|
</tr>
|
|
<tr>
|
|
<td>- {paidSats} sats</td>
|
|
<td align='right' className='font-weight-light'>already paid</td>
|
|
</tr>
|
|
</>}
|
|
{boost > 0 &&
|
|
<tr>
|
|
<td>+ {boost} sats</td>
|
|
<td className='font-weight-light' align='right'>boost</td>
|
|
</tr>}
|
|
</tbody>
|
|
<tfoot>
|
|
<tr>
|
|
<td className='fw-bold'>{cost} sats</td>
|
|
<td align='right' className='font-weight-light'>total fee</td>
|
|
</tr>
|
|
</tfoot>
|
|
</Table>
|
|
)
|
|
}
|
|
|
|
export function EditFeeButton ({ paidSats, hadImgLink, hasImgLink, ChildButton, variant, text, alwaysShow, parentId }) {
|
|
const formik = useFormikContext()
|
|
const boost = formik?.values?.boost || 0
|
|
const addImgLink = hasImgLink && !hadImgLink
|
|
const cost = (addImgLink ? paidSats * 9 : 0) + Number(boost)
|
|
|
|
const show = alwaysShow || !formik?.isSubmitting
|
|
return (
|
|
<div className='d-flex align-items-center'>
|
|
<ActionTooltip overlayText={`${cost} sats`}>
|
|
<ChildButton variant={variant}>{text}{cost > 0 && show && <small> {cost} sats</small>}</ChildButton>
|
|
</ActionTooltip>
|
|
{cost > 0 && show &&
|
|
<Info>
|
|
<EditReceipt paidSats={paidSats} addImgLink={addImgLink} cost={cost} parentId={parentId} boost={boost} />
|
|
</Info>}
|
|
</div>
|
|
)
|
|
}
|