@getpara/solana-wallet-connectors 1.4.3 → 1.5.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/dist/index.js CHANGED
@@ -1,2 +1,236 @@
1
1
  "use client";
2
- import{createContext as X,useEffect as L,useMemo as J}from"react";import{useWallet as H}from"@solana/wallet-adapter-react";import{WalletReadyState as E}from"@solana/wallet-adapter-base";import{createContext as O,useContext as U,useEffect as m,useMemo as Y,useState as f}from"react";import{ConnectionProvider as b,WalletProvider as v}from"@solana/wallet-adapter-react";import{useExternalWalletProviderStore as x}from"@getpara/react-sdk";import{createDefaultAddressSelector as h,createDefaultAuthorizationResultCache as G,createDefaultWalletNotFoundHandler as B,SolanaMobileWalletAdapter as Z}from"@solana-mobile/wallet-adapter-mobile";import{jsx as d}from"react/jsx-runtime";var R={wallets:[]},w=O(R);function V({children:c,wallets:a,endpoint:A,appIdentity:j,chain:u,connectionConfig:l}){let o=x(i=>i.updateState),n=x(i=>i.SolanaProvider),r=x(i=>i.solanaContext),[s,N]=f(!0);m(()=>{N(!1)},[]),m(()=>{(!r||!n)&&o({SolanaProvider:z,solanaContext:D})},[]);let g=Y(()=>({wallets:a}),[a]);return!r||!n?null:d(b,{endpoint:A,config:l,children:d(v,{wallets:[new Z({addressSelector:h(),appIdentity:j,authorizationResultCache:G(),chain:u,onWalletNotFound:B()})],localStorageKey:"paraSolanaExternal",autoConnect:s,children:d(w.Provider,{value:g,children:c})})})}var p=()=>U(w);import{WalletType as y}from"@getpara/web-sdk";import{jsx as K}from"react/jsx-runtime";var F={wallets:[],disconnect:()=>Promise.resolve()},D=X(F);function z({children:c,para:a,onSwitchWallet:A}){let{wallets:j,select:u,disconnect:l,publicKey:o,wallet:n,connecting:r}=H(),{wallets:s}=p(),N=async()=>{await l(),await a.logout()},g=async(M,e)=>{try{await a.externalWalletLogin({address:M,type:y.SOLANA,provider:e})}catch{throw await N(),"Error logging you in. Please try again."}},i=async M=>{let e;if(!M)await a.logout();else try{await g(M,n?.adapter?.name)}catch(t){e=t}A({address:M,error:e})};L(()=>{let M=a.externalWallets[o?.toString()??""];o&&!M&&N()},[]),L(()=>{let M=a.externalWallets[a.currentExternalWalletAddresses?.[0]??""];!r&&M?.type===y.SOLANA&&M?.address!==o?.toString()&&i(o?.toString())},[o,r]);let C=async M=>{if(await l(),!M)return{address:void 0,error:"Adapter not found."};u(M.name),await new Promise(I=>setTimeout(I,100));let e,t;try{if(await M.connect(),e=M.publicKey.toString(),e)try{await g(e,M.name)}catch(I){await l(),e=void 0,t=I}}catch(I){switch(I.message){case"User aborted.":case"Approval Denied":case"You canceled this request.":{t="Connection request rejected";break}default:{t="An unknown error occurred";break}}}return{address:e,error:t}},k=M=>j.find(e=>e.adapter.name==="Mobile Wallet Adapter"||e.adapter.name===M?e:!1)?.adapter,T=s.map(M=>{let e=M(),t=k(e.name);return{connect:()=>C(t),connectMobile:()=>C(t),getQrUri:()=>"",type:y.SOLANA,installed:t&&(t?.readyState===E.Installed||t?.readyState===E.Loadable),...e}}),S=async()=>{await l(),typeof window!==void 0&&window?.location.reload()};return K(D.Provider,{value:J(()=>({wallets:T,disconnect:S}),[T,S]),children:c})}var W="";var q=()=>({id:"phantom",name:"Phantom",iconUrl:W,isExtension:!0,isMobile:!0,getUri:()=>"",downloadUrl:"https://phantom.app/download"});var P="";var _=()=>({id:"glow",name:"Glow",iconUrl:P,isExtension:!0,isMobile:!0,getUri:()=>"",downloadUrl:"https://glow.app"});var Q="";var $=()=>({id:"backpack",name:"Backpack",iconUrl:Q,isExtension:!0,isMobile:!0,getUri:()=>"",downloadUrl:"https://backpack.app/download"});export{V as ParaSolanaProvider,D as SolanaExternalWalletContext,z as SolanaExternalWalletProvider,$ as backpackWallet,_ as glowWallet,q as phantomWallet};
2
+
3
+ // src/providers/SolanaExternalWalletContext.tsx
4
+ import { createContext as createContext2, useEffect as useEffect2, useMemo as useMemo2 } from "react";
5
+ import { useWallet } from "@solana/wallet-adapter-react";
6
+ import { WalletReadyState } from "@solana/wallet-adapter-base";
7
+
8
+ // src/providers/ParaSolanaProvider.tsx
9
+ import { createContext, useContext, useEffect, useMemo, useState } from "react";
10
+ import { ConnectionProvider, WalletProvider as SolanaWalletProvider } from "@solana/wallet-adapter-react";
11
+ import { useExternalWalletProviderStore } from "@getpara/react-sdk";
12
+ import {
13
+ createDefaultAddressSelector,
14
+ createDefaultAuthorizationResultCache,
15
+ createDefaultWalletNotFoundHandler,
16
+ SolanaMobileWalletAdapter
17
+ } from "@solana-mobile/wallet-adapter-mobile";
18
+ import { jsx } from "react/jsx-runtime";
19
+ var defaultWallet = {
20
+ wallets: []
21
+ };
22
+ var ParaSolanaContext = createContext(defaultWallet);
23
+ function ParaSolanaProvider({
24
+ children,
25
+ wallets: walletFns,
26
+ endpoint,
27
+ appIdentity,
28
+ chain,
29
+ connectionConfig
30
+ }) {
31
+ const updateExternalWalletProviderState = useExternalWalletProviderStore((state) => state.updateState);
32
+ const SolanaProvider = useExternalWalletProviderStore((state) => state.SolanaProvider);
33
+ const solanaContext = useExternalWalletProviderStore((state) => state.solanaContext);
34
+ const [shouldAutoConnect, setShouldAutoConnect] = useState(true);
35
+ useEffect(() => {
36
+ setShouldAutoConnect(false);
37
+ }, []);
38
+ useEffect(() => {
39
+ if (!solanaContext || !SolanaProvider) {
40
+ updateExternalWalletProviderState({
41
+ SolanaProvider: SolanaExternalWalletProvider,
42
+ solanaContext: SolanaExternalWalletContext
43
+ });
44
+ }
45
+ }, []);
46
+ const value = useMemo(() => ({ wallets: walletFns }), [walletFns]);
47
+ if (!solanaContext || !SolanaProvider) {
48
+ return null;
49
+ }
50
+ return /* @__PURE__ */ jsx(ConnectionProvider, { endpoint, config: connectionConfig, children: /* @__PURE__ */ jsx(
51
+ SolanaWalletProvider,
52
+ {
53
+ wallets: [
54
+ new SolanaMobileWalletAdapter({
55
+ addressSelector: createDefaultAddressSelector(),
56
+ appIdentity,
57
+ authorizationResultCache: createDefaultAuthorizationResultCache(),
58
+ chain,
59
+ onWalletNotFound: createDefaultWalletNotFoundHandler()
60
+ })
61
+ ],
62
+ localStorageKey: "paraSolanaExternal",
63
+ autoConnect: shouldAutoConnect,
64
+ children: /* @__PURE__ */ jsx(ParaSolanaContext.Provider, { value, children })
65
+ }
66
+ ) });
67
+ }
68
+ var useParaSolana = () => useContext(ParaSolanaContext);
69
+
70
+ // src/providers/SolanaExternalWalletContext.tsx
71
+ import { WalletType } from "@getpara/web-sdk";
72
+ import { jsx as jsx2 } from "react/jsx-runtime";
73
+ var defaultSolanaExternalWallet = {
74
+ wallets: [],
75
+ disconnect: () => Promise.resolve()
76
+ };
77
+ var SolanaExternalWalletContext = createContext2(defaultSolanaExternalWallet);
78
+ function SolanaExternalWalletProvider({ children, para, onSwitchWallet }) {
79
+ const {
80
+ wallets: adapters,
81
+ select: selectWallet,
82
+ disconnect: _disconnect,
83
+ publicKey: solanaAddress,
84
+ wallet,
85
+ connecting
86
+ } = useWallet();
87
+ const { wallets: walletFns } = useParaSolana();
88
+ const reset = async () => {
89
+ await _disconnect();
90
+ await para.logout();
91
+ };
92
+ const login = async (address, providerName) => {
93
+ try {
94
+ await para.externalWalletLogin({ address, type: WalletType.SOLANA, provider: providerName });
95
+ } catch (err) {
96
+ await reset();
97
+ throw "Error logging you in. Please try again.";
98
+ }
99
+ };
100
+ const switchWallet = async (address) => {
101
+ let error;
102
+ if (!address) {
103
+ await para.logout();
104
+ } else {
105
+ try {
106
+ await login(address, wallet?.adapter?.name);
107
+ } catch (err) {
108
+ error = err;
109
+ }
110
+ }
111
+ onSwitchWallet({ address, error });
112
+ };
113
+ useEffect2(() => {
114
+ const storedExternalWallet = para.externalWallets[solanaAddress?.toString() ?? ""];
115
+ if (!!solanaAddress && !storedExternalWallet) {
116
+ reset();
117
+ }
118
+ }, []);
119
+ useEffect2(() => {
120
+ const storedExternalWallet = Object.values(para.externalWallets || {})[0];
121
+ if (!connecting && storedExternalWallet?.type === WalletType.SOLANA && storedExternalWallet?.address !== solanaAddress?.toString()) {
122
+ switchWallet(solanaAddress?.toString());
123
+ }
124
+ }, [solanaAddress, connecting]);
125
+ const connect = async (adapter) => {
126
+ await _disconnect();
127
+ if (!adapter) {
128
+ return { address: void 0, error: "Adapter not found." };
129
+ }
130
+ selectWallet(adapter.name);
131
+ await new Promise((resolve) => setTimeout(resolve, 100));
132
+ let address;
133
+ let error;
134
+ try {
135
+ await adapter.connect();
136
+ address = adapter.publicKey.toString();
137
+ if (address) {
138
+ try {
139
+ await login(address, adapter.name);
140
+ } catch (err) {
141
+ await _disconnect();
142
+ address = void 0;
143
+ error = err;
144
+ }
145
+ }
146
+ } catch (err) {
147
+ switch (err.message) {
148
+ case "User aborted.":
149
+ case "Approval Denied":
150
+ case "You canceled this request.": {
151
+ error = "Connection request rejected";
152
+ break;
153
+ }
154
+ default: {
155
+ error = "An unknown error occurred";
156
+ break;
157
+ }
158
+ }
159
+ }
160
+ return { address, error };
161
+ };
162
+ const getAdapter = (name) => adapters.find((a) => a.adapter.name === "Mobile Wallet Adapter" ? a : a.adapter.name === name ? a : false)?.adapter;
163
+ const wallets = walletFns.map((walletFn) => {
164
+ const metaData = walletFn();
165
+ const adapter = getAdapter(metaData.name);
166
+ return {
167
+ connect: () => connect(adapter),
168
+ connectMobile: () => connect(adapter),
169
+ getQrUri: () => "",
170
+ type: WalletType.SOLANA,
171
+ installed: adapter && (adapter?.readyState === WalletReadyState.Installed || adapter?.readyState === WalletReadyState.Loadable),
172
+ ...metaData
173
+ };
174
+ });
175
+ const disconnect = async () => {
176
+ await _disconnect();
177
+ typeof window !== void 0 && window?.location.reload();
178
+ };
179
+ return /* @__PURE__ */ jsx2(SolanaExternalWalletContext.Provider, { value: useMemo2(() => ({ wallets, disconnect }), [wallets, disconnect]), children });
180
+ }
181
+
182
+ // src/wallets/connectors/phantom/phantomIcon.ts
183
+ var icon = "";
184
+
185
+ // src/wallets/connectors/phantom/phantom.ts
186
+ var phantomWallet = () => {
187
+ return {
188
+ id: "phantom",
189
+ name: "Phantom",
190
+ iconUrl: icon,
191
+ isExtension: true,
192
+ isMobile: true,
193
+ getUri: () => "",
194
+ downloadUrl: "https://phantom.app/download"
195
+ };
196
+ };
197
+
198
+ // src/wallets/connectors/glow/glowIcon.ts
199
+ var icon2 = "";
200
+
201
+ // src/wallets/connectors/glow/glow.ts
202
+ var glowWallet = () => {
203
+ return {
204
+ id: "glow",
205
+ name: "Glow",
206
+ iconUrl: icon2,
207
+ isExtension: true,
208
+ isMobile: true,
209
+ getUri: () => "",
210
+ downloadUrl: "https://glow.app"
211
+ };
212
+ };
213
+
214
+ // src/wallets/connectors/backpack/backpackIcon.ts
215
+ var icon3 = "";
216
+
217
+ // src/wallets/connectors/backpack/backpack.ts
218
+ var backpackWallet = () => {
219
+ return {
220
+ id: "backpack",
221
+ name: "Backpack",
222
+ iconUrl: icon3,
223
+ isExtension: true,
224
+ isMobile: true,
225
+ getUri: () => "",
226
+ downloadUrl: "https://backpack.app/download"
227
+ };
228
+ };
229
+ export {
230
+ ParaSolanaProvider,
231
+ SolanaExternalWalletContext,
232
+ SolanaExternalWalletProvider,
233
+ backpackWallet,
234
+ glowWallet,
235
+ phantomWallet
236
+ };
package/dist/index.js.br CHANGED
Binary file
package/dist/index.js.gz CHANGED
Binary file
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@getpara/solana-wallet-connectors",
3
- "version": "1.4.3",
3
+ "version": "1.5.0",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -9,7 +9,7 @@
9
9
  "./connectors": "./dist/wallets/connectors/index.js"
10
10
  },
11
11
  "dependencies": {
12
- "@getpara/react-sdk": "1.4.3"
12
+ "@getpara/react-sdk": "1.5.0"
13
13
  },
14
14
  "scripts": {
15
15
  "build": "rm -rf dist && yarn typegen && node ./scripts/build.mjs",
@@ -37,5 +37,5 @@
37
37
  "dist",
38
38
  "package.json"
39
39
  ],
40
- "gitHead": "1af7abd51e994057ff4afc90bd13650a47f6b26e"
40
+ "gitHead": "0e3c1401b4f1da60b288cdde7695077c9bcbc48f"
41
41
  }