@getpara/evm-wallet-connectors 2.0.0-alpha.18 → 2.0.0-alpha.20

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.d.ts CHANGED
@@ -1,6 +1,8 @@
1
+ export { createParaWagmiConfig } from './providers/createParaWagmiConfig.js';
1
2
  export { EvmExternalWalletContext } from './providers/EvmExternalWalletContext.js';
2
3
  export type { EvmExternalWalletContextType } from './providers/EvmExternalWalletContext.js';
3
4
  export { ParaEvmProvider } from './providers/ParaEvmContext.js';
4
5
  export type { ParaEvmProviderProps, ParaEvmProviderConfig, ParaWagmiProviderProps } from './providers/ParaEvmContext.js';
5
- export * from './wallets/connectors/index.js';
6
+ export { getWagmiConfig } from './stores/wagmiConfigStore.js';
6
7
  export type { WalletList } from './types/Wallet.js';
8
+ export * from './wallets/connectors/index.js';
package/dist/index.js CHANGED
@@ -1,9 +1,13 @@
1
1
  "use client";
2
2
  import "./chunk-MMUBH76A.js";
3
+ import { createParaWagmiConfig } from "./providers/createParaWagmiConfig.js";
3
4
  import { EvmExternalWalletContext } from "./providers/EvmExternalWalletContext.js";
4
5
  import { ParaEvmProvider } from "./providers/ParaEvmContext.js";
6
+ import { getWagmiConfig } from "./stores/wagmiConfigStore.js";
5
7
  export * from "./wallets/connectors/index.js";
6
8
  export {
7
9
  EvmExternalWalletContext,
8
- ParaEvmProvider
10
+ ParaEvmProvider,
11
+ createParaWagmiConfig,
12
+ getWagmiConfig
9
13
  };
@@ -4,12 +4,13 @@ import { WalletList } from '../types/Wallet.js';
4
4
  import { Chain, Transport } from 'viem';
5
5
  import { EvmExternalWalletProviderConfig } from './EvmExternalWalletContext.js';
6
6
  import { InjectedParameters } from 'wagmi/connectors';
7
+ import { TExternalWallet } from '@getpara/react-common';
7
8
  export interface ParaEvmProviderConfig<chains extends readonly [Chain, ...Chain[]], transports extends Record<chains[number]['id'], Transport>> extends Omit<CreateConfigParameters<chains, transports>, 'connectors'> {
8
9
  appName: string;
9
10
  appDescription?: string;
10
11
  appUrl?: string;
11
12
  appIcon?: string;
12
- wallets?: WalletList;
13
+ wallets?: WalletList | TExternalWallet[];
13
14
  projectId: string;
14
15
  paraConnectorOptions?: InjectedParameters;
15
16
  }
@@ -12,6 +12,8 @@ import { http } from "viem";
12
12
  import { computeWalletConnectMetaData } from "../utils/computeWalletConnectMetaData.js";
13
13
  import { EvmExternalWalletProvider } from "./EvmExternalWalletContext.js";
14
14
  import { paraConnector } from "@getpara/wagmi-v2-connector";
15
+ import { setWagmiConfig, getWagmiConfig } from "../stores/wagmiConfigStore.js";
16
+ import { resolveWalletList } from "../utils/resolveWalletList.js";
15
17
  const createDefaultTransports = (chains) => {
16
18
  const transportsObject = chains.reduce((acc, chain) => {
17
19
  const key = chain.id;
@@ -58,8 +60,11 @@ function ParaEvmProvider({
58
60
  });
59
61
  }, [para]);
60
62
  const config = useMemo(() => {
63
+ const existing = getWagmiConfig();
64
+ if (existing) return existing;
61
65
  const wcMetadata = computeWalletConnectMetaData({ appName, appDescription, appUrl, appIcon });
62
- const baseConnectors = connectorsForWallets(wallets, {
66
+ const walletFactories = resolveWalletList(wallets);
67
+ const baseConnectors = connectorsForWallets(walletFactories, {
63
68
  projectId,
64
69
  appName,
65
70
  appDescription,
@@ -68,11 +73,13 @@ function ParaEvmProvider({
68
73
  walletConnectParameters: { metadata: wcMetadata }
69
74
  });
70
75
  const allConnectors = [...baseConnectors, paraConnectorInstance];
71
- return createConfig(__spreadProps(__spreadValues({}, wagmiConfigParams), {
76
+ const createdConfig = createConfig(__spreadProps(__spreadValues({}, wagmiConfigParams), {
72
77
  chains,
73
78
  transports: transports || createDefaultTransports(chains),
74
79
  connectors: allConnectors
75
80
  }));
81
+ setWagmiConfig(createdConfig);
82
+ return createdConfig;
76
83
  }, [wallets, paraConnectorInstance]);
77
84
  return /* @__PURE__ */ jsx(WagmiProvider, __spreadProps(__spreadValues({ config }, wagmiProviderProps), { children: /* @__PURE__ */ jsx(EvmExternalWalletProvider, __spreadProps(__spreadValues({}, internalConfig), { children })) }));
78
85
  }
@@ -0,0 +1,10 @@
1
+ import { Chain, Transport } from 'viem';
2
+ import type { ParaEvmProviderConfig } from './ParaEvmContext.js';
3
+ import ParaWeb from '@getpara/web-sdk';
4
+ /**
5
+ * Creates a Wagmi configuration for the Para EVM provider.
6
+ * @param para - The ParaWeb instance to use.
7
+ * @param cfg - The configuration options for the Para EVM provider.
8
+ * @returns The created Wagmi configuration.
9
+ */
10
+ export declare function createParaWagmiConfig<const chains extends readonly [Chain, ...Chain[]], transports extends Record<chains[number]['id'], Transport>>(para: ParaWeb, cfg: ParaEvmProviderConfig<chains, transports>): import("wagmi").Config<chains, transports, readonly import("wagmi").CreateConnectorFn[]>;
@@ -0,0 +1,62 @@
1
+ "use client";
2
+ import {
3
+ __objRest,
4
+ __spreadProps,
5
+ __spreadValues
6
+ } from "../chunk-MMUBH76A.js";
7
+ import { createConfig } from "wagmi";
8
+ import { connectorsForWallets } from "../wallets/connectorsForWallets.js";
9
+ import { computeWalletConnectMetaData } from "../utils/computeWalletConnectMetaData.js";
10
+ import { paraConnector } from "@getpara/wagmi-v2-connector";
11
+ import { setWagmiConfig } from "../stores/wagmiConfigStore.js";
12
+ import { resolveWalletList } from "../utils/resolveWalletList.js";
13
+ function createParaWagmiConfig(para, cfg) {
14
+ const _a = cfg, {
15
+ projectId,
16
+ appName,
17
+ appDescription,
18
+ appIcon,
19
+ appUrl,
20
+ wallets,
21
+ chains,
22
+ transports,
23
+ paraConnectorOptions
24
+ } = _a, wagmiParams = __objRest(_a, [
25
+ "projectId",
26
+ "appName",
27
+ "appDescription",
28
+ "appIcon",
29
+ "appUrl",
30
+ "wallets",
31
+ "chains",
32
+ "transports",
33
+ "paraConnectorOptions"
34
+ ]);
35
+ const wcMetadata = computeWalletConnectMetaData({ appName, appDescription, appUrl, appIcon });
36
+ const walletFactories = resolveWalletList(wallets);
37
+ const baseConnectors = connectorsForWallets(walletFactories, {
38
+ projectId,
39
+ appName,
40
+ appDescription,
41
+ appUrl,
42
+ appIcon,
43
+ walletConnectParameters: { metadata: wcMetadata }
44
+ });
45
+ const paraConn = paraConnector({
46
+ para,
47
+ chains: [...chains],
48
+ disableModal: true,
49
+ appName,
50
+ options: paraConnectorOptions != null ? paraConnectorOptions : {}
51
+ });
52
+ const created = createConfig(__spreadProps(__spreadValues({}, wagmiParams), {
53
+ chains,
54
+ transports,
55
+ connectors: [...baseConnectors, paraConn]
56
+ }));
57
+ setWagmiConfig(created);
58
+ return created;
59
+ }
60
+ export {
61
+ createParaWagmiConfig
62
+ };
@@ -0,0 +1,14 @@
1
+ import type { Config } from 'wagmi';
2
+ /**
3
+ * Sets the Wagmi configuration in the global store.
4
+ *
5
+ * @param config - The Wagmi configuration object to be stored
6
+ * @returns {void}
7
+ */
8
+ export declare const setWagmiConfig: (config: Config) => void;
9
+ /**
10
+ * Retrieves the current Wagmi configuration from the global store.
11
+ *
12
+ * @returns {Config | null} - The current Wagmi configuration or null if not set
13
+ */
14
+ export declare const getWagmiConfig: () => Config;
@@ -0,0 +1,16 @@
1
+ "use client";
2
+ import "../chunk-MMUBH76A.js";
3
+ import { createStore } from "zustand/vanilla";
4
+ const wagmiConfigStore = createStore(() => ({
5
+ config: null
6
+ }));
7
+ const setWagmiConfig = (config) => {
8
+ wagmiConfigStore.setState({ config });
9
+ };
10
+ const getWagmiConfig = () => {
11
+ return wagmiConfigStore.getState().config;
12
+ };
13
+ export {
14
+ getWagmiConfig,
15
+ setWagmiConfig
16
+ };
@@ -0,0 +1,3 @@
1
+ import { WalletList } from '../types/Wallet.js';
2
+ import { TExternalWallet } from '@getpara/react-common';
3
+ export declare function resolveWalletList(wallets: WalletList | TExternalWallet[] | undefined): WalletList;
@@ -0,0 +1,16 @@
1
+ "use client";
2
+ import "../chunk-MMUBH76A.js";
3
+ import { allWallets } from "../wallets/connectors/index.js";
4
+ function resolveWalletList(wallets) {
5
+ if (!wallets || !wallets.length) return [];
6
+ if (typeof wallets[0] === "function") return wallets;
7
+ const ids = wallets;
8
+ const resolved = allWallets.filter((createWalletFn) => {
9
+ const meta = createWalletFn({ projectId: "", appName: "" });
10
+ return ids.includes(meta.id.toUpperCase());
11
+ });
12
+ return resolved;
13
+ }
14
+ export {
15
+ resolveWalletList
16
+ };
@@ -0,0 +1,3 @@
1
+ import { DefaultWalletOptions, Wallet } from '../../../types/Wallet.js';
2
+ export type BackpackWalletOptions = DefaultWalletOptions;
3
+ export declare const backpackWallet: ({ projectId, walletConnectParameters }: BackpackWalletOptions) => Wallet;
@@ -0,0 +1,30 @@
1
+ "use client";
2
+ import "../../../chunk-MMUBH76A.js";
3
+ import { getInjectedConnector, hasInjectedProvider } from "../../../utils/getInjectedConnector.js";
4
+ import { icon } from "./backpackIcon.js";
5
+ import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnector.js";
6
+ const backpackWallet = ({ projectId, walletConnectParameters }) => {
7
+ const isBackpackInjected = hasInjectedProvider({ namespace: "backpack.ethereum" });
8
+ const shouldUseWalletConnect = !isBackpackInjected;
9
+ const getUri = (uri) => {
10
+ return uri;
11
+ };
12
+ return {
13
+ id: "backpack",
14
+ name: "Backpack",
15
+ rdns: "app.backpack.mobile",
16
+ iconUrl: icon,
17
+ installed: isBackpackInjected,
18
+ isExtension: true,
19
+ isMobile: true,
20
+ getUri,
21
+ downloadUrl: "https://backpack.app/download",
22
+ createConnector: shouldUseWalletConnect ? getWalletConnectConnector({
23
+ projectId,
24
+ walletConnectParameters
25
+ }) : getInjectedConnector({ namespace: "backpack.ethereum" })
26
+ };
27
+ };
28
+ export {
29
+ backpackWallet
30
+ };
@@ -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 HahaWalletOptions = DefaultWalletOptions;
3
+ export declare const hahaWallet: ({ projectId, walletConnectParameters }: HahaWalletOptions) => Wallet;
@@ -0,0 +1,30 @@
1
+ "use client";
2
+ import "../../../chunk-MMUBH76A.js";
3
+ import { getInjectedConnector, hasInjectedProvider } from "../../../utils/getInjectedConnector.js";
4
+ import { icon } from "./hahaIcon.js";
5
+ import { getWalletConnectConnector } from "../../../utils/getWalletConnectConnector.js";
6
+ const hahaWallet = ({ projectId, walletConnectParameters }) => {
7
+ const isHahaInjected = hasInjectedProvider({ namespace: "haha" });
8
+ const shouldUseWalletConnect = !isHahaInjected;
9
+ const getUri = (uri) => {
10
+ return uri;
11
+ };
12
+ return {
13
+ id: "haha",
14
+ name: "HaHa",
15
+ rdns: "haha.me",
16
+ iconUrl: icon,
17
+ installed: isHahaInjected,
18
+ isExtension: true,
19
+ isMobile: true,
20
+ getUri,
21
+ downloadUrl: "https://www.haha.me/",
22
+ createConnector: shouldUseWalletConnect ? getWalletConnectConnector({
23
+ projectId,
24
+ walletConnectParameters
25
+ }) : getInjectedConnector({ namespace: "haha" })
26
+ };
27
+ };
28
+ export {
29
+ hahaWallet
30
+ };
@@ -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,5 +6,7 @@ import { zerionWallet } from './zerion/zerion.js';
6
6
  import { rabbyWallet } from './rabby/rabby.js';
7
7
  import { safeWallet } from './safe/safe.js';
8
8
  import { okxWallet } from './okx/okx.js';
9
- export { metaMaskWallet, rainbowWallet, walletConnectWallet, coinbaseWallet, zerionWallet, rabbyWallet, safeWallet, okxWallet, };
9
+ import { backpackWallet } from './backpack/backpack.js';
10
+ import { hahaWallet } from './haha/haha.js';
11
+ export { metaMaskWallet, rainbowWallet, walletConnectWallet, coinbaseWallet, zerionWallet, rabbyWallet, safeWallet, okxWallet, backpackWallet, hahaWallet, };
10
12
  export declare const allWallets: ((({ appName, appIcon }: import("./coinbase/coinbase.js").CoinbaseWalletOptions) => import("../../types/Wallet.js").Wallet) | (({ projectId, options }: import("./walletConnect/walletConnect.js").WalletConnectWalletOptions) => import("../../types/Wallet.js").Wallet) | (({ projectId, walletConnectParameters }: import("./metaMask/metaMask.js").MetaMaskWalletOptions) => import("../../types/Wallet.js").Wallet))[];
@@ -8,6 +8,8 @@ import { zerionWallet } from "./zerion/zerion.js";
8
8
  import { rabbyWallet } from "./rabby/rabby.js";
9
9
  import { safeWallet } from "./safe/safe.js";
10
10
  import { okxWallet } from "./okx/okx.js";
11
+ import { backpackWallet } from "./backpack/backpack.js";
12
+ import { hahaWallet } from "./haha/haha.js";
11
13
  const allWallets = [
12
14
  metaMaskWallet,
13
15
  rainbowWallet,
@@ -16,11 +18,15 @@ const allWallets = [
16
18
  zerionWallet,
17
19
  rabbyWallet,
18
20
  safeWallet,
19
- okxWallet
21
+ okxWallet,
22
+ backpackWallet,
23
+ hahaWallet
20
24
  ];
21
25
  export {
22
26
  allWallets,
27
+ backpackWallet,
23
28
  coinbaseWallet,
29
+ hahaWallet,
24
30
  metaMaskWallet,
25
31
  okxWallet,
26
32
  rabbyWallet,
@@ -1 +1 @@
1
- export declare const icon = "";
1
+ export declare const icon = "";
@@ -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
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@getpara/evm-wallet-connectors",
3
- "version": "2.0.0-alpha.18",
3
+ "version": "2.0.0-alpha.20",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -10,8 +10,8 @@
10
10
  },
11
11
  "dependencies": {
12
12
  "@coinbase/wallet-sdk": "4.3.0",
13
- "@getpara/wagmi-v2-connector": "2.0.0-alpha.18",
14
- "@getpara/web-sdk": "2.0.0-alpha.18",
13
+ "@getpara/wagmi-v2-connector": "2.0.0-alpha.20",
14
+ "@getpara/web-sdk": "2.0.0-alpha.20",
15
15
  "viem": "^2.24.2",
16
16
  "wagmi": "^2.14.16",
17
17
  "zustand": "^4.5.2",
@@ -23,7 +23,7 @@
23
23
  "test": "vitest run --coverage"
24
24
  },
25
25
  "devDependencies": {
26
- "@getpara/react-common": "2.0.0-alpha.18",
26
+ "@getpara/react-common": "2.0.0-alpha.20",
27
27
  "@tanstack/react-query": ">=5.0.0",
28
28
  "@types/react": "^18.0.31",
29
29
  "@types/react-dom": "^18.2.7",
@@ -39,5 +39,5 @@
39
39
  "dist",
40
40
  "package.json"
41
41
  ],
42
- "gitHead": "2333bc727fe61593821d448ee12facaee230c4b0"
42
+ "gitHead": "4c8d918b9fc387476968bfc08524fe1a8b6ec83b"
43
43
  }