|
|
|
import { useSelector } from 'react-redux'
|
|
|
|
import { useRouteMatch } from 'react-router-dom'
|
|
|
|
import { getTokens } from '../ducks/metamask/metamask'
|
|
|
|
import { ASSET_ROUTE } from '../helpers/constants/routes'
|
|
|
|
import { ETH_SWAPS_TOKEN_OBJECT } from '../helpers/constants/swaps'
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a token object for the asset that is currently being viewed.
|
|
|
|
* Will return the ETH_SWAPS_TOKEN_OBJECT when the user is viewing either
|
|
|
|
* the primary, unfiltered, activity list or the ETH asset page.
|
|
|
|
* @returns {import('./useTokenDisplayValue').Token}
|
|
|
|
*/
|
|
|
|
export function useCurrentAsset() {
|
|
|
|
// To determine which primary currency to display for swaps transactions we need to be aware
|
|
|
|
// of which asset, if any, we are viewing at present
|
|
|
|
const match = useRouteMatch({
|
|
|
|
path: `${ASSET_ROUTE}/:asset`,
|
|
|
|
exact: true,
|
|
|
|
strict: true,
|
|
|
|
})
|
|
|
|
const tokenAddress = match?.params?.asset
|
|
|
|
const knownTokens = useSelector(getTokens)
|
|
|
|
const token =
|
|
|
|
tokenAddress && knownTokens.find(({ address }) => address === tokenAddress)
|
|
|
|
|
|
|
|
return token ?? ETH_SWAPS_TOKEN_OBJECT
|
|
|
|
}
|