@getpara/solana-wallet-connectors 2.0.0-fc.2 → 2.0.0

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/README.md ADDED
@@ -0,0 +1,14 @@
1
+ https://www.npmjs.com/package/@getpara/solana-wallet-connectors
2
+
3
+ `@getpara/solana-wallet-connectors` is a package that provides wallet connectors for Solana when using Para's React SDK Lite.
4
+ The package enables integration with popular Solana wallets like Phantom, Backpack, Solflare, and Glow through Para's provider system. After installation, you can configure it in your ParaProvider.
5
+
6
+ ###Prerequisites
7
+
8
+ To use Para, you need an API key. This key authenticates your requests to Para services and is essential for integration.
9
+
10
+ Don't have an API key yet? Request access to the [Developer Portal](https://developer.getpara.com/) to create API keys, manage billing, teams, and more.
11
+
12
+ ###Learn more
13
+
14
+ For more information on Para’s Solana wallet connector visit the [Para Docs](https://docs.getpara.com/v2/react/guides/external-wallets/solana-lite#solana-wallets-with-react-sdk-lite)
@@ -48,7 +48,7 @@ function ParaSolanaProvider({ children, config, internalConfig }) {
48
48
  ],
49
49
  localStorageKey: "paraSolanaExternal",
50
50
  autoConnect: true,
51
- children: /* @__PURE__ */ jsx(SolanaExternalWalletProvider, __spreadProps(__spreadValues({}, solanaExternalWalletProviderProps), { children }))
51
+ children: /* @__PURE__ */ jsx(SolanaExternalWalletProvider, __spreadProps(__spreadValues({}, solanaExternalWalletProviderProps), { chain, children }))
52
52
  }
53
53
  ) });
54
54
  }
@@ -1,10 +1,13 @@
1
1
  import { PropsWithChildren } from 'react';
2
2
  import { CreateWalletFn } from '../types/Wallet.js';
3
- import { ExternalWalletContextType, ExternalWalletProviderConfig, ExternalWalletProviderConfigBase } from '@getpara/react-common';
3
+ import { ExternalWalletContextType, ExternalWalletProviderConfig, ExternalWalletProviderConfigBase, FarcasterMiniAppManagement } from '@getpara/react-common';
4
4
  import { TExternalHooks } from './externalHooks.js';
5
- export type SolanaExternalWalletContextType = ExternalWalletContextType & TExternalHooks;
5
+ import { Chain } from '@solana-mobile/mobile-wallet-adapter-protocol';
6
+ export type SolanaExternalWalletContextType = ExternalWalletContextType & TExternalHooks & FarcasterMiniAppManagement;
6
7
  export declare const SolanaExternalWalletContext: import("react").Context<SolanaExternalWalletContextType>;
7
8
  export type SolanaExternalWalletProviderConfig = ExternalWalletProviderConfigBase;
8
9
  type SolanaExternalWalletProviderConfigFull = ExternalWalletProviderConfig<CreateWalletFn>;
9
- export declare function SolanaExternalWalletProvider({ children, wallets: walletFns, onSwitchWallet, para, walletsWithFullAuth, includeWalletVerification, connectionOnly, }: SolanaExternalWalletProviderConfigFull & PropsWithChildren): import("react/jsx-runtime").JSX.Element;
10
+ export declare function SolanaExternalWalletProvider({ children, wallets: walletFns, onSwitchWallet, para, walletsWithFullAuth, includeWalletVerification, connectionOnly, chain, }: SolanaExternalWalletProviderConfigFull & PropsWithChildren & {
11
+ chain: Chain;
12
+ }): import("react/jsx-runtime").JSX.Element;
10
13
  export {};
@@ -1,5 +1,7 @@
1
1
  "use client";
2
2
  var __defProp = Object.defineProperty;
3
+ var __defProps = Object.defineProperties;
4
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
3
5
  var __getOwnPropSymbols = Object.getOwnPropertySymbols;
4
6
  var __hasOwnProp = Object.prototype.hasOwnProperty;
5
7
  var __propIsEnum = Object.prototype.propertyIsEnumerable;
@@ -15,6 +17,7 @@ var __spreadValues = (a, b) => {
15
17
  }
16
18
  return a;
17
19
  };
20
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
18
21
  var __async = (__this, __arguments, generator) => {
19
22
  return new Promise((resolve, reject) => {
20
23
  var fulfilled = (value) => {
@@ -36,7 +39,7 @@ var __async = (__this, __arguments, generator) => {
36
39
  });
37
40
  };
38
41
  import { jsx } from "react/jsx-runtime";
39
- import { createContext, useEffect, useMemo, useRef } from "react";
42
+ import { createContext, useEffect, useMemo, useRef, useState } from "react";
40
43
  import { useWallet } from "@solana/wallet-adapter-react";
41
44
  import { isIosAndRedirectable, WalletReadyState } from "@solana/wallet-adapter-base";
42
45
  import {
@@ -44,7 +47,10 @@ import {
44
47
  } from "@getpara/react-common";
45
48
  import bs58 from "bs58";
46
49
  import { externalHooks } from "./externalHooks.js";
47
- const SolanaExternalWalletContext = createContext(defaultSolanaExternalWallet);
50
+ import { farcasterWallet } from "../wallets/connectors/index.js";
51
+ const SolanaExternalWalletContext = createContext(__spreadProps(__spreadValues({}, defaultSolanaExternalWallet), {
52
+ farcasterStatus: void 0
53
+ }));
48
54
  function SolanaExternalWalletProvider({
49
55
  children,
50
56
  wallets: walletFns,
@@ -52,31 +58,28 @@ function SolanaExternalWalletProvider({
52
58
  para,
53
59
  walletsWithFullAuth,
54
60
  includeWalletVerification,
55
- connectionOnly
61
+ connectionOnly,
62
+ chain
56
63
  }) {
57
64
  const {
58
65
  wallets: adapters,
59
66
  select: selectWallet,
60
67
  disconnect,
68
+ disconnecting,
61
69
  publicKey: solanaAddress,
62
70
  wallet,
63
71
  connecting,
64
72
  signMessage: solanaSignMessage
65
73
  } = useWallet();
66
- const isLinkingAccount = useRef(false);
74
+ const disconnectTypeRef = useRef();
67
75
  const solanaSignMessageRef = useRef(solanaSignMessage);
68
76
  const solanaAddressRef = useRef(solanaAddress);
69
77
  const verificationMessage = useRef();
78
+ const [isFarcasterSetup, setIsFarcasterSetup] = useState(false);
70
79
  const reset = () => __async(this, null, function* () {
71
80
  yield disconnect();
72
81
  yield para.logout();
73
82
  });
74
- const _reset = (..._0) => __async(this, [..._0], function* ({ logout = false } = {}) {
75
- yield disconnect();
76
- if (logout) {
77
- yield para.logout();
78
- }
79
- });
80
83
  const login = (_0) => __async(this, [_0], function* ({
81
84
  address,
82
85
  providerId,
@@ -86,18 +89,19 @@ function SolanaExternalWalletProvider({
86
89
  try {
87
90
  return yield para.loginExternalWallet({
88
91
  externalWallet: {
92
+ partnerId: para.partnerId,
89
93
  address,
90
94
  type: "SOLANA",
91
95
  provider: providerName,
92
96
  providerId,
93
- withFullParaAuth: walletsWithFullAuth == null ? void 0 : walletsWithFullAuth.includes(
94
- (_b = (_a = getWallet(providerName != null ? providerName : "")) == null ? void 0 : _a.id.toUpperCase()) != null ? _b : ""
95
- ),
97
+ withFullParaAuth: walletsWithFullAuth === "ALL" || (walletsWithFullAuth == null ? void 0 : walletsWithFullAuth.includes((_b = (_a = getWallet(providerName != null ? providerName : "")) == null ? void 0 : _a.id.toUpperCase()) != null ? _b : "")),
96
98
  withVerification: includeWalletVerification,
97
99
  isConnectionOnly: connectionOnly
98
- }
100
+ },
101
+ uri: window == null ? void 0 : window.location.origin,
102
+ chainId: chain
99
103
  });
100
- } catch (err) {
104
+ } catch (e) {
101
105
  yield reset();
102
106
  throw "Error logging you in. Please try again.";
103
107
  }
@@ -114,7 +118,7 @@ function SolanaExternalWalletProvider({
114
118
  try {
115
119
  yield login({
116
120
  address,
117
- providerId: (_c = getWallet((_b = (_a = wallet == null ? void 0 : wallet.adapter) == null ? void 0 : _a.name) != null ? _b : "")) == null ? void 0 : _c.internalId,
121
+ providerId: (_c = getWallet((_b = (_a = wallet == null ? void 0 : wallet.adapter) == null ? void 0 : _a.name) != null ? _b : "")) == null ? void 0 : _c.id,
118
122
  providerName: (_d = wallet == null ? void 0 : wallet.adapter) == null ? void 0 : _d.name
119
123
  });
120
124
  } catch (err) {
@@ -127,7 +131,7 @@ function SolanaExternalWalletProvider({
127
131
  useEffect(() => {
128
132
  var _a;
129
133
  const storedExternalWallet = para.externalWallets[(_a = solanaAddress == null ? void 0 : solanaAddress.toString()) != null ? _a : ""];
130
- if (!!solanaAddress && !storedExternalWallet && !isLinkingAccount.current) {
134
+ if (!!solanaAddress && !storedExternalWallet && !disconnectTypeRef.current) {
131
135
  reset();
132
136
  }
133
137
  }, []);
@@ -139,7 +143,7 @@ function SolanaExternalWalletProvider({
139
143
  }, [solanaAddress]);
140
144
  useEffect(() => {
141
145
  const storedExternalWallet = Object.values(para.externalWallets || {})[0];
142
- if (!connecting && (!wallet || (wallet == null ? void 0 : wallet.adapter.connected)) && (storedExternalWallet == null ? void 0 : storedExternalWallet.type) === "SOLANA" && (storedExternalWallet == null ? void 0 : storedExternalWallet.address) !== (solanaAddress == null ? void 0 : solanaAddress.toString()) && !isLinkingAccount.current) {
146
+ if (!connecting && (!wallet || (wallet == null ? void 0 : wallet.adapter.connected)) && (storedExternalWallet == null ? void 0 : storedExternalWallet.type) === "SOLANA" && (storedExternalWallet == null ? void 0 : storedExternalWallet.address) !== (solanaAddress == null ? void 0 : solanaAddress.toString()) && !disconnectTypeRef.current) {
143
147
  switchWallet(solanaAddress == null ? void 0 : solanaAddress.toString());
144
148
  }
145
149
  }, [solanaAddress, connecting, wallet]);
@@ -177,6 +181,11 @@ function SolanaExternalWalletProvider({
177
181
  if (!adapter) {
178
182
  throw new Error("Adapter not found.");
179
183
  }
184
+ const wallet2 = getWallet(adapter.name);
185
+ if (wallet2 == null ? void 0 : wallet2.getQrUri) {
186
+ const qrUri = yield wallet2.getQrUri();
187
+ window.dispatchEvent(new CustomEvent("PARA_WALLETCONNECT_URI_READY", { detail: qrUri }));
188
+ }
180
189
  selectWallet(adapter.name);
181
190
  yield new Promise((resolve) => setTimeout(resolve, 100));
182
191
  let address;
@@ -225,7 +234,7 @@ function SolanaExternalWalletProvider({
225
234
  address = yield connectBase(adapter, true);
226
235
  if (address) {
227
236
  try {
228
- authState = yield login({ address, providerId: (_a = getWallet(adapter.name)) == null ? void 0 : _a.internalId, providerName: adapter.name });
237
+ authState = yield login({ address, providerId: (_a = getWallet(adapter.name)) == null ? void 0 : _a.id, providerName: adapter.name });
229
238
  verificationMessage.current = authState.stage === "verify" ? authState.signatureVerificationMessage : void 0;
230
239
  } catch (err) {
231
240
  yield disconnect();
@@ -237,7 +246,8 @@ function SolanaExternalWalletProvider({
237
246
  switch (err.message) {
238
247
  case "User aborted.":
239
248
  case "Approval Denied":
240
- case "You canceled this request.": {
249
+ case "You canceled this request.":
250
+ case "Disconnected before connect event": {
241
251
  error = "Connection request rejected";
242
252
  break;
243
253
  }
@@ -252,15 +262,16 @@ function SolanaExternalWalletProvider({
252
262
  });
253
263
  const requestInfo = (providerId) => __async(this, null, function* () {
254
264
  var _a, _b;
255
- const wallet2 = wallets.find((w) => w.internalId === providerId);
265
+ const wallet2 = wallets.find((w) => w.id === providerId);
256
266
  const adapter = getAdapter((_a = wallet2.name) != null ? _a : "");
257
- isLinkingAccount.current = true;
267
+ disconnectTypeRef.current = "ACCOUNT_LINKING";
258
268
  try {
259
269
  const address = yield connectBase(adapter);
260
270
  const externalWallet = {
271
+ partnerId: para.partnerId,
261
272
  address,
262
273
  type: "SOLANA",
263
- providerId: wallet2.internalId,
274
+ providerId: wallet2.id,
264
275
  provider: wallet2.name
265
276
  };
266
277
  return externalWallet;
@@ -269,19 +280,25 @@ function SolanaExternalWalletProvider({
269
280
  throw new Error((_b = e == null ? void 0 : e.message) != null ? _b : e);
270
281
  }
271
282
  });
272
- const disconnectBase = (providerId) => __async(this, null, function* () {
273
- var _a, _b;
274
- const wallet2 = wallets.find((w) => w.internalId === providerId);
283
+ const disconnectBase = (_0, ..._1) => __async(this, [_0, ..._1], function* (providerId, { disconnectType } = {}) {
284
+ var _a;
285
+ const wallet2 = wallets.find((w) => w.id === providerId);
286
+ if (!wallet2) {
287
+ return;
288
+ }
275
289
  const adapter = getAdapter((_a = wallet2.name) != null ? _a : "");
276
290
  if (!(adapter == null ? void 0 : adapter.connected)) {
277
291
  return;
278
292
  }
279
- isLinkingAccount.current = true;
293
+ if (disconnectType) {
294
+ disconnectTypeRef.current = disconnectType;
295
+ }
280
296
  try {
281
297
  yield adapter.disconnect();
282
298
  } catch (e) {
283
- console.error("Error disconnecting wallet:", e);
284
- throw new Error((_b = e == null ? void 0 : e.message) != null ? _b : e);
299
+ console.error("Error disconnecting Solana wallet:", e);
300
+ } finally {
301
+ disconnectTypeRef.current = void 0;
285
302
  }
286
303
  });
287
304
  const getAdapter = (name) => {
@@ -289,22 +306,103 @@ function SolanaExternalWalletProvider({
289
306
  return (_a = adapters.find((a) => a.adapter.name === "Mobile Wallet Adapter" ? a : a.adapter.name === name ? a : false)) == null ? void 0 : _a.adapter;
290
307
  };
291
308
  const getWallet = (name) => wallets.find((w) => w.name === name);
292
- const wallets = walletFns.map((walletFn) => {
309
+ const createWallet = (walletFn) => {
293
310
  const metaData = walletFn();
294
311
  const adapter = getAdapter(metaData.name);
295
- return __spreadValues({
312
+ return __spreadProps(__spreadValues({
296
313
  connect: () => connect(adapter),
297
314
  connectMobile: () => connect(adapter),
298
315
  type: "SOLANA",
299
316
  installed: adapter && ((adapter == null ? void 0 : adapter.readyState) === WalletReadyState.Installed || (adapter == null ? void 0 : adapter.readyState) === WalletReadyState.Loadable)
300
- }, metaData);
317
+ }, metaData), {
318
+ // Using name here since that's the only common id across the networks
319
+ id: metaData.name
320
+ });
321
+ };
322
+ const [wallets, setWallets] = useState(() => walletFns.map(createWallet));
323
+ const farcasterStatus = useMemo(() => {
324
+ if (!isFarcasterSetup) {
325
+ return void 0;
326
+ }
327
+ const farcasterAdapter = getAdapter("Farcaster");
328
+ if (!farcasterAdapter) {
329
+ return {
330
+ isPresent: false
331
+ };
332
+ }
333
+ return farcasterAdapter.connected && farcasterAdapter.publicKey ? {
334
+ isPresent: true,
335
+ isConnected: true,
336
+ address: farcasterAdapter.publicKey.toString()
337
+ } : {
338
+ isPresent: true,
339
+ isConnected: false
340
+ };
341
+ }, [isFarcasterSetup, adapters]);
342
+ useEffect(() => {
343
+ const detectFarcaster = () => __async(this, null, function* () {
344
+ if (para.isFarcasterMiniApp) {
345
+ try {
346
+ yield import("@farcaster/mini-app-solana");
347
+ } catch (e) {
348
+ }
349
+ }
350
+ });
351
+ detectFarcaster();
352
+ }, [para.isFarcasterMiniApp]);
353
+ useEffect(() => {
354
+ const setupFarcaster = () => __async(this, null, function* () {
355
+ const adapter = getAdapter("Farcaster");
356
+ if (para.isFarcasterMiniApp && !wallets.some((w) => w.internalId === "FARCASTER") && !!adapter) {
357
+ const wallet2 = createWallet(farcasterWallet);
358
+ setWallets((prev) => [...prev, wallet2]);
359
+ if (para.supportedWalletTypes.some(({ type }) => type === "SOLANA")) {
360
+ yield connectBase(adapter, true);
361
+ }
362
+ setIsFarcasterSetup(true);
363
+ }
364
+ });
365
+ setupFarcaster();
366
+ }, [para.isFarcasterMiniApp, wallets, adapters]);
367
+ const injectedWallets = adapters.filter((wallet2) => wallet2.adapter.name !== "Mobile Wallet Adapter" && !wallets.some((w) => w.name === wallet2.adapter.name)).map((wallet2) => {
368
+ const adapter = wallet2.adapter;
369
+ return {
370
+ connect: () => connect(adapter),
371
+ connectMobile: () => connect(adapter),
372
+ type: "SOLANA",
373
+ installed: adapter && ((adapter == null ? void 0 : adapter.readyState) === WalletReadyState.Installed || (adapter == null ? void 0 : adapter.readyState) === WalletReadyState.Loadable),
374
+ name: adapter.name,
375
+ iconUrl: adapter.icon,
376
+ // Using name here since that's the only common id across the networks
377
+ id: adapter.name,
378
+ internalId: adapter.name
379
+ };
301
380
  });
381
+ const walletsWithInjected = [...wallets, ...injectedWallets];
302
382
  return /* @__PURE__ */ jsx(
303
383
  SolanaExternalWalletContext.Provider,
304
384
  {
305
385
  value: useMemo(
306
- () => __spreadValues({ wallets, disconnect, signMessage, signVerificationMessage, requestInfo, disconnectBase }, externalHooks),
307
- [wallets, disconnect, signMessage, signVerificationMessage, requestInfo, disconnectBase]
386
+ () => __spreadValues({
387
+ wallets: walletsWithInjected,
388
+ disconnect,
389
+ disconnectStatus: disconnecting ? "pending" : "idle",
390
+ signMessage,
391
+ signVerificationMessage,
392
+ requestInfo,
393
+ disconnectBase,
394
+ farcasterStatus
395
+ }, externalHooks),
396
+ [
397
+ walletsWithInjected,
398
+ disconnect,
399
+ disconnecting,
400
+ signMessage,
401
+ signVerificationMessage,
402
+ requestInfo,
403
+ farcasterStatus,
404
+ disconnectBase
405
+ ]
308
406
  ),
309
407
  children
310
408
  }
@@ -0,0 +1,2 @@
1
+ import { Wallet } from '../../../types/Wallet.js';
2
+ export declare const farcasterWallet: () => Wallet;
@@ -0,0 +1,16 @@
1
+ "use client";
2
+ import { icon } from "./farcasterIcon.js";
3
+ const farcasterWallet = () => {
4
+ return {
5
+ id: "farcaster",
6
+ internalId: "FARCASTER",
7
+ name: "Farcaster",
8
+ iconUrl: icon,
9
+ isExtension: true,
10
+ hasIosSafariExtension: false,
11
+ downloadUrl: "https://farcaster.xyz"
12
+ };
13
+ };
14
+ export {
15
+ farcasterWallet
16
+ };
@@ -0,0 +1 @@
1
+ export declare const icon = "";
@@ -0,0 +1,5 @@
1
+ "use client";
2
+ const icon = "";
3
+ export {
4
+ icon
5
+ };
@@ -1,6 +1,8 @@
1
+ import { farcasterWallet } from './farcaster/farcaster.js';
1
2
  import { phantomWallet } from './phantom/phantom.js';
2
3
  import { glowWallet } from './glow/glow.js';
3
4
  import { backpackWallet } from './backpack/backpack.js';
4
5
  import { solflareWallet } from './solflare/solflare.js';
5
- export { phantomWallet, glowWallet, backpackWallet, solflareWallet };
6
+ import { metaMaskWallet } from './metaMask/metaMask.js';
7
+ export { farcasterWallet, phantomWallet, glowWallet, backpackWallet, solflareWallet, metaMaskWallet };
6
8
  export declare const allWallets: (() => import("../../types/Wallet.js").Wallet)[];
@@ -1,13 +1,17 @@
1
1
  "use client";
2
+ import { farcasterWallet } from "./farcaster/farcaster.js";
2
3
  import { phantomWallet } from "./phantom/phantom.js";
3
4
  import { glowWallet } from "./glow/glow.js";
4
5
  import { backpackWallet } from "./backpack/backpack.js";
5
6
  import { solflareWallet } from "./solflare/solflare.js";
6
- const allWallets = [phantomWallet, glowWallet, backpackWallet, solflareWallet];
7
+ import { metaMaskWallet } from "./metaMask/metaMask.js";
8
+ const allWallets = [phantomWallet, glowWallet, backpackWallet, solflareWallet, metaMaskWallet];
7
9
  export {
8
10
  allWallets,
9
11
  backpackWallet,
12
+ farcasterWallet,
10
13
  glowWallet,
14
+ metaMaskWallet,
11
15
  phantomWallet,
12
16
  solflareWallet
13
17
  };
@@ -0,0 +1,2 @@
1
+ import { Wallet } from '../../../types/Wallet.js';
2
+ export declare const metaMaskWallet: () => Wallet;
@@ -0,0 +1,25 @@
1
+ "use client";
2
+ import { icon } from "./metaMaskIcon.js";
3
+ const metaMaskWallet = () => {
4
+ return {
5
+ id: "metaMask",
6
+ internalId: "METAMASK",
7
+ name: "MetaMask",
8
+ iconUrl: icon,
9
+ isExtension: true,
10
+ isMobile: true,
11
+ hasIosSafariExtension: false,
12
+ // Metamask deep linking doesn't seem to work as expected currently.
13
+ // getQrUri: async () => {
14
+ // if (typeof window !== 'undefined' && isIosAndRedirectable()) {
15
+ // const url = encodeURIComponent(window.location.href);
16
+ // return `https://link.metamask.io/dapp/${url}`;
17
+ // }
18
+ // return '';
19
+ // },
20
+ downloadUrl: "https://metamask.io/download/"
21
+ };
22
+ };
23
+ export {
24
+ metaMaskWallet
25
+ };
@@ -0,0 +1 @@
1
+ export declare const icon = "";
@@ -0,0 +1,5 @@
1
+ "use client";
2
+ const icon = "";
3
+ export {
4
+ icon
5
+ };
package/package.json CHANGED
@@ -1,9 +1,9 @@
1
1
  {
2
2
  "name": "@getpara/solana-wallet-connectors",
3
- "version": "2.0.0-fc.2",
3
+ "version": "2.0.0",
4
4
  "dependencies": {
5
- "@getpara/react-common": "2.0.0-fc.2",
6
- "@getpara/web-sdk": "2.0.0-fc.2",
5
+ "@getpara/react-common": "2.0.0",
6
+ "@getpara/web-sdk": "2.0.0",
7
7
  "bs58": "6.0.0"
8
8
  },
9
9
  "devDependencies": {
@@ -23,9 +23,10 @@
23
23
  "dist",
24
24
  "package.json"
25
25
  ],
26
- "gitHead": "65106fd9662a2c32b2071a0dea67ef55b3e4e98f",
26
+ "gitHead": "a64b6aa9b3c481a2d955022f621e495fb55e549e",
27
27
  "main": "dist/index.js",
28
28
  "peerDependencies": {
29
+ "@farcaster/mini-app-solana": "^1.0.0",
29
30
  "@solana-mobile/wallet-adapter-mobile": "2.x",
30
31
  "@solana/wallet-adapter-base": "0.x",
31
32
  "@solana/wallet-adapter-react": "0.x",
@@ -33,6 +34,11 @@
33
34
  "react": ">=18",
34
35
  "react-dom": ">=18"
35
36
  },
37
+ "peerDependenciesMeta": {
38
+ "@farcaster/mini-app-solana": {
39
+ "optional": true
40
+ }
41
+ },
36
42
  "scripts": {
37
43
  "build": "rm -rf dist && yarn typegen && node ./scripts/build.mjs",
38
44
  "test": "vitest run --coverage",