btc-wallet 0.4.7-beta → 0.5.0-beta
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +34 -15
- package/dist/connector/binance.d.ts +6 -0
- package/dist/connector/index.d.ts +1 -0
- package/dist/connector/injected.d.ts +1 -0
- package/dist/connector/universalLink.d.ts +8 -0
- package/dist/core/btcUtils.d.ts +0 -6
- package/dist/evmSigner/index.d.ts +20 -20
- package/dist/index.js +438 -327
- package/dist/index.js.map +4 -4
- package/dist/utils/index.d.ts +1 -0
- package/esm/index.js +436 -325
- package/esm/index.js.map +4 -4
- package/package.json +1 -1
package/dist/index.js
CHANGED
@@ -79,6 +79,7 @@ var __async = (__this, __arguments, generator) => {
|
|
79
79
|
var src_exports = {};
|
80
80
|
__export(src_exports, {
|
81
81
|
BaseConnector: () => BaseConnector,
|
82
|
+
BinanceConnector: () => BinanceConnector,
|
82
83
|
BitgetConnector: () => BitgetConnector,
|
83
84
|
BtcWalletSelectorContextProvider: () => BtcWalletSelectorContextProvider,
|
84
85
|
BybitConnector: () => BybitConnector,
|
@@ -122,6 +123,346 @@ var BaseConnector = class {
|
|
122
123
|
// src/icons/bitget.png
|
123
124
|
var bitget_default = "";
|
124
125
|
|
126
|
+
// src/utils/index.ts
|
127
|
+
function shortString(str) {
|
128
|
+
if (Array.isArray(str)) {
|
129
|
+
str = "[" + str.toString() + "]";
|
130
|
+
}
|
131
|
+
if (str) {
|
132
|
+
if (typeof str.toString === "function") {
|
133
|
+
str = str.toString();
|
134
|
+
}
|
135
|
+
if (str.length <= 10) {
|
136
|
+
return str;
|
137
|
+
}
|
138
|
+
return `${str.slice(0, 5)}...${str.slice(str.length - 5, str.length)}`;
|
139
|
+
}
|
140
|
+
return "";
|
141
|
+
}
|
142
|
+
function copyToClipboard(text) {
|
143
|
+
return __async(this, null, function* () {
|
144
|
+
const clipboardCopy = () => __async(this, null, function* () {
|
145
|
+
if (navigator.clipboard) {
|
146
|
+
return navigator.clipboard.writeText(text);
|
147
|
+
} else {
|
148
|
+
const textarea = document.createElement("textarea");
|
149
|
+
textarea.value = text;
|
150
|
+
textarea.setAttribute("readonly", "");
|
151
|
+
textarea.style.position = "absolute";
|
152
|
+
textarea.style.left = "-9999px";
|
153
|
+
document.body.appendChild(textarea);
|
154
|
+
textarea.select();
|
155
|
+
const result = document.execCommand("copy");
|
156
|
+
document.body.removeChild(textarea);
|
157
|
+
if (!result) {
|
158
|
+
throw new Error("Copy to clipboard failed");
|
159
|
+
}
|
160
|
+
}
|
161
|
+
});
|
162
|
+
return new Promise((resolve, reject) => {
|
163
|
+
clipboardCopy().then(resolve).catch(reject);
|
164
|
+
});
|
165
|
+
});
|
166
|
+
}
|
167
|
+
var defaultTokenIcon = "https://static.particle.network/token-list/defaultToken/default.png";
|
168
|
+
var ipfsToSrc = (ipfs) => {
|
169
|
+
if (!ipfs || !ipfs.startsWith("ipfs://")) {
|
170
|
+
return ipfs || "";
|
171
|
+
}
|
172
|
+
return `https://ipfs.particle.network/${encodeURI(ipfs.slice(7))}`;
|
173
|
+
};
|
174
|
+
var checkBTCVersion = (accountContracts, accountContractKey, version) => {
|
175
|
+
if (!accountContracts[accountContractKey]) {
|
176
|
+
return false;
|
177
|
+
}
|
178
|
+
return accountContracts[accountContractKey].some((item) => item.version === version);
|
179
|
+
};
|
180
|
+
var delay = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
181
|
+
function retryOperation(_0, _1) {
|
182
|
+
return __async(this, arguments, function* (operation, shouldStop, {
|
183
|
+
maxRetries = 3,
|
184
|
+
delayMs = 1e3
|
185
|
+
} = {}) {
|
186
|
+
let retries = 0;
|
187
|
+
while (retries <= maxRetries) {
|
188
|
+
const result = yield operation();
|
189
|
+
if (shouldStop(result)) {
|
190
|
+
return result;
|
191
|
+
}
|
192
|
+
if (retries === maxRetries) {
|
193
|
+
console.warn("Max retries reached");
|
194
|
+
return result;
|
195
|
+
}
|
196
|
+
retries++;
|
197
|
+
yield delay(delayMs);
|
198
|
+
}
|
199
|
+
throw new Error("Unexpected execution path");
|
200
|
+
});
|
201
|
+
}
|
202
|
+
function toHex(originalString) {
|
203
|
+
const charArray = originalString.split("");
|
204
|
+
const asciiArray = charArray.map((char) => char.charCodeAt(0));
|
205
|
+
const hexArray = asciiArray.map((code) => code.toString(16));
|
206
|
+
let hexString = hexArray.join("");
|
207
|
+
hexString = hexString.replace(/(^0+)/g, "");
|
208
|
+
return hexString;
|
209
|
+
}
|
210
|
+
function isMobile() {
|
211
|
+
if (typeof window !== "undefined") {
|
212
|
+
return /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(
|
213
|
+
navigator == null ? void 0 : navigator.userAgent
|
214
|
+
);
|
215
|
+
}
|
216
|
+
return false;
|
217
|
+
}
|
218
|
+
|
219
|
+
// src/utils/Dialog.ts
|
220
|
+
var Dialog = class {
|
221
|
+
static injectStyles() {
|
222
|
+
if (!document.querySelector("#dialog-styles")) {
|
223
|
+
const styleSheet = document.createElement("style");
|
224
|
+
styleSheet.id = "dialog-styles";
|
225
|
+
styleSheet.textContent = this.style;
|
226
|
+
document.head.appendChild(styleSheet);
|
227
|
+
}
|
228
|
+
}
|
229
|
+
static confirm(options) {
|
230
|
+
return new Promise((resolve) => {
|
231
|
+
this.injectStyles();
|
232
|
+
const container = document.createElement("div");
|
233
|
+
container.innerHTML = this.template;
|
234
|
+
document.body.appendChild(container);
|
235
|
+
const titleEl = container.querySelector(".dialog-title");
|
236
|
+
const messageEl = container.querySelector(".dialog-message");
|
237
|
+
const confirmBtn = container.querySelector(".dialog-confirm-btn");
|
238
|
+
const cancelBtn = container.querySelector(".dialog-cancel-btn");
|
239
|
+
if (options.title) {
|
240
|
+
titleEl.textContent = options.title;
|
241
|
+
} else {
|
242
|
+
titleEl.style.display = "none";
|
243
|
+
}
|
244
|
+
messageEl.textContent = options.message;
|
245
|
+
const cleanup = () => {
|
246
|
+
document.body.removeChild(container);
|
247
|
+
};
|
248
|
+
confirmBtn.addEventListener("click", () => {
|
249
|
+
cleanup();
|
250
|
+
resolve(true);
|
251
|
+
});
|
252
|
+
cancelBtn.addEventListener("click", () => {
|
253
|
+
cleanup();
|
254
|
+
resolve(false);
|
255
|
+
});
|
256
|
+
});
|
257
|
+
}
|
258
|
+
static alert(options) {
|
259
|
+
const messageEl = options.dangerouslyUseHTML ? { dangerouslySetInnerHTML: { __html: options.message } } : { children: options.message };
|
260
|
+
return new Promise((resolve) => {
|
261
|
+
var _a;
|
262
|
+
this.injectStyles();
|
263
|
+
const container = document.createElement("div");
|
264
|
+
container.innerHTML = this.template;
|
265
|
+
(_a = container.querySelector(".dialog-overlay")) == null ? void 0 : _a.classList.add("dialog-alert");
|
266
|
+
if (options.closable === false) {
|
267
|
+
const overlay = container.querySelector(".dialog-overlay");
|
268
|
+
overlay.style.pointerEvents = "none";
|
269
|
+
const dialogContainer = container.querySelector(".dialog-container");
|
270
|
+
dialogContainer.style.pointerEvents = "auto";
|
271
|
+
}
|
272
|
+
document.body.appendChild(container);
|
273
|
+
const titleEl = container.querySelector(".dialog-title");
|
274
|
+
const messageEl2 = container.querySelector(".dialog-message");
|
275
|
+
const confirmBtn = container.querySelector(".dialog-confirm-btn");
|
276
|
+
const cancelBtn = container.querySelector(".dialog-cancel-btn");
|
277
|
+
if (options.title) {
|
278
|
+
titleEl.textContent = options.title;
|
279
|
+
} else {
|
280
|
+
titleEl.style.display = "none";
|
281
|
+
}
|
282
|
+
messageEl2.innerHTML = options.message;
|
283
|
+
cancelBtn.style.display = "none";
|
284
|
+
if (options.closable === false) {
|
285
|
+
confirmBtn.style.display = "none";
|
286
|
+
}
|
287
|
+
const cleanup = () => {
|
288
|
+
if (options.closable === false) {
|
289
|
+
return;
|
290
|
+
}
|
291
|
+
document.body.removeChild(container);
|
292
|
+
};
|
293
|
+
confirmBtn.addEventListener("click", () => {
|
294
|
+
cleanup();
|
295
|
+
resolve();
|
296
|
+
});
|
297
|
+
});
|
298
|
+
}
|
299
|
+
};
|
300
|
+
Dialog.template = `
|
301
|
+
<div class="dialog-overlay">
|
302
|
+
<div class="dialog-container">
|
303
|
+
<div class="dialog-content">
|
304
|
+
<div class="dialog-title"></div>
|
305
|
+
<div class="dialog-message"></div>
|
306
|
+
<div class="dialog-buttons">
|
307
|
+
<button class="dialog-cancel-btn">Cancel</button>
|
308
|
+
<button class="dialog-confirm-btn">OK</button>
|
309
|
+
</div>
|
310
|
+
</div>
|
311
|
+
</div>
|
312
|
+
</div>
|
313
|
+
`;
|
314
|
+
Dialog.style = `
|
315
|
+
.dialog-overlay {
|
316
|
+
position: fixed;
|
317
|
+
top: 0;
|
318
|
+
left: 0;
|
319
|
+
right: 0;
|
320
|
+
bottom: 0;
|
321
|
+
background-color: rgba(0, 0, 0, 0.75);
|
322
|
+
display: flex;
|
323
|
+
align-items: center;
|
324
|
+
justify-content: center;
|
325
|
+
z-index: 999999;
|
326
|
+
backdrop-filter: blur(4px);
|
327
|
+
}
|
328
|
+
.dialog-container {
|
329
|
+
background: #21232f;
|
330
|
+
border-radius: 12px;
|
331
|
+
padding: 24px;
|
332
|
+
width: 350px;
|
333
|
+
box-shadow: 0 4px 24px rgba(0, 0, 0, 0.3);
|
334
|
+
}
|
335
|
+
.dialog-title {
|
336
|
+
font-size: 18px;
|
337
|
+
font-weight: 600;
|
338
|
+
margin-bottom: 16px;
|
339
|
+
color: #ffffff;
|
340
|
+
}
|
341
|
+
.dialog-message {
|
342
|
+
margin-bottom: 24px;
|
343
|
+
line-height: 1.6;
|
344
|
+
color: rgba(255, 255, 255, 0.8);
|
345
|
+
font-size: 14px;
|
346
|
+
}
|
347
|
+
.dialog-buttons {
|
348
|
+
display: flex;
|
349
|
+
justify-content: flex-end;
|
350
|
+
gap: 12px;
|
351
|
+
}
|
352
|
+
.dialog-alert .dialog-buttons {
|
353
|
+
justify-content: center;
|
354
|
+
}
|
355
|
+
.dialog-confirm-btn {
|
356
|
+
padding: 8px 24px;
|
357
|
+
background-color: #ff7a00;
|
358
|
+
color: white;
|
359
|
+
border: none;
|
360
|
+
border-radius: 6px;
|
361
|
+
cursor: pointer;
|
362
|
+
font-size: 14px;
|
363
|
+
font-weight: 500;
|
364
|
+
transition: all 0.2s ease;
|
365
|
+
}
|
366
|
+
.dialog-confirm-btn:hover {
|
367
|
+
background-color: #ff8f1f;
|
368
|
+
transform: translateY(-1px);
|
369
|
+
}
|
370
|
+
.dialog-confirm-btn:active {
|
371
|
+
transform: translateY(0);
|
372
|
+
}
|
373
|
+
.dialog-cancel-btn {
|
374
|
+
padding: 8px 24px;
|
375
|
+
background-color: rgba(255, 255, 255, 0.1);
|
376
|
+
color: rgba(255, 255, 255, 0.8);
|
377
|
+
border: none;
|
378
|
+
border-radius: 6px;
|
379
|
+
cursor: pointer;
|
380
|
+
font-size: 14px;
|
381
|
+
font-weight: 500;
|
382
|
+
transition: all 0.2s ease;
|
383
|
+
}
|
384
|
+
.dialog-cancel-btn:hover {
|
385
|
+
background-color: rgba(255, 255, 255, 0.15);
|
386
|
+
transform: translateY(-1px);
|
387
|
+
}
|
388
|
+
.dialog-cancel-btn:active {
|
389
|
+
transform: translateY(0);
|
390
|
+
}
|
391
|
+
|
392
|
+
.dialog-overlay {
|
393
|
+
animation: fadeIn 0.2s ease;
|
394
|
+
}
|
395
|
+
.dialog-container {
|
396
|
+
animation: slideIn 0.2s ease;
|
397
|
+
}
|
398
|
+
@keyframes fadeIn {
|
399
|
+
from {
|
400
|
+
opacity: 0;
|
401
|
+
}
|
402
|
+
to {
|
403
|
+
opacity: 1;
|
404
|
+
}
|
405
|
+
}
|
406
|
+
@keyframes slideIn {
|
407
|
+
from {
|
408
|
+
transform: translateY(-20px);
|
409
|
+
opacity: 0;
|
410
|
+
}
|
411
|
+
to {
|
412
|
+
transform: translateY(0);
|
413
|
+
opacity: 1;
|
414
|
+
}
|
415
|
+
}
|
416
|
+
`;
|
417
|
+
|
418
|
+
// src/connector/universalLink.ts
|
419
|
+
var MobileWalletConnect = class {
|
420
|
+
static getUniversalLink(walletId, url) {
|
421
|
+
switch (walletId) {
|
422
|
+
case "okx":
|
423
|
+
return `okx://wallet/dapp/url?dappUrl=${encodeURIComponent(url)}`;
|
424
|
+
case "bitget":
|
425
|
+
return `https://bkcode.vip?action=dapp&url=${encodeURIComponent(url)}`;
|
426
|
+
case "xverse":
|
427
|
+
return `xverse://browser?url=${encodeURIComponent(url)}`;
|
428
|
+
default:
|
429
|
+
return "";
|
430
|
+
}
|
431
|
+
}
|
432
|
+
static redirectToWallet(walletId) {
|
433
|
+
return __async(this, null, function* () {
|
434
|
+
var _a;
|
435
|
+
if (isMobile()) {
|
436
|
+
const currentUrl = window.location.href;
|
437
|
+
const universalLink = this.getUniversalLink(walletId, currentUrl);
|
438
|
+
if (!universalLink) {
|
439
|
+
try {
|
440
|
+
yield (_a = navigator.clipboard) == null ? void 0 : _a.writeText(currentUrl);
|
441
|
+
} catch (error) {
|
442
|
+
console.error(error);
|
443
|
+
}
|
444
|
+
yield Dialog.alert({
|
445
|
+
title: "Open in Wallet Browser",
|
446
|
+
message: `
|
447
|
+
<div style="display: flex; flex-direction: column; gap: 12px;">
|
448
|
+
<p>Please follow these steps:</p>
|
449
|
+
<p>1. Open ${walletId} wallet app</p>
|
450
|
+
<p>2. Find the browser feature in the wallet</p>
|
451
|
+
<p>3. Paste the URL (already copied to clipboard)</p>
|
452
|
+
</div>
|
453
|
+
`,
|
454
|
+
dangerouslyUseHTML: true
|
455
|
+
});
|
456
|
+
return false;
|
457
|
+
}
|
458
|
+
window.location.href = universalLink;
|
459
|
+
return true;
|
460
|
+
}
|
461
|
+
return false;
|
462
|
+
});
|
463
|
+
}
|
464
|
+
};
|
465
|
+
|
125
466
|
// src/connector/injected.ts
|
126
467
|
var InjectedConnector = class extends BaseConnector {
|
127
468
|
constructor(propertity) {
|
@@ -137,21 +478,50 @@ var InjectedConnector = class extends BaseConnector {
|
|
137
478
|
if (typeof window !== "undefined") {
|
138
479
|
const props = this.propertity.split(".");
|
139
480
|
if (props.length === 1) {
|
140
|
-
|
481
|
+
if (typeof window[props[0]] !== "undefined") {
|
482
|
+
return true;
|
483
|
+
}
|
141
484
|
} else {
|
142
|
-
|
485
|
+
if (typeof window[props[0]] !== "undefined" && typeof window[props[0]][props[1]] !== "undefined") {
|
486
|
+
return true;
|
487
|
+
}
|
488
|
+
}
|
489
|
+
if (isMobile()) {
|
490
|
+
return true;
|
143
491
|
}
|
144
492
|
}
|
145
493
|
return false;
|
146
494
|
}
|
147
495
|
requestAccounts() {
|
148
496
|
return __async(this, null, function* () {
|
497
|
+
if (isMobile() && !this.getProvider()) {
|
498
|
+
MobileWalletConnect.redirectToWallet(this.metadata.id);
|
499
|
+
return [];
|
500
|
+
}
|
149
501
|
const accounts = yield this.getProviderOrThrow().requestAccounts();
|
150
502
|
console.log("network:", yield this.getNetwork());
|
151
503
|
console.log("\u{1F680} ~ InjectedConnector ~ requestAccounts ~ accounts:", accounts);
|
152
504
|
return accounts;
|
153
505
|
});
|
154
506
|
}
|
507
|
+
getUniversalLink(url) {
|
508
|
+
url = "https://www.deltatrade.ai/";
|
509
|
+
console.log(this.metadata.id);
|
510
|
+
switch (this.metadata.id) {
|
511
|
+
case "unisat":
|
512
|
+
return `unisat://dapp?url=${encodeURIComponent(url)}`;
|
513
|
+
case "okx":
|
514
|
+
return `okx://wallet/dapp/url?dappUrl=${encodeURIComponent(url)}`;
|
515
|
+
case "bitget":
|
516
|
+
return `https://bkcode.vip?action=dapp&url=${encodeURIComponent(url)}`;
|
517
|
+
case "binance":
|
518
|
+
return `binance://dapp?url=${encodeURIComponent(url)}`;
|
519
|
+
case "xverse":
|
520
|
+
return `https://connect.xverse.app/browser?url=${encodeURIComponent(url)}`;
|
521
|
+
default:
|
522
|
+
return url;
|
523
|
+
}
|
524
|
+
}
|
155
525
|
getAccounts() {
|
156
526
|
return __async(this, null, function* () {
|
157
527
|
const accounts = yield this.getProviderOrThrow().getAccounts();
|
@@ -368,7 +738,13 @@ var XverseConnector = class extends BaseConnector {
|
|
368
738
|
__privateGet(this, _event).setMaxListeners(100);
|
369
739
|
}
|
370
740
|
isReady() {
|
371
|
-
|
741
|
+
if (typeof window !== "undefined") {
|
742
|
+
if (typeof window.BitcoinProvider !== "undefined")
|
743
|
+
return true;
|
744
|
+
if (isMobile())
|
745
|
+
return true;
|
746
|
+
}
|
747
|
+
return false;
|
372
748
|
}
|
373
749
|
sendInscription() {
|
374
750
|
return __async(this, null, function* () {
|
@@ -377,8 +753,9 @@ var XverseConnector = class extends BaseConnector {
|
|
377
753
|
}
|
378
754
|
requestAccounts() {
|
379
755
|
return __async(this, null, function* () {
|
380
|
-
if (!this.
|
381
|
-
|
756
|
+
if (isMobile() && !this.getProvider()) {
|
757
|
+
MobileWalletConnect.redirectToWallet(this.metadata.id);
|
758
|
+
return [];
|
382
759
|
}
|
383
760
|
const addresses = yield this.loadAccounts(__privateGet(this, _network));
|
384
761
|
return addresses.map((item) => item.address);
|
@@ -699,6 +1076,22 @@ var MagicEdenConnector = class extends BaseConnector {
|
|
699
1076
|
_network2 = new WeakMap();
|
700
1077
|
_event2 = new WeakMap();
|
701
1078
|
|
1079
|
+
// src/icons/binance.png
|
1080
|
+
var binance_default = "";
|
1081
|
+
|
1082
|
+
// src/connector/binance.ts
|
1083
|
+
var BinanceConnector = class extends InjectedConnector {
|
1084
|
+
constructor() {
|
1085
|
+
super("binancew3w.bitcoin");
|
1086
|
+
this.metadata = {
|
1087
|
+
id: "binance",
|
1088
|
+
name: "Binance Wallet",
|
1089
|
+
icon: binance_default,
|
1090
|
+
downloadUrl: "https://www.binance.com/en/web3wallet"
|
1091
|
+
};
|
1092
|
+
}
|
1093
|
+
};
|
1094
|
+
|
702
1095
|
// src/context/index.tsx
|
703
1096
|
var import_aa = require("@particle-network/aa");
|
704
1097
|
var import_chains4 = require("@particle-network/chains");
|
@@ -1264,116 +1657,31 @@ var ConnectModal = ({ open, onClose }) => {
|
|
1264
1657
|
button_default,
|
1265
1658
|
{
|
1266
1659
|
className: connect_module_default.btnDownload,
|
1267
|
-
onClick: () => {
|
1268
|
-
window.open(selectConnector == null ? void 0 : selectConnector.metadata.downloadUrl, "_blank");
|
1269
|
-
},
|
1270
|
-
children: "Get"
|
1271
|
-
}
|
1272
|
-
)
|
1273
|
-
] })
|
1274
|
-
] })
|
1275
|
-
] });
|
1276
|
-
};
|
1277
|
-
var connectModal_default = ConnectModal;
|
1278
|
-
|
1279
|
-
// src/components/signModal/index.tsx
|
1280
|
-
var import_chains2 = require("@particle-network/chains");
|
1281
|
-
var import_react8 = require("react");
|
1282
|
-
var import_viem3 = require("viem");
|
1283
|
-
|
1284
|
-
// src/icons/check_box.svg
|
1285
|
-
var check_box_default = "";
|
1286
|
-
|
1287
|
-
// src/icons/check_box_blank.svg
|
1288
|
-
var check_box_blank_default = "";
|
1289
|
-
|
1290
|
-
// src/icons/copy.svg
|
1291
|
-
var copy_default = "";
|
1292
|
-
|
1293
|
-
// src/utils/index.ts
|
1294
|
-
function shortString(str) {
|
1295
|
-
if (Array.isArray(str)) {
|
1296
|
-
str = "[" + str.toString() + "]";
|
1297
|
-
}
|
1298
|
-
if (str) {
|
1299
|
-
if (typeof str.toString === "function") {
|
1300
|
-
str = str.toString();
|
1301
|
-
}
|
1302
|
-
if (str.length <= 10) {
|
1303
|
-
return str;
|
1304
|
-
}
|
1305
|
-
return `${str.slice(0, 5)}...${str.slice(str.length - 5, str.length)}`;
|
1306
|
-
}
|
1307
|
-
return "";
|
1308
|
-
}
|
1309
|
-
function copyToClipboard(text) {
|
1310
|
-
return __async(this, null, function* () {
|
1311
|
-
const clipboardCopy = () => __async(this, null, function* () {
|
1312
|
-
if (navigator.clipboard) {
|
1313
|
-
return navigator.clipboard.writeText(text);
|
1314
|
-
} else {
|
1315
|
-
const textarea = document.createElement("textarea");
|
1316
|
-
textarea.value = text;
|
1317
|
-
textarea.setAttribute("readonly", "");
|
1318
|
-
textarea.style.position = "absolute";
|
1319
|
-
textarea.style.left = "-9999px";
|
1320
|
-
document.body.appendChild(textarea);
|
1321
|
-
textarea.select();
|
1322
|
-
const result = document.execCommand("copy");
|
1323
|
-
document.body.removeChild(textarea);
|
1324
|
-
if (!result) {
|
1325
|
-
throw new Error("Copy to clipboard failed");
|
1326
|
-
}
|
1327
|
-
}
|
1328
|
-
});
|
1329
|
-
return new Promise((resolve, reject) => {
|
1330
|
-
clipboardCopy().then(resolve).catch(reject);
|
1331
|
-
});
|
1332
|
-
});
|
1333
|
-
}
|
1334
|
-
var defaultTokenIcon = "https://static.particle.network/token-list/defaultToken/default.png";
|
1335
|
-
var ipfsToSrc = (ipfs) => {
|
1336
|
-
if (!ipfs || !ipfs.startsWith("ipfs://")) {
|
1337
|
-
return ipfs || "";
|
1338
|
-
}
|
1339
|
-
return `https://ipfs.particle.network/${encodeURI(ipfs.slice(7))}`;
|
1340
|
-
};
|
1341
|
-
var checkBTCVersion = (accountContracts, accountContractKey, version) => {
|
1342
|
-
if (!accountContracts[accountContractKey]) {
|
1343
|
-
return false;
|
1344
|
-
}
|
1345
|
-
return accountContracts[accountContractKey].some((item) => item.version === version);
|
1660
|
+
onClick: () => {
|
1661
|
+
window.open(selectConnector == null ? void 0 : selectConnector.metadata.downloadUrl, "_blank");
|
1662
|
+
},
|
1663
|
+
children: "Get"
|
1664
|
+
}
|
1665
|
+
)
|
1666
|
+
] })
|
1667
|
+
] })
|
1668
|
+
] });
|
1346
1669
|
};
|
1347
|
-
var
|
1348
|
-
|
1349
|
-
|
1350
|
-
|
1351
|
-
|
1352
|
-
|
1353
|
-
|
1354
|
-
|
1355
|
-
|
1356
|
-
|
1357
|
-
|
1358
|
-
|
1359
|
-
|
1360
|
-
|
1361
|
-
|
1362
|
-
}
|
1363
|
-
retries++;
|
1364
|
-
yield delay(delayMs);
|
1365
|
-
}
|
1366
|
-
throw new Error("Unexpected execution path");
|
1367
|
-
});
|
1368
|
-
}
|
1369
|
-
function toHex(originalString) {
|
1370
|
-
const charArray = originalString.split("");
|
1371
|
-
const asciiArray = charArray.map((char) => char.charCodeAt(0));
|
1372
|
-
const hexArray = asciiArray.map((code) => code.toString(16));
|
1373
|
-
let hexString = hexArray.join("");
|
1374
|
-
hexString = hexString.replace(/(^0+)/g, "");
|
1375
|
-
return hexString;
|
1376
|
-
}
|
1670
|
+
var connectModal_default = ConnectModal;
|
1671
|
+
|
1672
|
+
// src/components/signModal/index.tsx
|
1673
|
+
var import_chains2 = require("@particle-network/chains");
|
1674
|
+
var import_react8 = require("react");
|
1675
|
+
var import_viem3 = require("viem");
|
1676
|
+
|
1677
|
+
// src/icons/check_box.svg
|
1678
|
+
var check_box_default = "";
|
1679
|
+
|
1680
|
+
// src/icons/check_box_blank.svg
|
1681
|
+
var check_box_blank_default = "";
|
1682
|
+
|
1683
|
+
// src/icons/copy.svg
|
1684
|
+
var copy_default = "";
|
1377
1685
|
|
1378
1686
|
// src/utils/ethereumUtils.ts
|
1379
1687
|
var import_util2 = require("@ethereumjs/util");
|
@@ -2589,7 +2897,7 @@ var import_near_api_js2 = require("near-api-js");
|
|
2589
2897
|
var import_transactions = require("@near-js/transactions");
|
2590
2898
|
var import_key_pair = require("near-api-js/lib/utils/key_pair");
|
2591
2899
|
var import_transaction = require("near-api-js/lib/transaction");
|
2592
|
-
var
|
2900
|
+
var import_utils10 = require("@near-js/utils");
|
2593
2901
|
var import_bs58 = __toESM(require("bs58"), 1);
|
2594
2902
|
var import_js_sha256 = require("js-sha256");
|
2595
2903
|
|
@@ -2617,15 +2925,15 @@ var walletConfig = {
|
|
2617
2925
|
accountContractId: "acc.toalice.near",
|
2618
2926
|
bridgeContractId: "brg.toalice.near",
|
2619
2927
|
walletUrl: "https://wallet-stg.satoshibridge.top",
|
2620
|
-
bridgeUrl: "https://ramp.satos.network
|
2928
|
+
bridgeUrl: "https://old.ramp.satos.network"
|
2621
2929
|
},
|
2622
2930
|
mainnet: {
|
2623
|
-
base_url: "https://api.
|
2624
|
-
token: "nbtc.
|
2625
|
-
accountContractId: "acc.
|
2626
|
-
bridgeContractId: "
|
2931
|
+
base_url: "https://api.satos.network",
|
2932
|
+
token: "nbtc.bridge.near",
|
2933
|
+
accountContractId: "acc.ref-labs.near",
|
2934
|
+
bridgeContractId: "btc-connector.bridge.near",
|
2627
2935
|
walletUrl: "https://wallet.satoshibridge.top",
|
2628
|
-
bridgeUrl: "https://
|
2936
|
+
bridgeUrl: "https://ramp.satos.network"
|
2629
2937
|
}
|
2630
2938
|
};
|
2631
2939
|
var nearRpcUrls = {
|
@@ -2698,6 +3006,7 @@ function createFloatingButtonWithIframe({
|
|
2698
3006
|
userSelect: "none"
|
2699
3007
|
});
|
2700
3008
|
document.body.appendChild(button);
|
3009
|
+
updateIframePosition(iframe, right, bottom, windowWidth, windowHeight);
|
2701
3010
|
let isDragging = false;
|
2702
3011
|
let startX = 0;
|
2703
3012
|
let startY = 0;
|
@@ -3129,205 +3438,6 @@ function getWhitelist(url) {
|
|
3129
3438
|
});
|
3130
3439
|
}
|
3131
3440
|
|
3132
|
-
// src/utils/Dialog.ts
|
3133
|
-
var Dialog = class {
|
3134
|
-
static injectStyles() {
|
3135
|
-
if (!document.querySelector("#dialog-styles")) {
|
3136
|
-
const styleSheet = document.createElement("style");
|
3137
|
-
styleSheet.id = "dialog-styles";
|
3138
|
-
styleSheet.textContent = this.style;
|
3139
|
-
document.head.appendChild(styleSheet);
|
3140
|
-
}
|
3141
|
-
}
|
3142
|
-
static confirm(options) {
|
3143
|
-
return new Promise((resolve) => {
|
3144
|
-
this.injectStyles();
|
3145
|
-
const container = document.createElement("div");
|
3146
|
-
container.innerHTML = this.template;
|
3147
|
-
document.body.appendChild(container);
|
3148
|
-
const titleEl = container.querySelector(".dialog-title");
|
3149
|
-
const messageEl = container.querySelector(".dialog-message");
|
3150
|
-
const confirmBtn = container.querySelector(".dialog-confirm-btn");
|
3151
|
-
const cancelBtn = container.querySelector(".dialog-cancel-btn");
|
3152
|
-
if (options.title) {
|
3153
|
-
titleEl.textContent = options.title;
|
3154
|
-
} else {
|
3155
|
-
titleEl.style.display = "none";
|
3156
|
-
}
|
3157
|
-
messageEl.textContent = options.message;
|
3158
|
-
const cleanup = () => {
|
3159
|
-
document.body.removeChild(container);
|
3160
|
-
};
|
3161
|
-
confirmBtn.addEventListener("click", () => {
|
3162
|
-
cleanup();
|
3163
|
-
resolve(true);
|
3164
|
-
});
|
3165
|
-
cancelBtn.addEventListener("click", () => {
|
3166
|
-
cleanup();
|
3167
|
-
resolve(false);
|
3168
|
-
});
|
3169
|
-
});
|
3170
|
-
}
|
3171
|
-
static alert(options) {
|
3172
|
-
const messageEl = options.dangerouslyUseHTML ? { dangerouslySetInnerHTML: { __html: options.message } } : { children: options.message };
|
3173
|
-
return new Promise((resolve) => {
|
3174
|
-
var _a;
|
3175
|
-
this.injectStyles();
|
3176
|
-
const container = document.createElement("div");
|
3177
|
-
container.innerHTML = this.template;
|
3178
|
-
(_a = container.querySelector(".dialog-overlay")) == null ? void 0 : _a.classList.add("dialog-alert");
|
3179
|
-
if (options.closable === false) {
|
3180
|
-
const overlay = container.querySelector(".dialog-overlay");
|
3181
|
-
overlay.style.pointerEvents = "none";
|
3182
|
-
const dialogContainer = container.querySelector(".dialog-container");
|
3183
|
-
dialogContainer.style.pointerEvents = "auto";
|
3184
|
-
}
|
3185
|
-
document.body.appendChild(container);
|
3186
|
-
const titleEl = container.querySelector(".dialog-title");
|
3187
|
-
const messageEl2 = container.querySelector(".dialog-message");
|
3188
|
-
const confirmBtn = container.querySelector(".dialog-confirm-btn");
|
3189
|
-
const cancelBtn = container.querySelector(".dialog-cancel-btn");
|
3190
|
-
if (options.title) {
|
3191
|
-
titleEl.textContent = options.title;
|
3192
|
-
} else {
|
3193
|
-
titleEl.style.display = "none";
|
3194
|
-
}
|
3195
|
-
messageEl2.innerHTML = options.message;
|
3196
|
-
cancelBtn.style.display = "none";
|
3197
|
-
if (options.closable === false) {
|
3198
|
-
confirmBtn.style.display = "none";
|
3199
|
-
}
|
3200
|
-
const cleanup = () => {
|
3201
|
-
if (options.closable === false) {
|
3202
|
-
return;
|
3203
|
-
}
|
3204
|
-
document.body.removeChild(container);
|
3205
|
-
};
|
3206
|
-
confirmBtn.addEventListener("click", () => {
|
3207
|
-
cleanup();
|
3208
|
-
resolve();
|
3209
|
-
});
|
3210
|
-
});
|
3211
|
-
}
|
3212
|
-
};
|
3213
|
-
Dialog.template = `
|
3214
|
-
<div class="dialog-overlay">
|
3215
|
-
<div class="dialog-container">
|
3216
|
-
<div class="dialog-content">
|
3217
|
-
<div class="dialog-title"></div>
|
3218
|
-
<div class="dialog-message"></div>
|
3219
|
-
<div class="dialog-buttons">
|
3220
|
-
<button class="dialog-cancel-btn">Cancel</button>
|
3221
|
-
<button class="dialog-confirm-btn">OK</button>
|
3222
|
-
</div>
|
3223
|
-
</div>
|
3224
|
-
</div>
|
3225
|
-
</div>
|
3226
|
-
`;
|
3227
|
-
Dialog.style = `
|
3228
|
-
.dialog-overlay {
|
3229
|
-
position: fixed;
|
3230
|
-
top: 0;
|
3231
|
-
left: 0;
|
3232
|
-
right: 0;
|
3233
|
-
bottom: 0;
|
3234
|
-
background-color: rgba(0, 0, 0, 0.75);
|
3235
|
-
display: flex;
|
3236
|
-
align-items: center;
|
3237
|
-
justify-content: center;
|
3238
|
-
z-index: 999999;
|
3239
|
-
backdrop-filter: blur(4px);
|
3240
|
-
}
|
3241
|
-
.dialog-container {
|
3242
|
-
background: #21232f;
|
3243
|
-
border-radius: 12px;
|
3244
|
-
padding: 24px;
|
3245
|
-
width: 350px;
|
3246
|
-
box-shadow: 0 4px 24px rgba(0, 0, 0, 0.3);
|
3247
|
-
}
|
3248
|
-
.dialog-title {
|
3249
|
-
font-size: 18px;
|
3250
|
-
font-weight: 600;
|
3251
|
-
margin-bottom: 16px;
|
3252
|
-
color: #ffffff;
|
3253
|
-
}
|
3254
|
-
.dialog-message {
|
3255
|
-
margin-bottom: 24px;
|
3256
|
-
line-height: 1.6;
|
3257
|
-
color: rgba(255, 255, 255, 0.8);
|
3258
|
-
font-size: 14px;
|
3259
|
-
}
|
3260
|
-
.dialog-buttons {
|
3261
|
-
display: flex;
|
3262
|
-
justify-content: flex-end;
|
3263
|
-
gap: 12px;
|
3264
|
-
}
|
3265
|
-
.dialog-alert .dialog-buttons {
|
3266
|
-
justify-content: center;
|
3267
|
-
}
|
3268
|
-
.dialog-confirm-btn {
|
3269
|
-
padding: 8px 24px;
|
3270
|
-
background-color: #ff7a00;
|
3271
|
-
color: white;
|
3272
|
-
border: none;
|
3273
|
-
border-radius: 6px;
|
3274
|
-
cursor: pointer;
|
3275
|
-
font-size: 14px;
|
3276
|
-
font-weight: 500;
|
3277
|
-
transition: all 0.2s ease;
|
3278
|
-
}
|
3279
|
-
.dialog-confirm-btn:hover {
|
3280
|
-
background-color: #ff8f1f;
|
3281
|
-
transform: translateY(-1px);
|
3282
|
-
}
|
3283
|
-
.dialog-confirm-btn:active {
|
3284
|
-
transform: translateY(0);
|
3285
|
-
}
|
3286
|
-
.dialog-cancel-btn {
|
3287
|
-
padding: 8px 24px;
|
3288
|
-
background-color: rgba(255, 255, 255, 0.1);
|
3289
|
-
color: rgba(255, 255, 255, 0.8);
|
3290
|
-
border: none;
|
3291
|
-
border-radius: 6px;
|
3292
|
-
cursor: pointer;
|
3293
|
-
font-size: 14px;
|
3294
|
-
font-weight: 500;
|
3295
|
-
transition: all 0.2s ease;
|
3296
|
-
}
|
3297
|
-
.dialog-cancel-btn:hover {
|
3298
|
-
background-color: rgba(255, 255, 255, 0.15);
|
3299
|
-
transform: translateY(-1px);
|
3300
|
-
}
|
3301
|
-
.dialog-cancel-btn:active {
|
3302
|
-
transform: translateY(0);
|
3303
|
-
}
|
3304
|
-
|
3305
|
-
.dialog-overlay {
|
3306
|
-
animation: fadeIn 0.2s ease;
|
3307
|
-
}
|
3308
|
-
.dialog-container {
|
3309
|
-
animation: slideIn 0.2s ease;
|
3310
|
-
}
|
3311
|
-
@keyframes fadeIn {
|
3312
|
-
from {
|
3313
|
-
opacity: 0;
|
3314
|
-
}
|
3315
|
-
to {
|
3316
|
-
opacity: 1;
|
3317
|
-
}
|
3318
|
-
}
|
3319
|
-
@keyframes slideIn {
|
3320
|
-
from {
|
3321
|
-
transform: translateY(-20px);
|
3322
|
-
opacity: 0;
|
3323
|
-
}
|
3324
|
-
to {
|
3325
|
-
transform: translateY(0);
|
3326
|
-
opacity: 1;
|
3327
|
-
}
|
3328
|
-
}
|
3329
|
-
`;
|
3330
|
-
|
3331
3441
|
// src/core/btcUtils.ts
|
3332
3442
|
var import_bitcoinjs_lib = __toESM(require("bitcoinjs-lib"), 1);
|
3333
3443
|
var import_coinselect = __toESM(require("coinselect"), 1);
|
@@ -3444,7 +3554,7 @@ function getBtcBalance() {
|
|
3444
3554
|
const { account } = yield retryOperation(getBtcProvider, (res) => !!res.account);
|
3445
3555
|
if (!account) {
|
3446
3556
|
console.error("BTC Account is not available.");
|
3447
|
-
return { rawBalance: 0, balance: 0,
|
3557
|
+
return { rawBalance: 0, balance: 0, availableBalance: 0 };
|
3448
3558
|
}
|
3449
3559
|
const btcRpcUrl = yield getBtcRpcUrl();
|
3450
3560
|
const utxos = yield fetch(`${btcRpcUrl}/address/${account}/utxo`).then((res) => res.json());
|
@@ -3452,11 +3562,12 @@ function getBtcBalance() {
|
|
3452
3562
|
const rawBalance = (utxos == null ? void 0 : utxos.reduce((acc, cur) => acc + cur.value, 0)) || 0;
|
3453
3563
|
const balance = rawBalance / __pow(10, btcDecimals);
|
3454
3564
|
const feeRate = yield getBtcGasPrice();
|
3455
|
-
const inputSize = ((utxos == null ? void 0 : utxos.length) || 0) *
|
3456
|
-
const outputSize =
|
3457
|
-
const overheadSize =
|
3565
|
+
const inputSize = ((utxos == null ? void 0 : utxos.length) || 0) * 69;
|
3566
|
+
const outputSize = 33 * 2;
|
3567
|
+
const overheadSize = 11;
|
3458
3568
|
const estimatedTxSize = inputSize + outputSize + overheadSize;
|
3459
|
-
const estimatedFee = estimatedTxSize * feeRate;
|
3569
|
+
const estimatedFee = Math.ceil(estimatedTxSize * feeRate);
|
3570
|
+
console.log("estimatedFee:", estimatedFee);
|
3460
3571
|
const availableRawBalance = (rawBalance - estimatedFee).toFixed(0);
|
3461
3572
|
const availableBalance = new import_big.default(availableRawBalance).div(__pow(10, btcDecimals)).round(btcDecimals, import_big.default.roundDown).toNumber();
|
3462
3573
|
return {
|
@@ -4267,7 +4378,7 @@ var BTCWallet = (_0) => __async(void 0, [_0], function* ({
|
|
4267
4378
|
transaction.receiverId,
|
4268
4379
|
BigInt(nearNonceNumber) + BigInt(index),
|
4269
4380
|
newActions,
|
4270
|
-
(0,
|
4381
|
+
(0, import_utils10.baseDecode)(header.hash)
|
4271
4382
|
);
|
4272
4383
|
const txBytes = (0, import_transaction.encodeTransaction)(_transaction);
|
4273
4384
|
const txHex = Array.from(txBytes, (byte) => ("0" + (byte & 255).toString(16)).slice(-2)).join(
|
@@ -4325,7 +4436,7 @@ function setupBTCWallet({
|
|
4325
4436
|
|
4326
4437
|
// src/index.ts
|
4327
4438
|
var getVersion = () => {
|
4328
|
-
return "0.
|
4439
|
+
return "0.5.0-beta";
|
4329
4440
|
};
|
4330
4441
|
if (typeof window !== "undefined") {
|
4331
4442
|
window.__BTC_WALLET_VERSION = getVersion();
|