import { useEffect } from 'react' 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 { SSR, ANON_COMMENT_FEE, ANON_POST_FEE } from '../lib/constants' import { numWithUnits } from '../lib/format' import { useMe } from './me' import AnonIcon from '../svgs/spy-fill.svg' import { useShowModal } from './modal' import Link from 'next/link' function Receipt ({ cost, repetition, imageFeesInfo, baseFee, parentId, boost }) { return ( {repetition > 0 && } {imageFeesInfo.totalFees > 0 && } {boost > 0 && }
{numWithUnits(baseFee, { abbreviate: false })} {parentId ? 'reply' : 'post'} fee
x 10{repetition} {repetition} {parentId ? 'repeat or self replies' : 'posts'} in 10m
+ {imageFeesInfo.nUnpaid} x {numWithUnits(imageFeesInfo.imageFee, { abbreviate: false })} image fee
+ {numWithUnits(boost, { abbreviate: false })} boost
{numWithUnits(cost, { abbreviate: false })} total fee
) } function AnonInfo () { const showModal = useShowModal() return ( showModal(onClose =>
You are posting without an account
  1. You'll pay by invoice
  2. Your content will be content-joined (get it?!) under the @anon account
  3. Any sats your content earns will go toward rewards
  4. We won't be able to notify you when you receive replies
btw if you don't need to be anonymous, posting is cheaper with an account
) } /> ) } export default function FeeButton ({ parentId, 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, SSR ? {} : { 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 * Math.pow(10, repetition) + Number(boost) useEffect(() => { formik?.setFieldValue('cost', cost) }, [formik?.getFieldProps('cost').value, cost]) const imageFeesInfo = formik?.getFieldProps('imageFeesInfo').value || { totalFees: 0 } const totalCost = cost + imageFeesInfo.totalFees const show = alwaysShow || !formik?.isSubmitting return (
{text}{totalCost > 1 && show && {numWithUnits(totalCost, { abbreviate: false })}} {!me && } {totalCost > baseFee && show && }
) } function EditReceipt ({ cost, paidSats, imageFeesInfo, boost, parentId }) { return ( {imageFeesInfo.totalFees > 0 && } {boost > 0 && }
{numWithUnits(0, { abbreviate: false })} edit fee
+ {imageFeesInfo.nUnpaid} x {numWithUnits(imageFeesInfo.imageFee, { abbreviate: false })} image fee
+ {numWithUnits(boost, { abbreviate: false })} boost
{numWithUnits(cost)} total fee
) } export function EditFeeButton ({ paidSats, ChildButton, variant, text, alwaysShow, parentId }) { const formik = useFormikContext() const boost = (formik?.values?.boost || 0) - (formik?.initialValues?.boost || 0) const cost = Number(boost) useEffect(() => { formik?.setFieldValue('cost', cost) }, [formik?.getFieldProps('cost').value, cost]) const imageFeesInfo = formik?.getFieldProps('imageFeesInfo').value || { totalFees: 0 } const totalCost = cost + imageFeesInfo.totalFees const show = alwaysShow || !formik?.isSubmitting return (
= 0 ? totalCost : 0, { abbreviate: false })}> {text}{totalCost > 0 && show && {numWithUnits(totalCost, { abbreviate: false })}} {totalCost > 0 && show && }
) }