@nexus-cross/connect-kit-react 1.0.0-beta.1
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 +258 -0
- package/dist/components/ConnectButton.d.ts +64 -0
- package/dist/components/ConnectButton.d.ts.map +1 -0
- package/dist/components/ConnectButton.js +257 -0
- package/dist/components/ConnectButton.js.map +1 -0
- package/dist/components/CrossConnectKitProvider.d.ts +15 -0
- package/dist/components/CrossConnectKitProvider.d.ts.map +1 -0
- package/dist/components/CrossConnectKitProvider.js +570 -0
- package/dist/components/CrossConnectKitProvider.js.map +1 -0
- package/dist/components/OtherWalletsModal.d.ts +20 -0
- package/dist/components/OtherWalletsModal.d.ts.map +1 -0
- package/dist/components/OtherWalletsModal.js +300 -0
- package/dist/components/OtherWalletsModal.js.map +1 -0
- package/dist/components/WalletInfoPopover.d.ts +7 -0
- package/dist/components/WalletInfoPopover.d.ts.map +1 -0
- package/dist/components/WalletInfoPopover.js +166 -0
- package/dist/components/WalletInfoPopover.js.map +1 -0
- package/dist/components/types.d.ts +23 -0
- package/dist/components/types.d.ts.map +1 -0
- package/dist/components/types.js +2 -0
- package/dist/components/types.js.map +1 -0
- package/dist/context/CrossConnectKitContext.d.ts +30 -0
- package/dist/context/CrossConnectKitContext.d.ts.map +1 -0
- package/dist/context/CrossConnectKitContext.js +10 -0
- package/dist/context/CrossConnectKitContext.js.map +1 -0
- package/dist/context/CrossConnectKitThemeContext.d.ts +41 -0
- package/dist/context/CrossConnectKitThemeContext.d.ts.map +1 -0
- package/dist/context/CrossConnectKitThemeContext.js +22 -0
- package/dist/context/CrossConnectKitThemeContext.js.map +1 -0
- package/dist/hooks/useCrossxEmbeddedInfo.d.ts +25 -0
- package/dist/hooks/useCrossxEmbeddedInfo.d.ts.map +1 -0
- package/dist/hooks/useCrossxEmbeddedInfo.js +71 -0
- package/dist/hooks/useCrossxEmbeddedInfo.js.map +1 -0
- package/dist/index.d.ts +20 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +10 -0
- package/dist/index.js.map +1 -0
- package/package.json +43 -0
|
@@ -0,0 +1,300 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useCallback, useEffect, useMemo, useState } from 'react';
|
|
3
|
+
import { detectWallets, DEFAULT_WALLET_REGISTRY } from '@nexus-cross/connect-kit-wagmi';
|
|
4
|
+
import { useCrossConnectKit } from '../context/CrossConnectKitContext.js';
|
|
5
|
+
const DEFAULT_TROUBLESHOOTING_TIPS = [
|
|
6
|
+
'Ensure your wallet extension is installed and unlocked',
|
|
7
|
+
'Try refreshing the page',
|
|
8
|
+
'Some wallets may require you to first open the extension',
|
|
9
|
+
'You can try clicking the wallet anyway',
|
|
10
|
+
];
|
|
11
|
+
const DEFAULT_DESCRIPTION = 'Connect with one of our available wallet providers to continue.';
|
|
12
|
+
/**
|
|
13
|
+
* Wallet selector modal. Port of posa's `ConnectWalletModal` backed by
|
|
14
|
+
* `ConnectorRegistry` — wallet order, icons, and descriptive copy match
|
|
15
|
+
* posa; DApps can override via `walletGuides` passed to
|
|
16
|
+
* `createCrossxConfig` and via modal props.
|
|
17
|
+
*/
|
|
18
|
+
export function OtherWalletsModal({ open, onClose, onSelect, title = 'Connect Wallet', description = DEFAULT_DESCRIPTION, troubleshootingTips = DEFAULT_TROUBLESHOOTING_TIPS, }) {
|
|
19
|
+
const { availableWallets } = useCrossConnectKit();
|
|
20
|
+
const [installedMap, setInstalledMap] = useState({});
|
|
21
|
+
useEffect(() => {
|
|
22
|
+
if (!open)
|
|
23
|
+
return;
|
|
24
|
+
const detected = detectWallets(DEFAULT_WALLET_REGISTRY);
|
|
25
|
+
const map = {};
|
|
26
|
+
for (const w of detected) {
|
|
27
|
+
if (w.installed !== undefined)
|
|
28
|
+
map[w.id] = w.installed;
|
|
29
|
+
}
|
|
30
|
+
setInstalledMap(map);
|
|
31
|
+
// Some extensions inject late; re-scan after a short delay (matches
|
|
32
|
+
// posa's 1000ms re-probe).
|
|
33
|
+
const timer = setTimeout(() => {
|
|
34
|
+
const detected2 = detectWallets(DEFAULT_WALLET_REGISTRY);
|
|
35
|
+
const map2 = {};
|
|
36
|
+
for (const w of detected2) {
|
|
37
|
+
if (w.installed !== undefined)
|
|
38
|
+
map2[w.id] = w.installed;
|
|
39
|
+
}
|
|
40
|
+
setInstalledMap(map2);
|
|
41
|
+
}, 1000);
|
|
42
|
+
return () => clearTimeout(timer);
|
|
43
|
+
}, [open]);
|
|
44
|
+
const isMobile = useMemo(() => {
|
|
45
|
+
if (typeof navigator === 'undefined')
|
|
46
|
+
return false;
|
|
47
|
+
return /Mobi|Android/i.test(navigator.userAgent);
|
|
48
|
+
}, []);
|
|
49
|
+
const filteredWallets = useMemo(() => isMobile
|
|
50
|
+
? availableWallets.filter((e) => e.type !== 'extension')
|
|
51
|
+
: availableWallets, [availableWallets, isMobile]);
|
|
52
|
+
const handleSelect = useCallback((entry) => {
|
|
53
|
+
const installed = installedMap[entry.walletId];
|
|
54
|
+
if (!installed && entry.installUrl && entry.type === 'extension') {
|
|
55
|
+
window.open(entry.installUrl, '_blank');
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
onClose();
|
|
59
|
+
onSelect(entry.walletId);
|
|
60
|
+
}, [onClose, onSelect, installedMap]);
|
|
61
|
+
const handleGuide = useCallback((e, url) => {
|
|
62
|
+
e.stopPropagation();
|
|
63
|
+
onClose();
|
|
64
|
+
window.open(url, '_blank');
|
|
65
|
+
}, [onClose]);
|
|
66
|
+
if (!open)
|
|
67
|
+
return null;
|
|
68
|
+
return (_jsx("div", { style: s.overlay, onClick: onClose, children: _jsxs("div", { style: s.modal, onClick: (e) => e.stopPropagation(), children: [_jsxs("div", { style: s.header, children: [_jsx("h2", { style: s.title, children: title }), _jsx("button", { type: "button", onClick: onClose, style: s.closeBtn, "aria-label": "Close", children: _jsxs("svg", { width: "20", height: "20", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2.5", strokeLinecap: "round", children: [_jsx("line", { x1: "18", y1: "6", x2: "6", y2: "18" }), _jsx("line", { x1: "6", y1: "6", x2: "18", y2: "18" })] }) })] }), _jsx("p", { style: s.desc, children: description }), _jsx("div", { style: s.walletList, children: filteredWallets.map((entry) => {
|
|
69
|
+
const installed = installedMap[entry.walletId];
|
|
70
|
+
const showInstallHint = installed === false &&
|
|
71
|
+
entry.type === 'extension' &&
|
|
72
|
+
!!entry.installUrl;
|
|
73
|
+
return (_jsxs("div", { style: s.walletGroup, children: [_jsxs("button", { type: "button", onClick: () => handleSelect(entry), style: {
|
|
74
|
+
...s.walletItem,
|
|
75
|
+
...(entry.walletId === 'cross_wallet' ? s.walletItemAccent : {}),
|
|
76
|
+
}, "aria-label": `Connect with ${entry.name}`, children: [entry.iconUrl ? (_jsx("img", { src: entry.iconUrl, alt: "", style: s.walletIcon })) : (_jsx("div", { style: s.walletIconPlaceholder })), _jsxs("div", { style: s.walletInfo, children: [_jsxs("div", { style: s.walletNameRow, children: [_jsx("span", { style: s.walletName, children: entry.name }), installed !== undefined && (_jsx("span", { style: {
|
|
77
|
+
...s.badge,
|
|
78
|
+
...(installed ? s.badgeInstalled : s.badgeNotInstalled),
|
|
79
|
+
}, children: installed ? 'Installed' : 'Not Installed' }))] }), _jsx("span", { style: s.walletDesc, children: showInstallHint
|
|
80
|
+
? 'Extension not detected — click to install'
|
|
81
|
+
: entry.type === 'extension'
|
|
82
|
+
? 'Browser extension approval is required'
|
|
83
|
+
: entry.walletId === 'cross_wallet'
|
|
84
|
+
? 'App approval is required'
|
|
85
|
+
: entry.walletId === 'binance'
|
|
86
|
+
? 'Mobile app only — Add CROSS network first'
|
|
87
|
+
: installed
|
|
88
|
+
? 'Connect with browser extension'
|
|
89
|
+
: 'Scan QR code with app' })] })] }), entry.guideUrl && (_jsxs("button", { type: "button", onClick: (e) => handleGuide(e, entry.guideUrl), style: s.guideBtn, children: [_jsx("span", { "aria-hidden": "true", children: "\u26A0\uFE0F" }), entry.guideLabel ?? 'Required Settings'] }))] }, entry.walletId));
|
|
90
|
+
}) }), _jsxs("div", { style: s.troubleshoot, children: [_jsx("h3", { style: s.troubleshootTitle, children: "Wallet not detected?" }), _jsx("ul", { style: s.troubleshootList, children: troubleshootingTips.map((tip) => (_jsxs("li", { style: s.troubleshootItem, children: [_jsx("span", { style: s.troubleshootDot, "aria-hidden": "true" }), _jsx("span", { children: tip })] }, tip))) })] })] }) }));
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Theme tokens shared with `@nexus-cross/dapp-ui`'s `WalletInfo` (`--wi-*`).
|
|
94
|
+
* Using the same variable names means a DApp that themes WalletInfo
|
|
95
|
+
* automatically themes this modal — no separate setup. Fallback values
|
|
96
|
+
* match posa's dark-mode palette.
|
|
97
|
+
*/
|
|
98
|
+
/**
|
|
99
|
+
* Fallback values match `@nexus-cross/dapp-ui`'s WalletInfo built-in dark
|
|
100
|
+
* palette so the modal renders cohesively even when the DApp has not
|
|
101
|
+
* set `--wi-*` on `:root`. DApps that override `--wi-*` get their
|
|
102
|
+
* palette applied here via the CSS cascade.
|
|
103
|
+
*/
|
|
104
|
+
const t = {
|
|
105
|
+
surfaceBg: 'var(--wi-surface-bg, #121212)',
|
|
106
|
+
surfaceDefault: 'var(--wi-surface-default, rgba(255,255,255,0.05))',
|
|
107
|
+
surfaceSubtle: 'var(--wi-surface-subtle, rgba(255,255,255,0.1))',
|
|
108
|
+
borderDefault: 'var(--wi-border-default, rgba(255,255,255,0.05))',
|
|
109
|
+
textPrimary: 'var(--wi-texticon-primary, #ffffff)',
|
|
110
|
+
textSecondary: 'var(--wi-texticon-secondary, rgba(255,255,255,0.7))',
|
|
111
|
+
textTertiary: 'var(--wi-texticon-tertiary, rgba(255,255,255,0.5))',
|
|
112
|
+
primary: 'var(--wi-primary, #019d92)',
|
|
113
|
+
primarySoft: 'var(--crossx-kit-primary-soft, rgba(1,157,146,0.15))',
|
|
114
|
+
accentGradient: 'var(--crossx-kit-accent-gradient, linear-gradient(113deg, rgba(255,255,255,0.05) 0%, rgba(1,157,146,0.12) 70%, rgba(255,255,255,0.05) 70%, rgba(1,157,146,0.12) 80%, rgba(255,255,255,0.05) 80%))',
|
|
115
|
+
warningBg: 'var(--crossx-kit-warning-bg, rgba(245,158,11,0.1))',
|
|
116
|
+
warningBorder: 'var(--crossx-kit-warning-border, rgba(245,158,11,0.25))',
|
|
117
|
+
warningText: 'var(--crossx-kit-warning-text, #fbbf24)',
|
|
118
|
+
};
|
|
119
|
+
const s = {
|
|
120
|
+
overlay: {
|
|
121
|
+
position: 'fixed',
|
|
122
|
+
inset: 0,
|
|
123
|
+
zIndex: 10000,
|
|
124
|
+
display: 'flex',
|
|
125
|
+
alignItems: 'center',
|
|
126
|
+
justifyContent: 'center',
|
|
127
|
+
background: 'rgba(0,0,0,0.6)',
|
|
128
|
+
backdropFilter: 'blur(4px)',
|
|
129
|
+
},
|
|
130
|
+
modal: {
|
|
131
|
+
width: '100%',
|
|
132
|
+
maxWidth: '420px',
|
|
133
|
+
margin: '16px',
|
|
134
|
+
background: t.surfaceBg,
|
|
135
|
+
border: `1px solid ${t.borderDefault}`,
|
|
136
|
+
borderRadius: '20px',
|
|
137
|
+
overflow: 'hidden',
|
|
138
|
+
},
|
|
139
|
+
header: {
|
|
140
|
+
display: 'flex',
|
|
141
|
+
alignItems: 'center',
|
|
142
|
+
justifyContent: 'space-between',
|
|
143
|
+
padding: '20px 24px 0',
|
|
144
|
+
},
|
|
145
|
+
title: {
|
|
146
|
+
fontSize: '18px',
|
|
147
|
+
fontWeight: 700,
|
|
148
|
+
color: t.textPrimary,
|
|
149
|
+
margin: 0,
|
|
150
|
+
},
|
|
151
|
+
closeBtn: {
|
|
152
|
+
background: 'none',
|
|
153
|
+
border: 'none',
|
|
154
|
+
color: t.textTertiary,
|
|
155
|
+
cursor: 'pointer',
|
|
156
|
+
padding: '4px',
|
|
157
|
+
borderRadius: '8px',
|
|
158
|
+
display: 'flex',
|
|
159
|
+
alignItems: 'center',
|
|
160
|
+
justifyContent: 'center',
|
|
161
|
+
},
|
|
162
|
+
desc: {
|
|
163
|
+
padding: '8px 24px 16px',
|
|
164
|
+
fontSize: '13px',
|
|
165
|
+
color: t.textTertiary,
|
|
166
|
+
margin: 0,
|
|
167
|
+
lineHeight: 1.5,
|
|
168
|
+
},
|
|
169
|
+
walletList: {
|
|
170
|
+
display: 'flex',
|
|
171
|
+
flexDirection: 'column',
|
|
172
|
+
gap: '6px',
|
|
173
|
+
padding: '0 12px 12px',
|
|
174
|
+
},
|
|
175
|
+
walletGroup: {
|
|
176
|
+
display: 'flex',
|
|
177
|
+
flexDirection: 'column',
|
|
178
|
+
borderRadius: '12px',
|
|
179
|
+
overflow: 'hidden',
|
|
180
|
+
background: t.surfaceDefault,
|
|
181
|
+
},
|
|
182
|
+
walletItem: {
|
|
183
|
+
display: 'flex',
|
|
184
|
+
alignItems: 'center',
|
|
185
|
+
gap: '14px',
|
|
186
|
+
width: '100%',
|
|
187
|
+
padding: '14px',
|
|
188
|
+
background: 'transparent',
|
|
189
|
+
border: 'none',
|
|
190
|
+
color: t.textPrimary,
|
|
191
|
+
cursor: 'pointer',
|
|
192
|
+
textAlign: 'left',
|
|
193
|
+
},
|
|
194
|
+
walletItemAccent: {
|
|
195
|
+
background: t.accentGradient,
|
|
196
|
+
},
|
|
197
|
+
walletIcon: {
|
|
198
|
+
width: '40px',
|
|
199
|
+
height: '40px',
|
|
200
|
+
borderRadius: '10px',
|
|
201
|
+
flexShrink: 0,
|
|
202
|
+
},
|
|
203
|
+
walletIconPlaceholder: {
|
|
204
|
+
width: '40px',
|
|
205
|
+
height: '40px',
|
|
206
|
+
borderRadius: '10px',
|
|
207
|
+
background: t.surfaceSubtle,
|
|
208
|
+
flexShrink: 0,
|
|
209
|
+
},
|
|
210
|
+
walletInfo: {
|
|
211
|
+
flex: 1,
|
|
212
|
+
minWidth: 0,
|
|
213
|
+
display: 'flex',
|
|
214
|
+
flexDirection: 'column',
|
|
215
|
+
gap: '3px',
|
|
216
|
+
},
|
|
217
|
+
walletNameRow: {
|
|
218
|
+
display: 'flex',
|
|
219
|
+
alignItems: 'center',
|
|
220
|
+
gap: '8px',
|
|
221
|
+
},
|
|
222
|
+
walletName: {
|
|
223
|
+
fontSize: '15px',
|
|
224
|
+
fontWeight: 700,
|
|
225
|
+
lineHeight: 1.3,
|
|
226
|
+
color: t.textPrimary,
|
|
227
|
+
},
|
|
228
|
+
badge: {
|
|
229
|
+
fontSize: '10px',
|
|
230
|
+
fontWeight: 600,
|
|
231
|
+
padding: '2px 7px',
|
|
232
|
+
borderRadius: '99px',
|
|
233
|
+
lineHeight: 1,
|
|
234
|
+
},
|
|
235
|
+
badgeInstalled: {
|
|
236
|
+
background: t.primarySoft,
|
|
237
|
+
color: t.primary,
|
|
238
|
+
},
|
|
239
|
+
badgeNotInstalled: {
|
|
240
|
+
background: 'rgba(255,255,255,0.05)',
|
|
241
|
+
color: t.textTertiary,
|
|
242
|
+
},
|
|
243
|
+
walletDesc: {
|
|
244
|
+
fontSize: '11px',
|
|
245
|
+
color: t.textSecondary,
|
|
246
|
+
lineHeight: 1.3,
|
|
247
|
+
},
|
|
248
|
+
guideBtn: {
|
|
249
|
+
display: 'flex',
|
|
250
|
+
alignItems: 'center',
|
|
251
|
+
justifyContent: 'center',
|
|
252
|
+
gap: '6px',
|
|
253
|
+
margin: '0 14px 14px',
|
|
254
|
+
padding: '10px 12px',
|
|
255
|
+
borderRadius: '10px',
|
|
256
|
+
border: `1px solid ${t.warningBorder}`,
|
|
257
|
+
background: t.warningBg,
|
|
258
|
+
color: t.warningText,
|
|
259
|
+
fontWeight: 600,
|
|
260
|
+
fontSize: '13px',
|
|
261
|
+
cursor: 'pointer',
|
|
262
|
+
},
|
|
263
|
+
troubleshoot: {
|
|
264
|
+
margin: '0 12px 16px',
|
|
265
|
+
background: t.surfaceDefault,
|
|
266
|
+
borderRadius: '12px',
|
|
267
|
+
padding: '14px 16px',
|
|
268
|
+
},
|
|
269
|
+
troubleshootTitle: {
|
|
270
|
+
fontSize: '12px',
|
|
271
|
+
fontWeight: 700,
|
|
272
|
+
color: t.textPrimary,
|
|
273
|
+
margin: '0 0 8px',
|
|
274
|
+
},
|
|
275
|
+
troubleshootList: {
|
|
276
|
+
listStyle: 'none',
|
|
277
|
+
padding: 0,
|
|
278
|
+
margin: 0,
|
|
279
|
+
display: 'flex',
|
|
280
|
+
flexDirection: 'column',
|
|
281
|
+
gap: '8px',
|
|
282
|
+
},
|
|
283
|
+
troubleshootItem: {
|
|
284
|
+
display: 'flex',
|
|
285
|
+
alignItems: 'flex-start',
|
|
286
|
+
gap: '8px',
|
|
287
|
+
fontSize: '11px',
|
|
288
|
+
color: t.textSecondary,
|
|
289
|
+
lineHeight: 1.5,
|
|
290
|
+
},
|
|
291
|
+
troubleshootDot: {
|
|
292
|
+
flexShrink: 0,
|
|
293
|
+
width: '4px',
|
|
294
|
+
height: '4px',
|
|
295
|
+
marginTop: '6px',
|
|
296
|
+
borderRadius: '50%',
|
|
297
|
+
background: t.textSecondary,
|
|
298
|
+
},
|
|
299
|
+
};
|
|
300
|
+
//# sourceMappingURL=OtherWalletsModal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OtherWalletsModal.js","sourceRoot":"","sources":["../../src/components/OtherWalletsModal.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export interface WalletInfoPopoverProps {
|
|
2
|
+
open: boolean;
|
|
3
|
+
onClose: () => void;
|
|
4
|
+
anchorRef?: React.RefObject<HTMLElement | null>;
|
|
5
|
+
}
|
|
6
|
+
export declare function WalletInfoPopover({ open, onClose }: WalletInfoPopoverProps): import("react/jsx-runtime").JSX.Element | null;
|
|
7
|
+
//# sourceMappingURL=WalletInfoPopover.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WalletInfoPopover.d.ts","sourceRoot":"","sources":["../../src/components/WalletInfoPopover.tsx"],"names":[],"mappings":"AAKA,MAAM,WAAW,sBAAsB;IACrC,IAAI,EAAE,OAAO,CAAC;IACd,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,SAAS,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC;CACjD;AAMD,wBAAgB,iBAAiB,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,sBAAsB,kDAuG1E"}
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { useCallback, useState } from 'react';
|
|
3
|
+
import { useAccount, useBalance, useDisconnect, useEnsName } from 'wagmi';
|
|
4
|
+
import { formatBalance } from '@nexus-cross/connect-kit-core';
|
|
5
|
+
import { useCrossConnectKit } from '../context/CrossConnectKitContext.js';
|
|
6
|
+
function truncateAddress(address) {
|
|
7
|
+
return `${address.slice(0, 6)}...${address.slice(-4)}`;
|
|
8
|
+
}
|
|
9
|
+
export function WalletInfoPopover({ open, onClose }) {
|
|
10
|
+
const { address, chain } = useAccount();
|
|
11
|
+
const { data: ensName } = useEnsName({ address });
|
|
12
|
+
const { data: balance } = useBalance({ address });
|
|
13
|
+
const { disconnect } = useDisconnect();
|
|
14
|
+
const { selectWallet, currentWallet } = useCrossConnectKit();
|
|
15
|
+
const [copied, setCopied] = useState(false);
|
|
16
|
+
const isEmbedded = currentWallet === 'cross_embedded';
|
|
17
|
+
const handleCopy = useCallback(() => {
|
|
18
|
+
if (!address)
|
|
19
|
+
return;
|
|
20
|
+
navigator.clipboard.writeText(address).then(() => {
|
|
21
|
+
setCopied(true);
|
|
22
|
+
setTimeout(() => setCopied(false), 2000);
|
|
23
|
+
});
|
|
24
|
+
}, [address]);
|
|
25
|
+
const handleDisconnect = useCallback(() => {
|
|
26
|
+
disconnect();
|
|
27
|
+
onClose();
|
|
28
|
+
}, [disconnect, onClose]);
|
|
29
|
+
const handleExplorer = useCallback(() => {
|
|
30
|
+
if (!chain?.blockExplorers?.default?.url || !address)
|
|
31
|
+
return;
|
|
32
|
+
window.open(`${chain.blockExplorers.default.url}/address/${address}`, '_blank');
|
|
33
|
+
}, [chain, address]);
|
|
34
|
+
if (!open || !address)
|
|
35
|
+
return null;
|
|
36
|
+
const displayName = ensName ?? truncateAddress(address);
|
|
37
|
+
const balanceText = balance
|
|
38
|
+
? `${formatBalance(balance.value, balance.decimals)} ${balance.symbol}`
|
|
39
|
+
: '—';
|
|
40
|
+
return (_jsxs(_Fragment, { children: [_jsx("div", { style: s.backdrop, onClick: onClose }), _jsxs("div", { style: s.popover, children: [_jsxs("div", { style: s.identity, children: [_jsx("div", { style: s.avatar, children: _jsxs("svg", { width: "40", height: "40", viewBox: "0 0 40 40", children: [_jsx("rect", { width: "40", height: "40", rx: "20", fill: "#00D5AA" }), _jsx("text", { x: "50%", y: "55%", textAnchor: "middle", dominantBaseline: "middle", fontSize: "16", fontWeight: "bold", fill: "#000", children: address.slice(2, 4).toUpperCase() })] }) }), _jsxs("div", { style: s.identityText, children: [_jsx("div", { style: s.displayName, children: displayName }), chain && _jsx("div", { style: s.chainName, children: chain.name })] })] }), _jsxs("div", { style: s.balanceCard, children: [_jsx("div", { style: s.balanceLabel, children: "Balance" }), _jsx("div", { style: s.balanceValue, children: balanceText })] }), _jsxs("div", { style: s.addressRow, children: [_jsx("code", { style: s.addressCode, children: truncateAddress(address) }), _jsx("button", { type: "button", onClick: handleCopy, style: s.actionBtn, title: "Copy address", children: copied ? (_jsx("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "none", stroke: "#00D5AA", strokeWidth: "2.5", strokeLinecap: "round", strokeLinejoin: "round", children: _jsx("polyline", { points: "20 6 9 17 4 12" }) })) : (_jsxs("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("rect", { x: "9", y: "9", width: "13", height: "13", rx: "2", ry: "2" }), _jsx("path", { d: "M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1" })] })) }), chain?.blockExplorers?.default && (_jsx("button", { type: "button", onClick: handleExplorer, style: s.actionBtn, title: "View on explorer", children: _jsxs("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("path", { d: "M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6" }), _jsx("polyline", { points: "15 3 21 3 21 9" }), _jsx("line", { x1: "10", y1: "14", x2: "21", y2: "3" })] }) }))] }), isEmbedded && (_jsxs("button", { type: "button", onClick: () => { selectWallet(); onClose(); }, style: s.selectWalletBtn, children: [_jsxs("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("rect", { x: "2", y: "6", width: "20", height: "14", rx: "2" }), _jsx("path", { d: "M22 10H2" })] }), "Select Wallet"] })), _jsxs("button", { type: "button", onClick: handleDisconnect, style: s.disconnectBtn, children: [_jsxs("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", children: [_jsx("path", { d: "M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4" }), _jsx("polyline", { points: "16 17 21 12 16 7" }), _jsx("line", { x1: "21", y1: "12", x2: "9", y2: "12" })] }), "Disconnect"] })] })] }));
|
|
41
|
+
}
|
|
42
|
+
const s = {
|
|
43
|
+
backdrop: {
|
|
44
|
+
position: 'fixed',
|
|
45
|
+
inset: 0,
|
|
46
|
+
zIndex: 9999,
|
|
47
|
+
},
|
|
48
|
+
popover: {
|
|
49
|
+
position: 'absolute',
|
|
50
|
+
top: 'calc(100% + 8px)',
|
|
51
|
+
right: 0,
|
|
52
|
+
width: '320px',
|
|
53
|
+
background: '#161922',
|
|
54
|
+
border: '1px solid #2a2d3a',
|
|
55
|
+
borderRadius: '20px',
|
|
56
|
+
padding: '20px',
|
|
57
|
+
zIndex: 10000,
|
|
58
|
+
boxShadow: '0 8px 40px rgba(0,0,0,0.5)',
|
|
59
|
+
display: 'flex',
|
|
60
|
+
flexDirection: 'column',
|
|
61
|
+
gap: '16px',
|
|
62
|
+
},
|
|
63
|
+
identity: {
|
|
64
|
+
display: 'flex',
|
|
65
|
+
alignItems: 'center',
|
|
66
|
+
gap: '12px',
|
|
67
|
+
},
|
|
68
|
+
avatar: {
|
|
69
|
+
flexShrink: 0,
|
|
70
|
+
borderRadius: '20px',
|
|
71
|
+
overflow: 'hidden',
|
|
72
|
+
},
|
|
73
|
+
identityText: {
|
|
74
|
+
display: 'flex',
|
|
75
|
+
flexDirection: 'column',
|
|
76
|
+
gap: '2px',
|
|
77
|
+
minWidth: 0,
|
|
78
|
+
},
|
|
79
|
+
displayName: {
|
|
80
|
+
fontSize: '16px',
|
|
81
|
+
fontWeight: 700,
|
|
82
|
+
color: '#fff',
|
|
83
|
+
overflow: 'hidden',
|
|
84
|
+
textOverflow: 'ellipsis',
|
|
85
|
+
whiteSpace: 'nowrap',
|
|
86
|
+
},
|
|
87
|
+
chainName: {
|
|
88
|
+
fontSize: '12px',
|
|
89
|
+
color: '#ffffff60',
|
|
90
|
+
fontWeight: 500,
|
|
91
|
+
},
|
|
92
|
+
balanceCard: {
|
|
93
|
+
background: '#1e232e',
|
|
94
|
+
borderRadius: '14px',
|
|
95
|
+
padding: '14px 16px',
|
|
96
|
+
},
|
|
97
|
+
balanceLabel: {
|
|
98
|
+
fontSize: '11px',
|
|
99
|
+
fontWeight: 600,
|
|
100
|
+
color: '#ffffff50',
|
|
101
|
+
marginBottom: '4px',
|
|
102
|
+
textTransform: 'uppercase',
|
|
103
|
+
letterSpacing: '0.05em',
|
|
104
|
+
},
|
|
105
|
+
balanceValue: {
|
|
106
|
+
fontSize: '20px',
|
|
107
|
+
fontWeight: 700,
|
|
108
|
+
color: '#fff',
|
|
109
|
+
},
|
|
110
|
+
addressRow: {
|
|
111
|
+
display: 'flex',
|
|
112
|
+
alignItems: 'center',
|
|
113
|
+
gap: '8px',
|
|
114
|
+
background: '#1e232e',
|
|
115
|
+
borderRadius: '12px',
|
|
116
|
+
padding: '10px 12px',
|
|
117
|
+
},
|
|
118
|
+
addressCode: {
|
|
119
|
+
flex: 1,
|
|
120
|
+
fontSize: '13px',
|
|
121
|
+
color: '#ffffff90',
|
|
122
|
+
fontFamily: 'monospace',
|
|
123
|
+
},
|
|
124
|
+
actionBtn: {
|
|
125
|
+
background: 'none',
|
|
126
|
+
border: 'none',
|
|
127
|
+
color: '#ffffff60',
|
|
128
|
+
cursor: 'pointer',
|
|
129
|
+
padding: '4px',
|
|
130
|
+
borderRadius: '6px',
|
|
131
|
+
display: 'flex',
|
|
132
|
+
alignItems: 'center',
|
|
133
|
+
justifyContent: 'center',
|
|
134
|
+
},
|
|
135
|
+
selectWalletBtn: {
|
|
136
|
+
width: '100%',
|
|
137
|
+
padding: '12px',
|
|
138
|
+
borderRadius: '12px',
|
|
139
|
+
border: 'none',
|
|
140
|
+
background: 'rgba(255,255,255,0.05)',
|
|
141
|
+
color: '#ffffffb2',
|
|
142
|
+
fontWeight: 600,
|
|
143
|
+
fontSize: '14px',
|
|
144
|
+
cursor: 'pointer',
|
|
145
|
+
display: 'flex',
|
|
146
|
+
alignItems: 'center',
|
|
147
|
+
justifyContent: 'center',
|
|
148
|
+
gap: '8px',
|
|
149
|
+
},
|
|
150
|
+
disconnectBtn: {
|
|
151
|
+
width: '100%',
|
|
152
|
+
padding: '12px',
|
|
153
|
+
borderRadius: '12px',
|
|
154
|
+
border: 'none',
|
|
155
|
+
background: 'rgba(255,255,255,0.05)',
|
|
156
|
+
color: '#ffffffb2',
|
|
157
|
+
fontWeight: 600,
|
|
158
|
+
fontSize: '14px',
|
|
159
|
+
cursor: 'pointer',
|
|
160
|
+
display: 'flex',
|
|
161
|
+
alignItems: 'center',
|
|
162
|
+
justifyContent: 'center',
|
|
163
|
+
gap: '8px',
|
|
164
|
+
},
|
|
165
|
+
};
|
|
166
|
+
//# sourceMappingURL=WalletInfoPopover.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WalletInfoPopover.js","sourceRoot":"","sources":["../../src/components/WalletInfoPopover.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { ReactNode } from 'react';
|
|
2
|
+
import type { WalletId } from '@nexus-cross/connect-kit-core';
|
|
3
|
+
import type { CrossxConfig } from '@nexus-cross/connect-kit-wagmi';
|
|
4
|
+
export interface CrossConnectKitProviderProps {
|
|
5
|
+
children: ReactNode;
|
|
6
|
+
config: CrossxConfig;
|
|
7
|
+
}
|
|
8
|
+
export interface ConnectButtonProps {
|
|
9
|
+
showBalance?: boolean;
|
|
10
|
+
label?: string;
|
|
11
|
+
className?: string;
|
|
12
|
+
}
|
|
13
|
+
export interface OtherWalletsModalProps {
|
|
14
|
+
open: boolean;
|
|
15
|
+
onClose: () => void;
|
|
16
|
+
onSelect: (walletId: WalletId) => void;
|
|
17
|
+
}
|
|
18
|
+
export interface WalletInfoPopoverProps {
|
|
19
|
+
open: boolean;
|
|
20
|
+
onClose: () => void;
|
|
21
|
+
anchorRef?: React.RefObject<HTMLElement | null>;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/components/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAK,EAAS,QAAQ,EAAE,MAAM,+BAA+B,CAAC;AACrE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAEnE,MAAM,WAAW,4BAA4B;IAC3C,QAAQ,EAAE,SAAS,CAAC;IACpB,MAAM,EAAE,YAAY,CAAC;CACtB;AAED,MAAM,WAAW,kBAAkB;IACjC,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,sBAAsB;IACrC,IAAI,EAAE,OAAO,CAAC;IACd,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,QAAQ,EAAE,CAAC,QAAQ,EAAE,QAAQ,KAAK,IAAI,CAAC;CACxC;AAED,MAAM,WAAW,sBAAsB;IACrC,IAAI,EAAE,OAAO,CAAC;IACd,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,SAAS,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC;CACjD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/components/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { CrossConnectKitConfig, WalletId } from '@nexus-cross/connect-kit-core';
|
|
2
|
+
import type { ConnectorEntry, ConnectorRegistry } from '@nexus-cross/connect-kit-wagmi';
|
|
3
|
+
export interface CrossConnectKitContextValue {
|
|
4
|
+
kitConfig: CrossConnectKitConfig;
|
|
5
|
+
connectorRegistry: ConnectorRegistry;
|
|
6
|
+
/** Available wallets derived from the registry (excludes embedded) */
|
|
7
|
+
availableWallets: readonly ConnectorEntry[];
|
|
8
|
+
/** Connect by walletId — resolved through the registry */
|
|
9
|
+
connect: (walletId: WalletId) => Promise<void>;
|
|
10
|
+
/** Shortcut: trigger embedded wallet connect (SDK modal) */
|
|
11
|
+
connectWallet: () => Promise<void>;
|
|
12
|
+
/** Disconnect and clean up wagmi + SDK + cached session storage. */
|
|
13
|
+
disconnect: () => Promise<void>;
|
|
14
|
+
/** Open the SDK's wallet selector (embedded only) */
|
|
15
|
+
selectWallet: () => Promise<{
|
|
16
|
+
address: string;
|
|
17
|
+
index: number;
|
|
18
|
+
} | null>;
|
|
19
|
+
/** Currently active wallet type, resolved from registry */
|
|
20
|
+
currentWallet: WalletId | null;
|
|
21
|
+
/** Open the "Other Wallets" modal */
|
|
22
|
+
openOtherWallets: () => void;
|
|
23
|
+
/** Close the "Other Wallets" modal */
|
|
24
|
+
closeOtherWallets: () => void;
|
|
25
|
+
/** Whether the "Other Wallets" modal is open */
|
|
26
|
+
otherWalletsOpen: boolean;
|
|
27
|
+
}
|
|
28
|
+
export declare const CrossConnectKitContext: import("react").Context<CrossConnectKitContextValue | null>;
|
|
29
|
+
export declare function useCrossConnectKit(): CrossConnectKitContextValue;
|
|
30
|
+
//# sourceMappingURL=CrossConnectKitContext.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CrossConnectKitContext.d.ts","sourceRoot":"","sources":["../../src/context/CrossConnectKitContext.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,qBAAqB,EAAE,QAAQ,EAAE,MAAM,+BAA+B,CAAC;AACrF,OAAO,KAAK,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AAExF,MAAM,WAAW,2BAA2B;IAC1C,SAAS,EAAE,qBAAqB,CAAC;IACjC,iBAAiB,EAAE,iBAAiB,CAAC;IAErC,sEAAsE;IACtE,gBAAgB,EAAE,SAAS,cAAc,EAAE,CAAC;IAE5C,0DAA0D;IAC1D,OAAO,EAAE,CAAC,QAAQ,EAAE,QAAQ,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/C,4DAA4D;IAC5D,aAAa,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IACnC,oEAAoE;IACpE,UAAU,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAChC,qDAAqD;IACrD,YAAY,EAAE,MAAM,OAAO,CAAC;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC,CAAC;IAEvE,2DAA2D;IAC3D,aAAa,EAAE,QAAQ,GAAG,IAAI,CAAC;IAE/B,qCAAqC;IACrC,gBAAgB,EAAE,MAAM,IAAI,CAAC;IAC7B,sCAAsC;IACtC,iBAAiB,EAAE,MAAM,IAAI,CAAC;IAC9B,gDAAgD;IAChD,gBAAgB,EAAE,OAAO,CAAC;CAC3B;AAED,eAAO,MAAM,sBAAsB,6DAA0D,CAAC;AAE9F,wBAAgB,kBAAkB,IAAI,2BAA2B,CAMhE"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { createContext, useContext } from 'react';
|
|
2
|
+
export const CrossConnectKitContext = createContext(null);
|
|
3
|
+
export function useCrossConnectKit() {
|
|
4
|
+
const ctx = useContext(CrossConnectKitContext);
|
|
5
|
+
if (!ctx) {
|
|
6
|
+
throw new Error('useCrossConnectKit must be used within <CrossConnectKitProvider>');
|
|
7
|
+
}
|
|
8
|
+
return ctx;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=CrossConnectKitContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CrossConnectKitContext.js","sourceRoot":"","sources":["../../src/context/CrossConnectKitContext.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AA+BlD,MAAM,CAAC,MAAM,sBAAsB,GAAG,aAAa,CAAqC,IAAI,CAAC,CAAC;AAE9F,MAAM,UAAU,kBAAkB;IAChC,MAAM,GAAG,GAAG,UAAU,CAAC,sBAAsB,CAAC,CAAC;IAC/C,IAAI,CAAC,GAAG,EAAE,CAAC;QACT,MAAM,IAAI,KAAK,CAAC,kEAAkE,CAAC,CAAC;IACtF,CAAC;IACD,OAAO,GAAG,CAAC;AACb,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import type { ThemeMode, ThemeTokens } from '@nexus-cross/connect-kit-core';
|
|
2
|
+
/**
|
|
3
|
+
* Resolved theme state exposed to consumers inside `<CrossConnectKitProvider>`.
|
|
4
|
+
* `mode` already accounts for `autoDetectTheme` and any runtime
|
|
5
|
+
* overrides via `setTheme`.
|
|
6
|
+
*/
|
|
7
|
+
export interface CrossConnectKitThemeContextValue {
|
|
8
|
+
/** Active theme mode (respects `autoDetectTheme` + runtime overrides). */
|
|
9
|
+
mode: ThemeMode;
|
|
10
|
+
/** Resolved token set passed to crossy-sdk + published as `--cck-*`. */
|
|
11
|
+
tokens: ThemeTokens | undefined;
|
|
12
|
+
/**
|
|
13
|
+
* Override the theme mode at runtime. Mirrors crossy-sdk's
|
|
14
|
+
* `sdk.applyTheme(mode)`.
|
|
15
|
+
*
|
|
16
|
+
* Passing `null` reverts to whatever the original `CrossConnectKitConfig`
|
|
17
|
+
* declared (including `autoDetectTheme`).
|
|
18
|
+
*/
|
|
19
|
+
setThemeMode: (mode: ThemeMode | null) => void;
|
|
20
|
+
/**
|
|
21
|
+
* Override color tokens at runtime. Passed straight through to
|
|
22
|
+
* crossy-sdk's `applyTheme(mode, themeTokens)` on the next render,
|
|
23
|
+
* and re-published as CSS variables so dapp-ui surfaces update too.
|
|
24
|
+
*
|
|
25
|
+
* Passing `null` reverts to `CrossConnectKitConfig.themeTokens`.
|
|
26
|
+
*/
|
|
27
|
+
setThemeTokens: (tokens: ThemeTokens | null) => void;
|
|
28
|
+
}
|
|
29
|
+
export declare const CrossConnectKitThemeContext: import("react").Context<CrossConnectKitThemeContextValue | null>;
|
|
30
|
+
/**
|
|
31
|
+
* Access the resolved theme and the runtime override setters. Must be
|
|
32
|
+
* called inside `<CrossConnectKitProvider>`.
|
|
33
|
+
*/
|
|
34
|
+
export declare function useCrossConnectKitTheme(): CrossConnectKitThemeContextValue;
|
|
35
|
+
/**
|
|
36
|
+
* Version that returns `null` when called outside the provider — handy
|
|
37
|
+
* for components (like `WalletInfo`) that want to opt into the kit's
|
|
38
|
+
* theme if mounted under the provider, but keep working standalone.
|
|
39
|
+
*/
|
|
40
|
+
export declare function useOptionalCrossConnectKitTheme(): CrossConnectKitThemeContextValue | null;
|
|
41
|
+
//# sourceMappingURL=CrossConnectKitThemeContext.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CrossConnectKitThemeContext.d.ts","sourceRoot":"","sources":["../../src/context/CrossConnectKitThemeContext.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAE5E;;;;GAIG;AACH,MAAM,WAAW,gCAAgC;IAC/C,0EAA0E;IAC1E,IAAI,EAAE,SAAS,CAAC;IAChB,wEAAwE;IACxE,MAAM,EAAE,WAAW,GAAG,SAAS,CAAC;IAChC;;;;;;OAMG;IACH,YAAY,EAAE,CAAC,IAAI,EAAE,SAAS,GAAG,IAAI,KAAK,IAAI,CAAC;IAC/C;;;;;;OAMG;IACH,cAAc,EAAE,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI,KAAK,IAAI,CAAC;CACtD;AAED,eAAO,MAAM,2BAA2B,kEACsB,CAAC;AAE/D;;;GAGG;AACH,wBAAgB,uBAAuB,IAAI,gCAAgC,CAQ1E;AAED;;;;GAIG;AACH,wBAAgB,+BAA+B,IAAI,gCAAgC,GAAG,IAAI,CAEzF"}
|