btc-wallet 0.3.1 → 0.3.3

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,6 +1,23 @@
1
- import { type WalletMetadata } from './base';
2
- import { InjectedConnector } from './injected';
3
- export declare class MagicEdenConnector extends InjectedConnector {
4
- readonly metadata: WalletMetadata;
1
+ import EventEmitter from 'events';
2
+ import { BaseConnector, type WalletMetadata } from './base';
3
+ export declare class MagicEdenConnector extends BaseConnector {
4
+ #private;
5
5
  constructor();
6
+ readonly metadata: WalletMetadata;
7
+ isReady(): boolean;
8
+ private loadAccounts;
9
+ sendInscription(): Promise<{
10
+ txid: string;
11
+ }>;
12
+ requestAccounts(): Promise<string[]>;
13
+ getAccounts(): Promise<string[]>;
14
+ getPublicKey(): Promise<string>;
15
+ signMessage(signStr: string): Promise<string>;
16
+ on(event: string, handler: (data?: unknown) => void): EventEmitter<[never]>;
17
+ removeListener(event: string, handler: (data?: unknown) => void): EventEmitter<[never]>;
18
+ getProvider(): any;
19
+ getNetwork(): Promise<'livenet' | 'testnet'>;
20
+ switchNetwork(): Promise<void>;
21
+ sendBitcoin(toAddress: string, satoshis: number): Promise<string>;
22
+ disconnect(): void;
6
23
  }
package/dist/index.js CHANGED
@@ -509,21 +509,209 @@ var XverseConnector = class extends BaseConnector {
509
509
  _network = new WeakMap();
510
510
  _event = new WeakMap();
511
511
 
512
+ // src/connector/magicEden.ts
513
+ var import_events2 = __toESM(require("events"), 1);
514
+
512
515
  // src/icons/magicEden.png
513
516
  var magicEden_default = "";
514
517
 
515
518
  // src/connector/magicEden.ts
516
- var MagicEdenConnector = class extends InjectedConnector {
519
+ var _network2, _event2;
520
+ var MagicEdenConnector = class extends BaseConnector {
517
521
  constructor() {
518
- super("magicEden.bitcoin");
522
+ super();
523
+ __privateAdd(this, _network2, "Mainnet");
524
+ __privateAdd(this, _event2, new import_events2.default());
519
525
  this.metadata = {
520
- id: "magic-eden",
521
- name: "MagicEden Wallet",
526
+ id: "magicEden",
527
+ name: "Magic Eden Wallet",
522
528
  icon: magicEden_default,
523
- downloadUrl: "https://wallet.magiceden.io/"
529
+ downloadUrl: "https://www.magiceden.io"
524
530
  };
531
+ this.loadAccounts = (network) => __async(this, null, function* () {
532
+ const { getAddress, AddressPurpose } = yield import("sats-connect");
533
+ const addresses = yield new Promise((resolve, reject) => {
534
+ const getAddressOptions = {
535
+ payload: {
536
+ purposes: [AddressPurpose.Payment, AddressPurpose.Ordinals],
537
+ message: "Address for receiving Ordinals and payments",
538
+ network: {
539
+ type: network
540
+ }
541
+ },
542
+ onFinish: (response) => {
543
+ resolve(response.addresses);
544
+ },
545
+ onCancel: () => reject({
546
+ code: 4001,
547
+ message: "User rejected the request."
548
+ })
549
+ };
550
+ getAddress(getAddressOptions).catch((error) => reject(error));
551
+ });
552
+ localStorage.setItem("btc-connect-magicEden-addresses-" + network, JSON.stringify(addresses));
553
+ return addresses;
554
+ });
555
+ __privateGet(this, _event2).setMaxListeners(100);
556
+ }
557
+ isReady() {
558
+ return typeof window !== "undefined" && "magicEden" in window && !!window.magicEden;
559
+ }
560
+ sendInscription() {
561
+ return __async(this, null, function* () {
562
+ throw new Error("Unsupported");
563
+ });
564
+ }
565
+ requestAccounts() {
566
+ return __async(this, null, function* () {
567
+ if (!this.isReady()) {
568
+ throw new Error(`${this.metadata.name} is not install!`);
569
+ }
570
+ const addresses = yield this.loadAccounts(__privateGet(this, _network2));
571
+ return addresses.map((item) => item.address);
572
+ });
573
+ }
574
+ getAccounts() {
575
+ return __async(this, null, function* () {
576
+ if (!this.isReady()) {
577
+ throw new Error(`${this.metadata.name} is not install!`);
578
+ }
579
+ const data = localStorage.getItem("btc-connect-magicEden-addresses-" + __privateGet(this, _network2));
580
+ if (data) {
581
+ const addresses = JSON.parse(data);
582
+ return addresses.map((item) => item.address);
583
+ } else {
584
+ return [];
585
+ }
586
+ });
587
+ }
588
+ getPublicKey() {
589
+ return __async(this, null, function* () {
590
+ if (!this.isReady()) {
591
+ throw new Error(`${this.metadata.name} is not install!`);
592
+ }
593
+ const data = localStorage.getItem("btc-connect-magicEden-addresses-" + __privateGet(this, _network2));
594
+ if (data) {
595
+ const addresses = JSON.parse(data);
596
+ return addresses[0].publicKey;
597
+ } else {
598
+ return "";
599
+ }
600
+ });
601
+ }
602
+ signMessage(signStr) {
603
+ return __async(this, null, function* () {
604
+ if (!this.isReady()) {
605
+ throw new Error(`${this.metadata.name} is not install!`);
606
+ }
607
+ const addresses = yield this.getAccounts();
608
+ if (addresses.length === 0) {
609
+ throw new Error(`${this.metadata.name} not connected!`);
610
+ }
611
+ const { signMessage } = yield import("sats-connect");
612
+ const sig = yield new Promise((resolve, reject) => {
613
+ const signMessageOptions = {
614
+ payload: {
615
+ network: {
616
+ type: __privateGet(this, _network2)
617
+ },
618
+ address: addresses[0],
619
+ message: signStr
620
+ },
621
+ onFinish: (response) => {
622
+ resolve(response);
623
+ },
624
+ onCancel: () => {
625
+ reject({
626
+ code: 4001,
627
+ message: "User rejected the request."
628
+ });
629
+ }
630
+ };
631
+ signMessage(signMessageOptions).catch((e) => {
632
+ reject(e);
633
+ });
634
+ });
635
+ const modifiedSig = Buffer.from(sig, "base64");
636
+ modifiedSig[0] = 31 + (modifiedSig[0] - 31) % 4;
637
+ return modifiedSig.toString("base64");
638
+ });
639
+ }
640
+ on(event, handler) {
641
+ return __privateGet(this, _event2).on(event, handler);
642
+ }
643
+ removeListener(event, handler) {
644
+ return __privateGet(this, _event2).removeListener(event, handler);
645
+ }
646
+ getProvider() {
647
+ if (this.isReady()) {
648
+ if ("magicEden" in window) {
649
+ const anyWindow = window;
650
+ if (anyWindow.magicEden.bitcoin && anyWindow.magicEden.bitcoin.isMagicEden)
651
+ return anyWindow.magicEden.bitcoin;
652
+ }
653
+ }
654
+ }
655
+ getNetwork() {
656
+ return __async(this, null, function* () {
657
+ if (!this.isReady()) {
658
+ throw new Error(`${this.metadata.name} is not install!`);
659
+ }
660
+ return __privateGet(this, _network2) === "Mainnet" ? "livenet" : "testnet";
661
+ });
662
+ }
663
+ switchNetwork() {
664
+ return __async(this, null, function* () {
665
+ throw new Error("Unsupported");
666
+ });
667
+ }
668
+ sendBitcoin(toAddress, satoshis) {
669
+ return __async(this, null, function* () {
670
+ const provider = this.getProvider();
671
+ if (!provider) {
672
+ throw new Error(`${this.metadata.name} is not install!`);
673
+ }
674
+ const { sendBtcTransaction } = yield import("sats-connect");
675
+ const addresses = yield this.getAccounts();
676
+ if (addresses.length === 0) {
677
+ throw new Error(`${this.metadata.name} not connected!`);
678
+ }
679
+ const result = yield new Promise((resolve, reject) => {
680
+ const sendBtcOptions = {
681
+ payload: {
682
+ network: {
683
+ type: __privateGet(this, _network2)
684
+ },
685
+ recipients: [
686
+ {
687
+ address: toAddress,
688
+ amountSats: BigInt(satoshis)
689
+ }
690
+ ],
691
+ senderAddress: addresses[0]
692
+ },
693
+ onFinish: (response) => {
694
+ resolve(response);
695
+ },
696
+ onCancel: () => {
697
+ reject({
698
+ code: 4001,
699
+ message: "User rejected the request."
700
+ });
701
+ }
702
+ };
703
+ sendBtcTransaction(sendBtcOptions).catch((e) => reject(e));
704
+ });
705
+ return result;
706
+ });
707
+ }
708
+ disconnect() {
709
+ localStorage.removeItem("btc-connect-magicEden-addresses-Mainnet");
710
+ localStorage.removeItem("btc-connect-magicEden-addresses-Testnet");
525
711
  }
526
712
  };
713
+ _network2 = new WeakMap();
714
+ _event2 = new WeakMap();
527
715
 
528
716
  // src/context/index.tsx
529
717
  var import_aa = require("@particle-network/aa");
@@ -645,8 +833,8 @@ var EthereumProvider = class {
645
833
  };
646
834
 
647
835
  // src/utils/eventUtils.ts
648
- var import_events2 = require("events");
649
- var events = new import_events2.EventEmitter();
836
+ var import_events3 = require("events");
837
+ var events = new import_events3.EventEmitter();
650
838
  events.setMaxListeners(100);
651
839
  var getPendingSignEventAccount = () => {
652
840
  return events.listenerCount("sendUserOpResult" /* sendUserOpResult */) + events.listenerCount("personalSignResult" /* personalSignResult */) + events.listenerCount("signTypedDataResult" /* signTypedDataResult */);
@@ -1703,7 +1891,7 @@ var signModal_default = SignModal;
1703
1891
  // src/evmSigner/index.ts
1704
1892
  var import_util3 = require("@ethereumjs/util");
1705
1893
  var import_chains3 = require("@particle-network/chains");
1706
- var import_events3 = require("events");
1894
+ var import_events4 = require("events");
1707
1895
  var import_viem4 = require("viem");
1708
1896
  var AASignerProvider = class {
1709
1897
  constructor(supportChainIds, projectId, clientKey, rpcUrls) {
@@ -1726,7 +1914,7 @@ var AASignerProvider = class {
1726
1914
  transport: (0, import_viem4.http)(rpcUrl)
1727
1915
  });
1728
1916
  };
1729
- this.events = new import_events3.EventEmitter();
1917
+ this.events = new import_events4.EventEmitter();
1730
1918
  this.events.setMaxListeners(100);
1731
1919
  if (typeof window !== "undefined") {
1732
1920
  const localChainId = localStorage.getItem("connect-evm-chain-id");
@@ -2875,18 +3063,8 @@ var BTCWallet = (_0) => __async(void 0, [_0], function* ({
2875
3063
  near_transactions: newTransactions.map((t) => t.txHex),
2876
3064
  gas_token: currentConfig.token,
2877
3065
  gas_limit: "3000",
2878
- use_near_pay_gas: false,
2879
3066
  nonce
2880
3067
  };
2881
- const nearAccount = yield provider.query({
2882
- request_type: "view_account",
2883
- account_id: accountId,
2884
- finality: "final"
2885
- });
2886
- const availableBalance = parseFloat(nearAccount.amount) / __pow(10, 24);
2887
- if (availableBalance > 0.2) {
2888
- intention.use_near_pay_gas = true;
2889
- }
2890
3068
  const strIntention = JSON.stringify(intention);
2891
3069
  const signature = yield btcContext.signMessage(strIntention);
2892
3070
  const result = yield uploadBTCTx(currentConfig.base_url, {
@@ -2909,10 +3087,6 @@ var BTCWallet = (_0) => __async(void 0, [_0], function* ({
2909
3087
  const checkAndSetupWalletButton = () => {
2910
3088
  const accountId = state.getAccount();
2911
3089
  const btcContext = window.btcContext;
2912
- console.log("checkAndSetupWalletButton:", {
2913
- nearAccountId: accountId,
2914
- btcAccountId: btcContext.account
2915
- });
2916
3090
  if (accountId && btcContext.account) {
2917
3091
  setupWalletButton(network, wallet2, btcContext);
2918
3092
  } else {
@@ -3120,7 +3294,7 @@ function executeBurrowSupply(_0) {
3120
3294
 
3121
3295
  // src/index.ts
3122
3296
  var getVersion = () => {
3123
- return "0.3.1";
3297
+ return "0.3.3";
3124
3298
  };
3125
3299
  if (typeof window !== "undefined") {
3126
3300
  window.__PARTICLE_BTC_CONNECT_VERSION = getVersion();