btc-wallet 0.4.7-beta → 0.4.8-beta

Sign up to get free protection for your applications and to get access to all the features.
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
- return typeof window[props[0]] !== "undefined";
481
+ if (typeof window[props[0]] !== "undefined") {
482
+ return true;
483
+ }
141
484
  } else {
142
- return typeof window[props[0]] !== "undefined" && typeof window[props[0]][props[1]] !== "undefined";
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
- return typeof window !== "undefined" && typeof window.BitcoinProvider !== "undefined";
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.isReady()) {
381
- throw new Error(`${this.metadata.name} is not install!`);
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");
@@ -1261,119 +1654,34 @@ var ConnectModal = ({ open, onClose }) => {
1261
1654
  ] }) : /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)(import_jsx_runtime4.Fragment, { children: [
1262
1655
  /* @__PURE__ */ (0, import_jsx_runtime4.jsx)("div", { className: connect_module_default.connection, children: "Wallet Not Installed." }),
1263
1656
  /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(
1264
- button_default,
1265
- {
1266
- 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);
1657
+ button_default,
1658
+ {
1659
+ className: connect_module_default.btnDownload,
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 delay = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
1348
- function retryOperation(_0, _1) {
1349
- return __async(this, arguments, function* (operation, shouldStop, {
1350
- maxRetries = 3,
1351
- delayMs = 1e3
1352
- } = {}) {
1353
- let retries = 0;
1354
- while (retries <= maxRetries) {
1355
- const result = yield operation();
1356
- if (shouldStop(result)) {
1357
- return result;
1358
- }
1359
- if (retries === maxRetries) {
1360
- console.warn("Max retries reached");
1361
- return result;
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 import_utils7 = require("@near-js/utils");
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
 
@@ -3129,205 +3437,6 @@ function getWhitelist(url) {
3129
3437
  });
3130
3438
  }
3131
3439
 
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
3440
  // src/core/btcUtils.ts
3332
3441
  var import_bitcoinjs_lib = __toESM(require("bitcoinjs-lib"), 1);
3333
3442
  var import_coinselect = __toESM(require("coinselect"), 1);
@@ -3444,7 +3553,7 @@ function getBtcBalance() {
3444
3553
  const { account } = yield retryOperation(getBtcProvider, (res) => !!res.account);
3445
3554
  if (!account) {
3446
3555
  console.error("BTC Account is not available.");
3447
- return { rawBalance: 0, balance: 0, maxSpendableBalance: 0 };
3556
+ return { rawBalance: 0, balance: 0, availableBalance: 0 };
3448
3557
  }
3449
3558
  const btcRpcUrl = yield getBtcRpcUrl();
3450
3559
  const utxos = yield fetch(`${btcRpcUrl}/address/${account}/utxo`).then((res) => res.json());
@@ -3452,11 +3561,12 @@ function getBtcBalance() {
3452
3561
  const rawBalance = (utxos == null ? void 0 : utxos.reduce((acc, cur) => acc + cur.value, 0)) || 0;
3453
3562
  const balance = rawBalance / __pow(10, btcDecimals);
3454
3563
  const feeRate = yield getBtcGasPrice();
3455
- const inputSize = ((utxos == null ? void 0 : utxos.length) || 0) * 66;
3456
- const outputSize = 34;
3457
- const overheadSize = 10;
3564
+ const inputSize = ((utxos == null ? void 0 : utxos.length) || 0) * 69;
3565
+ const outputSize = 33 * 2;
3566
+ const overheadSize = 11;
3458
3567
  const estimatedTxSize = inputSize + outputSize + overheadSize;
3459
- const estimatedFee = estimatedTxSize * feeRate;
3568
+ const estimatedFee = Math.ceil(estimatedTxSize * feeRate);
3569
+ console.log("estimatedFee:", estimatedFee);
3460
3570
  const availableRawBalance = (rawBalance - estimatedFee).toFixed(0);
3461
3571
  const availableBalance = new import_big.default(availableRawBalance).div(__pow(10, btcDecimals)).round(btcDecimals, import_big.default.roundDown).toNumber();
3462
3572
  return {
@@ -4267,7 +4377,7 @@ var BTCWallet = (_0) => __async(void 0, [_0], function* ({
4267
4377
  transaction.receiverId,
4268
4378
  BigInt(nearNonceNumber) + BigInt(index),
4269
4379
  newActions,
4270
- (0, import_utils7.baseDecode)(header.hash)
4380
+ (0, import_utils10.baseDecode)(header.hash)
4271
4381
  );
4272
4382
  const txBytes = (0, import_transaction.encodeTransaction)(_transaction);
4273
4383
  const txHex = Array.from(txBytes, (byte) => ("0" + (byte & 255).toString(16)).slice(-2)).join(
@@ -4325,7 +4435,7 @@ function setupBTCWallet({
4325
4435
 
4326
4436
  // src/index.ts
4327
4437
  var getVersion = () => {
4328
- return "0.4.7-beta";
4438
+ return "0.4.8-beta";
4329
4439
  };
4330
4440
  if (typeof window !== "undefined") {
4331
4441
  window.__BTC_WALLET_VERSION = getVersion();