utils APIs
- calculateSlippageAmount
- calculateGasMargin
- getRouterContract
- getBscScanLink
- isAddress
- shortenAddress
- getEtherscanLink
- basisPointsToPercent
- getTokenAddress
- copyToClipboard
- deepMergeByKey
- decrypt
- encrypt
- emailErrorMsg
- reqErrorMsg
- debouncePromise
- callbackify
- isValidURL
- hasUserApiEditAccess
- loadThirdPartyScript
- getCurrentWindow
- hashVote
- toEthSignedMessageHash
- MAINNET_ID
- usePrevious
- bnum
- normalizeBalance
- isWalletScheme
- WalletSchemeProposalState
- VotingMachineProposalState
- calculateStakes
- formatBalance
- denormalizeBalance
- PendingAction
- isVoteNo
- isVoteYes
- parseSignedVoteMessage
- toPercentage
- verifySignedVote
- NETWORK_ASSET_SYMBOL
- ZERO_ADDRESS
- enumKeys
- DEFAULT_CHAIN_ID
- useInterval
- getBlockchainLink
- getERC20Token
- getDxVoteContract
- toAddressStub
- getNetworkById
- formatNumberValue
- encodeDxdVestingCreate
- encodeErc20Approval
- encodeErc20Transfer
- encodeRepMint
- TXEvents
- BigNumber
- ZERO_HASH
- ANY_ADDRESS
- ERC20_APPROVE_SIGNATURE
- ERC20_TRANSFER_SIGNATURE
- QUEUED_PRIORITY_THRESHOLD
- NETWORKS
- toCamelCaseString
- ALCHEMY_NETWORK_URLS
- DEFAULT_RPC_URLS
- appendEthAPIKey
- NETWORK_APIS
- INFURA_NETWORK_NAMES
- POKT_NETWORK_URLS
- constants
- session
- displayFromWei
- getBigNumber
- getSupplyCap
- getAllowance
- approve
- fromWei
- getFullDisplayBalance
- getLibrary
- maxAmountSpend
- addMaticToMetamask
- returnTokenFromKey
- isSupportedNetwork
- formatTokenAmount
- formatCompact
- formatNumber
- isTokensOnList
- getAPYWithFee
- getRewardRate
- getStakedAmountStakingInfo
- getTVLStaking
- getEarnedUSDLPFarm
- getEarnedUSDDualFarm
- formatAPY
- getUSDString
- formatMulDivTokenAmount
- getExactTokenAmount
- escapeRegExp
- currencyId
- getOneYearFee
- returnStakingInfo
- getAllTokensOnUniswap
- getAllPairsOnUniswap
- getSecondsOneDay
- getValueTokenDecimals
- getPartialTokenAmount
- confirmPriceImpactWithoutFee
- halfAmountSpend
- getTokenInfo
- getEthPrice
- getIntervalTokenData
- getTokenAPRSyrup
- getEarnedUSDSyrup
- getFormattedPrice
- getPriceColor
- getTopTokens
- shortenTx
- getContract
- isZero
- getChartData
- getChartDates
- getChartStartTime
- getLimitedData
- getTopPairs
- getGlobalData
- getBulkPairData
- formatDateFromTimeStamp
- getPairChartData
- getYAXISValuesAnalytics
- getPairTransactions
- getTokenChartData
- getTokenPairs2
- useLairDQUICKAPY
- getPageItemsToLoad
- returnFullWidthMobile
- returnDualStakingInfo
- getDaysCurrentYear
- getTokenPairs
- getBlockFromTimestamp
- getFarmLPToken
- getSyrupLPToken
- initTokenAmountFromCallResult
- returnSyrupInfo
- getCallStateResult
- notEmpty
- DEFAULT_TO_CHAIN_ID
- CHAINS
- UnsupportedChainIdError
- switchChain
- showMigrationBanner
- isValidAddress
- ChainId
- COLORS
- QUERIES
- onboard
- disableSendForm
- max
- parseUnits
- formatUnits
- ParsingError
- TOKENS_LIST
- Token
- blockLiquidity
- migrationPoolV2Warning
- formatEtherRaw
- numberFormatter
- estimateGasForAddEthLiquidity
- DEFAULT_ADD_LIQUIDITY_ETH_GAS_ESTIMATE
- UPDATE_GAS_INTERVAL_MS
- toWeiSafe
- addEtherscan
- receiveAmount
- getEstimatedDepositTime
- DEFAULT_FROM_CHAIN_ID
- formatEther
- PROVIDERS
- getRelayFees
- getLpFee
- isSupportedChainId
- getAddress
- getDepositBox
- TransactionError
- MAX_APPROVAL_AMOUNT
- optimismErc20Pairs
- bobaErc20Pairs
- tagAddress
- validateContractAndChain
- multicallTwoAddress
- IChainSelection
- CHAINS_SELECTION
- onboardBaseConfig
- getConfirmationDepositTime
- shortenAddressLong
- timeAgo
- textareaAutoResize
- initOAuthWindow
- parseURL
- scrollToBottom
- isUrl
- get_url_extension
- wait
- b64_to_utf8
- utf8_to_b64
- callDelayer
- useKeyboardDidShow
- capitalizedCase
- getCoinSymbol
- getCountryName
- getTransactionStatusColor
- useAlert
- scaleSpacing
- getActiveCase
- changeBodyTheme
- getPercentage
- metaGenerator
- useFetch
- visualize
- worldLegends
- dateFormat
- getPerDayStats
- API_BASEURL
- API_INDONESIA
- indonesiaLegends
- getActiveCaseID
- isWsAddress
- constructApiDescriptionObject
- encodeURI
- NOOP
- isLoggedIn
- getBalance
- getAccount
- isTokenOnList
- formatAddressShort
- requiresTypeSlug
- getNextOffchainPollEndingTime
- slugify
- slugifyPreserveDashes
- setupSwagger
- isBlindMode
- getExplorerLink
- isCountdown
- showVvsPrice
- getCookies
- iconFromMIME
- makeRangeArray
- exitIfMaintenance
- sanitizeHtmlString
- parseDate
- retryWrapper
- batchPromises
- arrayPartitions
- sleep
- checkKeyboardTrigger
- clampValue
- debounce
- normalize
- strToInt
- getFromLocalStorage
- saveToLocalStorage
- generateTagColors
- formatNumberWithCommas
- memoize
- calculateTotalInvestment
- throttle
- urlParametersState
- mmddyyyy2ddmmyyy
- sortStringDates
- gtag
- compactNumberFormatter
- getNumberSign
- getLastArrayElement
- fillArrayUntil
- capitalizeFirstLetter
- buildUrl
- XmlWrapper
- XmlTemplate
- setCookie
Other Related APIs
- react#useState
- react#useEffect
- react#useCallback
- react#useContext
- react#useMemo
- react-router-dom#useLocation
- react-redux#useDispatch
- react-redux#useSelector
- react-redux#TypedUseSelectorHook
- redux#bindActionCreators
- ethers#ethers
- ethers#BigNumber
- utils#isValidAddress
- utils#ChainId
- utils#TOKENS_LIST
- utils#PROVIDERS
- utils#getDepositBox
- utils#TransactionError
- utils#MAX_APPROVAL_AMOUNT
- utils#optimismErc20Pairs
- utils#tagAddress
utils#bobaErc20Pairs TypeScript Examples
The following examples show how to use
utils#bobaErc20Pairs.
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example #1
Source File: hooks.ts From frontend-v1 with GNU Affero General Public License v3.0 | 4 votes |
export function useSendBoba() {
const [bobaBridge] = useState(new BobaBridgeClient());
const [bridgeAddress, setBridgeAddress] = useState("");
const { isConnected, chainId, account, signer } = useConnection();
const {
fromChain,
amount,
token,
currentlySelectedFromChain,
currentlySelectedToChain,
toAddress,
error,
} = useAppSelector((state) => state.send);
const { block } = useL2Block();
const { balance: balanceStr } = useBalance({
chainId: fromChain,
account,
tokenAddress: token,
});
const balance = BigNumber.from(balanceStr);
const { data: allowance } = useAllowance(
{
chainId: fromChain,
token,
owner: account!,
spender: bridgeAddress,
amount,
},
{ skip: !account || !isConnected || !chainId }
);
const canApprove = balance.gte(amount) && amount.gte(0);
const hasToApprove = allowance?.hasToApprove ?? true;
//TODO: Add fees
const [fees] = useState({
instantRelayFee: {
total: BigNumber.from("0"),
pct: BigNumber.from("0"),
},
slowRelayFee: {
total: BigNumber.from("0"),
pct: BigNumber.from("0"),
},
lpFee: {
total: BigNumber.from("0"),
pct: BigNumber.from("0"),
},
isAmountTooLow: false,
isLiquidityInsufficient: false,
});
useEffect(() => {
if (!bobaBridge) return;
bobaBridge
.getL1BridgeAddress(chainId as number, PROVIDERS[ChainId.MAINNET]())
.then((address) => {
setBridgeAddress(address);
})
.catch(() => {
setBridgeAddress("");
});
}, [bobaBridge, chainId]);
const send = useCallback(async () => {
if (!isConnected || !signer) return {};
if (!(await validateContractAndChain(bridgeAddress, fromChain, signer))) {
return {};
}
if (token === ethers.constants.AddressZero) {
return {
tx: await bobaBridge.depositEth(signer, amount),
fees,
};
} else {
const pairToken = bobaErc20Pairs()[token];
if (!pairToken) return {};
return {
tx: await bobaBridge.depositERC20(signer, token, pairToken, amount),
fees,
};
}
}, [
amount,
fees,
token,
isConnected,
bobaBridge,
signer,
fromChain,
bridgeAddress,
]);
const approve = useCallback(() => {
if (!signer) return;
return bobaBridge.approve(signer, token, MAX_APPROVAL_AMOUNT);
}, [bobaBridge, signer, token]);
const hasToSwitchChain =
isConnected && currentlySelectedFromChain.chainId !== chainId;
const canSend = useMemo(
() =>
currentlySelectedFromChain.chainId &&
block &&
currentlySelectedToChain.chainId &&
amount &&
token &&
fees &&
toAddress &&
isValidAddress(toAddress) &&
!hasToApprove &&
!hasToSwitchChain &&
!error &&
balance.gte(amount),
[
currentlySelectedFromChain.chainId,
block,
currentlySelectedToChain.chainId,
amount,
token,
fees,
toAddress,
hasToApprove,
hasToSwitchChain,
error,
balance,
]
);
return {
canSend,
canApprove,
hasToApprove,
hasToSwitchChain,
send,
approve,
fees,
spender: bridgeAddress,
};
}