From 3a3b71f2add61d7a7e193ff1f2b4a89fdd104d9f Mon Sep 17 00:00:00 2001 From: Kristof Csillag Date: Thu, 15 Jun 2023 20:49:21 +0200 Subject: [PATCH] Completely remove support for all token types except ERC-20 The indexer has removed the support, so it doesn't make sense for the explorer to try to support it. --- .changelog/542.breaking.md | 1 + .../components/Account/ShowMoreTokensLink.tsx | 15 ++-------- .../__tests__/ShowMoreTokensLink.test.tsx | 29 ++----------------- src/app/pages/AccountDetailsPage/index.tsx | 7 ++--- src/app/utils/route-utils.ts | 3 -- src/locales/en/translation.json | 1 - src/oasis-indexer/api.ts | 3 -- src/routes.tsx | 10 ------- 8 files changed, 7 insertions(+), 62 deletions(-) create mode 100644 .changelog/542.breaking.md diff --git a/.changelog/542.breaking.md b/.changelog/542.breaking.md new file mode 100644 index 000000000..4f3f36622 --- /dev/null +++ b/.changelog/542.breaking.md @@ -0,0 +1 @@ +Remove explorer support for token types dropped by indexer, incl. ERC721 diff --git a/src/app/components/Account/ShowMoreTokensLink.tsx b/src/app/components/Account/ShowMoreTokensLink.tsx index f782798a1..cfb1cc83f 100644 --- a/src/app/components/Account/ShowMoreTokensLink.tsx +++ b/src/app/components/Account/ShowMoreTokensLink.tsx @@ -29,26 +29,15 @@ export const ShowMoreTokensLink: FC = ({ account, token EvmTokenType.ERC20, accountTokenContainerId, ) - const erc721Link = RouteUtils.getAccountTokensRoute( - account, - account.address_eth ?? account.address, - EvmTokenType.ERC721, - accountTokenContainerId, - ) + const additionalTokensCounter = tokens.length - pills.length if (!additionalTokensCounter) { return null } - // link to ERC20 tab otherwise if there are only ERC721 tokens not included in pills link to the ERC721 - const pillsSymbols = new Set(pills.map(({ token_contract_addr }) => token_contract_addr)) - const showMoreItems = tokens.filter(({ token_contract_addr }) => !pillsSymbols.has(token_contract_addr)) - const hasERC20 = showMoreItems.some(item => item.token_type === EvmTokenType.ERC20) - const targetShowMoreLink = hasERC20 ? erc20link : erc721Link - return ( - + {t('account.showMore', { counter: additionalTokensCounter })} ) diff --git a/src/app/components/Account/__tests__/ShowMoreTokensLink.test.tsx b/src/app/components/Account/__tests__/ShowMoreTokensLink.test.tsx index 98042539b..960490c69 100644 --- a/src/app/components/Account/__tests__/ShowMoreTokensLink.test.tsx +++ b/src/app/components/Account/__tests__/ShowMoreTokensLink.test.tsx @@ -28,15 +28,6 @@ const mockedToken2: Token = { token_decimals: 18, } -const mockedToken3: Token = { - balance: '0.012345', - token_contract_addr: 'oasis1qrg90d4qlelg5zg4q4sd4y0z8j2lpjpvuspzjly3', - token_name: 'ERC721', - token_symbol: 'ERC721', - token_type: EvmTokenType.ERC721, - token_decimals: 18, -} - const mockedToken4: Token = { balance: '1123.5', token_contract_addr: 'oasis1qrg90d4qlelg5zg4q4sd4y0z8j2lpjpvuspzjly4', @@ -61,31 +52,15 @@ describe('ShowMoreTokensLink', () => { renderWithProviders( , ) - expect(screen.getByText('+ 3 more')).toBeInTheDocument() + expect(screen.getByText('+ 2 more')).toBeInTheDocument() expect(screen.getByRole('link')).toHaveAttribute( 'href', '/mainnet/emerald/address/oasis1qrvha284gfztn7wwq6z50c86ceu28jp7csqhpx9t/tokens/erc-20#tokens', ) }) - - it('should render ERC721 link if there is no ERC20 token', () => { - renderWithProviders( - , - ) - - expect(screen.getByText('+ 1 more')).toBeInTheDocument() - expect(screen.getByRole('link')).toHaveAttribute( - 'href', - '/mainnet/emerald/address/oasis1qrvha284gfztn7wwq6z50c86ceu28jp7csqhpx9t/tokens/erc-721#tokens', - ) - }) }) diff --git a/src/app/pages/AccountDetailsPage/index.tsx b/src/app/pages/AccountDetailsPage/index.tsx index bca46b932..3251b5fc0 100644 --- a/src/app/pages/AccountDetailsPage/index.tsx +++ b/src/app/pages/AccountDetailsPage/index.tsx @@ -26,12 +26,10 @@ export const AccountDetailsPage: FC = () => { const showErc20 = showEmptyAccountDetails || !!account?.tokenBalances[EvmTokenType.ERC20].length const erc20Link = useHref(`tokens/erc-20#${accountTokenContainerId}`) - const showErc721 = showEmptyAccountDetails || !!account?.tokenBalances[EvmTokenType.ERC721].length - const erc721Link = useHref(`tokens/erc-721#${accountTokenContainerId}`) - const showTxs = showEmptyAccountDetails || showErc20 || showErc721 || !!account?.stats.num_txns + const showTxs = showEmptyAccountDetails || showErc20 || !!account?.stats.num_txns const txLink = useHref('') - const showDetails = showTxs || showErc20 || showErc721 + const showDetails = showTxs || showErc20 return ( @@ -48,7 +46,6 @@ export const AccountDetailsPage: FC = () => { tabs={[ { label: t('common.transactions'), to: txLink, visible: showTxs }, { label: t('account.ERC20'), to: erc20Link, visible: showErc20 }, - { label: t('account.ERC721'), to: erc721Link, visible: showErc721 }, ]} /> )} diff --git a/src/app/utils/route-utils.ts b/src/app/utils/route-utils.ts index 93811542a..1d18d34fe 100644 --- a/src/app/utils/route-utils.ts +++ b/src/app/utils/route-utils.ts @@ -56,9 +56,6 @@ export abstract class RouteUtils { ) => { const map: Record = { ERC20: `${this.getAccountRoute(scope, account)}/tokens/erc-20`, - ERC721: `${this.getAccountRoute(scope, account)}/tokens/erc-721`, - ERC1155: undefined, - OasisSdk: undefined, } const tokenRoutes = map[tokenType] if (!tokenRoutes) throw new Error('Unexpected token type') diff --git a/src/locales/en/translation.json b/src/locales/en/translation.json index f117d26c3..fbd5aa530 100644 --- a/src/locales/en/translation.json +++ b/src/locales/en/translation.json @@ -4,7 +4,6 @@ "emptyTokenList": "This account holds no {{token}} tokens.", "emptyTransactionList": "There are no transactions on record for this account.", "ERC20": "ERC-20", - "ERC721": "ERC-721", "noTokens": "This account holds no tokens", "showMore": "+ {{counter}} more", "title": "Account", diff --git a/src/oasis-indexer/api.ts b/src/oasis-indexer/api.ts index 3c1c4fd07..043c22812 100644 --- a/src/oasis-indexer/api.ts +++ b/src/oasis-indexer/api.ts @@ -69,10 +69,7 @@ function wrapWithNetwork

, Q>(f: (...args: P) => Q): (net: N export const groupAccountTokenBalances = (account: Omit): RuntimeAccount => { const tokenBalances: Record = { - ERC1155: [], ERC20: [], - ERC721: [], - OasisSdk: [], } account.evm_balances.forEach(balance => { if (balance.token_type) tokenBalances[balance.token_type].push(balance) diff --git a/src/routes.tsx b/src/routes.tsx index d5688e105..d3d9502e4 100644 --- a/src/routes.tsx +++ b/src/routes.tsx @@ -79,11 +79,6 @@ export const routes: RouteObject[] = [ element: , loader: addressParamLoader, }, - { - path: 'tokens/erc-721', - element: , - loader: addressParamLoader, - }, ], }, { @@ -110,11 +105,6 @@ export const routes: RouteObject[] = [ element: , loader: addressParamLoader, }, - { - path: 'tokens/erc-721', - element: , - loader: addressParamLoader, - }, ], }, ],