Skip to content

Commit

Permalink
feat: update custom network
Browse files Browse the repository at this point in the history
  • Loading branch information
cs1707 committed Dec 4, 2024
1 parent 338d652 commit ab1488b
Show file tree
Hide file tree
Showing 18 changed files with 287 additions and 43 deletions.
2 changes: 2 additions & 0 deletions src/background/controller/wallet.ts
Original file line number Diff line number Diff line change
Expand Up @@ -132,6 +132,7 @@ import Browser from 'webextension-polyfill';
import SafeApiKit from '@safe-global/api-kit';
import { hashSafeMessage } from '@safe-global/protocol-kit';
import { userGuideService } from '../service/userGuide';
import { sleep } from '@/ui/views/HDManager/utils';

const stashKeyrings: Record<string | number, any> = {};

Expand Down Expand Up @@ -4812,6 +4813,7 @@ export class WalletController extends BaseController {
isAddedCustomTestnetToken = customTestnetService.hasToken;
getCustomTestnetTx = customTestnetService.getTx;
getCustomTestnetTxReceipt = customTestnetService.getTransactionReceipt;
getCustomTestnetLogos = () => customTestnetService.fetchLogos;
// getCustomTestnetTokenListWithBalance = customTestnetService.getTokenListWithBalance;

getUsedCustomTestnetChainList = async () => {
Expand Down
50 changes: 42 additions & 8 deletions src/background/service/customTestnet.ts
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,7 @@ export interface CustomTestnetTokenBase {
export interface CustomTestnetToken extends CustomTestnetTokenBase {
amount: number;
rawAmount: string;
logo?: string;
}

export type CutsomTestnetServiceStore = {
Expand All @@ -89,6 +90,14 @@ class CustomTestnetService {

chains: Record<string, Client> = {};

logos: Record<
string,
{
chain_logo_url: string;
token_logo_url?: string;
}
> = {};

init = async () => {
const storage = await createPersistStore<CutsomTestnetServiceStore>({
name: 'customTestnet',
Expand All @@ -102,10 +111,9 @@ class CustomTestnetService {
const client = createClientByChain(chain);
this.chains[chain.id] = client;
});
updateChainStore({
testnetList: Object.values(this.store.customTestnet).map((item) => {
return createTestnetChain(item);
}),
this.syncChainList();
this.fetchLogos().then(() => {
this.syncChainList();
});
};
add = async (chain: TestnetChainBase) => {
Expand Down Expand Up @@ -207,7 +215,14 @@ class CustomTestnetService {

getList = () => {
const list = Object.values(this.store.customTestnet).map((item) => {
return createTestnetChain(item);
const res = createTestnetChain(item);

if (this.logos?.[res.id]) {
res.logo = this.logos[res.id].chain_logo_url;
res.nativeTokenLogo = this.logos[res.id].token_logo_url || '';
}

return res;
});

return list;
Expand Down Expand Up @@ -257,6 +272,7 @@ class CustomTestnetService {
id: chain.nativeTokenAddress,
chainId: chain.id,
rawAmount: '0',
logo: this.logos?.[chain.id]?.token_logo_url,
}),
};
})
Expand All @@ -273,6 +289,7 @@ class CustomTestnetService {
id: chain.nativeTokenAddress,
chainId: chain.id,
rawAmount: '0',
logo: this.logos?.[chain.id]?.token_logo_url,
}),
};
});
Expand Down Expand Up @@ -444,7 +461,7 @@ class CustomTestnetService {
chainId: number;
address: string;
tokenId?: string | null;
}) => {
}): Promise<CustomTestnetToken> => {
const [balance, tokenInfo] = await Promise.all([
this.getBalance({
chainId,
Expand All @@ -463,6 +480,10 @@ class CustomTestnetService {
...tokenInfo,
amount: new BigNumber(balance.toString()).div(10 ** decimals).toNumber(),
rawAmount: balance.toString(),
logo:
tokenId?.replace('custom_', '') === String(chainId)
? this.logos?.[chainId]?.token_logo_url
: undefined,
};
};

Expand Down Expand Up @@ -641,6 +662,19 @@ class CustomTestnetService {
testnetList: testnetList,
});
};

fetchLogos = async () => {
try {
const { data } = await axios.get<typeof this.logos>(
'https://static.debank.com/supported_testnet_chains.json'
);
this.logos = data;
return data;
} catch (e) {
console.error(e);
return {};
}
};
}

export const customTestnetService = new CustomTestnetService();
Expand Down Expand Up @@ -677,8 +711,8 @@ export const createTestnetChain = (chain: TestnetChainBase): TestnetChain => {
nativeTokenDecimals: 18,
nativeTokenLogo: '',
scanLink: chain.scanLink || '',
logo: `data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'><circle cx='16' cy='16' r='16' fill='%236A7587'></circle><text x='16' y='17' dominant-baseline='middle' text-anchor='middle' fill='white' font-size='12' font-weight='400'>${encodeURIComponent(
chain.name.substring(0, 3)
logo: `data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'><circle cx='16' cy='16' r='16' fill='%236A7587'></circle><text x='16' y='17' dominant-baseline='middle' text-anchor='middle' fill='white' font-size='11' font-weight='500'>${encodeURIComponent(
chain.name.trim().substring(0, 1)
)}</text></svg>`,
eip: {
1559: false,
Expand Down
16 changes: 12 additions & 4 deletions src/ui/component/ChainSelector/components/SelectChainItem.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -95,10 +95,18 @@ export const SelectChainItem = forwardRef(
>
<div className="flex items-center flex-1">
{data.isTestnet ? (
<TestnetChainLogo
name={data.name}
className="select-chain-item-icon"
/>
data.logo ? (
<img
src={data.logo}
alt=""
className="select-chain-item-icon"
/>
) : (
<TestnetChainLogo
name={data.name}
className="select-chain-item-icon"
/>
)
) : (
<>
{showRPCStatus ? (
Expand Down
2 changes: 1 addition & 1 deletion src/ui/component/TestnetChainLogo/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ export const TestnetChainLogo = ({
className
)}
>
{name.substring(0, 3)}
{name.trim().substring(0, 1)}
</div>
);
};
13 changes: 8 additions & 5 deletions src/ui/models/chains.ts
Original file line number Diff line number Diff line change
Expand Up @@ -73,12 +73,15 @@ export const chains = createModel<RootModel>()({
},
effects: (dispatch) => ({
init(_: void, store) {
store.app.wallet.getCustomTestnetList().then((testnetList) => {
updateChainStore({
testnetList: testnetList,
store.app.wallet
.getCustomTestnetLogos()
.then(() => store.app.wallet.getCustomTestnetList())
.then((testnetList) => {
updateChainStore({
testnetList: testnetList,
});
this.setField({ testnetList });
});
this.setField({ testnetList });
});
getMainnetListFromLocal().then((mainnetList) => {
if (mainnetList.length) {
updateChainStore({
Expand Down
2 changes: 1 addition & 1 deletion src/ui/utils/token.ts
Original file line number Diff line number Diff line change
Expand Up @@ -199,7 +199,7 @@ export const customTestnetTokenToTokenItem = (
is_wallet: false,
is_scam: false,
is_suspicious: false,
logo_url: '',
logo_url: token.logo || '',
name: token.symbol,
optimized_symbol: token.symbol,
price: 0,
Expand Down
3 changes: 2 additions & 1 deletion src/ui/views/ApprovalManagePage/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -997,7 +997,8 @@ const ApprovalManagePage = () => {

const { t } = useTranslation();

const { isShowTestnet, selectedTab, onTabChange } = useSwitchNetTab();
const { selectedTab, onTabChange } = useSwitchNetTab();
const isShowTestnet = false;

const { isDarkTheme } = useThemeMode();
const [chain, setChain] = React.useState<CHAINS_ENUM>();
Expand Down
8 changes: 7 additions & 1 deletion src/ui/views/CommonPopup/AssetList/AssetList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import { Button } from 'antd';
import { SpecialTokenListPopup } from './components/TokenButton';
import { useRabbySelector } from '@/ui/store';
import useSortToken from '@/ui/hooks/useSortTokens';
import { TestnetChainList } from './TestnetChainList';

export const AssetList = ({
visible,
Expand Down Expand Up @@ -121,7 +122,12 @@ export const AssetList = ({
</div>
</div>
<div className={clsx(selectedTab === 'testnet' ? 'block' : 'hidden')}>
<CustomTestnetAssetList visible={visible} onClose={onClose} />
<TestnetChainList onChange={handleTestnetSelectChainChange} />
<CustomTestnetAssetList
selectChainId={selectTestnetChainId}
visible={visible}
onClose={onClose}
/>
</div>
</>
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { useRabbySelector } from '@/ui/store';
import { isSameAddress, useWallet } from '@/ui/utils';
import { useRequest } from 'ahooks';
import { Input } from 'antd';
import React from 'react';
import React, { useMemo } from 'react';
import {
TokenListSkeleton,
TokenListViewSkeleton,
Expand All @@ -22,16 +22,14 @@ interface Props {
className?: string;
visible: boolean;
onEmptyAssets: (isEmpty: boolean) => void;
isTestnet?: boolean;
onRefresh?: () => void;
selectChainId?: string | null;
}

export const CustomTestnetAssetListContainer: React.FC<Props> = ({
className,
visible,
onEmptyAssets,
isTestnet = false,
onRefresh,
selectChainId,
}) => {
const { t } = useTranslation();
const [search, setSearch] = React.useState<string>('');
Expand Down Expand Up @@ -67,7 +65,7 @@ export const CustomTestnetAssetListContainer: React.FC<Props> = ({

const wallet = useWallet();

const { data: list, loading, mutate, refreshAsync } = useRequest(
const { data: _list, loading, mutate, refreshAsync } = useRequest(
async () => {
return wallet.getCustomTestnetTokenList({
address: currentAccount!.address,
Expand All @@ -86,6 +84,15 @@ export const CustomTestnetAssetListContainer: React.FC<Props> = ({
}
);

const list = useMemo(() => {
if (!selectChainId) {
return _list;
}
return _list?.filter((item) => {
return String(item.chainId) === selectChainId;
});
}, [_list, selectChainId]);

if (!isFetched && !search) {
return <TokenListViewSkeleton isTestnet />;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ const TokenItemAsset: React.FC<Props> = ({ item }) => {
<div className="relative h-[24px]">
<Image
className="w-24 h-24 rounded-full"
src={IconUnknown}
src={item.logo || IconUnknown}
alt={item.symbol}
fallback={IconUnknown}
preview={false}
Expand All @@ -40,9 +40,12 @@ const TokenItemAsset: React.FC<Props> = ({ item }) => {
</TooltipWithMagnetArrow>
</div>
<div className="overflow-hidden">
<span className="text-r-neutral-title-1 text-13 font-medium leading-[15px]">
<div className="text-r-neutral-title-1 text-13 font-medium leading-[16px] mb-[1px]">
{item.symbol}
</span>
</div>
<div className="text-r-neutral-foot text-12 font-normal leading-[14px]">
{chain?.name}
</div>
</div>
</TCell>
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,11 @@ import { useHistory } from 'react-router-dom';
export const CustomTestnetAssetList = ({
visible,
onClose,
selectChainId,
}: {
visible: boolean;
onClose?(): void;
selectChainId?: string | null;
}) => {
const { t } = useTranslation();

Expand Down Expand Up @@ -50,6 +52,7 @@ export const CustomTestnetAssetList = ({
className="mt-12"
visible={visible}
onEmptyAssets={setIsTestnetEmptyAssets}
selectChainId={selectChainId}
/>
</div>
</>
Expand Down
Loading

0 comments on commit ab1488b

Please sign in to comment.