Skip to content

Commit

Permalink
feat(fb): show mining fee settings on fb creation/renewal
Browse files Browse the repository at this point in the history
  • Loading branch information
theborakompanioni committed Oct 18, 2023
1 parent 0a1b08f commit 675a4ae
Show file tree
Hide file tree
Showing 4 changed files with 70 additions and 30 deletions.
10 changes: 8 additions & 2 deletions src/components/PaymentConfirmModal.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { useMemo } from 'react'
import { PropsWithChildren, useMemo } from 'react'
import { Trans, useTranslation } from 'react-i18next'
import * as rb from 'react-bootstrap'
import Sprite from './Sprite'
Expand Down Expand Up @@ -82,8 +82,9 @@ export function PaymentConfirmModal({
feeConfigValues,
showPrivacyInfo = true,
},
children,
...confirmModalProps
}: PaymentConfirmModalProps) {
}: PropsWithChildren<PaymentConfirmModalProps>) {
const { t } = useTranslation()
const settings = useSettings()

Expand Down Expand Up @@ -208,6 +209,11 @@ export function PaymentConfirmModal({
</rb.Col>
</rb.Row>
)}
{children && (
<rb.Row>
<rb.Col xs={12}>{children}</rb.Col>
</rb.Row>
)}
</rb.Container>
</ConfirmModal>
)
Expand Down
79 changes: 55 additions & 24 deletions src/components/fb/CreateFidelityBond.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@ import { Trans, useTranslation } from 'react-i18next'
import { CurrentWallet, Utxo, Utxos, WalletInfo, useReloadCurrentWalletInfo } from '../../context/WalletContext'
import Alert from '../Alert'
import Sprite from '../Sprite'
import { ConfirmModal } from '../Modal'
import {
SelectJar,
SelectUtxos,
Expand All @@ -18,9 +17,33 @@ import {
import * as fb from './utils'
import { isDebugFeatureEnabled } from '../../constants/debugFeatures'
import styles from './CreateFidelityBond.module.css'
import { PaymentConfirmModal } from '../PaymentConfirmModal'
import { useFeeConfigValues } from '../../hooks/Fees'

const TIMEOUT_RELOAD_UTXOS_AFTER_FB_CREATE_MS = 2_500

export const LockInfoAlert = ({ lockDate, className }: { lockDate: Api.Lockdate; className?: string }) => {
const { t, i18n } = useTranslation()

return (
<Alert
className={className}
variant="warning"
message={
<>
{t('earn.fidelity_bond.confirm_modal.body', {
date: new Date(fb.lockdate.toTimestamp(lockDate)).toUTCString(),
humanReadableDuration: fb.time.humanReadableDuration({
to: fb.lockdate.toTimestamp(lockDate),
locale: i18n.resolvedLanguage || i18n.language,
}),
})}
</>
}
/>
)
}

const steps = {
selectDate: 0,
selectJar: 1,
Expand All @@ -41,8 +64,9 @@ interface CreateFidelityBondProps {
}

const CreateFidelityBond = ({ otherFidelityBondExists, wallet, walletInfo, onDone }: CreateFidelityBondProps) => {
const { t } = useTranslation()
const reloadCurrentWalletInfo = useReloadCurrentWalletInfo()
const { t, i18n } = useTranslation()
const feeConfigValues = useFeeConfigValues()[0]

const [isExpanded, setIsExpanded] = useState(false)
const [isLoading, setIsLoading] = useState(false)
Expand All @@ -53,17 +77,19 @@ const CreateFidelityBond = ({ otherFidelityBondExists, wallet, walletInfo, onDon
const [lockDate, setLockDate] = useState<Api.Lockdate | null>(null)
const [selectedJar, setSelectedJar] = useState<JarIndex>()
const [selectedUtxos, setSelectedUtxos] = useState<Utxos>([])
const [timelockedAddress, setTimelockedAddress] = useState(null)
const [timelockedAddress, setTimelockedAddress] = useState<Api.BitcoinAddress>()
const [utxoIdsToBeSpent, setUtxoIdsToBeSpent] = useState([])
const [createdFidelityBondUtxo, setCreatedFidelityBondUtxo] = useState<Utxo>()
const [frozenUtxos, setFrozenUtxos] = useState<Utxos>([])

const allUtxosSelected = useMemo(() => {
return (
walletInfo.balanceSummary.calculatedTotalBalanceInSats ===
selectedUtxos.map((it) => it.value).reduce((prev, curr) => prev + curr, 0)
)
}, [walletInfo, selectedUtxos])
const selectedUtxosTotalValue = useMemo(
() => selectedUtxos.map((it) => it.value).reduce((prev, curr) => prev + curr, 0),
[selectedUtxos],
)
const allUtxosSelected = useMemo(
() => walletInfo.balanceSummary.calculatedTotalBalanceInSats === selectedUtxosTotalValue,
[walletInfo, selectedUtxosTotalValue],
)

const yearsRange = useMemo(() => {
if (isDebugFeatureEnabled('allowCreatingExpiredFidelityBond')) {
Expand All @@ -79,7 +105,7 @@ const CreateFidelityBond = ({ otherFidelityBondExists, wallet, walletInfo, onDon
setSelectedJar(undefined)
setSelectedUtxos([])
setLockDate(null)
setTimelockedAddress(null)
setTimelockedAddress(undefined)
setAlert(undefined)
setCreatedFidelityBondUtxo(undefined)
setFrozenUtxos([])
Expand Down Expand Up @@ -307,7 +333,7 @@ const CreateFidelityBond = ({ otherFidelityBondExists, wallet, walletInfo, onDon
)
}

if (timelockedAddress === null) {
if (!timelockedAddress) {
return <div>{t('earn.fidelity_bond.error_loading_address')}</div>
}

Expand Down Expand Up @@ -386,7 +412,7 @@ const CreateFidelityBond = ({ otherFidelityBondExists, wallet, walletInfo, onDon

return t('earn.fidelity_bond.freeze_utxos.text_primary_button')
case steps.reviewInputs:
if (timelockedAddress === null) return t('earn.fidelity_bond.review_inputs.text_primary_button_error')
if (!timelockedAddress) return t('earn.fidelity_bond.review_inputs.text_primary_button_error')

if (!onlyCjOutOrFbUtxosSelected()) {
return t('earn.fidelity_bond.review_inputs.text_primary_button_unsafe')
Expand Down Expand Up @@ -522,7 +548,7 @@ const CreateFidelityBond = ({ otherFidelityBondExists, wallet, walletInfo, onDon
loadTimeLockedAddress(lockDate!)
}

if (step === steps.reviewInputs && timelockedAddress === null) {
if (step === steps.reviewInputs && !timelockedAddress) {
loadTimeLockedAddress(lockDate!)
return
}
Expand Down Expand Up @@ -568,26 +594,31 @@ const CreateFidelityBond = ({ otherFidelityBondExists, wallet, walletInfo, onDon
return (
<div className={styles.container}>
{alert && <Alert {...alert} className="mt-0" onClose={() => setAlert(undefined)} />}
{lockDate && (
<ConfirmModal
{lockDate && timelockedAddress && selectedJar !== undefined && (
<PaymentConfirmModal
isShown={showConfirmInputsModal}
title={t('earn.fidelity_bond.confirm_modal.title')}
onCancel={() => setShowConfirmInputsModal(false)}
onConfirm={() => {
setStep(steps.createFidelityBond)
setShowConfirmInputsModal(false)
directSweepToFidelityBond(selectedJar!, timelockedAddress!)
directSweepToFidelityBond(selectedJar, timelockedAddress)
}}
data={{
sourceJarIndex: undefined, // dont show a source jar - might be confusing in this context
destination: timelockedAddress,
amount: selectedUtxosTotalValue,
isSweep: true,
isCoinjoin: false, // not sent as collaborative transaction
numCollaborators: undefined,
feeConfigValues,
showPrivacyInfo: false,
}}
>
{t('earn.fidelity_bond.confirm_modal.body', {
date: new Date(fb.lockdate.toTimestamp(lockDate)).toUTCString(),
humanReadableDuration: fb.time.humanReadableDuration({
to: fb.lockdate.toTimestamp(lockDate),
locale: i18n.resolvedLanguage || i18n.language,
}),
})}
</ConfirmModal>
<LockInfoAlert className="text-start mt-4" lockDate={lockDate} />
</PaymentConfirmModal>
)}

<div className={styles.header} onClick={() => setIsExpanded(!isExpanded)}>
<div className="d-flex justify-content-between align-items-center">
<div className={styles.title}>
Expand Down
2 changes: 1 addition & 1 deletion src/components/fb/FidelityBondSteps.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ interface ReviewInputsProps {
jar: JarIndex
utxos: Array<Utxo>
selectedUtxos: Array<Utxo>
timelockedAddress: string
timelockedAddress: Api.BitcoinAddress
}

interface CreatedFidelityBondProps {
Expand Down
9 changes: 6 additions & 3 deletions src/components/fb/SpendFidelityBondModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import { useFeeConfigValues } from '../../hooks/Fees'
import styles from './SpendFidelityBondModal.module.css'
import { isDebugFeatureEnabled } from '../../constants/debugFeatures'
import { CopyButton } from '../CopyButton'
import { LockInfoAlert } from './CreateFidelityBond'

type Input = {
outpoint: Api.UtxoId
Expand Down Expand Up @@ -501,9 +502,9 @@ const RenewFidelityBondModal = ({
</div>
</rb.Modal.Footer>
</rb.Modal>
{showConfirmSendModal && fidelityBond && timelockedAddress !== undefined && (
{lockDate && fidelityBond && timelockedAddress !== undefined && (
<PaymentConfirmModal
isShown={true}
isShown={showConfirmSendModal}
title={t(`earn.fidelity_bond.renew.${timelockedAddress ? 'confirm_send_modal.title' : 'title'}`)}
onCancel={() => {
setShowConfirmSendModal(false)
Expand All @@ -522,7 +523,9 @@ const RenewFidelityBondModal = ({
feeConfigValues,
showPrivacyInfo: false,
}}
/>
>
<LockInfoAlert className="text-start mt-4" lockDate={lockDate} />
</PaymentConfirmModal>
)}
</>
)
Expand Down

0 comments on commit 675a4ae

Please sign in to comment.