Skip to content

Commit

Permalink
fix(synapse-interface): Generalizes airdrop decimal display based on …
Browse files Browse the repository at this point in the history
…SDK gasAirdropAmount [SLT-269] (#3196)

* Generalizes airdrop decimal display based on SDK gasAirdropAmount
  • Loading branch information
abtestingalpha authored Sep 26, 2024
1 parent 3222ee8 commit aa37b50
Show file tree
Hide file tree
Showing 4 changed files with 43 additions and 643 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ import { EMPTY_BRIDGE_QUOTE } from '@/constants/bridge'
import { CHAINS_BY_ID } from '@constants/chains'
import * as CHAINS from '@constants/chains/master'
import { useBridgeQuoteState } from '@/slices/bridgeQuote/hooks'
import { getSignificantDecimals } from '@/utils/getSignificantDecimals'

export const BridgeExchangeRateInfo = () => {
/* TODO:
Expand Down Expand Up @@ -134,7 +135,6 @@ const TimeEstimate = () => {
}

const GasDropLabel = () => {
let decimalsToDisplay
const { toChainId } = useBridgeState()
const {
bridgeQuote: { gasDropAmount },
Expand All @@ -143,20 +143,13 @@ const GasDropLabel = () => {
const t = useTranslations('Bridge')
const symbol = CHAINS_BY_ID[toChainId]?.nativeCurrency.symbol

if ([CHAINS.FANTOM.id].includes(toChainId)) {
decimalsToDisplay = 2
} else if (
[CHAINS.BNB.id, CHAINS.AVALANCHE.id, CHAINS.BOBA.id].includes(toChainId)
) {
decimalsToDisplay = 3
} else {
decimalsToDisplay = 4
}
const stringifiedGasAmount = formatBigIntToString(gasDropAmount, 18)
const significantDecimals = getSignificantDecimals(stringifiedGasAmount)

const formattedGasDropAmount = formatBigIntToString(
gasDropAmount,
18,
decimalsToDisplay
significantDecimals
)

const airdropInDollars = getAirdropInDollars(symbol, formattedGasDropAmount)
Expand Down Expand Up @@ -214,12 +207,13 @@ const getAirdropInDollars = (
symbol: string,
formattedGasDropAmount: string
) => {
const decimals = symbol === 'JEWEL' ? 4 : 2
const price = useCoingeckoPrice(symbol)

if (price) {
const airdropInDollars = parseFloat(formattedGasDropAmount) * price

return airdropInDollars.toFixed(2)
return airdropInDollars.toFixed(decimals)
} else {
return undefined
}
Expand Down
23 changes: 23 additions & 0 deletions packages/synapse-interface/utils/getSignificantDecimals.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
export const getSignificantDecimals = (
numberString: string,
defaultDecimals: number = 2
): number => {
const parts = numberString.split('.')
const decimalPart = parts[1]

if (!decimalPart) return 0

if (/^0*$/.test(decimalPart)) {
return defaultDecimals
}

let significantDecimals = 0

for (let i = 0; i < decimalPart.length; i++) {
if (decimalPart[i] !== '0') {
significantDecimals = i + 1
}
}

return significantDecimals
}
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ const ID_MAP = {
GLMR: 'moonbeam',
CANTO: 'canto',
FTM: 'fantom',
METIS: 'metis-token',
Metis: 'metis-token',
BNB: 'binancecoin',
MATIC: 'matic-network',
KLAY: 'klay-token',
Expand Down
Loading

0 comments on commit aa37b50

Please sign in to comment.