From 6d12c413097be9df9defa6014f219026af1f6db1 Mon Sep 17 00:00:00 2001 From: bigboydiamonds <57741810+bigboydiamonds@users.noreply.github.com> Date: Wed, 3 Apr 2024 10:44:51 -0700 Subject: [PATCH] Move to util --- .../StateManagedBridge/InputContainer.tsx | 24 ++----------------- .../utils/calculateGasFeeInGwei.ts | 22 +++++++++++++++++ 2 files changed, 24 insertions(+), 22 deletions(-) create mode 100644 packages/synapse-interface/utils/calculateGasFeeInGwei.ts diff --git a/packages/synapse-interface/components/StateManagedBridge/InputContainer.tsx b/packages/synapse-interface/components/StateManagedBridge/InputContainer.tsx index f1a98c825a..509e9ba65a 100644 --- a/packages/synapse-interface/components/StateManagedBridge/InputContainer.tsx +++ b/packages/synapse-interface/components/StateManagedBridge/InputContainer.tsx @@ -2,7 +2,7 @@ import toast from 'react-hot-toast' import React, { useEffect, useState, useRef, useCallback, useMemo } from 'react' import { useAppSelector } from '@/store/hooks' import { useDispatch } from 'react-redux' -import { zeroAddress, formatGwei } from 'viem' +import { zeroAddress } from 'viem' import { useAccount, useNetwork } from 'wagmi' import { initialState, updateFromValue } from '@/slices/bridge/reducer' import MiniMaxButton from '../buttons/MiniMaxButton' @@ -17,27 +17,7 @@ import { FromChainSelector } from './FromChainSelector' import { FromTokenSelector } from './FromTokenSelector' import { useBridgeState } from '@/slices/bridge/hooks' import { usePortfolioState } from '@/slices/portfolio/hooks' - -/** - * Calculates the estimated gas fee in Gwei. - * TODO: Hardcoding gas limit to 200k for now, update dynamically - * @param {string} gasPrice - The current gas price in Gwei as a string. - * @param {number} gasLimit - Function to format a value as Gwei. - * @returns {number|null} The formatted estimated gas cost, or null if the calculation is not possible. - */ -const calculateGasFeeInGwei = (gasPrice?: string, gasLimit = 200_000) => { - if (!gasPrice) return null - - const estimatedGasCostInGwei = gasLimit * parseFloat(gasPrice) - - const oneGwei = parseFloat(formatGwei(1n)) - - const formattedEstimatedGasCost = estimatedGasCostInGwei - ? estimatedGasCostInGwei * oneGwei - : null - - return formattedEstimatedGasCost -} +import { calculateGasFeeInGwei } from '../../utils/calculateGasFeeInGwei' export const inputRef = React.createRef() diff --git a/packages/synapse-interface/utils/calculateGasFeeInGwei.ts b/packages/synapse-interface/utils/calculateGasFeeInGwei.ts new file mode 100644 index 0000000000..1f769bdfb4 --- /dev/null +++ b/packages/synapse-interface/utils/calculateGasFeeInGwei.ts @@ -0,0 +1,22 @@ +import { formatGwei } from 'viem' + +/** + * Calculates the estimated gas fee in Gwei. + * TODO: Hardcoding gas limit to 200k for now, update dynamically + * @param {string} gasPrice - The current gas price in Gwei as a string. + * @param {number} gasLimit - Function to format a value as Gwei. + * @returns {number|null} The formatted estimated gas cost, or null if the calculation is not possible. + */ +export const calculateGasFeeInGwei = (gasPrice?: string, gasLimit = 200000) => { + if (!gasPrice) return null + + const estimatedGasCostInGwei = gasLimit * parseFloat(gasPrice) + + const oneGwei = parseFloat(formatGwei(1n)) + + const formattedEstimatedGasCost = estimatedGasCostInGwei + ? estimatedGasCostInGwei * oneGwei + : null + + return formattedEstimatedGasCost +}