Skip to content

Commit

Permalink
feat: added sbtc to top of tokens list
Browse files Browse the repository at this point in the history
  • Loading branch information
BLuEScioN committed Dec 18, 2024
1 parent c86e22c commit 40fd66c
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 6 deletions.
4 changes: 0 additions & 4 deletions src/app/tokens/TokensList/TokenTableSkeleton.tsx
Original file line number Diff line number Diff line change
@@ -1,8 +1,5 @@
'use client';

import { useColorMode } from '@chakra-ui/react';
import * as React from 'react';

import { Table } from '../../../ui/Table';
import { TableContainer } from '../../../ui/TableContainer';
import { Tbody } from '../../../ui/Tbody';
Expand All @@ -12,7 +9,6 @@ import { Tr } from '../../../ui/Tr';
import { Loading as TokenRowLoading } from '../TokenRow/loading';

export function TokenTableSkeleton() {
const colorMode = useColorMode().colorMode;
return (
<TableContainer>
<Table variant="simple" __css={{ tableLayout: 'fixed', width: 'full' }}>
Expand Down
24 changes: 22 additions & 2 deletions src/app/tokens/useTokens.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import {
useSuspenseInfiniteQueryResult,
} from '../../common/hooks/useInfiniteQueryResult';
import { useFtTokens, useSuspenseFtTokens } from '../../common/queries/useFtTokens';
import { sbtcContractAddress } from '../token/[tokenId]/consts';

export const useSuspenseTokens = (
debouncedSearchTerm: string
Expand All @@ -33,25 +34,44 @@ export const useSuspenseTokens = (
{ enabled: searchByAddress }
);

const shouldAddSbtc = useMemo(() => !debouncedSearchTerm, [debouncedSearchTerm]); // Only add sBTC if no search term is provided. If sbtc is searched, it will be added by default. If a search term that is not sbtc is provided, sbtc should not be added.
const sbtcResponse = useFtTokens({ address: sbtcContractAddress }, { enabled: shouldAddSbtc });

const ftTokensSearchedByName =
useSuspenseInfiniteQueryResult<FtBasicMetadataResponse>(searchByNameResponse);
const ftTokensSearchedBySymbol =
useInfiniteQueryResult<FtBasicMetadataResponse>(searchBySymbolResponse);
const ftTokensSearchedByAddress =
useInfiniteQueryResult<FtBasicMetadataResponse>(searchByAddressResponse);
const sbtc = useInfiniteQueryResult<FtBasicMetadataResponse>(sbtcResponse);

const allFtTokensDeduped = useMemo(() => {
const allFtTokens = [
...ftTokensSearchedByName,
...ftTokensSearchedBySymbol,
...ftTokensSearchedByAddress,
...(shouldAddSbtc ? sbtc : []),
];
const uniqueFtTokens = new Map<string, FtBasicMetadataResponse>();
allFtTokens.forEach(ftToken => {
uniqueFtTokens.set(ftToken.tx_id, ftToken);
});
return Array.from(uniqueFtTokens.values());
}, [ftTokensSearchedByAddress, ftTokensSearchedByName, ftTokensSearchedBySymbol]);
return Array.from(uniqueFtTokens.values()).sort((a, b) => {
// First check for sBTC
if (shouldAddSbtc) {
if (a.tx_id === sbtc[0]?.tx_id) return -1;
if (b.tx_id === sbtc[0]?.tx_id) return 1;
}
// Then do alphabetical comparison
return (a.name ?? '').localeCompare(b.name ?? '');
});
}, [
ftTokensSearchedByAddress,
ftTokensSearchedByName,
ftTokensSearchedBySymbol,
sbtc,
shouldAddSbtc,
]);

const loadMore = useCallback(() => {
void searchByNameResponse.fetchNextPage();
Expand Down

0 comments on commit 40fd66c

Please # to comment.