@getpara/evm-wallet-connectors 2.0.0-alpha.7 → 2.0.0-alpha.71

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 (61) hide show
  1. package/README.md +20 -0
  2. package/dist/connectors/walletConnect.d.ts +63 -0
  3. package/dist/connectors/walletConnect.js +366 -0
  4. package/dist/index.d.ts +4 -2
  5. package/dist/index.js +5 -1
  6. package/dist/providers/EvmExternalWalletContext.d.ts +7 -35
  7. package/dist/providers/EvmExternalWalletContext.js +280 -86
  8. package/dist/providers/ParaEvmContext.d.ts +2 -1
  9. package/dist/providers/ParaEvmContext.js +49 -7
  10. package/dist/providers/createParaWagmiConfig.d.ts +10 -0
  11. package/dist/providers/createParaWagmiConfig.js +65 -0
  12. package/dist/providers/externalHooks.d.ts +7 -0
  13. package/dist/providers/externalHooks.js +7 -0
  14. package/dist/stores/wagmiConfigStore.d.ts +14 -0
  15. package/dist/stores/wagmiConfigStore.js +16 -0
  16. package/dist/types/Wallet.d.ts +5 -1
  17. package/dist/types/utils.d.ts +1 -1
  18. package/dist/utils/getWalletConnectConnector.js +1 -1
  19. package/dist/utils/getWalletConnectUri.d.ts +1 -1
  20. package/dist/utils/getWalletConnectUri.js +20 -14
  21. package/dist/utils/isEIP6963Connector.js +1 -1
  22. package/dist/utils/resolveWalletList.d.ts +3 -0
  23. package/dist/utils/resolveWalletList.js +16 -0
  24. package/dist/wallets/connectors/backpack/backpack.d.ts +3 -0
  25. package/dist/wallets/connectors/backpack/backpack.js +31 -0
  26. package/dist/wallets/connectors/backpack/backpackIcon.d.ts +1 -0
  27. package/dist/wallets/connectors/backpack/backpackIcon.js +6 -0
  28. package/dist/wallets/connectors/coinbase/coinbase.js +1 -0
  29. package/dist/wallets/connectors/farcaster/farcaster.d.ts +2 -0
  30. package/dist/wallets/connectors/farcaster/farcaster.js +22 -0
  31. package/dist/wallets/connectors/farcaster/farcasterIcon.d.ts +1 -0
  32. package/dist/wallets/connectors/farcaster/farcasterIcon.js +6 -0
  33. package/dist/wallets/connectors/haha/haha.d.ts +3 -0
  34. package/dist/wallets/connectors/haha/haha.js +31 -0
  35. package/dist/wallets/connectors/haha/hahaIcon.d.ts +1 -0
  36. package/dist/wallets/connectors/haha/hahaIcon.js +6 -0
  37. package/dist/wallets/connectors/index.d.ts +7 -1
  38. package/dist/wallets/connectors/index.js +18 -1
  39. package/dist/wallets/connectors/metaMask/metaMask.js +8 -4
  40. package/dist/wallets/connectors/metaMask/metaMaskIcon.d.ts +1 -1
  41. package/dist/wallets/connectors/metaMask/metaMaskIcon.js +1 -1
  42. package/dist/wallets/connectors/okx/okx.d.ts +3 -0
  43. package/dist/wallets/connectors/okx/okx.js +32 -0
  44. package/dist/wallets/connectors/okx/okxIcon.d.ts +1 -0
  45. package/dist/wallets/connectors/okx/okxIcon.js +6 -0
  46. package/dist/wallets/connectors/phantom/phantom.d.ts +3 -0
  47. package/dist/wallets/connectors/phantom/phantom.js +31 -0
  48. package/dist/wallets/connectors/phantom/phantomIcon.d.ts +1 -0
  49. package/dist/wallets/connectors/phantom/phantomIcon.js +6 -0
  50. package/dist/wallets/connectors/rabby/rabby.js +1 -0
  51. package/dist/wallets/connectors/rainbow/rainbow.js +8 -1
  52. package/dist/wallets/connectors/safe/safe.js +1 -0
  53. package/dist/wallets/connectors/valora/valora.d.ts +3 -0
  54. package/dist/wallets/connectors/valora/valora.js +29 -0
  55. package/dist/wallets/connectors/valora/valoraIcon.d.ts +1 -0
  56. package/dist/wallets/connectors/valora/valoraIcon.js +6 -0
  57. package/dist/wallets/connectors/walletConnect/walletConnect.js +1 -0
  58. package/dist/wallets/connectors/zerion/zerion.js +5 -1
  59. package/dist/wallets/connectorsForWallets.d.ts +4 -1
  60. package/dist/wallets/connectorsForWallets.js +14 -3
  61. package/package.json +34 -26
@@ -1,6 +1,6 @@
1
1
  "use client";
2
2
  import "../../../chunk-MMUBH76A.js";
3
- const icon = "";
3
+ const icon = "";
4
4
  export {
5
5
  icon
6
6
  };
@@ -0,0 +1,3 @@
1
+ import { DefaultWalletOptions, Wallet } from '../../../types/Wallet.js';
2
+ export type OKXWalletOptions = DefaultWalletOptions;
3
+ export declare const okxWallet: ({ projectId, walletConnectParameters }: OKXWalletOptions) => Wallet;
@@ -0,0 +1,32 @@
1
+ "use client";
2
+ import "../../../chunk-MMUBH76A.js";
3
+ import { isAndroid } from "@getpara/web-sdk";
4
+ import { getInjectedConnector, hasInjectedProvider } from "../../../utils/getInjectedConnector.js";
5
+ import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnector.js";
6
+ import { icon } from "./okxIcon.js";
7
+ const okxWallet = ({ projectId, walletConnectParameters }) => {
8
+ const isOKXInjected = hasInjectedProvider({ namespace: "okxwallet" });
9
+ const shouldUseWalletConnect = !isOKXInjected;
10
+ const getUri = (uri) => {
11
+ return isAndroid() ? uri : `okex://main/wc?uri=${encodeURIComponent(uri)}`;
12
+ };
13
+ return {
14
+ id: "okx",
15
+ internalId: "OKX",
16
+ name: "OKX Wallet",
17
+ rdns: "com.okex.wallet",
18
+ iconUrl: icon,
19
+ installed: isOKXInjected,
20
+ isExtension: true,
21
+ isMobile: true,
22
+ getUri,
23
+ downloadUrl: "https://okx.com/download",
24
+ createConnector: shouldUseWalletConnect ? getWalletConnectConnector({
25
+ projectId,
26
+ walletConnectParameters
27
+ }) : getInjectedConnector({ namespace: "okxwallet" })
28
+ };
29
+ };
30
+ export {
31
+ okxWallet
32
+ };
@@ -0,0 +1 @@
1
+ export declare const icon = "";
@@ -0,0 +1,6 @@
1
+ "use client";
2
+ import "../../../chunk-MMUBH76A.js";
3
+ const icon = "";
4
+ export {
5
+ icon
6
+ };
@@ -0,0 +1,3 @@
1
+ import { DefaultWalletOptions, Wallet } from '../../../types/Wallet.js';
2
+ export type PhantomWalletOptions = DefaultWalletOptions;
3
+ export declare const phantomWallet: ({ projectId, walletConnectParameters }: PhantomWalletOptions) => Wallet;
@@ -0,0 +1,31 @@
1
+ "use client";
2
+ import "../../../chunk-MMUBH76A.js";
3
+ import { getInjectedConnector, hasInjectedProvider } from "../../../utils/getInjectedConnector.js";
4
+ import { icon } from "./phantomIcon.js";
5
+ import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnector.js";
6
+ const phantomWallet = ({ projectId, walletConnectParameters }) => {
7
+ const isPhantomInjected = hasInjectedProvider({ namespace: "phantom.ethereum" });
8
+ const shouldUseWalletConnect = !isPhantomInjected;
9
+ const getUri = (uri) => {
10
+ return uri;
11
+ };
12
+ return {
13
+ id: "phantom",
14
+ internalId: "PHANTOM",
15
+ name: "Phantom",
16
+ rdns: "app.phantom",
17
+ iconUrl: icon,
18
+ installed: isPhantomInjected,
19
+ isExtension: true,
20
+ isMobile: true,
21
+ getUri,
22
+ downloadUrl: "https://phantom.app/download",
23
+ createConnector: shouldUseWalletConnect ? getWalletConnectConnector({
24
+ projectId,
25
+ walletConnectParameters
26
+ }) : getInjectedConnector({ namespace: "phantom.ethereum" })
27
+ };
28
+ };
29
+ export {
30
+ phantomWallet
31
+ };
@@ -0,0 +1 @@
1
+ export declare const icon = "";
@@ -0,0 +1,6 @@
1
+ "use client";
2
+ import "../../../chunk-MMUBH76A.js";
3
+ const icon = "";
4
+ export {
5
+ icon
6
+ };
@@ -7,6 +7,7 @@ const rabbyWallet = ({ projectId, walletConnectParameters }) => {
7
7
  const isRabbyInjected = hasInjectedProvider({ flag: "isRabby" });
8
8
  return {
9
9
  id: "rabby",
10
+ internalId: "RABBY",
10
11
  name: "Rabby Wallet",
11
12
  rdns: "io.rabby",
12
13
  iconUrl: icon,
@@ -6,11 +6,17 @@ import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnec
6
6
  import { icon } from "./rainbowIcon.js";
7
7
  const rainbowWallet = ({ projectId, walletConnectParameters }) => {
8
8
  const isRainbowInjected = hasInjectedProvider({ flag: "isRainbow" });
9
+ const deeplinkUri = "rainbow://";
10
+ const baseUri = isAndroid() ? `${deeplinkUri}wc` : isIOS() ? !isTelegram() ? (
11
+ // currently broken in MetaMask v6.5.0 https://github.com/MetaMask/metamask-mobile/issues/6457
12
+ `${deeplinkUri}wc`
13
+ ) : "https://rnbwapp.com/wc" : "https://rnbwapp.com/wc";
9
14
  const getUri = (uri) => {
10
- return isAndroid() ? `rainbow://wc?uri=${encodeURIComponent(uri)}` : isIOS() ? !isTelegram() ? `rainbow://wc?uri=${encodeURIComponent(uri)}` : `https://rnbwapp.com/wc?uri=${encodeURIComponent(uri)}` : `https://rnbwapp.com/wc?uri=${encodeURIComponent(uri)}`;
15
+ return `${baseUri}?uri=${encodeURIComponent(uri)}`;
11
16
  };
12
17
  return {
13
18
  id: "rainbow",
19
+ internalId: "RAINBOW",
14
20
  name: "Rainbow",
15
21
  rdns: "me.rainbow",
16
22
  iconUrl: icon,
@@ -19,6 +25,7 @@ const rainbowWallet = ({ projectId, walletConnectParameters }) => {
19
25
  isMobile: true,
20
26
  downloadUrl: "https://rainbow.me/",
21
27
  getUri,
28
+ deeplinkUri,
22
29
  createConnector: isRainbowInjected ? getInjectedConnector({ flag: "isRainbow" }) : getWalletConnectConnector({
23
30
  projectId,
24
31
  walletConnectParameters
@@ -7,6 +7,7 @@ import { safe } from "wagmi/connectors";
7
7
  import { icon } from "./safeIcon.js";
8
8
  const safeWallet = () => ({
9
9
  id: "safe",
10
+ internalId: "SAFE",
10
11
  name: "Safe",
11
12
  rdns: "io.safe",
12
13
  iconUrl: icon,
@@ -0,0 +1,3 @@
1
+ import type { DefaultWalletOptions, Wallet } from '../../../types/Wallet.js';
2
+ export type ValoraWalletOptions = DefaultWalletOptions;
3
+ export declare const valoraWallet: ({ projectId, walletConnectParameters }: ValoraWalletOptions) => Wallet;
@@ -0,0 +1,29 @@
1
+ "use client";
2
+ import "../../../chunk-MMUBH76A.js";
3
+ import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnector.js";
4
+ import { icon } from "./valoraIcon.js";
5
+ import { isMobile } from "@getpara/web-sdk";
6
+ const valoraWallet = ({ projectId, walletConnectParameters }) => {
7
+ const getUri = (uri) => {
8
+ return !isMobile() ? uri : `celo://wallet/wc?uri=${encodeURIComponent(uri)}`;
9
+ };
10
+ return {
11
+ id: "valora",
12
+ internalId: "VALORA",
13
+ name: "Valora",
14
+ rdns: "co.clabs.valora",
15
+ iconUrl: icon,
16
+ installed: false,
17
+ isExtension: false,
18
+ isMobile: true,
19
+ downloadUrl: "https://valora.xyz",
20
+ getUri,
21
+ createConnector: getWalletConnectConnector({
22
+ projectId,
23
+ walletConnectParameters
24
+ })
25
+ };
26
+ };
27
+ export {
28
+ valoraWallet
29
+ };
@@ -0,0 +1 @@
1
+ export declare const icon = "";
@@ -0,0 +1,6 @@
1
+ "use client";
2
+ import "../../../chunk-MMUBH76A.js";
3
+ const icon = "";
4
+ export {
5
+ icon
6
+ };
@@ -6,6 +6,7 @@ const walletConnectWallet = ({ projectId, options }) => {
6
6
  const getUri = (uri) => uri;
7
7
  return {
8
8
  id: "walletConnect",
9
+ internalId: "WALLETCONNECT",
9
10
  name: "WalletConnect",
10
11
  installed: void 0,
11
12
  iconUrl: icon,
@@ -9,11 +9,14 @@ const zerionWallet = ({ projectId, walletConnectParameters }) => {
9
9
  namespace: "zerionWallet",
10
10
  flag: "isZerion"
11
11
  });
12
+ const deeplinkUri = "zerion://";
13
+ const baseUri = isTelegram() && isIOS() ? "https://app.zerion.io/wc" : `${deeplinkUri}wc`;
12
14
  const getUri = (uri) => {
13
- return isTelegram() && isIOS() ? `https://app.zerion.io/wc?uri=${encodeURIComponent(uri)}` : `zerion://wc?uri=${encodeURIComponent(uri)}`;
15
+ return `${baseUri}?uri=${encodeURIComponent(uri)}`;
14
16
  };
15
17
  return {
16
18
  id: "zerion",
19
+ internalId: "ZERION",
17
20
  name: "Zerion",
18
21
  rdns: "io.zerion.wallet",
19
22
  iconUrl: icon,
@@ -21,6 +24,7 @@ const zerionWallet = ({ projectId, walletConnectParameters }) => {
21
24
  isExtension: true,
22
25
  isMobile: true,
23
26
  getUri,
27
+ deeplinkUri,
24
28
  downloadUrl: "https://zerion.io/download",
25
29
  createConnector: isZerionInjected ? getInjectedConnector({
26
30
  namespace: "zerionWallet",
@@ -1,10 +1,13 @@
1
1
  import type { CreateConnectorFn } from 'wagmi';
2
2
  import type { WalletList } from '../types/Wallet.js';
3
3
  import type { ParaWalletConnectParameters, Wallet } from '../types/Wallet.js';
4
+ import ParaWeb from '@getpara/web-sdk';
4
5
  export interface WalletListItem extends Wallet {
5
6
  index: number;
6
7
  }
7
8
  export interface ConnectorsForWalletsParameters {
9
+ para: ParaWeb;
10
+ createFarcasterConnector?: () => any;
8
11
  projectId: string;
9
12
  appName: string;
10
13
  appDescription?: string;
@@ -12,4 +15,4 @@ export interface ConnectorsForWalletsParameters {
12
15
  appIcon?: string;
13
16
  walletConnectParameters?: ParaWalletConnectParameters;
14
17
  }
15
- export declare const connectorsForWallets: (walletList: WalletList, { projectId, walletConnectParameters, appName, appDescription, appUrl, appIcon }: ConnectorsForWalletsParameters) => CreateConnectorFn[];
18
+ export declare const connectorsForWallets: (walletList: WalletList, { para, projectId, walletConnectParameters, appName, appDescription, appUrl, appIcon, createFarcasterConnector, }: ConnectorsForWalletsParameters) => CreateConnectorFn[];
@@ -7,7 +7,16 @@ import {
7
7
  import { uniqueBy } from "../utils/uniqueBy.js";
8
8
  import { computeWalletConnectMetaData } from "../utils/computeWalletConnectMetaData.js";
9
9
  import { omitUndefinedValues } from "../utils/omitUndefinedValues.js";
10
- const connectorsForWallets = (walletList, { projectId, walletConnectParameters, appName, appDescription, appUrl, appIcon }) => {
10
+ const connectorsForWallets = (walletList, {
11
+ para,
12
+ projectId,
13
+ walletConnectParameters,
14
+ appName,
15
+ appDescription,
16
+ appUrl,
17
+ appIcon,
18
+ createFarcasterConnector
19
+ }) => {
11
20
  if (!walletList.length) {
12
21
  return [];
13
22
  }
@@ -23,6 +32,7 @@ const connectorsForWallets = (walletList, { projectId, walletConnectParameters,
23
32
  walletList.forEach((createWallet) => {
24
33
  index++;
25
34
  const wallet = createWallet({
35
+ para,
26
36
  projectId,
27
37
  appName,
28
38
  appIcon,
@@ -34,7 +44,8 @@ const connectorsForWallets = (walletList, { projectId, walletConnectParameters,
34
44
  // `walletConnectWallet` wallet will have `walletConnectParameters` property
35
45
  walletConnectParameters: __spreadValues({
36
46
  metadata: walletConnectMetaData
37
- }, walletConnectParameters)
47
+ }, walletConnectParameters),
48
+ createFarcasterConnector
38
49
  });
39
50
  const walletListItem = __spreadProps(__spreadValues({}, wallet), {
40
51
  index
@@ -51,7 +62,7 @@ const connectorsForWallets = (walletList, { projectId, walletConnectParameters,
51
62
  }), additionalParaParams ? additionalParaParams : {}))
52
63
  };
53
64
  };
54
- const isWalletConnectConnector = walletMeta.id === "walletConnect";
65
+ const isWalletConnectConnector = walletMeta.internalId === "WALLETCONNECT";
55
66
  if (isWalletConnectConnector && createConnector) {
56
67
  connectors.push(
57
68
  createConnector(
package/package.json CHANGED
@@ -1,43 +1,51 @@
1
1
  {
2
2
  "name": "@getpara/evm-wallet-connectors",
3
- "version": "2.0.0-alpha.7",
4
- "type": "module",
5
- "main": "dist/index.js",
6
- "types": "dist/index.d.ts",
7
- "exports": {
8
- ".": "./dist/index.js",
9
- "./connectors": "./dist/wallets/connectors/index.js"
10
- },
3
+ "version": "2.0.0-alpha.71",
11
4
  "dependencies": {
12
5
  "@coinbase/wallet-sdk": "4.3.0",
13
- "@getpara/wagmi-v2-connector": "2.0.0-alpha.7",
14
- "@getpara/web-sdk": "2.0.0-alpha.7",
15
- "viem": "^2.24.2",
16
- "wagmi": "^2.14.16",
6
+ "@getpara/wagmi-v2-connector": "2.0.0-alpha.71",
7
+ "@getpara/web-sdk": "2.0.0-alpha.71",
8
+ "@walletconnect/ethereum-provider": "^2.22.4",
17
9
  "zustand": "^4.5.2",
18
10
  "zustand-sync-tabs": "^0.2.2"
19
11
  },
20
- "scripts": {
21
- "build": "rm -rf dist && yarn typegen && node ./scripts/build.mjs",
22
- "typegen": "tsc --emitDeclarationOnly",
23
- "test": "vitest run --coverage"
24
- },
25
12
  "devDependencies": {
26
- "@getpara/react-common": "2.0.0-alpha.7",
27
- "@tanstack/react-query": ">=5.0.0",
13
+ "@getpara/react-common": "2.0.0-alpha.71",
14
+ "@tanstack/react-query": "^5.74.0",
28
15
  "@types/react": "^18.0.31",
29
16
  "@types/react-dom": "^18.2.7",
30
- "typescript": "^5.4.3",
31
- "viem": "2.x",
32
- "wagmi": "2.x"
17
+ "typescript": "^5.8.3",
18
+ "viem": "^2.38.5",
19
+ "wagmi": "^2.14.16"
33
20
  },
34
- "peerDependencies": {
35
- "react": ">=18",
36
- "react-dom": ">=18"
21
+ "exports": {
22
+ ".": "./dist/index.js",
23
+ "./connectors": "./dist/wallets/connectors/index.js"
37
24
  },
38
25
  "files": [
39
26
  "dist",
40
27
  "package.json"
41
28
  ],
42
- "gitHead": "0a6b297b70c7f9b7b93381944e3f5314252ad6a5"
29
+ "gitHead": "30e5bad6a141f1b56959432f11aaf1536b84dece",
30
+ "main": "dist/index.js",
31
+ "peerDependencies": {
32
+ "@farcaster/miniapp-wagmi-connector": "^1.0.0",
33
+ "@tanstack/react-query": ">=5.0.0",
34
+ "react": ">=18",
35
+ "react-dom": ">=18",
36
+ "viem": "2.x",
37
+ "wagmi": "^2.9.0"
38
+ },
39
+ "peerDependenciesMeta": {
40
+ "@farcaster/miniapp-wagmi-connector": {
41
+ "optional": true
42
+ }
43
+ },
44
+ "scripts": {
45
+ "build": "rm -rf dist && yarn typegen && node ./scripts/build.mjs",
46
+ "test": "vitest run --coverage",
47
+ "typegen": "tsc --emitDeclarationOnly"
48
+ },
49
+ "type": "module",
50
+ "types": "dist/index.d.ts"
43
51
  }