@tomo-inc/wallet-adaptor-base 0.0.1 → 0.0.3
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/index.cjs +1024 -330
- package/dist/index.d.cts +172 -6
- package/dist/index.d.ts +172 -6
- package/dist/index.js +955 -332
- package/package.json +4 -2
- package/project.json +2 -2
- package/src/global.d.ts +7 -0
- package/src/index.ts +14 -8
- package/src/type.ts +13 -0
- package/src/utils/browsers.ts +13 -0
- package/src/utils/chainId.ts +1 -1
- package/src/utils/isMobile.ts +1 -1
- package/src/utils/log.ts +7 -0
- package/src/utils/utils.ts +5 -0
- package/src/wallet-api/balance.ts +4 -2
- package/src/wallet-api/chain.ts +9 -2
- package/src/wallet-api/connect.ts +142 -12
- package/src/wallet-api/sign-in.ts +23 -26
- package/src/wallet-api/sign-message.ts +116 -13
- package/src/wallets/Wallet.ts +6 -1
- package/src/wallets/default/backpackWallet/backpackWallet.ts +2 -4
- package/src/wallets/default/berasigWallet/berasigWallet.ts +2 -4
- package/src/wallets/default/binanceWallet/binanceWallet.ts +29 -4
- package/src/wallets/default/bitgetWallet/bitgetWallet.ts +12 -4
- package/src/wallets/default/bitskiWallet/bitskiWallet.ts +2 -4
- package/src/wallets/default/bitverseWallet/bitverseWallet.ts +5 -4
- package/src/wallets/default/bloomWallet/bloomWallet.ts +2 -4
- package/src/wallets/default/braveWallet/braveWallet.ts +2 -4
- package/src/wallets/default/bybitWallet/bybitWallet.ts +7 -4
- package/src/wallets/default/clvWallet/clvWallet.ts +2 -4
- package/src/wallets/default/coin98Wallet/coin98Wallet.ts +2 -4
- package/src/wallets/default/coinbaseWallet/coinbaseWallet.ts +9 -4
- package/src/wallets/default/compassWallet/compassWallet.ts +2 -4
- package/src/wallets/default/coreWallet/coreWallet.ts +2 -4
- package/src/wallets/default/ctrlWallet/ctrlWallet.ts +2 -4
- package/src/wallets/default/dawnWallet/dawnWallet.ts +2 -4
- package/src/wallets/default/desigWallet/desigWallet.ts +2 -4
- package/src/wallets/default/enkryptWallet/enkryptWallet.ts +2 -4
- package/src/wallets/default/foxWallet/foxWallet.ts +7 -4
- package/src/wallets/default/frameWallet/frameWallet.ts +2 -4
- package/src/wallets/default/gateWallet/gateWallet.ts +8 -4
- package/src/wallets/default/imTokenWallet/imTokenWallet.ts +11 -4
- package/src/wallets/default/injectedWallet/injectedWallet.ts +2 -4
- package/src/wallets/default/iopayWallet/iopayWallet.ts +8 -4
- package/src/wallets/default/kaiaWallet/kaiaWallet.ts +7 -4
- package/src/wallets/default/kaikasWallet/kaikasWallet.ts +7 -4
- package/src/wallets/default/krakenWallet/krakenWallet.ts +7 -4
- package/src/wallets/default/kresusWallet/kresusWallet.ts +5 -4
- package/src/wallets/default/ledgerWallet/ledgerWallet.ts +8 -4
- package/src/wallets/default/magicEdenWallet/magicEdenWallet.ts +5 -7
- package/src/wallets/default/mathWallet/mathWallet.svg +9 -0
- package/src/wallets/default/mathWallet/mathWallet.ts +2 -2
- package/src/wallets/default/metaMaskWallet/metaMaskWallet.ts +20 -2
- package/src/wallets/default/myDogeWallet/mydogeWallet.ts +1 -1
- package/src/wallets/default/nestWallet/nestWallet.ts +2 -4
- package/src/wallets/default/novaWallet/novaWallet.ts +2 -4
- package/src/wallets/default/oktoWallet/oktoWallet.ts +8 -4
- package/src/wallets/default/okxWallet/okxWallet.ts +13 -4
- package/src/wallets/default/omniWallet/omniWallet.ts +8 -4
- package/src/wallets/default/oneInchWallet/oneInchWallet.svg +30 -1
- package/src/wallets/default/oneInchWallet/oneInchWallet.ts +5 -4
- package/src/wallets/default/oneKeyWallet/oneKeyWallet.ts +2 -4
- package/src/wallets/default/paraSwapWallet/paraswapWallet.ts +7 -4
- package/src/wallets/default/petraWallet/petraWallet.svg +5 -0
- package/src/wallets/default/petraWallet/petraWallet.ts +24 -0
- package/src/wallets/default/phantomWallet/phantomWallet.ts +9 -4
- package/src/wallets/default/rabbyWallet/rabbyWallet.ts +2 -4
- package/src/wallets/default/rainbowWallet/rainbowWallet.ts +12 -4
- package/src/wallets/default/ramperWallet/ramperWallet.ts +2 -4
- package/src/wallets/default/readyWallet/readyWallet.ts +2 -4
- package/src/wallets/default/roninWallet/roninWallet.ts +2 -4
- package/src/wallets/default/safeWallet/safeWallet.ts +2 -4
- package/src/wallets/default/safeheronWallet/safeheronWallet.ts +2 -4
- package/src/wallets/default/safepalWallet/safepalWallet.ts +2 -4
- package/src/wallets/default/seifWallet/seifWallet.ts +2 -4
- package/src/wallets/default/solflareWallet/solflareWallet.svg +11 -0
- package/src/wallets/default/solflareWallet/solflareWallet.ts +9 -2
- package/src/wallets/default/subWallet/subWallet.ts +2 -4
- package/src/wallets/default/tahoWallet/tahoWallet.ts +2 -4
- package/src/wallets/default/talismanWallet/talismanWallet.ts +2 -4
- package/src/wallets/default/tokenPocketWallet/tokenPocketWallet.ts +8 -4
- package/src/wallets/default/tokenaryWallet/tokenaryWallet.ts +2 -4
- package/src/wallets/default/trezorWallet/trezorWallet.svg +7 -0
- package/src/wallets/default/trezorWallet/trezorWallet.ts +2 -2
- package/src/wallets/default/trustWallet/trustWallet.ts +9 -5
- package/src/wallets/default/uniswapWallet/uniswapWallet.ts +7 -4
- package/src/wallets/default/universalProfilesWallet/universalProfilesWallet.svg +13 -1351
- package/src/wallets/default/universalProfilesWallet/universalProfilesWallet.ts +2 -2
- package/src/wallets/default/valoraWallet/valoraWallet.ts +6 -4
- package/src/wallets/default/walletConnectWallet/walletConnectWallet.ts +2 -4
- package/src/wallets/default/wigwamWallet/wigwamWallet.ts +2 -4
- package/src/wallets/default/xPortalWallet/xPortalWallet.ts +2 -4
- package/src/wallets/default/zealWallet/zealWallet.ts +7 -4
- package/src/wallets/default/zerionWallet/zerionWallet.ts +8 -4
- package/src/wallets/default/zilPayWallet/zilPayWallet.ts +2 -4
- package/src/wallets/defaultConnectors.ts +213 -0
- package/src/wallets/detector.ts +34 -17
- package/src/wallets/index.ts +7 -76
- package/src/wallets/providers/WalletConnectProvider.ts +3 -2
- package/src/wallets/wallet-standard.ts +147 -47
- package/src/wallets/wallet-walletconnect.ts +1 -1
- package/tsconfig.json +4 -1
- package/tsup.config.ts +55 -0
- package/src/wallets/default/mathWallet/icon.ts +0 -2
- package/src/wallets/default/metaMaskWallet/icon.ts +0 -2
- package/src/wallets/default/myDogeWallet/icon.ts +0 -2
- package/src/wallets/default/solflareWallet/icon.ts +0 -2
- package/src/wallets/default/trezorWallet/icon.ts +0 -2
- package/src/wallets/default/universalProfilesWallet/icon.ts +0 -2
|
@@ -1,4 +1,7 @@
|
|
|
1
|
-
import { WalletOptions } from "type";
|
|
1
|
+
import { WalletInfo, WalletOptions } from "type";
|
|
2
|
+
import { openUri } from "utils/browsers";
|
|
3
|
+
import { isMobile } from "utils/isMobile";
|
|
4
|
+
import { uint8arrayToHex } from "utils/utils";
|
|
2
5
|
|
|
3
6
|
/*
|
|
4
7
|
const params = {
|
|
@@ -12,9 +15,14 @@ const params = {
|
|
|
12
15
|
};
|
|
13
16
|
*/
|
|
14
17
|
|
|
15
|
-
export const signMessage = async (
|
|
16
|
-
|
|
18
|
+
export const signMessage = async (
|
|
19
|
+
data: { message: string; nonce: string },
|
|
20
|
+
walletOptions: WalletOptions & { isInstalled?: boolean },
|
|
21
|
+
): Promise<string> => {
|
|
22
|
+
const { chainType, account, provider, walletInfo, isInstalled } = walletOptions;
|
|
17
23
|
const { message, nonce } = data;
|
|
24
|
+
const isMobileDevice = isMobile();
|
|
25
|
+
const isWalletConnect = walletInfo?.uuid === "walletConnect";
|
|
18
26
|
|
|
19
27
|
if (!provider) {
|
|
20
28
|
throw new Error("Provider is required");
|
|
@@ -24,11 +32,24 @@ export const signMessage = async (data: { message: string; nonce: string }, wall
|
|
|
24
32
|
|
|
25
33
|
if (chainType === "evm") {
|
|
26
34
|
try {
|
|
27
|
-
|
|
35
|
+
// start provider.request, this is an asynchronous operation, will wait for user confirmation
|
|
36
|
+
const signaturePromise = provider.request({
|
|
28
37
|
method: "personal_sign",
|
|
29
38
|
params: [message, address],
|
|
30
|
-
})
|
|
31
|
-
|
|
39
|
+
}) as Promise<string>;
|
|
40
|
+
|
|
41
|
+
// if the mobile wallet application needs to be opened, open it after the signature request is started (not blocking)
|
|
42
|
+
// delay opening can ensure that provider.request has been started, avoid immediate jump causing subsequent code to fail to execute
|
|
43
|
+
if (isMobileDevice && !isWalletConnect && !isInstalled) {
|
|
44
|
+
handleOpenMobileWalletDelayed(walletOptions, 100).catch((error) => {
|
|
45
|
+
console.error("Failed to schedule mobile wallet open:", error);
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
// wait for the signature result
|
|
50
|
+
const signature: string = await signaturePromise;
|
|
51
|
+
console.log("signMessage res:", chainType, provider, message, signature);
|
|
52
|
+
return signature;
|
|
32
53
|
} catch (error) {
|
|
33
54
|
throw error as Error;
|
|
34
55
|
}
|
|
@@ -37,20 +58,57 @@ export const signMessage = async (data: { message: string; nonce: string }, wall
|
|
|
37
58
|
if (chainType === "solana") {
|
|
38
59
|
try {
|
|
39
60
|
const encodedMessage = new TextEncoder().encode(message);
|
|
40
|
-
|
|
41
|
-
|
|
61
|
+
let signature = "";
|
|
62
|
+
if (provider?.signMessage) {
|
|
63
|
+
const res = await provider.signMessage(encodedMessage, "utf8");
|
|
64
|
+
if (typeof res === "object" && res?.signature) {
|
|
65
|
+
signature = res?.signature?.toHex?.() || uint8arrayToHex(res?.signature as Uint8Array) || "";
|
|
66
|
+
} else if (Array.isArray(res)) {
|
|
67
|
+
signature = res?.[0]?.signature?.toHex?.() || uint8arrayToHex(res?.[0]?.signature as Uint8Array) || "";
|
|
68
|
+
} else {
|
|
69
|
+
signature = res || "";
|
|
70
|
+
}
|
|
71
|
+
console.log("signMessage solana res:", chainType, provider, message, signature);
|
|
72
|
+
return signature;
|
|
73
|
+
}
|
|
74
|
+
if (provider?.["solana:signMessage"]) {
|
|
75
|
+
const res: any[] = await provider["solana:signMessage"]?.signMessage({
|
|
76
|
+
message: encodedMessage,
|
|
77
|
+
account: { address },
|
|
78
|
+
});
|
|
79
|
+
signature = res?.[0]?.signature?.toHex?.() || uint8arrayToHex(res?.[0]?.signature as Uint8Array) || "";
|
|
80
|
+
console.log("signMessage solana res:", chainType, provider, message, signature);
|
|
81
|
+
return signature;
|
|
82
|
+
}
|
|
83
|
+
throw new Error("signMessage solana not supported");
|
|
42
84
|
} catch (error) {
|
|
85
|
+
console.log("signMessage solana error:", chainType, provider, message, error);
|
|
43
86
|
throw error as Error;
|
|
44
87
|
}
|
|
45
88
|
}
|
|
46
89
|
|
|
47
90
|
if (chainType === "aptos") {
|
|
48
91
|
try {
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
92
|
+
let signature = "";
|
|
93
|
+
if (provider?.signMessage) {
|
|
94
|
+
const res = await provider.signMessage({
|
|
95
|
+
message,
|
|
96
|
+
nonce,
|
|
97
|
+
});
|
|
98
|
+
signature = getAPTOSSignatureFromResponse(res);
|
|
99
|
+
console.log("signMessage aptos res:", chainType, provider, message, signature);
|
|
100
|
+
return signature;
|
|
101
|
+
}
|
|
102
|
+
if (provider?.["aptos:signMessage"]) {
|
|
103
|
+
const res = await provider["aptos:signMessage"]?.signMessage({
|
|
104
|
+
message,
|
|
105
|
+
nonce,
|
|
106
|
+
});
|
|
107
|
+
signature = getAPTOSSignatureFromResponse(res);
|
|
108
|
+
console.log("signMessage aptos res:", chainType, provider, message, signature);
|
|
109
|
+
return signature;
|
|
110
|
+
}
|
|
111
|
+
throw new Error("signMessage aptos not supported");
|
|
54
112
|
} catch (error) {
|
|
55
113
|
throw error as Error;
|
|
56
114
|
}
|
|
@@ -58,3 +116,48 @@ export const signMessage = async (data: { message: string; nonce: string }, wall
|
|
|
58
116
|
|
|
59
117
|
throw new Error(`signMessage not supported in ${chainType}`);
|
|
60
118
|
};
|
|
119
|
+
|
|
120
|
+
function getAPTOSSignatureFromResponse(res: any): string {
|
|
121
|
+
let signature = "";
|
|
122
|
+
if (typeof res === "object" && res?.args?.signature) {
|
|
123
|
+
const oSignature = res?.args?.signature;
|
|
124
|
+
// signature is an object with data and signature properties
|
|
125
|
+
if (typeof oSignature === "object" && oSignature?.data?.data) {
|
|
126
|
+
// some wallet signature is an object, can be converted to hex string
|
|
127
|
+
if (oSignature?.data?.data?.toHex) {
|
|
128
|
+
signature = oSignature?.data?.data?.toHex?.() || "";
|
|
129
|
+
} else if (typeof oSignature?.data?.data === "object") {
|
|
130
|
+
// the gate wallet signature is an object like { data: { data: { } } }, need to convert to hex string
|
|
131
|
+
signature = uint8arrayToHex(new Uint8Array(Object.values(oSignature?.data?.data))) || "";
|
|
132
|
+
} else {
|
|
133
|
+
signature = oSignature || "";
|
|
134
|
+
}
|
|
135
|
+
// signature is an object with signature property, like petra wallet
|
|
136
|
+
} else if (typeof oSignature === "object" && oSignature?.signature) {
|
|
137
|
+
signature = oSignature?.signature?.toString("hex") || "";
|
|
138
|
+
} else {
|
|
139
|
+
signature = oSignature || "";
|
|
140
|
+
}
|
|
141
|
+
// signature is a string, like okx wallet
|
|
142
|
+
} else if (res?.signature && typeof res?.signature === "string") {
|
|
143
|
+
signature = res?.signature || "";
|
|
144
|
+
}
|
|
145
|
+
return signature;
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
// delay open mobile wallet application, avoid immediate jump causing subsequent code to fail to execute
|
|
149
|
+
async function handleOpenMobileWalletDelayed(walletOptions: WalletOptions, delay: number = 100): Promise<void> {
|
|
150
|
+
// get deeplink, determine if a longer delay is needed
|
|
151
|
+
const { mobile } = (walletOptions.walletInfo as WalletInfo) || {};
|
|
152
|
+
const dappUrl = typeof window !== "undefined" ? window.location.href : "";
|
|
153
|
+
const chainId = walletOptions.account?.chainId ? parseInt(walletOptions.account.chainId, 16) : undefined;
|
|
154
|
+
const deeplink = await mobile?.getDeeplink?.(dappUrl, chainId);
|
|
155
|
+
if (!deeplink) return;
|
|
156
|
+
|
|
157
|
+
// if the deeplink does not start with http, a longer delay is needed to ensure provider.request has been started
|
|
158
|
+
const actualDelay = deeplink && !deeplink.startsWith("http") ? Math.max(delay, 300) : delay;
|
|
159
|
+
|
|
160
|
+
setTimeout(() => {
|
|
161
|
+
openUri(deeplink);
|
|
162
|
+
}, actualDelay);
|
|
163
|
+
}
|
package/src/wallets/Wallet.ts
CHANGED
|
@@ -2,7 +2,7 @@ export type WalletConfig = {
|
|
|
2
2
|
id: string;
|
|
3
3
|
name: string;
|
|
4
4
|
rdns?: string;
|
|
5
|
-
namespace
|
|
5
|
+
namespace?: string;
|
|
6
6
|
flag?: string;
|
|
7
7
|
solana?: {
|
|
8
8
|
namespace?: string;
|
|
@@ -16,6 +16,7 @@ export type WalletConfig = {
|
|
|
16
16
|
iconAccent?: string;
|
|
17
17
|
iconBackground: string;
|
|
18
18
|
installed?: boolean;
|
|
19
|
+
deeplink?: string;
|
|
19
20
|
downloadUrls?: {
|
|
20
21
|
android?: string;
|
|
21
22
|
ios?: string;
|
|
@@ -32,6 +33,10 @@ export type WalletConfig = {
|
|
|
32
33
|
linux?: string;
|
|
33
34
|
desktop?: string;
|
|
34
35
|
};
|
|
36
|
+
mobile?: {
|
|
37
|
+
getUri?: (uri: string) => string;
|
|
38
|
+
getDeeplink?: (dappUrl?: string, chainId?: number) => string | Promise<string>;
|
|
39
|
+
};
|
|
35
40
|
};
|
|
36
41
|
|
|
37
42
|
export type WagmiWalletConfig = any;
|
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
import type { WalletConfig } from "../../Wallet";
|
|
2
|
-
|
|
3
|
-
const backpackWalletIcon =
|
|
4
|
-
"";
|
|
2
|
+
import icon from "./backpackWallet.svg";
|
|
5
3
|
|
|
6
4
|
export const backpackWallet = (): WalletConfig => {
|
|
7
5
|
return {
|
|
@@ -9,7 +7,7 @@ export const backpackWallet = (): WalletConfig => {
|
|
|
9
7
|
name: "Backpack",
|
|
10
8
|
namespace: "backpack.ethereum",
|
|
11
9
|
rdns: "app.backpack.mobile",
|
|
12
|
-
icon
|
|
10
|
+
icon,
|
|
13
11
|
iconBackground: "#0C0D10",
|
|
14
12
|
downloadUrls: {
|
|
15
13
|
android: "https://play.google.com/store/apps/details?id=app.backpack.mobile",
|
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
import type { WalletConfig } from "../../Wallet";
|
|
2
|
-
|
|
3
|
-
const berasigWalletIcon =
|
|
4
|
-
"";
|
|
2
|
+
import icon from "./berasigWallet.svg";
|
|
5
3
|
|
|
6
4
|
export const berasigWallet = (): WalletConfig => {
|
|
7
5
|
return {
|
|
@@ -9,7 +7,7 @@ export const berasigWallet = (): WalletConfig => {
|
|
|
9
7
|
name: "BeraSig",
|
|
10
8
|
namespace: "berasig.ethereum",
|
|
11
9
|
rdns: "app.berasig",
|
|
12
|
-
icon
|
|
10
|
+
icon,
|
|
13
11
|
iconBackground: "#ffffff",
|
|
14
12
|
downloadUrls: {
|
|
15
13
|
android: "https://play.google.com/store/apps/details?id=io.berasig.ios",
|
|
@@ -1,7 +1,6 @@
|
|
|
1
|
+
import { isAndroid } from "../../../utils/isMobile";
|
|
1
2
|
import type { WalletConfig } from "../../Wallet";
|
|
2
|
-
|
|
3
|
-
const binanceWalletIcon =
|
|
4
|
-
"";
|
|
3
|
+
import icon from "./binanceWallet.svg";
|
|
5
4
|
|
|
6
5
|
export const binanceWallet = (): WalletConfig => {
|
|
7
6
|
return {
|
|
@@ -10,7 +9,7 @@ export const binanceWallet = (): WalletConfig => {
|
|
|
10
9
|
namespace: "binancew3w.isExtension",
|
|
11
10
|
flag: "isBinance",
|
|
12
11
|
rdns: "com.binance.wallet",
|
|
13
|
-
icon
|
|
12
|
+
icon,
|
|
14
13
|
iconBackground: "#000000",
|
|
15
14
|
downloadUrls: {
|
|
16
15
|
android: "https://play.google.com/store/apps/details?id=com.binance.dev",
|
|
@@ -19,5 +18,31 @@ export const binanceWallet = (): WalletConfig => {
|
|
|
19
18
|
qrCode: "https://www.binance.com/en/web3wallet",
|
|
20
19
|
chrome: "https://chromewebstore.google.com/detail/cadiboklkpojfamcoggejbbdjcoiljjk",
|
|
21
20
|
},
|
|
21
|
+
mobile: {
|
|
22
|
+
getUri: (uri: string) => {
|
|
23
|
+
return isAndroid() ? uri : `bnc://app.binance.com/cedefi/wc?uri=${encodeURIComponent(uri)}`;
|
|
24
|
+
},
|
|
25
|
+
getDeeplink: async (dappUrl?: string, chainId?: number): Promise<string> => {
|
|
26
|
+
if (!dappUrl) return "";
|
|
27
|
+
// Binance wallet uses @binance/w3w-utils for deep link generation
|
|
28
|
+
// This is a fallback implementation. For full support, use the binance utils package
|
|
29
|
+
try {
|
|
30
|
+
// Try to use binance utils if available
|
|
31
|
+
const binanceUtils = await import("@binance/w3w-utils").catch(() => null);
|
|
32
|
+
if (binanceUtils && "getDeepLink" in binanceUtils) {
|
|
33
|
+
const getDeepLink = binanceUtils.getDeepLink as (
|
|
34
|
+
url: string,
|
|
35
|
+
chainId?: number,
|
|
36
|
+
) => { http: string; bnc: string };
|
|
37
|
+
const result = getDeepLink(dappUrl, chainId);
|
|
38
|
+
return result?.http || "";
|
|
39
|
+
}
|
|
40
|
+
} catch (e) {
|
|
41
|
+
// Fallback if binance utils not available
|
|
42
|
+
}
|
|
43
|
+
// Fallback: use binance deep link format
|
|
44
|
+
return `bnc://app.binance.com/cedefi/dapp?url=${encodeURIComponent(dappUrl)}`;
|
|
45
|
+
},
|
|
46
|
+
},
|
|
22
47
|
};
|
|
23
48
|
};
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import type { WalletConfig } from "../../Wallet";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
"";
|
|
2
|
+
import { isAndroid } from "../../../utils/isMobile";
|
|
3
|
+
import icon from "./bitgetWallet.svg";
|
|
5
4
|
|
|
6
5
|
export const bitgetWallet = (): WalletConfig => {
|
|
7
6
|
return {
|
|
@@ -15,7 +14,7 @@ export const bitgetWallet = (): WalletConfig => {
|
|
|
15
14
|
namespace: "bitkeep.aptos",
|
|
16
15
|
},
|
|
17
16
|
rdns: "com.bitget.web3",
|
|
18
|
-
icon
|
|
17
|
+
icon,
|
|
19
18
|
iconAccent: "#f6851a",
|
|
20
19
|
iconBackground: "#fff",
|
|
21
20
|
downloadUrls: {
|
|
@@ -26,5 +25,14 @@ export const bitgetWallet = (): WalletConfig => {
|
|
|
26
25
|
chrome: "https://chrome.google.com/webstore/detail/bitkeep-crypto-nft-wallet/jiidiaalihmmhddjgbnbgdfflelocpak",
|
|
27
26
|
browserExtension: "https://web3.bitget.com/en/wallet-download",
|
|
28
27
|
},
|
|
28
|
+
mobile: {
|
|
29
|
+
getUri: (uri: string) => {
|
|
30
|
+
return isAndroid() ? uri : `bitkeep://wc?uri=${encodeURIComponent(uri)}`;
|
|
31
|
+
},
|
|
32
|
+
getDeeplink: (dappUrl?: string): string => {
|
|
33
|
+
if (!dappUrl) return "";
|
|
34
|
+
return `https://bkcode.vip?action=dapp&url=${dappUrl}`;
|
|
35
|
+
},
|
|
36
|
+
},
|
|
29
37
|
};
|
|
30
38
|
};
|
|
@@ -1,14 +1,12 @@
|
|
|
1
1
|
import type { WalletConfig } from "../../Wallet";
|
|
2
|
-
|
|
3
|
-
const bitskiWalletIcon =
|
|
4
|
-
"";
|
|
2
|
+
import icon from "./bitskiWallet.svg";
|
|
5
3
|
|
|
6
4
|
export const bitskiWallet = (): WalletConfig => ({
|
|
7
5
|
id: "bitski",
|
|
8
6
|
name: "Bitski",
|
|
9
7
|
namespace: "",
|
|
10
8
|
flag: "isBitski",
|
|
11
|
-
icon
|
|
9
|
+
icon,
|
|
12
10
|
iconBackground: "#fff",
|
|
13
11
|
downloadUrls: {
|
|
14
12
|
chrome: "https://chrome.google.com/webstore/detail/bitski/feejiigddaafeojfddjjlmfkabimkell",
|
|
@@ -1,17 +1,18 @@
|
|
|
1
1
|
import type { WalletConfig } from "../../Wallet";
|
|
2
|
-
|
|
3
|
-
const bitverseWalletIcon =
|
|
4
|
-
"";
|
|
2
|
+
import icon from "./bitverseWallet.svg";
|
|
5
3
|
|
|
6
4
|
export const bitverseWallet = (): WalletConfig => ({
|
|
7
5
|
id: "bitverse",
|
|
8
6
|
name: "Bitverse Wallet",
|
|
9
7
|
namespace: "",
|
|
10
|
-
icon
|
|
8
|
+
icon,
|
|
11
9
|
iconBackground: "#171728",
|
|
12
10
|
downloadUrls: {
|
|
13
11
|
android: "https://play.google.com/store/apps/details?id=com.bitverse.app&pli=1",
|
|
14
12
|
ios: "https://apps.apple.com/us/app/bitverse-discover-web3-wealth/id1645515614",
|
|
15
13
|
qrCode: "https://www.bitverse.zone/download",
|
|
16
14
|
},
|
|
15
|
+
mobile: {
|
|
16
|
+
getUri: (uri: string) => `bitverseapp://open/wallet/wc?uri=${encodeURIComponent(uri)}`,
|
|
17
|
+
},
|
|
17
18
|
});
|
|
@@ -1,14 +1,12 @@
|
|
|
1
1
|
import type { WalletConfig } from "../../Wallet";
|
|
2
|
-
|
|
3
|
-
const bloomWalletIcon =
|
|
4
|
-
"";
|
|
2
|
+
import icon from "./bloomWallet.svg";
|
|
5
3
|
|
|
6
4
|
export const bloomWallet = (): WalletConfig => ({
|
|
7
5
|
id: "bloom",
|
|
8
6
|
name: "Bloom Wallet",
|
|
9
7
|
iconBackground: "#000",
|
|
10
8
|
iconAccent: "#000",
|
|
11
|
-
icon
|
|
9
|
+
icon,
|
|
12
10
|
downloadUrls: {
|
|
13
11
|
desktop: "https://bloomwallet.io/",
|
|
14
12
|
},
|
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
import type { WalletConfig } from "../../Wallet";
|
|
2
|
-
|
|
3
|
-
const braveWalletIcon =
|
|
4
|
-
"";
|
|
2
|
+
import icon from "./braveWallet.svg";
|
|
5
3
|
|
|
6
4
|
export const braveWallet = (): WalletConfig => ({
|
|
7
5
|
id: "brave",
|
|
@@ -9,7 +7,7 @@ export const braveWallet = (): WalletConfig => ({
|
|
|
9
7
|
namespace: "",
|
|
10
8
|
flag: "isBraveWallet",
|
|
11
9
|
rdns: "com.brave.wallet",
|
|
12
|
-
icon
|
|
10
|
+
icon,
|
|
13
11
|
iconBackground: "#fff",
|
|
14
12
|
downloadUrls: {
|
|
15
13
|
// We're opting not to provide a download prompt if Brave isn't the current
|
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
import type { WalletConfig } from "../../Wallet";
|
|
2
|
-
|
|
3
|
-
const bybitWalletIcon =
|
|
4
|
-
"";
|
|
2
|
+
import icon from "./bybitWallet.svg";
|
|
5
3
|
|
|
6
4
|
export const bybitWallet = (): WalletConfig => {
|
|
7
5
|
return {
|
|
@@ -9,7 +7,7 @@ export const bybitWallet = (): WalletConfig => {
|
|
|
9
7
|
name: "Bybit Wallet",
|
|
10
8
|
namespace: "bybitWallet",
|
|
11
9
|
rdns: "com.bybit",
|
|
12
|
-
icon
|
|
10
|
+
icon,
|
|
13
11
|
iconBackground: "#000000",
|
|
14
12
|
downloadUrls: {
|
|
15
13
|
chrome: "https://chromewebstore.google.com/detail/bybit-wallet/pdliaogehgdbhbnmkklieghmmjkpigpa",
|
|
@@ -19,5 +17,10 @@ export const bybitWallet = (): WalletConfig => {
|
|
|
19
17
|
mobile: "https://www.bybit.com/en/web3",
|
|
20
18
|
qrCode: "https://www.bybit.com/en/web3",
|
|
21
19
|
},
|
|
20
|
+
mobile: {
|
|
21
|
+
getUri: (uri: string) => {
|
|
22
|
+
return `bybitapp://open/route?targetUrl=by://web3/walletconnect/wc?uri=${encodeURIComponent(uri)}`;
|
|
23
|
+
},
|
|
24
|
+
},
|
|
22
25
|
};
|
|
23
26
|
};
|
|
@@ -1,14 +1,12 @@
|
|
|
1
1
|
import type { WalletConfig } from "../../Wallet";
|
|
2
|
-
|
|
3
|
-
const clvWalletIcon =
|
|
4
|
-
"";
|
|
2
|
+
import icon from "./clvWallet.svg";
|
|
5
3
|
|
|
6
4
|
export const clvWallet = (): WalletConfig => {
|
|
7
5
|
return {
|
|
8
6
|
id: "clv",
|
|
9
7
|
name: "CLV",
|
|
10
8
|
namespace: "clover",
|
|
11
|
-
icon
|
|
9
|
+
icon,
|
|
12
10
|
iconBackground: "#fff",
|
|
13
11
|
iconAccent: "#BDFDE2",
|
|
14
12
|
downloadUrls: {
|
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
import type { WalletConfig } from "../../Wallet";
|
|
2
|
-
|
|
3
|
-
const coin98WalletIcon =
|
|
4
|
-
"";
|
|
2
|
+
import icon from "./coin98Wallet.svg";
|
|
5
3
|
|
|
6
4
|
export const coin98Wallet = (): WalletConfig => {
|
|
7
5
|
return {
|
|
@@ -9,7 +7,7 @@ export const coin98Wallet = (): WalletConfig => {
|
|
|
9
7
|
name: "Coin98 Wallet",
|
|
10
8
|
namespace: "coin98.provider",
|
|
11
9
|
flag: "isCoin98",
|
|
12
|
-
icon
|
|
10
|
+
icon,
|
|
13
11
|
iconAccent: "#CDA349",
|
|
14
12
|
iconBackground: "#fff",
|
|
15
13
|
rdns: "com.coin98",
|
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
import type { WalletConfig } from "../../Wallet";
|
|
2
|
-
|
|
3
|
-
const coinbaseWalletIcon =
|
|
4
|
-
"";
|
|
2
|
+
import icon from "./coinbaseWallet.svg";
|
|
5
3
|
|
|
6
4
|
export const coinbaseWallet = (): WalletConfig => {
|
|
7
5
|
return {
|
|
@@ -10,7 +8,7 @@ export const coinbaseWallet = (): WalletConfig => {
|
|
|
10
8
|
namespace: "",
|
|
11
9
|
flag: "isCoinbaseWallet",
|
|
12
10
|
rdns: "com.coinbase.wallet",
|
|
13
|
-
icon
|
|
11
|
+
icon,
|
|
14
12
|
iconAccent: "#2c5ff6",
|
|
15
13
|
iconBackground: "#2c5ff6",
|
|
16
14
|
downloadUrls: {
|
|
@@ -21,5 +19,12 @@ export const coinbaseWallet = (): WalletConfig => {
|
|
|
21
19
|
chrome: "https://chrome.google.com/webstore/detail/coinbase-wallet-extension/hnfanknocfeofbddgcijnmhnfnkdnaad",
|
|
22
20
|
browserExtension: "https://coinbase.com/wallet",
|
|
23
21
|
},
|
|
22
|
+
mobile: {
|
|
23
|
+
getDeeplink: (dappUrl?: string): string => {
|
|
24
|
+
if (!dappUrl) return "";
|
|
25
|
+
const encodedDappUrl = encodeURIComponent(dappUrl);
|
|
26
|
+
return `https://go.cb-w.com/dapp?cb_url=${encodedDappUrl}`;
|
|
27
|
+
},
|
|
28
|
+
},
|
|
24
29
|
};
|
|
25
30
|
};
|
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
import type { WalletConfig } from "../../Wallet";
|
|
2
|
-
|
|
3
|
-
const compassWalletIcon =
|
|
4
|
-
"";
|
|
2
|
+
import icon from "./compassWallet.svg";
|
|
5
3
|
|
|
6
4
|
export const compassWallet = (): WalletConfig => {
|
|
7
5
|
return {
|
|
@@ -9,7 +7,7 @@ export const compassWallet = (): WalletConfig => {
|
|
|
9
7
|
name: "Compass Wallet",
|
|
10
8
|
namespace: "compassEvm",
|
|
11
9
|
rdns: "io.leapwallet.CompassWallet",
|
|
12
|
-
icon
|
|
10
|
+
icon,
|
|
13
11
|
iconBackground: "#fff",
|
|
14
12
|
downloadUrls: {
|
|
15
13
|
chrome: "https://chromewebstore.google.com/detail/compass-wallet-for-sei/anokgmphncpekkhclmingpimjmcooifb",
|