Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(synapse-interface): bridge gas handler #2437

Merged
merged 151 commits into from
May 9, 2024
Merged
Show file tree
Hide file tree
Changes from 12 commits
Commits
Show all changes
151 commits
Select commit Hold shift + click to select a range
86d769a
Initial gas data slice state
bigboydiamonds Apr 2, 2024
57866b3
Async thunk fetchGasData
bigboydiamonds Apr 2, 2024
b2a2ec0
Add gas data reducers
bigboydiamonds Apr 2, 2024
2eeb3ab
useFetchGasDataOnInterval added to Bridge Listener
bigboydiamonds Apr 2, 2024
c0db7cf
Explicitly declare fetching gas data in gwei
bigboydiamonds Apr 2, 2024
365c017
Calculate max bridgeable amount
bigboydiamonds Apr 2, 2024
c75c77f
On max balance factoring in gas cost
bigboydiamonds Apr 2, 2024
c16b276
Add comment
bigboydiamonds Apr 2, 2024
0bf73d3
Differentiate max balance vs max bridgeable balance
bigboydiamonds Apr 3, 2024
e821ef8
Add error toaster for when max balance less than bridge fee
bigboydiamonds Apr 3, 2024
9f09239
refactor; calculateGasFeeInGwei()
bigboydiamonds Apr 3, 2024
6d12c41
Move to util
bigboydiamonds Apr 3, 2024
9758112
Fix lint error
bigboydiamonds Apr 3, 2024
1496842
Fetch gas when fromChainId on bridge card changes
bigboydiamonds Apr 3, 2024
c01109f
Use exact token balance when calculate max bridgeable amount
bigboydiamonds Apr 3, 2024
eee9c50
Conditions for showing max button
bigboydiamonds Apr 4, 2024
8092671
Merge branch 'master' into fe/bridge-gas
bigboydiamonds Apr 4, 2024
93d2047
showMaxOption to determine display
bigboydiamonds Apr 4, 2024
c5e222c
Disable max button if gas fees more than gas balance
bigboydiamonds Apr 4, 2024
f580a80
Clean jsx
bigboydiamonds Apr 4, 2024
561a62b
AvailableBalance component to track subscript detail in bridge origin…
bigboydiamonds Apr 4, 2024
b4c91bf
Return raw and formatted gas cost in calculateGasCost
bigboydiamonds Apr 5, 2024
85c4a7f
Update comments
bigboydiamonds Apr 5, 2024
cd7ae73
Fix imports based on name cange
bigboydiamonds Apr 5, 2024
a109662
Use parsed
bigboydiamonds Apr 5, 2024
e9266ba
calculateMaxBridgeableGas
bigboydiamonds Apr 5, 2024
79d540c
Clean
bigboydiamonds Apr 5, 2024
28a8811
refactor: clean InputContainer
bigboydiamonds Apr 5, 2024
c6754d7
Replace onMaxBalance() with onMaxBridgeableBalance()`
bigboydiamonds Apr 5, 2024
8867be6
Allow undefined object when destructuring
bigboydiamonds Apr 5, 2024
1d00de2
Display when token balance is trace balance
bigboydiamonds Apr 5, 2024
a9d3446
Typing
bigboydiamonds Apr 5, 2024
1f7ec54
showGasReserved
bigboydiamonds Apr 5, 2024
8d9c491
Update avail balance text and color when gas cost greater than balance
bigboydiamonds Apr 8, 2024
a8a5d78
Detect when input value is less than required estimated gas
bigboydiamonds Apr 8, 2024
4d3a0bd
onAvailableBalance applied
bigboydiamonds Apr 8, 2024
104866e
Make opacity greater when Max button disabled
bigboydiamonds Apr 8, 2024
9ab631d
Fix calculations for when gas input is enough to cover gas
bigboydiamonds Apr 8, 2024
76037f4
Clean
bigboydiamonds Apr 8, 2024
3427616
Add hover tooltip for warning gas states
bigboydiamonds Apr 8, 2024
44edc57
Use tooltip to describe gas status
bigboydiamonds Apr 8, 2024
3052e57
Update tooltip text
bigboydiamonds Apr 8, 2024
86a3cfb
Add buffer to calculate gas cost, use 1.5x
bigboydiamonds Apr 9, 2024
be6bcda
-mMerge
bigboydiamonds Apr 11, 2024
b0e5e52
AvailableBalance component to replace label in AmountInput
bigboydiamonds Apr 11, 2024
06e1044
Display trace balances in AvailableBalance
bigboydiamonds Apr 11, 2024
52d65ce
Fix naming
bigboydiamonds Apr 11, 2024
d7b073b
Add HoverTooltip to Available Balance
bigboydiamonds Apr 11, 2024
e34a363
Add conditions for displaying gas error based on input
bigboydiamonds Apr 11, 2024
677a8fc
Use full parsed balance when making comparisons for gas checks
bigboydiamonds Apr 11, 2024
6864b5b
Show gas reserved in Available Balance
bigboydiamonds Apr 11, 2024
2d48a9d
hasOnlyZeroes to return true if string contains only zeroes and periods
bigboydiamonds Apr 11, 2024
d0e7116
Display estimated gas cost in tool tip
bigboydiamonds Apr 11, 2024
e813eea
Remove Available Balance elements from AmountInput, migrated to Avail…
bigboydiamonds Apr 11, 2024
d8fabef
Display trace amount for input when displaying how much is reserved f…
bigboydiamonds Apr 11, 2024
89a386f
Fetch estimated gas limit based on real bridge quote using max gas ba…
bigboydiamonds Apr 11, 2024
f3bd4f1
Fetching accurate gasLimit
bigboydiamonds Apr 11, 2024
7d75555
Fix Trace balance
bigboydiamonds Apr 11, 2024
ec90bd0
Set gasLimit to 0 if not valid bridge data avail
bigboydiamonds Apr 11, 2024
a2b8f64
...
bigboydiamonds Apr 11, 2024
509f66a
Fix when gas covered msg appears
bigboydiamonds Apr 11, 2024
ef9d11c
Available Balance
bigboydiamonds Apr 11, 2024
8b23f18
Clean available balance flow
bigboydiamonds Apr 11, 2024
cb16d7a
useGasEstimator hook to encapsulate logic to clean InputContainer
bigboydiamonds Apr 12, 2024
990afcc
Merge branch 'master' of https://github.com/synapsecns/sanguine into …
bigboydiamonds Apr 12, 2024
4db337f
Merge branch 'master' into fe/bridge-gas
bigboydiamonds Apr 17, 2024
7a54739
Merge branch 'master' into fe/bridge-gas
bigboydiamonds Apr 17, 2024
914d237
Fix prop issue
bigboydiamonds Apr 17, 2024
fb72b99
Remove duplicate HoverTooltip
bigboydiamonds Apr 17, 2024
8377d7a
Move HoverTooltip to shared component folder
bigboydiamonds Apr 17, 2024
3954eee
Update gas fetch for wagmi v2, up limit to 1.7
bigboydiamonds Apr 17, 2024
2f618cc
Estimated gas bridge quote fetched on load
bigboydiamonds Apr 18, 2024
e25cd3e
Update var naming
bigboydiamonds Apr 18, 2024
340496e
Improve Available Balance flow
bigboydiamonds Apr 18, 2024
a6517e7
Display estimated bridgeable balance on hover
bigboydiamonds Apr 18, 2024
5529577
Show gas estimate when estimated gas cost available
bigboydiamonds Apr 18, 2024
a0e333c
Do not show negative bridgable balance
bigboydiamonds Apr 18, 2024
c234f50
Separate out bridge gas limit calculations into smaller functions
bigboydiamonds Apr 19, 2024
2db63d1
Wrap async functions with try catch
bigboydiamonds Apr 19, 2024
8f30fd9
Implement updated gas estimation flow
bigboydiamonds Apr 19, 2024
f5a85f0
Move gas estimate logic to useGasEstimator
bigboydiamonds Apr 19, 2024
135e4b0
Move async sdk fetch functions to useGasEstimator file
bigboydiamonds Apr 19, 2024
fde785b
Remove unused vars
bigboydiamonds Apr 19, 2024
f52c0bd
Shorten est gas cost
bigboydiamonds Apr 19, 2024
9dae803
Improve code legibility in AvailableBalance
bigboydiamonds Apr 19, 2024
6e30bb7
Assign conditions to vars to reduce clutter
bigboydiamonds Apr 19, 2024
c517245
Reset gas price data when fromChainId changes
bigboydiamonds Apr 19, 2024
ccb4e5c
Reset fetched gas limit when fromChainId changes
bigboydiamonds Apr 19, 2024
a6b6fa2
Clean
bigboydiamonds Apr 19, 2024
02366ae
Fix old import
bigboydiamonds Apr 19, 2024
44c4915
Merge branch 'master' into fe/bridge-gas
bigboydiamonds Apr 19, 2024
e11dc66
Merge branch 'master' into fe/bridge-gas
bigboydiamonds Apr 29, 2024
225efad
Fix max button placement
bigboydiamonds Apr 30, 2024
ab5503d
Add loading state for useGasEstimator
bigboydiamonds Apr 30, 2024
c6ab2a9
Remove available balance states for gas est
bigboydiamonds Apr 30, 2024
a3d31fa
Remove unused props
bigboydiamonds Apr 30, 2024
fa4109f
Clean gas token detection in PortfolioTokenAsset
bigboydiamonds Apr 30, 2024
8da8876
Simplify onMaxBalance()
bigboydiamonds Apr 30, 2024
13e54af
Clean constants in InputContainer
bigboydiamonds Apr 30, 2024
4987688
Clean token detail destructuring
bigboydiamonds Apr 30, 2024
7d68957
Include gas estimate when updating input from Portfolio token selection
bigboydiamonds Apr 30, 2024
83a87f8
Fire error toaster if gas fees exceed balance
bigboydiamonds Apr 30, 2024
eafb8ec
Render error toaster when firing onMaxBalance callback instead of a s…
bigboydiamonds Apr 30, 2024
dd76066
Clean useGasEstimator
bigboydiamonds Apr 30, 2024
651b5ea
Ensure available balance does not show if wallet not connected, set d…
bigboydiamonds Apr 30, 2024
3110540
Replicate onMax behavior in Portfolio
bigboydiamonds Apr 30, 2024
ecfe813
Use fetched gas
bigboydiamonds Apr 30, 2024
6b6a3f0
Improve error handling in gas estimator
bigboydiamonds Apr 30, 2024
a59a2a8
...
bigboydiamonds Apr 30, 2024
31e9e13
Remove tooltip on AvailableBalance
bigboydiamonds May 1, 2024
5040a59
Remove balance prefill from Portfolio Token selection
bigboydiamonds May 1, 2024
6303bb3
Update available balance in input based on max bridgeable gas toke
bigboydiamonds May 1, 2024
870bccb
Destructure estimateGasLimit callback from useGasEstimator to retrigg…
bigboydiamonds May 1, 2024
db53502
Refetch gas ata in estimateGasLimit callback
bigboydiamonds May 1, 2024
26e4c8f
Display total vs bridgeable balance on hover in Portfolio gas token w…
bigboydiamonds May 1, 2024
e1b87cc
Update balance shown on hover
bigboydiamonds May 1, 2024
7b33d3b
Clean
bigboydiamonds May 1, 2024
8fe478b
Simplify useFetchGasDataOnInterval
bigboydiamonds May 1, 2024
e0ebedc
Prevent unnecessary fetches, fix chain update old gas issue
bigboydiamonds May 1, 2024
095d985
Fetch estimated bridgeable max gas amount onClick token max input, fi…
bigboydiamonds May 2, 2024
723ae59
Clean
bigboydiamonds May 2, 2024
2972908
onMaxBalance will use default balanceif fetched bridgeable balance es…
bigboydiamonds May 2, 2024
1383bfc
Show dust gas amounts on hover in Portfolio
bigboydiamonds May 2, 2024
04a430b
Clean
bigboydiamonds May 2, 2024
cd90fef
Available balance including gas estimates moved to within Input to sy…
bigboydiamonds May 2, 2024
db75b99
Move gasLimit to global store to share data between Bridge components
bigboydiamonds May 2, 2024
7a46279
Display max bridgeable balance on hover in Portfolio, add onMaxBalanc…
bigboydiamonds May 2, 2024
9bb0901
Portfolio and Input available balance onClick behave the same
bigboydiamonds May 2, 2024
96815b6
Fetch gas prices to provide most accurate gas cost
bigboydiamonds May 2, 2024
ee8d3ac
Remove hover on AvailableBalance
bigboydiamonds May 3, 2024
3d901d2
Fix Token Selector width
bigboydiamonds May 3, 2024
e5e7a1d
Remove onClick Portfolio Token Balance, allow Token selection from Po…
bigboydiamonds May 3, 2024
b220371
Cursor default on Portfolio Token Balance
bigboydiamonds May 3, 2024
a83aceb
Show available/max buttons when bridge valid selections
bigboydiamonds May 6, 2024
cc9f96d
Swap input to have available balance
bigboydiamonds May 6, 2024
bc5eca7
Clean
bigboydiamonds May 6, 2024
63f2849
Basic MaxButton onClick and hidden when loading gas data
bigboydiamonds May 7, 2024
9f20c05
Show MaxButton when input is not full balance or bridgeable balance
bigboydiamonds May 7, 2024
429a023
Implement Max button and placement in Bridge/Swap
bigboydiamonds May 7, 2024
1d36a72
Hide MaxButton until connected
bigboydiamonds May 7, 2024
a350cf9
Hide MaxButton conditions
bigboydiamonds May 7, 2024
973fc67
Show Max when all input selections are made
bigboydiamonds May 7, 2024
962f372
Remove click states for AvailableBalance on Bridge/Swap
bigboydiamonds May 7, 2024
744c42e
Style Input / Max
bigboydiamonds May 7, 2024
11f31ee
Max mobile size
bigboydiamonds May 8, 2024
f274044
Fe/format amount (#2598)
bigboydiamonds May 8, 2024
2f6b360
Clean imports
bigboydiamonds May 8, 2024
e8ca7e6
Swap Max spacing
bigboydiamonds May 8, 2024
38669bd
Improve html element composition
bigboydiamonds May 8, 2024
6b70424
Merge branch 'master' into fe/bridge-gas
bigboydiamonds May 9, 2024
0cbe497
Prevent layout shift in Swap UI
bigboydiamonds May 9, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
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 } from 'viem'
import { useAccount, useNetwork } from 'wagmi'

import { initialState, updateFromValue } from '@/slices/bridge/reducer'
import MiniMaxButton from '../buttons/MiniMaxButton'
import { formatBigIntToString } from '@/utils/bigint/format'
Expand All @@ -15,11 +17,16 @@ import { FromChainSelector } from './FromChainSelector'
import { FromTokenSelector } from './FromTokenSelector'
import { useBridgeState } from '@/slices/bridge/hooks'
import { usePortfolioState } from '@/slices/portfolio/hooks'
import { calculateGasFeeInGwei } from '../../utils/calculateGasFeeInGwei'

export const inputRef = React.createRef<HTMLInputElement>()

export const InputContainer = () => {
const { fromChainId, fromToken, fromValue } = useBridgeState()
const { gasData } = useAppSelector((state) => state.gasData)

const { gasPrice, maxFeePerGas } = gasData?.formatted

const [showValue, setShowValue] = useState('')

const [hasMounted, setHasMounted] = useState(false)
Expand All @@ -43,6 +50,10 @@ export const InputContainer = () => {
(token) => token.tokenAddress === fromToken?.addresses[fromChainId]
)?.balance

const estimatedGasCostInGwei = calculateGasFeeInGwei(gasPrice, 200_000)

const isNativeToken = fromToken?.addresses[fromChainId] === zeroAddress

useEffect(() => {
if (fromToken && fromToken?.decimals[fromChainId]) {
setShowValue(fromValue)
Expand Down Expand Up @@ -80,6 +91,40 @@ export const InputContainer = () => {
)
}, [balance, fromChainId, fromToken])

const onMaxBridgeableBalance = useCallback(() => {
if (estimatedGasCostInGwei && isNativeToken) {
const maxBalance = Number(parsedBalance) - estimatedGasCostInGwei

if (maxBalance < 0) {
toast.error(`Balance is less than estimated gas fee.`, {
id: 'not-enough-balance-popup',
duration: 5000,
})

dispatch(
updateFromValue(
formatBigIntToString(0n, fromToken?.decimals[fromChainId])
)
)
} else {
dispatch(updateFromValue(maxBalance.toString()))
}
} else {
dispatch(
updateFromValue(
formatBigIntToString(balance, fromToken?.decimals[fromChainId])
)
)
}
bigboydiamonds marked this conversation as resolved.
Show resolved Hide resolved
}, [
parsedBalance,
balance,
fromChainId,
fromToken,
estimatedGasCostInGwei,
isNativeToken,
])

const connectedStatus = useMemo(() => {
if (hasMounted && !isConnected) {
return <ConnectWalletButton />
Expand Down Expand Up @@ -158,7 +203,7 @@ export const InputContainer = () => {
<div className="m">
<MiniMaxButton
disabled={!balance || balance === 0n ? true : false}
onClickBalance={onMaxBalance}
onClickBalance={onMaxBridgeableBalance}
/>
</div>
)}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import { useRiskEvent } from '@/utils/hooks/useRiskEvent'
import { useTransactionListener } from '@/utils/hooks/useTransactionListener'
import { use_TransactionsListener } from '@/utils/hooks/use_TransactionsListener'
import { useFetchPricesOnInterval } from '@/utils/hooks/useFetchPricesOnInterval'
import { useFetchGasDataOnInterval } from '@/utils/hooks/useFetchGasDataOnInterval'

const BackgroundListenerContext = createContext(null)

Expand All @@ -18,6 +19,7 @@ export const BackgroundListenerProvider = ({ children }) => {
useBridgeListener()
useRiskEvent()
useFetchPricesOnInterval()
useFetchGasDataOnInterval()

return (
<BackgroundListenerContext.Provider value={null}>
Expand Down
69 changes: 69 additions & 0 deletions packages/synapse-interface/slices/gasDataSlice.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
import { createAsyncThunk, createSlice } from '@reduxjs/toolkit'
import { fetchFeeData } from '@wagmi/core'

export interface GasDataState {
gasData: {
gasPrice: bigint
maxFeePerGas: bigint
maxPriorityFeePerGas: bigint
formatted: {
gasPrice: string
maxFeePerGas: string
maxPriorityFeePerGas: string
}
}
isLoadingGasData: boolean
}

const getGasData = async (chainId: number) => {
const feeData = await fetchFeeData({
chainId,
formatUnits: 'gwei',
})

return feeData
}

export const fetchGasData = createAsyncThunk(
'gasData/fetchGasData',
async (chainId: number) => {
const gasData = await getGasData(chainId)
return gasData
}
)

const initialState: GasDataState = {
gasData: {
gasPrice: null,
maxFeePerGas: null,
maxPriorityFeePerGas: null,
formatted: {
gasPrice: null,
maxFeePerGas: null,
maxPriorityFeePerGas: null,
},
},
isLoadingGasData: true,
}

export const gasDataSlice = createSlice({
name: 'gasData',
initialState,
reducers: {},
extraReducers: (builder) => {
builder.addCase(fetchGasData.pending, (state) => {
state.isLoadingGasData = true
})
builder
.addCase(fetchGasData.fulfilled, (state, action) => {
state.isLoadingGasData = false
state.gasData = action.payload
})
.addCase(fetchGasData.rejected, (state) => {
state.isLoadingGasData = false
console.error('Error fetching gas data')
bigboydiamonds marked this conversation as resolved.
Show resolved Hide resolved
})
},
})

export default gasDataSlice.reducer
2 changes: 2 additions & 0 deletions packages/synapse-interface/store/reducer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import poolDeposit from '@/slices/poolDepositSlice'
import poolUserData from '@/slices/poolUserDataSlice'
import poolWithdraw from '@/slices/poolWithdrawSlice'
import priceData from '@/slices/priceDataSlice'
import gasData from '@/slices/gasDataSlice'
import swapDisplay from '@/slices/swapDisplaySlice'
import { api } from '@/slices/api/slice'
import { RootActions } from '@/slices/application/actions'
Expand Down Expand Up @@ -43,6 +44,7 @@ export const appReducer = combineReducers({
poolUserData,
poolWithdraw,
priceData,
gasData,
swapDisplay,
[api.reducerPath]: api.reducer,
...persistedReducers,
Expand Down
22 changes: 22 additions & 0 deletions packages/synapse-interface/utils/calculateGasFeeInGwei.ts
Original file line number Diff line number Diff line change
@@ -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

Check failure on line 5 in packages/synapse-interface/utils/calculateGasFeeInGwei.ts

View workflow job for this annotation

GitHub Actions / lint

There must be a newline after the description of the JSDoc block

Check failure on line 5 in packages/synapse-interface/utils/calculateGasFeeInGwei.ts

View workflow job for this annotation

GitHub Actions / lint

There must be a newline after the description of the JSDoc block
bigboydiamonds marked this conversation as resolved.
Show resolved Hide resolved
* @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
bigboydiamonds marked this conversation as resolved.
Show resolved Hide resolved
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
import { useEffect } from 'react'
import { useNetwork } from 'wagmi'

import { useAppDispatch } from '@/store/hooks'
import { fetchGasData } from '@/slices/gasDataSlice'

export const useFetchGasDataOnInterval = () => {
const dispatch = useAppDispatch()
const { chain } = useNetwork()

const fetchData = (chainId: number) => {
dispatch(fetchGasData(chainId))
}

useEffect(() => {
// Fetch when chainId available
if (chain?.id) {
fetchData(chain?.id)
}

// Fetch every 60 seconds
const interval = setInterval(fetchGasData, 60000)
bigboydiamonds marked this conversation as resolved.
Show resolved Hide resolved

return () => clearInterval(interval)
}, [dispatch, chain?.id])
}
Loading