@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,17 +1,21 @@
1
1
  "use client";
2
2
  import {
3
+ __async,
3
4
  __objRest,
4
5
  __spreadProps,
5
6
  __spreadValues
6
7
  } from "../chunk-MMUBH76A.js";
7
8
  import { jsx } from "react/jsx-runtime";
8
- import { useMemo } from "react";
9
- import { createConfig, WagmiProvider } from "wagmi";
9
+ import { useEffect, useMemo, useRef, useState } from "react";
10
+ import { createConfig as createWagmiConfig, WagmiProvider } from "wagmi";
10
11
  import { connectorsForWallets } from "../wallets/connectorsForWallets.js";
11
12
  import { http } from "viem";
12
13
  import { computeWalletConnectMetaData } from "../utils/computeWalletConnectMetaData.js";
13
14
  import { EvmExternalWalletProvider } from "./EvmExternalWalletContext.js";
14
15
  import { paraConnector } from "@getpara/wagmi-v2-connector";
16
+ import { setWagmiConfig, getWagmiConfig } from "../stores/wagmiConfigStore.js";
17
+ import { resolveWalletList } from "../utils/resolveWalletList.js";
18
+ import { farcasterWallet } from "../wallets/connectors/index.js";
15
19
  const createDefaultTransports = (chains) => {
16
20
  const transportsObject = chains.reduce((acc, chain) => {
17
21
  const key = chain.id;
@@ -33,7 +37,7 @@ function ParaEvmProvider({
33
37
  appDescription,
34
38
  appIcon,
35
39
  appUrl,
36
- wallets,
40
+ wallets: propsWallets,
37
41
  chains,
38
42
  transports,
39
43
  paraConnectorOptions
@@ -48,6 +52,10 @@ function ParaEvmProvider({
48
52
  "transports",
49
53
  "paraConnectorOptions"
50
54
  ]);
55
+ const propsWalletList = useMemo(() => {
56
+ return resolveWalletList(propsWallets != null ? propsWallets : []);
57
+ }, [propsWallets]);
58
+ const prevWallets = useRef(propsWalletList);
51
59
  const paraConnectorInstance = useMemo(() => {
52
60
  return paraConnector({
53
61
  para,
@@ -57,9 +65,16 @@ function ParaEvmProvider({
57
65
  options: paraConnectorOptions != null ? paraConnectorOptions : {}
58
66
  });
59
67
  }, [para]);
60
- const config = useMemo(() => {
68
+ const createConfig = (walletList, createFarcasterConnector) => {
69
+ const existing = getWagmiConfig();
70
+ if (existing && prevWallets.current === walletList) {
71
+ return existing;
72
+ }
73
+ prevWallets.current = walletList;
61
74
  const wcMetadata = computeWalletConnectMetaData({ appName, appDescription, appUrl, appIcon });
62
- const baseConnectors = connectorsForWallets(wallets, {
75
+ const baseConnectors = connectorsForWallets(walletList, {
76
+ para,
77
+ createFarcasterConnector,
63
78
  projectId,
64
79
  appName,
65
80
  appDescription,
@@ -68,12 +83,39 @@ function ParaEvmProvider({
68
83
  walletConnectParameters: { metadata: wcMetadata }
69
84
  });
70
85
  const allConnectors = [...baseConnectors, paraConnectorInstance];
71
- return createConfig(__spreadProps(__spreadValues({}, wagmiConfigParams), {
86
+ const createdConfig = createWagmiConfig(__spreadProps(__spreadValues({
87
+ ssr: true
88
+ }, wagmiConfigParams), {
72
89
  chains,
73
90
  transports: transports || createDefaultTransports(chains),
74
91
  connectors: allConnectors
75
92
  }));
76
- }, [wallets, paraConnectorInstance]);
93
+ setWagmiConfig(createdConfig);
94
+ return createdConfig;
95
+ };
96
+ const [config, setConfig] = useState(null);
97
+ useEffect(() => {
98
+ if (!para.isReady) {
99
+ return;
100
+ }
101
+ const initializeConfig = () => __async(this, null, function* () {
102
+ var _a2;
103
+ if (para.isFarcasterMiniApp) {
104
+ let createFarcasterConnector = null;
105
+ try {
106
+ createFarcasterConnector = (_a2 = (yield import("@farcaster/miniapp-wagmi-connector")).farcasterMiniApp) != null ? _a2 : void 0;
107
+ } catch (e) {
108
+ }
109
+ setConfig(createConfig([...propsWalletList, farcasterWallet], createFarcasterConnector));
110
+ } else {
111
+ setConfig(createConfig([...propsWalletList]));
112
+ }
113
+ });
114
+ initializeConfig();
115
+ }, [para.isFarcasterMiniApp, para.isReady, propsWalletList]);
116
+ if (!config) {
117
+ return null;
118
+ }
77
119
  return /* @__PURE__ */ jsx(WagmiProvider, __spreadProps(__spreadValues({ config }, wagmiProviderProps), { children: /* @__PURE__ */ jsx(EvmExternalWalletProvider, __spreadProps(__spreadValues({}, internalConfig), { children })) }));
78
120
  }
79
121
  export {
@@ -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,65 @@
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
+ para,
39
+ projectId,
40
+ appName,
41
+ appDescription,
42
+ appUrl,
43
+ appIcon,
44
+ walletConnectParameters: { metadata: wcMetadata }
45
+ });
46
+ const paraConn = paraConnector({
47
+ para,
48
+ chains: [...chains],
49
+ disableModal: true,
50
+ appName,
51
+ options: paraConnectorOptions != null ? paraConnectorOptions : {}
52
+ });
53
+ const created = createConfig(__spreadProps(__spreadValues({
54
+ ssr: true
55
+ }, wagmiParams), {
56
+ chains,
57
+ transports,
58
+ connectors: [...baseConnectors, paraConn]
59
+ }));
60
+ setWagmiConfig(created);
61
+ return created;
62
+ }
63
+ export {
64
+ createParaWagmiConfig
65
+ };
@@ -0,0 +1,7 @@
1
+ import { useAccount } from 'wagmi';
2
+ export type TExternalHooks = {
3
+ useAccount: typeof useAccount;
4
+ };
5
+ export declare const externalHooks: {
6
+ useAccount: typeof useAccount;
7
+ };
@@ -0,0 +1,7 @@
1
+ "use client";
2
+ import "../chunk-MMUBH76A.js";
3
+ import { useAccount } from "wagmi";
4
+ const externalHooks = { useAccount };
5
+ export {
6
+ externalHooks
7
+ };
@@ -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
+ };
@@ -1,14 +1,18 @@
1
1
  import { Connector, CreateConnectorFn } from 'wagmi';
2
- import { WalletConnectParameters } from 'wagmi/connectors';
3
2
  import { CoinbaseWalletOptions } from '../wallets/connectors/coinbase/coinbase.js';
4
3
  import { WalletConnectWalletOptions } from '../wallets/connectors/walletConnect/walletConnect.js';
5
4
  import { type WalletMetadata } from '@getpara/react-common';
5
+ import ParaWeb from '@getpara/web-sdk';
6
+ import { WalletConnectParameters } from '../connectors/walletConnect.js';
6
7
  export type Wallet = {
7
8
  createConnector?: (walletDetails: WalletDetailsParams) => CreateConnectorFn;
8
9
  createMobileConnector?: (walletDetails: WalletDetailsParams) => CreateConnectorFn;
9
10
  getUri?: (uri: string) => string;
11
+ deeplinkUri?: string;
10
12
  } & WalletMetadata;
11
13
  export interface DefaultWalletOptions {
14
+ para?: ParaWeb;
15
+ createFarcasterConnector?: () => any;
12
16
  projectId: string;
13
17
  walletConnectParameters?: ParaWalletConnectParameters;
14
18
  }
@@ -9,7 +9,7 @@ export type Mutable<type extends object> = {
9
9
  };
10
10
  /** Strict version of built-in Omit type */
11
11
  export type Omit<type, keys extends keyof type> = Pick<type, Exclude<keyof type, keys>>;
12
- export type WalletProviderFlags = 'isApexWallet' | 'isAvalanche' | 'isBackpack' | 'isBifrost' | 'isBitKeep' | 'isBitski' | 'isBlockWallet' | 'isBraveWallet' | 'isCoinbaseWallet' | 'isDawn' | 'isEnkrypt' | 'isExodus' | 'isFrame' | 'isFrontier' | 'isGamestop' | 'isHyperPay' | 'isImToken' | 'isKuCoinWallet' | 'isMathWallet' | 'isMetaMask' | 'isNestWallet' | 'isOkxWallet' | 'isOKExWallet' | 'isOneInchAndroidWallet' | 'isOneInchIOSWallet' | 'isOpera' | 'isPhantom' | 'isPortal' | 'isRabby' | 'isRainbow' | 'isSafe' | 'isStatus' | 'isTally' | 'isTokenPocket' | 'isTokenary' | 'isTrust' | 'isTrustWallet' | 'isXDEFI' | 'isZerion' | 'isTalisman' | 'isZeal' | 'isCoin98' | 'isMEWwallet' | 'isSafeheron' | 'isSafePal' | '__seif';
12
+ export type WalletProviderFlags = 'isApexWallet' | 'isAvalanche' | 'isBackpack' | 'isBifrost' | 'isBitKeep' | 'isBitski' | 'isBlockWallet' | 'isBraveWallet' | 'isCoinbaseWallet' | 'isDawn' | 'isEnkrypt' | 'isExodus' | 'isFarcaster' | 'isFrame' | 'isFrontier' | 'isGamestop' | 'isHyperPay' | 'isImToken' | 'isKuCoinWallet' | 'isMathWallet' | 'isMetaMask' | 'isNestWallet' | 'isOkxWallet' | 'isOKExWallet' | 'isOneInchAndroidWallet' | 'isOneInchIOSWallet' | 'isOpera' | 'isPhantom' | 'isPortal' | 'isRabby' | 'isRainbow' | 'isSafe' | 'isStatus' | 'isTally' | 'isTokenPocket' | 'isTokenary' | 'isTrust' | 'isTrustWallet' | 'isXDEFI' | 'isZerion' | 'isTalisman' | 'isZeal' | 'isCoin98' | 'isMEWwallet' | 'isSafeheron' | 'isSafePal' | '__seif';
13
13
  export type WalletProvider = Evaluate<EIP1193Provider & {
14
14
  [key in WalletProviderFlags]?: true | undefined;
15
15
  } & {
@@ -4,7 +4,7 @@ import {
4
4
  __spreadValues
5
5
  } from "../chunk-MMUBH76A.js";
6
6
  import { createConnector } from "wagmi";
7
- import { walletConnect } from "wagmi/connectors";
7
+ import { walletConnect } from "../connectors/walletConnect.js";
8
8
  const walletConnectInstances = /* @__PURE__ */ new Map();
9
9
  const getOrCreateWalletConnectInstance = ({
10
10
  projectId,
@@ -1,2 +1,2 @@
1
1
  import { Connector } from 'wagmi';
2
- export declare const getWalletConnectUri: (connector: Connector, uriConverter?: (uri: string) => string) => Promise<string>;
2
+ export declare const emitWalletConnectUri: (connector: Connector, uriConverter?: (uri: string) => string) => Promise<void>;
@@ -2,21 +2,27 @@
2
2
  import {
3
3
  __async
4
4
  } from "../chunk-MMUBH76A.js";
5
- const getWalletConnectUri = (connector, uriConverter) => __async(void 0, null, function* () {
6
- const provider = yield connector.getProvider();
7
- if (connector.type === "coinbaseWallet") {
8
- return provider.qrUrl;
5
+ const emitWalletConnectUri = (connector, uriConverter) => __async(void 0, null, function* () {
6
+ var _a, _b;
7
+ if (typeof window === "undefined") {
8
+ return;
9
9
  }
10
- return new Promise(
11
- (resolve) => (
12
- // Wagmi v2 doesn't have a return type for provider yet
13
- // @ts-expect-error
14
- provider.once("display_uri", (uri) => {
15
- resolve(uriConverter ? uriConverter(uri) : uri);
16
- })
17
- )
18
- );
10
+ const provider = yield (_b = (_a = connector.getProvider) == null ? void 0 : _a.call(connector)) != null ? _b : void 0;
11
+ if (connector.type === "coinbaseWallet" && (provider == null ? void 0 : provider.qrUrl)) {
12
+ window.dispatchEvent(new CustomEvent("PARA_WALLETCONNECT_URI_READY", { detail: provider.qrUrl }));
13
+ }
14
+ if (!provider || typeof provider.once !== "function" && typeof provider.on !== "function") {
15
+ throw new Error("display_uri event not supported for this connector");
16
+ }
17
+ const listen = typeof provider.once === "function" ? provider.once.bind(provider) : provider.on.bind(provider);
18
+ const cancel = setTimeout(() => console.error("display_uri event not emitted"), 1e4);
19
+ listen("display_uri", (uri) => {
20
+ clearTimeout(cancel);
21
+ window.dispatchEvent(
22
+ new CustomEvent("PARA_WALLETCONNECT_URI_READY", { detail: uriConverter ? uriConverter(uri) : uri })
23
+ );
24
+ });
19
25
  });
20
26
  export {
21
- getWalletConnectUri
27
+ emitWalletConnectUri
22
28
  };
@@ -2,7 +2,7 @@
2
2
  import "../chunk-MMUBH76A.js";
3
3
  const isEIP6963Connector = (wallet) => {
4
4
  var _a;
5
- return !!(!wallet.isRainbowKitConnector && ((_a = wallet.icon) == null ? void 0 : _a.startsWith("data:image")) && wallet.uid && wallet.name);
5
+ return !!(!wallet.isRainbowKitConnector && ((_a = wallet.icon) == null ? void 0 : _a.trim().startsWith("data:image")) && wallet.uid && wallet.name);
6
6
  };
7
7
  export {
8
8
  isEIP6963Connector
@@ -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,31 @@
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
+ internalId: "BACKPACK",
15
+ name: "Backpack",
16
+ rdns: "app.backpack",
17
+ iconUrl: icon,
18
+ installed: isBackpackInjected,
19
+ isExtension: true,
20
+ isMobile: true,
21
+ getUri,
22
+ downloadUrl: "https://backpack.app/download",
23
+ createConnector: shouldUseWalletConnect ? getWalletConnectConnector({
24
+ projectId,
25
+ walletConnectParameters
26
+ }) : getInjectedConnector({ namespace: "backpack.ethereum" })
27
+ };
28
+ };
29
+ export {
30
+ backpackWallet
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
+ };
@@ -11,6 +11,7 @@ const coinbaseWallet = ({ appName, appIcon }) => {
11
11
  const getUri = (uri) => uri;
12
12
  return {
13
13
  id: "coinbase",
14
+ internalId: "COINBASE",
14
15
  name: "Coinbase Wallet",
15
16
  rdns: "com.coinbase.wallet",
16
17
  iconUrl: icon,
@@ -0,0 +1,2 @@
1
+ import { DefaultWalletOptions, Wallet } from '../../../types/Wallet.js';
2
+ export declare const farcasterWallet: ({ para, createFarcasterConnector }: DefaultWalletOptions) => Wallet;
@@ -0,0 +1,22 @@
1
+ "use client";
2
+ import {
3
+ __spreadValues
4
+ } from "../../../chunk-MMUBH76A.js";
5
+ import { createConnector } from "wagmi";
6
+ import { icon } from "./farcasterIcon.js";
7
+ const farcasterWallet = ({ para, createFarcasterConnector }) => {
8
+ return {
9
+ id: "farcaster",
10
+ internalId: "FARCASTER",
11
+ name: "Farcaster",
12
+ rdns: "xyz.farcaster.MiniAppWallet",
13
+ iconUrl: icon,
14
+ installed: (para == null ? void 0 : para.isReady) && (para == null ? void 0 : para.isFarcasterMiniApp),
15
+ isExtension: true,
16
+ downloadUrl: "https://farcaster.xyz/",
17
+ createConnector: (walletDetails) => createConnector((config) => __spreadValues(__spreadValues({}, createFarcasterConnector()(config)), walletDetails))
18
+ };
19
+ };
20
+ export {
21
+ farcasterWallet
22
+ };
@@ -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,31 @@
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
+ internalId: "HAHA",
15
+ name: "HaHa",
16
+ rdns: "haha.me",
17
+ iconUrl: icon,
18
+ installed: isHahaInjected,
19
+ isExtension: true,
20
+ isMobile: true,
21
+ getUri,
22
+ downloadUrl: "https://www.haha.me/",
23
+ createConnector: shouldUseWalletConnect ? getWalletConnectConnector({
24
+ projectId,
25
+ walletConnectParameters
26
+ }) : getInjectedConnector({ namespace: "haha" })
27
+ };
28
+ };
29
+ export {
30
+ hahaWallet
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
+ };
@@ -1,3 +1,4 @@
1
+ import { farcasterWallet } from './farcaster/farcaster.js';
1
2
  import { metaMaskWallet } from './metaMask/metaMask.js';
2
3
  import { rainbowWallet } from './rainbow/rainbow.js';
3
4
  import { walletConnectWallet } from './walletConnect/walletConnect.js';
@@ -5,5 +6,10 @@ import { coinbaseWallet } from './coinbase/coinbase.js';
5
6
  import { zerionWallet } from './zerion/zerion.js';
6
7
  import { rabbyWallet } from './rabby/rabby.js';
7
8
  import { safeWallet } from './safe/safe.js';
8
- export { metaMaskWallet, rainbowWallet, walletConnectWallet, coinbaseWallet, zerionWallet, rabbyWallet, safeWallet };
9
+ import { okxWallet } from './okx/okx.js';
10
+ import { backpackWallet } from './backpack/backpack.js';
11
+ import { hahaWallet } from './haha/haha.js';
12
+ import { phantomWallet } from './phantom/phantom.js';
13
+ import { valoraWallet } from './valora/valora.js';
14
+ export { farcasterWallet, metaMaskWallet, rainbowWallet, walletConnectWallet, coinbaseWallet, zerionWallet, rabbyWallet, safeWallet, okxWallet, backpackWallet, hahaWallet, phantomWallet, valoraWallet, };
9
15
  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))[];
@@ -1,5 +1,6 @@
1
1
  "use client";
2
2
  import "../../chunk-MMUBH76A.js";
3
+ import { farcasterWallet } from "./farcaster/farcaster.js";
3
4
  import { metaMaskWallet } from "./metaMask/metaMask.js";
4
5
  import { rainbowWallet } from "./rainbow/rainbow.js";
5
6
  import { walletConnectWallet } from "./walletConnect/walletConnect.js";
@@ -7,6 +8,11 @@ import { coinbaseWallet } from "./coinbase/coinbase.js";
7
8
  import { zerionWallet } from "./zerion/zerion.js";
8
9
  import { rabbyWallet } from "./rabby/rabby.js";
9
10
  import { safeWallet } from "./safe/safe.js";
11
+ import { okxWallet } from "./okx/okx.js";
12
+ import { backpackWallet } from "./backpack/backpack.js";
13
+ import { hahaWallet } from "./haha/haha.js";
14
+ import { phantomWallet } from "./phantom/phantom.js";
15
+ import { valoraWallet } from "./valora/valora.js";
10
16
  const allWallets = [
11
17
  metaMaskWallet,
12
18
  rainbowWallet,
@@ -14,15 +20,26 @@ const allWallets = [
14
20
  coinbaseWallet,
15
21
  zerionWallet,
16
22
  rabbyWallet,
17
- safeWallet
23
+ safeWallet,
24
+ okxWallet,
25
+ backpackWallet,
26
+ hahaWallet,
27
+ phantomWallet,
28
+ valoraWallet
18
29
  ];
19
30
  export {
20
31
  allWallets,
32
+ backpackWallet,
21
33
  coinbaseWallet,
34
+ farcasterWallet,
35
+ hahaWallet,
22
36
  metaMaskWallet,
37
+ okxWallet,
38
+ phantomWallet,
23
39
  rabbyWallet,
24
40
  rainbowWallet,
25
41
  safeWallet,
42
+ valoraWallet,
26
43
  walletConnectWallet,
27
44
  zerionWallet
28
45
  };
@@ -55,14 +55,17 @@ const metaMaskWallet = ({ projectId, walletConnectParameters }) => {
55
55
  if (providerMapTarget) {
56
56
  metaMaskTarget = providerMapTarget;
57
57
  }
58
+ const deeplinkUri = "metamask://";
59
+ const baseUri = isAndroid() ? `${deeplinkUri}wc` : isIOS() ? !isTelegram() ? (
60
+ // currently broken in MetaMask v6.5.0 https://github.com/MetaMask/metamask-mobile/issues/6457
61
+ `${deeplinkUri}wc`
62
+ ) : "https://metamask.app.link/wc" : "https://metamask.app.link/wc";
58
63
  const getUri = (uri) => {
59
- return isAndroid() ? `metamask://wc?uri=${encodeURIComponent(uri)}` : isIOS() ? !isTelegram() ? (
60
- // currently broken in MetaMask v6.5.0 https://github.com/MetaMask/metamask-mobile/issues/6457
61
- `metamask://wc?uri=${encodeURIComponent(uri)}`
62
- ) : `https://metamask.app.link/wc?uri=${encodeURIComponent(uri)}` : `https://metamask.app.link/wc?uri=${encodeURIComponent(uri)}`;
64
+ return `${baseUri}?uri=${encodeURIComponent(uri)}`;
63
65
  };
64
66
  return {
65
67
  id: "metaMask",
68
+ internalId: "METAMASK",
66
69
  name: "MetaMask",
67
70
  rdns: "io.metamask",
68
71
  iconUrl: icon,
@@ -71,6 +74,7 @@ const metaMaskWallet = ({ projectId, walletConnectParameters }) => {
71
74
  isMobile: true,
72
75
  downloadUrl: "https://metamask.io/download/",
73
76
  getUri,
77
+ deeplinkUri,
74
78
  createConnector: isMetaMaskInjected ? getInjectedConnector({
75
79
  target: metaMaskTarget
76
80
  }) : getWalletConnectConnector({
@@ -1 +1 @@
1
- export declare const icon = "";
1
+ export declare const icon = "";