btc-wallet 0.3.1 → 0.3.3

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/esm/index.js CHANGED
@@ -459,21 +459,209 @@ var XverseConnector = class extends BaseConnector {
459
459
  _network = new WeakMap();
460
460
  _event = new WeakMap();
461
461
 
462
+ // src/connector/magicEden.ts
463
+ import EventEmitter2 from "events";
464
+
462
465
  // src/icons/magicEden.png
463
466
  var magicEden_default = "";
464
467
 
465
468
  // src/connector/magicEden.ts
466
- var MagicEdenConnector = class extends InjectedConnector {
469
+ var _network2, _event2;
470
+ var MagicEdenConnector = class extends BaseConnector {
467
471
  constructor() {
468
- super("magicEden.bitcoin");
472
+ super();
473
+ __privateAdd(this, _network2, "Mainnet");
474
+ __privateAdd(this, _event2, new EventEmitter2());
469
475
  this.metadata = {
470
- id: "magic-eden",
471
- name: "MagicEden Wallet",
476
+ id: "magicEden",
477
+ name: "Magic Eden Wallet",
472
478
  icon: magicEden_default,
473
- downloadUrl: "https://wallet.magiceden.io/"
479
+ downloadUrl: "https://www.magiceden.io"
474
480
  };
481
+ this.loadAccounts = (network) => __async(this, null, function* () {
482
+ const { getAddress, AddressPurpose } = yield import("sats-connect");
483
+ const addresses = yield new Promise((resolve, reject) => {
484
+ const getAddressOptions = {
485
+ payload: {
486
+ purposes: [AddressPurpose.Payment, AddressPurpose.Ordinals],
487
+ message: "Address for receiving Ordinals and payments",
488
+ network: {
489
+ type: network
490
+ }
491
+ },
492
+ onFinish: (response) => {
493
+ resolve(response.addresses);
494
+ },
495
+ onCancel: () => reject({
496
+ code: 4001,
497
+ message: "User rejected the request."
498
+ })
499
+ };
500
+ getAddress(getAddressOptions).catch((error) => reject(error));
501
+ });
502
+ localStorage.setItem("btc-connect-magicEden-addresses-" + network, JSON.stringify(addresses));
503
+ return addresses;
504
+ });
505
+ __privateGet(this, _event2).setMaxListeners(100);
506
+ }
507
+ isReady() {
508
+ return typeof window !== "undefined" && "magicEden" in window && !!window.magicEden;
509
+ }
510
+ sendInscription() {
511
+ return __async(this, null, function* () {
512
+ throw new Error("Unsupported");
513
+ });
514
+ }
515
+ requestAccounts() {
516
+ return __async(this, null, function* () {
517
+ if (!this.isReady()) {
518
+ throw new Error(`${this.metadata.name} is not install!`);
519
+ }
520
+ const addresses = yield this.loadAccounts(__privateGet(this, _network2));
521
+ return addresses.map((item) => item.address);
522
+ });
523
+ }
524
+ getAccounts() {
525
+ return __async(this, null, function* () {
526
+ if (!this.isReady()) {
527
+ throw new Error(`${this.metadata.name} is not install!`);
528
+ }
529
+ const data = localStorage.getItem("btc-connect-magicEden-addresses-" + __privateGet(this, _network2));
530
+ if (data) {
531
+ const addresses = JSON.parse(data);
532
+ return addresses.map((item) => item.address);
533
+ } else {
534
+ return [];
535
+ }
536
+ });
537
+ }
538
+ getPublicKey() {
539
+ return __async(this, null, function* () {
540
+ if (!this.isReady()) {
541
+ throw new Error(`${this.metadata.name} is not install!`);
542
+ }
543
+ const data = localStorage.getItem("btc-connect-magicEden-addresses-" + __privateGet(this, _network2));
544
+ if (data) {
545
+ const addresses = JSON.parse(data);
546
+ return addresses[0].publicKey;
547
+ } else {
548
+ return "";
549
+ }
550
+ });
551
+ }
552
+ signMessage(signStr) {
553
+ return __async(this, null, function* () {
554
+ if (!this.isReady()) {
555
+ throw new Error(`${this.metadata.name} is not install!`);
556
+ }
557
+ const addresses = yield this.getAccounts();
558
+ if (addresses.length === 0) {
559
+ throw new Error(`${this.metadata.name} not connected!`);
560
+ }
561
+ const { signMessage } = yield import("sats-connect");
562
+ const sig = yield new Promise((resolve, reject) => {
563
+ const signMessageOptions = {
564
+ payload: {
565
+ network: {
566
+ type: __privateGet(this, _network2)
567
+ },
568
+ address: addresses[0],
569
+ message: signStr
570
+ },
571
+ onFinish: (response) => {
572
+ resolve(response);
573
+ },
574
+ onCancel: () => {
575
+ reject({
576
+ code: 4001,
577
+ message: "User rejected the request."
578
+ });
579
+ }
580
+ };
581
+ signMessage(signMessageOptions).catch((e) => {
582
+ reject(e);
583
+ });
584
+ });
585
+ const modifiedSig = Buffer.from(sig, "base64");
586
+ modifiedSig[0] = 31 + (modifiedSig[0] - 31) % 4;
587
+ return modifiedSig.toString("base64");
588
+ });
589
+ }
590
+ on(event, handler) {
591
+ return __privateGet(this, _event2).on(event, handler);
592
+ }
593
+ removeListener(event, handler) {
594
+ return __privateGet(this, _event2).removeListener(event, handler);
595
+ }
596
+ getProvider() {
597
+ if (this.isReady()) {
598
+ if ("magicEden" in window) {
599
+ const anyWindow = window;
600
+ if (anyWindow.magicEden.bitcoin && anyWindow.magicEden.bitcoin.isMagicEden)
601
+ return anyWindow.magicEden.bitcoin;
602
+ }
603
+ }
604
+ }
605
+ getNetwork() {
606
+ return __async(this, null, function* () {
607
+ if (!this.isReady()) {
608
+ throw new Error(`${this.metadata.name} is not install!`);
609
+ }
610
+ return __privateGet(this, _network2) === "Mainnet" ? "livenet" : "testnet";
611
+ });
612
+ }
613
+ switchNetwork() {
614
+ return __async(this, null, function* () {
615
+ throw new Error("Unsupported");
616
+ });
617
+ }
618
+ sendBitcoin(toAddress, satoshis) {
619
+ return __async(this, null, function* () {
620
+ const provider = this.getProvider();
621
+ if (!provider) {
622
+ throw new Error(`${this.metadata.name} is not install!`);
623
+ }
624
+ const { sendBtcTransaction } = yield import("sats-connect");
625
+ const addresses = yield this.getAccounts();
626
+ if (addresses.length === 0) {
627
+ throw new Error(`${this.metadata.name} not connected!`);
628
+ }
629
+ const result = yield new Promise((resolve, reject) => {
630
+ const sendBtcOptions = {
631
+ payload: {
632
+ network: {
633
+ type: __privateGet(this, _network2)
634
+ },
635
+ recipients: [
636
+ {
637
+ address: toAddress,
638
+ amountSats: BigInt(satoshis)
639
+ }
640
+ ],
641
+ senderAddress: addresses[0]
642
+ },
643
+ onFinish: (response) => {
644
+ resolve(response);
645
+ },
646
+ onCancel: () => {
647
+ reject({
648
+ code: 4001,
649
+ message: "User rejected the request."
650
+ });
651
+ }
652
+ };
653
+ sendBtcTransaction(sendBtcOptions).catch((e) => reject(e));
654
+ });
655
+ return result;
656
+ });
657
+ }
658
+ disconnect() {
659
+ localStorage.removeItem("btc-connect-magicEden-addresses-Mainnet");
660
+ localStorage.removeItem("btc-connect-magicEden-addresses-Testnet");
475
661
  }
476
662
  };
663
+ _network2 = new WeakMap();
664
+ _event2 = new WeakMap();
477
665
 
478
666
  // src/context/index.tsx
479
667
  import { SmartAccount } from "@particle-network/aa";
@@ -595,8 +783,8 @@ var EthereumProvider = class {
595
783
  };
596
784
 
597
785
  // src/utils/eventUtils.ts
598
- import { EventEmitter as EventEmitter2 } from "events";
599
- var events = new EventEmitter2();
786
+ import { EventEmitter as EventEmitter3 } from "events";
787
+ var events = new EventEmitter3();
600
788
  events.setMaxListeners(100);
601
789
  var getPendingSignEventAccount = () => {
602
790
  return events.listenerCount("sendUserOpResult" /* sendUserOpResult */) + events.listenerCount("personalSignResult" /* personalSignResult */) + events.listenerCount("signTypedDataResult" /* signTypedDataResult */);
@@ -1659,7 +1847,7 @@ var signModal_default = SignModal;
1659
1847
  // src/evmSigner/index.ts
1660
1848
  import { intToHex as intToHex2 } from "@ethereumjs/util";
1661
1849
  import { chains as chains3 } from "@particle-network/chains";
1662
- import { EventEmitter as EventEmitter3 } from "events";
1850
+ import { EventEmitter as EventEmitter4 } from "events";
1663
1851
  import {
1664
1852
  InvalidParamsRpcError,
1665
1853
  SwitchChainError,
@@ -1690,7 +1878,7 @@ var AASignerProvider = class {
1690
1878
  transport: http(rpcUrl)
1691
1879
  });
1692
1880
  };
1693
- this.events = new EventEmitter3();
1881
+ this.events = new EventEmitter4();
1694
1882
  this.events.setMaxListeners(100);
1695
1883
  if (typeof window !== "undefined") {
1696
1884
  const localChainId = localStorage.getItem("connect-evm-chain-id");
@@ -2839,18 +3027,8 @@ var BTCWallet = (_0) => __async(void 0, [_0], function* ({
2839
3027
  near_transactions: newTransactions.map((t) => t.txHex),
2840
3028
  gas_token: currentConfig.token,
2841
3029
  gas_limit: "3000",
2842
- use_near_pay_gas: false,
2843
3030
  nonce
2844
3031
  };
2845
- const nearAccount = yield provider.query({
2846
- request_type: "view_account",
2847
- account_id: accountId,
2848
- finality: "final"
2849
- });
2850
- const availableBalance = parseFloat(nearAccount.amount) / __pow(10, 24);
2851
- if (availableBalance > 0.2) {
2852
- intention.use_near_pay_gas = true;
2853
- }
2854
3032
  const strIntention = JSON.stringify(intention);
2855
3033
  const signature = yield btcContext.signMessage(strIntention);
2856
3034
  const result = yield uploadBTCTx(currentConfig.base_url, {
@@ -2873,10 +3051,6 @@ var BTCWallet = (_0) => __async(void 0, [_0], function* ({
2873
3051
  const checkAndSetupWalletButton = () => {
2874
3052
  const accountId = state.getAccount();
2875
3053
  const btcContext = window.btcContext;
2876
- console.log("checkAndSetupWalletButton:", {
2877
- nearAccountId: accountId,
2878
- btcAccountId: btcContext.account
2879
- });
2880
3054
  if (accountId && btcContext.account) {
2881
3055
  setupWalletButton(network, wallet2, btcContext);
2882
3056
  } else {
@@ -3084,7 +3258,7 @@ function executeBurrowSupply(_0) {
3084
3258
 
3085
3259
  // src/index.ts
3086
3260
  var getVersion = () => {
3087
- return "0.3.1";
3261
+ return "0.3.3";
3088
3262
  };
3089
3263
  if (typeof window !== "undefined") {
3090
3264
  window.__PARTICLE_BTC_CONNECT_VERSION = getVersion();