@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.
Files changed (109) hide show
  1. package/dist/index.cjs +1024 -330
  2. package/dist/index.d.cts +172 -6
  3. package/dist/index.d.ts +172 -6
  4. package/dist/index.js +955 -332
  5. package/package.json +4 -2
  6. package/project.json +2 -2
  7. package/src/global.d.ts +7 -0
  8. package/src/index.ts +14 -8
  9. package/src/type.ts +13 -0
  10. package/src/utils/browsers.ts +13 -0
  11. package/src/utils/chainId.ts +1 -1
  12. package/src/utils/isMobile.ts +1 -1
  13. package/src/utils/log.ts +7 -0
  14. package/src/utils/utils.ts +5 -0
  15. package/src/wallet-api/balance.ts +4 -2
  16. package/src/wallet-api/chain.ts +9 -2
  17. package/src/wallet-api/connect.ts +142 -12
  18. package/src/wallet-api/sign-in.ts +23 -26
  19. package/src/wallet-api/sign-message.ts +116 -13
  20. package/src/wallets/Wallet.ts +6 -1
  21. package/src/wallets/default/backpackWallet/backpackWallet.ts +2 -4
  22. package/src/wallets/default/berasigWallet/berasigWallet.ts +2 -4
  23. package/src/wallets/default/binanceWallet/binanceWallet.ts +29 -4
  24. package/src/wallets/default/bitgetWallet/bitgetWallet.ts +12 -4
  25. package/src/wallets/default/bitskiWallet/bitskiWallet.ts +2 -4
  26. package/src/wallets/default/bitverseWallet/bitverseWallet.ts +5 -4
  27. package/src/wallets/default/bloomWallet/bloomWallet.ts +2 -4
  28. package/src/wallets/default/braveWallet/braveWallet.ts +2 -4
  29. package/src/wallets/default/bybitWallet/bybitWallet.ts +7 -4
  30. package/src/wallets/default/clvWallet/clvWallet.ts +2 -4
  31. package/src/wallets/default/coin98Wallet/coin98Wallet.ts +2 -4
  32. package/src/wallets/default/coinbaseWallet/coinbaseWallet.ts +9 -4
  33. package/src/wallets/default/compassWallet/compassWallet.ts +2 -4
  34. package/src/wallets/default/coreWallet/coreWallet.ts +2 -4
  35. package/src/wallets/default/ctrlWallet/ctrlWallet.ts +2 -4
  36. package/src/wallets/default/dawnWallet/dawnWallet.ts +2 -4
  37. package/src/wallets/default/desigWallet/desigWallet.ts +2 -4
  38. package/src/wallets/default/enkryptWallet/enkryptWallet.ts +2 -4
  39. package/src/wallets/default/foxWallet/foxWallet.ts +7 -4
  40. package/src/wallets/default/frameWallet/frameWallet.ts +2 -4
  41. package/src/wallets/default/gateWallet/gateWallet.ts +8 -4
  42. package/src/wallets/default/imTokenWallet/imTokenWallet.ts +11 -4
  43. package/src/wallets/default/injectedWallet/injectedWallet.ts +2 -4
  44. package/src/wallets/default/iopayWallet/iopayWallet.ts +8 -4
  45. package/src/wallets/default/kaiaWallet/kaiaWallet.ts +7 -4
  46. package/src/wallets/default/kaikasWallet/kaikasWallet.ts +7 -4
  47. package/src/wallets/default/krakenWallet/krakenWallet.ts +7 -4
  48. package/src/wallets/default/kresusWallet/kresusWallet.ts +5 -4
  49. package/src/wallets/default/ledgerWallet/ledgerWallet.ts +8 -4
  50. package/src/wallets/default/magicEdenWallet/magicEdenWallet.ts +5 -7
  51. package/src/wallets/default/mathWallet/mathWallet.svg +9 -0
  52. package/src/wallets/default/mathWallet/mathWallet.ts +2 -2
  53. package/src/wallets/default/metaMaskWallet/metaMaskWallet.ts +20 -2
  54. package/src/wallets/default/myDogeWallet/mydogeWallet.ts +1 -1
  55. package/src/wallets/default/nestWallet/nestWallet.ts +2 -4
  56. package/src/wallets/default/novaWallet/novaWallet.ts +2 -4
  57. package/src/wallets/default/oktoWallet/oktoWallet.ts +8 -4
  58. package/src/wallets/default/okxWallet/okxWallet.ts +13 -4
  59. package/src/wallets/default/omniWallet/omniWallet.ts +8 -4
  60. package/src/wallets/default/oneInchWallet/oneInchWallet.svg +30 -1
  61. package/src/wallets/default/oneInchWallet/oneInchWallet.ts +5 -4
  62. package/src/wallets/default/oneKeyWallet/oneKeyWallet.ts +2 -4
  63. package/src/wallets/default/paraSwapWallet/paraswapWallet.ts +7 -4
  64. package/src/wallets/default/petraWallet/petraWallet.svg +5 -0
  65. package/src/wallets/default/petraWallet/petraWallet.ts +24 -0
  66. package/src/wallets/default/phantomWallet/phantomWallet.ts +9 -4
  67. package/src/wallets/default/rabbyWallet/rabbyWallet.ts +2 -4
  68. package/src/wallets/default/rainbowWallet/rainbowWallet.ts +12 -4
  69. package/src/wallets/default/ramperWallet/ramperWallet.ts +2 -4
  70. package/src/wallets/default/readyWallet/readyWallet.ts +2 -4
  71. package/src/wallets/default/roninWallet/roninWallet.ts +2 -4
  72. package/src/wallets/default/safeWallet/safeWallet.ts +2 -4
  73. package/src/wallets/default/safeheronWallet/safeheronWallet.ts +2 -4
  74. package/src/wallets/default/safepalWallet/safepalWallet.ts +2 -4
  75. package/src/wallets/default/seifWallet/seifWallet.ts +2 -4
  76. package/src/wallets/default/solflareWallet/solflareWallet.svg +11 -0
  77. package/src/wallets/default/solflareWallet/solflareWallet.ts +9 -2
  78. package/src/wallets/default/subWallet/subWallet.ts +2 -4
  79. package/src/wallets/default/tahoWallet/tahoWallet.ts +2 -4
  80. package/src/wallets/default/talismanWallet/talismanWallet.ts +2 -4
  81. package/src/wallets/default/tokenPocketWallet/tokenPocketWallet.ts +8 -4
  82. package/src/wallets/default/tokenaryWallet/tokenaryWallet.ts +2 -4
  83. package/src/wallets/default/trezorWallet/trezorWallet.svg +7 -0
  84. package/src/wallets/default/trezorWallet/trezorWallet.ts +2 -2
  85. package/src/wallets/default/trustWallet/trustWallet.ts +9 -5
  86. package/src/wallets/default/uniswapWallet/uniswapWallet.ts +7 -4
  87. package/src/wallets/default/universalProfilesWallet/universalProfilesWallet.svg +13 -1351
  88. package/src/wallets/default/universalProfilesWallet/universalProfilesWallet.ts +2 -2
  89. package/src/wallets/default/valoraWallet/valoraWallet.ts +6 -4
  90. package/src/wallets/default/walletConnectWallet/walletConnectWallet.ts +2 -4
  91. package/src/wallets/default/wigwamWallet/wigwamWallet.ts +2 -4
  92. package/src/wallets/default/xPortalWallet/xPortalWallet.ts +2 -4
  93. package/src/wallets/default/zealWallet/zealWallet.ts +7 -4
  94. package/src/wallets/default/zerionWallet/zerionWallet.ts +8 -4
  95. package/src/wallets/default/zilPayWallet/zilPayWallet.ts +2 -4
  96. package/src/wallets/defaultConnectors.ts +213 -0
  97. package/src/wallets/detector.ts +34 -17
  98. package/src/wallets/index.ts +7 -76
  99. package/src/wallets/providers/WalletConnectProvider.ts +3 -2
  100. package/src/wallets/wallet-standard.ts +147 -47
  101. package/src/wallets/wallet-walletconnect.ts +1 -1
  102. package/tsconfig.json +4 -1
  103. package/tsup.config.ts +55 -0
  104. package/src/wallets/default/mathWallet/icon.ts +0 -2
  105. package/src/wallets/default/metaMaskWallet/icon.ts +0 -2
  106. package/src/wallets/default/myDogeWallet/icon.ts +0 -2
  107. package/src/wallets/default/solflareWallet/icon.ts +0 -2
  108. package/src/wallets/default/trezorWallet/icon.ts +0 -2
  109. 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 (data: { message: string; nonce: string }, walletOptions: WalletOptions) => {
16
- const { chainType, account, provider } = walletOptions;
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
- const sign: string = await provider.request({
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
- return sign;
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
- const { signature } = await provider.signMessage(encodedMessage, "utf8");
41
- return signature;
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
- const { signature } = await provider.signMessage({
50
- message,
51
- nonce,
52
- });
53
- return signature;
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
+ }
@@ -2,7 +2,7 @@ export type WalletConfig = {
2
2
  id: string;
3
3
  name: string;
4
4
  rdns?: string;
5
- namespace: string;
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: backpackWalletIcon,
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: berasigWalletIcon,
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: binanceWalletIcon,
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
- const bitgetWalletIcon =
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: bitgetWalletIcon,
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: bitskiWalletIcon,
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: bitverseWalletIcon,
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: bloomWalletIcon,
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: braveWalletIcon,
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: bybitWalletIcon,
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: clvWalletIcon,
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: coin98WalletIcon,
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: coinbaseWalletIcon,
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: compassWalletIcon,
10
+ icon,
13
11
  iconBackground: "#fff",
14
12
  downloadUrls: {
15
13
  chrome: "https://chromewebstore.google.com/detail/compass-wallet-for-sei/anokgmphncpekkhclmingpimjmcooifb",