From e3d9c9aaaac8dcb75946051d207c1de2ab702c17 Mon Sep 17 00:00:00 2001 From: theborakompanioni Date: Sat, 9 Sep 2023 13:16:33 +0200 Subject: [PATCH] fix(fee-randomization): fix fee range in PaymentConfirmModal --- src/components/PaymentConfirmModal.tsx | 22 ++++++++++++++-------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/src/components/PaymentConfirmModal.tsx b/src/components/PaymentConfirmModal.tsx index 3a7ac8f97..5b5f1520e 100644 --- a/src/components/PaymentConfirmModal.tsx +++ b/src/components/PaymentConfirmModal.tsx @@ -11,6 +11,13 @@ import { AmountSats } from '../libs/JmWalletApi' import { jarInitial } from './jars/Jar' import { isValidNumber } from '../utils' +const feeRange: (feeValues: FeeValues) => [number, number] = (feeValues) => { + const feeTargetInSatsPerVByte = feeValues.tx_fees! / 1_000 + const minFeeSatsPerVByte = Math.max(1, feeTargetInSatsPerVByte) + const maxFeeSatsPerVByte = feeTargetInSatsPerVByte * (1 + feeValues.tx_fees_factor!) + return [minFeeSatsPerVByte, maxFeeSatsPerVByte] +} + const useMiningFeeText = ({ feeConfigValues }: { feeConfigValues?: FeeValues }) => { const { t } = useTranslation() @@ -24,24 +31,23 @@ const useMiningFeeText = ({ feeConfigValues }: { feeConfigValues?: FeeValues }) } else if (unit === 'blocks') { return t('send.confirm_send_modal.text_miner_fee_in_targeted_blocks', { count: feeConfigValues.tx_fees }) } else { - const feeTargetInSatsPerVByte = feeConfigValues.tx_fees! / 1_000 - if (feeConfigValues.tx_fees_factor === 0) { + const [minFeeSatsPerVByte, maxFeeSatsPerVByte] = feeRange(feeConfigValues) + const fractionDigits = 2 + + if (minFeeSatsPerVByte.toFixed(fractionDigits) === maxFeeSatsPerVByte.toFixed(fractionDigits)) { return t('send.confirm_send_modal.text_miner_fee_in_satspervbyte_exact', { - value: feeTargetInSatsPerVByte.toLocaleString(undefined, { + value: minFeeSatsPerVByte.toLocaleString(undefined, { maximumFractionDigits: Math.log10(1_000), }), }) } - const minFeeSatsPerVByte = Math.max(1, feeTargetInSatsPerVByte * (1 - feeConfigValues.tx_fees_factor!)) - const maxFeeSatsPerVByte = feeTargetInSatsPerVByte * (1 + feeConfigValues.tx_fees_factor!) - return t('send.confirm_send_modal.text_miner_fee_in_satspervbyte_randomized', { min: minFeeSatsPerVByte.toLocaleString(undefined, { - maximumFractionDigits: 1, + maximumFractionDigits: fractionDigits, }), max: maxFeeSatsPerVByte.toLocaleString(undefined, { - maximumFractionDigits: 1, + maximumFractionDigits: fractionDigits, }), }) }