btc-wallet 0.0.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 +9 -0
- package/dist/components/btcWalletSelectorContext.d.ts +12 -0
- package/dist/components/button/index.d.ts +10 -0
- package/dist/components/confirmBox/Modal.d.ts +7 -0
- package/dist/components/confirmBox/index.d.ts +9 -0
- package/dist/components/connectModal/index.d.ts +5 -0
- package/dist/components/copyText/index.d.ts +8 -0
- package/dist/components/hook.d.ts +1 -0
- package/dist/components/modal/index.d.ts +11 -0
- package/dist/components/signModal/index.d.ts +6 -0
- package/dist/components/spinner/index.d.ts +6 -0
- package/dist/components/tooltip/index.d.ts +7 -0
- package/dist/components/transactionDetails/index.d.ts +5 -0
- package/dist/connector/base.d.ts +29 -0
- package/dist/connector/bitget.d.ts +6 -0
- package/dist/connector/bybit.d.ts +6 -0
- package/dist/connector/index.d.ts +9 -0
- package/dist/connector/injected.d.ts +25 -0
- package/dist/connector/okx.d.ts +6 -0
- package/dist/connector/tokenPocket.d.ts +6 -0
- package/dist/connector/unisat.d.ts +6 -0
- package/dist/connector/wizz.d.ts +6 -0
- package/dist/connector/xverse.d.ts +23 -0
- package/dist/context/index.d.ts +45 -0
- package/dist/evmSigner/index.d.ts +4966 -0
- package/dist/evmSigner/provider.d.ts +13 -0
- package/dist/evmSigner/walletClientProvider.d.ts +10 -0
- package/dist/hooks/index.d.ts +6 -0
- package/dist/hooks/useAccountContract.d.ts +4 -0
- package/dist/hooks/useAccounts.d.ts +3 -0
- package/dist/hooks/useBTCProvider.d.ts +16 -0
- package/dist/hooks/useConnectModal.d.ts +4 -0
- package/dist/hooks/useConnector.d.ts +4 -0
- package/dist/hooks/useETHProvider.d.ts +1 -0
- package/dist/hooks/useModalStateValue.d.ts +6 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +2738 -0
- package/dist/index.js.map +7 -0
- package/dist/package.json +1 -0
- package/dist/types/accountInfo.d.ts +6 -0
- package/dist/types/deserializeTx.d.ts +97 -0
- package/dist/types/eventName.d.ts +8 -0
- package/dist/types/evmMethod.d.ts +4 -0
- package/dist/utils/ethereumUtils.d.ts +7 -0
- package/dist/utils/eventUtils.d.ts +4 -0
- package/dist/utils/index.d.ts +11 -0
- package/dist/utils/initWalletButton.d.ts +6 -0
- package/dist/utils/setupBTCWallet.d.ts +11 -0
- package/dist/utils/setupSatoshiWallet.d.ts +11 -0
- package/dist/utils/txConfirmUtils.d.ts +6 -0
- package/esm/index.js +2720 -0
- package/esm/index.js.map +7 -0
- package/package.json +89 -0
package/esm/index.js
ADDED
@@ -0,0 +1,2720 @@
|
|
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 __accessCheck = (obj, member, msg) => {
|
22
|
+
if (!member.has(obj))
|
23
|
+
throw TypeError("Cannot " + msg);
|
24
|
+
};
|
25
|
+
var __privateGet = (obj, member, getter) => {
|
26
|
+
__accessCheck(obj, member, "read from private field");
|
27
|
+
return getter ? getter.call(obj) : member.get(obj);
|
28
|
+
};
|
29
|
+
var __privateAdd = (obj, member, value) => {
|
30
|
+
if (member.has(obj))
|
31
|
+
throw TypeError("Cannot add the same private member more than once");
|
32
|
+
member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
33
|
+
};
|
34
|
+
var __async = (__this, __arguments, generator) => {
|
35
|
+
return new Promise((resolve, reject) => {
|
36
|
+
var fulfilled = (value) => {
|
37
|
+
try {
|
38
|
+
step(generator.next(value));
|
39
|
+
} catch (e) {
|
40
|
+
reject(e);
|
41
|
+
}
|
42
|
+
};
|
43
|
+
var rejected = (value) => {
|
44
|
+
try {
|
45
|
+
step(generator.throw(value));
|
46
|
+
} catch (e) {
|
47
|
+
reject(e);
|
48
|
+
}
|
49
|
+
};
|
50
|
+
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
51
|
+
step((generator = generator.apply(__this, __arguments)).next());
|
52
|
+
});
|
53
|
+
};
|
54
|
+
|
55
|
+
// src/connector/base.ts
|
56
|
+
var BaseConnector = class {
|
57
|
+
};
|
58
|
+
|
59
|
+
// src/icons/bitget.png
|
60
|
+
var bitget_default = "";
|
61
|
+
|
62
|
+
// src/connector/injected.ts
|
63
|
+
var InjectedConnector = class extends BaseConnector {
|
64
|
+
constructor(propertity) {
|
65
|
+
var _a;
|
66
|
+
super();
|
67
|
+
this.propertity = propertity;
|
68
|
+
const props = (_a = this.propertity) == null ? void 0 : _a.split(".");
|
69
|
+
if (!this.propertity || props.length > 2) {
|
70
|
+
throw new Error("please input valid propertity");
|
71
|
+
}
|
72
|
+
}
|
73
|
+
isReady() {
|
74
|
+
if (typeof window !== "undefined") {
|
75
|
+
const props = this.propertity.split(".");
|
76
|
+
if (props.length === 1) {
|
77
|
+
return typeof window[props[0]] !== "undefined";
|
78
|
+
} else {
|
79
|
+
return typeof window[props[0]] !== "undefined" && typeof window[props[0]][props[1]] !== "undefined";
|
80
|
+
}
|
81
|
+
}
|
82
|
+
return false;
|
83
|
+
}
|
84
|
+
requestAccounts() {
|
85
|
+
return __async(this, null, function* () {
|
86
|
+
const accounts = yield this.getProviderOrThrow().requestAccounts();
|
87
|
+
return accounts;
|
88
|
+
});
|
89
|
+
}
|
90
|
+
getAccounts() {
|
91
|
+
return __async(this, null, function* () {
|
92
|
+
const accounts = yield this.getProviderOrThrow().getAccounts();
|
93
|
+
return accounts;
|
94
|
+
});
|
95
|
+
}
|
96
|
+
getPublicKey() {
|
97
|
+
return __async(this, null, function* () {
|
98
|
+
return this.getProviderOrThrow().getPublicKey();
|
99
|
+
});
|
100
|
+
}
|
101
|
+
signMessage(signStr, type) {
|
102
|
+
return __async(this, null, function* () {
|
103
|
+
const addresses = yield this.getAccounts();
|
104
|
+
if (addresses.length === 0) {
|
105
|
+
throw new Error(`${this.metadata.name} not connected!`);
|
106
|
+
}
|
107
|
+
return this.getProviderOrThrow().signMessage(signStr, type);
|
108
|
+
});
|
109
|
+
}
|
110
|
+
on(event, handler) {
|
111
|
+
var _a;
|
112
|
+
const provider = this.getProvider();
|
113
|
+
return (_a = provider == null ? void 0 : provider.on) == null ? void 0 : _a.call(provider, event, handler);
|
114
|
+
}
|
115
|
+
removeListener(event, handler) {
|
116
|
+
var _a;
|
117
|
+
const provider = this.getProvider();
|
118
|
+
return (_a = provider == null ? void 0 : provider.removeListener) == null ? void 0 : _a.call(provider, event, handler);
|
119
|
+
}
|
120
|
+
getProvider() {
|
121
|
+
if (this.isReady()) {
|
122
|
+
const props = this.propertity.split(".");
|
123
|
+
if (props.length === 1) {
|
124
|
+
return window[props[0]];
|
125
|
+
} else {
|
126
|
+
return window[props[0]][props[1]];
|
127
|
+
}
|
128
|
+
}
|
129
|
+
}
|
130
|
+
getProviderOrThrow() {
|
131
|
+
const provider = this.getProvider();
|
132
|
+
if (!provider) {
|
133
|
+
throw new Error(`${this.metadata.name} is not install or not create Bitcoin wallet!`);
|
134
|
+
}
|
135
|
+
return provider;
|
136
|
+
}
|
137
|
+
getNetwork() {
|
138
|
+
return __async(this, null, function* () {
|
139
|
+
return this.getProviderOrThrow().getNetwork();
|
140
|
+
});
|
141
|
+
}
|
142
|
+
switchNetwork(network) {
|
143
|
+
return __async(this, null, function* () {
|
144
|
+
return this.getProviderOrThrow().switchNetwork(network);
|
145
|
+
});
|
146
|
+
}
|
147
|
+
sendBitcoin(toAddress, satoshis, options) {
|
148
|
+
return __async(this, null, function* () {
|
149
|
+
return this.getProviderOrThrow().sendBitcoin(toAddress, satoshis, options);
|
150
|
+
});
|
151
|
+
}
|
152
|
+
sendInscription(address, inscriptionId, options) {
|
153
|
+
return __async(this, null, function* () {
|
154
|
+
const result = yield this.getProviderOrThrow().sendInscription(address, inscriptionId, options);
|
155
|
+
if (typeof result === "string") {
|
156
|
+
return {
|
157
|
+
txid: result
|
158
|
+
};
|
159
|
+
}
|
160
|
+
return result;
|
161
|
+
});
|
162
|
+
}
|
163
|
+
disconnect() {
|
164
|
+
}
|
165
|
+
};
|
166
|
+
|
167
|
+
// src/connector/bitget.ts
|
168
|
+
var BitgetConnector = class extends InjectedConnector {
|
169
|
+
constructor() {
|
170
|
+
super("bitkeep.unisat");
|
171
|
+
this.metadata = {
|
172
|
+
id: "bitget",
|
173
|
+
name: "Bitget Wallet",
|
174
|
+
icon: bitget_default,
|
175
|
+
downloadUrl: "https://web3.bitget.com/en/wallet-download"
|
176
|
+
};
|
177
|
+
}
|
178
|
+
};
|
179
|
+
|
180
|
+
// src/icons/bybit.png
|
181
|
+
var bybit_default = "";
|
182
|
+
|
183
|
+
// src/connector/bybit.ts
|
184
|
+
var BybitConnector = class extends InjectedConnector {
|
185
|
+
constructor() {
|
186
|
+
super("bybitWallet.bitcoin");
|
187
|
+
this.metadata = {
|
188
|
+
id: "bybit",
|
189
|
+
name: "Bybit Wallet",
|
190
|
+
icon: bybit_default,
|
191
|
+
downloadUrl: "https://www.bybit.com/download/"
|
192
|
+
};
|
193
|
+
}
|
194
|
+
};
|
195
|
+
|
196
|
+
// src/icons/okx.svg
|
197
|
+
var okx_default = "";
|
198
|
+
|
199
|
+
// src/connector/okx.ts
|
200
|
+
var OKXConnector = class extends InjectedConnector {
|
201
|
+
constructor() {
|
202
|
+
super("okxwallet.bitcoin");
|
203
|
+
this.metadata = {
|
204
|
+
id: "okx",
|
205
|
+
name: "OKX Wallet",
|
206
|
+
icon: okx_default,
|
207
|
+
downloadUrl: "https://www.okx.com/download"
|
208
|
+
};
|
209
|
+
}
|
210
|
+
};
|
211
|
+
|
212
|
+
// src/icons/tokenpocket.png
|
213
|
+
var tokenpocket_default = "";
|
214
|
+
|
215
|
+
// src/connector/tokenPocket.ts
|
216
|
+
var TokenPocketConnector = class extends InjectedConnector {
|
217
|
+
constructor() {
|
218
|
+
super("tokenpocket.bitcoin");
|
219
|
+
this.metadata = {
|
220
|
+
id: "tokenpocket",
|
221
|
+
name: "TokenPocket",
|
222
|
+
icon: tokenpocket_default,
|
223
|
+
downloadUrl: "https://www.tokenpocket.pro/en/download/app"
|
224
|
+
};
|
225
|
+
}
|
226
|
+
};
|
227
|
+
|
228
|
+
// src/icons/unisat.svg
|
229
|
+
var unisat_default = "";
|
230
|
+
|
231
|
+
// src/connector/unisat.ts
|
232
|
+
var UnisatConnector = class extends InjectedConnector {
|
233
|
+
constructor() {
|
234
|
+
super("unisat");
|
235
|
+
this.metadata = {
|
236
|
+
id: "unisat",
|
237
|
+
name: "Unisat Wallet",
|
238
|
+
icon: unisat_default,
|
239
|
+
downloadUrl: "https://unisat.io"
|
240
|
+
};
|
241
|
+
}
|
242
|
+
};
|
243
|
+
|
244
|
+
// src/icons/wizz.svg
|
245
|
+
var wizz_default = "";
|
246
|
+
|
247
|
+
// src/connector/wizz.ts
|
248
|
+
var WizzConnector = class extends InjectedConnector {
|
249
|
+
constructor() {
|
250
|
+
super("wizz");
|
251
|
+
this.metadata = {
|
252
|
+
id: "wizz",
|
253
|
+
name: "Wizz Wallet",
|
254
|
+
icon: wizz_default,
|
255
|
+
downloadUrl: "https://wizzwallet.io"
|
256
|
+
};
|
257
|
+
}
|
258
|
+
};
|
259
|
+
|
260
|
+
// src/connector/xverse.ts
|
261
|
+
import EventEmitter from "events";
|
262
|
+
|
263
|
+
// src/icons/xverse.png
|
264
|
+
var xverse_default = "";
|
265
|
+
|
266
|
+
// src/connector/xverse.ts
|
267
|
+
var _network, _event;
|
268
|
+
var XverseConnector = class extends BaseConnector {
|
269
|
+
constructor() {
|
270
|
+
super();
|
271
|
+
__privateAdd(this, _network, "Mainnet");
|
272
|
+
__privateAdd(this, _event, new EventEmitter());
|
273
|
+
this.metadata = {
|
274
|
+
id: "xverse",
|
275
|
+
name: "Xverse Wallet",
|
276
|
+
icon: xverse_default,
|
277
|
+
downloadUrl: "https://www.xverse.app"
|
278
|
+
};
|
279
|
+
this.loadAccounts = (network) => __async(this, null, function* () {
|
280
|
+
const { getAddress, AddressPurpose } = yield import("sats-connect");
|
281
|
+
const addresses = yield new Promise((resolve, reject) => {
|
282
|
+
const getAddressOptions = {
|
283
|
+
payload: {
|
284
|
+
purposes: [AddressPurpose.Payment, AddressPurpose.Ordinals],
|
285
|
+
message: "Address for receiving Ordinals and payments",
|
286
|
+
network: {
|
287
|
+
type: network
|
288
|
+
}
|
289
|
+
},
|
290
|
+
onFinish: (response) => {
|
291
|
+
resolve(response.addresses);
|
292
|
+
},
|
293
|
+
onCancel: () => reject({
|
294
|
+
code: 4001,
|
295
|
+
message: "User rejected the request."
|
296
|
+
})
|
297
|
+
};
|
298
|
+
getAddress(getAddressOptions).catch((error) => reject(error));
|
299
|
+
});
|
300
|
+
localStorage.setItem("btc-connect-xverse-addresses-" + network, JSON.stringify(addresses));
|
301
|
+
return addresses;
|
302
|
+
});
|
303
|
+
__privateGet(this, _event).setMaxListeners(100);
|
304
|
+
}
|
305
|
+
isReady() {
|
306
|
+
return typeof window !== "undefined" && typeof window.BitcoinProvider !== "undefined";
|
307
|
+
}
|
308
|
+
sendInscription() {
|
309
|
+
return __async(this, null, function* () {
|
310
|
+
throw new Error("Unsupported");
|
311
|
+
});
|
312
|
+
}
|
313
|
+
requestAccounts() {
|
314
|
+
return __async(this, null, function* () {
|
315
|
+
if (!this.isReady()) {
|
316
|
+
throw new Error(`${this.metadata.name} is not install!`);
|
317
|
+
}
|
318
|
+
const addresses = yield this.loadAccounts(__privateGet(this, _network));
|
319
|
+
return addresses.map((item) => item.address);
|
320
|
+
});
|
321
|
+
}
|
322
|
+
getAccounts() {
|
323
|
+
return __async(this, null, function* () {
|
324
|
+
if (!this.isReady()) {
|
325
|
+
throw new Error(`${this.metadata.name} is not install!`);
|
326
|
+
}
|
327
|
+
const data = localStorage.getItem("btc-connect-xverse-addresses-" + __privateGet(this, _network));
|
328
|
+
if (data) {
|
329
|
+
const addresses = JSON.parse(data);
|
330
|
+
return addresses.map((item) => item.address);
|
331
|
+
} else {
|
332
|
+
return [];
|
333
|
+
}
|
334
|
+
});
|
335
|
+
}
|
336
|
+
getPublicKey() {
|
337
|
+
return __async(this, null, function* () {
|
338
|
+
if (!this.isReady()) {
|
339
|
+
throw new Error(`${this.metadata.name} is not install!`);
|
340
|
+
}
|
341
|
+
const data = localStorage.getItem("btc-connect-xverse-addresses-" + __privateGet(this, _network));
|
342
|
+
if (data) {
|
343
|
+
const addresses = JSON.parse(data);
|
344
|
+
return addresses[0].publicKey;
|
345
|
+
} else {
|
346
|
+
return "";
|
347
|
+
}
|
348
|
+
});
|
349
|
+
}
|
350
|
+
signMessage(signStr) {
|
351
|
+
return __async(this, null, function* () {
|
352
|
+
if (!this.isReady()) {
|
353
|
+
throw new Error(`${this.metadata.name} is not install!`);
|
354
|
+
}
|
355
|
+
const addresses = yield this.getAccounts();
|
356
|
+
if (addresses.length === 0) {
|
357
|
+
throw new Error(`${this.metadata.name} not connected!`);
|
358
|
+
}
|
359
|
+
const { signMessage } = yield import("sats-connect");
|
360
|
+
const sig = yield new Promise((resolve, reject) => {
|
361
|
+
const signMessageOptions = {
|
362
|
+
payload: {
|
363
|
+
network: {
|
364
|
+
type: __privateGet(this, _network)
|
365
|
+
},
|
366
|
+
address: addresses[0],
|
367
|
+
message: signStr
|
368
|
+
},
|
369
|
+
onFinish: (response) => {
|
370
|
+
resolve(response);
|
371
|
+
},
|
372
|
+
onCancel: () => {
|
373
|
+
reject({
|
374
|
+
code: 4001,
|
375
|
+
message: "User rejected the request."
|
376
|
+
});
|
377
|
+
}
|
378
|
+
};
|
379
|
+
signMessage(signMessageOptions).catch((e) => {
|
380
|
+
reject(e);
|
381
|
+
});
|
382
|
+
});
|
383
|
+
const modifiedSig = Buffer.from(sig, "base64");
|
384
|
+
modifiedSig[0] = 31 + (modifiedSig[0] - 31) % 4;
|
385
|
+
return modifiedSig.toString("base64");
|
386
|
+
});
|
387
|
+
}
|
388
|
+
on(event, handler) {
|
389
|
+
return __privateGet(this, _event).on(event, handler);
|
390
|
+
}
|
391
|
+
removeListener(event, handler) {
|
392
|
+
return __privateGet(this, _event).removeListener(event, handler);
|
393
|
+
}
|
394
|
+
getProvider() {
|
395
|
+
if (this.isReady()) {
|
396
|
+
return window.BitcoinProvider;
|
397
|
+
}
|
398
|
+
}
|
399
|
+
getNetwork() {
|
400
|
+
return __async(this, null, function* () {
|
401
|
+
if (!this.isReady()) {
|
402
|
+
throw new Error(`${this.metadata.name} is not install!`);
|
403
|
+
}
|
404
|
+
return __privateGet(this, _network) === "Mainnet" ? "livenet" : "testnet";
|
405
|
+
});
|
406
|
+
}
|
407
|
+
switchNetwork() {
|
408
|
+
return __async(this, null, function* () {
|
409
|
+
throw new Error("Unsupported");
|
410
|
+
});
|
411
|
+
}
|
412
|
+
sendBitcoin(toAddress, satoshis) {
|
413
|
+
return __async(this, null, function* () {
|
414
|
+
const provider = this.getProvider();
|
415
|
+
if (!provider) {
|
416
|
+
throw new Error(`${this.metadata.name} is not install!`);
|
417
|
+
}
|
418
|
+
const { sendBtcTransaction } = yield import("sats-connect");
|
419
|
+
const addresses = yield this.getAccounts();
|
420
|
+
if (addresses.length === 0) {
|
421
|
+
throw new Error(`${this.metadata.name} not connected!`);
|
422
|
+
}
|
423
|
+
const result = yield new Promise((resolve, reject) => {
|
424
|
+
const sendBtcOptions = {
|
425
|
+
payload: {
|
426
|
+
network: {
|
427
|
+
type: __privateGet(this, _network)
|
428
|
+
},
|
429
|
+
recipients: [
|
430
|
+
{
|
431
|
+
address: toAddress,
|
432
|
+
amountSats: BigInt(satoshis)
|
433
|
+
}
|
434
|
+
],
|
435
|
+
senderAddress: addresses[0]
|
436
|
+
},
|
437
|
+
onFinish: (response) => {
|
438
|
+
resolve(response);
|
439
|
+
},
|
440
|
+
onCancel: () => {
|
441
|
+
reject({
|
442
|
+
code: 4001,
|
443
|
+
message: "User rejected the request."
|
444
|
+
});
|
445
|
+
}
|
446
|
+
};
|
447
|
+
sendBtcTransaction(sendBtcOptions).catch((e) => reject(e));
|
448
|
+
});
|
449
|
+
return result;
|
450
|
+
});
|
451
|
+
}
|
452
|
+
disconnect() {
|
453
|
+
localStorage.removeItem("btc-connect-xverse-addresses-Mainnet");
|
454
|
+
localStorage.removeItem("btc-connect-xverse-addresses-Testnet");
|
455
|
+
}
|
456
|
+
};
|
457
|
+
_network = new WeakMap();
|
458
|
+
_event = new WeakMap();
|
459
|
+
|
460
|
+
// src/context/index.tsx
|
461
|
+
import { SmartAccount } from "@particle-network/aa";
|
462
|
+
import { chains as chains4 } from "@particle-network/chains";
|
463
|
+
import { walletEntryPlugin } from "@particle-network/wallet";
|
464
|
+
import { createContext, useCallback as useCallback7, useContext, useEffect as useEffect5, useMemo as useMemo5, useState as useState7 } from "react";
|
465
|
+
|
466
|
+
// src/components/connectModal/index.tsx
|
467
|
+
import { useEffect as useEffect3, useState as useState3 } from "react";
|
468
|
+
|
469
|
+
// src/hooks/useAccountContract.ts
|
470
|
+
var useAccountContract = () => {
|
471
|
+
const { accountContract, setAccountContract } = useConnectProvider();
|
472
|
+
return {
|
473
|
+
accountContract,
|
474
|
+
setAccountContract
|
475
|
+
};
|
476
|
+
};
|
477
|
+
|
478
|
+
// src/hooks/useAccounts.ts
|
479
|
+
var useAccounts = () => {
|
480
|
+
const { accounts } = useConnectProvider();
|
481
|
+
return { accounts };
|
482
|
+
};
|
483
|
+
|
484
|
+
// src/hooks/useBTCProvider.ts
|
485
|
+
import { useCallback } from "react";
|
486
|
+
var useBTCProvider = () => {
|
487
|
+
const { connector, provider, accounts, getPublicKey, signMessage, getNetwork, switchNetwork, sendBitcoin } = useConnectProvider();
|
488
|
+
const sendInscription = useCallback(
|
489
|
+
(address, inscriptionId, options) => __async(void 0, null, function* () {
|
490
|
+
if (!connector) {
|
491
|
+
throw new Error("Wallet not connected!");
|
492
|
+
}
|
493
|
+
const result = yield connector.sendInscription(address, inscriptionId, options);
|
494
|
+
return result;
|
495
|
+
}),
|
496
|
+
[connector]
|
497
|
+
);
|
498
|
+
return { provider, accounts, getPublicKey, signMessage, getNetwork, switchNetwork, sendBitcoin, sendInscription };
|
499
|
+
};
|
500
|
+
|
501
|
+
// src/hooks/useConnectModal.ts
|
502
|
+
var useConnectModal = () => {
|
503
|
+
const { openConnectModal, disconnect } = useConnectProvider();
|
504
|
+
return { openConnectModal, disconnect };
|
505
|
+
};
|
506
|
+
|
507
|
+
// src/hooks/useConnector.ts
|
508
|
+
import { useCallback as useCallback2 } from "react";
|
509
|
+
var useConnector = () => {
|
510
|
+
const { connectors, setConnectorId } = useConnectProvider();
|
511
|
+
const connect = useCallback2(
|
512
|
+
(connectorId) => __async(void 0, null, function* () {
|
513
|
+
const connector = connectors.find((item) => item.metadata.id === connectorId);
|
514
|
+
if (!connector) {
|
515
|
+
throw new Error(`connector id ${connectorId} not found`);
|
516
|
+
}
|
517
|
+
const accounts = yield connector.requestAccounts();
|
518
|
+
if (accounts.length > 0) {
|
519
|
+
localStorage.setItem("current-connector-id", connector.metadata.id);
|
520
|
+
setConnectorId(connector.metadata.id);
|
521
|
+
}
|
522
|
+
}),
|
523
|
+
[connectors, setConnectorId]
|
524
|
+
);
|
525
|
+
return { connectors, connect };
|
526
|
+
};
|
527
|
+
|
528
|
+
// src/hooks/useETHProvider.ts
|
529
|
+
import { intToHex } from "@ethereumjs/util";
|
530
|
+
import { useCallback as useCallback3, useEffect, useMemo, useState } from "react";
|
531
|
+
import { createWalletClient, custom } from "viem";
|
532
|
+
|
533
|
+
// src/evmSigner/provider.ts
|
534
|
+
var EthereumProvider = class {
|
535
|
+
constructor(sendUserOp, signer, account) {
|
536
|
+
this.sendUserOp = sendUserOp;
|
537
|
+
this.signer = signer;
|
538
|
+
this.account = account;
|
539
|
+
}
|
540
|
+
on(event, listener) {
|
541
|
+
var _a;
|
542
|
+
(_a = this.signer) == null ? void 0 : _a.on(event, listener);
|
543
|
+
return this;
|
544
|
+
}
|
545
|
+
once(event, listener) {
|
546
|
+
var _a;
|
547
|
+
(_a = this.signer) == null ? void 0 : _a.once(event, listener);
|
548
|
+
return this;
|
549
|
+
}
|
550
|
+
off(event, listener) {
|
551
|
+
var _a;
|
552
|
+
(_a = this.signer) == null ? void 0 : _a.off(event, listener);
|
553
|
+
return this;
|
554
|
+
}
|
555
|
+
removeListener(event, listener) {
|
556
|
+
var _a;
|
557
|
+
(_a = this.signer) == null ? void 0 : _a.removeListener(event, listener);
|
558
|
+
return this;
|
559
|
+
}
|
560
|
+
request(arg) {
|
561
|
+
return __async(this, null, function* () {
|
562
|
+
var _a, _b;
|
563
|
+
const method = arg.method;
|
564
|
+
if (!method) {
|
565
|
+
throw new Error("Method not found.");
|
566
|
+
}
|
567
|
+
if (method === "eth_accounts" || method === "eth_requestAccounts") {
|
568
|
+
return this.account ? [this.account] : [];
|
569
|
+
} else if (method === "eth_sendTransaction") {
|
570
|
+
const txData = (_a = arg.params) == null ? void 0 : _a[0];
|
571
|
+
const result = yield this.sendUserOp({ tx: txData });
|
572
|
+
return result;
|
573
|
+
}
|
574
|
+
return (_b = this.signer) == null ? void 0 : _b.request(arg);
|
575
|
+
});
|
576
|
+
}
|
577
|
+
};
|
578
|
+
|
579
|
+
// src/utils/eventUtils.ts
|
580
|
+
import { EventEmitter as EventEmitter2 } from "events";
|
581
|
+
var events = new EventEmitter2();
|
582
|
+
events.setMaxListeners(100);
|
583
|
+
var getPendingSignEventAccount = () => {
|
584
|
+
return events.listenerCount("sendUserOpResult" /* sendUserOpResult */) + events.listenerCount("personalSignResult" /* personalSignResult */) + events.listenerCount("signTypedDataResult" /* signTypedDataResult */);
|
585
|
+
};
|
586
|
+
var eventUtils_default = events;
|
587
|
+
|
588
|
+
// src/utils/txConfirmUtils.ts
|
589
|
+
var txConfirm = {
|
590
|
+
isNotRemind: () => {
|
591
|
+
if (typeof window === "undefined")
|
592
|
+
return false;
|
593
|
+
const value = localStorage.getItem("tx-confirm-modal-remind");
|
594
|
+
return value === "0";
|
595
|
+
},
|
596
|
+
setNotRemind: (notRemind) => {
|
597
|
+
if (typeof window === "undefined")
|
598
|
+
return;
|
599
|
+
if (notRemind) {
|
600
|
+
localStorage.setItem("tx-confirm-modal-remind", "0");
|
601
|
+
} else {
|
602
|
+
localStorage.removeItem("tx-confirm-modal-remind");
|
603
|
+
}
|
604
|
+
},
|
605
|
+
reset: () => {
|
606
|
+
if (typeof window === "undefined")
|
607
|
+
return;
|
608
|
+
localStorage.removeItem("tx-confirm-modal-remind");
|
609
|
+
}
|
610
|
+
};
|
611
|
+
var txConfirmUtils_default = txConfirm;
|
612
|
+
|
613
|
+
// src/evmSigner/walletClientProvider.ts
|
614
|
+
var WalletClientProvider = class {
|
615
|
+
constructor(provider) {
|
616
|
+
this.provider = provider;
|
617
|
+
}
|
618
|
+
on(event, listener) {
|
619
|
+
this.provider.on(event, listener);
|
620
|
+
return this;
|
621
|
+
}
|
622
|
+
once(event, listener) {
|
623
|
+
this.provider.once(event, listener);
|
624
|
+
return this;
|
625
|
+
}
|
626
|
+
off(event, listener) {
|
627
|
+
this.provider.off(event, listener);
|
628
|
+
return this;
|
629
|
+
}
|
630
|
+
removeListener(event, listener) {
|
631
|
+
this.provider.removeListener(event, listener);
|
632
|
+
return this;
|
633
|
+
}
|
634
|
+
request(arg) {
|
635
|
+
return __async(this, null, function* () {
|
636
|
+
const method = arg.method;
|
637
|
+
if (!method) {
|
638
|
+
throw new Error("Method not found.");
|
639
|
+
}
|
640
|
+
if (method === "personal_sign" /* personalSign */ || method.startsWith("eth_signTypedData" /* signTypedData */)) {
|
641
|
+
const showConfirmModal = !txConfirmUtils_default.isNotRemind();
|
642
|
+
if (showConfirmModal) {
|
643
|
+
if (getPendingSignEventAccount() > 0) {
|
644
|
+
throw new Error("Operation failed, there is a transaction being processed");
|
645
|
+
}
|
646
|
+
}
|
647
|
+
if (!showConfirmModal) {
|
648
|
+
return this.provider.request(arg);
|
649
|
+
}
|
650
|
+
}
|
651
|
+
if (method === "personal_sign" /* personalSign */) {
|
652
|
+
return new Promise((resolve, reject) => {
|
653
|
+
eventUtils_default.emit("personalSign" /* personalSign */, arg);
|
654
|
+
eventUtils_default.once("personalSignResult" /* personalSignResult */, ({ result, error }) => {
|
655
|
+
if (result) {
|
656
|
+
resolve(result);
|
657
|
+
} else {
|
658
|
+
reject(error);
|
659
|
+
}
|
660
|
+
});
|
661
|
+
});
|
662
|
+
} else if (method.startsWith("eth_signTypedData" /* signTypedData */)) {
|
663
|
+
return new Promise((resolve, reject) => {
|
664
|
+
eventUtils_default.emit("signTypedData" /* signTypedData */, arg);
|
665
|
+
eventUtils_default.once("signTypedDataResult" /* signTypedDataResult */, ({ result, error }) => {
|
666
|
+
if (result) {
|
667
|
+
resolve(result);
|
668
|
+
} else {
|
669
|
+
reject(error);
|
670
|
+
}
|
671
|
+
});
|
672
|
+
});
|
673
|
+
}
|
674
|
+
return this.provider.request(arg);
|
675
|
+
});
|
676
|
+
}
|
677
|
+
};
|
678
|
+
|
679
|
+
// src/hooks/useETHProvider.ts
|
680
|
+
var useETHProvider = () => {
|
681
|
+
const { evmAccount, smartAccount, getSmartAccountInfo } = useConnectProvider();
|
682
|
+
const [chainId, setChainId] = useState();
|
683
|
+
useEffect(() => {
|
684
|
+
if (smartAccount) {
|
685
|
+
const chainId2 = smartAccount.provider.chainId;
|
686
|
+
setChainId(chainId2);
|
687
|
+
const onChangeChange = (id) => {
|
688
|
+
setChainId(Number(id));
|
689
|
+
};
|
690
|
+
smartAccount.provider.on("chainChanged", onChangeChange);
|
691
|
+
return () => {
|
692
|
+
smartAccount.provider.removeListener("chainChanged", onChangeChange);
|
693
|
+
};
|
694
|
+
}
|
695
|
+
}, [smartAccount]);
|
696
|
+
const switchChain = useCallback3(
|
697
|
+
(chainId2) => __async(void 0, null, function* () {
|
698
|
+
if (smartAccount == null ? void 0 : smartAccount.provider) {
|
699
|
+
yield smartAccount.provider.request({
|
700
|
+
method: "wallet_switchEthereumChain",
|
701
|
+
params: [
|
702
|
+
{
|
703
|
+
chainId: intToHex(chainId2)
|
704
|
+
}
|
705
|
+
]
|
706
|
+
});
|
707
|
+
}
|
708
|
+
}),
|
709
|
+
[smartAccount == null ? void 0 : smartAccount.provider]
|
710
|
+
);
|
711
|
+
const getFeeQuotes = useCallback3(
|
712
|
+
(tx) => __async(void 0, null, function* () {
|
713
|
+
if (!smartAccount) {
|
714
|
+
throw new Error("The smart account is not initialized.");
|
715
|
+
}
|
716
|
+
return smartAccount.getFeeQuotes(tx);
|
717
|
+
}),
|
718
|
+
[smartAccount]
|
719
|
+
);
|
720
|
+
const buildUserOp = useCallback3(
|
721
|
+
(_0) => __async(void 0, [_0], function* ({ tx, feeQuote, tokenPaymasterAddress }) {
|
722
|
+
if (!smartAccount) {
|
723
|
+
throw new Error("The smart account is not initialized.");
|
724
|
+
}
|
725
|
+
const result = yield smartAccount.buildUserOperation({ tx, feeQuote, tokenPaymasterAddress });
|
726
|
+
return result;
|
727
|
+
}),
|
728
|
+
[smartAccount]
|
729
|
+
);
|
730
|
+
const sendUserOp = useCallback3(
|
731
|
+
(params, forceHideConfirmModal) => __async(void 0, null, function* () {
|
732
|
+
if (!smartAccount) {
|
733
|
+
throw new Error("The smart account is not initialized.");
|
734
|
+
}
|
735
|
+
const showConfirmModal = !forceHideConfirmModal && !txConfirmUtils_default.isNotRemind();
|
736
|
+
if (showConfirmModal) {
|
737
|
+
if (getPendingSignEventAccount() > 0) {
|
738
|
+
throw new Error("Operation failed, there is a transaction being processed");
|
739
|
+
}
|
740
|
+
}
|
741
|
+
let userOpBundle;
|
742
|
+
if (Object.prototype.hasOwnProperty.call(params, "userOpHash") && Object.prototype.hasOwnProperty.call(params, "userOp")) {
|
743
|
+
const { userOpHash, userOp } = params;
|
744
|
+
if (userOpHash && userOp) {
|
745
|
+
userOpBundle = { userOpHash, userOp };
|
746
|
+
}
|
747
|
+
}
|
748
|
+
if (!userOpBundle) {
|
749
|
+
const { tx, feeQuote, tokenPaymasterAddress } = params;
|
750
|
+
userOpBundle = yield buildUserOp({ tx, feeQuote, tokenPaymasterAddress });
|
751
|
+
}
|
752
|
+
if (!showConfirmModal) {
|
753
|
+
return smartAccount.sendUserOperation(userOpBundle);
|
754
|
+
}
|
755
|
+
return new Promise((resolve, reject) => {
|
756
|
+
eventUtils_default.emit("sendUserOp" /* sendUserOp */, userOpBundle);
|
757
|
+
eventUtils_default.once("sendUserOpResult" /* sendUserOpResult */, ({ result, error }) => {
|
758
|
+
if (result) {
|
759
|
+
resolve(result);
|
760
|
+
} else {
|
761
|
+
reject(error);
|
762
|
+
}
|
763
|
+
});
|
764
|
+
});
|
765
|
+
}),
|
766
|
+
[smartAccount, buildUserOp]
|
767
|
+
);
|
768
|
+
const publicClient = useMemo(() => {
|
769
|
+
if (!smartAccount || !chainId) {
|
770
|
+
return void 0;
|
771
|
+
}
|
772
|
+
return (smartAccount == null ? void 0 : smartAccount.provider).publicClient;
|
773
|
+
}, [smartAccount, chainId]);
|
774
|
+
const provider = useMemo(() => {
|
775
|
+
const ethereumProvider = new EthereumProvider(sendUserOp, smartAccount == null ? void 0 : smartAccount.provider, evmAccount);
|
776
|
+
return ethereumProvider;
|
777
|
+
}, [evmAccount, sendUserOp, smartAccount == null ? void 0 : smartAccount.provider]);
|
778
|
+
const walletClient = useMemo(() => {
|
779
|
+
return createWalletClient({
|
780
|
+
transport: custom(new WalletClientProvider(provider))
|
781
|
+
});
|
782
|
+
}, [provider]);
|
783
|
+
return {
|
784
|
+
provider,
|
785
|
+
evmAccount,
|
786
|
+
account: evmAccount,
|
787
|
+
getSmartAccountInfo,
|
788
|
+
switchChain,
|
789
|
+
chainId,
|
790
|
+
getFeeQuotes,
|
791
|
+
buildUserOp,
|
792
|
+
sendUserOp,
|
793
|
+
publicClient,
|
794
|
+
walletClient
|
795
|
+
};
|
796
|
+
};
|
797
|
+
|
798
|
+
// src/icons/back.svg
|
799
|
+
var back_default = "";
|
800
|
+
|
801
|
+
// src/icons/close.svg
|
802
|
+
var close_default = "";
|
803
|
+
|
804
|
+
// src/icons/retry.svg
|
805
|
+
var retry_default = "";
|
806
|
+
|
807
|
+
// esbuild-scss-modules-plugin:./spinner.module.scss
|
808
|
+
var digest = "906d42389ecad5c2ab92642c8e0775ea667c413b069684ce9d01199562f2d0be";
|
809
|
+
var classes = { "loader": "_loader_g0am3_1", "rotate": "_rotate_g0am3_1", "prixClipFix": "_prixClipFix_g0am3_1" };
|
810
|
+
var css = `._loader_g0am3_1{animation:_rotate_g0am3_1 1s linear infinite;border-radius:50%;height:20px;position:relative;width:20px}._loader_g0am3_1:before{animation:_prixClipFix_g0am3_1 2s linear infinite;border:2px solid #000;border-radius:50%;box-sizing:border-box;content:"";inset:0;position:absolute}@keyframes _rotate_g0am3_1{to{transform:rotate(1turn)}}@keyframes _prixClipFix_g0am3_1{0%{clip-path:polygon(50% 50%,0 0,0 0,0 0,0 0,0 0)}25%{clip-path:polygon(50% 50%,0 0,100% 0,100% 0,100% 0,100% 0)}50%{clip-path:polygon(50% 50%,0 0,100% 0,100% 100%,100% 100%,100% 100%)}75%{clip-path:polygon(50% 50%,0 0,100% 0,100% 100%,0 100%,0 100%)}to{clip-path:polygon(50% 50%,0 0,100% 0,100% 100%,0 100%,0 0)}}`;
|
811
|
+
(function() {
|
812
|
+
if (typeof document !== "undefined" && !document.getElementById(digest)) {
|
813
|
+
var ele = document.createElement("style");
|
814
|
+
ele.id = digest;
|
815
|
+
ele.textContent = css;
|
816
|
+
document.head.appendChild(ele);
|
817
|
+
}
|
818
|
+
})();
|
819
|
+
var spinner_module_default = classes;
|
820
|
+
|
821
|
+
// src/components/spinner/index.tsx
|
822
|
+
import { jsx } from "react/jsx-runtime";
|
823
|
+
var Spinner = ({ className, style }) => {
|
824
|
+
return /* @__PURE__ */ jsx("span", { className: spinner_module_default.loader + (className ? ` ${className}` : ""), style });
|
825
|
+
};
|
826
|
+
var spinner_default = Spinner;
|
827
|
+
|
828
|
+
// esbuild-scss-modules-plugin:./button.module.scss
|
829
|
+
var digest2 = "424d614dbc2763d7cad7ca35c00bd255c6ed55da308a1f3018594201a47127bf";
|
830
|
+
var classes2 = { "btn": "_btn_ofd87_1" };
|
831
|
+
var css2 = `._btn_ofd87_1{align-items:center;background:#fff;border-radius:8px;color:#000;display:flex;flex-direction:row;font-size:16px;gap:16px;justify-content:center;padding:6px 24px;position:relative}._btn_ofd87_1:hover{opacity:.85}._btn_ofd87_1:disabled{background:hsla(0,0%,100%,.2);color:hsla(0,0%,100%,.639);cursor:not-allowed;opacity:1}`;
|
832
|
+
(function() {
|
833
|
+
if (typeof document !== "undefined" && !document.getElementById(digest2)) {
|
834
|
+
var ele = document.createElement("style");
|
835
|
+
ele.id = digest2;
|
836
|
+
ele.textContent = css2;
|
837
|
+
document.head.appendChild(ele);
|
838
|
+
}
|
839
|
+
})();
|
840
|
+
var button_module_default = classes2;
|
841
|
+
|
842
|
+
// src/components/button/index.tsx
|
843
|
+
import { jsx as jsx2, jsxs } from "react/jsx-runtime";
|
844
|
+
var Button = ({
|
845
|
+
children,
|
846
|
+
isLoading,
|
847
|
+
isDisabled,
|
848
|
+
onClick,
|
849
|
+
className,
|
850
|
+
style
|
851
|
+
}) => {
|
852
|
+
return /* @__PURE__ */ jsxs(
|
853
|
+
"button",
|
854
|
+
{
|
855
|
+
className: button_module_default.btn + (className ? ` ${className}` : ""),
|
856
|
+
onClick: isLoading || isDisabled ? void 0 : onClick,
|
857
|
+
disabled: isDisabled,
|
858
|
+
style,
|
859
|
+
children: [
|
860
|
+
isLoading && !isDisabled && /* @__PURE__ */ jsx2(spinner_default, {}),
|
861
|
+
children
|
862
|
+
]
|
863
|
+
}
|
864
|
+
);
|
865
|
+
};
|
866
|
+
var button_default = Button;
|
867
|
+
|
868
|
+
// src/components/modal/index.tsx
|
869
|
+
import { useEffect as useEffect2, useMemo as useMemo2, useState as useState2 } from "react";
|
870
|
+
import { createPortal } from "react-dom";
|
871
|
+
import { RemoveScroll } from "react-remove-scroll";
|
872
|
+
|
873
|
+
// esbuild-scss-modules-plugin:./modal.module.scss
|
874
|
+
var digest3 = "65eada90924218eba4e72a5f00291c3cb69387ecce1351e454cdefd066d4bcff";
|
875
|
+
var classes3 = { "container": "_container_smzpm_1", "modal": "_modal_smzpm_18" };
|
876
|
+
var css3 = `._container_smzpm_1{align-items:center;backdrop-filter:blur(12px);background:rgba(0,0,0,.502);bottom:0;color:#fff;display:flex;height:100%;justify-content:center;left:0;overflow:hidden;position:fixed;right:0;top:0;width:100%;z-index:100000}._container_smzpm_1 ._modal_smzpm_18{align-items:center;background-color:#171a1f;border-radius:16px;display:flex;flex-direction:column;font-size:14px;height:auto;margin:16px;max-height:80%;max-width:100%;overflow:auto;padding:24px;position:relative;width:380px}`;
|
877
|
+
(function() {
|
878
|
+
if (typeof document !== "undefined" && !document.getElementById(digest3)) {
|
879
|
+
var ele = document.createElement("style");
|
880
|
+
ele.id = digest3;
|
881
|
+
ele.textContent = css3;
|
882
|
+
document.head.appendChild(ele);
|
883
|
+
}
|
884
|
+
})();
|
885
|
+
var modal_module_default = classes3;
|
886
|
+
|
887
|
+
// src/components/modal/index.tsx
|
888
|
+
import { Fragment, jsx as jsx3 } from "react/jsx-runtime";
|
889
|
+
var stopPropagation = (event) => event.stopPropagation();
|
890
|
+
var Modal = ({ open, onClose, children, isDismissable = true, contentStyle, contentClassName }) => {
|
891
|
+
const handleBackdropClick = useMemo2(() => isDismissable ? onClose : void 0, [onClose, isDismissable]);
|
892
|
+
useEffect2(() => {
|
893
|
+
if (isDismissable) {
|
894
|
+
const handleEscape = (event) => open && event.key === "Escape" && onClose();
|
895
|
+
document.addEventListener("keydown", handleEscape);
|
896
|
+
return () => document.removeEventListener("keydown", handleEscape);
|
897
|
+
}
|
898
|
+
}, [open, onClose, isDismissable]);
|
899
|
+
const [bodyScrollable, setBodyScrollable] = useState2(true);
|
900
|
+
useEffect2(() => {
|
901
|
+
setBodyScrollable(getComputedStyle(window.document.body).overflow !== "hidden");
|
902
|
+
}, []);
|
903
|
+
return /* @__PURE__ */ jsx3(Fragment, { children: open ? createPortal(
|
904
|
+
/* @__PURE__ */ jsx3(RemoveScroll, { enabled: bodyScrollable, children: /* @__PURE__ */ jsx3("div", { className: modal_module_default.container, onClick: handleBackdropClick, children: /* @__PURE__ */ jsx3(
|
905
|
+
"div",
|
906
|
+
{
|
907
|
+
className: modal_module_default.modal + (contentClassName ? ` ${contentClassName}` : ""),
|
908
|
+
style: contentStyle,
|
909
|
+
onClick: stopPropagation,
|
910
|
+
children
|
911
|
+
}
|
912
|
+
) }) }),
|
913
|
+
document.body
|
914
|
+
) : null });
|
915
|
+
};
|
916
|
+
var modal_default = Modal;
|
917
|
+
|
918
|
+
// esbuild-scss-modules-plugin:./connect.module.scss
|
919
|
+
var digest4 = "c7bbc091f1227154742a5bd0d55a3df29eb913eb0ad4cafc7ab236b574002f65";
|
920
|
+
var classes4 = { "connectModal": "_connectModal_1kqtj_1", "title": "_title_1kqtj_4", "closeBtn": "_closeBtn_1kqtj_9", "backBtn": "_backBtn_1kqtj_15", "walletItem": "_walletItem_1kqtj_21", "walletIcon": "_walletIcon_1kqtj_33", "walletName": "_walletName_1kqtj_38", "connecting": "_connecting_1kqtj_43", "connectingIconContainer": "_connectingIconContainer_1kqtj_51", "retryContainer": "_retryContainer_1kqtj_54", "retryIcon": "_retryIcon_1kqtj_63", "connectingIcon": "_connectingIcon_1kqtj_51", "connection": "_connection_1kqtj_72", "acceptRequest": "_acceptRequest_1kqtj_76", "btnDownload": "_btnDownload_1kqtj_83" };
|
921
|
+
var css4 = `._connectModal_1kqtj_1{gap:12px}._connectModal_1kqtj_1 ._title_1kqtj_4{font-size:18px;font-weight:700;margin-bottom:4px}._connectModal_1kqtj_1 ._closeBtn_1kqtj_9{cursor:pointer;position:absolute;right:16px;top:16px}._connectModal_1kqtj_1 ._backBtn_1kqtj_15{cursor:pointer;left:16px;position:absolute;top:16px}._connectModal_1kqtj_1 ._walletItem_1kqtj_21{border:1px solid #3a3a3a;border-radius:8px;box-sizing:border-box;cursor:pointer;display:flex;padding:8px;width:100%}._connectModal_1kqtj_1 ._walletItem_1kqtj_21:hover{background:hsla(0,0%,100%,.05)}._connectModal_1kqtj_1 ._walletItem_1kqtj_21 ._walletIcon_1kqtj_33{border-radius:4px;height:42px;width:42px}._connectModal_1kqtj_1 ._walletItem_1kqtj_21 ._walletName_1kqtj_38{flex-grow:1;line-height:42px;text-align:center}._connectModal_1kqtj_1 ._connecting_1kqtj_43{align-items:center;display:flex;flex-direction:column;height:204px;justify-content:center;width:100%}._connectModal_1kqtj_1 ._connecting_1kqtj_43 ._connectingIconContainer_1kqtj_51{position:relative}._connectModal_1kqtj_1 ._connecting_1kqtj_43 ._connectingIconContainer_1kqtj_51 ._retryContainer_1kqtj_54{background:#4b5563;border-radius:50%;bottom:-12px;cursor:pointer;padding:4px;position:absolute;right:-12px}._connectModal_1kqtj_1 ._connecting_1kqtj_43 ._connectingIconContainer_1kqtj_51 ._retryContainer_1kqtj_54 ._retryIcon_1kqtj_63{height:24px;width:24px}._connectModal_1kqtj_1 ._connecting_1kqtj_43 ._connectingIcon_1kqtj_51{border-radius:4px;height:60px;width:60px}._connectModal_1kqtj_1 ._connecting_1kqtj_43 ._connection_1kqtj_72{font-size:18px;margin-top:20px}._connectModal_1kqtj_1 ._connecting_1kqtj_43 ._acceptRequest_1kqtj_76{color:hsla(0,0%,100%,.4);font-size:14px;margin-top:6px;text-align:center;white-space:pre-wrap}._connectModal_1kqtj_1 ._connecting_1kqtj_43 ._btnDownload_1kqtj_83{margin-top:20px}`;
|
922
|
+
(function() {
|
923
|
+
if (typeof document !== "undefined" && !document.getElementById(digest4)) {
|
924
|
+
var ele = document.createElement("style");
|
925
|
+
ele.id = digest4;
|
926
|
+
ele.textContent = css4;
|
927
|
+
document.head.appendChild(ele);
|
928
|
+
}
|
929
|
+
})();
|
930
|
+
var connect_module_default = classes4;
|
931
|
+
|
932
|
+
// src/components/connectModal/index.tsx
|
933
|
+
import { Fragment as Fragment2, jsx as jsx4, jsxs as jsxs2 } from "react/jsx-runtime";
|
934
|
+
var ConnectModal = ({ open, onClose }) => {
|
935
|
+
const [backVisible, setBackVisible] = useState3(false);
|
936
|
+
const [retryVisible, setRetryVisible] = useState3(false);
|
937
|
+
const [walletReady, setWalletReady] = useState3(true);
|
938
|
+
const [selectConnector, setSelectConnector] = useState3();
|
939
|
+
const { closeConnectModal } = useConnectProvider();
|
940
|
+
const { connect, connectors } = useConnector();
|
941
|
+
useEffect3(() => {
|
942
|
+
if (!open) {
|
943
|
+
setBackVisible(false);
|
944
|
+
setRetryVisible(false);
|
945
|
+
setWalletReady(true);
|
946
|
+
setSelectConnector(void 0);
|
947
|
+
}
|
948
|
+
}, [open]);
|
949
|
+
const onConnect = (connector) => __async(void 0, null, function* () {
|
950
|
+
setBackVisible(true);
|
951
|
+
setSelectConnector(connector);
|
952
|
+
if (connector.isReady()) {
|
953
|
+
try {
|
954
|
+
yield connect(connector.metadata.id);
|
955
|
+
closeConnectModal();
|
956
|
+
} catch (error) {
|
957
|
+
if (error.code === 4001) {
|
958
|
+
setRetryVisible(true);
|
959
|
+
}
|
960
|
+
}
|
961
|
+
} else {
|
962
|
+
setWalletReady(false);
|
963
|
+
}
|
964
|
+
});
|
965
|
+
const onBack = () => {
|
966
|
+
setBackVisible(false);
|
967
|
+
setRetryVisible(false);
|
968
|
+
setWalletReady(true);
|
969
|
+
setSelectConnector(void 0);
|
970
|
+
};
|
971
|
+
const onRetry = () => {
|
972
|
+
setRetryVisible(false);
|
973
|
+
if (selectConnector) {
|
974
|
+
onConnect(selectConnector);
|
975
|
+
}
|
976
|
+
};
|
977
|
+
return /* @__PURE__ */ jsxs2(modal_default, { open, onClose, isDismissable: false, contentClassName: connect_module_default.connectModal, children: [
|
978
|
+
/* @__PURE__ */ jsx4("div", { className: connect_module_default.title, children: (selectConnector == null ? void 0 : selectConnector.metadata.name) || "Choose Wallet" }),
|
979
|
+
/* @__PURE__ */ jsx4("img", { className: connect_module_default.closeBtn, src: close_default, onClick: onClose }),
|
980
|
+
backVisible && /* @__PURE__ */ jsx4("img", { className: connect_module_default.backBtn, src: back_default, onClick: onBack }),
|
981
|
+
!backVisible && connectors.map((connector) => {
|
982
|
+
return /* @__PURE__ */ jsxs2("div", { className: connect_module_default.walletItem, onClick: () => onConnect(connector), children: [
|
983
|
+
/* @__PURE__ */ jsx4("img", { className: connect_module_default.walletIcon, src: connector.metadata.icon }),
|
984
|
+
/* @__PURE__ */ jsx4("div", { className: connect_module_default.walletName, children: connector.metadata.name })
|
985
|
+
] }, connector.metadata.id);
|
986
|
+
}),
|
987
|
+
backVisible && selectConnector && /* @__PURE__ */ jsxs2("div", { className: connect_module_default.connecting, children: [
|
988
|
+
/* @__PURE__ */ jsxs2("div", { className: connect_module_default.connectingIconContainer, children: [
|
989
|
+
/* @__PURE__ */ jsx4("img", { className: connect_module_default.connectingIcon, src: selectConnector.metadata.icon }),
|
990
|
+
retryVisible && /* @__PURE__ */ jsx4("div", { className: connect_module_default.retryContainer, onClick: onRetry, children: /* @__PURE__ */ jsx4("img", { className: connect_module_default.retryIcon, src: retry_default }) })
|
991
|
+
] }),
|
992
|
+
walletReady ? /* @__PURE__ */ jsxs2(Fragment2, { children: [
|
993
|
+
/* @__PURE__ */ jsx4("div", { className: connect_module_default.connection, children: retryVisible ? "Request Cancelled" : "Requesting Connection" }),
|
994
|
+
/* @__PURE__ */ jsx4("div", { className: connect_module_default.acceptRequest, children: retryVisible ? "You cancelled the request.\nClick above to try again." : "Accept the request through your wallet to connect to this app." })
|
995
|
+
] }) : /* @__PURE__ */ jsxs2(Fragment2, { children: [
|
996
|
+
/* @__PURE__ */ jsx4("div", { className: connect_module_default.connection, children: "Wallet Not Installed." }),
|
997
|
+
/* @__PURE__ */ jsx4(
|
998
|
+
button_default,
|
999
|
+
{
|
1000
|
+
className: connect_module_default.btnDownload,
|
1001
|
+
onClick: () => {
|
1002
|
+
window.open(selectConnector == null ? void 0 : selectConnector.metadata.downloadUrl, "_blank");
|
1003
|
+
},
|
1004
|
+
children: "Get"
|
1005
|
+
}
|
1006
|
+
)
|
1007
|
+
] })
|
1008
|
+
] })
|
1009
|
+
] });
|
1010
|
+
};
|
1011
|
+
var connectModal_default = ConnectModal;
|
1012
|
+
|
1013
|
+
// src/components/signModal/index.tsx
|
1014
|
+
import { chains as chains2 } from "@particle-network/chains";
|
1015
|
+
import { useCallback as useCallback5, useEffect as useEffect4, useMemo as useMemo4, useState as useState5 } from "react";
|
1016
|
+
import { formatEther, hexToString } from "viem";
|
1017
|
+
|
1018
|
+
// src/icons/check_box.svg
|
1019
|
+
var check_box_default = "";
|
1020
|
+
|
1021
|
+
// src/icons/check_box_blank.svg
|
1022
|
+
var check_box_blank_default = "";
|
1023
|
+
|
1024
|
+
// src/icons/copy.svg
|
1025
|
+
var copy_default = "";
|
1026
|
+
|
1027
|
+
// src/utils/index.ts
|
1028
|
+
function shortString(str) {
|
1029
|
+
if (Array.isArray(str)) {
|
1030
|
+
str = "[" + str.toString() + "]";
|
1031
|
+
}
|
1032
|
+
if (str) {
|
1033
|
+
if (typeof str.toString === "function") {
|
1034
|
+
str = str.toString();
|
1035
|
+
}
|
1036
|
+
if (str.length <= 10) {
|
1037
|
+
return str;
|
1038
|
+
}
|
1039
|
+
return `${str.slice(0, 5)}...${str.slice(str.length - 5, str.length)}`;
|
1040
|
+
}
|
1041
|
+
return "";
|
1042
|
+
}
|
1043
|
+
function copyToClipboard(text) {
|
1044
|
+
return __async(this, null, function* () {
|
1045
|
+
const clipboardCopy = () => __async(this, null, function* () {
|
1046
|
+
if (navigator.clipboard) {
|
1047
|
+
return navigator.clipboard.writeText(text);
|
1048
|
+
} else {
|
1049
|
+
const textarea = document.createElement("textarea");
|
1050
|
+
textarea.value = text;
|
1051
|
+
textarea.setAttribute("readonly", "");
|
1052
|
+
textarea.style.position = "absolute";
|
1053
|
+
textarea.style.left = "-9999px";
|
1054
|
+
document.body.appendChild(textarea);
|
1055
|
+
textarea.select();
|
1056
|
+
const result = document.execCommand("copy");
|
1057
|
+
document.body.removeChild(textarea);
|
1058
|
+
if (!result) {
|
1059
|
+
throw new Error("Copy to clipboard failed");
|
1060
|
+
}
|
1061
|
+
}
|
1062
|
+
});
|
1063
|
+
return new Promise((resolve, reject) => {
|
1064
|
+
clipboardCopy().then(resolve).catch(reject);
|
1065
|
+
});
|
1066
|
+
});
|
1067
|
+
}
|
1068
|
+
var defaultTokenIcon = "https://static.particle.network/token-list/defaultToken/default.png";
|
1069
|
+
var ipfsToSrc = (ipfs) => {
|
1070
|
+
if (!ipfs || !ipfs.startsWith("ipfs://")) {
|
1071
|
+
return ipfs || "";
|
1072
|
+
}
|
1073
|
+
return `https://ipfs.particle.network/${encodeURI(ipfs.slice(7))}`;
|
1074
|
+
};
|
1075
|
+
var checkBTCVersion = (accountContracts, accountContractKey, version) => {
|
1076
|
+
if (!accountContracts[accountContractKey]) {
|
1077
|
+
return false;
|
1078
|
+
}
|
1079
|
+
return accountContracts[accountContractKey].some((item) => item.version === version);
|
1080
|
+
};
|
1081
|
+
|
1082
|
+
// src/utils/ethereumUtils.ts
|
1083
|
+
import { bytesToHex, publicToAddress, toBytes, toChecksumAddress, toRpcSig } from "@ethereumjs/util";
|
1084
|
+
import bitcore from "bitcore-lib";
|
1085
|
+
var pubKeyToEVMAddress = (pubKey) => {
|
1086
|
+
const address = toChecksumAddress(bytesToHex(publicToAddress(toBytes(`0x${pubKey}`), true)));
|
1087
|
+
return address;
|
1088
|
+
};
|
1089
|
+
var convertSignature = (signature) => {
|
1090
|
+
const sig = bitcore.crypto.Signature.fromCompact(Buffer.from(signature, "base64"));
|
1091
|
+
const v = BigInt(sig.i + 27);
|
1092
|
+
const evmSig = toRpcSig(v, sig.r.toBuffer(), sig.s.toBuffer());
|
1093
|
+
return evmSig;
|
1094
|
+
};
|
1095
|
+
function caculateNativeFee(userOp) {
|
1096
|
+
return (BigInt(userOp.callGasLimit) + BigInt(userOp.verificationGasLimit) + BigInt(userOp.preVerificationGas)) * BigInt(userOp.maxFeePerGas);
|
1097
|
+
}
|
1098
|
+
var getBTCAAAddress = (smartAccount, btcAddress, name, version) => __async(void 0, null, function* () {
|
1099
|
+
var _a;
|
1100
|
+
const addresses = yield smartAccount.provider.request({ method: "eth_accounts" });
|
1101
|
+
const owner = addresses[0];
|
1102
|
+
const localKey = `particle_${name}_${version}_${owner}`;
|
1103
|
+
if (typeof window !== "undefined" && localStorage) {
|
1104
|
+
const localAA = localStorage.getItem(localKey);
|
1105
|
+
if (localAA) {
|
1106
|
+
return localAA;
|
1107
|
+
}
|
1108
|
+
}
|
1109
|
+
const btcPublicKey = yield smartAccount.provider.getPublicKey();
|
1110
|
+
const accountInfo = yield smartAccount.sendRpc({
|
1111
|
+
method: "particle_aa_getBTCAccount",
|
1112
|
+
params: [
|
1113
|
+
{
|
1114
|
+
name,
|
1115
|
+
version,
|
1116
|
+
btcPublicKey,
|
1117
|
+
btcAddress
|
1118
|
+
}
|
1119
|
+
]
|
1120
|
+
});
|
1121
|
+
const address = (_a = accountInfo == null ? void 0 : accountInfo[0]) == null ? void 0 : _a.smartAccountAddress;
|
1122
|
+
if (typeof window !== "undefined" && localStorage && address) {
|
1123
|
+
localStorage.setItem(localKey, address);
|
1124
|
+
}
|
1125
|
+
return address;
|
1126
|
+
});
|
1127
|
+
var getBTCAccountInfo = (smartAccount, btcAddress, name, version) => __async(void 0, null, function* () {
|
1128
|
+
const btcPublicKey = yield smartAccount.provider.getPublicKey();
|
1129
|
+
const [accountInfo] = yield smartAccount.sendRpc({
|
1130
|
+
method: "particle_aa_getBTCAccount",
|
1131
|
+
params: [
|
1132
|
+
{
|
1133
|
+
name,
|
1134
|
+
version,
|
1135
|
+
btcPublicKey,
|
1136
|
+
btcAddress
|
1137
|
+
}
|
1138
|
+
]
|
1139
|
+
});
|
1140
|
+
const address = accountInfo.smartAccountAddress;
|
1141
|
+
const addresses = yield smartAccount.provider.request({ method: "eth_accounts" });
|
1142
|
+
const owner = addresses[0];
|
1143
|
+
const localKey = `particle_${name}_${version}_${owner}`;
|
1144
|
+
if (typeof window !== "undefined" && localStorage && address) {
|
1145
|
+
localStorage.setItem(localKey, address);
|
1146
|
+
}
|
1147
|
+
return accountInfo;
|
1148
|
+
});
|
1149
|
+
|
1150
|
+
// src/components/copyText/index.tsx
|
1151
|
+
import { useState as useState4 } from "react";
|
1152
|
+
|
1153
|
+
// esbuild-scss-modules-plugin:./copyText.module.scss
|
1154
|
+
var digest5 = "d6fbb5df7ed6ec51d41f665ca768306181bb1e7d7c1cef8eed9bd4230368d7bb";
|
1155
|
+
var classes5 = { "copyText": "_copyText_smolu_1", "copied": "_copied_smolu_9" };
|
1156
|
+
var css5 = `._copyText_smolu_1{cursor:pointer;text-decoration-line:underline}._copyText_smolu_1:hover{opacity:.75}._copied_smolu_9{color:#a855f7;cursor:none;text-decoration-line:none}._copied_smolu_9:hover{opacity:1}`;
|
1157
|
+
(function() {
|
1158
|
+
if (typeof document !== "undefined" && !document.getElementById(digest5)) {
|
1159
|
+
var ele = document.createElement("style");
|
1160
|
+
ele.id = digest5;
|
1161
|
+
ele.textContent = css5;
|
1162
|
+
document.head.appendChild(ele);
|
1163
|
+
}
|
1164
|
+
})();
|
1165
|
+
var copyText_module_default = classes5;
|
1166
|
+
|
1167
|
+
// src/components/copyText/index.tsx
|
1168
|
+
import { jsx as jsx5 } from "react/jsx-runtime";
|
1169
|
+
function CopyText({ children, value, className, style }) {
|
1170
|
+
const [copied, setCopied] = useState4();
|
1171
|
+
const handleClick = () => __async(this, null, function* () {
|
1172
|
+
if (copied) {
|
1173
|
+
return;
|
1174
|
+
}
|
1175
|
+
try {
|
1176
|
+
if (value) {
|
1177
|
+
yield copyToClipboard(value);
|
1178
|
+
} else if (typeof children === "string" || typeof children === "number" || typeof children === "boolean") {
|
1179
|
+
yield copyToClipboard(children.toString());
|
1180
|
+
} else {
|
1181
|
+
throw new Error("please set copy value");
|
1182
|
+
}
|
1183
|
+
setCopied(true);
|
1184
|
+
setTimeout(() => setCopied(false), 1e3);
|
1185
|
+
} catch (error) {
|
1186
|
+
}
|
1187
|
+
});
|
1188
|
+
return /* @__PURE__ */ jsx5(
|
1189
|
+
"div",
|
1190
|
+
{
|
1191
|
+
className: copyText_module_default.copyText + (className ? ` ${className}` : "") + (copied ? ` ${copyText_module_default.copied}` : ""),
|
1192
|
+
onClick: handleClick,
|
1193
|
+
style,
|
1194
|
+
children: copied ? "Copied" : children
|
1195
|
+
}
|
1196
|
+
);
|
1197
|
+
}
|
1198
|
+
|
1199
|
+
// src/components/transactionDetails/index.tsx
|
1200
|
+
import { chains } from "@particle-network/chains";
|
1201
|
+
import { useCallback as useCallback4, useMemo as useMemo3 } from "react";
|
1202
|
+
import { formatUnits } from "viem";
|
1203
|
+
|
1204
|
+
// src/icons/unverified.svg
|
1205
|
+
var unverified_default = "";
|
1206
|
+
|
1207
|
+
// src/icons/verified.svg
|
1208
|
+
var verified_default = "";
|
1209
|
+
|
1210
|
+
// esbuild-scss-modules-plugin:./tooltip.module.scss
|
1211
|
+
var digest6 = "ee15dc27fcfd209601159e7f0e0063ff4e7a886b7b892c1600a911372b82a0b1";
|
1212
|
+
var classes6 = { "tipContainer": "_tipContainer_ufud7_1", "tipContent": "_tipContent_ufud7_5" };
|
1213
|
+
var css6 = `._tipContainer_ufud7_1{overflow:visible;position:relative}._tipContainer_ufud7_1 ._tipContent_ufud7_5{background:#3f3f46;border-radius:8px;bottom:100%;color:#fff;font-size:11px;left:-100%;opacity:0;padding:3px 6px;position:absolute;transition:opacity .5s;visibility:hidden;white-space:nowrap;z-index:1}._tipContainer_ufud7_1:hover ._tipContent_ufud7_5{opacity:1;visibility:visible}`;
|
1214
|
+
(function() {
|
1215
|
+
if (typeof document !== "undefined" && !document.getElementById(digest6)) {
|
1216
|
+
var ele = document.createElement("style");
|
1217
|
+
ele.id = digest6;
|
1218
|
+
ele.textContent = css6;
|
1219
|
+
document.head.appendChild(ele);
|
1220
|
+
}
|
1221
|
+
})();
|
1222
|
+
var tooltip_module_default = classes6;
|
1223
|
+
|
1224
|
+
// src/components/tooltip/index.tsx
|
1225
|
+
import { jsx as jsx6, jsxs as jsxs3 } from "react/jsx-runtime";
|
1226
|
+
var Tooltip = ({ children, content, className }) => {
|
1227
|
+
return /* @__PURE__ */ jsxs3("div", { className: tooltip_module_default.tipContainer, children: [
|
1228
|
+
children,
|
1229
|
+
/* @__PURE__ */ jsx6("div", { className: tooltip_module_default.tipContent + (className ? ` ${className}` : ""), children: content })
|
1230
|
+
] });
|
1231
|
+
};
|
1232
|
+
var tooltip_default = Tooltip;
|
1233
|
+
|
1234
|
+
// esbuild-scss-modules-plugin:./transactionDetails.module.scss
|
1235
|
+
var digest7 = "a81c744751497ed4b401c08b9e5aeef1991aeb86f2cbba3ee57c1926c0502f1a";
|
1236
|
+
var classes7 = { "detailsCard": "_detailsCard_ml2p9_1", "title": "_title_ml2p9_13", "nftContract": "_nftContract_ml2p9_19", "row": "_row_ml2p9_26", "tokenIcon": "_tokenIcon_ml2p9_35", "nftIcon": "_nftIcon_ml2p9_41", "balanceChange": "_balanceChange_ml2p9_49", "tokenSymbol": "_tokenSymbol_ml2p9_56", "toContract": "_toContract_ml2p9_61", "right": "_right_ml2p9_71" };
|
1237
|
+
var css7 = `._detailsCard_ml2p9_1{background:#232529;border:1px solid #252525;border-radius:8px;color:#fff;margin-top:16px;overflow-x:hidden;padding:10px;position:relative;width:100%}._detailsCard_ml2p9_1 ._title_ml2p9_13{font-size:16px;font-weight:600;margin-bottom:12px;text-align:left}._detailsCard_ml2p9_1 ._nftContract_ml2p9_19{color:#a855f7;font-size:16px;position:absolute;right:8px;top:8px}._detailsCard_ml2p9_1 ._row_ml2p9_26{align-items:center;display:flex;flex-direction:row;font-size:14px;gap:8px;justify-content:space-between;margin-top:6px}._detailsCard_ml2p9_1 ._row_ml2p9_26 ._tokenIcon_ml2p9_35{border-radius:50%;height:32px;margin:10px 0;width:32px}._detailsCard_ml2p9_1 ._row_ml2p9_26 ._nftIcon_ml2p9_41{border-radius:2px;display:inline;height:32px;margin:10px 8px 10px 0;width:32px}._detailsCard_ml2p9_1 ._row_ml2p9_26 ._balanceChange_ml2p9_49{flex-grow:2;font-size:16px;font-weight:500;text-align:end;word-break:break-word}._detailsCard_ml2p9_1 ._row_ml2p9_26 ._tokenSymbol_ml2p9_56{font-size:16px;font-weight:500;text-align:end}._detailsCard_ml2p9_1 ._row_ml2p9_26 ._toContract_ml2p9_61{align-items:center;display:flex;gap:8px}._detailsCard_ml2p9_1 ._row_ml2p9_26 ._toContract_ml2p9_61 img{display:inline;height:18px;width:18px}._detailsCard_ml2p9_1 ._row_ml2p9_26 ._right_ml2p9_71{text-align:end}`;
|
1238
|
+
(function() {
|
1239
|
+
if (typeof document !== "undefined" && !document.getElementById(digest7)) {
|
1240
|
+
var ele = document.createElement("style");
|
1241
|
+
ele.id = digest7;
|
1242
|
+
ele.textContent = css7;
|
1243
|
+
document.head.appendChild(ele);
|
1244
|
+
}
|
1245
|
+
})();
|
1246
|
+
var transactionDetails_module_default = classes7;
|
1247
|
+
|
1248
|
+
// src/components/transactionDetails/index.tsx
|
1249
|
+
import { jsx as jsx7, jsxs as jsxs4 } from "react/jsx-runtime";
|
1250
|
+
var TransactionDetails = ({ details }) => {
|
1251
|
+
const { chainId } = useETHProvider();
|
1252
|
+
const chainInfo = useMemo3(() => {
|
1253
|
+
if (chainId) {
|
1254
|
+
return chains.getEVMChainInfoById(chainId);
|
1255
|
+
}
|
1256
|
+
}, [chainId]);
|
1257
|
+
const titleContent = useMemo3(() => {
|
1258
|
+
var _a;
|
1259
|
+
switch (details.type) {
|
1260
|
+
case "native_transfer" /* NATIVE_TRANSFER */:
|
1261
|
+
return `Send ${chainInfo == null ? void 0 : chainInfo.nativeCurrency.symbol}`;
|
1262
|
+
case "erc20_transfer" /* ERC20_TRANSFER */:
|
1263
|
+
return `Send ${(_a = details.estimatedChanges.tokens[0]) == null ? void 0 : _a.symbol}`;
|
1264
|
+
case "erc20_approve" /* ERC20_APPROVE */:
|
1265
|
+
return "Approve Spending";
|
1266
|
+
case "erc721_transfer" /* ERC721_TRANFER */:
|
1267
|
+
return "Send NFT";
|
1268
|
+
case "erc1155_transfer" /* ERC1155_TRANFER */:
|
1269
|
+
return "Send NFT";
|
1270
|
+
default:
|
1271
|
+
return "Transaction Details";
|
1272
|
+
}
|
1273
|
+
}, [details, chainInfo]);
|
1274
|
+
const nftContractType = useMemo3(() => {
|
1275
|
+
if (details.type === "erc721_transfer" /* ERC721_TRANFER */) {
|
1276
|
+
return "ERC721";
|
1277
|
+
} else if (details.type === "erc1155_transfer" /* ERC1155_TRANFER */) {
|
1278
|
+
return "ERC1155";
|
1279
|
+
}
|
1280
|
+
}, [details]);
|
1281
|
+
const nativeIcon = useMemo3(() => {
|
1282
|
+
if (chainInfo) {
|
1283
|
+
if (chainInfo.nativeCurrency.symbol === "ETH") {
|
1284
|
+
return "https://static.particle.network/token-list/ethereum/native.png";
|
1285
|
+
} else {
|
1286
|
+
return chainInfo.nativeIcon || chainInfo.icon;
|
1287
|
+
}
|
1288
|
+
}
|
1289
|
+
return defaultTokenIcon;
|
1290
|
+
}, [chainInfo]);
|
1291
|
+
const to = useMemo3(() => {
|
1292
|
+
var _a, _b;
|
1293
|
+
const params = (_b = (_a = details.data) == null ? void 0 : _a.function) == null ? void 0 : _b.params;
|
1294
|
+
if (details.type == "erc20_transfer" /* ERC20_TRANSFER */) {
|
1295
|
+
return params ? params[params.length === 3 ? 1 : 0].value : "";
|
1296
|
+
} else if (details.type == "erc20_approve" /* ERC20_APPROVE */) {
|
1297
|
+
return params ? params[0].value : "";
|
1298
|
+
} else if (details.type == "native_transfer" /* NATIVE_TRANSFER */) {
|
1299
|
+
return details.data.to;
|
1300
|
+
} else if (details.type == "erc721_transfer" /* ERC721_TRANFER */ || details.type == "erc1155_transfer" /* ERC1155_TRANFER */) {
|
1301
|
+
return params ? params[1].value : "";
|
1302
|
+
} else {
|
1303
|
+
return details.data.to;
|
1304
|
+
}
|
1305
|
+
}, [details]);
|
1306
|
+
const balanceChangeTextColor = useCallback4((value) => {
|
1307
|
+
if (BigInt(value) > 0) {
|
1308
|
+
return "#4ade80";
|
1309
|
+
} else if (BigInt(value) < 0) {
|
1310
|
+
return "#ef4444";
|
1311
|
+
} else {
|
1312
|
+
return "white";
|
1313
|
+
}
|
1314
|
+
}, []);
|
1315
|
+
const functionContent = useMemo3(() => {
|
1316
|
+
if (details.type !== "native_transfer" /* NATIVE_TRANSFER */ && details.data.function) {
|
1317
|
+
const params = details.data.function.params.map((item) => item.name);
|
1318
|
+
return `${details.data.function.name}(${params.join(", ")})`;
|
1319
|
+
}
|
1320
|
+
}, [details]);
|
1321
|
+
const approveTokenAmount = useMemo3(() => {
|
1322
|
+
var _a, _b, _c, _d;
|
1323
|
+
if (details.type === "erc20_approve" /* ERC20_APPROVE */) {
|
1324
|
+
const amount = (_d = (_c = (_b = (_a = details.data) == null ? void 0 : _a.function) == null ? void 0 : _b.params) == null ? void 0 : _c[1]) == null ? void 0 : _d.value;
|
1325
|
+
return BigInt(amount || 0);
|
1326
|
+
}
|
1327
|
+
return BigInt(0);
|
1328
|
+
}, [details]);
|
1329
|
+
const tokenAmountChange = useCallback4(
|
1330
|
+
(tokenItem) => {
|
1331
|
+
const result = formatUnits(
|
1332
|
+
details.type === "erc20_approve" /* ERC20_APPROVE */ ? approveTokenAmount : BigInt(tokenItem.amountChange),
|
1333
|
+
tokenItem.decimals
|
1334
|
+
);
|
1335
|
+
if (details.type !== "erc20_approve" /* ERC20_APPROVE */ && BigInt(tokenItem.amountChange) > BigInt(0)) {
|
1336
|
+
return `+${result}`;
|
1337
|
+
}
|
1338
|
+
return result;
|
1339
|
+
},
|
1340
|
+
[approveTokenAmount, details]
|
1341
|
+
);
|
1342
|
+
const showContactAddress = useMemo3(() => {
|
1343
|
+
return details.type === "erc20_transfer" /* ERC20_TRANSFER */ || details.type === "erc20_approve" /* ERC20_APPROVE */ || details.type === "erc721_transfer" /* ERC721_TRANFER */ || details.type === "erc1155_transfer" /* ERC1155_TRANFER */;
|
1344
|
+
}, [details]);
|
1345
|
+
return /* @__PURE__ */ jsxs4("div", { className: transactionDetails_module_default.detailsCard, children: [
|
1346
|
+
/* @__PURE__ */ jsx7("div", { className: transactionDetails_module_default.title, children: titleContent }),
|
1347
|
+
nftContractType && /* @__PURE__ */ jsx7("div", { className: transactionDetails_module_default.nftContract, children: nftContractType }),
|
1348
|
+
details.estimatedChanges.natives.map((nativeItem) => {
|
1349
|
+
return /* @__PURE__ */ jsxs4("div", { className: transactionDetails_module_default.row, children: [
|
1350
|
+
/* @__PURE__ */ jsx7("img", { className: transactionDetails_module_default.tokenIcon, src: nativeIcon }),
|
1351
|
+
/* @__PURE__ */ jsxs4("div", { className: transactionDetails_module_default.balanceChange, style: { color: balanceChangeTextColor(nativeItem.nativeChange) }, children: [
|
1352
|
+
BigInt(nativeItem.nativeChange) > 0 ? "+" : void 0,
|
1353
|
+
formatUnits(BigInt(nativeItem.nativeChange), (chainInfo == null ? void 0 : chainInfo.nativeCurrency.decimals) || 18)
|
1354
|
+
] }),
|
1355
|
+
/* @__PURE__ */ jsx7("div", { className: transactionDetails_module_default.tokenSymbol, children: chainInfo == null ? void 0 : chainInfo.nativeCurrency.symbol })
|
1356
|
+
] }, nativeItem.address);
|
1357
|
+
}),
|
1358
|
+
details.estimatedChanges.tokens.map((tokenItem) => {
|
1359
|
+
return /* @__PURE__ */ jsxs4("div", { className: transactionDetails_module_default.row, children: [
|
1360
|
+
/* @__PURE__ */ jsx7("img", { className: transactionDetails_module_default.tokenIcon, src: tokenItem.image || defaultTokenIcon }),
|
1361
|
+
/* @__PURE__ */ jsxs4("div", { className: transactionDetails_module_default.balanceChange, children: [
|
1362
|
+
/* @__PURE__ */ jsx7("span", { style: { color: balanceChangeTextColor(tokenItem.amountChange) }, children: tokenAmountChange(tokenItem) }),
|
1363
|
+
` ${tokenItem.symbol}`
|
1364
|
+
] })
|
1365
|
+
] }, tokenItem.address);
|
1366
|
+
}),
|
1367
|
+
details.estimatedChanges.nfts.map((nftItem) => {
|
1368
|
+
return /* @__PURE__ */ jsxs4("div", { className: transactionDetails_module_default.row, children: [
|
1369
|
+
/* @__PURE__ */ jsxs4("div", { style: { fontSize: 16 }, children: [
|
1370
|
+
/* @__PURE__ */ jsx7("img", { className: transactionDetails_module_default.nftIcon, src: ipfsToSrc(nftItem.image || defaultTokenIcon) }),
|
1371
|
+
nftItem.name || `NFT#${nftItem.tokenId}`
|
1372
|
+
] }),
|
1373
|
+
/* @__PURE__ */ jsx7("div", { className: transactionDetails_module_default.balanceChange, style: { color: balanceChangeTextColor(nftItem.amountChange) }, children: nftItem.amountChange })
|
1374
|
+
] }, nftItem.address);
|
1375
|
+
}),
|
1376
|
+
to && /* @__PURE__ */ jsxs4("div", { className: transactionDetails_module_default.row, children: [
|
1377
|
+
/* @__PURE__ */ jsx7("div", { children: "To" }),
|
1378
|
+
/* @__PURE__ */ jsxs4("div", { className: transactionDetails_module_default.toContract, children: [
|
1379
|
+
details.toVerified != null && !showContactAddress && /* @__PURE__ */ jsx7(tooltip_default, { content: details.toVerified ? "Verified Contract" : "Unverified Contract", children: /* @__PURE__ */ jsx7("img", { src: details.toVerified ? verified_default : unverified_default }) }),
|
1380
|
+
/* @__PURE__ */ jsx7(CopyText, { value: to, children: shortString(to) })
|
1381
|
+
] })
|
1382
|
+
] }),
|
1383
|
+
showContactAddress && /* @__PURE__ */ jsxs4("div", { className: transactionDetails_module_default.row, children: [
|
1384
|
+
/* @__PURE__ */ jsx7("div", { children: "Contract" }),
|
1385
|
+
/* @__PURE__ */ jsxs4("div", { className: transactionDetails_module_default.toContract, children: [
|
1386
|
+
details.toVerified != null && /* @__PURE__ */ jsx7(tooltip_default, { content: details.toVerified ? "Verified Contract" : "Unverified Contract", children: /* @__PURE__ */ jsx7("img", { src: details.toVerified ? verified_default : unverified_default }) }),
|
1387
|
+
/* @__PURE__ */ jsx7(CopyText, { value: details.data.to, children: shortString(details.data.to) })
|
1388
|
+
] })
|
1389
|
+
] }),
|
1390
|
+
/* @__PURE__ */ jsxs4("div", { className: transactionDetails_module_default.row, children: [
|
1391
|
+
/* @__PURE__ */ jsx7("div", { children: "Hex Data" }),
|
1392
|
+
/* @__PURE__ */ jsx7(CopyText, { value: details.data.data, children: shortString(details.data.data) })
|
1393
|
+
] }),
|
1394
|
+
functionContent && /* @__PURE__ */ jsxs4("div", { className: transactionDetails_module_default.row, children: [
|
1395
|
+
/* @__PURE__ */ jsx7("div", { children: "Function" }),
|
1396
|
+
/* @__PURE__ */ jsx7("div", { className: transactionDetails_module_default.right, children: functionContent })
|
1397
|
+
] })
|
1398
|
+
] });
|
1399
|
+
};
|
1400
|
+
var transactionDetails_default = TransactionDetails;
|
1401
|
+
|
1402
|
+
// esbuild-scss-modules-plugin:./sign.module.scss
|
1403
|
+
var digest8 = "3ab1a455562ae7e24c2ac49572897e615b9e9275066fd0d64f0cf24844521bab";
|
1404
|
+
var classes8 = { "modalContent": "_modalContent_aoysu_1", "closeBtn": "_closeBtn_aoysu_5", "signTitle": "_signTitle_aoysu_11", "chainInfo": "_chainInfo_aoysu_16", "addressContainer": "_addressContainer_aoysu_29", "addressInfo": "_addressInfo_aoysu_34", "detailsContent": "_detailsContent_aoysu_49", "fill": "_fill_aoysu_58", "unsignedMessage": "_unsignedMessage_aoysu_61", "estimatedGas": "_estimatedGas_aoysu_76", "signBtn": "_signBtn_aoysu_81", "notRemind": "_notRemind_aoysu_85" };
|
1405
|
+
var css8 = `._modalContent_aoysu_1{color:#fff;text-align:center}._modalContent_aoysu_1 ._closeBtn_aoysu_5{cursor:pointer;position:absolute;right:16px;top:16px}._modalContent_aoysu_1 ._signTitle_aoysu_11{font-size:20px;font-weight:600;margin-bottom:10px}._modalContent_aoysu_1 ._chainInfo_aoysu_16{align-items:center;display:flex;flex-direction:row;font-size:12px;gap:8px;justify-content:center;margin-bottom:8px}._modalContent_aoysu_1 ._chainInfo_aoysu_16 img{height:18px;width:18px}._modalContent_aoysu_1 ._addressContainer_aoysu_29{height:28px;margin-bottom:16px;margin-top:8px}._modalContent_aoysu_1 ._addressContainer_aoysu_29 ._addressInfo_aoysu_34{align-items:center;background:rgba(58,58,58,.635);border-radius:20px;display:flex;flex-direction:row;font-size:12px;gap:4px;justify-content:center;padding:4px 8px}._modalContent_aoysu_1 ._addressContainer_aoysu_29 ._addressInfo_aoysu_34 img{height:18px;width:18px}._modalContent_aoysu_1 ._detailsContent_aoysu_49{max-height:0;overflow-y:auto;transition:max-height .3s linear;width:100%}._modalContent_aoysu_1 ._detailsContent_aoysu_49::-webkit-scrollbar{display:none}._modalContent_aoysu_1 ._detailsContent_aoysu_49._fill_aoysu_58{max-height:500px}._modalContent_aoysu_1 ._detailsContent_aoysu_49 ._unsignedMessage_aoysu_61{background:#232529;border:1px solid #252525;border-radius:8px;box-sizing:border-box;color:#fff;font-size:14px;padding:8px;width:100%;word-wrap:break-word;color:hsla(0,0%,100%,.631);text-align:left;white-space:pre-wrap}._modalContent_aoysu_1 ._estimatedGas_aoysu_76{color:hsla(0,0%,100%,.631);font-size:12px;margin-top:24px}._modalContent_aoysu_1 ._signBtn_aoysu_81{margin-top:24px;min-width:200px}._modalContent_aoysu_1 ._notRemind_aoysu_85{align-items:center;color:hsla(0,0%,100%,.631);cursor:pointer;display:inline-flex;font-size:12px;gap:4px;margin-top:16px}._modalContent_aoysu_1 ._notRemind_aoysu_85:hover{opacity:.85}`;
|
1406
|
+
(function() {
|
1407
|
+
if (typeof document !== "undefined" && !document.getElementById(digest8)) {
|
1408
|
+
var ele = document.createElement("style");
|
1409
|
+
ele.id = digest8;
|
1410
|
+
ele.textContent = css8;
|
1411
|
+
document.head.appendChild(ele);
|
1412
|
+
}
|
1413
|
+
})();
|
1414
|
+
var sign_module_default = classes8;
|
1415
|
+
|
1416
|
+
// src/components/signModal/index.tsx
|
1417
|
+
import { Fragment as Fragment3, jsx as jsx8, jsxs as jsxs5 } from "react/jsx-runtime";
|
1418
|
+
var SignModal = ({ open, onClose, onOpen }) => {
|
1419
|
+
const [userOpBundle, setUserOpBundle] = useState5();
|
1420
|
+
const [notRemindChecked, setNotRemindChecked] = useState5(false);
|
1421
|
+
const [loading, setLoading] = useState5(false);
|
1422
|
+
const [deserializeLoading, setDeserializeLoading] = useState5(false);
|
1423
|
+
const [deserializeResult, setDeserializeResult] = useState5();
|
1424
|
+
const [disabled, setDisabled] = useState5(false);
|
1425
|
+
const [showNotRemind, setShowNotRemind] = useState5(true);
|
1426
|
+
const [nativeBalance, setNativeBalance] = useState5();
|
1427
|
+
const { accountContract } = useAccountContract();
|
1428
|
+
const [requestArguments, setRequestArguments] = useState5();
|
1429
|
+
const { chainId, publicClient, evmAccount, provider } = useETHProvider();
|
1430
|
+
const { smartAccount } = useConnectProvider();
|
1431
|
+
useEffect4(() => {
|
1432
|
+
if (!open) {
|
1433
|
+
setDeserializeResult(void 0);
|
1434
|
+
setUserOpBundle(void 0);
|
1435
|
+
setRequestArguments(void 0);
|
1436
|
+
setLoading(false);
|
1437
|
+
setDisabled(false);
|
1438
|
+
setDeserializeLoading(false);
|
1439
|
+
setNativeBalance(void 0);
|
1440
|
+
}
|
1441
|
+
}, [open]);
|
1442
|
+
useEffect4(() => {
|
1443
|
+
if (open) {
|
1444
|
+
const notRemind = txConfirmUtils_default.isNotRemind();
|
1445
|
+
setShowNotRemind(!notRemind);
|
1446
|
+
if (!notRemind) {
|
1447
|
+
setNotRemindChecked(false);
|
1448
|
+
}
|
1449
|
+
}
|
1450
|
+
}, [open]);
|
1451
|
+
const chainInfo = useMemo4(() => {
|
1452
|
+
if (chainId) {
|
1453
|
+
return chains2.getEVMChainInfoById(chainId);
|
1454
|
+
}
|
1455
|
+
}, [chainId]);
|
1456
|
+
useEffect4(() => {
|
1457
|
+
const onSendUserOp = (opBundle) => {
|
1458
|
+
setUserOpBundle(opBundle);
|
1459
|
+
onOpen();
|
1460
|
+
};
|
1461
|
+
const onPersonalSign = (arg) => {
|
1462
|
+
setRequestArguments(arg);
|
1463
|
+
onOpen();
|
1464
|
+
};
|
1465
|
+
const onSignTypedData = (arg) => {
|
1466
|
+
setRequestArguments(arg);
|
1467
|
+
onOpen();
|
1468
|
+
};
|
1469
|
+
eventUtils_default.on("sendUserOp" /* sendUserOp */, onSendUserOp);
|
1470
|
+
eventUtils_default.on("personalSign" /* personalSign */, onPersonalSign);
|
1471
|
+
eventUtils_default.on("signTypedData" /* signTypedData */, onSignTypedData);
|
1472
|
+
return () => {
|
1473
|
+
eventUtils_default.off("sendUserOp" /* sendUserOp */, onSendUserOp);
|
1474
|
+
eventUtils_default.off("personalSign" /* personalSign */, onPersonalSign);
|
1475
|
+
eventUtils_default.off("signTypedData" /* signTypedData */, onSignTypedData);
|
1476
|
+
};
|
1477
|
+
}, [onOpen, setUserOpBundle]);
|
1478
|
+
const deserializeUserOp = useCallback5(() => __async(void 0, null, function* () {
|
1479
|
+
if (userOpBundle && smartAccount) {
|
1480
|
+
const addresses = yield smartAccount.provider.request({ method: "eth_accounts" });
|
1481
|
+
const owner = addresses[0];
|
1482
|
+
const result = yield smartAccount.sendRpc({
|
1483
|
+
method: "particle_aa_deserializeUserOp",
|
1484
|
+
params: [
|
1485
|
+
{
|
1486
|
+
name: accountContract.name,
|
1487
|
+
version: accountContract.version,
|
1488
|
+
ownerAddress: owner
|
1489
|
+
},
|
1490
|
+
userOpBundle.userOp
|
1491
|
+
]
|
1492
|
+
});
|
1493
|
+
return result;
|
1494
|
+
}
|
1495
|
+
}), [userOpBundle, smartAccount, accountContract]);
|
1496
|
+
useEffect4(() => {
|
1497
|
+
if (userOpBundle && open) {
|
1498
|
+
setDeserializeLoading(true);
|
1499
|
+
deserializeUserOp().then((result) => {
|
1500
|
+
setDeserializeResult(result);
|
1501
|
+
}).catch((error) => {
|
1502
|
+
eventUtils_default.emit("sendUserOpResult" /* sendUserOpResult */, {
|
1503
|
+
error
|
1504
|
+
});
|
1505
|
+
onClose();
|
1506
|
+
});
|
1507
|
+
}
|
1508
|
+
}, [deserializeUserOp, userOpBundle, open, onClose]);
|
1509
|
+
useEffect4(() => {
|
1510
|
+
if (open && publicClient && evmAccount && userOpBundle) {
|
1511
|
+
publicClient.getBalance({ address: evmAccount }).then((result) => setNativeBalance(result)).catch((error) => {
|
1512
|
+
eventUtils_default.emit("sendUserOpResult" /* sendUserOpResult */, {
|
1513
|
+
error
|
1514
|
+
});
|
1515
|
+
onClose();
|
1516
|
+
});
|
1517
|
+
}
|
1518
|
+
}, [open, publicClient, evmAccount, userOpBundle, onClose]);
|
1519
|
+
useEffect4(() => {
|
1520
|
+
if (nativeBalance != null && deserializeResult != null) {
|
1521
|
+
setDeserializeLoading(false);
|
1522
|
+
}
|
1523
|
+
}, [nativeBalance, deserializeResult]);
|
1524
|
+
const toggleNotRemind = () => {
|
1525
|
+
setNotRemindChecked(!notRemindChecked);
|
1526
|
+
txConfirmUtils_default.setNotRemind(!notRemindChecked);
|
1527
|
+
};
|
1528
|
+
const gasFee = useMemo4(() => {
|
1529
|
+
if (userOpBundle == null ? void 0 : userOpBundle.userOp) {
|
1530
|
+
return caculateNativeFee(userOpBundle == null ? void 0 : userOpBundle.userOp);
|
1531
|
+
}
|
1532
|
+
return BigInt(0);
|
1533
|
+
}, [userOpBundle]);
|
1534
|
+
const closeModal = () => {
|
1535
|
+
var _a;
|
1536
|
+
let event;
|
1537
|
+
if (userOpBundle) {
|
1538
|
+
event = "sendUserOpResult" /* sendUserOpResult */;
|
1539
|
+
} else if ((requestArguments == null ? void 0 : requestArguments.method) === "personal_sign" /* personalSign */) {
|
1540
|
+
event = "personalSignResult" /* personalSignResult */;
|
1541
|
+
} else if ((_a = requestArguments == null ? void 0 : requestArguments.method) == null ? void 0 : _a.startsWith("eth_signTypedData" /* signTypedData */)) {
|
1542
|
+
event = "signTypedDataResult" /* signTypedDataResult */;
|
1543
|
+
}
|
1544
|
+
if (event) {
|
1545
|
+
eventUtils_default.emit(event, {
|
1546
|
+
error: {
|
1547
|
+
code: 4001,
|
1548
|
+
message: "The user rejected the request."
|
1549
|
+
}
|
1550
|
+
});
|
1551
|
+
}
|
1552
|
+
onClose();
|
1553
|
+
};
|
1554
|
+
const confirmTx = useCallback5(() => __async(void 0, null, function* () {
|
1555
|
+
if (smartAccount && provider) {
|
1556
|
+
setLoading(true);
|
1557
|
+
if (userOpBundle) {
|
1558
|
+
try {
|
1559
|
+
const hash = yield smartAccount.sendUserOperation(userOpBundle);
|
1560
|
+
eventUtils_default.emit("sendUserOpResult" /* sendUserOpResult */, { result: hash });
|
1561
|
+
} catch (error) {
|
1562
|
+
eventUtils_default.emit("sendUserOpResult" /* sendUserOpResult */, {
|
1563
|
+
error
|
1564
|
+
});
|
1565
|
+
} finally {
|
1566
|
+
setLoading(false);
|
1567
|
+
}
|
1568
|
+
} else if (requestArguments) {
|
1569
|
+
try {
|
1570
|
+
const hash = yield provider.request(requestArguments);
|
1571
|
+
eventUtils_default.emit(
|
1572
|
+
requestArguments.method == "personal_sign" /* personalSign */ ? "personalSignResult" /* personalSignResult */ : "signTypedDataResult" /* signTypedDataResult */,
|
1573
|
+
{ result: hash }
|
1574
|
+
);
|
1575
|
+
} catch (error) {
|
1576
|
+
eventUtils_default.emit(
|
1577
|
+
requestArguments.method == "personal_sign" /* personalSign */ ? "personalSignResult" /* personalSignResult */ : "signTypedDataResult" /* signTypedDataResult */,
|
1578
|
+
{
|
1579
|
+
error
|
1580
|
+
}
|
1581
|
+
);
|
1582
|
+
} finally {
|
1583
|
+
setLoading(false);
|
1584
|
+
}
|
1585
|
+
}
|
1586
|
+
onClose();
|
1587
|
+
}
|
1588
|
+
}), [smartAccount, provider, requestArguments, userOpBundle, onClose]);
|
1589
|
+
useEffect4(() => {
|
1590
|
+
if (userOpBundle && nativeBalance != null && deserializeResult) {
|
1591
|
+
const nativeChange = deserializeResult.filter(
|
1592
|
+
(item) => {
|
1593
|
+
var _a, _b;
|
1594
|
+
return ((_b = (_a = item.estimatedChanges.natives) == null ? void 0 : _a[0]) == null ? void 0 : _b.nativeChange) && item.estimatedChanges.natives[0].nativeChange.startsWith("-");
|
1595
|
+
}
|
1596
|
+
).map((item) => {
|
1597
|
+
var _a, _b, _c, _d;
|
1598
|
+
return BigInt(((_d = (_c = (_b = (_a = item.estimatedChanges) == null ? void 0 : _a.natives) == null ? void 0 : _b[0]) == null ? void 0 : _c.nativeChange) == null ? void 0 : _d.replace("-", "")) || 0);
|
1599
|
+
}).reduce((accumulator, currentValue) => accumulator + currentValue, BigInt(0));
|
1600
|
+
if (userOpBundle.userOp.paymasterAndData.length > 2) {
|
1601
|
+
setDisabled(nativeBalance < nativeChange);
|
1602
|
+
} else {
|
1603
|
+
setDisabled(nativeBalance < gasFee + nativeChange);
|
1604
|
+
}
|
1605
|
+
}
|
1606
|
+
}, [userOpBundle, gasFee, nativeBalance, deserializeResult]);
|
1607
|
+
const unsignedMessage = useMemo4(() => {
|
1608
|
+
var _a, _b;
|
1609
|
+
if (!requestArguments) {
|
1610
|
+
return void 0;
|
1611
|
+
}
|
1612
|
+
if (requestArguments.method === "personal_sign" /* personalSign */) {
|
1613
|
+
const message = ((_a = requestArguments.params) == null ? void 0 : _a[0]) || "0x";
|
1614
|
+
return hexToString(message);
|
1615
|
+
} else {
|
1616
|
+
const typedData = (_b = requestArguments.params) == null ? void 0 : _b[1];
|
1617
|
+
const obj = typeof typedData === "string" ? JSON.parse(typedData) : typedData;
|
1618
|
+
return JSON.stringify(obj, null, 2);
|
1619
|
+
}
|
1620
|
+
}, [requestArguments]);
|
1621
|
+
return /* @__PURE__ */ jsx8(modal_default, { open, onClose, isDismissable: false, contentClassName: sign_module_default.modalContent, children: /* @__PURE__ */ jsxs5(Fragment3, { children: [
|
1622
|
+
/* @__PURE__ */ jsx8("img", { className: sign_module_default.closeBtn, src: close_default, onClick: closeModal }),
|
1623
|
+
requestArguments && /* @__PURE__ */ jsx8("div", { className: sign_module_default.signTitle, children: requestArguments.method == "personal_sign" /* personalSign */ ? "Sign Message" : "Sign Typed Data" }),
|
1624
|
+
/* @__PURE__ */ jsxs5("div", { className: sign_module_default.chainInfo, children: [
|
1625
|
+
/* @__PURE__ */ jsx8("img", { src: chainInfo == null ? void 0 : chainInfo.icon }),
|
1626
|
+
chainInfo == null ? void 0 : chainInfo.fullname.replace("Mainnet", "")
|
1627
|
+
] }),
|
1628
|
+
/* @__PURE__ */ jsx8("div", { className: sign_module_default.addressContainer, children: /* @__PURE__ */ jsx8(CopyText, { value: evmAccount, style: { textDecorationLine: "none" }, children: /* @__PURE__ */ jsxs5("div", { className: sign_module_default.addressInfo, children: [
|
1629
|
+
shortString(evmAccount),
|
1630
|
+
/* @__PURE__ */ jsx8("img", { src: copy_default })
|
1631
|
+
] }) }) }),
|
1632
|
+
/* @__PURE__ */ jsxs5("div", { className: sign_module_default.detailsContent + (deserializeResult || requestArguments ? ` ${sign_module_default.fill}` : ""), children: [
|
1633
|
+
deserializeResult && deserializeResult.map((details, index) => /* @__PURE__ */ jsx8(transactionDetails_default, { details }, `${details.type}-${index}`)),
|
1634
|
+
unsignedMessage && /* @__PURE__ */ jsx8("div", { className: sign_module_default.unsignedMessage, children: unsignedMessage })
|
1635
|
+
] }),
|
1636
|
+
gasFee && /* @__PURE__ */ jsx8("div", { className: sign_module_default.estimatedGas, children: `Estimated gas fee: ${formatEther(gasFee)} ${chainInfo == null ? void 0 : chainInfo.nativeCurrency.symbol}` }),
|
1637
|
+
/* @__PURE__ */ jsx8(
|
1638
|
+
button_default,
|
1639
|
+
{
|
1640
|
+
onClick: confirmTx,
|
1641
|
+
className: sign_module_default.signBtn,
|
1642
|
+
isLoading: loading || deserializeLoading,
|
1643
|
+
isDisabled: disabled,
|
1644
|
+
children: deserializeLoading ? "LOADING" : disabled ? "INSUFFICIENT FEE" : "CONFIRM"
|
1645
|
+
}
|
1646
|
+
),
|
1647
|
+
showNotRemind && /* @__PURE__ */ jsxs5("div", { className: sign_module_default.notRemind, onClick: toggleNotRemind, children: [
|
1648
|
+
/* @__PURE__ */ jsx8("img", { src: notRemindChecked ? check_box_default : check_box_blank_default }),
|
1649
|
+
"Do not remind me again"
|
1650
|
+
] })
|
1651
|
+
] }) });
|
1652
|
+
};
|
1653
|
+
var signModal_default = SignModal;
|
1654
|
+
|
1655
|
+
// src/evmSigner/index.ts
|
1656
|
+
import { intToHex as intToHex2 } from "@ethereumjs/util";
|
1657
|
+
import { chains as chains3 } from "@particle-network/chains";
|
1658
|
+
import { EventEmitter as EventEmitter3 } from "events";
|
1659
|
+
import {
|
1660
|
+
InvalidParamsRpcError,
|
1661
|
+
SwitchChainError,
|
1662
|
+
UnsupportedProviderMethodError,
|
1663
|
+
createPublicClient,
|
1664
|
+
hashMessage,
|
1665
|
+
hashTypedData,
|
1666
|
+
http
|
1667
|
+
} from "viem";
|
1668
|
+
var AASignerProvider = class {
|
1669
|
+
constructor(supportChainIds, projectId, clientKey, rpcUrls) {
|
1670
|
+
this.supportChainIds = supportChainIds;
|
1671
|
+
this.projectId = projectId;
|
1672
|
+
this.clientKey = clientKey;
|
1673
|
+
this.rpcUrls = rpcUrls;
|
1674
|
+
this.chainId = 1;
|
1675
|
+
this.personalSign = (message) => __async(this, null, function* () {
|
1676
|
+
throw new Error("Wallet not connected!");
|
1677
|
+
});
|
1678
|
+
this.getPublicKey = () => __async(this, null, function* () {
|
1679
|
+
throw new Error("Wallet not connected!");
|
1680
|
+
});
|
1681
|
+
this.getPublicClient = () => {
|
1682
|
+
var _a, _b;
|
1683
|
+
const rpcUrl = ((_a = this == null ? void 0 : this.rpcUrls) == null ? void 0 : _a[this.chainId]) || ((_b = chains3.getEVMChainInfoById(this.chainId || 1)) == null ? void 0 : _b.rpcUrl);
|
1684
|
+
return createPublicClient({
|
1685
|
+
transport: http(rpcUrl)
|
1686
|
+
});
|
1687
|
+
};
|
1688
|
+
this.events = new EventEmitter3();
|
1689
|
+
this.events.setMaxListeners(100);
|
1690
|
+
if (typeof window !== "undefined") {
|
1691
|
+
const localChainId = localStorage.getItem("connect-evm-chain-id");
|
1692
|
+
if (localChainId && supportChainIds.includes(Number(localChainId))) {
|
1693
|
+
this.chainId = Number(localChainId);
|
1694
|
+
} else {
|
1695
|
+
const chainId = supportChainIds[0];
|
1696
|
+
if (chainId) {
|
1697
|
+
localStorage.setItem("connect-evm-chain-id", chainId.toString());
|
1698
|
+
this.chainId = chainId;
|
1699
|
+
}
|
1700
|
+
}
|
1701
|
+
}
|
1702
|
+
this.publicClient = this.getPublicClient();
|
1703
|
+
}
|
1704
|
+
request(arg) {
|
1705
|
+
return __async(this, null, function* () {
|
1706
|
+
var _a, _b;
|
1707
|
+
if (arg.method === "eth_sendTransaction" || arg.method === "wallet_addEthereumChain" || arg.method === "wallet_watchAsset" || arg.method === "eth_sign") {
|
1708
|
+
throw new UnsupportedProviderMethodError(new Error("The Provider does not support the requested method."));
|
1709
|
+
}
|
1710
|
+
if (arg.method === "eth_accounts" || arg.method === "eth_requestAccounts") {
|
1711
|
+
const pubKey = yield this.getPublicKey();
|
1712
|
+
const address = pubKeyToEVMAddress(pubKey);
|
1713
|
+
return [address];
|
1714
|
+
} else if (arg.method === "eth_chainId") {
|
1715
|
+
return `0x${this.chainId.toString(16)}`;
|
1716
|
+
} else if (arg.method === "personal_sign" /* personalSign */) {
|
1717
|
+
let message = (_a = arg.params) == null ? void 0 : _a[0];
|
1718
|
+
if (message.length !== 66) {
|
1719
|
+
const hash = hashMessage({ raw: message });
|
1720
|
+
message = hash;
|
1721
|
+
}
|
1722
|
+
const result = yield this.personalSign(message || "");
|
1723
|
+
const convertResult = convertSignature(result);
|
1724
|
+
if (!convertResult) {
|
1725
|
+
throw new Error("sign error");
|
1726
|
+
}
|
1727
|
+
return convertResult;
|
1728
|
+
} else if (arg.method === "eth_signTypedData" || arg.method === "eth_signTypedData_v4") {
|
1729
|
+
const typedData = (_b = arg.params) == null ? void 0 : _b[1];
|
1730
|
+
const hash = hashTypedData(typeof typedData === "string" ? JSON.parse(typedData) : typedData);
|
1731
|
+
const result = yield this.personalSign(hash || "");
|
1732
|
+
const convertResult = convertSignature(result);
|
1733
|
+
if (!convertResult) {
|
1734
|
+
throw new Error("sign error");
|
1735
|
+
}
|
1736
|
+
return convertResult;
|
1737
|
+
} else if (arg.method === "wallet_switchEthereumChain") {
|
1738
|
+
if (arg.params && arg.params instanceof Array && arg.params[0] && arg.params[0].chainId) {
|
1739
|
+
const chainId = Number(arg.params[0].chainId);
|
1740
|
+
if (this.supportChainIds.includes(this.chainId)) {
|
1741
|
+
this.chainId = chainId;
|
1742
|
+
localStorage.setItem("connect-evm-chain-id", this.chainId.toString());
|
1743
|
+
this.publicClient = this.getPublicClient();
|
1744
|
+
setTimeout(() => this.events.emit("chainChanged", intToHex2(this.chainId)), 0);
|
1745
|
+
return Promise.resolve(null);
|
1746
|
+
}
|
1747
|
+
throw new SwitchChainError(new Error(`The chain: ${chainId} is not supported`));
|
1748
|
+
} else {
|
1749
|
+
throw new InvalidParamsRpcError(new Error("Invalid Params"));
|
1750
|
+
}
|
1751
|
+
} else {
|
1752
|
+
const result = yield this.publicClient.request(arg);
|
1753
|
+
return result;
|
1754
|
+
}
|
1755
|
+
});
|
1756
|
+
}
|
1757
|
+
removeListener(event, listener) {
|
1758
|
+
this.events.removeListener(event, listener);
|
1759
|
+
return this;
|
1760
|
+
}
|
1761
|
+
on(event, listener) {
|
1762
|
+
this.events.on(event, listener);
|
1763
|
+
return this;
|
1764
|
+
}
|
1765
|
+
once(event, listener) {
|
1766
|
+
this.events.once(event, listener);
|
1767
|
+
return this;
|
1768
|
+
}
|
1769
|
+
off(event, listener) {
|
1770
|
+
this.events.off(event, listener);
|
1771
|
+
return this;
|
1772
|
+
}
|
1773
|
+
emit(event, ...args) {
|
1774
|
+
this.events.emit(event, args);
|
1775
|
+
}
|
1776
|
+
};
|
1777
|
+
|
1778
|
+
// src/hooks/useModalStateValue.ts
|
1779
|
+
import { useCallback as useCallback6, useState as useState6 } from "react";
|
1780
|
+
var useModalStateValue = () => {
|
1781
|
+
const [isModalOpen, setModalOpen] = useState6(false);
|
1782
|
+
return {
|
1783
|
+
closeModal: useCallback6(() => setModalOpen(false), []),
|
1784
|
+
isModalOpen,
|
1785
|
+
openModal: useCallback6(() => setModalOpen(true), [])
|
1786
|
+
};
|
1787
|
+
};
|
1788
|
+
var useModalStateValue_default = useModalStateValue;
|
1789
|
+
|
1790
|
+
// src/context/index.tsx
|
1791
|
+
import { jsx as jsx9, jsxs as jsxs6 } from "react/jsx-runtime";
|
1792
|
+
var ConnectContext = createContext({});
|
1793
|
+
var SAContractKey = "particle-sa-config";
|
1794
|
+
var ConnectProvider = ({
|
1795
|
+
children,
|
1796
|
+
options,
|
1797
|
+
connectors,
|
1798
|
+
autoConnect = true
|
1799
|
+
}) => {
|
1800
|
+
var _a, _b, _c;
|
1801
|
+
const {
|
1802
|
+
closeModal: closeConnectModal,
|
1803
|
+
isModalOpen: connectModalOpen,
|
1804
|
+
openModal: openConnectModal
|
1805
|
+
} = useModalStateValue_default();
|
1806
|
+
const { closeModal: closeSignModal, isModalOpen: signModalOpen, openModal: openSignModal } = useModalStateValue_default();
|
1807
|
+
const [connectorId, setConnectorId] = useState7();
|
1808
|
+
const [accounts, setAccounts] = useState7([]);
|
1809
|
+
const [evmAccount, setEVMAccount] = useState7();
|
1810
|
+
const [accountContract, _setAccountContract] = useState7({
|
1811
|
+
name: ((_a = Object.keys(options.aaOptions.accountContracts)) == null ? void 0 : _a[0]) || "BTC",
|
1812
|
+
version: ((_c = options.aaOptions.accountContracts[((_b = Object.keys(options.aaOptions.accountContracts)) == null ? void 0 : _b[0]) || "BTC"]) == null ? void 0 : _c[0].version) || "1.0.0"
|
1813
|
+
});
|
1814
|
+
const setAccountContract = useCallback7(
|
1815
|
+
(config) => {
|
1816
|
+
if (!checkBTCVersion(options.aaOptions.accountContracts, config.name, config.version)) {
|
1817
|
+
throw new Error("Invalid Account Contract");
|
1818
|
+
}
|
1819
|
+
localStorage.setItem(SAContractKey, JSON.stringify(config));
|
1820
|
+
_setAccountContract(config);
|
1821
|
+
},
|
1822
|
+
[options.aaOptions.accountContracts, _setAccountContract]
|
1823
|
+
);
|
1824
|
+
useEffect5(() => {
|
1825
|
+
const id = localStorage.getItem("current-connector-id");
|
1826
|
+
if (autoConnect && id) {
|
1827
|
+
setConnectorId(id);
|
1828
|
+
}
|
1829
|
+
}, [autoConnect]);
|
1830
|
+
const evmSupportChainIds = useMemo5(() => {
|
1831
|
+
var _a2;
|
1832
|
+
let chainIds = (_a2 = options.aaOptions.accountContracts[accountContract.name]) == null ? void 0 : _a2.filter((item) => item.version === accountContract.version).map((item) => item.chainIds).reduce((a, b) => {
|
1833
|
+
a.push(...b);
|
1834
|
+
return a;
|
1835
|
+
}, []);
|
1836
|
+
chainIds = Array.from(new Set(chainIds || []));
|
1837
|
+
return chainIds;
|
1838
|
+
}, [options.aaOptions.accountContracts, accountContract]);
|
1839
|
+
const connector = useMemo5(() => {
|
1840
|
+
return connectors.find((item) => item.metadata.id === connectorId);
|
1841
|
+
}, [connectorId, connectors]);
|
1842
|
+
const getPublicKey = useCallback7(() => __async(void 0, null, function* () {
|
1843
|
+
if (!connector) {
|
1844
|
+
throw new Error("Wallet not connected!");
|
1845
|
+
}
|
1846
|
+
const pubKey = yield connector.getPublicKey();
|
1847
|
+
return pubKey;
|
1848
|
+
}), [connector]);
|
1849
|
+
const signMessage = useCallback7(
|
1850
|
+
(message) => __async(void 0, null, function* () {
|
1851
|
+
if (!connector) {
|
1852
|
+
throw new Error("Wallet not connected!");
|
1853
|
+
}
|
1854
|
+
const signature = yield connector.signMessage(message);
|
1855
|
+
return signature;
|
1856
|
+
}),
|
1857
|
+
[connector]
|
1858
|
+
);
|
1859
|
+
const sendBitcoin = useCallback7(
|
1860
|
+
(toAddress, satoshis, options2) => __async(void 0, null, function* () {
|
1861
|
+
if (!connector) {
|
1862
|
+
throw new Error("Wallet not connected!");
|
1863
|
+
}
|
1864
|
+
const signature = yield connector.sendBitcoin(toAddress, satoshis, options2);
|
1865
|
+
return signature;
|
1866
|
+
}),
|
1867
|
+
[connector]
|
1868
|
+
);
|
1869
|
+
const getNetwork = useCallback7(() => __async(void 0, null, function* () {
|
1870
|
+
if (!connector) {
|
1871
|
+
throw new Error("Wallet not connected!");
|
1872
|
+
}
|
1873
|
+
const network = yield connector.getNetwork();
|
1874
|
+
return network;
|
1875
|
+
}), [connector]);
|
1876
|
+
const switchNetwork = useCallback7(
|
1877
|
+
(network) => __async(void 0, null, function* () {
|
1878
|
+
if (!connector) {
|
1879
|
+
throw new Error("Wallet not connected!");
|
1880
|
+
}
|
1881
|
+
yield connector.switchNetwork(network);
|
1882
|
+
}),
|
1883
|
+
[connector]
|
1884
|
+
);
|
1885
|
+
const smartAccount = useMemo5(() => {
|
1886
|
+
if (typeof window === "undefined") {
|
1887
|
+
return void 0;
|
1888
|
+
}
|
1889
|
+
if (!window.__bitcoinSmartAccount || (window == null ? void 0 : window.__bitcoinSmartAccount) && ((window == null ? void 0 : window.__bitcoinSmartAccount.smartAccountContract.version) !== accountContract.version || (window == null ? void 0 : window.__bitcoinSmartAccount.smartAccountContract.name) !== accountContract.name)) {
|
1890
|
+
const smartAccount2 = new SmartAccount(
|
1891
|
+
new AASignerProvider(evmSupportChainIds, options.projectId, options.clientKey, options.rpcUrls),
|
1892
|
+
options
|
1893
|
+
);
|
1894
|
+
smartAccount2.setSmartAccountContract(accountContract);
|
1895
|
+
window.__bitcoinSmartAccount = smartAccount2;
|
1896
|
+
}
|
1897
|
+
window.__bitcoinSmartAccount.provider.getPublicKey = getPublicKey;
|
1898
|
+
window.__bitcoinSmartAccount.provider.personalSign = signMessage;
|
1899
|
+
return window.__bitcoinSmartAccount;
|
1900
|
+
}, [options, evmSupportChainIds, getPublicKey, signMessage, accountContract]);
|
1901
|
+
useEffect5(() => {
|
1902
|
+
if (accounts.length > 0 && smartAccount) {
|
1903
|
+
getBTCAAAddress(smartAccount, accounts[0], accountContract.name, accountContract.version).then((res) => {
|
1904
|
+
setEVMAccount(res);
|
1905
|
+
}).catch((e) => {
|
1906
|
+
setEVMAccount(void 0);
|
1907
|
+
});
|
1908
|
+
} else {
|
1909
|
+
setEVMAccount(void 0);
|
1910
|
+
}
|
1911
|
+
}, [accountContract, accounts, smartAccount]);
|
1912
|
+
const getSmartAccountInfo = useCallback7(() => __async(void 0, null, function* () {
|
1913
|
+
if (accounts.length > 0 && smartAccount) {
|
1914
|
+
const accountInfo = yield getBTCAccountInfo(
|
1915
|
+
smartAccount,
|
1916
|
+
accounts[0],
|
1917
|
+
accountContract.name,
|
1918
|
+
accountContract.version
|
1919
|
+
);
|
1920
|
+
setEVMAccount(accountInfo.smartAccountAddress);
|
1921
|
+
return accountInfo;
|
1922
|
+
}
|
1923
|
+
return void 0;
|
1924
|
+
}), [accounts, smartAccount, accountContract, setEVMAccount]);
|
1925
|
+
const requestAccount = useCallback7(
|
1926
|
+
(connector2) => __async(void 0, null, function* () {
|
1927
|
+
let accounts2 = yield connector2.getAccounts();
|
1928
|
+
if (accounts2.length === 0 && autoConnect) {
|
1929
|
+
accounts2 = yield connector2.requestAccounts();
|
1930
|
+
}
|
1931
|
+
setAccounts(accounts2);
|
1932
|
+
}),
|
1933
|
+
[autoConnect]
|
1934
|
+
);
|
1935
|
+
useEffect5(() => {
|
1936
|
+
if (connector) {
|
1937
|
+
requestAccount(connector).catch((e) => {
|
1938
|
+
setAccounts([]);
|
1939
|
+
});
|
1940
|
+
} else {
|
1941
|
+
setAccounts([]);
|
1942
|
+
}
|
1943
|
+
}, [connector, requestAccount]);
|
1944
|
+
useEffect5(() => {
|
1945
|
+
const onAccountChange = (accounts2) => {
|
1946
|
+
setAccounts(accounts2);
|
1947
|
+
};
|
1948
|
+
connector == null ? void 0 : connector.on("accountsChanged", onAccountChange);
|
1949
|
+
return () => {
|
1950
|
+
connector == null ? void 0 : connector.removeListener("accountsChanged", onAccountChange);
|
1951
|
+
};
|
1952
|
+
}, [connector]);
|
1953
|
+
const provider = useMemo5(() => {
|
1954
|
+
var _a2;
|
1955
|
+
if (connectorId) {
|
1956
|
+
return (_a2 = connectors.find((item) => item.metadata.id === connectorId)) == null ? void 0 : _a2.getProvider();
|
1957
|
+
}
|
1958
|
+
}, [connectorId, connectors]);
|
1959
|
+
const disconnect = useCallback7(() => {
|
1960
|
+
localStorage.removeItem("current-connector-id");
|
1961
|
+
txConfirmUtils_default.reset();
|
1962
|
+
if (connector) {
|
1963
|
+
connector.disconnect();
|
1964
|
+
}
|
1965
|
+
setConnectorId(void 0);
|
1966
|
+
}, [connector]);
|
1967
|
+
useEffect5(() => {
|
1968
|
+
const config = JSON.parse(localStorage.getItem(SAContractKey) || "{}");
|
1969
|
+
if (config.name && config.version && checkBTCVersion(options.aaOptions.accountContracts, config.name, config.version)) {
|
1970
|
+
_setAccountContract(config);
|
1971
|
+
}
|
1972
|
+
}, [options.aaOptions.accountContracts, _setAccountContract]);
|
1973
|
+
useEffect5(() => {
|
1974
|
+
var _a2, _b2;
|
1975
|
+
if (((_a2 = options.walletOptions) == null ? void 0 : _a2.visible) !== false) {
|
1976
|
+
const supportChains = evmSupportChainIds.map((id) => chains4.getEVMChainInfoById(id));
|
1977
|
+
if (supportChains.some((chain) => !chain)) {
|
1978
|
+
throw new Error(`Please config valid chain ids, ${JSON.stringify(evmSupportChainIds)}`);
|
1979
|
+
}
|
1980
|
+
walletEntryPlugin.init(
|
1981
|
+
{
|
1982
|
+
projectId: options.projectId,
|
1983
|
+
clientKey: options.clientKey,
|
1984
|
+
appId: options.appId
|
1985
|
+
},
|
1986
|
+
__spreadProps(__spreadValues({}, options.walletOptions), {
|
1987
|
+
erc4337: accountContract,
|
1988
|
+
customStyle: __spreadProps(__spreadValues({}, (_b2 = options.walletOptions) == null ? void 0 : _b2.customStyle), {
|
1989
|
+
supportChains
|
1990
|
+
})
|
1991
|
+
})
|
1992
|
+
);
|
1993
|
+
}
|
1994
|
+
}, [options, evmSupportChainIds, accountContract]);
|
1995
|
+
useEffect5(() => {
|
1996
|
+
var _a2;
|
1997
|
+
if (smartAccount && ((_a2 = options.walletOptions) == null ? void 0 : _a2.visible) !== false) {
|
1998
|
+
walletEntryPlugin.setWalletCore({
|
1999
|
+
ethereum: smartAccount.provider
|
2000
|
+
});
|
2001
|
+
}
|
2002
|
+
}, [smartAccount, options]);
|
2003
|
+
useEffect5(() => {
|
2004
|
+
var _a2;
|
2005
|
+
if (((_a2 = options.walletOptions) == null ? void 0 : _a2.visible) !== false) {
|
2006
|
+
if (evmAccount) {
|
2007
|
+
walletEntryPlugin.walletEntryCreate();
|
2008
|
+
} else {
|
2009
|
+
walletEntryPlugin.walletEntryDestroy();
|
2010
|
+
}
|
2011
|
+
}
|
2012
|
+
}, [evmAccount, smartAccount, options]);
|
2013
|
+
useEffect5(() => {
|
2014
|
+
if (accounts.length === 0) {
|
2015
|
+
closeConnectModal();
|
2016
|
+
closeSignModal();
|
2017
|
+
if (eventUtils_default.listenerCount("sendUserOpResult" /* sendUserOpResult */) > 0) {
|
2018
|
+
eventUtils_default.emit("sendUserOpResult" /* sendUserOpResult */, {
|
2019
|
+
error: {
|
2020
|
+
code: -32600,
|
2021
|
+
message: "Wallet disconnected"
|
2022
|
+
}
|
2023
|
+
});
|
2024
|
+
} else if (eventUtils_default.listenerCount("personalSignResult" /* personalSignResult */) > 0) {
|
2025
|
+
eventUtils_default.emit("personalSignResult" /* personalSignResult */, {
|
2026
|
+
error: {
|
2027
|
+
code: -32600,
|
2028
|
+
message: "Wallet disconnected"
|
2029
|
+
}
|
2030
|
+
});
|
2031
|
+
} else if (eventUtils_default.listenerCount("signTypedDataResult" /* signTypedDataResult */) > 0) {
|
2032
|
+
eventUtils_default.emit("signTypedDataResult" /* signTypedDataResult */, {
|
2033
|
+
error: {
|
2034
|
+
code: -32600,
|
2035
|
+
message: "Wallet disconnected"
|
2036
|
+
}
|
2037
|
+
});
|
2038
|
+
}
|
2039
|
+
}
|
2040
|
+
}, [accounts, closeConnectModal, closeSignModal]);
|
2041
|
+
return /* @__PURE__ */ jsxs6(
|
2042
|
+
ConnectContext.Provider,
|
2043
|
+
{
|
2044
|
+
value: {
|
2045
|
+
connectorId,
|
2046
|
+
setConnectorId,
|
2047
|
+
connector,
|
2048
|
+
connectors,
|
2049
|
+
openConnectModal,
|
2050
|
+
closeConnectModal,
|
2051
|
+
accounts,
|
2052
|
+
provider,
|
2053
|
+
disconnect,
|
2054
|
+
getPublicKey,
|
2055
|
+
signMessage,
|
2056
|
+
evmAccount,
|
2057
|
+
smartAccount,
|
2058
|
+
getNetwork,
|
2059
|
+
switchNetwork,
|
2060
|
+
sendBitcoin,
|
2061
|
+
accountContract,
|
2062
|
+
setAccountContract,
|
2063
|
+
getSmartAccountInfo
|
2064
|
+
},
|
2065
|
+
children: [
|
2066
|
+
children,
|
2067
|
+
/* @__PURE__ */ jsx9(connectModal_default, { open: connectModalOpen, onClose: closeConnectModal }),
|
2068
|
+
/* @__PURE__ */ jsx9(signModal_default, { open: signModalOpen, onClose: closeSignModal, onOpen: openSignModal })
|
2069
|
+
]
|
2070
|
+
}
|
2071
|
+
);
|
2072
|
+
};
|
2073
|
+
var useConnectProvider = () => {
|
2074
|
+
const context = useContext(ConnectContext);
|
2075
|
+
return context;
|
2076
|
+
};
|
2077
|
+
|
2078
|
+
// src/components/btcWalletSelectorContext.tsx
|
2079
|
+
import React, { useContext as useContext2, useEffect as useEffect6, useMemo as useMemo6, useRef, useState as useState8 } from "react";
|
2080
|
+
|
2081
|
+
// src/components/confirmBox/Modal.tsx
|
2082
|
+
import { jsx as jsx10, jsxs as jsxs7 } from "react/jsx-runtime";
|
2083
|
+
function Modal2({ children, onClose, style = {} }) {
|
2084
|
+
return /* @__PURE__ */ jsxs7("div", { children: [
|
2085
|
+
/* @__PURE__ */ jsx10("div", { className: "layer" }),
|
2086
|
+
/* @__PURE__ */ jsxs7("div", { className: "modal", style, children: [
|
2087
|
+
/* @__PURE__ */ jsx10("div", { className: "close", onClick: () => {
|
2088
|
+
onClose && onClose();
|
2089
|
+
}, children: /* @__PURE__ */ jsx10("svg", { width: "12", height: "12", viewBox: "0 0 12 12", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: /* @__PURE__ */ jsx10("path", { d: "M7.73284 5.99997L11.7359 1.99698C12.0368 1.69598 12.0882 1.25928 11.8507 1.02188L10.9779 0.149088C10.7404 -0.0884114 10.3043 -0.0363117 10.0028 0.264487L6.00013 4.26737L1.99719 0.264587C1.69619 -0.0367116 1.25948 -0.0884115 1.02198 0.149388L0.149174 1.02228C-0.0882276 1.25938 -0.0368271 1.69608 0.264576 1.99708L4.26761 5.99997L0.264576 10.0032C-0.0363271 10.304 -0.0884276 10.7404 0.149174 10.9779L1.02198 11.8507C1.25948 12.0882 1.69619 12.0367 1.99719 11.7358L6.00033 7.73266L10.0029 11.7352C10.3044 12.0368 10.7405 12.0882 10.978 11.8507L11.8508 10.9779C12.0882 10.7404 12.0368 10.304 11.736 10.0028L7.73284 5.99997Z", fill: "#808095" }) }) }),
|
2090
|
+
children
|
2091
|
+
] })
|
2092
|
+
] });
|
2093
|
+
}
|
2094
|
+
|
2095
|
+
// src/components/confirmBox/index.tsx
|
2096
|
+
import { Fragment as Fragment4, jsx as jsx11, jsxs as jsxs8 } from "react/jsx-runtime";
|
2097
|
+
function ComfirmBox({ onClose, status = 1, fromChain = {
|
2098
|
+
name: "NEAR"
|
2099
|
+
}, toChain = {
|
2100
|
+
name: "BTC"
|
2101
|
+
}, hash }) {
|
2102
|
+
return /* @__PURE__ */ jsxs8(Modal2, { onClose, children: [
|
2103
|
+
/* @__PURE__ */ jsx11("div", { className: "title", children: "Transaction Detail" }),
|
2104
|
+
/* @__PURE__ */ jsx11("div", { className: "chians", children: status === 0 ? /* @__PURE__ */ jsx11("svg", { className: "loading", width: "54", height: "54", viewBox: "0 0 54 54", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: /* @__PURE__ */ jsx11("path", { d: "M52.0766 10.7867C53.0482 11.0471 53.6273 12.0399 53.3741 13.0134C53.1219 13.977 52.1361 14.5546 51.1725 14.3024L47.6172 13.3498L46.3268 18.1657C44.8261 23.7665 40.0219 27.6146 34.2721 28.6546C38.7381 32.4056 40.9681 38.1648 39.4673 43.7656L38.1769 48.5815L41.6972 49.5248C42.6655 49.7843 43.2401 50.7794 42.9806 51.7477C42.7212 52.7159 41.726 53.2905 40.7578 53.031L2.02593 42.6529L1.71657 42.5396C0.800668 42.1375 0.383843 41.0689 0.785965 40.153C1.15472 39.3126 2.09436 38.8809 2.97262 39.1481L6.52126 40.0989L7.81144 35.2839C9.31216 29.6832 14.1131 25.8341 19.8661 24.795C15.3968 21.0432 13.1702 15.2848 14.6709 9.68407L15.9615 4.86764L12.4128 3.91679C11.4445 3.65734 10.87 2.66223 11.1295 1.69395C11.3889 0.725662 12.384 0.151138 13.3523 0.410589L52.0766 10.7867ZM44.0959 12.4063L19.471 5.80801L18.1871 10.5994C17.0693 14.7711 18.671 19.3131 22.2022 22.3268C23.2549 23.2994 23.6544 24.61 23.3544 25.7297C23.0485 27.0126 21.9665 27.9627 20.6551 28.1007C16.1146 28.9516 12.432 32.0776 11.3175 36.2502L10.0214 41.0874L11.982 41.6127L12.5291 39.571C13.5385 35.8039 16.032 32.0464 21.0065 30.689L21.8135 30.4937C23.6047 30.2306 25.3145 29.1151 26.9388 27.1507C27.1931 29.441 28.1726 31.2771 29.8857 32.6567C34.4351 36.8 34.1706 41.1245 33.1094 45.0849L32.5623 47.1267L34.6428 47.6841L35.9323 42.8715C37.0501 38.6998 35.4522 34.1588 31.9215 31.1412C30.8693 30.1687 30.4684 28.8613 30.7693 27.7383C31.1136 26.4535 32.114 25.5215 33.4676 25.3711C38.0072 24.5235 41.6865 21.3966 42.8052 17.2216L44.0959 12.4063ZM40.7578 15.6185C40.1797 19.9295 35.6431 22.9023 32.7256 23.2863C30.9809 23.5169 29.1741 24.3456 27.3087 25.7742C26.4809 23.6244 25.3731 22.0143 23.9948 20.9474C21.5041 19.0198 20.6551 17.2216 20.3797 15.1185L40.7578 15.6185Z", fill: "white", "fill-opacity": "0.21" }) }) : /* @__PURE__ */ jsxs8("svg", { width: "54", height: "54", viewBox: "0 0 54 54", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: [
|
2105
|
+
/* @__PURE__ */ jsx11("circle", { cx: "27", cy: "27", r: "21", fill: "#33FFDA" }),
|
2106
|
+
/* @__PURE__ */ jsx11("circle", { cx: "27", cy: "27", r: "24", stroke: "#33FFDA", "stroke-opacity": "0.3", "stroke-width": "6" }),
|
2107
|
+
/* @__PURE__ */ jsx11("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M37.342 19.6604C38.2111 20.5494 38.2205 22.0006 37.363 22.9016L24.8987 36L17.651 28.5196C16.7858 27.6266 16.7826 26.1754 17.6439 25.2783C18.5052 24.3813 19.9048 24.378 20.77 25.271L24.8705 29.5031L34.2159 19.6822C35.0733 18.7812 36.4729 18.7714 37.342 19.6604Z", fill: "black" })
|
2108
|
+
] }) }),
|
2109
|
+
status === 0 && /* @__PURE__ */ jsxs8(Fragment4, { children: [
|
2110
|
+
/* @__PURE__ */ jsx11("div", { className: "time", children: "Est Time: 5 mins" }),
|
2111
|
+
/* @__PURE__ */ jsx11("div", { className: "processing", children: "Transaction is processing." })
|
2112
|
+
] }),
|
2113
|
+
status === 1 && /* @__PURE__ */ jsxs8(Fragment4, { children: [
|
2114
|
+
/* @__PURE__ */ jsx11("div", { className: "time", children: "Bridge Completed" }),
|
2115
|
+
/* @__PURE__ */ jsxs8("div", { className: "processing", children: [
|
2116
|
+
"You can view your transaction on the ",
|
2117
|
+
/* @__PURE__ */ jsx11("a", { href: "/history", children: "bridge transaction history." })
|
2118
|
+
] })
|
2119
|
+
] }),
|
2120
|
+
!!hash && /* @__PURE__ */ jsx11(Fragment4, { children: /* @__PURE__ */ jsxs8("div", { className: "srcBtn", onClick: () => {
|
2121
|
+
if (fromChain.name === "BTC") {
|
2122
|
+
window.open(`https://mempool.space/testnet/tx/${hash}`);
|
2123
|
+
} else if (fromChain.name === "NEAR") {
|
2124
|
+
window.open(`https://testnet.nearblocks.io/txns/${hash}`);
|
2125
|
+
}
|
2126
|
+
}, children: [
|
2127
|
+
"SRC TX ",
|
2128
|
+
/* @__PURE__ */ jsx11("svg", { width: "8", height: "8", viewBox: "0 0 8 8", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: /* @__PURE__ */ jsx11("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M5.97871 8H2.02129C0.907217 8 0 7.09294 0 5.97905V2.02095C0 0.907063 0.907217 0 2.02129 0H3.73973C3.98175 0 4.17779 0.196012 4.17779 0.437986C4.17779 0.679959 3.98175 0.875972 3.73973 0.875972H2.02129C1.71573 0.875972 1.42775 0.994931 1.21142 1.21122C0.995099 1.42751 0.87612 1.71544 0.87612 2.02095V5.97769C0.87612 6.2832 0.995099 6.57114 1.21142 6.78743C1.42775 7.00372 1.71573 7.12268 2.02129 7.12268H5.97871C6.61011 7.12268 7.12388 6.60899 7.12388 5.97769V4.12977C7.12388 3.97432 7.20771 3.82832 7.34291 3.74992C7.40916 3.71206 7.48487 3.69179 7.56194 3.69179C7.63901 3.69179 7.71472 3.71206 7.78097 3.74992C7.91617 3.82832 8 3.97296 8 4.12977V5.97769C8 7.09294 7.09414 8 5.97871 8ZM7.35223 2.78066C7.41578 2.81715 7.48879 2.83608 7.56179 2.83608C7.6348 2.83608 7.70781 2.8158 7.77271 2.7793C7.90251 2.70496 7.98228 2.56572 7.98228 2.41702V0.438001C7.98228 0.206844 7.79434 0.0189453 7.56315 0.0189453H5.58378C5.35258 0.0189453 5.16465 0.206844 5.16465 0.438001C5.16465 0.669157 5.35258 0.857056 5.58378 0.857056H6.55077L3.70328 3.70405L3.70058 3.70676C3.62658 3.7861 3.58634 3.89111 3.58835 3.99958C3.59037 4.10806 3.6345 4.21149 3.7114 4.28803C3.79117 4.36779 3.89527 4.41105 4.00749 4.41105C4.1143 4.41105 4.2157 4.37049 4.29277 4.29885L4.29412 4.2975L7.14267 1.44944V2.41838C7.14267 2.56707 7.22379 2.70631 7.35223 2.78066Z", fill: "#FF7A00" }) })
|
2129
|
+
] }) })
|
2130
|
+
] });
|
2131
|
+
}
|
2132
|
+
|
2133
|
+
// src/components/btcWalletSelectorContext.tsx
|
2134
|
+
import { jsx as jsx12, jsxs as jsxs9 } from "react/jsx-runtime";
|
2135
|
+
var WalletSelectorContext = React.createContext(null);
|
2136
|
+
function BtcWalletSelectorContextProvider({ children }) {
|
2137
|
+
const [isProcessing, setIsProcessing] = useState8(false);
|
2138
|
+
const walletSelectorContextValue = useMemo6(() => {
|
2139
|
+
return {
|
2140
|
+
setIsProcessing
|
2141
|
+
};
|
2142
|
+
}, []);
|
2143
|
+
return /* @__PURE__ */ jsx12(WalletSelectorContext.Provider, { value: walletSelectorContextValue, children: /* @__PURE__ */ jsxs9(
|
2144
|
+
ConnectProvider,
|
2145
|
+
{
|
2146
|
+
options: {
|
2147
|
+
projectId: "btc",
|
2148
|
+
clientKey: "btc",
|
2149
|
+
appId: "btc",
|
2150
|
+
aaOptions: {
|
2151
|
+
accountContracts: {
|
2152
|
+
BTC: [
|
2153
|
+
{
|
2154
|
+
chainIds: [686868],
|
2155
|
+
version: "1.0.0"
|
2156
|
+
}
|
2157
|
+
]
|
2158
|
+
}
|
2159
|
+
},
|
2160
|
+
walletOptions: {
|
2161
|
+
visible: true
|
2162
|
+
}
|
2163
|
+
},
|
2164
|
+
autoConnect: true,
|
2165
|
+
connectors: [new UnisatConnector()],
|
2166
|
+
children: [
|
2167
|
+
children,
|
2168
|
+
isProcessing && /* @__PURE__ */ jsx12(ComfirmBox, { hash: "", status: 0, onClose: () => {
|
2169
|
+
setIsProcessing(false);
|
2170
|
+
} })
|
2171
|
+
]
|
2172
|
+
}
|
2173
|
+
) });
|
2174
|
+
}
|
2175
|
+
function useBtcWalletSelector() {
|
2176
|
+
const { openConnectModal, openConnectModalAsync, disconnect } = useConnectModal();
|
2177
|
+
const { accounts, sendBitcoin, getPublicKey, provider, signMessage } = useBTCProvider();
|
2178
|
+
const publicKey = useRef(null);
|
2179
|
+
const signMessageFn = useRef(null);
|
2180
|
+
const [updater, setUpdater] = useState8(1);
|
2181
|
+
const context = useContext2(WalletSelectorContext);
|
2182
|
+
useEffect6(() => {
|
2183
|
+
if (provider) {
|
2184
|
+
getPublicKey().then((res) => {
|
2185
|
+
publicKey.current = res;
|
2186
|
+
});
|
2187
|
+
}
|
2188
|
+
}, [provider, updater]);
|
2189
|
+
useEffect6(() => {
|
2190
|
+
signMessageFn.current = signMessage;
|
2191
|
+
}, [signMessage]);
|
2192
|
+
return {
|
2193
|
+
login: () => __async(this, null, function* () {
|
2194
|
+
setUpdater(updater + 1);
|
2195
|
+
if (openConnectModal) {
|
2196
|
+
yield openConnectModal();
|
2197
|
+
}
|
2198
|
+
return null;
|
2199
|
+
}),
|
2200
|
+
logout: () => {
|
2201
|
+
disconnect && disconnect();
|
2202
|
+
},
|
2203
|
+
account: accounts && accounts.length ? accounts[0] : null,
|
2204
|
+
getPublicKey: () => __async(this, null, function* () {
|
2205
|
+
let times = 0;
|
2206
|
+
while (!publicKey.current) {
|
2207
|
+
yield sleep(1e3);
|
2208
|
+
if (times++ > 10) {
|
2209
|
+
return null;
|
2210
|
+
}
|
2211
|
+
}
|
2212
|
+
return publicKey.current;
|
2213
|
+
}),
|
2214
|
+
signMessage: (msg) => {
|
2215
|
+
return signMessageFn.current(msg);
|
2216
|
+
},
|
2217
|
+
getContext: () => {
|
2218
|
+
return context;
|
2219
|
+
}
|
2220
|
+
};
|
2221
|
+
}
|
2222
|
+
function sleep(time) {
|
2223
|
+
return new Promise(function(resolve) {
|
2224
|
+
setTimeout(resolve, time);
|
2225
|
+
});
|
2226
|
+
}
|
2227
|
+
|
2228
|
+
// src/utils/setupBTCWallet.ts
|
2229
|
+
import { providers, transactions } from "near-api-js";
|
2230
|
+
import { actionCreators } from "@near-js/transactions";
|
2231
|
+
import { PublicKey } from "near-api-js/lib/utils/key_pair";
|
2232
|
+
import { encodeTransaction } from "near-api-js/lib/transaction";
|
2233
|
+
import { baseDecode } from "@near-js/utils";
|
2234
|
+
import bs58 from "bs58";
|
2235
|
+
import { sha256 } from "js-sha256";
|
2236
|
+
|
2237
|
+
// src/utils/initWalletButton.ts
|
2238
|
+
function setupWalletButton(network, wallet, originalWallet) {
|
2239
|
+
if (document.getElementById("satoshi-wallet-button"))
|
2240
|
+
return;
|
2241
|
+
const iframe = createIframe({
|
2242
|
+
iframeUrl: network === "testnet" ? "https://wallet-dev.satoshibridge.top" : "https://wallet.satoshibridge.top",
|
2243
|
+
iframeStyle: { width: "400px", height: "650px" }
|
2244
|
+
});
|
2245
|
+
const button = createFloatingButtonWithIframe({
|
2246
|
+
openImageUrl: "https://assets.deltatrade.ai/wallet-assets/wallet-btn.png",
|
2247
|
+
closeImageUrl: "https://assets.deltatrade.ai/wallet-assets/wallet-btn-active.png",
|
2248
|
+
iframe
|
2249
|
+
});
|
2250
|
+
setupButtonClickHandler(button, iframe, wallet, originalWallet);
|
2251
|
+
}
|
2252
|
+
function createFloatingButtonWithIframe({
|
2253
|
+
openImageUrl,
|
2254
|
+
closeImageUrl,
|
2255
|
+
iframe
|
2256
|
+
}) {
|
2257
|
+
const button = document.createElement("img");
|
2258
|
+
button.id = "satoshi-wallet-button";
|
2259
|
+
button.src = openImageUrl;
|
2260
|
+
Object.assign(button.style, {
|
2261
|
+
position: "fixed",
|
2262
|
+
bottom: "20px",
|
2263
|
+
right: "20px",
|
2264
|
+
zIndex: "100000",
|
2265
|
+
width: "60px",
|
2266
|
+
height: "60px",
|
2267
|
+
borderRadius: "50%",
|
2268
|
+
cursor: "pointer",
|
2269
|
+
transition: "transform 0.15s ease"
|
2270
|
+
});
|
2271
|
+
document.body.appendChild(button);
|
2272
|
+
const iframeVisible = localStorage.getItem("iframeVisible") === "true" || localStorage.getItem("iframeVisible") === null;
|
2273
|
+
button.src = iframeVisible ? closeImageUrl : openImageUrl;
|
2274
|
+
iframe.style.display = iframeVisible ? "block" : "none";
|
2275
|
+
button.onclick = function() {
|
2276
|
+
const isCurrentlyVisible = iframe.style.display === "block";
|
2277
|
+
button.style.transform = "scale(0.8)";
|
2278
|
+
setTimeout(() => {
|
2279
|
+
button.style.transform = "scale(1)";
|
2280
|
+
}, 150);
|
2281
|
+
iframe.style.display = isCurrentlyVisible ? "none" : "block";
|
2282
|
+
button.src = isCurrentlyVisible ? openImageUrl : closeImageUrl;
|
2283
|
+
localStorage.setItem("iframeVisible", String(!isCurrentlyVisible));
|
2284
|
+
};
|
2285
|
+
return button;
|
2286
|
+
}
|
2287
|
+
function createIframe({
|
2288
|
+
iframeUrl,
|
2289
|
+
iframeStyle = {}
|
2290
|
+
}) {
|
2291
|
+
const iframe = document.createElement("iframe");
|
2292
|
+
iframe.id = "satoshi-wallet-iframe";
|
2293
|
+
iframe.src = iframeUrl;
|
2294
|
+
Object.assign(iframe.style, __spreadValues({
|
2295
|
+
position: "fixed",
|
2296
|
+
bottom: "90px",
|
2297
|
+
right: "20px",
|
2298
|
+
zIndex: "100000",
|
2299
|
+
boxShadow: "0 0 10px rgba(0, 0, 0, 0.1)",
|
2300
|
+
borderRadius: "10px",
|
2301
|
+
display: "block"
|
2302
|
+
}, iframeStyle));
|
2303
|
+
document.body.appendChild(iframe);
|
2304
|
+
return iframe;
|
2305
|
+
}
|
2306
|
+
function setupButtonClickHandler(button, iframe, wallet, originalWallet) {
|
2307
|
+
return __async(this, null, function* () {
|
2308
|
+
var _a;
|
2309
|
+
const accountId = (_a = yield wallet == null ? void 0 : wallet.getAccounts()) == null ? void 0 : _a[0].accountId;
|
2310
|
+
const originalAccountId = originalWallet.account;
|
2311
|
+
const originalPublicKey = yield originalWallet.getPublicKey();
|
2312
|
+
const iframeSrc = new URL(iframe.src);
|
2313
|
+
iframeSrc.searchParams.set("origin", window.location.origin);
|
2314
|
+
if (accountId)
|
2315
|
+
iframeSrc.searchParams.set("accountId", accountId);
|
2316
|
+
if (originalAccountId)
|
2317
|
+
iframeSrc.searchParams.set("originalAccountId", originalAccountId);
|
2318
|
+
if (originalPublicKey)
|
2319
|
+
iframeSrc.searchParams.set("originalPublicKey", originalPublicKey);
|
2320
|
+
iframe.src = iframeSrc.toString();
|
2321
|
+
window.addEventListener("message", (event) => __async(this, null, function* () {
|
2322
|
+
var _a2, _b;
|
2323
|
+
if (event.origin !== iframeSrc.origin)
|
2324
|
+
return;
|
2325
|
+
const { action, requestId, params } = event.data;
|
2326
|
+
if (action === "signAndSendTransaction") {
|
2327
|
+
try {
|
2328
|
+
const result = yield wallet.signAndSendTransaction(params);
|
2329
|
+
(_a2 = event.source) == null ? void 0 : _a2.postMessage(
|
2330
|
+
{
|
2331
|
+
requestId,
|
2332
|
+
result,
|
2333
|
+
success: true
|
2334
|
+
},
|
2335
|
+
{ targetOrigin: event.origin }
|
2336
|
+
);
|
2337
|
+
} catch (error) {
|
2338
|
+
(_b = event.source) == null ? void 0 : _b.postMessage(
|
2339
|
+
{
|
2340
|
+
requestId,
|
2341
|
+
error: error.message,
|
2342
|
+
success: false
|
2343
|
+
},
|
2344
|
+
{ targetOrigin: event.origin }
|
2345
|
+
);
|
2346
|
+
}
|
2347
|
+
}
|
2348
|
+
}));
|
2349
|
+
});
|
2350
|
+
}
|
2351
|
+
function removeWalletButton() {
|
2352
|
+
const button = document.getElementById("satoshi-wallet-button");
|
2353
|
+
button == null ? void 0 : button.remove();
|
2354
|
+
const iframe = document.getElementById("satoshi-wallet-iframe");
|
2355
|
+
iframe == null ? void 0 : iframe.remove();
|
2356
|
+
}
|
2357
|
+
|
2358
|
+
// src/utils/setupBTCWallet.ts
|
2359
|
+
var { signedDelegate, transfer, functionCall } = actionCreators;
|
2360
|
+
var base_url = "https://api.dev.satoshibridge.top/v1";
|
2361
|
+
var token = "nbtc1-nsp.testnet";
|
2362
|
+
var contractId = "dev1-nsp.testnet";
|
2363
|
+
var state = {
|
2364
|
+
saveAccount(account) {
|
2365
|
+
window.localStorage.setItem("btc-wallet-account", account);
|
2366
|
+
},
|
2367
|
+
removeAccount() {
|
2368
|
+
window.localStorage.removeItem("btc-wallet-account");
|
2369
|
+
},
|
2370
|
+
savePublicKey(publicKey) {
|
2371
|
+
window.localStorage.setItem("btc-wallet-publickey", publicKey);
|
2372
|
+
},
|
2373
|
+
removePublicKey() {
|
2374
|
+
window.localStorage.removeItem("btc-wallet-publickey");
|
2375
|
+
},
|
2376
|
+
saveBtcPublicKey(publicKey) {
|
2377
|
+
window.localStorage.setItem("btc-wallet-btc-publickey", publicKey);
|
2378
|
+
},
|
2379
|
+
removeBtcPublicKey() {
|
2380
|
+
window.localStorage.removeItem("btc-wallet-btc-publickey");
|
2381
|
+
},
|
2382
|
+
clear() {
|
2383
|
+
this.removeAccount();
|
2384
|
+
this.removePublicKey();
|
2385
|
+
this.removeBtcPublicKey();
|
2386
|
+
},
|
2387
|
+
save(account, publicKey) {
|
2388
|
+
this.saveAccount(account);
|
2389
|
+
this.savePublicKey(publicKey);
|
2390
|
+
},
|
2391
|
+
getAccount() {
|
2392
|
+
return window.localStorage.getItem("btc-wallet-account");
|
2393
|
+
},
|
2394
|
+
getPublicKey() {
|
2395
|
+
return window.localStorage.getItem("btc-wallet-publickey");
|
2396
|
+
},
|
2397
|
+
getBtcPublicKey() {
|
2398
|
+
return window.localStorage.getItem("btc-wallet-btc-publickey");
|
2399
|
+
}
|
2400
|
+
};
|
2401
|
+
var BTCWallet = (_0) => __async(void 0, [_0], function* ({
|
2402
|
+
metadata,
|
2403
|
+
options,
|
2404
|
+
store,
|
2405
|
+
emitter,
|
2406
|
+
logger,
|
2407
|
+
id,
|
2408
|
+
provider
|
2409
|
+
}) {
|
2410
|
+
const wallet = {
|
2411
|
+
signIn,
|
2412
|
+
signOut,
|
2413
|
+
getAccounts,
|
2414
|
+
verifyOwner,
|
2415
|
+
signMessage,
|
2416
|
+
signAndSendTransaction,
|
2417
|
+
signAndSendTransactions
|
2418
|
+
};
|
2419
|
+
function viewMethod(_02) {
|
2420
|
+
return __async(this, arguments, function* ({ method, args = {} }) {
|
2421
|
+
const res = yield provider.query({
|
2422
|
+
request_type: "call_function",
|
2423
|
+
account_id: contractId,
|
2424
|
+
method_name: method,
|
2425
|
+
args_base64: Buffer.from(JSON.stringify(args)).toString("base64"),
|
2426
|
+
finality: "optimistic"
|
2427
|
+
});
|
2428
|
+
return JSON.parse(Buffer.from(res.result).toString());
|
2429
|
+
});
|
2430
|
+
}
|
2431
|
+
;
|
2432
|
+
function signIn(_02) {
|
2433
|
+
return __async(this, arguments, function* ({ contractId: contractId2, methodNames }) {
|
2434
|
+
const accountId = state.getAccount();
|
2435
|
+
const publicKey = state.getPublicKey();
|
2436
|
+
const btcContext = window.btcContext;
|
2437
|
+
if (accountId && publicKey) {
|
2438
|
+
return [{
|
2439
|
+
accountId,
|
2440
|
+
publicKey
|
2441
|
+
}];
|
2442
|
+
}
|
2443
|
+
const btcAccount = yield btcContext.login();
|
2444
|
+
const btcPublicKey = yield btcContext.getPublicKey();
|
2445
|
+
const nearTempAddress = yield viewMethod({
|
2446
|
+
method: "get_chain_signature_near_account",
|
2447
|
+
args: { "btc_public_key": btcPublicKey }
|
2448
|
+
});
|
2449
|
+
const nearTempPublicKey = yield viewMethod({
|
2450
|
+
method: "get_chain_signature_near_account_public_key",
|
2451
|
+
args: { "btc_public_key": btcPublicKey }
|
2452
|
+
});
|
2453
|
+
state.saveAccount(nearTempAddress);
|
2454
|
+
state.savePublicKey(nearTempPublicKey);
|
2455
|
+
state.saveBtcPublicKey(btcPublicKey);
|
2456
|
+
return [
|
2457
|
+
{
|
2458
|
+
accountId: nearTempAddress,
|
2459
|
+
publicKey: nearTempPublicKey
|
2460
|
+
}
|
2461
|
+
];
|
2462
|
+
});
|
2463
|
+
}
|
2464
|
+
function signOut() {
|
2465
|
+
return __async(this, null, function* () {
|
2466
|
+
const btcContext = window.btcContext;
|
2467
|
+
btcContext.logout();
|
2468
|
+
state.clear();
|
2469
|
+
window.localStorage.removeItem("near-wallet-selector:selectedWalletId");
|
2470
|
+
removeWalletButton();
|
2471
|
+
});
|
2472
|
+
}
|
2473
|
+
function getAccounts() {
|
2474
|
+
return __async(this, null, function* () {
|
2475
|
+
const accountId = state.getAccount();
|
2476
|
+
initWalletButton(options.network.networkId, accountId, wallet);
|
2477
|
+
return [{ accountId: state.getAccount() }];
|
2478
|
+
});
|
2479
|
+
}
|
2480
|
+
function verifyOwner() {
|
2481
|
+
return __async(this, null, function* () {
|
2482
|
+
throw new Error(`Method not supported by ${metadata.name}`);
|
2483
|
+
});
|
2484
|
+
}
|
2485
|
+
function signMessage() {
|
2486
|
+
return __async(this, null, function* () {
|
2487
|
+
throw new Error(`Method not supported by ${metadata.name}`);
|
2488
|
+
});
|
2489
|
+
}
|
2490
|
+
function signAndSendTransaction(_02) {
|
2491
|
+
return __async(this, arguments, function* ({ signerId, receiverId, actions }) {
|
2492
|
+
const btcContext = window.btcContext;
|
2493
|
+
const accountId = state.getAccount();
|
2494
|
+
const publicKey = state.getPublicKey();
|
2495
|
+
const newActions = actions.map((action) => {
|
2496
|
+
switch (action.type) {
|
2497
|
+
case "FunctionCall":
|
2498
|
+
return functionCall(action.params.methodName, action.params.args, action.params.gas, action.params.deposit);
|
2499
|
+
case "Transfer":
|
2500
|
+
return transfer(action.params.deposit);
|
2501
|
+
}
|
2502
|
+
});
|
2503
|
+
const { header } = yield provider.block({ finality: "final" });
|
2504
|
+
const rawAccessKey = yield provider.query({
|
2505
|
+
request_type: "view_access_key",
|
2506
|
+
account_id: accountId,
|
2507
|
+
public_key: publicKey,
|
2508
|
+
finality: "final"
|
2509
|
+
});
|
2510
|
+
const accessKey = __spreadProps(__spreadValues({}, rawAccessKey), {
|
2511
|
+
nonce: BigInt(rawAccessKey.nonce || 0)
|
2512
|
+
});
|
2513
|
+
const publicKeyFromat = PublicKey.from(publicKey);
|
2514
|
+
let nearNonceNumber = accessKey.nonce + BigInt(1);
|
2515
|
+
const nearNonceApi = yield getNearNonceFromApi(accountId);
|
2516
|
+
if (nearNonceApi) {
|
2517
|
+
nearNonceNumber = nearNonceApi.result_data && Number(nearNonceApi.result_data) > 0 ? BigInt(Number(nearNonceApi.result_data)) : accessKey.nonce + BigInt(1);
|
2518
|
+
}
|
2519
|
+
const _transiton = yield transactions.createTransaction(
|
2520
|
+
accountId,
|
2521
|
+
publicKeyFromat,
|
2522
|
+
receiverId,
|
2523
|
+
nearNonceNumber,
|
2524
|
+
newActions,
|
2525
|
+
baseDecode(header.hash)
|
2526
|
+
);
|
2527
|
+
const tx_bytes = encodeTransaction(_transiton);
|
2528
|
+
const hash = bs58.encode(new Uint8Array(sha256.array(tx_bytes)));
|
2529
|
+
const accountInfo = yield viewMethod({
|
2530
|
+
method: "get_account",
|
2531
|
+
args: { "account_id": accountId }
|
2532
|
+
});
|
2533
|
+
const nonceApi = yield getNonceFromApi(accountId);
|
2534
|
+
const nonce = (nonceApi == null ? void 0 : nonceApi.result_data) ? Number(nonceApi == null ? void 0 : nonceApi.result_data) : accountInfo.nonce;
|
2535
|
+
const outcome = {
|
2536
|
+
near_transactions: Array.from(tx_bytes),
|
2537
|
+
nonce: Number(nonce),
|
2538
|
+
chain_id: 397,
|
2539
|
+
csna: accountId,
|
2540
|
+
btcPublicKey: state.getBtcPublicKey(),
|
2541
|
+
nearPublicKey: publicKey
|
2542
|
+
};
|
2543
|
+
const intention = {
|
2544
|
+
chain_id: outcome.chain_id.toString(),
|
2545
|
+
csna: outcome.csna,
|
2546
|
+
near_transactions: [outcome.near_transactions],
|
2547
|
+
"gas_token": token,
|
2548
|
+
"gas_limit": "3000",
|
2549
|
+
nonce: Number(outcome.nonce).toString()
|
2550
|
+
};
|
2551
|
+
const strIntention = JSON.stringify(intention);
|
2552
|
+
const signature = yield btcContext.signMessage(strIntention);
|
2553
|
+
const result = yield uploadCAWithdraw({
|
2554
|
+
sig: signature,
|
2555
|
+
btcPubKey: outcome.btcPublicKey,
|
2556
|
+
data: toHex(strIntention),
|
2557
|
+
near_nonce: [Number(nearNonceNumber)]
|
2558
|
+
});
|
2559
|
+
if (result.result_code === 0) {
|
2560
|
+
const result2 = yield pollTransactionStatus(options.network.networkId, hash);
|
2561
|
+
return result2;
|
2562
|
+
} else {
|
2563
|
+
return null;
|
2564
|
+
}
|
2565
|
+
});
|
2566
|
+
}
|
2567
|
+
function signAndSendTransactions(_02) {
|
2568
|
+
return __async(this, arguments, function* ({ transactions: transactions2 }) {
|
2569
|
+
const result = yield Promise.all(transactions2.map(
|
2570
|
+
(transaction) => __async(this, null, function* () {
|
2571
|
+
return yield signAndSendTransaction(transaction);
|
2572
|
+
})
|
2573
|
+
));
|
2574
|
+
return result;
|
2575
|
+
});
|
2576
|
+
}
|
2577
|
+
return wallet;
|
2578
|
+
});
|
2579
|
+
function getNonceFromApi(accountId) {
|
2580
|
+
return fetch(`${base_url}/nonce?csna=${accountId}`, {
|
2581
|
+
method: "GET",
|
2582
|
+
headers: {
|
2583
|
+
"Content-Type": "application/json"
|
2584
|
+
}
|
2585
|
+
}).then((res) => res.json());
|
2586
|
+
}
|
2587
|
+
function getNearNonceFromApi(accountId) {
|
2588
|
+
return fetch(`${base_url}/nonceNear?csna=${accountId}`, {
|
2589
|
+
method: "GET",
|
2590
|
+
headers: {
|
2591
|
+
"Content-Type": "application/json"
|
2592
|
+
}
|
2593
|
+
}).then((res) => res.json());
|
2594
|
+
}
|
2595
|
+
function uploadCAWithdraw(data) {
|
2596
|
+
return fetch(`${base_url}/receiveTransaction`, {
|
2597
|
+
method: "POST",
|
2598
|
+
headers: {
|
2599
|
+
"Content-Type": "application/json"
|
2600
|
+
},
|
2601
|
+
body: JSON.stringify(data)
|
2602
|
+
}).then((res) => res.json());
|
2603
|
+
}
|
2604
|
+
function setupBTCWallet({
|
2605
|
+
iconUrl = "https://assets.deltatrade.ai/assets/chain/btc.svg",
|
2606
|
+
deprecated = false,
|
2607
|
+
btcContext
|
2608
|
+
}) {
|
2609
|
+
const btcWallet = () => __async(this, null, function* () {
|
2610
|
+
return {
|
2611
|
+
id: "btc-wallet",
|
2612
|
+
type: "injected",
|
2613
|
+
metadata: {
|
2614
|
+
name: "BTC Wallet",
|
2615
|
+
description: "BTC Wallet",
|
2616
|
+
iconUrl,
|
2617
|
+
downloadUrl: iconUrl,
|
2618
|
+
deprecated,
|
2619
|
+
available: true,
|
2620
|
+
btcContext
|
2621
|
+
},
|
2622
|
+
init: BTCWallet
|
2623
|
+
};
|
2624
|
+
});
|
2625
|
+
return btcWallet;
|
2626
|
+
}
|
2627
|
+
function toHex(originalString) {
|
2628
|
+
let charArray = originalString.split("");
|
2629
|
+
let asciiArray = charArray.map((char) => char.charCodeAt(0));
|
2630
|
+
let hexArray = asciiArray.map((code) => code.toString(16));
|
2631
|
+
let hexString = hexArray.join("");
|
2632
|
+
hexString = hexString.replace(/(^0+)/g, "");
|
2633
|
+
return hexString;
|
2634
|
+
}
|
2635
|
+
function initWalletButton(network, accountId, wallet) {
|
2636
|
+
const checkAndSetupWalletButton = () => {
|
2637
|
+
if (accountId && window.btcContext.account) {
|
2638
|
+
setupWalletButton(network, wallet, window.btcContext);
|
2639
|
+
} else {
|
2640
|
+
removeWalletButton();
|
2641
|
+
setTimeout(() => {
|
2642
|
+
checkAndSetupWalletButton();
|
2643
|
+
}, 5e3);
|
2644
|
+
}
|
2645
|
+
};
|
2646
|
+
checkAndSetupWalletButton();
|
2647
|
+
}
|
2648
|
+
var rcpUrls = {
|
2649
|
+
mainnet: ["https://near.lava.build", "https://rpc.mainnet.near.org", "https://free.rpc.fastnear.com", "https://near.drpc.org"],
|
2650
|
+
testnet: ["https://near-testnet.lava.build", "https://rpc.testnet.near.org", "https://near-testnet.drpc.org"]
|
2651
|
+
};
|
2652
|
+
function delay(ms) {
|
2653
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
2654
|
+
}
|
2655
|
+
function pollTransactionStatus(network, hash) {
|
2656
|
+
return __async(this, null, function* () {
|
2657
|
+
const provider = new providers.FailoverRpcProvider(
|
2658
|
+
Object.values(rcpUrls[network]).map(
|
2659
|
+
(url) => new providers.JsonRpcProvider({ url })
|
2660
|
+
)
|
2661
|
+
);
|
2662
|
+
const maxAttempts = 3;
|
2663
|
+
let attempt = 0;
|
2664
|
+
while (attempt < maxAttempts) {
|
2665
|
+
attempt++;
|
2666
|
+
const result = yield provider.txStatus(hash, "unused", "FINAL").catch((error) => {
|
2667
|
+
if (attempt === maxAttempts) {
|
2668
|
+
throw new Error(`Transaction not found: ${hash}`);
|
2669
|
+
}
|
2670
|
+
return;
|
2671
|
+
});
|
2672
|
+
if (result && result.status) {
|
2673
|
+
return result;
|
2674
|
+
}
|
2675
|
+
yield delay(1e4);
|
2676
|
+
}
|
2677
|
+
});
|
2678
|
+
}
|
2679
|
+
|
2680
|
+
// src/components/hook.tsx
|
2681
|
+
import { useEffect as useEffect7 } from "react";
|
2682
|
+
function InitContextHook() {
|
2683
|
+
const btcContext = useBtcWalletSelector();
|
2684
|
+
useEffect7(() => {
|
2685
|
+
window.btcContext = btcContext;
|
2686
|
+
}, [btcContext]);
|
2687
|
+
return null;
|
2688
|
+
}
|
2689
|
+
|
2690
|
+
// src/index.ts
|
2691
|
+
var getVersion = () => {
|
2692
|
+
return "0.0.1";
|
2693
|
+
};
|
2694
|
+
if (typeof window !== "undefined") {
|
2695
|
+
window.__PARTICLE_BTC_CONNECT_VERSION = getVersion();
|
2696
|
+
}
|
2697
|
+
export {
|
2698
|
+
BaseConnector,
|
2699
|
+
BitgetConnector,
|
2700
|
+
BtcWalletSelectorContextProvider,
|
2701
|
+
BybitConnector,
|
2702
|
+
ConnectProvider,
|
2703
|
+
InitContextHook,
|
2704
|
+
InjectedConnector,
|
2705
|
+
OKXConnector,
|
2706
|
+
TokenPocketConnector,
|
2707
|
+
UnisatConnector,
|
2708
|
+
WizzConnector,
|
2709
|
+
XverseConnector,
|
2710
|
+
getVersion,
|
2711
|
+
setupBTCWallet,
|
2712
|
+
useAccountContract,
|
2713
|
+
useAccounts,
|
2714
|
+
useBTCProvider,
|
2715
|
+
useBtcWalletSelector,
|
2716
|
+
useConnectModal,
|
2717
|
+
useConnector,
|
2718
|
+
useETHProvider
|
2719
|
+
};
|
2720
|
+
//# sourceMappingURL=index.js.map
|