btc-wallet 0.3.0 → 0.3.2
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/connector/index.d.ts +1 -0
- package/dist/connector/magicEden.d.ts +23 -0
- package/dist/core/btcWalletSelectorContext.d.ts +1 -1
- package/dist/index.js +218 -8
- package/dist/index.js.map +4 -4
- package/esm/index.js +218 -8
- package/esm/index.js.map +4 -4
- package/package.json +1 -1
package/esm/index.js
CHANGED
@@ -459,6 +459,210 @@ 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
|
+
|
465
|
+
// src/icons/magicEden.png
|
466
|
+
var magicEden_default = "";
|
467
|
+
|
468
|
+
// src/connector/magicEden.ts
|
469
|
+
var _network2, _event2;
|
470
|
+
var MagicEdenConnector = class extends BaseConnector {
|
471
|
+
constructor() {
|
472
|
+
super();
|
473
|
+
__privateAdd(this, _network2, "Mainnet");
|
474
|
+
__privateAdd(this, _event2, new EventEmitter2());
|
475
|
+
this.metadata = {
|
476
|
+
id: "magicEden",
|
477
|
+
name: "Magic Eden Wallet",
|
478
|
+
icon: magicEden_default,
|
479
|
+
downloadUrl: "https://www.magiceden.io"
|
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");
|
661
|
+
}
|
662
|
+
};
|
663
|
+
_network2 = new WeakMap();
|
664
|
+
_event2 = new WeakMap();
|
665
|
+
|
462
666
|
// src/context/index.tsx
|
463
667
|
import { SmartAccount } from "@particle-network/aa";
|
464
668
|
import { chains as chains4 } from "@particle-network/chains";
|
@@ -579,8 +783,8 @@ var EthereumProvider = class {
|
|
579
783
|
};
|
580
784
|
|
581
785
|
// src/utils/eventUtils.ts
|
582
|
-
import { EventEmitter as
|
583
|
-
var events = new
|
786
|
+
import { EventEmitter as EventEmitter3 } from "events";
|
787
|
+
var events = new EventEmitter3();
|
584
788
|
events.setMaxListeners(100);
|
585
789
|
var getPendingSignEventAccount = () => {
|
586
790
|
return events.listenerCount("sendUserOpResult" /* sendUserOpResult */) + events.listenerCount("personalSignResult" /* personalSignResult */) + events.listenerCount("signTypedDataResult" /* signTypedDataResult */);
|
@@ -1643,7 +1847,7 @@ var signModal_default = SignModal;
|
|
1643
1847
|
// src/evmSigner/index.ts
|
1644
1848
|
import { intToHex as intToHex2 } from "@ethereumjs/util";
|
1645
1849
|
import { chains as chains3 } from "@particle-network/chains";
|
1646
|
-
import { EventEmitter as
|
1850
|
+
import { EventEmitter as EventEmitter4 } from "events";
|
1647
1851
|
import {
|
1648
1852
|
InvalidParamsRpcError,
|
1649
1853
|
SwitchChainError,
|
@@ -1674,7 +1878,7 @@ var AASignerProvider = class {
|
|
1674
1878
|
transport: http(rpcUrl)
|
1675
1879
|
});
|
1676
1880
|
};
|
1677
|
-
this.events = new
|
1881
|
+
this.events = new EventEmitter4();
|
1678
1882
|
this.events.setMaxListeners(100);
|
1679
1883
|
if (typeof window !== "undefined") {
|
1680
1884
|
const localChainId = localStorage.getItem("connect-evm-chain-id");
|
@@ -2127,11 +2331,16 @@ function ComfirmBox({ onClose, status = 1, fromChain = {
|
|
2127
2331
|
import { jsx as jsx12, jsxs as jsxs9 } from "react/jsx-runtime";
|
2128
2332
|
var WalletSelectorContext = React.createContext(null);
|
2129
2333
|
function BtcWalletSelectorContextProvider({
|
2130
|
-
children
|
2131
|
-
autoConnect = false
|
2334
|
+
children
|
2132
2335
|
}) {
|
2133
2336
|
const [isProcessing, setIsProcessing] = useState8(false);
|
2134
|
-
const connectors = [
|
2337
|
+
const connectors = [
|
2338
|
+
new UnisatConnector(),
|
2339
|
+
new XverseConnector(),
|
2340
|
+
new OKXConnector(),
|
2341
|
+
new BitgetConnector(),
|
2342
|
+
new MagicEdenConnector()
|
2343
|
+
];
|
2135
2344
|
const walletSelectorContextValue = useMemo6(() => {
|
2136
2345
|
const simpleFn = {};
|
2137
2346
|
return {
|
@@ -3063,7 +3272,7 @@ function executeBurrowSupply(_0) {
|
|
3063
3272
|
|
3064
3273
|
// src/index.ts
|
3065
3274
|
var getVersion = () => {
|
3066
|
-
return "0.3.
|
3275
|
+
return "0.3.2";
|
3067
3276
|
};
|
3068
3277
|
if (typeof window !== "undefined") {
|
3069
3278
|
window.__PARTICLE_BTC_CONNECT_VERSION = getVersion();
|
@@ -3075,6 +3284,7 @@ export {
|
|
3075
3284
|
BybitConnector,
|
3076
3285
|
ConnectProvider,
|
3077
3286
|
InjectedConnector,
|
3287
|
+
MagicEdenConnector,
|
3078
3288
|
OKXConnector,
|
3079
3289
|
TokenPocketConnector,
|
3080
3290
|
UnisatConnector,
|