UNPKG

@openocean.finance/widget

Version:

Openocean Widget for cross-chain bridging and swapping. It will drive your multi-chain strategy and attract new users from everywhere.

69 lines (59 loc) 1.8 kB
import type { Chain } from '@openocean.finance/widget-sdk' import { useAvailableChains } from '../hooks/useAvailableChains.js' import { useWidgetConfig } from '../providers/WidgetProvider/WidgetProvider.js' const sanitiseBaseUrl = (baseUrl: string) => baseUrl.trim().replace(/\/+$/, '') export type TransactionLinkProps = { chain?: Chain | number } & ( | { txHash: string txLink?: never } | { txHash?: never txLink: string } ) export const useExplorer = () => { const { explorerUrls } = useWidgetConfig() const { getChainById } = useAvailableChains() const getBaseUrl = (chain: Chain) => { const baseUrl = explorerUrls?.[chain.id] ? explorerUrls[chain.id][0] : chain.metamask.blockExplorerUrls[0] return sanitiseBaseUrl(baseUrl) } const resolveChain = (chain: Chain | number) => Number.isFinite(chain) ? getChainById(chain as number) : (chain as Chain) const getTransactionLink = ({ txHash, txLink, chain, }: TransactionLinkProps) => { if (!txHash && txLink) { return txLink } if (!chain) { throw new Error( 'Chain parameter is required for getting transaction link' ) } const resolvedChain = resolveChain(chain) if (!resolvedChain) { throw new Error('Invalid chain') } return `${getBaseUrl(resolvedChain)}/tx/${txHash}` } const getAddressLink = (address: string, chain?: Chain | number) => { if (!chain) { throw new Error('Chain parameter is required for getting address link') } const resolvedChain = resolveChain(chain) if (!resolvedChain) { throw new Error('Invalid chain') } return `${getBaseUrl(resolvedChain)}/address/${address}` } return { getTransactionLink, getAddressLink, } }