@getpara/solana-wallet-connectors 2.0.0-dev.1 → 2.0.0-dev.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.
package/dist/index.d.ts CHANGED
@@ -1,6 +1,7 @@
1
1
  export { SolanaExternalWalletContext } from './providers/SolanaExternalWalletContext.js';
2
- export type { SolanaExternalWalletContextType } from './providers/SolanaExternalWalletContext.js';
2
+ export { type SolanaExternalWalletContextType } from './providers/SolanaExternalWalletContext.js';
3
3
  export { ParaSolanaProvider } from './providers/ParaSolanaProvider.js';
4
4
  export type { ParaSolanaProviderConfig, ParaSolanaProviderProps } from './providers/ParaSolanaProvider.js';
5
5
  export * from './wallets/connectors/index.js';
6
6
  export type { WalletList } from './types/Wallet.js';
7
+ export type { Adapter } from '@solana/wallet-adapter-base';
package/dist/index.js CHANGED
@@ -1,305 +1,8 @@
1
1
  "use client";
2
- var __defProp = Object.defineProperty;
3
- var __defProps = Object.defineProperties;
4
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
5
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
6
- var __hasOwnProp = Object.prototype.hasOwnProperty;
7
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
8
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
9
- var __spreadValues = (a, b) => {
10
- for (var prop in b || (b = {}))
11
- if (__hasOwnProp.call(b, prop))
12
- __defNormalProp(a, prop, b[prop]);
13
- if (__getOwnPropSymbols)
14
- for (var prop of __getOwnPropSymbols(b)) {
15
- if (__propIsEnum.call(b, prop))
16
- __defNormalProp(a, prop, b[prop]);
17
- }
18
- return a;
19
- };
20
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
21
- var __async = (__this, __arguments, generator) => {
22
- return new Promise((resolve, reject) => {
23
- var fulfilled = (value) => {
24
- try {
25
- step(generator.next(value));
26
- } catch (e) {
27
- reject(e);
28
- }
29
- };
30
- var rejected = (value) => {
31
- try {
32
- step(generator.throw(value));
33
- } catch (e) {
34
- reject(e);
35
- }
36
- };
37
- var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
38
- step((generator = generator.apply(__this, __arguments)).next());
39
- });
40
- };
41
-
42
- // src/providers/SolanaExternalWalletContext.tsx
43
- import { createContext, useEffect, useMemo, useRef } from "react";
44
- import { useWallet } from "@solana/wallet-adapter-react";
45
- import { WalletReadyState } from "@solana/wallet-adapter-base";
46
- import { WalletType } from "@getpara/web-sdk";
47
- import bs58 from "bs58";
48
- import { jsx } from "react/jsx-runtime";
49
- var defaultSolanaExternalWallet = {
50
- wallets: [],
51
- disconnect: () => Promise.resolve(),
52
- signMessage: () => Promise.resolve({}),
53
- signVerificationMessage: () => Promise.resolve({})
54
- };
55
- var SolanaExternalWalletContext = createContext(defaultSolanaExternalWallet);
56
- function SolanaExternalWalletProvider({
57
- children,
58
- wallets: walletFns,
59
- onSwitchWallet,
60
- para,
61
- walletsWithFullAuth
62
- }) {
63
- const {
64
- wallets: adapters,
65
- select: selectWallet,
66
- disconnect: _disconnect,
67
- publicKey: solanaAddress,
68
- wallet,
69
- connecting,
70
- connected,
71
- signMessage: solanaSignMessage
72
- } = useWallet();
73
- const verificationMessage = useRef();
74
- const reset = () => __async(this, null, function* () {
75
- yield _disconnect();
76
- yield para.logout();
77
- });
78
- const login = (_0) => __async(this, [_0], function* ({ address, providerName }) {
79
- var _a, _b;
80
- try {
81
- return yield para.externalWalletLogin({
82
- address,
83
- type: WalletType.SOLANA,
84
- provider: providerName,
85
- withFullParaAuth: walletsWithFullAuth == null ? void 0 : walletsWithFullAuth.includes(
86
- (_b = (_a = getWallet(providerName != null ? providerName : "")) == null ? void 0 : _a.id.toUpperCase()) != null ? _b : ""
87
- )
88
- });
89
- } catch (err) {
90
- yield reset();
91
- throw "Error logging you in. Please try again.";
92
- }
93
- });
94
- const switchWallet = (address) => __async(this, null, function* () {
95
- var _a;
96
- let error;
97
- if (!address) {
98
- yield para.logout();
99
- } else {
100
- try {
101
- yield login({ address, providerName: (_a = wallet == null ? void 0 : wallet.adapter) == null ? void 0 : _a.name });
102
- } catch (err) {
103
- error = err;
104
- }
105
- }
106
- onSwitchWallet({ address, error });
107
- });
108
- useEffect(() => {
109
- var _a;
110
- const storedExternalWallet = para.externalWallets[(_a = solanaAddress == null ? void 0 : solanaAddress.toString()) != null ? _a : ""];
111
- if (!!solanaAddress && !storedExternalWallet) {
112
- reset();
113
- }
114
- }, []);
115
- useEffect(() => {
116
- const storedExternalWallet = Object.values(para.externalWallets || {})[0];
117
- if (!connecting && (!wallet || (wallet == null ? void 0 : wallet.adapter.connected)) && (storedExternalWallet == null ? void 0 : storedExternalWallet.type) === WalletType.SOLANA && (storedExternalWallet == null ? void 0 : storedExternalWallet.address) !== (solanaAddress == null ? void 0 : solanaAddress.toString())) {
118
- switchWallet(solanaAddress == null ? void 0 : solanaAddress.toString());
119
- }
120
- }, [solanaAddress, connecting, wallet]);
121
- const signMessage = (message) => __async(this, null, function* () {
122
- try {
123
- const encodedMessage = new TextEncoder().encode(message);
124
- const signature = yield solanaSignMessage(encodedMessage);
125
- return {
126
- address: solanaAddress.toString(),
127
- signature: bs58.encode(signature)
128
- };
129
- } catch (e) {
130
- if (e.message.includes("User rejected the request")) {
131
- return { error: "Signature request rejected" };
132
- }
133
- return { error: "An unknown error occurred" };
134
- }
135
- });
136
- const signVerificationMessage = () => __async(this, null, function* () {
137
- const signature = yield signMessage(verificationMessage.current);
138
- return signature;
139
- });
140
- const connect = (adapter) => __async(this, null, function* () {
141
- yield _disconnect();
142
- if (!adapter) {
143
- return { address: void 0, error: "Adapter not found.", userExists: false, isVerified: false };
144
- }
145
- selectWallet(adapter.name);
146
- yield new Promise((resolve) => setTimeout(resolve, 100));
147
- let address;
148
- let error;
149
- let userExists = false;
150
- let isVerified = false;
151
- try {
152
- yield adapter.connect();
153
- address = adapter.publicKey.toString();
154
- if (address) {
155
- try {
156
- yield login({ address, providerName: adapter.name });
157
- } catch (err) {
158
- yield _disconnect();
159
- address = void 0;
160
- error = err;
161
- }
162
- }
163
- } catch (err) {
164
- switch (err.message) {
165
- case "User aborted.":
166
- case "Approval Denied":
167
- case "You canceled this request.": {
168
- error = "Connection request rejected";
169
- break;
170
- }
171
- default: {
172
- error = "An unknown error occurred";
173
- break;
174
- }
175
- }
176
- }
177
- return { address, error, userExists, isVerified };
178
- });
179
- const getAdapter = (name) => {
180
- var _a;
181
- return (_a = adapters.find((a) => a.adapter.name === "Mobile Wallet Adapter" ? a : a.adapter.name === name ? a : false)) == null ? void 0 : _a.adapter;
182
- };
183
- const getWallet = (name) => wallets.find((w) => w.name === name);
184
- const wallets = walletFns.map((walletFn) => {
185
- const metaData = walletFn();
186
- const adapter = getAdapter(metaData.name);
187
- return __spreadValues({
188
- connect: () => connect(adapter),
189
- connectMobile: () => connect(adapter),
190
- getQrUri: () => "",
191
- type: WalletType.SOLANA,
192
- installed: adapter && ((adapter == null ? void 0 : adapter.readyState) === WalletReadyState.Installed || (adapter == null ? void 0 : adapter.readyState) === WalletReadyState.Loadable)
193
- }, metaData);
194
- });
195
- const disconnect = () => __async(this, null, function* () {
196
- yield _disconnect();
197
- if (connected) {
198
- typeof window !== void 0 && (window == null ? void 0 : window.location.reload());
199
- }
200
- });
201
- return /* @__PURE__ */ jsx(
202
- SolanaExternalWalletContext.Provider,
203
- {
204
- value: useMemo(
205
- () => ({ wallets, disconnect, signMessage, signVerificationMessage }),
206
- [wallets, disconnect, signMessage, signVerificationMessage]
207
- ),
208
- children
209
- }
210
- );
211
- }
212
-
213
- // src/providers/ParaSolanaProvider.tsx
214
- import { useMemo as useMemo2 } from "react";
215
- import { ConnectionProvider, WalletProvider as SolanaWalletProvider } from "@solana/wallet-adapter-react";
216
- import {
217
- createDefaultAddressSelector,
218
- createDefaultAuthorizationResultCache,
219
- createDefaultWalletNotFoundHandler,
220
- SolanaMobileWalletAdapter
221
- } from "@solana-mobile/wallet-adapter-mobile";
222
- import { jsx as jsx2 } from "react/jsx-runtime";
223
- function ParaSolanaProvider({ children, config, internalConfig }) {
224
- const { wallets: walletFns, endpoint, appIdentity, chain, connectionConfig } = config;
225
- const solanaExternalWalletProviderProps = useMemo2(
226
- () => __spreadValues({ wallets: walletFns }, internalConfig),
227
- [walletFns, internalConfig]
228
- );
229
- return /* @__PURE__ */ jsx2(ConnectionProvider, { endpoint, config: connectionConfig, children: /* @__PURE__ */ jsx2(
230
- SolanaWalletProvider,
231
- {
232
- wallets: [
233
- new SolanaMobileWalletAdapter({
234
- addressSelector: createDefaultAddressSelector(),
235
- appIdentity,
236
- authorizationResultCache: createDefaultAuthorizationResultCache(),
237
- chain,
238
- onWalletNotFound: createDefaultWalletNotFoundHandler()
239
- })
240
- ],
241
- localStorageKey: "paraSolanaExternal",
242
- autoConnect: true,
243
- children: /* @__PURE__ */ jsx2(SolanaExternalWalletProvider, __spreadProps(__spreadValues({}, solanaExternalWalletProviderProps), { children }))
244
- }
245
- ) });
246
- }
247
-
248
- // src/wallets/connectors/phantom/phantomIcon.ts
249
- var icon = "";
250
-
251
- // src/wallets/connectors/phantom/phantom.ts
252
- var phantomWallet = () => {
253
- return {
254
- id: "phantom",
255
- name: "Phantom",
256
- iconUrl: icon,
257
- isExtension: true,
258
- isMobile: true,
259
- getUri: () => "",
260
- downloadUrl: "https://phantom.app/download"
261
- };
262
- };
263
-
264
- // src/wallets/connectors/glow/glowIcon.ts
265
- var icon2 = "";
266
-
267
- // src/wallets/connectors/glow/glow.ts
268
- var glowWallet = () => {
269
- return {
270
- id: "glow",
271
- name: "Glow",
272
- iconUrl: icon2,
273
- isExtension: true,
274
- isMobile: true,
275
- getUri: () => "",
276
- downloadUrl: "https://glow.app"
277
- };
278
- };
279
-
280
- // src/wallets/connectors/backpack/backpackIcon.ts
281
- var icon3 = "";
282
-
283
- // src/wallets/connectors/backpack/backpack.ts
284
- var backpackWallet = () => {
285
- return {
286
- id: "backpack",
287
- name: "Backpack",
288
- iconUrl: icon3,
289
- isExtension: true,
290
- isMobile: true,
291
- getUri: () => "",
292
- downloadUrl: "https://backpack.app/download"
293
- };
294
- };
295
-
296
- // src/wallets/connectors/index.ts
297
- var allWallets = [phantomWallet, glowWallet, backpackWallet];
2
+ import { SolanaExternalWalletContext } from "./providers/SolanaExternalWalletContext.js";
3
+ import { ParaSolanaProvider } from "./providers/ParaSolanaProvider.js";
4
+ export * from "./wallets/connectors/index.js";
298
5
  export {
299
6
  ParaSolanaProvider,
300
- SolanaExternalWalletContext,
301
- allWallets,
302
- backpackWallet,
303
- glowWallet,
304
- phantomWallet
7
+ SolanaExternalWalletContext
305
8
  };
@@ -0,0 +1,3 @@
1
+ {
2
+ "type": "module"
3
+ }
@@ -0,0 +1,57 @@
1
+ "use client";
2
+ var __defProp = Object.defineProperty;
3
+ var __defProps = Object.defineProperties;
4
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
5
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
8
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
9
+ var __spreadValues = (a, b) => {
10
+ for (var prop in b || (b = {}))
11
+ if (__hasOwnProp.call(b, prop))
12
+ __defNormalProp(a, prop, b[prop]);
13
+ if (__getOwnPropSymbols)
14
+ for (var prop of __getOwnPropSymbols(b)) {
15
+ if (__propIsEnum.call(b, prop))
16
+ __defNormalProp(a, prop, b[prop]);
17
+ }
18
+ return a;
19
+ };
20
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
21
+ import { jsx } from "react/jsx-runtime";
22
+ import { useMemo } from "react";
23
+ import { ConnectionProvider, WalletProvider as SolanaWalletProvider } from "@solana/wallet-adapter-react";
24
+ import { SolanaExternalWalletProvider } from "./SolanaExternalWalletContext.js";
25
+ import {
26
+ createDefaultAddressSelector,
27
+ createDefaultAuthorizationResultCache,
28
+ createDefaultWalletNotFoundHandler,
29
+ SolanaMobileWalletAdapter
30
+ } from "@solana-mobile/wallet-adapter-mobile";
31
+ function ParaSolanaProvider({ children, config, internalConfig }) {
32
+ const { wallets: walletFns, endpoint, appIdentity, chain, connectionConfig } = config;
33
+ const solanaExternalWalletProviderProps = useMemo(
34
+ () => __spreadValues({ wallets: walletFns }, internalConfig),
35
+ [walletFns, internalConfig]
36
+ );
37
+ return /* @__PURE__ */ jsx(ConnectionProvider, { endpoint, config: connectionConfig, children: /* @__PURE__ */ jsx(
38
+ SolanaWalletProvider,
39
+ {
40
+ wallets: [
41
+ new SolanaMobileWalletAdapter({
42
+ addressSelector: createDefaultAddressSelector(),
43
+ appIdentity,
44
+ authorizationResultCache: createDefaultAuthorizationResultCache(),
45
+ chain,
46
+ onWalletNotFound: createDefaultWalletNotFoundHandler()
47
+ })
48
+ ],
49
+ localStorageKey: "paraSolanaExternal",
50
+ autoConnect: true,
51
+ children: /* @__PURE__ */ jsx(SolanaExternalWalletProvider, __spreadProps(__spreadValues({}, solanaExternalWalletProviderProps), { children }))
52
+ }
53
+ ) });
54
+ }
55
+ export {
56
+ ParaSolanaProvider
57
+ };
@@ -1,31 +1,10 @@
1
1
  import { PropsWithChildren } from 'react';
2
- import ParaWeb from '@getpara/web-sdk';
3
- import { WalletList } from '../types/Wallet.js';
4
- import { TExternalWallet, type CommonWallet } from '@getpara/react-common';
5
- export type SolanaExternalWalletContextType = {
6
- wallets: CommonWallet[];
7
- disconnect: () => Promise<void>;
8
- signMessage: (message: string) => Promise<{
9
- signature?: string;
10
- error?: string;
11
- }>;
12
- signVerificationMessage: () => Promise<{
13
- address?: string;
14
- signature?: string;
15
- error?: string;
16
- }>;
17
- };
2
+ import { CreateWalletFn } from '../types/Wallet.js';
3
+ import { ExternalWalletContextType, ExternalWalletProviderConfig, ExternalWalletProviderConfigBase } from '@getpara/react-common';
4
+ import { TExternalHooks } from './externalHooks.js';
5
+ export type SolanaExternalWalletContextType = ExternalWalletContextType & TExternalHooks;
18
6
  export declare const SolanaExternalWalletContext: import("react").Context<SolanaExternalWalletContextType>;
19
- export type SolanaExternalWalletProviderConfig = {
20
- onSwitchWallet?: (args: {
21
- address?: string;
22
- error?: string;
23
- }) => void;
24
- para: ParaWeb;
25
- walletsWithFullAuth: TExternalWallet[];
26
- };
27
- type SolanaExternalWalletProviderConfigFull = {
28
- wallets: WalletList;
29
- } & SolanaExternalWalletProviderConfig;
30
- export declare function SolanaExternalWalletProvider({ children, wallets: walletFns, onSwitchWallet, para, walletsWithFullAuth, }: SolanaExternalWalletProviderConfigFull & PropsWithChildren): import("react/jsx-runtime").JSX.Element;
7
+ export type SolanaExternalWalletProviderConfig = ExternalWalletProviderConfigBase;
8
+ 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;
31
10
  export {};
@@ -0,0 +1,316 @@
1
+ "use client";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
6
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
7
+ var __spreadValues = (a, b) => {
8
+ for (var prop in b || (b = {}))
9
+ if (__hasOwnProp.call(b, prop))
10
+ __defNormalProp(a, prop, b[prop]);
11
+ if (__getOwnPropSymbols)
12
+ for (var prop of __getOwnPropSymbols(b)) {
13
+ if (__propIsEnum.call(b, prop))
14
+ __defNormalProp(a, prop, b[prop]);
15
+ }
16
+ return a;
17
+ };
18
+ var __async = (__this, __arguments, generator) => {
19
+ return new Promise((resolve, reject) => {
20
+ var fulfilled = (value) => {
21
+ try {
22
+ step(generator.next(value));
23
+ } catch (e) {
24
+ reject(e);
25
+ }
26
+ };
27
+ var rejected = (value) => {
28
+ try {
29
+ step(generator.throw(value));
30
+ } catch (e) {
31
+ reject(e);
32
+ }
33
+ };
34
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
35
+ step((generator = generator.apply(__this, __arguments)).next());
36
+ });
37
+ };
38
+ import { jsx } from "react/jsx-runtime";
39
+ import { createContext, useEffect, useMemo, useRef } from "react";
40
+ import { useWallet } from "@solana/wallet-adapter-react";
41
+ import { isIosAndRedirectable, WalletReadyState } from "@solana/wallet-adapter-base";
42
+ import {
43
+ defaultSolanaExternalWallet
44
+ } from "@getpara/react-common";
45
+ import bs58 from "bs58";
46
+ import { externalHooks } from "./externalHooks.js";
47
+ const SolanaExternalWalletContext = createContext(defaultSolanaExternalWallet);
48
+ function SolanaExternalWalletProvider({
49
+ children,
50
+ wallets: walletFns,
51
+ onSwitchWallet,
52
+ para,
53
+ walletsWithFullAuth,
54
+ includeWalletVerification,
55
+ connectionOnly
56
+ }) {
57
+ const {
58
+ wallets: adapters,
59
+ select: selectWallet,
60
+ disconnect,
61
+ publicKey: solanaAddress,
62
+ wallet,
63
+ connecting,
64
+ signMessage: solanaSignMessage
65
+ } = useWallet();
66
+ const isLinkingAccount = useRef(false);
67
+ const solanaSignMessageRef = useRef(solanaSignMessage);
68
+ const solanaAddressRef = useRef(solanaAddress);
69
+ const verificationMessage = useRef();
70
+ const reset = () => __async(this, null, function* () {
71
+ yield disconnect();
72
+ yield para.logout();
73
+ });
74
+ const _reset = (..._0) => __async(this, [..._0], function* ({ logout = false } = {}) {
75
+ yield disconnect();
76
+ if (logout) {
77
+ yield para.logout();
78
+ }
79
+ });
80
+ const login = (_0) => __async(this, [_0], function* ({
81
+ address,
82
+ providerId,
83
+ providerName
84
+ }) {
85
+ var _a, _b;
86
+ try {
87
+ return yield para.loginExternalWallet({
88
+ externalWallet: {
89
+ address,
90
+ type: "SOLANA",
91
+ provider: providerName,
92
+ 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
+ ),
96
+ withVerification: includeWalletVerification,
97
+ isConnectionOnly: connectionOnly
98
+ }
99
+ });
100
+ } catch (err) {
101
+ yield reset();
102
+ throw "Error logging you in. Please try again.";
103
+ }
104
+ });
105
+ const switchWallet = (address) => __async(this, null, function* () {
106
+ var _a, _b, _c, _d;
107
+ let error;
108
+ if (!address) {
109
+ yield para.logout();
110
+ } else {
111
+ if (para.isExternalWalletAuth || para.isExternalWalletWithVerification) {
112
+ yield reset();
113
+ } else {
114
+ try {
115
+ yield login({
116
+ 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,
118
+ providerName: (_d = wallet == null ? void 0 : wallet.adapter) == null ? void 0 : _d.name
119
+ });
120
+ } catch (err) {
121
+ error = err;
122
+ }
123
+ }
124
+ }
125
+ onSwitchWallet({ address, error });
126
+ });
127
+ useEffect(() => {
128
+ var _a;
129
+ const storedExternalWallet = para.externalWallets[(_a = solanaAddress == null ? void 0 : solanaAddress.toString()) != null ? _a : ""];
130
+ if (!!solanaAddress && !storedExternalWallet && !isLinkingAccount.current) {
131
+ reset();
132
+ }
133
+ }, []);
134
+ useEffect(() => {
135
+ solanaSignMessageRef.current = solanaSignMessage;
136
+ }, [solanaSignMessage]);
137
+ useEffect(() => {
138
+ solanaAddressRef.current = solanaAddress;
139
+ }, [solanaAddress]);
140
+ useEffect(() => {
141
+ 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) {
143
+ switchWallet(solanaAddress == null ? void 0 : solanaAddress.toString());
144
+ }
145
+ }, [solanaAddress, connecting, wallet]);
146
+ const signMessage = (_0) => __async(this, [_0], function* ({ message }) {
147
+ var _a, _b, _c, _d;
148
+ try {
149
+ let solanaAddressNow = (_a = solanaAddressRef.current) != null ? _a : solanaAddress, solanaSignMessageNow = (_b = solanaSignMessageRef.current) != null ? _b : solanaSignMessage;
150
+ while (!solanaAddressNow || !solanaSignMessageNow) {
151
+ yield new Promise((resolve) => setTimeout(resolve, 100));
152
+ solanaAddressNow = (_c = solanaAddressRef.current) != null ? _c : solanaAddress;
153
+ solanaSignMessageNow = (_d = solanaSignMessageRef.current) != null ? _d : solanaSignMessage;
154
+ }
155
+ const encodedMessage = new TextEncoder().encode(message);
156
+ const signature = yield solanaSignMessageNow(encodedMessage);
157
+ solanaAddressRef.current = void 0;
158
+ solanaSignMessageRef.current = void 0;
159
+ return {
160
+ address: solanaAddressNow.toString(),
161
+ signature: bs58.encode(signature)
162
+ };
163
+ } catch (e) {
164
+ console.error(e);
165
+ if (e.message.includes("User rejected the request")) {
166
+ return { error: "Signature request rejected" };
167
+ }
168
+ console.error("Solana signature error:", e.message);
169
+ return { error: "An unknown error occurred" };
170
+ }
171
+ });
172
+ const signVerificationMessage = () => __async(this, null, function* () {
173
+ const signature = yield signMessage({ message: verificationMessage.current });
174
+ return signature;
175
+ });
176
+ const connectBase = (adapter, _switchWallet = false) => __async(this, null, function* () {
177
+ if (!adapter) {
178
+ throw new Error("Adapter not found.");
179
+ }
180
+ selectWallet(adapter.name);
181
+ yield new Promise((resolve) => setTimeout(resolve, 100));
182
+ let address;
183
+ let error;
184
+ try {
185
+ yield adapter.connect();
186
+ if (adapter.publicKey) {
187
+ address = adapter.publicKey.toString();
188
+ } else {
189
+ yield new Promise((resolve, reject) => {
190
+ adapter.once("connect", () => __async(this, null, function* () {
191
+ try {
192
+ address = adapter.publicKey.toString();
193
+ resolve();
194
+ } catch (err) {
195
+ reject(err);
196
+ }
197
+ }));
198
+ adapter.once("error", (err) => {
199
+ error = (err == null ? void 0 : err.message) || "An unknown error occurred";
200
+ reject(err);
201
+ });
202
+ adapter.once("disconnect", () => {
203
+ error = "Disconnected before connect event";
204
+ reject(new Error(error));
205
+ });
206
+ });
207
+ }
208
+ return address;
209
+ } catch (e) {
210
+ console.error(e);
211
+ yield adapter.disconnect();
212
+ throw e;
213
+ }
214
+ });
215
+ const connect = (adapter) => __async(this, null, function* () {
216
+ var _a;
217
+ if (isIosAndRedirectable()) {
218
+ return;
219
+ }
220
+ yield disconnect();
221
+ let address;
222
+ let error;
223
+ let authState;
224
+ try {
225
+ address = yield connectBase(adapter, true);
226
+ if (address) {
227
+ try {
228
+ authState = yield login({ address, providerId: (_a = getWallet(adapter.name)) == null ? void 0 : _a.internalId, providerName: adapter.name });
229
+ verificationMessage.current = authState.stage === "verify" ? authState.signatureVerificationMessage : void 0;
230
+ } catch (err) {
231
+ yield disconnect();
232
+ address = void 0;
233
+ error = err;
234
+ }
235
+ }
236
+ } catch (err) {
237
+ switch (err.message) {
238
+ case "User aborted.":
239
+ case "Approval Denied":
240
+ case "You canceled this request.": {
241
+ error = "Connection request rejected";
242
+ break;
243
+ }
244
+ default: {
245
+ console.error("Solana connection error:", err.message);
246
+ error = "An unknown error occurred";
247
+ break;
248
+ }
249
+ }
250
+ }
251
+ return { address, error, authState };
252
+ });
253
+ const requestInfo = (providerId) => __async(this, null, function* () {
254
+ var _a, _b;
255
+ const wallet2 = wallets.find((w) => w.internalId === providerId);
256
+ const adapter = getAdapter((_a = wallet2.name) != null ? _a : "");
257
+ isLinkingAccount.current = true;
258
+ try {
259
+ const address = yield connectBase(adapter);
260
+ const externalWallet = {
261
+ address,
262
+ type: "SOLANA",
263
+ providerId: wallet2.internalId,
264
+ provider: wallet2.name
265
+ };
266
+ return externalWallet;
267
+ } catch (e) {
268
+ console.error("Error linking account:", e);
269
+ throw new Error((_b = e == null ? void 0 : e.message) != null ? _b : e);
270
+ }
271
+ });
272
+ const disconnectBase = (providerId) => __async(this, null, function* () {
273
+ var _a, _b;
274
+ const wallet2 = wallets.find((w) => w.internalId === providerId);
275
+ const adapter = getAdapter((_a = wallet2.name) != null ? _a : "");
276
+ if (!(adapter == null ? void 0 : adapter.connected)) {
277
+ return;
278
+ }
279
+ isLinkingAccount.current = true;
280
+ try {
281
+ yield adapter.disconnect();
282
+ } catch (e) {
283
+ console.error("Error disconnecting wallet:", e);
284
+ throw new Error((_b = e == null ? void 0 : e.message) != null ? _b : e);
285
+ }
286
+ });
287
+ const getAdapter = (name) => {
288
+ var _a;
289
+ return (_a = adapters.find((a) => a.adapter.name === "Mobile Wallet Adapter" ? a : a.adapter.name === name ? a : false)) == null ? void 0 : _a.adapter;
290
+ };
291
+ const getWallet = (name) => wallets.find((w) => w.name === name);
292
+ const wallets = walletFns.map((walletFn) => {
293
+ const metaData = walletFn();
294
+ const adapter = getAdapter(metaData.name);
295
+ return __spreadValues({
296
+ connect: () => connect(adapter),
297
+ connectMobile: () => connect(adapter),
298
+ type: "SOLANA",
299
+ installed: adapter && ((adapter == null ? void 0 : adapter.readyState) === WalletReadyState.Installed || (adapter == null ? void 0 : adapter.readyState) === WalletReadyState.Loadable)
300
+ }, metaData);
301
+ });
302
+ return /* @__PURE__ */ jsx(
303
+ SolanaExternalWalletContext.Provider,
304
+ {
305
+ value: useMemo(
306
+ () => __spreadValues({ wallets, disconnect, signMessage, signVerificationMessage, requestInfo, disconnectBase }, externalHooks),
307
+ [wallets, disconnect, signMessage, signVerificationMessage, requestInfo, disconnectBase]
308
+ ),
309
+ children
310
+ }
311
+ );
312
+ }
313
+ export {
314
+ SolanaExternalWalletContext,
315
+ SolanaExternalWalletProvider
316
+ };
@@ -0,0 +1,7 @@
1
+ import { useWallet } from '@solana/wallet-adapter-react';
2
+ export type TExternalHooks = {
3
+ useWallet: typeof useWallet;
4
+ };
5
+ export declare const externalHooks: {
6
+ useWallet: typeof useWallet;
7
+ };
@@ -0,0 +1,6 @@
1
+ "use client";
2
+ import { useWallet } from "@solana/wallet-adapter-react";
3
+ const externalHooks = { useWallet };
4
+ export {
5
+ externalHooks
6
+ };
@@ -1,6 +1,4 @@
1
1
  import { type WalletMetadata } from '@getpara/react-common';
2
- export type Wallet = {
3
- getUri?: (uri: string) => string;
4
- } & WalletMetadata;
2
+ export type Wallet = WalletMetadata;
5
3
  export type CreateWalletFn = () => Wallet;
6
4
  export type WalletList = CreateWalletFn[];
@@ -0,0 +1 @@
1
+ "use client";
@@ -0,0 +1,46 @@
1
+ "use client";
2
+ var __async = (__this, __arguments, generator) => {
3
+ return new Promise((resolve, reject) => {
4
+ var fulfilled = (value) => {
5
+ try {
6
+ step(generator.next(value));
7
+ } catch (e) {
8
+ reject(e);
9
+ }
10
+ };
11
+ var rejected = (value) => {
12
+ try {
13
+ step(generator.throw(value));
14
+ } catch (e) {
15
+ reject(e);
16
+ }
17
+ };
18
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
19
+ step((generator = generator.apply(__this, __arguments)).next());
20
+ });
21
+ };
22
+ import { isIosAndRedirectable } from "@solana/wallet-adapter-base";
23
+ import { icon } from "./backpackIcon.js";
24
+ const backpackWallet = () => {
25
+ return {
26
+ id: "backpack",
27
+ internalId: "BACKPACK",
28
+ name: "Backpack",
29
+ iconUrl: icon,
30
+ isExtension: true,
31
+ isMobile: true,
32
+ hasIosSafariExtension: false,
33
+ getQrUri: () => __async(void 0, null, function* () {
34
+ if (typeof window !== "undefined" && isIosAndRedirectable()) {
35
+ const url = encodeURIComponent(window.location.href);
36
+ const ref = encodeURIComponent(window.location.origin);
37
+ return `https://backpack.app/ul/v1/browse/${url}?ref=${ref}`;
38
+ }
39
+ return "";
40
+ }),
41
+ downloadUrl: "https://backpack.app/download"
42
+ };
43
+ };
44
+ export {
45
+ backpackWallet
46
+ };
@@ -0,0 +1,5 @@
1
+ "use client";
2
+ const icon = "";
3
+ export {
4
+ icon
5
+ };
@@ -0,0 +1,18 @@
1
+ "use client";
2
+ import { icon } from "./glowIcon.js";
3
+ import { isIosAndRedirectable } from "@solana/wallet-adapter-base";
4
+ const glowWallet = () => {
5
+ return {
6
+ id: "glow",
7
+ internalId: "GLOW",
8
+ name: "Glow",
9
+ iconUrl: icon,
10
+ isExtension: true,
11
+ isMobile: true,
12
+ hasIosSafariExtension: isIosAndRedirectable(),
13
+ downloadUrl: "https://glow.app"
14
+ };
15
+ };
16
+ export {
17
+ glowWallet
18
+ };
@@ -0,0 +1,5 @@
1
+ "use client";
2
+ const icon = "";
3
+ export {
4
+ icon
5
+ };
@@ -1,5 +1,6 @@
1
1
  import { phantomWallet } from './phantom/phantom.js';
2
2
  import { glowWallet } from './glow/glow.js';
3
3
  import { backpackWallet } from './backpack/backpack.js';
4
- export { phantomWallet, glowWallet, backpackWallet };
4
+ import { solflareWallet } from './solflare/solflare.js';
5
+ export { phantomWallet, glowWallet, backpackWallet, solflareWallet };
5
6
  export declare const allWallets: (() => import("../../types/Wallet.js").Wallet)[];
@@ -0,0 +1,13 @@
1
+ "use client";
2
+ import { phantomWallet } from "./phantom/phantom.js";
3
+ import { glowWallet } from "./glow/glow.js";
4
+ import { backpackWallet } from "./backpack/backpack.js";
5
+ import { solflareWallet } from "./solflare/solflare.js";
6
+ const allWallets = [phantomWallet, glowWallet, backpackWallet, solflareWallet];
7
+ export {
8
+ allWallets,
9
+ backpackWallet,
10
+ glowWallet,
11
+ phantomWallet,
12
+ solflareWallet
13
+ };
@@ -0,0 +1,46 @@
1
+ "use client";
2
+ var __async = (__this, __arguments, generator) => {
3
+ return new Promise((resolve, reject) => {
4
+ var fulfilled = (value) => {
5
+ try {
6
+ step(generator.next(value));
7
+ } catch (e) {
8
+ reject(e);
9
+ }
10
+ };
11
+ var rejected = (value) => {
12
+ try {
13
+ step(generator.throw(value));
14
+ } catch (e) {
15
+ reject(e);
16
+ }
17
+ };
18
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
19
+ step((generator = generator.apply(__this, __arguments)).next());
20
+ });
21
+ };
22
+ import { isIosAndRedirectable } from "@solana/wallet-adapter-base";
23
+ import { icon } from "./phantomIcon.js";
24
+ const phantomWallet = () => {
25
+ return {
26
+ id: "phantom",
27
+ internalId: "PHANTOM",
28
+ name: "Phantom",
29
+ iconUrl: icon,
30
+ isExtension: true,
31
+ isMobile: true,
32
+ hasIosSafariExtension: false,
33
+ getQrUri: () => __async(void 0, null, function* () {
34
+ if (typeof window !== "undefined" && isIosAndRedirectable()) {
35
+ const url = encodeURIComponent(window.location.href);
36
+ const ref = encodeURIComponent(window.location.origin);
37
+ return `https://phantom.app/ul/browse/${url}?ref=${ref}`;
38
+ }
39
+ return "";
40
+ }),
41
+ downloadUrl: "https://phantom.app/download"
42
+ };
43
+ };
44
+ export {
45
+ phantomWallet
46
+ };
@@ -1 +1 @@
1
- export declare const icon = "";
1
+ export declare const icon = "";
@@ -0,0 +1,5 @@
1
+ "use client";
2
+ const icon = "";
3
+ export {
4
+ icon
5
+ };
@@ -0,0 +1,2 @@
1
+ import { Wallet } from '../../../types/Wallet.js';
2
+ export declare const solflareWallet: () => Wallet;
@@ -0,0 +1,46 @@
1
+ "use client";
2
+ var __async = (__this, __arguments, generator) => {
3
+ return new Promise((resolve, reject) => {
4
+ var fulfilled = (value) => {
5
+ try {
6
+ step(generator.next(value));
7
+ } catch (e) {
8
+ reject(e);
9
+ }
10
+ };
11
+ var rejected = (value) => {
12
+ try {
13
+ step(generator.throw(value));
14
+ } catch (e) {
15
+ reject(e);
16
+ }
17
+ };
18
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
19
+ step((generator = generator.apply(__this, __arguments)).next());
20
+ });
21
+ };
22
+ import { isIosAndRedirectable } from "@solana/wallet-adapter-base";
23
+ import { icon } from "./solflareIcon.js";
24
+ const solflareWallet = () => {
25
+ return {
26
+ id: "solflare",
27
+ internalId: "SOLFLARE",
28
+ name: "Solflare",
29
+ iconUrl: icon,
30
+ isExtension: true,
31
+ isMobile: true,
32
+ hasIosSafariExtension: false,
33
+ getQrUri: () => __async(void 0, null, function* () {
34
+ if (typeof window !== "undefined" && isIosAndRedirectable()) {
35
+ const url = encodeURIComponent(window.location.href);
36
+ const ref = encodeURIComponent(window.location.origin);
37
+ return `https://solflare.com/ul/v1/browse/${url}?ref=${ref}`;
38
+ }
39
+ return "";
40
+ }),
41
+ downloadUrl: "https://www.solflare.com/download/"
42
+ };
43
+ };
44
+ export {
45
+ solflareWallet
46
+ };
@@ -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,39 +1,43 @@
1
1
  {
2
2
  "name": "@getpara/solana-wallet-connectors",
3
- "version": "2.0.0-dev.1",
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
- },
11
- "scripts": {
12
- "build": "rm -rf dist && yarn typegen && node ./scripts/build.mjs",
13
- "typegen": "tsc --emitDeclarationOnly",
14
- "test": "vitest run --coverage"
15
- },
3
+ "version": "2.0.0-dev.3",
16
4
  "dependencies": {
17
- "@getpara/web-sdk": "^2.0.0-dev.1",
18
- "@solana-mobile/wallet-adapter-mobile": "2.1.3",
19
- "@solana/wallet-adapter-base": "0.9.23",
20
- "@solana/wallet-adapter-react": "0.15.35",
21
- "@solana/wallet-adapter-walletconnect": "0.1.16",
5
+ "@getpara/react-common": "2.0.0-dev.3",
6
+ "@getpara/web-sdk": "2.0.0-dev.3",
22
7
  "bs58": "6.0.0"
23
8
  },
24
9
  "devDependencies": {
25
- "@getpara/react-common": "^2.0.0-dev.1",
10
+ "@solana-mobile/wallet-adapter-mobile": "^2.2.0",
11
+ "@solana/wallet-adapter-base": "^0.9.27",
12
+ "@solana/wallet-adapter-react": "^0.15.39",
13
+ "@solana/wallet-adapter-walletconnect": "^0.1.21",
26
14
  "@types/react": "^18.0.31",
27
15
  "@types/react-dom": "^18.2.7",
28
- "typescript": "^5.4.3"
16
+ "typescript": "^5.8.3"
29
17
  },
30
- "peerDependencies": {
31
- "react": ">=18",
32
- "react-dom": ">=18"
18
+ "exports": {
19
+ ".": "./dist/index.js",
20
+ "./connectors": "./dist/wallets/connectors/index.js"
33
21
  },
34
22
  "files": [
35
23
  "dist",
36
24
  "package.json"
37
25
  ],
38
- "gitHead": "426e843bd6084fb2e5f30ab87b02c79fc2f52832"
26
+ "gitHead": "ffe34f7d8df2dd3c2327ca1f35bcc9764e0a68a2",
27
+ "main": "dist/index.js",
28
+ "peerDependencies": {
29
+ "@solana-mobile/wallet-adapter-mobile": "2.x",
30
+ "@solana/wallet-adapter-base": "0.x",
31
+ "@solana/wallet-adapter-react": "0.x",
32
+ "@solana/wallet-adapter-walletconnect": "0.x",
33
+ "react": ">=18",
34
+ "react-dom": ">=18"
35
+ },
36
+ "scripts": {
37
+ "build": "rm -rf dist && yarn typegen && node ./scripts/build.mjs",
38
+ "test": "vitest run --coverage",
39
+ "typegen": "tsc --emitDeclarationOnly"
40
+ },
41
+ "type": "module",
42
+ "types": "dist/index.d.ts"
39
43
  }
package/dist/index.js.br DELETED
Binary file
package/dist/index.js.gz DELETED
Binary file