@0xsquid/react-hooks 6.4.5 → 6.4.7-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/core/connectors/bitcoin/errors/index.d.ts +2 -1
- package/dist/core/connectors/bitcoin/errors/index.js +1 -1
- package/dist/core/connectors/bitcoin/errors/index.js.map +1 -1
- package/dist/core/constants.d.ts +7 -7
- package/dist/core/constants.js +21 -7
- package/dist/core/constants.js.map +1 -1
- package/dist/core/externalLinks.d.ts +1 -1
- package/dist/core/externalLinks.js +1 -1
- package/dist/core/index.d.ts +1 -1
- package/dist/core/index.js +1 -1
- package/dist/core/index.js.map +1 -1
- package/dist/core/providers/CosmosProvider.d.ts +1 -1
- package/dist/core/providers/CosmosProvider.js.map +1 -1
- package/dist/core/providers/SuiProvider.d.ts +19 -0
- package/dist/core/providers/SuiProvider.js +15 -0
- package/dist/core/providers/SuiProvider.js.map +1 -0
- package/dist/core/queries/queries-keys.d.ts +4 -4
- package/dist/core/types/error.d.ts +0 -1
- package/dist/core/types/error.js.map +1 -1
- package/dist/core/types/rpc.d.ts +10 -0
- package/dist/core/types/rpc.js +2 -0
- package/dist/core/types/rpc.js.map +1 -0
- package/dist/core/types/sui.d.ts +14 -0
- package/dist/core/types/sui.js +2 -0
- package/dist/core/types/sui.js.map +1 -0
- package/dist/core/types/transaction.d.ts +0 -1
- package/dist/core/types/wallet.d.ts +19 -2
- package/dist/core/types/wallet.js.map +1 -1
- package/dist/core/wagmiConfig.js +2 -8
- package/dist/core/wagmiConfig.js.map +1 -1
- package/dist/core/wallets.d.ts +1 -0
- package/dist/core/wallets.js +1 -1
- package/dist/core/wallets.js.map +1 -1
- package/dist/hooks/chains/useSquidChains.d.ts +1 -0
- package/dist/hooks/chains/useSquidChains.js +23 -4
- package/dist/hooks/chains/useSquidChains.js.map +1 -1
- package/dist/hooks/cosmos/useCosmos.js +15 -20
- package/dist/hooks/cosmos/useCosmos.js.map +1 -1
- package/dist/hooks/index.d.ts +1 -0
- package/dist/hooks/index.js +1 -0
- package/dist/hooks/index.js.map +1 -1
- package/dist/hooks/solana/useSolana.js +8 -2
- package/dist/hooks/solana/useSolana.js.map +1 -1
- package/dist/hooks/store/useWalletStore.d.ts +5 -5
- package/dist/hooks/store/useWalletStore.js +13 -20
- package/dist/hooks/store/useWalletStore.js.map +1 -1
- package/dist/hooks/sui/useSui.d.ts +2 -0
- package/dist/hooks/sui/useSui.js +28 -0
- package/dist/hooks/sui/useSui.js.map +1 -0
- package/dist/hooks/sui/useSuiClient.d.ts +9 -0
- package/dist/hooks/sui/useSuiClient.js +16 -0
- package/dist/hooks/sui/useSuiClient.js.map +1 -0
- package/dist/hooks/sui/useSuiWallets.d.ts +7 -0
- package/dist/hooks/sui/useSuiWallets.js +36 -0
- package/dist/hooks/sui/useSuiWallets.js.map +1 -0
- package/dist/hooks/swap/useSwap.js +3 -3
- package/dist/hooks/swap/useSwap.js.map +1 -1
- package/dist/hooks/tokens/useAllConnectedWalletBalances.js +12 -1
- package/dist/hooks/tokens/useAllConnectedWalletBalances.js.map +1 -1
- package/dist/hooks/tokens/useAllTokensWithBalanceForChainType.d.ts +4 -5
- package/dist/hooks/tokens/useAllTokensWithBalanceForChainType.js +30 -17
- package/dist/hooks/tokens/useAllTokensWithBalanceForChainType.js.map +1 -1
- package/dist/hooks/tokens/useBalance.d.ts +18 -246
- package/dist/hooks/tokens/useBalance.js +66 -25
- package/dist/hooks/tokens/useBalance.js.map +1 -1
- package/dist/hooks/tokens/useMultiChainBalance.d.ts +2 -2
- package/dist/hooks/tokens/useMultiChainBalance.js +38 -35
- package/dist/hooks/tokens/useMultiChainBalance.js.map +1 -1
- package/dist/hooks/tokens/useNativeBalance.d.ts +16 -18
- package/dist/hooks/tokens/useNativeBalance.js +121 -56
- package/dist/hooks/tokens/useNativeBalance.js.map +1 -1
- package/dist/hooks/tokens/useNativeTokenForChain.js +6 -4
- package/dist/hooks/tokens/useNativeTokenForChain.js.map +1 -1
- package/dist/hooks/tokens/useSquidTokens.d.ts +2 -11
- package/dist/hooks/tokens/useSquidTokens.js +8 -16
- package/dist/hooks/tokens/useSquidTokens.js.map +1 -1
- package/dist/hooks/transaction/useEstimate.js +1 -1
- package/dist/hooks/transaction/useEstimate.js.map +1 -1
- package/dist/hooks/transaction/useExecuteTransaction.d.ts +0 -2
- package/dist/hooks/transaction/useExecuteTransaction.js +81 -39
- package/dist/hooks/transaction/useExecuteTransaction.js.map +1 -1
- package/dist/hooks/transaction/useGetRoute.d.ts +1 -2
- package/dist/hooks/transaction/useGetRoute.js +2 -2
- package/dist/hooks/transaction/useGetRoute.js.map +1 -1
- package/dist/hooks/transaction/useSingleTransaction.js +1 -1
- package/dist/hooks/transaction/useSingleTransaction.js.map +1 -1
- package/dist/hooks/user/useUserParams.js +1 -1
- package/dist/hooks/user/useUserParams.js.map +1 -1
- package/dist/hooks/wallet/useIntegratorContext.js +1 -1
- package/dist/hooks/wallet/useIntegratorContext.js.map +1 -1
- package/dist/hooks/wallet/useMultiChainWallet.d.ts +1 -3
- package/dist/hooks/wallet/useMultiChainWallet.js +32 -25
- package/dist/hooks/wallet/useMultiChainWallet.js.map +1 -1
- package/dist/hooks/wallet/useSigner.d.ts +2 -2
- package/dist/hooks/wallet/useSigner.js +32 -3
- package/dist/hooks/wallet/useSigner.js.map +1 -1
- package/dist/hooks/wallet/useWallet.d.ts +53 -7
- package/dist/hooks/wallet/useWallet.js +25 -11
- package/dist/hooks/wallet/useWallet.js.map +1 -1
- package/dist/hooks/wallet/useWallets.d.ts +29 -1
- package/dist/hooks/wallet/useWallets.js +5 -1
- package/dist/hooks/wallet/useWallets.js.map +1 -1
- package/dist/provider/index.d.ts +1 -1
- package/dist/provider/index.js +10 -8
- package/dist/provider/index.js.map +1 -1
- package/dist/services/external/rpcService.d.ts +8 -4
- package/dist/services/external/rpcService.js +38 -14
- package/dist/services/external/rpcService.js.map +1 -1
- package/dist/services/external/suiRpcClient.d.ts +32 -0
- package/dist/services/external/suiRpcClient.js +80 -0
- package/dist/services/external/suiRpcClient.js.map +1 -0
- package/dist/services/internal/assetsService.d.ts +2 -2
- package/dist/services/internal/assetsService.js +2 -2
- package/dist/services/internal/assetsService.js.map +1 -1
- package/dist/services/internal/bitcoinService.d.ts +3 -5
- package/dist/services/internal/bitcoinService.js.map +1 -1
- package/dist/services/internal/cosmosService.d.ts +4 -14
- package/dist/services/internal/cosmosService.js +1 -1
- package/dist/services/internal/cosmosService.js.map +1 -1
- package/dist/services/internal/errorService.d.ts +15 -0
- package/dist/services/internal/errorService.js +34 -4
- package/dist/services/internal/errorService.js.map +1 -1
- package/dist/services/internal/evmService.d.ts +3 -6
- package/dist/services/internal/evmService.js.map +1 -1
- package/dist/services/internal/solanaService.d.ts +3 -6
- package/dist/services/internal/solanaService.js.map +1 -1
- package/dist/services/internal/suiService.d.ts +9 -0
- package/dist/services/internal/suiService.js +88 -0
- package/dist/services/internal/suiService.js.map +1 -0
- package/dist/services/internal/transactionService.d.ts +0 -1
- package/dist/services/internal/walletService.d.ts +20 -14
- package/dist/services/internal/walletService.js +32 -25
- package/dist/services/internal/walletService.js.map +1 -1
- package/package.json +11 -7
|
@@ -4,12 +4,12 @@ import { useMemo } from "react";
|
|
|
4
4
|
import { useCosmosContext } from "../../core";
|
|
5
5
|
import { keys } from "../../core/queries/queries-keys";
|
|
6
6
|
import { calculateTotalUsdBalanceUSD, getAllKeysForSupportedCosmosChains, } from "../../services";
|
|
7
|
-
import { getAllBitcoinTokensBalance,
|
|
7
|
+
import { getAllBitcoinTokensBalance, getAllCosmosBalances, getAllEvmTokensBalance, getAllSolanaTokensBalance, getAllSuiTokensBalance, } from "../../services/external/rpcService";
|
|
8
8
|
import { useSquidChains } from "../chains/useSquidChains";
|
|
9
9
|
import { useSquidTokens } from "./useSquidTokens";
|
|
10
10
|
export const useAllTokensWithBalanceForChainType = ({ chainType, address, direction, queryOptions, }) => {
|
|
11
|
-
const { cosmosChains, chains } = useSquidChains(direction);
|
|
12
|
-
const { evmTokens, cosmosTokens, solanaTokens, bitcoinTokens } = useSquidTokens(direction);
|
|
11
|
+
const { cosmosChains, suiChains, chains } = useSquidChains(direction);
|
|
12
|
+
const { evmTokens, cosmosTokens, solanaTokens, bitcoinTokens, suiTokens } = useSquidTokens(direction);
|
|
13
13
|
const { keplrTypeWallet } = useCosmosContext();
|
|
14
14
|
const placeholderData = useMemo(() => {
|
|
15
15
|
const tokens = {
|
|
@@ -17,10 +17,12 @@ export const useAllTokensWithBalanceForChainType = ({ chainType, address, direct
|
|
|
17
17
|
[ChainType.COSMOS]: cosmosTokens.map((t) => ({ ...t, balance: "0" })),
|
|
18
18
|
[ChainType.SOLANA]: solanaTokens.map((t) => ({ ...t, balance: "0" })),
|
|
19
19
|
[ChainType.BTC]: bitcoinTokens.map((t) => ({ ...t, balance: "0" })),
|
|
20
|
+
[ChainType.SUI]: suiTokens.map((t) => ({ ...t, balance: "0" })),
|
|
20
21
|
};
|
|
21
22
|
if (!chainType) {
|
|
23
|
+
// Return all tokens with zero balance
|
|
22
24
|
return {
|
|
23
|
-
tokens:
|
|
25
|
+
tokens: Object.values(tokens).flat(),
|
|
24
26
|
totalUsdBalance: "0",
|
|
25
27
|
};
|
|
26
28
|
}
|
|
@@ -28,33 +30,41 @@ export const useAllTokensWithBalanceForChainType = ({ chainType, address, direct
|
|
|
28
30
|
tokens: tokens[chainType],
|
|
29
31
|
totalUsdBalance: "0",
|
|
30
32
|
};
|
|
31
|
-
}, [
|
|
33
|
+
}, [
|
|
34
|
+
chainType,
|
|
35
|
+
evmTokens,
|
|
36
|
+
cosmosTokens,
|
|
37
|
+
solanaTokens,
|
|
38
|
+
bitcoinTokens,
|
|
39
|
+
suiTokens,
|
|
40
|
+
]);
|
|
32
41
|
const isQueryEnabled = useMemo(() => {
|
|
33
42
|
// Respect the queryOptions.enabled override if provided
|
|
34
43
|
if (queryOptions?.enabled === false)
|
|
35
44
|
return false;
|
|
45
|
+
if (!chainType || !address)
|
|
46
|
+
return false;
|
|
36
47
|
switch (chainType) {
|
|
37
48
|
case ChainType.EVM:
|
|
38
|
-
return evmTokens.length > 0
|
|
49
|
+
return evmTokens.length > 0;
|
|
39
50
|
case ChainType.COSMOS:
|
|
40
|
-
return cosmosTokens.length > 0
|
|
51
|
+
return cosmosTokens.length > 0;
|
|
41
52
|
case ChainType.SOLANA:
|
|
42
|
-
return solanaTokens.length > 0
|
|
53
|
+
return solanaTokens.length > 0;
|
|
43
54
|
case ChainType.BTC:
|
|
44
|
-
return bitcoinTokens.length > 0
|
|
45
|
-
case
|
|
46
|
-
return
|
|
47
|
-
default:
|
|
48
|
-
return true;
|
|
55
|
+
return bitcoinTokens.length > 0;
|
|
56
|
+
case ChainType.SUI:
|
|
57
|
+
return suiTokens.length > 0;
|
|
49
58
|
}
|
|
50
59
|
}, [
|
|
51
60
|
chainType,
|
|
61
|
+
address,
|
|
62
|
+
queryOptions?.enabled,
|
|
52
63
|
evmTokens.length,
|
|
53
64
|
cosmosTokens.length,
|
|
54
65
|
solanaTokens.length,
|
|
55
66
|
bitcoinTokens.length,
|
|
56
|
-
|
|
57
|
-
queryOptions?.enabled,
|
|
67
|
+
suiTokens.length,
|
|
58
68
|
]);
|
|
59
69
|
const query = useQuery(keys().allTokensBalance(address, chainType), async () => {
|
|
60
70
|
// Return zero balances if no address
|
|
@@ -73,18 +83,21 @@ export const useAllTokensWithBalanceForChainType = ({ chainType, address, direct
|
|
|
73
83
|
break;
|
|
74
84
|
case ChainType.COSMOS:
|
|
75
85
|
const addresses = await getAllKeysForSupportedCosmosChains(cosmosChains.map((c) => c.chainId), keplrTypeWallet);
|
|
76
|
-
fetchedTokens = await
|
|
86
|
+
fetchedTokens = await getAllCosmosBalances({
|
|
77
87
|
addresses,
|
|
78
88
|
cosmosChains,
|
|
79
89
|
cosmosTokens,
|
|
80
90
|
});
|
|
81
91
|
break;
|
|
82
92
|
case ChainType.SOLANA:
|
|
83
|
-
fetchedTokens = await getAllSolanaTokensBalance(solanaTokens, address
|
|
93
|
+
fetchedTokens = await getAllSolanaTokensBalance(solanaTokens, address);
|
|
84
94
|
break;
|
|
85
95
|
case ChainType.BTC:
|
|
86
96
|
fetchedTokens = await getAllBitcoinTokensBalance(address, bitcoinTokens);
|
|
87
97
|
break;
|
|
98
|
+
case ChainType.SUI:
|
|
99
|
+
fetchedTokens = await getAllSuiTokensBalance(address, suiTokens, suiChains);
|
|
100
|
+
break;
|
|
88
101
|
default:
|
|
89
102
|
fetchedTokens = placeholderData.tokens;
|
|
90
103
|
break;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useAllTokensWithBalanceForChainType.js","sourceRoot":"","sources":["../../../src/hooks/tokens/useAllTokensWithBalanceForChainType.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAGL,QAAQ,GACT,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAChC,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAC9C,OAAO,EAAE,IAAI,EAAE,MAAM,iCAAiC,CAAC;AAEvD,OAAO,EACL,2BAA2B,EAC3B,kCAAkC,GACnC,MAAM,gBAAgB,CAAC;AACxB,OAAO,EACL,0BAA0B,EAC1B,
|
|
1
|
+
{"version":3,"file":"useAllTokensWithBalanceForChainType.js","sourceRoot":"","sources":["../../../src/hooks/tokens/useAllTokensWithBalanceForChainType.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,246 +1,18 @@
|
|
|
1
|
-
import type { ChainData,
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
}) =>
|
|
18
|
-
|
|
19
|
-
data: string;
|
|
20
|
-
error: unknown;
|
|
21
|
-
isError: true;
|
|
22
|
-
isLoading: false;
|
|
23
|
-
isLoadingError: false;
|
|
24
|
-
isRefetchError: true;
|
|
25
|
-
isSuccess: false;
|
|
26
|
-
status: "error";
|
|
27
|
-
dataUpdatedAt: number;
|
|
28
|
-
errorUpdatedAt: number;
|
|
29
|
-
failureCount: number;
|
|
30
|
-
failureReason: unknown;
|
|
31
|
-
errorUpdateCount: number;
|
|
32
|
-
isFetched: boolean;
|
|
33
|
-
isFetchedAfterMount: boolean;
|
|
34
|
-
isFetching: boolean;
|
|
35
|
-
isInitialLoading: boolean;
|
|
36
|
-
isPaused: boolean;
|
|
37
|
-
isPlaceholderData: boolean;
|
|
38
|
-
isPreviousData: boolean;
|
|
39
|
-
isRefetching: boolean;
|
|
40
|
-
isStale: boolean;
|
|
41
|
-
refetch: <TPageData>(options?: (import("@tanstack/react-query").RefetchOptions & import("@tanstack/react-query").RefetchQueryFilters<TPageData>) | undefined) => Promise<import("@tanstack/react-query").QueryObserverResult<string, unknown>>;
|
|
42
|
-
remove: () => void;
|
|
43
|
-
fetchStatus: import("@tanstack/react-query").FetchStatus;
|
|
44
|
-
} | {
|
|
45
|
-
balance: string;
|
|
46
|
-
data: string;
|
|
47
|
-
error: null;
|
|
48
|
-
isError: false;
|
|
49
|
-
isLoading: false;
|
|
50
|
-
isLoadingError: false;
|
|
51
|
-
isRefetchError: false;
|
|
52
|
-
isSuccess: true;
|
|
53
|
-
status: "success";
|
|
54
|
-
dataUpdatedAt: number;
|
|
55
|
-
errorUpdatedAt: number;
|
|
56
|
-
failureCount: number;
|
|
57
|
-
failureReason: unknown;
|
|
58
|
-
errorUpdateCount: number;
|
|
59
|
-
isFetched: boolean;
|
|
60
|
-
isFetchedAfterMount: boolean;
|
|
61
|
-
isFetching: boolean;
|
|
62
|
-
isInitialLoading: boolean;
|
|
63
|
-
isPaused: boolean;
|
|
64
|
-
isPlaceholderData: boolean;
|
|
65
|
-
isPreviousData: boolean;
|
|
66
|
-
isRefetching: boolean;
|
|
67
|
-
isStale: boolean;
|
|
68
|
-
refetch: <TPageData>(options?: (import("@tanstack/react-query").RefetchOptions & import("@tanstack/react-query").RefetchQueryFilters<TPageData>) | undefined) => Promise<import("@tanstack/react-query").QueryObserverResult<string, unknown>>;
|
|
69
|
-
remove: () => void;
|
|
70
|
-
fetchStatus: import("@tanstack/react-query").FetchStatus;
|
|
71
|
-
} | {
|
|
72
|
-
balance: string;
|
|
73
|
-
data: undefined;
|
|
74
|
-
error: unknown;
|
|
75
|
-
isError: true;
|
|
76
|
-
isLoading: false;
|
|
77
|
-
isLoadingError: true;
|
|
78
|
-
isRefetchError: false;
|
|
79
|
-
isSuccess: false;
|
|
80
|
-
status: "error";
|
|
81
|
-
dataUpdatedAt: number;
|
|
82
|
-
errorUpdatedAt: number;
|
|
83
|
-
failureCount: number;
|
|
84
|
-
failureReason: unknown;
|
|
85
|
-
errorUpdateCount: number;
|
|
86
|
-
isFetched: boolean;
|
|
87
|
-
isFetchedAfterMount: boolean;
|
|
88
|
-
isFetching: boolean;
|
|
89
|
-
isInitialLoading: boolean;
|
|
90
|
-
isPaused: boolean;
|
|
91
|
-
isPlaceholderData: boolean;
|
|
92
|
-
isPreviousData: boolean;
|
|
93
|
-
isRefetching: boolean;
|
|
94
|
-
isStale: boolean;
|
|
95
|
-
refetch: <TPageData>(options?: (import("@tanstack/react-query").RefetchOptions & import("@tanstack/react-query").RefetchQueryFilters<TPageData>) | undefined) => Promise<import("@tanstack/react-query").QueryObserverResult<string, unknown>>;
|
|
96
|
-
remove: () => void;
|
|
97
|
-
fetchStatus: import("@tanstack/react-query").FetchStatus;
|
|
98
|
-
} | {
|
|
99
|
-
balance: string;
|
|
100
|
-
data: undefined;
|
|
101
|
-
error: null;
|
|
102
|
-
isError: false;
|
|
103
|
-
isLoading: true;
|
|
104
|
-
isLoadingError: false;
|
|
105
|
-
isRefetchError: false;
|
|
106
|
-
isSuccess: false;
|
|
107
|
-
status: "loading";
|
|
108
|
-
dataUpdatedAt: number;
|
|
109
|
-
errorUpdatedAt: number;
|
|
110
|
-
failureCount: number;
|
|
111
|
-
failureReason: unknown;
|
|
112
|
-
errorUpdateCount: number;
|
|
113
|
-
isFetched: boolean;
|
|
114
|
-
isFetchedAfterMount: boolean;
|
|
115
|
-
isFetching: boolean;
|
|
116
|
-
isInitialLoading: boolean;
|
|
117
|
-
isPaused: boolean;
|
|
118
|
-
isPlaceholderData: boolean;
|
|
119
|
-
isPreviousData: boolean;
|
|
120
|
-
isRefetching: boolean;
|
|
121
|
-
isStale: boolean;
|
|
122
|
-
refetch: <TPageData>(options?: (import("@tanstack/react-query").RefetchOptions & import("@tanstack/react-query").RefetchQueryFilters<TPageData>) | undefined) => Promise<import("@tanstack/react-query").QueryObserverResult<string, unknown>>;
|
|
123
|
-
remove: () => void;
|
|
124
|
-
fetchStatus: import("@tanstack/react-query").FetchStatus;
|
|
125
|
-
};
|
|
126
|
-
export declare const useSolanaBalance: ({ chain, token, userAddress, enabled, refreshIntervalMs, }: {
|
|
127
|
-
chain?: ChainData | undefined;
|
|
128
|
-
token?: Token | undefined;
|
|
129
|
-
userAddress?: string | undefined;
|
|
130
|
-
enabled?: boolean | undefined;
|
|
131
|
-
refreshIntervalMs?: number | undefined;
|
|
132
|
-
}) => {
|
|
133
|
-
balance: string;
|
|
134
|
-
data: string;
|
|
135
|
-
error: unknown;
|
|
136
|
-
isError: true;
|
|
137
|
-
isLoading: false;
|
|
138
|
-
isLoadingError: false;
|
|
139
|
-
isRefetchError: true;
|
|
140
|
-
isSuccess: false;
|
|
141
|
-
status: "error";
|
|
142
|
-
dataUpdatedAt: number;
|
|
143
|
-
errorUpdatedAt: number;
|
|
144
|
-
failureCount: number;
|
|
145
|
-
failureReason: unknown;
|
|
146
|
-
errorUpdateCount: number;
|
|
147
|
-
isFetched: boolean;
|
|
148
|
-
isFetchedAfterMount: boolean;
|
|
149
|
-
isFetching: boolean;
|
|
150
|
-
isInitialLoading: boolean;
|
|
151
|
-
isPaused: boolean;
|
|
152
|
-
isPlaceholderData: boolean;
|
|
153
|
-
isPreviousData: boolean;
|
|
154
|
-
isRefetching: boolean;
|
|
155
|
-
isStale: boolean;
|
|
156
|
-
refetch: <TPageData>(options?: (import("@tanstack/react-query").RefetchOptions & import("@tanstack/react-query").RefetchQueryFilters<TPageData>) | undefined) => Promise<import("@tanstack/react-query").QueryObserverResult<string, unknown>>;
|
|
157
|
-
remove: () => void;
|
|
158
|
-
fetchStatus: import("@tanstack/react-query").FetchStatus;
|
|
159
|
-
} | {
|
|
160
|
-
balance: string;
|
|
161
|
-
data: string;
|
|
162
|
-
error: null;
|
|
163
|
-
isError: false;
|
|
164
|
-
isLoading: false;
|
|
165
|
-
isLoadingError: false;
|
|
166
|
-
isRefetchError: false;
|
|
167
|
-
isSuccess: true;
|
|
168
|
-
status: "success";
|
|
169
|
-
dataUpdatedAt: number;
|
|
170
|
-
errorUpdatedAt: number;
|
|
171
|
-
failureCount: number;
|
|
172
|
-
failureReason: unknown;
|
|
173
|
-
errorUpdateCount: number;
|
|
174
|
-
isFetched: boolean;
|
|
175
|
-
isFetchedAfterMount: boolean;
|
|
176
|
-
isFetching: boolean;
|
|
177
|
-
isInitialLoading: boolean;
|
|
178
|
-
isPaused: boolean;
|
|
179
|
-
isPlaceholderData: boolean;
|
|
180
|
-
isPreviousData: boolean;
|
|
181
|
-
isRefetching: boolean;
|
|
182
|
-
isStale: boolean;
|
|
183
|
-
refetch: <TPageData>(options?: (import("@tanstack/react-query").RefetchOptions & import("@tanstack/react-query").RefetchQueryFilters<TPageData>) | undefined) => Promise<import("@tanstack/react-query").QueryObserverResult<string, unknown>>;
|
|
184
|
-
remove: () => void;
|
|
185
|
-
fetchStatus: import("@tanstack/react-query").FetchStatus;
|
|
186
|
-
} | {
|
|
187
|
-
balance: string;
|
|
188
|
-
data: undefined;
|
|
189
|
-
error: unknown;
|
|
190
|
-
isError: true;
|
|
191
|
-
isLoading: false;
|
|
192
|
-
isLoadingError: true;
|
|
193
|
-
isRefetchError: false;
|
|
194
|
-
isSuccess: false;
|
|
195
|
-
status: "error";
|
|
196
|
-
dataUpdatedAt: number;
|
|
197
|
-
errorUpdatedAt: number;
|
|
198
|
-
failureCount: number;
|
|
199
|
-
failureReason: unknown;
|
|
200
|
-
errorUpdateCount: number;
|
|
201
|
-
isFetched: boolean;
|
|
202
|
-
isFetchedAfterMount: boolean;
|
|
203
|
-
isFetching: boolean;
|
|
204
|
-
isInitialLoading: boolean;
|
|
205
|
-
isPaused: boolean;
|
|
206
|
-
isPlaceholderData: boolean;
|
|
207
|
-
isPreviousData: boolean;
|
|
208
|
-
isRefetching: boolean;
|
|
209
|
-
isStale: boolean;
|
|
210
|
-
refetch: <TPageData>(options?: (import("@tanstack/react-query").RefetchOptions & import("@tanstack/react-query").RefetchQueryFilters<TPageData>) | undefined) => Promise<import("@tanstack/react-query").QueryObserverResult<string, unknown>>;
|
|
211
|
-
remove: () => void;
|
|
212
|
-
fetchStatus: import("@tanstack/react-query").FetchStatus;
|
|
213
|
-
} | {
|
|
214
|
-
balance: string;
|
|
215
|
-
data: undefined;
|
|
216
|
-
error: null;
|
|
217
|
-
isError: false;
|
|
218
|
-
isLoading: true;
|
|
219
|
-
isLoadingError: false;
|
|
220
|
-
isRefetchError: false;
|
|
221
|
-
isSuccess: false;
|
|
222
|
-
status: "loading";
|
|
223
|
-
dataUpdatedAt: number;
|
|
224
|
-
errorUpdatedAt: number;
|
|
225
|
-
failureCount: number;
|
|
226
|
-
failureReason: unknown;
|
|
227
|
-
errorUpdateCount: number;
|
|
228
|
-
isFetched: boolean;
|
|
229
|
-
isFetchedAfterMount: boolean;
|
|
230
|
-
isFetching: boolean;
|
|
231
|
-
isInitialLoading: boolean;
|
|
232
|
-
isPaused: boolean;
|
|
233
|
-
isPlaceholderData: boolean;
|
|
234
|
-
isPreviousData: boolean;
|
|
235
|
-
isRefetching: boolean;
|
|
236
|
-
isStale: boolean;
|
|
237
|
-
refetch: <TPageData>(options?: (import("@tanstack/react-query").RefetchOptions & import("@tanstack/react-query").RefetchQueryFilters<TPageData>) | undefined) => Promise<import("@tanstack/react-query").QueryObserverResult<string, unknown>>;
|
|
238
|
-
remove: () => void;
|
|
239
|
-
fetchStatus: import("@tanstack/react-query").FetchStatus;
|
|
240
|
-
};
|
|
241
|
-
export declare const useBitcoinBalance: ({ address, chain, }: {
|
|
242
|
-
chain?: ChainData | undefined;
|
|
243
|
-
address?: string | undefined;
|
|
244
|
-
}) => {
|
|
245
|
-
balance: string | undefined;
|
|
246
|
-
};
|
|
1
|
+
import type { ChainData, Token } from "@0xsquid/squid-types";
|
|
2
|
+
interface UseBalanceResult {
|
|
3
|
+
balance: string;
|
|
4
|
+
isLoading: boolean;
|
|
5
|
+
}
|
|
6
|
+
interface UseBalanceOptions {
|
|
7
|
+
chain?: ChainData;
|
|
8
|
+
token?: Token;
|
|
9
|
+
userAddress?: string;
|
|
10
|
+
enabled?: boolean;
|
|
11
|
+
refreshIntervalMs?: number;
|
|
12
|
+
}
|
|
13
|
+
export declare const useEvmBalance: ({ chain, token, userAddress, enabled, refreshIntervalMs, }: UseBalanceOptions) => UseBalanceResult;
|
|
14
|
+
export declare const useCosmosBalance: ({ chain, token, userAddress, enabled, refreshIntervalMs, }: UseBalanceOptions) => UseBalanceResult;
|
|
15
|
+
export declare const useSolanaBalance: ({ chain, token, userAddress, enabled, refreshIntervalMs, }: UseBalanceOptions) => UseBalanceResult;
|
|
16
|
+
export declare const useBitcoinBalance: ({ userAddress, chain, }: UseBalanceOptions) => UseBalanceResult;
|
|
17
|
+
export declare const useSuiBalance: ({ chain, token, userAddress, enabled, refreshIntervalMs, }: UseBalanceOptions) => UseBalanceResult;
|
|
18
|
+
export {};
|
|
@@ -1,39 +1,46 @@
|
|
|
1
1
|
import { ChainType } from "@0xsquid/squid-types";
|
|
2
2
|
import { useQuery } from "@tanstack/react-query";
|
|
3
|
-
import {
|
|
3
|
+
import { useReadContract, useBalance as useWagmiBalance } from "wagmi";
|
|
4
|
+
import { useMemo } from "react";
|
|
4
5
|
import { erc20Abi } from "viem";
|
|
5
6
|
import { useCosmosContext } from "../../core";
|
|
6
7
|
import { nativeEvmTokenAddress } from "../../core/constants";
|
|
7
8
|
import { keys } from "../../core/queries/queries-keys";
|
|
8
9
|
import { formatBNToReadable, isCosmosAddressValid } from "../../services";
|
|
9
|
-
import { getCosmosTokenBalance, getSolanaTokenBalance, } from "../../services/external/rpcService";
|
|
10
|
+
import { getCosmosTokenBalance, getSolanaTokenBalance, getSuiTokenBalance, } from "../../services/external/rpcService";
|
|
11
|
+
import { isSuiAddressValid } from "../../services/internal/suiService";
|
|
10
12
|
import { useWallet } from "../wallet/useWallet";
|
|
11
13
|
import { useBitcoinNativeBalance } from "./useNativeBalance";
|
|
12
14
|
const DEFAULT_REFRESH_INTERVAL_MS = 15000;
|
|
13
15
|
export const useEvmBalance = ({ chain, token, userAddress, enabled = true, refreshIntervalMs = DEFAULT_REFRESH_INTERVAL_MS, }) => {
|
|
14
|
-
const {
|
|
16
|
+
const { isChainTypeConnected } = useWallet();
|
|
15
17
|
const isNativeToken = token?.address.toLowerCase() === nativeEvmTokenAddress.toLowerCase();
|
|
16
18
|
const userAddressParsed = userAddress;
|
|
17
19
|
// Only fetch using useBalance if it's a native token
|
|
18
|
-
const { data: nativeBalance } =
|
|
20
|
+
const { data: nativeBalance, isLoading: isNativeTokenLoading } = useWagmiBalance({
|
|
19
21
|
address: userAddressParsed,
|
|
20
22
|
chainId: Number(chain?.chainId),
|
|
21
23
|
query: {
|
|
22
|
-
enabled:
|
|
24
|
+
enabled: enabled &&
|
|
25
|
+
!!userAddress &&
|
|
26
|
+
isNativeToken &&
|
|
27
|
+
!!chain &&
|
|
28
|
+
chain.chainType === ChainType.EVM &&
|
|
29
|
+
isChainTypeConnected(chain.chainType),
|
|
23
30
|
refetchInterval: refreshIntervalMs,
|
|
24
31
|
retry: 2,
|
|
25
32
|
},
|
|
26
33
|
});
|
|
27
34
|
// Only fetch using useReadContract if it's not a native token
|
|
28
35
|
// This is temporary, because of wagmi error: https://github.com/wevm/wagmi/issues/4353
|
|
29
|
-
const { data: erc20Balance } = useReadContract({
|
|
36
|
+
const { data: erc20Balance, isLoading: isErc20Loading } = useReadContract({
|
|
30
37
|
address: token?.address,
|
|
31
38
|
abi: erc20Abi,
|
|
32
39
|
functionName: "balanceOf",
|
|
33
40
|
args: [userAddressParsed],
|
|
34
41
|
chainId: Number(chain?.chainId),
|
|
35
42
|
query: {
|
|
36
|
-
enabled:
|
|
43
|
+
enabled: isChainTypeConnected(ChainType.EVM) &&
|
|
37
44
|
enabled &&
|
|
38
45
|
!!userAddress &&
|
|
39
46
|
!isNativeToken,
|
|
@@ -42,41 +49,44 @@ export const useEvmBalance = ({ chain, token, userAddress, enabled = true, refre
|
|
|
42
49
|
},
|
|
43
50
|
});
|
|
44
51
|
const balance = isNativeToken ? nativeBalance?.value : erc20Balance;
|
|
45
|
-
const
|
|
46
|
-
|
|
52
|
+
const isLoading = isNativeToken ? isNativeTokenLoading : isErc20Loading;
|
|
53
|
+
const formattedBalance = balance != null && token?.decimals != null
|
|
54
|
+
? formatBNToReadable(balance, token.decimals)
|
|
55
|
+
: "0";
|
|
56
|
+
return { balance: formattedBalance, isLoading };
|
|
47
57
|
};
|
|
48
|
-
export const useCosmosBalance = ({
|
|
58
|
+
export const useCosmosBalance = ({ chain, token, userAddress, enabled = true, refreshIntervalMs = DEFAULT_REFRESH_INTERVAL_MS, }) => {
|
|
49
59
|
const { isConnected } = useCosmosContext();
|
|
50
|
-
const
|
|
51
|
-
queryKey: keys().balance(
|
|
60
|
+
const { data: balance = "0", isLoading } = useQuery({
|
|
61
|
+
queryKey: keys().balance(chain?.chainId, token?.address, userAddress),
|
|
52
62
|
queryFn: async () => {
|
|
53
|
-
if (!userAddress || !token ||
|
|
63
|
+
if (!userAddress || !token || chain?.chainType !== ChainType.COSMOS) {
|
|
54
64
|
return "0";
|
|
55
65
|
}
|
|
56
|
-
const isAddressValid = isCosmosAddressValid(
|
|
66
|
+
const isAddressValid = isCosmosAddressValid(chain.bech32Config.bech32PrefixAccAddr, userAddress);
|
|
57
67
|
if (!isAddressValid)
|
|
58
68
|
return "0";
|
|
59
|
-
const
|
|
60
|
-
return formatBNToReadable(
|
|
69
|
+
const balanceBn = await getCosmosTokenBalance(chain, userAddress, token.address);
|
|
70
|
+
return formatBNToReadable(balanceBn, token.decimals);
|
|
61
71
|
},
|
|
62
72
|
enabled: isConnected &&
|
|
63
73
|
enabled &&
|
|
64
74
|
!!userAddress &&
|
|
65
75
|
!!token &&
|
|
66
|
-
|
|
76
|
+
chain?.chainType === ChainType.COSMOS,
|
|
67
77
|
refetchInterval: refreshIntervalMs,
|
|
68
78
|
retry: 2,
|
|
69
79
|
});
|
|
70
|
-
return {
|
|
80
|
+
return { balance, isLoading };
|
|
71
81
|
};
|
|
72
82
|
export const useSolanaBalance = ({ chain, token, userAddress, enabled = true, refreshIntervalMs = DEFAULT_REFRESH_INTERVAL_MS, }) => {
|
|
73
|
-
const
|
|
83
|
+
const { data: balance = "0", isLoading } = useQuery({
|
|
74
84
|
queryKey: keys().balance(chain?.chainId, token?.address, userAddress),
|
|
75
85
|
queryFn: async () => {
|
|
76
86
|
if (!userAddress || !token)
|
|
77
87
|
return "0";
|
|
78
|
-
const
|
|
79
|
-
return formatBNToReadable(
|
|
88
|
+
const balanceBn = await getSolanaTokenBalance(userAddress, token.address);
|
|
89
|
+
return formatBNToReadable(balanceBn, token.decimals);
|
|
80
90
|
},
|
|
81
91
|
enabled: enabled &&
|
|
82
92
|
!!userAddress &&
|
|
@@ -85,11 +95,42 @@ export const useSolanaBalance = ({ chain, token, userAddress, enabled = true, re
|
|
|
85
95
|
refetchInterval: refreshIntervalMs,
|
|
86
96
|
retry: 2,
|
|
87
97
|
});
|
|
88
|
-
return {
|
|
98
|
+
return { balance, isLoading };
|
|
89
99
|
};
|
|
90
100
|
// TODO: implement fetching balances for all bitcoin tokens
|
|
91
|
-
export const useBitcoinBalance = ({
|
|
92
|
-
const {
|
|
93
|
-
|
|
101
|
+
export const useBitcoinBalance = ({ userAddress, chain, }) => {
|
|
102
|
+
const { balance: balanceBn, isLoading } = useBitcoinNativeBalance({
|
|
103
|
+
address: userAddress,
|
|
104
|
+
chain,
|
|
105
|
+
});
|
|
106
|
+
const balance = useMemo(() => {
|
|
107
|
+
if (!balanceBn)
|
|
108
|
+
return "0";
|
|
109
|
+
return formatBNToReadable(balanceBn?.value, balanceBn?.decimals);
|
|
110
|
+
}, [balanceBn]);
|
|
111
|
+
return { balance, isLoading };
|
|
112
|
+
};
|
|
113
|
+
export const useSuiBalance = ({ chain, token, userAddress, enabled = true, refreshIntervalMs = DEFAULT_REFRESH_INTERVAL_MS, }) => {
|
|
114
|
+
const { data: balance = "0", isLoading } = useQuery({
|
|
115
|
+
queryKey: keys().balance(chain?.chainId, token?.address, userAddress),
|
|
116
|
+
queryFn: async () => {
|
|
117
|
+
if (!userAddress ||
|
|
118
|
+
token?.type !== ChainType.SUI ||
|
|
119
|
+
chain?.chainType !== ChainType.SUI) {
|
|
120
|
+
throw new Error("Invalid SUI balance query parameters");
|
|
121
|
+
}
|
|
122
|
+
const balanceBn = await getSuiTokenBalance(userAddress, token.address, chain.rpc);
|
|
123
|
+
return formatBNToReadable(balanceBn, token.decimals) ?? "0";
|
|
124
|
+
},
|
|
125
|
+
enabled: enabled &&
|
|
126
|
+
!!userAddress &&
|
|
127
|
+
!!chain?.rpc &&
|
|
128
|
+
token?.type === ChainType.SUI &&
|
|
129
|
+
chain?.chainType === ChainType.SUI &&
|
|
130
|
+
isSuiAddressValid(userAddress),
|
|
131
|
+
refetchInterval: refreshIntervalMs,
|
|
132
|
+
retry: 2,
|
|
133
|
+
});
|
|
134
|
+
return { balance, isLoading };
|
|
94
135
|
};
|
|
95
136
|
//# sourceMappingURL=useBalance.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useBalance.js","sourceRoot":"","sources":["../../../src/hooks/tokens/useBalance.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"useBalance.js","sourceRoot":"","sources":["../../../src/hooks/tokens/useBalance.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { ChainData, Token } from "@0xsquid/squid-types";
|
|
2
2
|
/**
|
|
3
|
-
*
|
|
3
|
+
* Hook to get balance depending on the chain type
|
|
4
4
|
* @param {ChainData} chain
|
|
5
5
|
* @param {Token} token
|
|
6
6
|
* @param {string} userAddress
|
|
@@ -13,5 +13,5 @@ export declare const useMultiChainBalance: ({ chain, token, userAddress, enabled
|
|
|
13
13
|
userAddress?: string | undefined;
|
|
14
14
|
enabled?: boolean | undefined;
|
|
15
15
|
}) => {
|
|
16
|
-
balance: string
|
|
16
|
+
balance: string;
|
|
17
17
|
};
|