@0xsquid/react-hooks 7.1.1-xrpl-beta.1 → 7.1.1
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/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/connectors/xrpl/XamanQr.js +21 -6
- package/dist/core/connectors/xrpl/XamanQr.js.map +1 -1
- package/dist/core/connectors/xrpl/XrplMetamaskSnap.js +0 -1
- package/dist/core/connectors/xrpl/XrplMetamaskSnap.js.map +1 -1
- package/dist/core/constants.d.ts +3 -2
- package/dist/core/constants.js +4 -7
- package/dist/core/constants.js.map +1 -1
- package/dist/core/multicall3.js +1 -1
- package/dist/core/multicall3.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/error.d.ts +3 -0
- package/dist/core/types/error.js +6 -0
- package/dist/core/types/error.js.map +1 -1
- package/dist/core/types/event.d.ts +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 +35 -32
- 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 +22 -346
- 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/evm/useEvm.d.ts +2 -0
- package/dist/hooks/evm/useEvm.js +77 -0
- package/dist/hooks/evm/useEvm.js.map +1 -0
- package/dist/hooks/evm/useEvmWallets.d.ts +4 -0
- package/dist/hooks/evm/useEvmWallets.js +13 -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 +60 -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/useSendTransactionStore.js.map +1 -1
- package/dist/hooks/store/useSquidStore.d.ts +1 -1
- package/dist/hooks/store/useSquidStore.js +8 -10
- package/dist/hooks/store/useSquidStore.js.map +1 -1
- package/dist/hooks/store/useWalletStore.d.ts +21 -4
- package/dist/hooks/store/useWalletStore.js +21 -2
- package/dist/hooks/store/useWalletStore.js.map +1 -1
- package/dist/hooks/sui/useSui.js +60 -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/useExecuteTransaction.js +4 -1
- package/dist/hooks/transaction/useExecuteTransaction.js.map +1 -1
- package/dist/hooks/wallet/useAutoConnect.js +13 -9
- package/dist/hooks/wallet/useAutoConnect.js.map +1 -1
- package/dist/hooks/wallet/useMultiChainWallet.d.ts +241 -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 +248 -39
- package/dist/hooks/wallet/useWallet.js +18 -56
- package/dist/hooks/wallet/useWallet.js.map +1 -1
- package/dist/hooks/wallet/useWallets.d.ts +1 -31
- package/dist/hooks/wallet/useWallets.js +16 -21
- package/dist/hooks/wallet/useWallets.js.map +1 -1
- package/dist/hooks/xrpl/useXrplTrustLine.js +4 -3
- package/dist/hooks/xrpl/useXrplTrustLine.js.map +1 -1
- package/dist/hooks/xrpl/useXrplWallets.d.ts +41 -2
- package/dist/provider/index.js +8 -4
- package/dist/provider/index.js.map +1 -1
- package/dist/services/external/onrampAdapter.js +2 -1
- package/dist/services/external/onrampAdapter.js.map +1 -1
- package/dist/services/internal/assetsService.js +0 -5
- package/dist/services/internal/assetsService.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/eventService.d.ts +5 -0
- package/dist/services/internal/eventService.js +7 -0
- package/dist/services/internal/eventService.js.map +1 -1
- package/dist/services/internal/evmService.d.ts +8 -7
- package/dist/services/internal/evmService.js +36 -12
- package/dist/services/internal/evmService.js.map +1 -1
- package/dist/services/internal/fiatToCryptoService.js +2 -2
- package/dist/services/internal/fiatToCryptoService.js.map +1 -1
- package/dist/services/internal/sendTransaction.d.ts +3 -3
- package/dist/services/internal/sendTransaction.js.map +1 -1
- package/dist/services/internal/solanaService.d.ts +7 -7
- package/dist/services/internal/solanaService.js +42 -9
- 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/transactionService.js +1 -1
- package/dist/services/internal/transactionService.js.map +1 -1
- package/dist/services/internal/walletService.d.ts +12 -22
- package/dist/services/internal/walletService.js +109 -54
- package/dist/services/internal/walletService.js.map +1 -1
- package/dist/services/internal/walletStandardService.d.ts +24 -0
- package/dist/services/internal/walletStandardService.js +133 -0
- package/dist/services/internal/walletStandardService.js.map +1 -0
- package/dist/services/internal/xrplService.js +2 -0
- package/dist/services/internal/xrplService.js.map +1 -1
- package/dist/tests/walletService.test.js +228 -4
- package/dist/tests/walletService.test.js.map +1 -1
- package/package.json +4 -4
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { ChainType } from "@0xsquid/squid-types";
|
|
2
|
+
import { useMutation } from "@tanstack/react-query";
|
|
3
|
+
import { useCallback, useEffect } from "react";
|
|
4
|
+
import { useAccount, useConnect, useDisconnect } from "wagmi";
|
|
5
|
+
import { useWalletStore } from "../store/useWalletStore";
|
|
6
|
+
import { useEvmWallets } from "./useEvmWallets";
|
|
7
|
+
export function useEvm() {
|
|
8
|
+
const disconnectWallet = useWalletStore((store) => store.disconnectWallet);
|
|
9
|
+
const setConnectedWallet = useWalletStore((store) => store.setConnectedWallet);
|
|
10
|
+
const { connectAsync } = useConnect();
|
|
11
|
+
const { disconnect } = useDisconnect();
|
|
12
|
+
const { address, connector } = useAccount();
|
|
13
|
+
const { wallets } = useEvmWallets();
|
|
14
|
+
const connectedEvmWallet = useWalletStore((store) => store.connectedWalletsByChainType[ChainType.EVM]);
|
|
15
|
+
const recentEvmWalletId = useWalletStore((store) => store.recentConnectorIds[ChainType.EVM]);
|
|
16
|
+
const connectEvm = useMutation(async ({ wallet, }) => {
|
|
17
|
+
const result = await connectAsync({
|
|
18
|
+
connector: wallet.connector,
|
|
19
|
+
});
|
|
20
|
+
const [firstAddress] = result.accounts;
|
|
21
|
+
return {
|
|
22
|
+
wallet,
|
|
23
|
+
address: firstAddress,
|
|
24
|
+
};
|
|
25
|
+
});
|
|
26
|
+
const disconnectEvm = useCallback(async () => {
|
|
27
|
+
disconnect({ connector: connectedEvmWallet.wallet?.connector });
|
|
28
|
+
}, [connectedEvmWallet.wallet?.connector, disconnect]);
|
|
29
|
+
const autoConnectEvm = useCallback(async () => {
|
|
30
|
+
const recentEvmWallet = wallets.find((w) => w.connectorId === recentEvmWalletId);
|
|
31
|
+
if (!recentEvmWallet) {
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
const isAuthorized = await recentEvmWallet.connector.isAuthorized();
|
|
35
|
+
if (!isAuthorized)
|
|
36
|
+
return;
|
|
37
|
+
const data = await recentEvmWallet.connector
|
|
38
|
+
.connect({ isReconnecting: true })
|
|
39
|
+
.catch(() => null);
|
|
40
|
+
if (!data)
|
|
41
|
+
return;
|
|
42
|
+
const [firstAddress] = data.accounts;
|
|
43
|
+
setConnectedWallet(ChainType.EVM, {
|
|
44
|
+
wallet: recentEvmWallet,
|
|
45
|
+
address: firstAddress,
|
|
46
|
+
});
|
|
47
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
48
|
+
}, [
|
|
49
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
50
|
+
wallets.map((w) => w.connectorId),
|
|
51
|
+
recentEvmWalletId,
|
|
52
|
+
setConnectedWallet,
|
|
53
|
+
]);
|
|
54
|
+
useEffect(() => {
|
|
55
|
+
if (!connector?.id || !address) {
|
|
56
|
+
disconnectWallet(ChainType.EVM);
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
const connectedWallet = wallets.find((w) => w.rdns === connector.id);
|
|
60
|
+
if (!connectedWallet)
|
|
61
|
+
return;
|
|
62
|
+
setConnectedWallet(ChainType.EVM, {
|
|
63
|
+
wallet: connectedWallet,
|
|
64
|
+
address,
|
|
65
|
+
});
|
|
66
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
67
|
+
}, [address, connector?.id, disconnectWallet, setConnectedWallet]);
|
|
68
|
+
return {
|
|
69
|
+
connectEvm,
|
|
70
|
+
disconnectEvm,
|
|
71
|
+
autoConnectEvm,
|
|
72
|
+
isConnected: !!connectedEvmWallet.wallet,
|
|
73
|
+
signer: connectedEvmWallet.wallet?.connector,
|
|
74
|
+
wallets,
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
//# sourceMappingURL=useEvm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useEvm.js","sourceRoot":"","sources":["../../../src/hooks/evm/useEvm.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { useMemo } from "react";
|
|
2
|
+
import { useConnectors } from "wagmi";
|
|
3
|
+
import { filterWagmiConnector, formatEvmWallet, } from "../../services/internal/evmService";
|
|
4
|
+
export function useEvmWallets() {
|
|
5
|
+
const connectors = useConnectors();
|
|
6
|
+
const wallets = useMemo(() => {
|
|
7
|
+
return connectors.filter(filterWagmiConnector).map(formatEvmWallet);
|
|
8
|
+
}, [connectors]);
|
|
9
|
+
return {
|
|
10
|
+
wallets,
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=useEvmWallets.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useEvmWallets.js","sourceRoot":"","sources":["../../../src/hooks/evm/useEvmWallets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAChC,OAAO,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAEtC,OAAO,EACL,oBAAoB,EACpB,eAAe,GAChB,MAAM,oCAAoC,CAAC;AAE5C,MAAM,UAAU,aAAa;IAG3B,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IAEnC,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,EAAE;QAC3B,OAAO,UAAU,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;IACtE,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;IAEjB,OAAO;QACL,OAAO;KACR,CAAC;AACJ,CAAC"}
|
|
@@ -1,11 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { Connection, PublicKey } from "@solana/web3.js";
|
|
1
|
+
import { Connection } from "@solana/web3.js";
|
|
3
2
|
import { ISolanaContextData } from "../../core/providers/SolanaProvider";
|
|
4
|
-
export
|
|
5
|
-
connect(publicKey: PublicKey): void;
|
|
6
|
-
disconnect(): void;
|
|
7
|
-
accountChanged(publicKey: PublicKey | null): void;
|
|
8
|
-
}
|
|
9
|
-
export type SolanaWalletAdapter = Adapter;
|
|
10
|
-
export declare const useSolana: () => ISolanaContextData;
|
|
3
|
+
export declare function useSolana(): ISolanaContextData;
|
|
11
4
|
export declare const useSolanaConnection: () => Connection;
|
|
@@ -1,104 +1,80 @@
|
|
|
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 { getWalletWindowProvider } from "../../services/internal/walletService";
|
|
8
|
-
import { useClient } from "../client/useClient";
|
|
9
6
|
import { useWalletStore } from "../store/useWalletStore";
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
const
|
|
13
|
-
const
|
|
14
|
-
const
|
|
15
|
-
const
|
|
16
|
-
const
|
|
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]);
|
|
7
|
+
import { useSolanaWallets } from "./useSolanaWallets";
|
|
8
|
+
export function useSolana() {
|
|
9
|
+
const disconnectWallet = useWalletStore((store) => store.disconnectWallet);
|
|
10
|
+
const setConnectedWallet = useWalletStore((store) => store.setConnectedWallet);
|
|
11
|
+
const { wallets } = useSolanaWallets();
|
|
12
|
+
const connectedSolanaWallet = useWalletStore((store) => store.connectedWalletsByChainType[ChainType.SOLANA]);
|
|
13
|
+
const recentSolanaWalletId = useWalletStore((store) => store.recentConnectorIds[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
|
-
// Inconsistent behavior on different wallets
|
|
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 recentSolanaWallet = wallets.find((w) => w.connectorId === recentSolanaWalletId);
|
|
35
|
+
if (!recentSolanaWallet) {
|
|
36
|
+
return;
|
|
67
37
|
}
|
|
68
|
-
|
|
69
|
-
|
|
38
|
+
await recentSolanaWallet.connector.autoConnect();
|
|
39
|
+
const [account] = recentSolanaWallet.connector.wallet.accounts;
|
|
40
|
+
setConnectedWallet(ChainType.SOLANA, {
|
|
41
|
+
wallet: recentSolanaWallet,
|
|
42
|
+
address: account.address,
|
|
43
|
+
});
|
|
44
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
45
|
+
}, [wallets.map((w) => w.connectorId), recentSolanaWalletId]);
|
|
70
46
|
useEffect(() => {
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
return
|
|
74
|
-
solanaWalletObject.off("connect", handleAccountChange);
|
|
75
|
-
};
|
|
47
|
+
const wallet = connectedSolanaWallet.wallet;
|
|
48
|
+
if (!wallet) {
|
|
49
|
+
return;
|
|
76
50
|
}
|
|
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);
|
|
51
|
+
function onConnect(newAddress) {
|
|
52
|
+
if (wallet) {
|
|
53
|
+
setConnectedWallet(ChainType.SOLANA, {
|
|
54
|
+
wallet,
|
|
55
|
+
address: newAddress.toString(),
|
|
56
|
+
});
|
|
87
57
|
}
|
|
88
|
-
return phantomAdapter;
|
|
89
58
|
}
|
|
90
|
-
|
|
91
|
-
|
|
59
|
+
function onDisconnect() {
|
|
60
|
+
disconnectWallet(ChainType.SOLANA);
|
|
61
|
+
}
|
|
62
|
+
wallet.connector.on("connect", onConnect);
|
|
63
|
+
wallet.connector.on("disconnect", onDisconnect);
|
|
64
|
+
return () => {
|
|
65
|
+
wallet.connector.off("connect", onConnect);
|
|
66
|
+
wallet.connector.off("disconnect", onDisconnect);
|
|
67
|
+
};
|
|
68
|
+
}, [disconnectWallet, setConnectedWallet, connectedSolanaWallet.wallet]);
|
|
92
69
|
return {
|
|
93
70
|
connectSolana,
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
wallet: solanaConnectedWallet,
|
|
71
|
+
disconnectSolana,
|
|
72
|
+
autoConnectSolana,
|
|
73
|
+
isConnected: !!connectedSolanaWallet.wallet,
|
|
74
|
+
signer: connectedSolanaWallet.wallet?.connector,
|
|
75
|
+
wallets,
|
|
100
76
|
};
|
|
101
|
-
}
|
|
77
|
+
}
|
|
102
78
|
export const useSolanaConnection = () => {
|
|
103
79
|
const connectionRef = useRef(new Connection(SOLANA_RPC_URL));
|
|
104
80
|
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 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useSendTransactionStore.js","sourceRoot":"","sources":["../../../src/hooks/store/useSendTransactionStore.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"useSendTransactionStore.js","sourceRoot":"","sources":["../../../src/hooks/store/useSendTransactionStore.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAyBjC,MAAM,CAAC,MAAM,uBAAuB,GAAG,MAAM,CAC3C,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;IACb,SAAS,EAAE,SAAS;IACpB,YAAY,EAAE,EAAE;IAChB,kBAAkB,EAAE,SAAS;IAC7B,mBAAmB,CAAC,IAAI,EAAE,EAAE;QAC1B,IAAI,CAAC,IAAI;YAAE,OAAO;QAElB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YACZ,MAAM,eAAe,GAAG,EAAE,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC;YAE9D,OAAO;gBACL,YAAY,EAAE,eAAe;gBAC7B,kBAAkB,EAChB,IAAI,KAAK,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,kBAAkB;aAC3D,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IACD,cAAc,CAAC,EAAE;QACf,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC;CACF,CAAC,CACH,CAAC"}
|
|
@@ -24,8 +24,8 @@ interface TransactionState {
|
|
|
24
24
|
fromPrice?: string;
|
|
25
25
|
txLocalId?: string;
|
|
26
26
|
transactions: Record<string, TransactionParams>;
|
|
27
|
+
currentTransaction?: TransactionParams;
|
|
27
28
|
setTransactionState: (id: string | undefined, transaction: TransactionParams) => void;
|
|
28
|
-
getCurrentTransaction: () => TransactionParams | undefined;
|
|
29
29
|
getTransaction: (id: string) => TransactionParams | undefined;
|
|
30
30
|
}
|
|
31
31
|
export declare const useTransactionStore: import("zustand").UseBoundStore<import("zustand").StoreApi<TransactionState>>;
|
|
@@ -16,20 +16,18 @@ export const useTransactionStore = create((set, get) => ({
|
|
|
16
16
|
fromPrice: undefined,
|
|
17
17
|
txLocalId: undefined,
|
|
18
18
|
transactions: {},
|
|
19
|
+
currentTransaction: undefined,
|
|
19
20
|
setTransactionState(txId, tx) {
|
|
21
|
+
if (!txId)
|
|
22
|
+
return;
|
|
20
23
|
set((state) => {
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
24
|
+
const newTransactions = { ...state.transactions, [txId]: tx };
|
|
25
|
+
return {
|
|
26
|
+
transactions: newTransactions,
|
|
27
|
+
currentTransaction: txId === state.txLocalId ? tx : state.currentTransaction,
|
|
28
|
+
};
|
|
25
29
|
});
|
|
26
30
|
},
|
|
27
|
-
getCurrentTransaction() {
|
|
28
|
-
const { txLocalId, transactions } = get();
|
|
29
|
-
if (!txLocalId)
|
|
30
|
-
return;
|
|
31
|
-
return transactions[txLocalId];
|
|
32
|
-
},
|
|
33
31
|
getTransaction(id) {
|
|
34
32
|
return get().transactions[id];
|
|
35
33
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useSquidStore.js","sourceRoot":"","sources":["../../../src/hooks/store/useSquidStore.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AACjC,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAsB3D,MAAM,CAAC,MAAM,aAAa,GAAG,MAAM,CAAa,GAAG,EAAE,CAAC,CAAC;IACrD,KAAK,EAAE,SAAS;IAChB,eAAe,EAAE;QACf,MAAM,EAAE,KAAK;QACb,OAAO,EAAE,SAAS;KACnB;CACF,CAAC,CAAC,CAAC;AAUJ,MAAM,CAAC,MAAM,cAAc,GAAG,MAAM,CAAc,GAAG,EAAE,CAAC,CAAC;IACvD,MAAM,EAAE,mBAAmB;IAC3B,aAAa,EAAE,KAAK;CACrB,CAAC,CAAC,CAAC;AAiBJ,MAAM,CAAC,MAAM,mBAAmB,GAAG,MAAM,CAAmB,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;IACzE,SAAS,EAAE,SAAS;IACpB,SAAS,EAAE,SAAS;IACpB,YAAY,EAAE,EAAE;IAChB,mBAAmB,CAAC,IAAI,EAAE,EAAE;QAC1B,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YACZ,
|
|
1
|
+
{"version":3,"file":"useSquidStore.js","sourceRoot":"","sources":["../../../src/hooks/store/useSquidStore.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AACjC,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAsB3D,MAAM,CAAC,MAAM,aAAa,GAAG,MAAM,CAAa,GAAG,EAAE,CAAC,CAAC;IACrD,KAAK,EAAE,SAAS;IAChB,eAAe,EAAE;QACf,MAAM,EAAE,KAAK;QACb,OAAO,EAAE,SAAS;KACnB;CACF,CAAC,CAAC,CAAC;AAUJ,MAAM,CAAC,MAAM,cAAc,GAAG,MAAM,CAAc,GAAG,EAAE,CAAC,CAAC;IACvD,MAAM,EAAE,mBAAmB;IAC3B,aAAa,EAAE,KAAK;CACrB,CAAC,CAAC,CAAC;AAiBJ,MAAM,CAAC,MAAM,mBAAmB,GAAG,MAAM,CAAmB,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;IACzE,SAAS,EAAE,SAAS;IACpB,SAAS,EAAE,SAAS;IACpB,YAAY,EAAE,EAAE;IAChB,kBAAkB,EAAE,SAAS;IAC7B,mBAAmB,CAAC,IAAI,EAAE,EAAE;QAC1B,IAAI,CAAC,IAAI;YAAE,OAAO;QAElB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YACZ,MAAM,eAAe,GAAG,EAAE,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC;YAE9D,OAAO;gBACL,YAAY,EAAE,eAAe;gBAC7B,kBAAkB,EAChB,IAAI,KAAK,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,kBAAkB;aAC3D,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IACD,cAAc,CAAC,EAAE;QACf,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC;CACF,CAAC,CAAC,CAAC;AAOJ,MAAM,CAAC,MAAM,wBAAwB,GAAG,MAAM,EAAyB,CACrE,OAAO,CACL,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IACR,SAAS,EAAE,SAAS;IACpB,cAAc,EAAE,GAAG,EAAE,CACnB,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACd,SAAS,EAAE,KAAK,CAAC,SAAS;YACxB,CAAC,CAAC;gBACE,GAAG,KAAK,CAAC,SAAS;gBAClB,kBAAkB,EAAE,SAAS;gBAC7B,eAAe,EAAE,SAAS;aAC3B;YACH,CAAC,CAAC,SAAS;KACd,CAAC,CAAC;CACN,CAAC,EACF;IACE,IAAI,EAAE,wBAAwB;IAC9B,kBAAkB,EAAE,GAAG,EAAE,CAAC,CAAC,KAAK,EAAE,EAAE;QAClC,2CAA2C;QAC3C,KAAK,EAAE,cAAc,EAAE,CAAC;IAC1B,CAAC;CACF,CACF,CACF,CAAC"}
|
|
@@ -4,7 +4,8 @@ import { ChainTypeToWalletState } from "../../core/types/wallet";
|
|
|
4
4
|
export declare enum ConnectingWalletStatus {
|
|
5
5
|
IDLE = 0,
|
|
6
6
|
CONNECTING = 1,
|
|
7
|
-
REJECTED = 2
|
|
7
|
+
REJECTED = 2,
|
|
8
|
+
QR_GENERATION_FAILED = 3
|
|
8
9
|
}
|
|
9
10
|
export interface ConnectingWalletState {
|
|
10
11
|
wallet: Wallet | undefined;
|
|
@@ -13,15 +14,31 @@ export interface ConnectingWalletState {
|
|
|
13
14
|
matrix: boolean[][];
|
|
14
15
|
};
|
|
15
16
|
}
|
|
16
|
-
interface
|
|
17
|
+
interface WalletStoreState {
|
|
17
18
|
connectedWalletsByChainType: {
|
|
18
19
|
[K in keyof ChainTypeToWalletState]: Partial<ChainTypeToWalletState[K]>;
|
|
19
20
|
};
|
|
20
21
|
connectingWalletState: ConnectingWalletState;
|
|
22
|
+
recentConnectorIds: Partial<Record<ChainType, string>>;
|
|
21
23
|
}
|
|
22
|
-
|
|
24
|
+
type WalletStoreActions = {
|
|
23
25
|
setConnectedWallet: <T extends ChainType>(chainType: ChainType, state: ChainTypeToWalletState[T]) => void;
|
|
24
26
|
setConnectingWallet: (state: ConnectingWalletState) => void;
|
|
25
27
|
disconnectWallet: (chainType: ChainType) => void;
|
|
26
|
-
}
|
|
28
|
+
};
|
|
29
|
+
export declare const useWalletStore: import("zustand").UseBoundStore<Omit<import("zustand").StoreApi<WalletStoreState & WalletStoreActions>, "persist"> & {
|
|
30
|
+
persist: {
|
|
31
|
+
setOptions: (options: Partial<import("zustand/middleware").PersistOptions<WalletStoreState & WalletStoreActions, {
|
|
32
|
+
recentConnectorIds: Partial<Record<ChainType, string>>;
|
|
33
|
+
}>>) => void;
|
|
34
|
+
clearStorage: () => void;
|
|
35
|
+
rehydrate: () => void | Promise<void>;
|
|
36
|
+
hasHydrated: () => boolean;
|
|
37
|
+
onHydrate: (fn: (state: WalletStoreState & WalletStoreActions) => void) => () => void;
|
|
38
|
+
onFinishHydration: (fn: (state: WalletStoreState & WalletStoreActions) => void) => () => void;
|
|
39
|
+
getOptions: () => Partial<import("zustand/middleware").PersistOptions<WalletStoreState & WalletStoreActions, {
|
|
40
|
+
recentConnectorIds: Partial<Record<ChainType, string>>;
|
|
41
|
+
}>>;
|
|
42
|
+
};
|
|
43
|
+
}>;
|
|
27
44
|
export {};
|
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
import { ChainType } from "@0xsquid/squid-types";
|
|
2
2
|
import { create } from "zustand";
|
|
3
|
+
import { persist } from "zustand/middleware";
|
|
4
|
+
import { isEmptyObject } from "../../services";
|
|
3
5
|
export var ConnectingWalletStatus;
|
|
4
6
|
(function (ConnectingWalletStatus) {
|
|
5
7
|
ConnectingWalletStatus[ConnectingWalletStatus["IDLE"] = 0] = "IDLE";
|
|
6
8
|
ConnectingWalletStatus[ConnectingWalletStatus["CONNECTING"] = 1] = "CONNECTING";
|
|
7
9
|
ConnectingWalletStatus[ConnectingWalletStatus["REJECTED"] = 2] = "REJECTED";
|
|
10
|
+
ConnectingWalletStatus[ConnectingWalletStatus["QR_GENERATION_FAILED"] = 3] = "QR_GENERATION_FAILED";
|
|
8
11
|
})(ConnectingWalletStatus || (ConnectingWalletStatus = {}));
|
|
9
12
|
const initialWalletState = {
|
|
10
13
|
// Initialize all chain types to an empty wallet object
|
|
@@ -16,8 +19,9 @@ const initialWalletState = {
|
|
|
16
19
|
wallet: undefined,
|
|
17
20
|
status: ConnectingWalletStatus.IDLE,
|
|
18
21
|
},
|
|
22
|
+
recentConnectorIds: {},
|
|
19
23
|
};
|
|
20
|
-
export const useWalletStore = create((set) => ({
|
|
24
|
+
export const useWalletStore = create()(persist((set) => ({
|
|
21
25
|
...initialWalletState,
|
|
22
26
|
setConnectedWallet: (chainType, connectedWalletState) => set((state) => {
|
|
23
27
|
return {
|
|
@@ -25,18 +29,33 @@ export const useWalletStore = create((set) => ({
|
|
|
25
29
|
...state.connectedWalletsByChainType,
|
|
26
30
|
[chainType]: connectedWalletState,
|
|
27
31
|
},
|
|
32
|
+
recentConnectorIds: {
|
|
33
|
+
...state.recentConnectorIds,
|
|
34
|
+
[chainType]: connectedWalletState.wallet.connectorId,
|
|
35
|
+
},
|
|
28
36
|
};
|
|
29
37
|
}),
|
|
30
38
|
setConnectingWallet: (state) => set({ connectingWalletState: state }),
|
|
31
39
|
disconnectWallet: (chainType) => set((state) => {
|
|
32
|
-
if (
|
|
40
|
+
if (isEmptyObject(state.connectedWalletsByChainType[chainType])) {
|
|
33
41
|
return state;
|
|
42
|
+
}
|
|
43
|
+
const { [chainType]: _, ...recentConnectorIds } = state.recentConnectorIds;
|
|
34
44
|
return {
|
|
35
45
|
connectedWalletsByChainType: {
|
|
36
46
|
...state.connectedWalletsByChainType,
|
|
37
47
|
[chainType]: {},
|
|
38
48
|
},
|
|
49
|
+
recentConnectorIds,
|
|
39
50
|
};
|
|
40
51
|
}),
|
|
52
|
+
}), {
|
|
53
|
+
name: "squid.wallet.store",
|
|
54
|
+
version: 0,
|
|
55
|
+
partialize({ recentConnectorIds }) {
|
|
56
|
+
return {
|
|
57
|
+
recentConnectorIds,
|
|
58
|
+
};
|
|
59
|
+
},
|
|
41
60
|
}));
|
|
42
61
|
//# sourceMappingURL=useWalletStore.js.map
|
|
@@ -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;AACjC,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAG7C,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAE/C,MAAM,CAAN,IAAY,sBAKX;AALD,WAAY,sBAAsB;IAChC,mEAAI,CAAA;IACJ,+EAAU,CAAA;IACV,2EAAQ,CAAA;IACR,mGAAoB,CAAA;AACtB,CAAC,EALW,sBAAsB,KAAtB,sBAAsB,QAKjC;AA2BD,MAAM,kBAAkB,GAAqB;IAC3C,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,EAAqD,CACtD;IACD,qBAAqB,EAAE;QACrB,MAAM,EAAE,SAAS;QACjB,MAAM,EAAE,sBAAsB,CAAC,IAAI;KACpC;IACD,kBAAkB,EAAE,EAAE;CACvB,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAG,MAAM,EAAyC,CAC3E,OAAO,CACL,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IACR,GAAG,kBAAkB;IACrB,kBAAkB,EAAE,CAAC,SAAS,EAAE,oBAAoB,EAAE,EAAE,CACtD,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACZ,OAAO;YACL,2BAA2B,EAAE;gBAC3B,GAAG,KAAK,CAAC,2BAA2B;gBACpC,CAAC,SAAS,CAAC,EAAE,oBAAoB;aAClC;YACD,kBAAkB,EAAE;gBAClB,GAAG,KAAK,CAAC,kBAAkB;gBAC3B,CAAC,SAAS,CAAC,EAAE,oBAAoB,CAAC,MAAM,CAAC,WAAW;aACrD;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,MAAM,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,GAAG,kBAAkB,EAAE,GAC7C,KAAK,CAAC,kBAAkB,CAAC;QAE3B,OAAO;YACL,2BAA2B,EAAE;gBAC3B,GAAG,KAAK,CAAC,2BAA2B;gBACpC,CAAC,SAAS,CAAC,EAAE,EAAE;aAChB;YACD,kBAAkB;SACnB,CAAC;IACJ,CAAC,CAAC;CACL,CAAC,EACF;IACE,IAAI,EAAE,oBAAoB;IAC1B,OAAO,EAAE,CAAC;IACV,UAAU,CAAC,EAAE,kBAAkB,EAAE;QAC/B,OAAO;YACL,kBAAkB;SACnB,CAAC;IACJ,CAAC;CACF,CACF,CACF,CAAC"}
|
package/dist/hooks/sui/useSui.js
CHANGED
|
@@ -1,27 +1,81 @@
|
|
|
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
4
|
import { useWalletStore } from "../store/useWalletStore";
|
|
5
5
|
import { useSuiWallets } from "./useSuiWallets";
|
|
6
6
|
export function useSui() {
|
|
7
7
|
const { wallets } = useSuiWallets();
|
|
8
8
|
const connectedSuiWallet = useWalletStore((store) => store.connectedWalletsByChainType[ChainType.SUI]);
|
|
9
|
+
const recentSuiWalletId = useWalletStore((store) => store.recentConnectorIds[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 recentSuiWallet = wallets.find((w) => w.connectorId === recentSuiWalletId);
|
|
34
|
+
if (!recentSuiWallet) {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
const { account } = await recentSuiWallet.connector.connect({
|
|
38
|
+
silent: true,
|
|
39
|
+
});
|
|
40
|
+
setConnectedWallet(ChainType.SUI, {
|
|
41
|
+
wallet: recentSuiWallet,
|
|
42
|
+
address: account.address,
|
|
43
|
+
account,
|
|
44
|
+
});
|
|
45
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
46
|
+
}, [wallets.map((w) => w.connectorId), recentSuiWalletId]);
|
|
47
|
+
useEffect(() => {
|
|
48
|
+
const wallet = connectedSuiWallet.wallet;
|
|
49
|
+
if (!wallet) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
function onAccountsChanged({ accounts = [], }) {
|
|
53
|
+
if (!wallet) {
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
const [account] = accounts;
|
|
57
|
+
if (account) {
|
|
58
|
+
setConnectedWallet(ChainType.SUI, {
|
|
59
|
+
wallet: wallet,
|
|
60
|
+
address: account.address,
|
|
61
|
+
account: account,
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
disconnectWallet(ChainType.SUI);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
const removeListener = wallet.connector.on("change", onAccountsChanged);
|
|
69
|
+
return () => {
|
|
70
|
+
removeListener();
|
|
71
|
+
};
|
|
72
|
+
}, [disconnectWallet, setConnectedWallet, connectedSuiWallet.wallet]);
|
|
20
73
|
return {
|
|
21
74
|
connectSui,
|
|
22
75
|
disconnectSui,
|
|
76
|
+
autoConnectSui,
|
|
23
77
|
isConnected: !!connectedSuiWallet.wallet,
|
|
24
|
-
signer: connectedSuiWallet.wallet?.connector
|
|
78
|
+
signer: connectedSuiWallet.wallet?.connector,
|
|
25
79
|
wallets,
|
|
26
80
|
};
|
|
27
81
|
}
|
|
@@ -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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"}
|