@coin-voyage/crypto 0.0.26 → 0.0.28
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/evm/create-default-evm-config.js +6 -1
- package/dist/evm/create-default-evm-config.js.map +1 -1
- package/dist/hooks/use-connect-callback.js +45 -28
- package/dist/hooks/use-connect-callback.js.map +1 -1
- package/dist/lib/utils/get-wallet-priority.js +7 -5
- package/dist/lib/utils/get-wallet-priority.js.map +1 -1
- package/dist/lib/utils/is-wallet-installed.js +2 -0
- package/dist/lib/utils/is-wallet-installed.js.map +1 -1
- package/dist/solana/provider/base-provider.js +1 -1
- package/dist/solana/provider/base-provider.js.map +1 -1
- package/dist/solana/use-solana-transaction.js +5 -3
- package/dist/solana/use-solana-transaction.js.map +1 -1
- package/package.json +17 -17
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { createClient, http } from "viem";
|
|
2
|
-
import { createConfig } from "wagmi";
|
|
2
|
+
import { createConfig, injected } from "wagmi";
|
|
3
3
|
import { safe, } from "wagmi/connectors";
|
|
4
4
|
import { DEFAULT_CHAINS } from "../lib/config/chain";
|
|
5
5
|
import { createCoinbaseConnector } from "../lib/connectors/coinbase";
|
|
@@ -33,6 +33,11 @@ export function createDefaultEVMConfig(props) {
|
|
|
33
33
|
connectors.push(walletConnect);
|
|
34
34
|
}
|
|
35
35
|
}
|
|
36
|
+
if (isWalletInstalled("app.phantom.ethereum")) {
|
|
37
|
+
connectors.push(injected({
|
|
38
|
+
target: "phantom"
|
|
39
|
+
}));
|
|
40
|
+
}
|
|
36
41
|
if (!isWalletInstalled("coinbase")) {
|
|
37
42
|
const coinbase = createCoinbaseConnector(props?.coinbase ?? {
|
|
38
43
|
appName: "Coin Voyage",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-default-evm-config.js","sourceRoot":"","sources":["../../src/evm/create-default-evm-config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,IAAI,EAAE,MAAM,MAAM,CAAA;AAEzC,OAAO,EAAE,YAAY,EAAE,MAAM,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"create-default-evm-config.js","sourceRoot":"","sources":["../../src/evm/create-default-evm-config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,IAAI,EAAE,MAAM,MAAM,CAAA;AAEzC,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAC9C,OAAO,EACL,IAAI,GAIL,MAAM,kBAAkB,CAAA;AACzB,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAA;AACpD,OAAO,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAA;AACpE,OAAO,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAA;AACpE,OAAO,EAAE,4BAA4B,EAAE,MAAM,iCAAiC,CAAA;AAC9E,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAA;AAmCpE,MAAM,UAAU,sBAAsB,CACpC,KAAwB;IAExB,MAAM,UAAU,GAAwB,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,IAAI,EAAE,CAAC,CAAC,CAAA;IAEtE,MAAM,SAAS,GAAG,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAE,MAAc,CAAC,CAAC,CAAC,SAAS,CAAA;IAC7E,MAAM,YAAY,GAAG,SAAS,EAAE,YAAY,CAAA;IAC5C,wDAAwD;IACxD,MAAM,sBAAsB,GAAG,SAAS,IAAI,SAAS,CAAC,MAAM,KAAK,SAAS,CAAA;IAE1E,MAAM,8BAA8B,GAAG,sBAAsB;QAC3D,CAAC,CAAC,KAAK;QACP,CAAC,CAAC,CAAC,KAAK,EAAE,uBAAuB,EAAE,8BAA8B,IAAI,IAAI,CAAC,CAAA;IAE5E,IAAI,sBAAsB,EAAE,CAAC;QAC3B,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC;YACtB,cAAc,EAAE,CAAC,iBAAiB,EAAE,kBAAkB,CAAC;SACxD,CAAC,CAAC,CAAA;IACL,CAAC;IAED,+EAA+E;IAC/E,MAAM,iBAAiB,GAAG,YAAY,EAAE,OAAO,CAAC,yBAAyB,CAAC,CAAA;IAE1E,sFAAsF;IACtF,0EAA0E;IAC1E,IAAI,SAAS,EAAE,CAAC;QACd,MAAM,aAAa,GAAG,yBAAyB,CAAC,KAAK,EAAE,aAAa,CAAC,CAAA;QACrE,IAAI,iBAAiB,EAAE,QAAQ,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC;YACnE,UAAU,CAAC,OAAO,CAAC,aAAa,CAAC,CAAA;QACnC,CAAC;aAAM,CAAC;YACN,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA;QAChC,CAAC;IACH,CAAC;IAED,IAAI,iBAAiB,CAAC,sBAAsB,CAAC,EAAE,CAAC;QAC9C,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC;YACvB,MAAM,EAAE,SAAS;SAClB,CAAC,CAAC,CAAA;IACL,CAAC;IAED,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,EAAE,CAAC;QACnC,MAAM,QAAQ,GAAG,uBAAuB,CAAC,KAAK,EAAE,QAAQ,IAAI;YAC1D,OAAO,EAAE,aAAa;YACtB,kBAAkB,EAAE,KAAK;SAC1B,CAAC,CAAC;QACH,IAAI,iBAAiB,EAAE,QAAQ,EAAE,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC;YACvE,UAAU,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;QAC9B,CAAC;aAAM,CAAC;YACN,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QAC3B,CAAC;IACH,CAAC;IAED,IAAI,KAAK,EAAE,QAAQ,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,EAAE,CAAC;QACtD,IAAI,iBAAiB,EAAE,QAAQ,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YAChE,UAAU,CAAC,OAAO,CAAC,uBAAuB,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAA;QAC7D,CAAC;IACH,CAAC;IAED,MAAM,MAAM,GAAG,YAAY,CAAC;QAC1B,GAAG,KAAK,EAAE,uBAAuB;QACjC,MAAM,EAAE,cAAc;QACtB,MAAM,CAAC,EAAE,KAAK,EAAE;YACd,OAAO,YAAY,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,EAAE,CAAC,CAAA;QACnD,CAAC;QACD,UAAU;QACV,8BAA8B;KAC/B,CAAC,CAAA;IAEF,OAAO;QACL,MAAM;KACP,CAAA;AACH,CAAC;AAED,IAAI,uBAAuB,GAA2D,IAAI,CAAC;AAE3F,MAAM,UAAU,yBAAyB,CAAC,MAAgC;IACxE,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC7B,uBAAuB,GAAG,4BAA4B,CAAC;YACrD,GAAG,MAAM;YACT,SAAS,EACP,MAAM,EAAE,SAAS,IAAI,kCAAkC;SAC1D,CAAC,CAAA;IACJ,CAAC;IACD,OAAO,uBAAuB,CAAA;AAChC,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { useEffect, useState } from "react";
|
|
1
|
+
import { useEffect, useRef, useState } from "react";
|
|
2
2
|
import { useAccount } from "./use-account";
|
|
3
3
|
export const useConnectCallback = ({ onConnect, onDisconnect, onConnectValidation, setAllowedWallets }) => {
|
|
4
4
|
const { account } = useAccount();
|
|
@@ -6,43 +6,60 @@ export const useConnectCallback = ({ onConnect, onDisconnect, onConnectValidatio
|
|
|
6
6
|
const chainId = account?.chainId;
|
|
7
7
|
const chainType = account?.chainType;
|
|
8
8
|
const connectorId = account?.connector?.id;
|
|
9
|
+
const isConnected = !!account?.isConnected;
|
|
9
10
|
const [activeAccount, setActiveAccount] = useState(null);
|
|
11
|
+
// keep stable references for callbacks
|
|
12
|
+
const onConnectRef = useRef(onConnect);
|
|
13
|
+
const onDisconnectRef = useRef(onDisconnect);
|
|
14
|
+
const onConnectValidationRef = useRef(onConnectValidation);
|
|
15
|
+
const setAllowedWalletsRef = useRef(setAllowedWallets);
|
|
10
16
|
useEffect(() => {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
17
|
+
onConnectRef.current = onConnect;
|
|
18
|
+
onDisconnectRef.current = onDisconnect;
|
|
19
|
+
onConnectValidationRef.current = onConnectValidation;
|
|
20
|
+
setAllowedWalletsRef.current = setAllowedWallets;
|
|
21
|
+
}, [onConnect, onDisconnect, onConnectValidation, setAllowedWallets]);
|
|
22
|
+
useEffect(() => {
|
|
23
|
+
if (!isConnected || !address)
|
|
24
|
+
return;
|
|
25
|
+
if (activeAccount === address)
|
|
26
|
+
return;
|
|
27
|
+
setActiveAccount(address);
|
|
28
|
+
onConnectRef.current?.({
|
|
29
|
+
address,
|
|
30
|
+
chainId,
|
|
31
|
+
connectorId,
|
|
32
|
+
type: chainType,
|
|
33
|
+
});
|
|
34
|
+
const validateAndSet = async () => {
|
|
35
|
+
const validator = onConnectValidationRef.current;
|
|
36
|
+
if (!validator) {
|
|
37
|
+
setAllowedWalletsRef.current(null);
|
|
22
38
|
return;
|
|
23
39
|
}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
const existingWallet = prev?.find(wallet => wallet.address === address);
|
|
31
|
-
if (existingWallet) {
|
|
32
|
-
return prev.map(wallet => wallet.address === address ? { ...wallet, allowed: isValid } : wallet);
|
|
40
|
+
try {
|
|
41
|
+
const isValid = await validator({ address, chainId, chainType });
|
|
42
|
+
setAllowedWalletsRef.current((prev) => {
|
|
43
|
+
const existing = prev?.find((w) => w.address === address);
|
|
44
|
+
if (existing) {
|
|
45
|
+
return prev.map((w) => w.address === address ? { ...w, allowed: isValid } : w);
|
|
33
46
|
}
|
|
34
47
|
if (!isValid)
|
|
35
48
|
return prev || [];
|
|
36
|
-
return [...(prev || []), {
|
|
49
|
+
return [...(prev || []), { address, chainId, chainType, allowed: isValid }];
|
|
37
50
|
});
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
|
|
51
|
+
}
|
|
52
|
+
catch (err) {
|
|
53
|
+
console.error("onConnectValidation failed:", err);
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
validateAndSet();
|
|
57
|
+
}, [isConnected, address, chainId, chainType, connectorId, activeAccount]);
|
|
41
58
|
useEffect(() => {
|
|
42
|
-
if (activeAccount && !
|
|
59
|
+
if (activeAccount && !isConnected) {
|
|
43
60
|
setActiveAccount(null);
|
|
44
|
-
|
|
61
|
+
onDisconnectRef.current?.();
|
|
45
62
|
}
|
|
46
|
-
}, [
|
|
63
|
+
}, [isConnected, activeAccount]);
|
|
47
64
|
};
|
|
48
65
|
//# sourceMappingURL=use-connect-callback.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-connect-callback.js","sourceRoot":"","sources":["../../src/hooks/use-connect-callback.ts"],"names":[],"mappings":"AACA,OAAc,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"use-connect-callback.js","sourceRoot":"","sources":["../../src/hooks/use-connect-callback.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,15 +1,17 @@
|
|
|
1
1
|
const walletPriority = {
|
|
2
|
-
|
|
2
|
+
metamasksdk: 1,
|
|
3
|
+
metamask: 1,
|
|
3
4
|
"io.metamask": 1,
|
|
4
5
|
"io.metamask.mobile": 1,
|
|
6
|
+
"phantom": 1,
|
|
5
7
|
"app.phantom": 1,
|
|
6
|
-
"
|
|
7
|
-
|
|
8
|
+
"slush": 1,
|
|
9
|
+
coinbasewalletsdk: 2,
|
|
8
10
|
"com.coinbase.wallet": 2,
|
|
9
|
-
|
|
11
|
+
walletconnect: 1001,
|
|
10
12
|
safe: 4,
|
|
11
13
|
};
|
|
12
14
|
export const getWalletPriority = (id) => {
|
|
13
|
-
return walletPriority?.[id] || 1000;
|
|
15
|
+
return walletPriority?.[id.toLowerCase()] || 1000;
|
|
14
16
|
};
|
|
15
17
|
//# sourceMappingURL=get-wallet-priority.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-wallet-priority.js","sourceRoot":"","sources":["../../../src/lib/utils/get-wallet-priority.ts"],"names":[],"mappings":"AAAA,MAAM,cAAc,GAA2B;IAC7C,WAAW,EAAE,CAAC;IACd,aAAa,EAAE,CAAC;IAChB,oBAAoB,EAAE,CAAC;IACvB,aAAa,EAAE,CAAC;IAChB,
|
|
1
|
+
{"version":3,"file":"get-wallet-priority.js","sourceRoot":"","sources":["../../../src/lib/utils/get-wallet-priority.ts"],"names":[],"mappings":"AAAA,MAAM,cAAc,GAA2B;IAC7C,WAAW,EAAE,CAAC;IACd,QAAQ,EAAE,CAAC;IACX,aAAa,EAAE,CAAC;IAChB,oBAAoB,EAAE,CAAC;IACvB,SAAS,EAAE,CAAC;IACZ,aAAa,EAAE,CAAC;IAChB,OAAO,EAAE,CAAC;IACV,iBAAiB,EAAE,CAAC;IACpB,qBAAqB,EAAE,CAAC;IACxB,aAAa,EAAE,IAAI;IACnB,IAAI,EAAE,CAAC;CACR,CAAA;AAED,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,EAAU,EAAE,EAAE;IAC9C,OAAO,cAAc,EAAE,CAAC,EAAE,CAAC,WAAW,EAAE,CAAC,IAAI,IAAI,CAAA;AACnD,CAAC,CAAA"}
|
|
@@ -13,6 +13,8 @@ export const isWalletInstalled = (id) => {
|
|
|
13
13
|
!anyWindow?.ethereum?.isCoinbaseBrowser) ||
|
|
14
14
|
anyWindow?.coinbaseWalletExtension?.isCoinbaseWallet ||
|
|
15
15
|
anyWindow?.ethereum?.providers?.some((provider) => provider.isCoinbaseWallet));
|
|
16
|
+
case "app.phantom.ethereum":
|
|
17
|
+
return anyWindow?.phantom?.ethereum?.isPhantom;
|
|
16
18
|
case "app.phantom":
|
|
17
19
|
return anyWindow?.phantom?.isPhantom;
|
|
18
20
|
case "app.phantom.sui":
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"is-wallet-installed.js","sourceRoot":"","sources":["../../../src/lib/utils/is-wallet-installed.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,EAAU,EAAW,EAAE;IACvD,MAAM,SAAS,GAAG,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAE,MAAc,CAAC,CAAC,CAAC,SAAS,CAAA;IAC7E,QAAQ,EAAE,EAAE,CAAC;QACX,KAAK,UAAU;YACb,OAAO,CACL,SAAS,EAAE,QAAQ,EAAE,UAAU;gBAC/B,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,CAClC,CAAC,QAAa,EAAE,EAAE,CAAC,QAAQ,CAAC,UAAU,CACvC,CACF,CAAA;QACH,KAAK,UAAU;YACf,4BAA4B;YAC1B,OAAO;YACL,uDAAuD;YACvD,iGAAiG;YACjG,CAAC,SAAS,EAAE,QAAQ,EAAE,gBAAgB;gBACpC,CAAC,SAAS,EAAE,QAAQ,EAAE,iBAAiB,CAAC;gBAC1C,SAAS,EAAE,uBAAuB,EAAE,gBAAgB;gBACpD,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,CAClC,CAAC,QAAa,EAAE,EAAE,CAAC,QAAQ,CAAC,gBAAgB,CAC7C,CACF,CAAA;QACH,KAAK,aAAa;YAChB,OAAO,SAAS,EAAE,OAAO,EAAE,SAAS,CAAA;QACtC,KAAK,iBAAiB;YACpB,OAAO,SAAS,EAAE,OAAO,EAAE,GAAG,EAAE,SAAS,CAAA;QAE3C,eAAe;QACf,KAAK,qBAAqB;YACxB,OAAO,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,SAAS,CAAA;QAC/C,KAAK,yBAAyB;YAC5B,OAAO,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,WAAW,CAAA;QACnD,KAAK,iCAAiC;YACpC,OAAO,SAAS,EAAE,eAAe,EAAE,eAAe,CAAA;QACpD,KAAK,QAAQ;YACX,OAAO,SAAS,EAAE,MAAM,CAAA;QAC1B,KAAK,kBAAkB;YACrB,OAAO,SAAS,EAAE,GAAG,EAAE,OAAO,CAAA;QAChC,KAAK,uBAAuB;YAC1B,OAAO,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,WAAW,CAAA;QACnD,KAAK,iBAAiB;YACpB,OAAO,SAAS,EAAE,eAAe,EAAE,SAAS,CAAA;QAC9C,KAAK,8BAA8B;YACjC,OAAO,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,CAAA;QAChD;YACE;;eAEG;YACH,OAAO,IAAI,CAAA;IACf,CAAC;AACH,CAAC,CAAA"}
|
|
1
|
+
{"version":3,"file":"is-wallet-installed.js","sourceRoot":"","sources":["../../../src/lib/utils/is-wallet-installed.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,EAAU,EAAW,EAAE;IACvD,MAAM,SAAS,GAAG,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAE,MAAc,CAAC,CAAC,CAAC,SAAS,CAAA;IAC7E,QAAQ,EAAE,EAAE,CAAC;QACX,KAAK,UAAU;YACb,OAAO,CACL,SAAS,EAAE,QAAQ,EAAE,UAAU;gBAC/B,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,CAClC,CAAC,QAAa,EAAE,EAAE,CAAC,QAAQ,CAAC,UAAU,CACvC,CACF,CAAA;QACH,KAAK,UAAU;YACf,4BAA4B;YAC1B,OAAO;YACL,uDAAuD;YACvD,iGAAiG;YACjG,CAAC,SAAS,EAAE,QAAQ,EAAE,gBAAgB;gBACpC,CAAC,SAAS,EAAE,QAAQ,EAAE,iBAAiB,CAAC;gBAC1C,SAAS,EAAE,uBAAuB,EAAE,gBAAgB;gBACpD,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,CAClC,CAAC,QAAa,EAAE,EAAE,CAAC,QAAQ,CAAC,gBAAgB,CAC7C,CACF,CAAA;QACH,KAAK,sBAAsB;YACzB,OAAO,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,CAAA;QAChD,KAAK,aAAa;YAChB,OAAO,SAAS,EAAE,OAAO,EAAE,SAAS,CAAA;QACtC,KAAK,iBAAiB;YACpB,OAAO,SAAS,EAAE,OAAO,EAAE,GAAG,EAAE,SAAS,CAAA;QAE3C,eAAe;QACf,KAAK,qBAAqB;YACxB,OAAO,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,SAAS,CAAA;QAC/C,KAAK,yBAAyB;YAC5B,OAAO,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,WAAW,CAAA;QACnD,KAAK,iCAAiC;YACpC,OAAO,SAAS,EAAE,eAAe,EAAE,eAAe,CAAA;QACpD,KAAK,QAAQ;YACX,OAAO,SAAS,EAAE,MAAM,CAAA;QAC1B,KAAK,kBAAkB;YACrB,OAAO,SAAS,EAAE,GAAG,EAAE,OAAO,CAAA;QAChC,KAAK,uBAAuB;YAC1B,OAAO,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,WAAW,CAAA;QACnD,KAAK,iBAAiB;YACpB,OAAO,SAAS,EAAE,eAAe,EAAE,SAAS,CAAA;QAC9C,KAAK,8BAA8B;YACjC,OAAO,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,QAAQ,CAAA;QAChD;YACE;;eAEG;YACH,OAAO,IAAI,CAAA;IACf,CAAC;AACH,CAAC,CAAA"}
|
|
@@ -4,7 +4,7 @@ import { CoinbaseWalletAdapter } from '@solana/wallet-adapter-coinbase';
|
|
|
4
4
|
import { ConnectionProvider, WalletProvider, } from "@solana/wallet-adapter-react";
|
|
5
5
|
import { WalletConnectWalletAdapter } from "@solana/wallet-adapter-walletconnect";
|
|
6
6
|
import { useMemo } from "react";
|
|
7
|
-
const DEFAULT_SOLANA_RPC = "https://
|
|
7
|
+
const DEFAULT_SOLANA_RPC = "https://solana-mainnet.g.alchemy.com/v2/vPIG6RGK7rUDSwR1MHfEgXlZ2acwA4MG";
|
|
8
8
|
const wallets = [new CoinbaseWalletAdapter()];
|
|
9
9
|
export function SolanaBaseProvider({ children, config }) {
|
|
10
10
|
const solanaConfig = useMemo(() => config, [JSON.stringify(config)]);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"base-provider.js","sourceRoot":"","sources":["../../../src/solana/provider/base-provider.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,oBAAoB,EAAgB,MAAM,6BAA6B,CAAA;AAChF,OAAO,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAA;AACvE,OAAO,EACL,kBAAkB,EAClB,cAAc,GACf,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,0BAA0B,EAAE,MAAM,sCAAsC,CAAA;AACjF,OAAO,EAAE,OAAO,EAA0B,MAAM,OAAO,CAAA;AAIvD,MAAM,kBAAkB,GAAG,
|
|
1
|
+
{"version":3,"file":"base-provider.js","sourceRoot":"","sources":["../../../src/solana/provider/base-provider.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,oBAAoB,EAAgB,MAAM,6BAA6B,CAAA;AAChF,OAAO,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAA;AACvE,OAAO,EACL,kBAAkB,EAClB,cAAc,GACf,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAAE,0BAA0B,EAAE,MAAM,sCAAsC,CAAA;AACjF,OAAO,EAAE,OAAO,EAA0B,MAAM,OAAO,CAAA;AAIvD,MAAM,kBAAkB,GAAG,0EAA0E,CAAA;AAErG,MAAM,OAAO,GAAc,CAAC,IAAI,qBAAqB,EAAE,CAAC,CAAA;AAExD,MAAM,UAAU,kBAAkB,CAAC,EAAE,QAAQ,EAAE,MAAM,EAInD;IACA,MAAM,YAAY,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAA;IAEpE,OAAO,CAAC,IAAI,CAAC,yBAAyB,CAAC,YAAY,EAAE,aAAa,CAAC,CAAC,CAAA;IAEpE,OAAO,CACL,KAAC,kBAAkB,IAAC,QAAQ,EAAE,YAAY,EAAE,MAAM,IAAI,kBAAkB,YACtE,KAAC,cAAc,OACT,YAAY,EAAE,mBAAmB,EACrC,eAAe,EAAE,YAAY,EAAE,mBAAmB,EAAE,eAAe,IAAI,4BAA4B,EACnG,WAAW,EAAE,YAAY,EAAE,mBAAmB,EAAE,WAAW,IAAI,IAAI,EACnE,OAAO,EAAE,CAAC,GAAG,YAAY,EAAE,mBAAmB,EAAE,OAAO,IAAI,EAAE,EAAE,GAAG,OAAO,CAAC,YAEzE,QAAQ,GACM,GACE,CACtB,CAAA;AACH,CAAC;AAED,SAAS,yBAAyB,CAAC,MAAgC;IACjE,OAAO,IAAI,0BAA0B,CAAC;QACpC,OAAO,EAAE,oBAAoB,CAAC,OAAO;QACrC,OAAO,EAAE;YACP,IAAI,EAAE,eAAe;YACrB,SAAS,EACP,MAAM,EAAE,SAAS,IAAI,kCAAkC;YACzD,QAAQ,EAAE,MAAM,EAAE,QAAQ,IAAI,+BAA+B;YAC7D,QAAQ,EAAE,MAAM,EAAE,QAAQ;SAC3B;KACF,CAAC,CAAA;AACJ,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { createTransferCheckedInstruction, getAssociatedTokenAddress
|
|
1
|
+
import { createTransferCheckedInstruction, getAssociatedTokenAddress } from "@solana/spl-token";
|
|
2
2
|
import { useConnection, useWallet } from "@solana/wallet-adapter-react";
|
|
3
3
|
import { ComputeBudgetProgram, PublicKey, SystemProgram, Transaction, TransactionInstruction } from "@solana/web3.js";
|
|
4
4
|
import { getOrCreateAssociatedTokenAccount } from "./get-or-create-ata";
|
|
@@ -27,8 +27,10 @@ export function useSolanaTransaction() {
|
|
|
27
27
|
}
|
|
28
28
|
else {
|
|
29
29
|
const mint = new PublicKey(token.address);
|
|
30
|
-
const payerAta = await
|
|
31
|
-
|
|
30
|
+
const [payerAta, receiverAta] = await Promise.all([
|
|
31
|
+
getAssociatedTokenAddress(mint, senderPubKey, false),
|
|
32
|
+
getAssociatedTokenAddress(mint, receiverPubKey, true)
|
|
33
|
+
]);
|
|
32
34
|
const accountOrTransactionInstruction = await getOrCreateAssociatedTokenAccount(connection, senderPubKey, mint, receiverPubKey);
|
|
33
35
|
if (accountOrTransactionInstruction instanceof TransactionInstruction) {
|
|
34
36
|
instructions.push(accountOrTransactionInstruction);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-solana-transaction.js","sourceRoot":"","sources":["../../src/solana/use-solana-transaction.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"use-solana-transaction.js","sourceRoot":"","sources":["../../src/solana/use-solana-transaction.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,gCAAgC,EAChC,yBAAyB,EAC1B,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AACxE,OAAO,EACL,oBAAoB,EACpB,SAAS,EACT,aAAa,EACb,WAAW,EACX,sBAAsB,EACvB,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,iCAAiC,EAAE,MAAM,qBAAqB,CAAC;AAExE,MAAM,UAAU,oBAAoB;IAGlC,MAAM,EAAE,UAAU,EAAE,GAAG,aAAa,EAAE,CAAC;IACvC,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAE3B,MAAM,OAAO,GAAG,KAAK,EAAE,MAA0B,EAAE,EAAE;QACnD,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC;QACzD,IAAI,WAAW,GAAG,IAAI,WAAW,EAAE,CAAC;QAEpC,MAAM,YAAY,GAAG,IAAI,SAAS,CAAC,WAAW,CAAC,CAAC;QAChD,MAAM,cAAc,GAAG,IAAI,SAAS,CAAC,SAAS,CAAC,CAAC;QAEhD,MAAM,YAAY,GAA6B;YAC7C,oBAAoB;YACpB,oBAAoB,CAAC,mBAAmB,CAAC;gBACvC,aAAa,EAAE,OAAS;aACzB,CAAC;SACH,CAAC;QAEF,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QAE7B,sBAAsB;QACtB,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,YAAY,CAAC,IAAI,CACf,aAAa,CAAC,QAAQ,CAAC;gBACrB,UAAU,EAAE,YAAY;gBACxB,QAAQ,EAAE,cAAc;gBACxB,QAAQ,EAAE,KAAK;aAChB,CAAC,CACH,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,GAAG,IAAI,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAE1C,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;gBAChD,yBAAyB,CAAC,IAAI,EAAE,YAAY,EAAE,KAAK,CAAC;gBACpD,yBAAyB,CAAC,IAAI,EAAE,cAAc,EAAE,IAAI,CAAC;aACtD,CAAC,CAAA;YAEF,MAAM,+BAA+B,GAAG,MAAM,iCAAiC,CAC7E,UAAU,EACV,YAAY,EACZ,IAAI,EACJ,cAAc,CACf,CAAC;YACF,IAAI,+BAA+B,YAAY,sBAAsB,EAAE,CAAC;gBACtE,YAAY,CAAC,IAAI,CAAC,+BAA+B,CAAC,CAAC;YACrD,CAAC;YAED,YAAY,CAAC,IAAI,CACf,gCAAgC,CAC9B,QAAQ,EAAE,OAAO;YACjB,IAAI,EACJ,WAAW,EAAE,KAAK;YAClB,YAAY,EAAE,eAAe;YAC7B,KAAK,EACL,KAAK,CAAC,QAAQ,CACf,CACF,CAAC;QACJ,CAAC;QAED,MAAM,EACJ,OAAO,EAAE,EAAE,IAAI,EAAE,cAAc,EAAE,EACjC,KAAK,EAAE,EAAE,SAAS,EAAE,EACrB,GAAG,MAAM,UAAU,CAAC,4BAA4B,EAAE,CAAC;QAEpD,WAAW,CAAC,QAAQ,GAAG,YAAY,CAAC;QACpC,WAAW,CAAC,eAAe,GAAG,SAAS,CAAC;QACxC,WAAW,CAAC,YAAY,GAAG,YAAY,CAAC;QAExC,OAAO,MAAM,MAAM,CAAC,eAAe,CAAC,WAAW,EAAE,UAAU,EAAE;YAC3D,cAAc;SACf,CAAC,CAAC;IACL,CAAC,CAAA;IAED,OAAO,EAAE,OAAO,EAAE,CAAA;AACpB,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@coin-voyage/crypto",
|
|
3
3
|
"description": "Crypto utilities for Coin Voyage",
|
|
4
|
-
"version": "0.0.
|
|
4
|
+
"version": "0.0.28",
|
|
5
5
|
"private": false,
|
|
6
6
|
"sideEffects": false,
|
|
7
7
|
"author": "Lars <lars@coinvoyage.io>",
|
|
@@ -30,8 +30,8 @@
|
|
|
30
30
|
}
|
|
31
31
|
},
|
|
32
32
|
"dependencies": {
|
|
33
|
-
"@bigmi/client": "0.6.
|
|
34
|
-
"@bigmi/core": "0.6.
|
|
33
|
+
"@bigmi/client": "0.6.1",
|
|
34
|
+
"@bigmi/core": "0.6.1",
|
|
35
35
|
"@noble/secp256k1": "1.7.1",
|
|
36
36
|
"@noble/ed25519": "2.3.0",
|
|
37
37
|
"@scure/base": "1.1.1",
|
|
@@ -39,31 +39,31 @@
|
|
|
39
39
|
"@stablelib/random": "2.0.1",
|
|
40
40
|
"jsontokens": "4.0.1",
|
|
41
41
|
"bitcoinjs-lib": "6.1.7",
|
|
42
|
-
"bitcoinjs-message": "
|
|
43
|
-
"bitcoin-address-validation": "
|
|
44
|
-
"@mysten/sui": "1.
|
|
45
|
-
"@mysten/wallet-standard": "0.
|
|
46
|
-
"@solana/
|
|
42
|
+
"bitcoinjs-message": "2.2.0",
|
|
43
|
+
"bitcoin-address-validation": "3.0.0",
|
|
44
|
+
"@mysten/sui": "1.44.0",
|
|
45
|
+
"@mysten/wallet-standard": "0.19.6",
|
|
46
|
+
"@solana/web3.js": "1.98.4",
|
|
47
|
+
"@solana/spl-token": "0.4.14",
|
|
47
48
|
"@solana/wallet-standard-features": "1.3.0",
|
|
48
49
|
"@solana/wallet-standard-util": "1.1.2",
|
|
49
50
|
"@solana/wallet-adapter-walletconnect": "0.1.21",
|
|
50
|
-
"@solana/wallet-adapter-base": "0.9.
|
|
51
|
+
"@solana/wallet-adapter-base": "0.9.27",
|
|
51
52
|
"@solana/wallet-adapter-coinbase": "0.1.23",
|
|
52
|
-
"@coin-voyage/shared": "0.0.
|
|
53
|
+
"@coin-voyage/shared": "0.0.25"
|
|
53
54
|
},
|
|
54
55
|
"devDependencies": {
|
|
55
56
|
"@types/elliptic": "6.4.18"
|
|
56
57
|
},
|
|
57
58
|
"peerDependencies": {
|
|
58
|
-
"@bigmi/react": "
|
|
59
|
+
"@bigmi/react": "^0.6.1",
|
|
60
|
+
"@mysten/dapp-kit": "^0.19.8",
|
|
61
|
+
"@solana/wallet-adapter-react": "^0.15.39",
|
|
62
|
+
"@tanstack/react-query": "^5.90.6",
|
|
59
63
|
"react": "^18 || ^19",
|
|
60
64
|
"react-dom": "^18 || ^19",
|
|
61
|
-
"
|
|
62
|
-
"
|
|
63
|
-
"@solana/web3.js": "^1.98.0",
|
|
64
|
-
"@tanstack/react-query": "^5.80.2",
|
|
65
|
-
"viem": "^2.30.6",
|
|
66
|
-
"wagmi": "^2.15.5"
|
|
65
|
+
"viem": "^2.38.6",
|
|
66
|
+
"wagmi": "^2.17.5"
|
|
67
67
|
},
|
|
68
68
|
"scripts": {
|
|
69
69
|
"watch": "tsc -w -p ./tsconfig.json",
|