@0xsquid/react-hooks 7.0.4-dest-address-refactor-beta.0 → 7.1.1-wallets-refactor-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/client/index.d.ts +2 -1
- package/dist/core/client/index.js +4 -1
- package/dist/core/client/index.js.map +1 -1
- package/dist/core/connectors/bitcoin/index.d.ts +0 -8
- package/dist/core/connectors/bitcoin/wallets/keplr.d.ts +1 -1
- package/dist/core/connectors/bitcoin/wallets/phantom.d.ts +1 -1
- package/dist/core/connectors/bitcoin/wallets/unisat.d.ts +1 -1
- package/dist/core/constants.d.ts +5 -9
- package/dist/core/constants.js +5 -9
- package/dist/core/constants.js.map +1 -1
- package/dist/core/providers/BitcoinProvider.d.ts +17 -0
- package/dist/core/providers/BitcoinProvider.js +15 -0
- package/dist/core/providers/BitcoinProvider.js.map +1 -0
- package/dist/core/providers/EvmProvider.d.ts +20 -0
- package/dist/core/providers/EvmProvider.js +15 -0
- package/dist/core/providers/EvmProvider.js.map +1 -0
- package/dist/core/providers/SolanaProvider.d.ts +10 -15
- package/dist/core/providers/SolanaProvider.js.map +1 -1
- package/dist/core/providers/SuiProvider.d.ts +1 -0
- package/dist/core/providers/SuiProvider.js.map +1 -1
- package/dist/core/types/bitcoin.d.ts +8 -0
- package/dist/core/types/bitcoin.js +2 -0
- package/dist/core/types/bitcoin.js.map +1 -0
- package/dist/core/types/evm.d.ts +2 -0
- package/dist/core/types/evm.js +2 -0
- package/dist/core/types/evm.js.map +1 -0
- package/dist/core/types/solana.d.ts +2 -0
- package/dist/core/types/solana.js +2 -0
- package/dist/core/types/solana.js.map +1 -0
- package/dist/core/types/sui.d.ts +3 -2
- package/dist/core/types/wallet.d.ts +16 -23
- package/dist/core/types/wallet.js +0 -15
- package/dist/core/types/wallet.js.map +1 -1
- package/dist/core/wagmiConfig.js +14 -1
- package/dist/core/wagmiConfig.js.map +1 -1
- package/dist/core/wallets.d.ts +1 -3
- package/dist/core/wallets.js +25 -350
- package/dist/core/wallets.js.map +1 -1
- package/dist/hooks/bitcoin/useBitcoin.d.ts +2 -0
- package/dist/hooks/bitcoin/useBitcoin.js +19 -0
- package/dist/hooks/bitcoin/useBitcoin.js.map +1 -0
- package/dist/hooks/bitcoin/useBitcoinWallets.d.ts +4 -0
- package/dist/hooks/bitcoin/useBitcoinWallets.js +10 -0
- package/dist/hooks/bitcoin/useBitcoinWallets.js.map +1 -0
- package/dist/hooks/evm/useEvm.d.ts +2 -0
- package/dist/hooks/evm/useEvm.js +55 -0
- package/dist/hooks/evm/useEvm.js.map +1 -0
- package/dist/hooks/evm/useEvmWallets.d.ts +7 -0
- package/dist/hooks/evm/useEvmWallets.js +16 -0
- package/dist/hooks/evm/useEvmWallets.js.map +1 -0
- package/dist/hooks/solana/useSolana.d.ts +2 -9
- package/dist/hooks/solana/useSolana.js +61 -84
- package/dist/hooks/solana/useSolana.js.map +1 -1
- package/dist/hooks/solana/useSolanaWallets.d.ts +4 -0
- package/dist/hooks/solana/useSolanaWallets.js +8 -0
- package/dist/hooks/solana/useSolanaWallets.js.map +1 -0
- package/dist/hooks/store/useWalletStore.js +5 -1
- package/dist/hooks/store/useWalletStore.js.map +1 -1
- package/dist/hooks/sui/useSui.js +61 -6
- package/dist/hooks/sui/useSui.js.map +1 -1
- package/dist/hooks/sui/useSuiWallets.d.ts +0 -3
- package/dist/hooks/sui/useSuiWallets.js +18 -37
- package/dist/hooks/sui/useSuiWallets.js.map +1 -1
- package/dist/hooks/transaction/send/useSendTransaction.js +21 -4
- package/dist/hooks/transaction/send/useSendTransaction.js.map +1 -1
- package/dist/hooks/transaction/useExecuteTransaction.js +3 -3
- package/dist/hooks/transaction/useExecuteTransaction.js.map +1 -1
- package/dist/hooks/wallet/useAutoConnect.js +13 -6
- package/dist/hooks/wallet/useAutoConnect.js.map +1 -1
- package/dist/hooks/wallet/useSigner.d.ts +2 -3
- package/dist/hooks/wallet/useSigner.js +2 -19
- package/dist/hooks/wallet/useSigner.js.map +1 -1
- package/dist/hooks/wallet/useStandardWallets.d.ts +9 -0
- package/dist/hooks/wallet/useStandardWallets.js +26 -0
- package/dist/hooks/wallet/useStandardWallets.js.map +1 -0
- package/dist/hooks/wallet/useWallet.d.ts +2 -3
- package/dist/hooks/wallet/useWallet.js +11 -52
- package/dist/hooks/wallet/useWallet.js.map +1 -1
- package/dist/hooks/wallet/useWallets.js +15 -21
- package/dist/hooks/wallet/useWallets.js.map +1 -1
- package/dist/provider/index.js +7 -3
- package/dist/provider/index.js.map +1 -1
- package/dist/services/external/cosmosRestClient.d.ts +18 -0
- package/dist/services/external/cosmosRestClient.js +45 -0
- package/dist/services/external/cosmosRestClient.js.map +1 -0
- package/dist/services/external/rpcService.d.ts +2 -2
- package/dist/services/external/rpcService.js +12 -45
- package/dist/services/external/rpcService.js.map +1 -1
- package/dist/services/internal/bitcoinService.d.ts +0 -3
- package/dist/services/internal/bitcoinService.js +0 -31
- package/dist/services/internal/bitcoinService.js.map +1 -1
- package/dist/services/internal/evmService.d.ts +8 -7
- package/dist/services/internal/evmService.js +29 -12
- package/dist/services/internal/evmService.js.map +1 -1
- package/dist/services/internal/sendTransaction.d.ts +12 -5
- package/dist/services/internal/sendTransaction.js +85 -5
- package/dist/services/internal/sendTransaction.js.map +1 -1
- package/dist/services/internal/sendTransactionStatus.js +23 -3
- package/dist/services/internal/sendTransactionStatus.js.map +1 -1
- package/dist/services/internal/solanaService.d.ts +7 -7
- package/dist/services/internal/solanaService.js +40 -10
- package/dist/services/internal/solanaService.js.map +1 -1
- package/dist/services/internal/suiService.d.ts +1 -11
- package/dist/services/internal/suiService.js +20 -58
- package/dist/services/internal/suiService.js.map +1 -1
- package/dist/services/internal/walletService.d.ts +18 -22
- package/dist/services/internal/walletService.js +128 -48
- package/dist/services/internal/walletService.js.map +1 -1
- package/dist/services/internal/walletStandardService.d.ts +17 -0
- package/dist/services/internal/walletStandardService.js +126 -0
- package/dist/services/internal/walletStandardService.js.map +1 -0
- package/dist/tests/walletService.test.js +242 -18
- package/dist/tests/walletService.test.js.map +1 -1
- package/package.json +4 -4
- package/dist/hooks/sui/useSuiClient.d.ts +0 -9
- package/dist/hooks/sui/useSuiClient.js +0 -16
- package/dist/hooks/sui/useSuiClient.js.map +0 -1
|
@@ -1,104 +1,81 @@
|
|
|
1
1
|
import { ChainType } from "@0xsquid/squid-types";
|
|
2
|
-
import { PhantomWalletAdapter } from "@solana/wallet-adapter-phantom";
|
|
3
2
|
import { Connection } from "@solana/web3.js";
|
|
4
3
|
import { useMutation } from "@tanstack/react-query";
|
|
5
|
-
import { useCallback, useEffect,
|
|
4
|
+
import { useCallback, useEffect, useRef } from "react";
|
|
6
5
|
import { SOLANA_RPC_URL } from "../../core/constants";
|
|
7
|
-
import {
|
|
8
|
-
import { useClient } from "../client/useClient";
|
|
6
|
+
import { RecentWalletStorage } from "../../services";
|
|
9
7
|
import { useWalletStore } from "../store/useWalletStore";
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
const
|
|
13
|
-
const
|
|
14
|
-
const
|
|
15
|
-
const
|
|
16
|
-
const { clientWindow, isClient } = useClient();
|
|
17
|
-
const window = clientWindow;
|
|
18
|
-
const { setConnectedWallet, disconnectWallet } = useWalletStore();
|
|
19
|
-
// Safely access wallet provider from window object
|
|
20
|
-
const solanaWalletObject = useMemo(() => {
|
|
21
|
-
if (isClient && solanaConnectedWallet?.windowFlag) {
|
|
22
|
-
return getWalletWindowProvider(window, solanaConnectedWallet, ChainType.SOLANA);
|
|
23
|
-
}
|
|
24
|
-
return undefined;
|
|
25
|
-
}, [solanaConnectedWallet, isClient, window]);
|
|
8
|
+
import { useSolanaWallets } from "./useSolanaWallets";
|
|
9
|
+
export function useSolana() {
|
|
10
|
+
const disconnectWallet = useWalletStore((store) => store.disconnectWallet);
|
|
11
|
+
const setConnectedWallet = useWalletStore((store) => store.setConnectedWallet);
|
|
12
|
+
const { wallets } = useSolanaWallets();
|
|
13
|
+
const connectedSolanaWallet = useWalletStore((store) => store.connectedWalletsByChainType[ChainType.SOLANA]);
|
|
26
14
|
const connectSolana = useMutation(async ({ wallet, }) => {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
}
|
|
31
|
-
const walletObject = getWalletWindowProvider(window, selectedWallet, ChainType.SOLANA);
|
|
32
|
-
if (!walletObject) {
|
|
33
|
-
return undefined;
|
|
15
|
+
try {
|
|
16
|
+
// try to connect silently first
|
|
17
|
+
await wallet.connector.autoConnect();
|
|
34
18
|
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
wallet: selectedWallet,
|
|
40
|
-
address,
|
|
41
|
-
});
|
|
42
|
-
return address;
|
|
19
|
+
catch {
|
|
20
|
+
// if auto-connect fails (e.g. not authorized yet)
|
|
21
|
+
// fallback to connect via popup
|
|
22
|
+
await wallet.connector.connect();
|
|
43
23
|
}
|
|
44
|
-
|
|
24
|
+
const address = wallet.connector.wallet.accounts[0].address;
|
|
25
|
+
return {
|
|
26
|
+
wallet,
|
|
27
|
+
address,
|
|
28
|
+
};
|
|
45
29
|
});
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
// Try to parse response to handle both PublicKey and { publicKey: PublicKey }
|
|
55
|
-
const parsedPublicKey = _publicKey?.publicKey;
|
|
56
|
-
if (typeof parsedPublicKey === "string") {
|
|
57
|
-
publicKey = parsedPublicKey;
|
|
58
|
-
}
|
|
59
|
-
if (publicKey && solanaConnectedWallet) {
|
|
60
|
-
setConnectedWallet(ChainType.SOLANA, {
|
|
61
|
-
wallet: solanaConnectedWallet,
|
|
62
|
-
address: publicKey,
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
else {
|
|
66
|
-
clearData();
|
|
30
|
+
const disconnectSolana = useCallback(async () => {
|
|
31
|
+
await connectedSolanaWallet.wallet?.connector.disconnect();
|
|
32
|
+
}, [connectedSolanaWallet.wallet?.connector]);
|
|
33
|
+
const autoConnectSolana = useCallback(async () => {
|
|
34
|
+
const recentSolanaWalletId = RecentWalletStorage.get(ChainType.SOLANA);
|
|
35
|
+
const recentSolanaWallet = wallets.find((w) => w.connectorId === recentSolanaWalletId);
|
|
36
|
+
if (!recentSolanaWallet) {
|
|
37
|
+
return;
|
|
67
38
|
}
|
|
68
|
-
|
|
69
|
-
|
|
39
|
+
await recentSolanaWallet.connector.autoConnect();
|
|
40
|
+
const [account] = recentSolanaWallet.connector.wallet.accounts;
|
|
41
|
+
setConnectedWallet(ChainType.SOLANA, {
|
|
42
|
+
wallet: recentSolanaWallet,
|
|
43
|
+
address: account.address,
|
|
44
|
+
});
|
|
45
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
46
|
+
}, [wallets.map((w) => w.connectorId)]);
|
|
70
47
|
useEffect(() => {
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
return
|
|
74
|
-
solanaWalletObject.off("connect", handleAccountChange);
|
|
75
|
-
};
|
|
48
|
+
const wallet = connectedSolanaWallet.wallet;
|
|
49
|
+
if (!wallet) {
|
|
50
|
+
return;
|
|
76
51
|
}
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
"isPhantom" in solanaWalletObject) {
|
|
84
|
-
const phantomAdapter = new PhantomWalletAdapter();
|
|
85
|
-
if (!phantomAdapter.connected && solanaAddress) {
|
|
86
|
-
phantomAdapter.connect().catch(console.error);
|
|
52
|
+
function onConnect(newAddress) {
|
|
53
|
+
if (wallet) {
|
|
54
|
+
setConnectedWallet(ChainType.SOLANA, {
|
|
55
|
+
wallet,
|
|
56
|
+
address: newAddress.toString(),
|
|
57
|
+
});
|
|
87
58
|
}
|
|
88
|
-
return phantomAdapter;
|
|
89
59
|
}
|
|
90
|
-
|
|
91
|
-
|
|
60
|
+
function onDisconnect() {
|
|
61
|
+
disconnectWallet(ChainType.SOLANA);
|
|
62
|
+
}
|
|
63
|
+
wallet.connector.on("connect", onConnect);
|
|
64
|
+
wallet.connector.on("disconnect", onDisconnect);
|
|
65
|
+
return () => {
|
|
66
|
+
wallet.connector.off("connect", onConnect);
|
|
67
|
+
wallet.connector.off("disconnect", onDisconnect);
|
|
68
|
+
};
|
|
69
|
+
}, [disconnectWallet, setConnectedWallet, connectedSolanaWallet.wallet]);
|
|
92
70
|
return {
|
|
93
71
|
connectSolana,
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
wallet: solanaConnectedWallet,
|
|
72
|
+
disconnectSolana,
|
|
73
|
+
autoConnectSolana,
|
|
74
|
+
isConnected: !!connectedSolanaWallet.wallet,
|
|
75
|
+
signer: connectedSolanaWallet.wallet?.connector,
|
|
76
|
+
wallets,
|
|
100
77
|
};
|
|
101
|
-
}
|
|
78
|
+
}
|
|
102
79
|
export const useSolanaConnection = () => {
|
|
103
80
|
const connectionRef = useRef(new Connection(SOLANA_RPC_URL));
|
|
104
81
|
return connectionRef.current;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useSolana.js","sourceRoot":"","sources":["../../../src/hooks/solana/useSolana.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"useSolana.js","sourceRoot":"","sources":["../../../src/hooks/solana/useSolana.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { filterSolanaWallets } from "../../services/internal/solanaService";
|
|
2
|
+
import { useStandardWallets } from "../wallet/useStandardWallets";
|
|
3
|
+
export function useSolanaWallets() {
|
|
4
|
+
return useStandardWallets({
|
|
5
|
+
filterWallets: filterSolanaWallets,
|
|
6
|
+
});
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=useSolanaWallets.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useSolanaWallets.js","sourceRoot":"","sources":["../../../src/hooks/solana/useSolanaWallets.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AAC5E,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAElE,MAAM,UAAU,gBAAgB;IAC9B,OAAO,kBAAkB,CAAe;QACtC,aAAa,EAAE,mBAAmB;KACnC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { ChainType } from "@0xsquid/squid-types";
|
|
2
2
|
import { create } from "zustand";
|
|
3
|
+
import { isEmptyObject, RecentWalletStorage } from "../../services";
|
|
3
4
|
export var ConnectingWalletStatus;
|
|
4
5
|
(function (ConnectingWalletStatus) {
|
|
5
6
|
ConnectingWalletStatus[ConnectingWalletStatus["IDLE"] = 0] = "IDLE";
|
|
@@ -20,6 +21,7 @@ const initialWalletState = {
|
|
|
20
21
|
export const useWalletStore = create((set) => ({
|
|
21
22
|
...initialWalletState,
|
|
22
23
|
setConnectedWallet: (chainType, connectedWalletState) => set((state) => {
|
|
24
|
+
RecentWalletStorage.set(chainType, connectedWalletState.wallet.connectorId);
|
|
23
25
|
return {
|
|
24
26
|
connectedWalletsByChainType: {
|
|
25
27
|
...state.connectedWalletsByChainType,
|
|
@@ -29,8 +31,10 @@ export const useWalletStore = create((set) => ({
|
|
|
29
31
|
}),
|
|
30
32
|
setConnectingWallet: (state) => set({ connectingWalletState: state }),
|
|
31
33
|
disconnectWallet: (chainType) => set((state) => {
|
|
32
|
-
if (
|
|
34
|
+
if (isEmptyObject(state.connectedWalletsByChainType[chainType])) {
|
|
33
35
|
return state;
|
|
36
|
+
}
|
|
37
|
+
RecentWalletStorage.remove(chainType);
|
|
34
38
|
return {
|
|
35
39
|
connectedWalletsByChainType: {
|
|
36
40
|
...state.connectedWalletsByChainType,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useWalletStore.js","sourceRoot":"","sources":["../../../src/hooks/store/useWalletStore.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"useWalletStore.js","sourceRoot":"","sources":["../../../src/hooks/store/useWalletStore.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAGjC,OAAO,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAEpE,MAAM,CAAN,IAAY,sBAIX;AAJD,WAAY,sBAAsB;IAChC,mEAAI,CAAA;IACJ,+EAAU,CAAA;IACV,2EAAQ,CAAA;AACV,CAAC,EAJW,sBAAsB,KAAtB,sBAAsB,QAIjC;AAcD,MAAM,kBAAkB,GAAgB;IACtC,uDAAuD;IACvD,2BAA2B,EAAE,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,MAAM,CAC1D,CAAC,GAAG,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC;QACnB,GAAG,GAAG;QACN,CAAC,SAAS,CAAC,EAAE,EAAE;KAChB,CAAC,EACF,EAAgD,CACjD;IACD,qBAAqB,EAAE;QACrB,MAAM,EAAE,SAAS;QACjB,MAAM,EAAE,sBAAsB,CAAC,IAAI;KACpC;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAG,MAAM,CASlC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IACV,GAAG,kBAAkB;IACrB,kBAAkB,EAAE,CAAC,SAAS,EAAE,oBAAoB,EAAE,EAAE,CACtD,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACZ,mBAAmB,CAAC,GAAG,CACrB,SAAS,EACT,oBAAoB,CAAC,MAAM,CAAC,WAAW,CACxC,CAAC;QAEF,OAAO;YACL,2BAA2B,EAAE;gBAC3B,GAAG,KAAK,CAAC,2BAA2B;gBACpC,CAAC,SAAS,CAAC,EAAE,oBAAoB;aAClC;SACF,CAAC;IACJ,CAAC,CAAC;IACJ,mBAAmB,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,qBAAqB,EAAE,KAAK,EAAE,CAAC;IACrE,gBAAgB,EAAE,CAAC,SAAS,EAAE,EAAE,CAC9B,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACZ,IAAI,aAAa,CAAC,KAAK,CAAC,2BAA2B,CAAC,SAAS,CAAC,CAAC,EAAE;YAC/D,OAAO,KAAK,CAAC;SACd;QAED,mBAAmB,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QAEtC,OAAO;YACL,2BAA2B,EAAE;gBAC3B,GAAG,KAAK,CAAC,2BAA2B;gBACpC,CAAC,SAAS,CAAC,EAAE,EAAE;aAChB;SACF,CAAC;IACJ,CAAC,CAAC;CACL,CAAC,CAAC,CAAC"}
|
package/dist/hooks/sui/useSui.js
CHANGED
|
@@ -1,27 +1,82 @@
|
|
|
1
1
|
import { ChainType } from "@0xsquid/squid-types";
|
|
2
2
|
import { useMutation } from "@tanstack/react-query";
|
|
3
|
-
import { useCallback } from "react";
|
|
3
|
+
import { useCallback, useEffect } from "react";
|
|
4
|
+
import { RecentWalletStorage } from "../../services";
|
|
4
5
|
import { useWalletStore } from "../store/useWalletStore";
|
|
5
6
|
import { useSuiWallets } from "./useSuiWallets";
|
|
6
7
|
export function useSui() {
|
|
7
8
|
const { wallets } = useSuiWallets();
|
|
8
9
|
const connectedSuiWallet = useWalletStore((store) => store.connectedWalletsByChainType[ChainType.SUI]);
|
|
10
|
+
const setConnectedWallet = useWalletStore((store) => store.setConnectedWallet);
|
|
11
|
+
const disconnectWallet = useWalletStore((store) => store.disconnectWallet);
|
|
9
12
|
const connectSui = useMutation(async ({ wallet, }) => {
|
|
10
|
-
|
|
13
|
+
let account;
|
|
14
|
+
try {
|
|
15
|
+
// try to connect silently first
|
|
16
|
+
account = await wallet.connector.connect({ silent: true });
|
|
17
|
+
}
|
|
18
|
+
catch {
|
|
19
|
+
// if auto-connect fails (e.g. not authorized yet)
|
|
20
|
+
// fallback to connect via popup
|
|
21
|
+
account = await wallet.connector.connect();
|
|
22
|
+
}
|
|
11
23
|
return {
|
|
12
24
|
wallet,
|
|
13
|
-
address: account.address,
|
|
14
|
-
account,
|
|
25
|
+
address: account.account.address,
|
|
26
|
+
account: account.account,
|
|
15
27
|
};
|
|
16
28
|
});
|
|
17
29
|
const disconnectSui = useCallback(async () => {
|
|
18
|
-
await connectedSuiWallet.wallet?.connector
|
|
30
|
+
await connectedSuiWallet.wallet?.connector.disconnect();
|
|
19
31
|
}, [connectedSuiWallet.wallet]);
|
|
32
|
+
const autoConnectSui = useCallback(async () => {
|
|
33
|
+
const recentSuiWalletId = RecentWalletStorage.get(ChainType.SUI);
|
|
34
|
+
const recentSuiWallet = wallets.find((w) => w.connectorId === recentSuiWalletId);
|
|
35
|
+
if (!recentSuiWallet) {
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
const { account } = await recentSuiWallet.connector.connect({
|
|
39
|
+
silent: true,
|
|
40
|
+
});
|
|
41
|
+
setConnectedWallet(ChainType.SUI, {
|
|
42
|
+
wallet: recentSuiWallet,
|
|
43
|
+
address: account.address,
|
|
44
|
+
account,
|
|
45
|
+
});
|
|
46
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
47
|
+
}, [wallets.map((w) => w.connectorId)]);
|
|
48
|
+
useEffect(() => {
|
|
49
|
+
const wallet = connectedSuiWallet.wallet;
|
|
50
|
+
if (!wallet) {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
function onAccountsChanged({ accounts = [], }) {
|
|
54
|
+
if (!wallet) {
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
const [account] = accounts;
|
|
58
|
+
if (account) {
|
|
59
|
+
setConnectedWallet(ChainType.SUI, {
|
|
60
|
+
wallet: wallet,
|
|
61
|
+
address: account.address,
|
|
62
|
+
account: account,
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
disconnectWallet(ChainType.SUI);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
const removeListener = wallet.connector.on("change", onAccountsChanged);
|
|
70
|
+
return () => {
|
|
71
|
+
removeListener();
|
|
72
|
+
};
|
|
73
|
+
}, [disconnectWallet, setConnectedWallet, connectedSuiWallet.wallet]);
|
|
20
74
|
return {
|
|
21
75
|
connectSui,
|
|
22
76
|
disconnectSui,
|
|
77
|
+
autoConnectSui,
|
|
23
78
|
isConnected: !!connectedSuiWallet.wallet,
|
|
24
|
-
signer: connectedSuiWallet.wallet?.connector
|
|
79
|
+
signer: connectedSuiWallet.wallet?.connector,
|
|
25
80
|
wallets,
|
|
26
81
|
};
|
|
27
82
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useSui.js","sourceRoot":"","sources":["../../../src/hooks/sui/useSui.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;
|
|
1
|
+
{"version":3,"file":"useSui.js","sourceRoot":"","sources":["../../../src/hooks/sui/useSui.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,42 +1,23 @@
|
|
|
1
1
|
import { SlushWallet } from "@mysten/slush-wallet";
|
|
2
|
-
import { getWallets as getWalletsApi, } from "@mysten/wallet-standard";
|
|
3
|
-
import { useCallback, useEffect, useRef, useState } from "react";
|
|
4
2
|
import { filterSuiWallets, slushWebWalletData, } from "../../services/internal/suiService";
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
3
|
+
import { useStandardWallets } from "../wallet/useStandardWallets";
|
|
4
|
+
function getExtraWallets() {
|
|
5
|
+
const slushWebWallet = new SlushWallet({
|
|
6
|
+
name: "Squid",
|
|
7
|
+
chain: "sui:mainnet",
|
|
8
|
+
metadata: {
|
|
9
|
+
enabled: true,
|
|
10
|
+
icon: slushWebWalletData.icon,
|
|
11
|
+
id: slushWebWalletData.id,
|
|
12
|
+
walletName: slushWebWalletData.name,
|
|
13
|
+
},
|
|
14
|
+
});
|
|
15
|
+
return [slushWebWallet];
|
|
16
|
+
}
|
|
8
17
|
export function useSuiWallets() {
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
}, []);
|
|
14
|
-
useEffect(() => {
|
|
15
|
-
const walletsApi = getWalletsApi();
|
|
16
|
-
const removeOnRegisterListener = walletsApi.on("register", (wallet) => {
|
|
17
|
-
setRegisteredWallets([wallet]);
|
|
18
|
-
});
|
|
19
|
-
if (!isInitializedRef.current) {
|
|
20
|
-
const slushWebWallet = new SlushWallet({
|
|
21
|
-
name: "Squid",
|
|
22
|
-
chain: "sui:mainnet",
|
|
23
|
-
metadata: {
|
|
24
|
-
enabled: true,
|
|
25
|
-
icon: slushWebWalletData.icon,
|
|
26
|
-
id: slushWebWalletData.id,
|
|
27
|
-
walletName: slushWebWalletData.name,
|
|
28
|
-
},
|
|
29
|
-
});
|
|
30
|
-
walletsApi.register(slushWebWallet);
|
|
31
|
-
setRegisteredWallets(walletsApi.get());
|
|
32
|
-
isInitializedRef.current = true;
|
|
33
|
-
}
|
|
34
|
-
return () => {
|
|
35
|
-
removeOnRegisterListener();
|
|
36
|
-
};
|
|
37
|
-
}, [setRegisteredWallets]);
|
|
38
|
-
return {
|
|
39
|
-
wallets,
|
|
40
|
-
};
|
|
18
|
+
return useStandardWallets({
|
|
19
|
+
filterWallets: filterSuiWallets,
|
|
20
|
+
getExtraWallets,
|
|
21
|
+
});
|
|
41
22
|
}
|
|
42
23
|
//# sourceMappingURL=useSuiWallets.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useSuiWallets.js","sourceRoot":"","sources":["../../../src/hooks/sui/useSuiWallets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"useSuiWallets.js","sourceRoot":"","sources":["../../../src/hooks/sui/useSuiWallets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAEnD,OAAO,EACL,gBAAgB,EAChB,kBAAkB,GACnB,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAElE,SAAS,eAAe;IACtB,MAAM,cAAc,GAAG,IAAI,WAAW,CAAC;QACrC,IAAI,EAAE,OAAO;QACb,KAAK,EAAE,aAAa;QACpB,QAAQ,EAAE;YACR,OAAO,EAAE,IAAI;YACb,IAAI,EAAE,kBAAkB,CAAC,IAAI;YAC7B,EAAE,EAAE,kBAAkB,CAAC,EAAE;YACzB,UAAU,EAAE,kBAAkB,CAAC,IAAI;SACpC;KACF,CAAC,CAAC;IAEH,OAAO,CAAC,cAAc,CAAC,CAAC;AAC1B,CAAC;AAED,MAAM,UAAU,aAAa;IAG3B,OAAO,kBAAkB,CAAY;QACnC,aAAa,EAAE,gBAAgB;QAC/B,eAAe;KAChB,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -8,15 +8,17 @@ import { useHistoryStore } from "../../../hooks/store/useHistoryStore";
|
|
|
8
8
|
import { useSendTransactionStore, } from "../../../hooks/store/useSendTransactionStore";
|
|
9
9
|
import { useNativeTokenForChain } from "../../../hooks/tokens/useNativeTokenForChain";
|
|
10
10
|
import { useMultiChainWallet } from "../../../hooks/wallet/useMultiChainWallet";
|
|
11
|
+
import { useWallet } from "../../../hooks/wallet/useWallet";
|
|
11
12
|
import { isWalletAddressValid, parseToBigInt, WidgetEvents, } from "../../../services";
|
|
12
13
|
import { getWorkingCosmosRpcUrl } from "../../../services/external/rpcService";
|
|
13
14
|
import { getTransactionError } from "../../../services/internal/errorService";
|
|
14
|
-
import { sendTransactionBitcoin, sendTransactionCosmos, sendTransactionEvm, sendTransactionSolana, } from "../../../services/internal/sendTransaction";
|
|
15
|
+
import { sendTransactionBitcoin, sendTransactionCosmos, sendTransactionEvm, sendTransactionSolana, sendTransactionSui, } from "../../../services/internal/sendTransaction";
|
|
15
16
|
import { useSolanaConnection } from "../../solana/useSolana";
|
|
16
17
|
import { useSigner } from "../../wallet/useSigner";
|
|
17
18
|
export function useSendTransaction({ to, amount, token, chain, }) {
|
|
19
|
+
const { connectedWalletsByChainType } = useWallet();
|
|
18
20
|
const { connectedAddress } = useMultiChainWallet(chain);
|
|
19
|
-
const { evmSigner, cosmosSigner, solanaSigner, bitcoinSigner, isSignerReady, } = useSigner({
|
|
21
|
+
const { evmSigner, cosmosSigner, solanaSigner, bitcoinSigner, suiSigner, isSignerReady, } = useSigner({
|
|
20
22
|
chain,
|
|
21
23
|
});
|
|
22
24
|
const solanaClient = useSolanaConnection();
|
|
@@ -144,8 +146,23 @@ export function useSendTransaction({ to, amount, token, chain, }) {
|
|
|
144
146
|
signer: bitcoinSigner,
|
|
145
147
|
});
|
|
146
148
|
break;
|
|
147
|
-
|
|
148
|
-
|
|
149
|
+
case ChainType.SUI:
|
|
150
|
+
if (!suiSigner) {
|
|
151
|
+
throw new Error("Need Sui signer");
|
|
152
|
+
}
|
|
153
|
+
const suiAccount = connectedWalletsByChainType[ChainType.SUI];
|
|
154
|
+
if (!suiAccount.account) {
|
|
155
|
+
throw new Error("Need Sui account");
|
|
156
|
+
}
|
|
157
|
+
tx = await sendTransactionSui({
|
|
158
|
+
amount: rawAmount,
|
|
159
|
+
to,
|
|
160
|
+
token,
|
|
161
|
+
chain,
|
|
162
|
+
account: suiAccount.account,
|
|
163
|
+
signer: suiSigner,
|
|
164
|
+
});
|
|
165
|
+
break;
|
|
149
166
|
}
|
|
150
167
|
return {
|
|
151
168
|
amount,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useSendTransaction.js","sourceRoot":"","sources":["../../../../src/hooks/transaction/send/useSendTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,SAAS,EAAS,MAAM,sBAAsB,CAAC;AACnE,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACpE,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACpC,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,oCAAoC,CAAC;AAC7E,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAC5D,OAAO,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AACxE,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAEL,uBAAuB,GACxB,MAAM,8CAA8C,CAAC;AACtD,OAAO,EAAE,sBAAsB,EAAE,MAAM,8CAA8C,CAAC;AACtF,OAAO,EAAE,mBAAmB,EAAE,MAAM,2CAA2C,CAAC;AAChF,OAAO,EACL,oBAAoB,EACpB,aAAa,EACb,YAAY,GACb,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,sBAAsB,EAAE,MAAM,uCAAuC,CAAC;AAC/E,OAAO,EAAE,mBAAmB,EAAE,MAAM,yCAAyC,CAAC;AAC9E,OAAO,EACL,sBAAsB,EACtB,qBAAqB,EACrB,kBAAkB,EAElB,qBAAqB,
|
|
1
|
+
{"version":3,"file":"useSendTransaction.js","sourceRoot":"","sources":["../../../../src/hooks/transaction/send/useSendTransaction.ts"],"names":[],"mappings":"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"}
|
|
@@ -12,6 +12,7 @@ import { TransactionStatus } from "../../core/types/transaction";
|
|
|
12
12
|
import { getWorkingCosmosRpcUrl } from "../../services/external/rpcService";
|
|
13
13
|
import { getSourceExplorerTxUrl, isDepositRoute, sleep, } from "../../services/internal/transactionService";
|
|
14
14
|
import { InjectiveSigningStargateClient } from "@injectivelabs/sdk-ts/dist/cjs/core/stargate";
|
|
15
|
+
import { getClient } from "../../core/client";
|
|
15
16
|
import { CHAIN_IDS } from "../../core/constants";
|
|
16
17
|
import { executeSolanaSwap, executeSolanaTransfer, getCosmosSigningClient, getTransactionError, handleTransactionErrorEvents, isProblematicConnector, isUserRejectionError, normalizeError, } from "../../services";
|
|
17
18
|
import { WidgetEvents } from "../../services/internal/eventService";
|
|
@@ -20,7 +21,6 @@ import { useSquidChains } from "../chains/useSquidChains";
|
|
|
20
21
|
import { useSolanaConnection } from "../solana/useSolana";
|
|
21
22
|
import { useDepositAddressStore } from "../store/useDepositAddressStore";
|
|
22
23
|
import { useSquidStore, useTransactionStore } from "../store/useSquidStore";
|
|
23
|
-
import { useSuiClient } from "../sui/useSuiClient";
|
|
24
24
|
import { useSwap } from "../swap/useSwap";
|
|
25
25
|
import { useSquidTokens } from "../tokens/useSquidTokens";
|
|
26
26
|
import { useHistory } from "../user/useHistory";
|
|
@@ -42,7 +42,6 @@ export const useExecuteTransaction = (squidRoute) => {
|
|
|
42
42
|
const getTransaction = useTransactionStore((state) => state.getTransaction);
|
|
43
43
|
const setTransactionStoreState = useTransactionStore((state) => state.setTransactionState);
|
|
44
44
|
const { connector: activeConnector } = useAccount();
|
|
45
|
-
const { client: suiClient } = useSuiClient({ chain: fromChain });
|
|
46
45
|
const { getGnosisTransactionHash } = useGnosisContext();
|
|
47
46
|
const { addSwapTransaction, replaceSwapTransactionNonce, replaceSwapTransactionStatus, } = useHistory();
|
|
48
47
|
const { connectedAddress: { address: sourceUserAddress }, changeNetworkIfNeeded, } = useMultiChainWallet(fromChain);
|
|
@@ -448,7 +447,7 @@ export const useExecuteTransaction = (squidRoute) => {
|
|
|
448
447
|
}
|
|
449
448
|
});
|
|
450
449
|
const swapQuerySui = useMutation(async ({ id, route }) => {
|
|
451
|
-
if (!route || !suiSigner || !
|
|
450
|
+
if (!route || !suiSigner || !fromChain) {
|
|
452
451
|
throw new Error("Need all parameters");
|
|
453
452
|
}
|
|
454
453
|
if (route.transactionRequest?.type !== SquidDataType.OnChainExecution) {
|
|
@@ -463,6 +462,7 @@ export const useExecuteTransaction = (squidRoute) => {
|
|
|
463
462
|
if (!suiChain) {
|
|
464
463
|
throw new Error(`Source chain (${fromChainId}) does not match any Sui chain`);
|
|
465
464
|
}
|
|
465
|
+
const suiClient = await getClient(fromChain);
|
|
466
466
|
const txJson = route.transactionRequest.data;
|
|
467
467
|
const tx = Transaction.from(txJson);
|
|
468
468
|
const signedTx = await suiSigner.signTransaction({
|