From 327191efc70109985123f6d08150963896496119 Mon Sep 17 00:00:00 2001 From: kyranjamie Date: Tue, 26 Jan 2021 09:42:35 +0100 Subject: [PATCH] fix: stacking fee adjustment --- app/modals/stacking/stacking-modal.tsx | 28 ++++++++++++++++++-------- 1 file changed, 20 insertions(+), 8 deletions(-) diff --git a/app/modals/stacking/stacking-modal.tsx b/app/modals/stacking/stacking-modal.tsx index 015b3d53a..db08ebed0 100644 --- a/app/modals/stacking/stacking-modal.tsx +++ b/app/modals/stacking/stacking-modal.tsx @@ -59,6 +59,8 @@ interface StackingModalProps { onClose(): void; } +const CONTRACT_CALL_FEE = 260; + export const StackingModal: FC = props => { const { onClose, numCycles, poxAddress, amountToStack } = props; @@ -93,6 +95,10 @@ export const StackingModal: FC = props => { balance: selectAddressBalance(state), })); + const accountBalance = new BigNumber(balance?.balance ?? 0); + + const shouldModifyTxFee = accountBalance.minus(amountToStack).isLessThan(CONTRACT_CALL_FEE); + const initialStep = walletType === 'software' ? StackingModalStep.DecryptWalletAndSend @@ -126,10 +132,12 @@ export const StackingModal: FC = props => { burnBlockHeight: coreNodeInfo.burn_block_height, }); const tx = await makeContractCall({ ...txOptions, senderKey: privateKey }); - const modifiedFeeTx = stackingClient.modifyLockTxFee({ - tx, - amountMicroStx: new BN(amountToStack.toString()), - }); + const modifiedFeeTx = shouldModifyTxFee + ? stackingClient.modifyLockTxFee({ + tx, + amountMicroStx: new BN(amountToStack.toString()), + }) + : tx; const signer = new TransactionSigner(modifiedFeeTx); signer.signOrigin(createStacksPrivateKey(privateKey)); @@ -145,6 +153,7 @@ export const StackingModal: FC = props => { amountToStack, poxAddress, numCycles, + shouldModifyTxFee, ]); const createLedgerWalletTx = useCallback( @@ -168,10 +177,12 @@ export const StackingModal: FC = props => { publicKey: options.publicKey.toString('hex'), }); - const modifiedFeeTx = stackingClient.modifyLockTxFee({ - tx: unsignedTx, - amountMicroStx: new BN(amountToStack.toString()), - }); + const modifiedFeeTx = shouldModifyTxFee + ? stackingClient.modifyLockTxFee({ + tx: unsignedTx, + amountMicroStx: new BN(amountToStack.toString()), + }) + : unsignedTx; const resp: ResponseSign = await blockstackApp.sign( STX_DERIVATION_PATH, modifiedFeeTx.serialize() @@ -190,6 +201,7 @@ export const StackingModal: FC = props => { amountToStack, poxAddress, numCycles, + shouldModifyTxFee, ] );