Skip to content

Commit

Permalink
Add support for using different tokens on ParaTimes
Browse files Browse the repository at this point in the history
Up to now, we assumed that the native token on each ParaTime
is always the same as the native token on the network.

Unfortunately this is not always true, so now we have to make
it possible to use different tokens on paratimes.
  • Loading branch information
csillag committed Feb 16, 2024
1 parent 88abc73 commit c99910b
Show file tree
Hide file tree
Showing 8 changed files with 48 additions and 23 deletions.
1 change: 1 addition & 0 deletions .changelog/1265.feature.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Add support for using different tokens on ParaTimes
5 changes: 3 additions & 2 deletions src/app/pages/RuntimeTransactionDetailPage/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,8 @@ import { TransactionLink } from '../../components/Transactions/TransactionLink'
import { TransactionEvents } from '../../components/Transactions/TransactionEvents'
import { useRequiredScopeParam } from '../../hooks/useScopeParam'
import { DashboardLink } from '../ParatimeDashboardPage/DashboardLink'
import { getNameForTicker, getTickerForNetwork, Ticker } from '../../../types/ticker'
import { getNameForTicker, Ticker } from '../../../types/ticker'
import { getTickerForScope } from '../../../config'
import { TokenPriceInfo, useTokenPrice } from '../../../coin-gecko/api'
import { CurrentFiatValue } from './CurrentFiatValue'
import { AddressSwitch, AddressSwitchOption } from '../../components/AddressSwitch'
Expand Down Expand Up @@ -102,7 +103,7 @@ export const RuntimeTransactionDetailPage: FC = () => {
data?.data,
)

const tokenPriceInfo = useTokenPrice(getTickerForNetwork(scope.network))
const tokenPriceInfo = useTokenPrice(getTickerForScope(scope))

if (!transaction && !isLoading) {
throw AppErrors.NotFoundTxHash
Expand Down
4 changes: 2 additions & 2 deletions src/app/pages/RuntimeTransactionsPage/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ import { TableLayout, TableLayoutButton } from '../../components/TableLayoutButt
import { RuntimeTransactionDetailView } from '../RuntimeTransactionDetailPage'
import { useRequiredScopeParam } from '../../hooks/useScopeParam'
import { useTokenPrice } from '../../../coin-gecko/api'
import { getTickerForNetwork } from '../../../types/ticker'
import { getTickerForScope } from '../../../config'
import { VerticalList } from '../../components/VerticalList'

const limit = NUMBER_OF_ITEMS_ON_SEPARATE_PAGE
Expand All @@ -35,7 +35,7 @@ export const RuntimeTransactionsPage: FC = () => {
// we should call useGetConsensusTransactions()
}

const tokenPriceInfo = useTokenPrice(getTickerForNetwork(scope.network))
const tokenPriceInfo = useTokenPrice(getTickerForScope(scope))

useEffect(() => {
if (!isMobile) {
Expand Down
7 changes: 4 additions & 3 deletions src/app/pages/SearchResultsPage/SearchResultsList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import { AllTokenPrices } from '../../../coin-gecko/api'
import { ResultListFrame } from './ResultListFrame'
import { TokenDetails } from '../../components/Tokens/TokenDetails'
import { ProposalDetailView } from '../ProposalDetailsPage'
import { getTickerForScope } from '../../../config'

/**
* Component for displaying a list of search results
Expand Down Expand Up @@ -70,7 +71,7 @@ export const SearchResultsList: FC<{
<RuntimeTransactionDetailView
isLoading={false}
transaction={item}
tokenPriceInfo={tokenPrices[item.network]}
tokenPriceInfo={tokenPrices[getTickerForScope(item)]}
showLayer={true}
/>
)}
Expand All @@ -86,7 +87,7 @@ export const SearchResultsList: FC<{
isLoading={false}
isError={false}
account={item}
tokenPriceInfo={tokenPrices[item.network]}
tokenPriceInfo={tokenPrices[getTickerForScope(item)]}
showLayer={true}
/>
)}
Expand All @@ -102,7 +103,7 @@ export const SearchResultsList: FC<{
isLoading={false}
isError={false}
account={item}
tokenPriceInfo={tokenPrices[item.network]}
tokenPriceInfo={tokenPrices[getTickerForScope(item)]}
showLayer={true}
/>
)}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import {
} from '../../../utils/test-fixtures'
import { Network } from '../../../../types/network'
import { SearchResultsList } from '../SearchResultsList'
import { Ticker } from '../../../../types/ticker'

describe('SearchResultsView', () => {
beforeEach(() => {
Expand All @@ -24,13 +25,13 @@ describe('SearchResultsView', () => {
<SearchResultsList
searchResults={[suggestedParsedBlock, sapphireParsedBlock]}
tokenPrices={{
[Network.mainnet]: {
[Ticker.ROSE]: {
isLoading: false,
isFree: false,
price: 1,
hasUsedCoinGecko: true,
},
[Network.testnet]: {
[Ticker.TEST]: {
isLoading: false,
isFree: true,
hasUsedCoinGecko: false,
Expand Down Expand Up @@ -62,13 +63,13 @@ describe('SearchResultsView', () => {
title="test search"
networkForTheme={Network.mainnet}
tokenPrices={{
[Network.mainnet]: {
[Ticker.ROSE]: {
isLoading: false,
isFree: false,
price: 1,
hasUsedCoinGecko: true,
},
[Network.testnet]: {
[Ticker.TEST]: {
isLoading: false,
isFree: true,
hasUsedCoinGecko: false,
Expand Down
15 changes: 9 additions & 6 deletions src/coin-gecko/api.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
import axios from 'axios'
import type { AxiosResponse, AxiosError } from 'axios'
import { useQuery } from '@tanstack/react-query'
import { getTickerForNetwork, NativeTicker, Ticker } from '../types/ticker'
import { Network } from '../types/network'
import { NativeTicker, Ticker } from '../types/ticker'
import { getTickerForScope } from '../config'
import { RouteUtils } from '../app/utils/route-utils'
import { exhaustedTypeWarning } from '../types/errors'

Expand Down Expand Up @@ -78,12 +78,15 @@ export const useTokenPrice = (ticker: NativeTicker): TokenPriceInfo => {
}
}

export type AllTokenPrices = Record<Network, TokenPriceInfo>
export type AllTokenPrices = Record<NativeTicker, TokenPriceInfo>

export const useAllTokenPrices = (): AllTokenPrices => {
const results = {} as any
// The list of networks will never change on the run, so we can do this
// eslint-disable-next-line react-hooks/rules-of-hooks
RouteUtils.getEnabledNetworks().forEach(net => (results[net] = useTokenPrice(getTickerForNetwork(net))))
RouteUtils.getEnabledScopes().forEach(scope => {
const ticker = getTickerForScope(scope)
// The list of networks will never change on the run, so we can do this
// eslint-disable-next-line react-hooks/rules-of-hooks
results[ticker] = useTokenPrice(ticker)
})
return results
}
20 changes: 19 additions & 1 deletion src/config.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
// eslint-disable-next-line no-restricted-imports
import { Layer } from './oasis-nexus/generated/api' // We get this from the generated code to avoid circular imports
import { Layer } from './oasis-nexus/generated/api'
import { getTickerForNetwork, NativeTicker, Ticker } from './types/ticker'

Check warning on line 3 in src/config.ts

View workflow job for this annotation

GitHub Actions / lint

'Ticker' is defined but never used
import { SearchScope } from './types/searchScope' // We get this from the generated code to avoid circular imports

export const consensusDecimals = 9

Expand All @@ -8,6 +10,13 @@ type LayerNetwork = {
address: string | undefined
blockGasLimit: number | undefined
runtimeId: string | undefined

/**
* What do we call the native ticker on this layer?
*
* (If not given, the network's default token will be used.)
*/
ticker?: NativeTicker
}

type LayerConfig = {
Expand Down Expand Up @@ -164,3 +173,12 @@ const stableDeploys = [...deploys.production, deploys.staging]
export const isStableDeploy = stableDeploys.some(url => window.location.origin === url)

export const getAppTitle = () => process.env.REACT_APP_META_TITLE

export const getTickerForScope = ({ network, layer }: SearchScope): NativeTicker => {
const networkDefault = getTickerForNetwork(network)

if (layer !== Layer.consensus) {
return paraTimesConfig[layer][network].ticker ?? networkDefault
}
return networkDefault
}
10 changes: 5 additions & 5 deletions src/oasis-nexus/api.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
/** @file Wrappers around generated API */

import axios, { AxiosResponse } from 'axios'
import { consensusDecimals, paraTimesConfig } from '../config'
import { consensusDecimals, getTickerForScope, paraTimesConfig } from '../config'
import * as generated from './generated/api'
import { QueryKey, UseQueryOptions, UseQueryResult } from '@tanstack/react-query'
import {
Expand Down Expand Up @@ -176,7 +176,7 @@ export const useGetRuntimeTransactions: typeof generated.useGetRuntimeTransactio
params?,
options?,
) => {
const ticker = getTickerForNetwork(network)
const ticker = getTickerForScope({ network, layer: runtime })
return generated.useGetRuntimeTransactions(network, runtime, params, {
...options,
request: {
Expand Down Expand Up @@ -248,7 +248,7 @@ export const useGetRuntimeTransactionsTxHash: typeof generated.useGetRuntimeTran
) => {
// Sometimes we will call this with an undefined txHash, so we must be careful here.
const actualHash = txHash?.startsWith('0x') ? txHash.substring(2) : txHash
const ticker = getTickerForNetwork(network)
const ticker = getTickerForScope({ network, layer: runtime })
return generated.useGetRuntimeTransactionsTxHash(network, runtime, actualHash, {
...options,
request: {
Expand Down Expand Up @@ -317,7 +317,7 @@ export const useGetRuntimeAccountsAddress: typeof generated.useGetRuntimeAccount

const oasisAddress = useTransformToOasisAddress(address)

const ticker = getTickerForNetwork(network)
const ticker = getTickerForScope({ network, layer: runtime })
const query = generated.useGetRuntimeAccountsAddress(network, runtime, oasisAddress!, {
...options,
query: {
Expand Down Expand Up @@ -752,7 +752,7 @@ export const useGetRuntimeEvents: typeof generated.useGetRuntimeEvents = (
event.body.amount.Amount,
paraTimesConfig[runtime].decimals,
),
Denomination: getTickerForNetwork(network),
Denomination: getTickerForScope({ network, layer: runtime }),
}
: event.body.amount,
},
Expand Down

0 comments on commit c99910b

Please sign in to comment.