btc-wallet 0.5.53-beta → 0.5.56-beta
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/README.md +25 -16
- package/dist/core/setupBTCWallet/index.d.ts +2 -1
- package/dist/core/setupModal.d.ts +7 -1
- package/dist/index.js +190 -97
- package/dist/index.js.map +3 -3
- package/dist/utils/index.d.ts +10 -0
- package/dist/utils/initWalletButton.d.ts +7 -1
- package/dist/utils/satoshi.d.ts +4 -1
- package/esm/index.js +188 -95
- package/esm/index.js.map +3 -3
- package/package.json +1 -1
package/dist/index.js
CHANGED
@@ -234,6 +234,51 @@ function isMobile() {
|
|
234
234
|
}
|
235
235
|
return false;
|
236
236
|
}
|
237
|
+
function safeJSONParse(str) {
|
238
|
+
try {
|
239
|
+
return JSON.parse(str);
|
240
|
+
} catch (e) {
|
241
|
+
console.error("safeJSONParse", e);
|
242
|
+
return void 0;
|
243
|
+
}
|
244
|
+
}
|
245
|
+
function safeJSONStringify(obj) {
|
246
|
+
try {
|
247
|
+
return JSON.stringify(obj);
|
248
|
+
} catch (e) {
|
249
|
+
console.error("safeJSONStringify", e);
|
250
|
+
return void 0;
|
251
|
+
}
|
252
|
+
}
|
253
|
+
function storageStore(namespace, options) {
|
254
|
+
if (typeof window === "undefined")
|
255
|
+
return;
|
256
|
+
const _namespace = namespace || "SATOSHI_WALLET_DEFAULT";
|
257
|
+
const storage5 = (options == null ? void 0 : options.storage) || (window == null ? void 0 : window.localStorage);
|
258
|
+
const namespaceKey = (key) => {
|
259
|
+
return _namespace + ":" + key;
|
260
|
+
};
|
261
|
+
return {
|
262
|
+
set(key, value) {
|
263
|
+
const _value = safeJSONStringify(value);
|
264
|
+
_value ? storage5.setItem(namespaceKey(key), _value) : storage5.removeItem(namespaceKey(key));
|
265
|
+
},
|
266
|
+
get(key) {
|
267
|
+
const _value = storage5.getItem(namespaceKey(key));
|
268
|
+
return _value ? safeJSONParse(_value) : void 0;
|
269
|
+
},
|
270
|
+
remove(key) {
|
271
|
+
storage5.removeItem(namespaceKey(key));
|
272
|
+
},
|
273
|
+
clearAll: function clearAll() {
|
274
|
+
for (const key in storage5) {
|
275
|
+
if (key.startsWith(namespace + ":")) {
|
276
|
+
storage5.removeItem(key);
|
277
|
+
}
|
278
|
+
}
|
279
|
+
}
|
280
|
+
};
|
281
|
+
}
|
237
282
|
|
238
283
|
// src/utils/Dialog.ts
|
239
284
|
var Dialog = class {
|
@@ -503,7 +548,7 @@ var MobileWalletConnect = class {
|
|
503
548
|
case "okx":
|
504
549
|
return `okx://wallet/dapp/url?dappUrl=${encodeURIComponent(url)}`;
|
505
550
|
case "bitget":
|
506
|
-
return `
|
551
|
+
return `bitkeep://bkconnect?action=dapp&url=${encodeURIComponent(url)}`;
|
507
552
|
case "xverse":
|
508
553
|
return `xverse://browser?url=${encodeURIComponent(url)}`;
|
509
554
|
default:
|
@@ -589,9 +634,13 @@ var InjectedConnector = class extends BaseConnector {
|
|
589
634
|
}
|
590
635
|
requestAccounts() {
|
591
636
|
return __async(this, null, function* () {
|
592
|
-
if (isMobile()
|
593
|
-
|
594
|
-
|
637
|
+
if (isMobile()) {
|
638
|
+
try {
|
639
|
+
this.getProvider();
|
640
|
+
} catch (error) {
|
641
|
+
yield MobileWalletConnect.redirectToWallet(this.metadata.id);
|
642
|
+
return [];
|
643
|
+
}
|
595
644
|
}
|
596
645
|
const accounts = yield this.getProviderOrThrow().requestAccounts();
|
597
646
|
console.log("network:", yield this.getNetwork());
|
@@ -776,6 +825,7 @@ var import_events = __toESM(require("events"), 1);
|
|
776
825
|
var xverse_default = "";
|
777
826
|
|
778
827
|
// src/connector/xverse.ts
|
828
|
+
var storage = storageStore("SATOSHI_WALLET_XVERSE");
|
779
829
|
var _network, _event;
|
780
830
|
var XverseConnector = class extends BaseConnector {
|
781
831
|
constructor() {
|
@@ -801,7 +851,7 @@ var XverseConnector = class extends BaseConnector {
|
|
801
851
|
walletType
|
802
852
|
}));
|
803
853
|
console.log("\u{1F680} ~ XverseConnector ~ loadAccounts ~ res:", addresses);
|
804
|
-
|
854
|
+
storage == null ? void 0 : storage.set(`${network}:addresses`, addresses);
|
805
855
|
return addresses;
|
806
856
|
});
|
807
857
|
__privateGet(this, _event).setMaxListeners(100);
|
@@ -836,9 +886,9 @@ var XverseConnector = class extends BaseConnector {
|
|
836
886
|
}
|
837
887
|
getAddresses() {
|
838
888
|
return __async(this, null, function* () {
|
839
|
-
const data =
|
889
|
+
const data = storage == null ? void 0 : storage.get(`${__privateGet(this, _network)}:addresses`);
|
840
890
|
if (data) {
|
841
|
-
return
|
891
|
+
return data;
|
842
892
|
}
|
843
893
|
return [];
|
844
894
|
});
|
@@ -923,8 +973,7 @@ var XverseConnector = class extends BaseConnector {
|
|
923
973
|
});
|
924
974
|
}
|
925
975
|
disconnect() {
|
926
|
-
|
927
|
-
localStorage.removeItem("btc-connect-xverse-addresses-Testnet");
|
976
|
+
storage == null ? void 0 : storage.remove(`${__privateGet(this, _network)}:addresses`);
|
928
977
|
}
|
929
978
|
};
|
930
979
|
_network = new WeakMap();
|
@@ -937,6 +986,7 @@ var import_events2 = __toESM(require("events"), 1);
|
|
937
986
|
var magicEden_default = "";
|
938
987
|
|
939
988
|
// src/connector/magicEden.ts
|
989
|
+
var storage2 = storageStore("SATOSHI_WALLET_MAGICEDEN");
|
940
990
|
var _network2, _event2;
|
941
991
|
var MagicEdenConnector = class extends BaseConnector {
|
942
992
|
constructor() {
|
@@ -970,7 +1020,7 @@ var MagicEdenConnector = class extends BaseConnector {
|
|
970
1020
|
};
|
971
1021
|
getAddress(getAddressOptions).catch((error) => reject(error));
|
972
1022
|
});
|
973
|
-
|
1023
|
+
storage2 == null ? void 0 : storage2.set(`${network}:addresses`, addresses);
|
974
1024
|
return addresses;
|
975
1025
|
});
|
976
1026
|
__privateGet(this, _event2).setMaxListeners(100);
|
@@ -997,10 +1047,9 @@ var MagicEdenConnector = class extends BaseConnector {
|
|
997
1047
|
if (!this.isReady()) {
|
998
1048
|
throw new Error(`${this.metadata.name} is not install!`);
|
999
1049
|
}
|
1000
|
-
const data =
|
1050
|
+
const data = storage2 == null ? void 0 : storage2.get(`${__privateGet(this, _network2)}:addresses`);
|
1001
1051
|
if (data) {
|
1002
|
-
|
1003
|
-
return addresses.map((item) => item.address);
|
1052
|
+
return data.map((item) => item.address);
|
1004
1053
|
} else {
|
1005
1054
|
return [];
|
1006
1055
|
}
|
@@ -1011,10 +1060,9 @@ var MagicEdenConnector = class extends BaseConnector {
|
|
1011
1060
|
if (!this.isReady()) {
|
1012
1061
|
throw new Error(`${this.metadata.name} is not install!`);
|
1013
1062
|
}
|
1014
|
-
const data =
|
1063
|
+
const data = storage2 == null ? void 0 : storage2.get(`${__privateGet(this, _network2)}:addresses`);
|
1015
1064
|
if (data) {
|
1016
|
-
|
1017
|
-
return addresses[0].publicKey;
|
1065
|
+
return data[0].publicKey;
|
1018
1066
|
} else {
|
1019
1067
|
return "";
|
1020
1068
|
}
|
@@ -1127,8 +1175,7 @@ var MagicEdenConnector = class extends BaseConnector {
|
|
1127
1175
|
});
|
1128
1176
|
}
|
1129
1177
|
disconnect() {
|
1130
|
-
|
1131
|
-
localStorage.removeItem("btc-connect-magicEden-addresses-Testnet");
|
1178
|
+
storage2 == null ? void 0 : storage2.remove(`${__privateGet(this, _network2)}:addresses`);
|
1132
1179
|
}
|
1133
1180
|
};
|
1134
1181
|
_network2 = new WeakMap();
|
@@ -1222,13 +1269,14 @@ var useConnector = () => {
|
|
1222
1269
|
const { connectors, setConnectorId } = useConnectProvider();
|
1223
1270
|
const connect = (0, import_react2.useCallback)(
|
1224
1271
|
(connectorId) => __async(void 0, null, function* () {
|
1272
|
+
var _a;
|
1225
1273
|
const connector = connectors.find((item) => item.metadata.id === connectorId);
|
1226
1274
|
if (!connector) {
|
1227
1275
|
throw new Error(`connector id ${connectorId} not found`);
|
1228
1276
|
}
|
1229
1277
|
const accounts = yield connector.requestAccounts();
|
1230
1278
|
if (accounts.length > 0) {
|
1231
|
-
|
1279
|
+
(_a = storageStore()) == null ? void 0 : _a.set("current-connector-id", connector.metadata.id);
|
1232
1280
|
setConnectorId(connector.metadata.id);
|
1233
1281
|
}
|
1234
1282
|
}),
|
@@ -2391,10 +2439,11 @@ var ConnectProvider = ({
|
|
2391
2439
|
version: ((_c = options.aaOptions.accountContracts[((_b = Object.keys(options.aaOptions.accountContracts)) == null ? void 0 : _b[0]) || "BTC"]) == null ? void 0 : _c[0].version) || "1.0.0"
|
2392
2440
|
});
|
2393
2441
|
const getConnectorId = (0, import_react10.useCallback)(() => {
|
2442
|
+
var _a2;
|
2394
2443
|
if (typeof window === "undefined") {
|
2395
2444
|
return "";
|
2396
2445
|
}
|
2397
|
-
const id =
|
2446
|
+
const id = (_a2 = storageStore()) == null ? void 0 : _a2.get("current-connector-id");
|
2398
2447
|
return id != null ? id : "";
|
2399
2448
|
}, []);
|
2400
2449
|
const getConnector = (0, import_react10.useCallback)(() => {
|
@@ -2536,7 +2585,8 @@ var ConnectProvider = ({
|
|
2536
2585
|
}
|
2537
2586
|
}, [connectorId, connectors]);
|
2538
2587
|
const disconnect = (0, import_react10.useCallback)(() => {
|
2539
|
-
|
2588
|
+
var _a2;
|
2589
|
+
(_a2 = storageStore()) == null ? void 0 : _a2.remove("current-connector-id");
|
2540
2590
|
txConfirmUtils_default.reset();
|
2541
2591
|
if (connector) {
|
2542
2592
|
connector.disconnect();
|
@@ -2725,7 +2775,9 @@ function BtcWalletSelectorContextProvider({
|
|
2725
2775
|
new UnisatConnector(),
|
2726
2776
|
new XverseConnector(),
|
2727
2777
|
new OKXConnector(),
|
2728
|
-
new BitgetConnector()
|
2778
|
+
new BitgetConnector(),
|
2779
|
+
new MagicEdenConnector(),
|
2780
|
+
new BybitConnector()
|
2729
2781
|
];
|
2730
2782
|
const walletSelectorContextValue = (0, import_react11.useMemo)(() => {
|
2731
2783
|
const simpleFn = {};
|
@@ -3148,7 +3200,7 @@ function pollTransactionStatuses(network, hashes) {
|
|
3148
3200
|
var import_transactions = require("@near-js/transactions");
|
3149
3201
|
var import_key_pair = require("near-api-js/lib/utils/key_pair");
|
3150
3202
|
var import_transaction = require("near-api-js/lib/transaction");
|
3151
|
-
var
|
3203
|
+
var import_utils13 = require("@near-js/utils");
|
3152
3204
|
var import_bs58 = __toESM(require("bs58"), 1);
|
3153
3205
|
var import_js_sha256 = require("js-sha256");
|
3154
3206
|
var import_near_api_js2 = require("near-api-js");
|
@@ -3160,36 +3212,37 @@ var STORAGE_KEYS = {
|
|
3160
3212
|
PUBLIC_KEY: "btc-wallet-publickey",
|
3161
3213
|
BTC_PUBLIC_KEY: "btc-wallet-btc-publickey"
|
3162
3214
|
};
|
3215
|
+
var storage3 = storageStore("SATOSHI_WALLET_ACCOUNT");
|
3163
3216
|
var state_default = {
|
3164
3217
|
saveAccount(account) {
|
3165
3218
|
if (!account) {
|
3166
3219
|
this.removeAccount();
|
3167
3220
|
return;
|
3168
3221
|
}
|
3169
|
-
|
3222
|
+
storage3 == null ? void 0 : storage3.set(STORAGE_KEYS.ACCOUNT, account);
|
3170
3223
|
},
|
3171
3224
|
removeAccount() {
|
3172
|
-
|
3225
|
+
storage3 == null ? void 0 : storage3.remove(STORAGE_KEYS.ACCOUNT);
|
3173
3226
|
},
|
3174
3227
|
savePublicKey(publicKey) {
|
3175
3228
|
if (!publicKey) {
|
3176
3229
|
this.removePublicKey();
|
3177
3230
|
return;
|
3178
3231
|
}
|
3179
|
-
|
3232
|
+
storage3 == null ? void 0 : storage3.set(STORAGE_KEYS.PUBLIC_KEY, publicKey);
|
3180
3233
|
},
|
3181
3234
|
removePublicKey() {
|
3182
|
-
|
3235
|
+
storage3 == null ? void 0 : storage3.remove(STORAGE_KEYS.PUBLIC_KEY);
|
3183
3236
|
},
|
3184
3237
|
saveBtcPublicKey(publicKey) {
|
3185
3238
|
if (!publicKey) {
|
3186
3239
|
this.removeBtcPublicKey();
|
3187
3240
|
return;
|
3188
3241
|
}
|
3189
|
-
|
3242
|
+
storage3 == null ? void 0 : storage3.set(STORAGE_KEYS.BTC_PUBLIC_KEY, publicKey);
|
3190
3243
|
},
|
3191
3244
|
removeBtcPublicKey() {
|
3192
|
-
|
3245
|
+
storage3 == null ? void 0 : storage3.remove(STORAGE_KEYS.BTC_PUBLIC_KEY);
|
3193
3246
|
},
|
3194
3247
|
clear() {
|
3195
3248
|
this.removeAccount();
|
@@ -3205,13 +3258,13 @@ var state_default = {
|
|
3205
3258
|
this.savePublicKey(publicKey);
|
3206
3259
|
},
|
3207
3260
|
getAccount() {
|
3208
|
-
return
|
3261
|
+
return (storage3 == null ? void 0 : storage3.get(STORAGE_KEYS.ACCOUNT)) || "";
|
3209
3262
|
},
|
3210
3263
|
getPublicKey() {
|
3211
|
-
return
|
3264
|
+
return (storage3 == null ? void 0 : storage3.get(STORAGE_KEYS.PUBLIC_KEY)) || "";
|
3212
3265
|
},
|
3213
3266
|
getBtcPublicKey() {
|
3214
|
-
return
|
3267
|
+
return (storage3 == null ? void 0 : storage3.get(STORAGE_KEYS.BTC_PUBLIC_KEY)) || "";
|
3215
3268
|
},
|
3216
3269
|
isValid() {
|
3217
3270
|
const account = this.getAccount();
|
@@ -3514,7 +3567,7 @@ function convertTransactionToTxHex(_0) {
|
|
3514
3567
|
transaction.receiverId,
|
3515
3568
|
BigInt(nearNonceNumber) + BigInt(index),
|
3516
3569
|
newActions,
|
3517
|
-
(0,
|
3570
|
+
(0, import_utils13.baseDecode)(header.hash)
|
3518
3571
|
);
|
3519
3572
|
const txBytes = (0, import_transaction.encodeTransaction)(_transaction);
|
3520
3573
|
const txHex = Array.from(txBytes, (byte) => ("0" + (byte & 255).toString(16)).slice(-2)).join(
|
@@ -3536,7 +3589,8 @@ function calculateGasStrategy(_0) {
|
|
3536
3589
|
return __async(this, arguments, function* ({
|
3537
3590
|
csna,
|
3538
3591
|
transactions: transactions2,
|
3539
|
-
env
|
3592
|
+
env,
|
3593
|
+
gasStrategy = "auto"
|
3540
3594
|
}) {
|
3541
3595
|
var _a;
|
3542
3596
|
const currentConfig = getWalletConfig(env);
|
@@ -3568,6 +3622,7 @@ function calculateGasStrategy(_0) {
|
|
3568
3622
|
const nearAvailableBalance = new import_big.default(nearBalance).minus(transferAmount.near).toNumber();
|
3569
3623
|
console.log("available near balance:", nearAvailableBalance);
|
3570
3624
|
console.log("available gas token balance:", gasTokenBalance);
|
3625
|
+
console.log("gas strategy:", gasStrategy);
|
3571
3626
|
const convertTx = yield Promise.all(
|
3572
3627
|
transactions2.map(
|
3573
3628
|
(transaction, index) => convertTransactionToTxHex({
|
@@ -3579,8 +3634,20 @@ function calculateGasStrategy(_0) {
|
|
3579
3634
|
})
|
3580
3635
|
)
|
3581
3636
|
);
|
3582
|
-
|
3583
|
-
|
3637
|
+
let useNearPayGas = false;
|
3638
|
+
let perTxFee;
|
3639
|
+
if (gasStrategy === "near") {
|
3640
|
+
console.log("Forcing NEAR as gas token based on gasStrategy");
|
3641
|
+
useNearPayGas = true;
|
3642
|
+
} else if (gasStrategy === "btc") {
|
3643
|
+
console.log("Forcing BTC token as gas token based on gasStrategy");
|
3644
|
+
useNearPayGas = false;
|
3645
|
+
} else if (nearAvailableBalance > 0.5) {
|
3646
|
+
console.log("NEAR balance is enough, using NEAR to pay for gas");
|
3647
|
+
useNearPayGas = true;
|
3648
|
+
}
|
3649
|
+
let gasAmount;
|
3650
|
+
if (useNearPayGas) {
|
3584
3651
|
const gasTokens = yield nearCallFunction(
|
3585
3652
|
currentConfig.accountContractId,
|
3586
3653
|
"list_gas_token",
|
@@ -3588,39 +3655,29 @@ function calculateGasStrategy(_0) {
|
|
3588
3655
|
{ network: currentConfig.network }
|
3589
3656
|
);
|
3590
3657
|
console.log("list_gas_token gas tokens:", gasTokens);
|
3591
|
-
const
|
3592
|
-
|
3593
|
-
100
|
3594
|
-
);
|
3658
|
+
const fee = Math.max(Number(((_a = gasTokens[currentConfig.btcToken]) == null ? void 0 : _a.per_tx_protocol_fee) || 0), 100);
|
3659
|
+
perTxFee = fee.toString();
|
3595
3660
|
console.log("perTxFee:", perTxFee);
|
3596
|
-
|
3597
|
-
console.log("protocolFee:", protocolFee);
|
3598
|
-
const transferTx = yield createGasTokenTransfer({ csna, amount: protocolFee, env });
|
3599
|
-
return recalculateGasWithTransfer({
|
3600
|
-
csna,
|
3601
|
-
transferTx,
|
3602
|
-
transactions: convertTx,
|
3603
|
-
useNearPayGas: true,
|
3604
|
-
perTxFee: perTxFee.toString(),
|
3605
|
-
env
|
3606
|
-
});
|
3661
|
+
gasAmount = new import_big.default(perTxFee || "0").mul(convertTx.length).toFixed(0);
|
3607
3662
|
} else {
|
3608
|
-
|
3609
|
-
const adjustedGas = yield getPredictedGasAmount({
|
3663
|
+
gasAmount = yield getPredictedGasAmount({
|
3610
3664
|
accountContractId: currentConfig.accountContractId,
|
3611
3665
|
tokenId: currentConfig.btcToken,
|
3612
3666
|
transactions: convertTx.map((t) => t.txHex),
|
3613
3667
|
env
|
3614
3668
|
});
|
3615
|
-
const transferTx = yield createGasTokenTransfer({ csna, amount: adjustedGas, env });
|
3616
|
-
return recalculateGasWithTransfer({
|
3617
|
-
csna,
|
3618
|
-
transferTx,
|
3619
|
-
transactions: convertTx,
|
3620
|
-
useNearPayGas: false,
|
3621
|
-
env
|
3622
|
-
});
|
3623
3669
|
}
|
3670
|
+
console.log("useNearPayGas:", useNearPayGas);
|
3671
|
+
console.log("gasAmount:", gasAmount);
|
3672
|
+
const transferTx = yield createGasTokenTransfer({ csna, amount: gasAmount, env });
|
3673
|
+
return recalculateGasWithTransfer({
|
3674
|
+
csna,
|
3675
|
+
transferTx,
|
3676
|
+
transactions: convertTx,
|
3677
|
+
useNearPayGas,
|
3678
|
+
perTxFee,
|
3679
|
+
env
|
3680
|
+
});
|
3624
3681
|
});
|
3625
3682
|
}
|
3626
3683
|
function createGasTokenTransfer(_0) {
|
@@ -3907,11 +3964,13 @@ function getCsnaAccountId(env) {
|
|
3907
3964
|
});
|
3908
3965
|
}
|
3909
3966
|
function checkDepositDisabledAddress() {
|
3910
|
-
|
3967
|
+
var _a;
|
3968
|
+
const data = (_a = storageStore("SATOSHI_WALLET_XVERSE")) == null ? void 0 : _a.get(
|
3969
|
+
`Mainnet:addresses`
|
3970
|
+
);
|
3911
3971
|
if (!data)
|
3912
3972
|
return;
|
3913
|
-
const
|
3914
|
-
const address = addresses == null ? void 0 : addresses[0];
|
3973
|
+
const address = data == null ? void 0 : data[0];
|
3915
3974
|
if (address.walletType === "ledger" && !["p2wpkh", "p2sh"].includes(address.addressType)) {
|
3916
3975
|
throw new Error("Ledger is only supported for p2wpkh and p2sh address");
|
3917
3976
|
}
|
@@ -3948,7 +4007,7 @@ function executeBTCDepositAndAction(_0) {
|
|
3948
4007
|
throw new Error("Deposit amount or action is required");
|
3949
4008
|
}
|
3950
4009
|
const csna = yield getCsnaAccountId(env);
|
3951
|
-
const depositAmount =
|
4010
|
+
const depositAmount = new import_big2.default(amount || (action == null ? void 0 : action.amount) || 0).round(0, import_big2.default.roundDown).toNumber();
|
3952
4011
|
console.log("depositAmount", depositAmount);
|
3953
4012
|
if (depositAmount <= 0) {
|
3954
4013
|
throw new Error("Invalid deposit amount");
|
@@ -4052,13 +4111,14 @@ function checkSatoshiWhitelist(btcAccountId, env = "mainnet") {
|
|
4052
4111
|
return __async(this, null, function* () {
|
4053
4112
|
if (env !== "mainnet")
|
4054
4113
|
return;
|
4055
|
-
const
|
4114
|
+
const storage5 = storageStore();
|
4115
|
+
const hasShownNotice = storage5 == null ? void 0 : storage5.get("private-mainnet-notice");
|
4056
4116
|
if (!hasShownNotice) {
|
4057
4117
|
Dialog.alert({
|
4058
4118
|
title: "Notice",
|
4059
4119
|
message: "You are currently using Satoshi Private Mainnet. This is a private version for testing. Please try a small amount of assets in Ramp"
|
4060
4120
|
});
|
4061
|
-
|
4121
|
+
storage5 == null ? void 0 : storage5.set("private-mainnet-notice", "true");
|
4062
4122
|
}
|
4063
4123
|
if (!btcAccountId)
|
4064
4124
|
return;
|
@@ -4388,7 +4448,13 @@ function uint8ArrayToHex(uint8Array) {
|
|
4388
4448
|
}
|
4389
4449
|
|
4390
4450
|
// src/utils/initWalletButton.ts
|
4391
|
-
|
4451
|
+
var storage4 = storageStore("SATOSHI_WALLET_BUTTON");
|
4452
|
+
function setupWalletButton({
|
4453
|
+
env,
|
4454
|
+
nearWallet,
|
4455
|
+
btcWallet,
|
4456
|
+
walletUrl
|
4457
|
+
}) {
|
4392
4458
|
console.log(`setupWalletButton ${walletUrl || ""}`);
|
4393
4459
|
if (document.getElementById("satoshi-wallet-button")) {
|
4394
4460
|
return;
|
@@ -4411,23 +4477,25 @@ function setupWalletButton(env, wallet, originalWallet, walletUrl) {
|
|
4411
4477
|
closeImageUrl: "https://assets.deltatrade.ai/wallet-assets/wallet-btn-active.png",
|
4412
4478
|
iframe
|
4413
4479
|
});
|
4414
|
-
setupButtonClickHandler(button, iframe,
|
4480
|
+
setupButtonClickHandler(button, iframe, nearWallet, btcWallet);
|
4415
4481
|
}
|
4416
4482
|
function createFloatingButtonWithIframe({
|
4417
4483
|
openImageUrl,
|
4418
4484
|
closeImageUrl,
|
4419
4485
|
iframe
|
4420
4486
|
}) {
|
4487
|
+
var _a;
|
4421
4488
|
const button = document.createElement("img");
|
4422
4489
|
button.id = "satoshi-wallet-button";
|
4423
|
-
const isIframeVisible =
|
4490
|
+
const isIframeVisible = (_a = storage4 == null ? void 0 : storage4.get("visible")) != null ? _a : true;
|
4424
4491
|
button.src = isIframeVisible ? closeImageUrl : openImageUrl;
|
4425
4492
|
iframe.style.display = isIframeVisible ? "block" : "none";
|
4426
4493
|
const windowWidth = window.innerWidth;
|
4427
4494
|
const windowHeight = window.innerHeight;
|
4428
|
-
const savedPosition =
|
4429
|
-
|
4430
|
-
|
4495
|
+
const savedPosition = (storage4 == null ? void 0 : storage4.get("position")) || {
|
4496
|
+
right: "20px",
|
4497
|
+
bottom: "20px"
|
4498
|
+
};
|
4431
4499
|
const right = Math.min(Math.max(20, parseInt(savedPosition.right)), windowWidth - 80);
|
4432
4500
|
const bottom = Math.min(Math.max(20, parseInt(savedPosition.bottom)), windowHeight - 80);
|
4433
4501
|
Object.assign(button.style, {
|
@@ -4523,13 +4591,10 @@ function createFloatingButtonWithIframe({
|
|
4523
4591
|
isDragging = false;
|
4524
4592
|
button.style.cursor = "grab";
|
4525
4593
|
button.style.transition = "transform 0.15s ease";
|
4526
|
-
|
4527
|
-
|
4528
|
-
|
4529
|
-
|
4530
|
-
bottom: button.style.bottom
|
4531
|
-
})
|
4532
|
-
);
|
4594
|
+
storage4 == null ? void 0 : storage4.set("position", {
|
4595
|
+
right: button.style.right,
|
4596
|
+
bottom: button.style.bottom
|
4597
|
+
});
|
4533
4598
|
if (!isDragEvent) {
|
4534
4599
|
handleButtonClick();
|
4535
4600
|
}
|
@@ -4543,7 +4608,7 @@ function createFloatingButtonWithIframe({
|
|
4543
4608
|
const newVisibleState = !isCurrentlyVisible;
|
4544
4609
|
iframe.style.display = newVisibleState ? "block" : "none";
|
4545
4610
|
button.src = newVisibleState ? closeImageUrl : openImageUrl;
|
4546
|
-
|
4611
|
+
storage4 == null ? void 0 : storage4.set("visible", newVisibleState);
|
4547
4612
|
setTimeout(() => {
|
4548
4613
|
if (newVisibleState) {
|
4549
4614
|
iframe.focus();
|
@@ -4557,11 +4622,12 @@ function createIframe({
|
|
4557
4622
|
iframeUrl,
|
4558
4623
|
iframeStyle = {}
|
4559
4624
|
}) {
|
4625
|
+
var _a;
|
4560
4626
|
const iframe = document.createElement("iframe");
|
4561
4627
|
iframe.id = "satoshi-wallet-iframe";
|
4562
4628
|
iframe.allow = "clipboard-read; clipboard-write";
|
4563
4629
|
iframe.src = iframeUrl;
|
4564
|
-
const isVisible =
|
4630
|
+
const isVisible = (_a = storage4 == null ? void 0 : storage4.get("visible")) != null ? _a : true;
|
4565
4631
|
Object.assign(iframe.style, __spreadValues({
|
4566
4632
|
position: "fixed",
|
4567
4633
|
bottom: "90px",
|
@@ -4576,12 +4642,12 @@ function createIframe({
|
|
4576
4642
|
return iframe;
|
4577
4643
|
}
|
4578
4644
|
var currentMessageHandler = null;
|
4579
|
-
function setupButtonClickHandler(button, iframe,
|
4645
|
+
function setupButtonClickHandler(button, iframe, nearWallet, btcWallet) {
|
4580
4646
|
return __async(this, null, function* () {
|
4581
4647
|
var _a;
|
4582
|
-
const accountId = (_a = yield
|
4583
|
-
const originalAccountId =
|
4584
|
-
const originalPublicKey = yield
|
4648
|
+
const accountId = (_a = yield nearWallet == null ? void 0 : nearWallet.getAccounts()) == null ? void 0 : _a[0].accountId;
|
4649
|
+
const originalAccountId = btcWallet == null ? void 0 : btcWallet.account;
|
4650
|
+
const originalPublicKey = yield btcWallet == null ? void 0 : btcWallet.getPublicKey();
|
4585
4651
|
console.log({ accountId, originalAccountId, originalPublicKey });
|
4586
4652
|
const iframeSrc = new URL(iframe.src);
|
4587
4653
|
iframeSrc.searchParams.set("origin", window.location.origin);
|
@@ -4590,8 +4656,8 @@ function setupButtonClickHandler(button, iframe, wallet, originalWallet) {
|
|
4590
4656
|
originalPublicKey && iframeSrc.searchParams.set("originalPublicKey", originalPublicKey);
|
4591
4657
|
iframe.src = iframeSrc.toString();
|
4592
4658
|
const actions = {
|
4593
|
-
signAndSendTransaction:
|
4594
|
-
signAndSendTransactions:
|
4659
|
+
signAndSendTransaction: nearWallet.signAndSendTransaction,
|
4660
|
+
signAndSendTransactions: nearWallet.signAndSendTransactions,
|
4595
4661
|
executeBTCDepositAndAction,
|
4596
4662
|
getWithdrawTransaction
|
4597
4663
|
};
|
@@ -4636,6 +4702,7 @@ function setupButtonClickHandler(button, iframe, wallet, originalWallet) {
|
|
4636
4702
|
});
|
4637
4703
|
}
|
4638
4704
|
function removeWalletButton() {
|
4705
|
+
console.log("removeWalletButton");
|
4639
4706
|
const button = document.getElementById("satoshi-wallet-button");
|
4640
4707
|
button == null ? void 0 : button.remove();
|
4641
4708
|
const iframe = document.getElementById("satoshi-wallet-iframe");
|
@@ -4742,10 +4809,14 @@ var BTCWallet = (_0) => __async(void 0, [_0], function* ({
|
|
4742
4809
|
if (btcPublicKey) {
|
4743
4810
|
yield getNearAccountByBtcPublicKey(btcPublicKey);
|
4744
4811
|
removeWalletButton();
|
4745
|
-
setupWalletButton(
|
4812
|
+
setupWalletButton({
|
4813
|
+
env,
|
4814
|
+
nearWallet: wallet,
|
4815
|
+
btcWallet: btcContext,
|
4816
|
+
walletUrl: metadata.walletUrl
|
4817
|
+
});
|
4746
4818
|
}
|
4747
4819
|
} else {
|
4748
|
-
removeWalletButton();
|
4749
4820
|
connectionUpdateTimeout = setTimeout(() => {
|
4750
4821
|
handleConnectionUpdate();
|
4751
4822
|
}, 5e3);
|
@@ -4884,7 +4955,8 @@ var BTCWallet = (_0) => __async(void 0, [_0], function* ({
|
|
4884
4955
|
const { transferGasTransaction, useNearPayGas, gasLimit } = yield calculateGasStrategy({
|
4885
4956
|
csna,
|
4886
4957
|
transactions: trans,
|
4887
|
-
env
|
4958
|
+
env,
|
4959
|
+
gasStrategy: metadata.gasStrategy
|
4888
4960
|
});
|
4889
4961
|
console.log("transferGasTransaction:", transferGasTransaction);
|
4890
4962
|
console.log("useNearPayGas:", useNearPayGas);
|
@@ -4956,9 +5028,10 @@ function setupBTCWallet({
|
|
4956
5028
|
autoConnect = true,
|
4957
5029
|
syncLogOut = true,
|
4958
5030
|
env = "mainnet",
|
4959
|
-
walletUrl
|
5031
|
+
walletUrl,
|
5032
|
+
gasStrategy = "auto"
|
4960
5033
|
} = {}) {
|
4961
|
-
console.log("\u26A1\uFE0F BTC Wallet Version:", getVersion(), "env:", env);
|
5034
|
+
console.log("\u26A1\uFE0F BTC Wallet Version:", getVersion(), "env:", env, "gasStrategy:", gasStrategy);
|
4962
5035
|
const btcWallet = () => __async(this, null, function* () {
|
4963
5036
|
return {
|
4964
5037
|
id: "btc-wallet",
|
@@ -4973,7 +5046,8 @@ function setupBTCWallet({
|
|
4973
5046
|
autoConnect,
|
4974
5047
|
syncLogOut,
|
4975
5048
|
env,
|
4976
|
-
walletUrl
|
5049
|
+
walletUrl,
|
5050
|
+
gasStrategy
|
4977
5051
|
},
|
4978
5052
|
init: BTCWallet
|
4979
5053
|
};
|
@@ -4983,11 +5057,30 @@ function setupBTCWallet({
|
|
4983
5057
|
|
4984
5058
|
// src/core/setupModal.ts
|
4985
5059
|
var import_ref_modal_ui = require("ref-modal-ui");
|
5060
|
+
var subscription;
|
4986
5061
|
function setupWalletSelectorModal(selector, options) {
|
4987
5062
|
if (!selector)
|
4988
5063
|
throw new Error("selector is required");
|
5064
|
+
const {
|
5065
|
+
showChainGroups = true,
|
5066
|
+
showWalletUIForNearAccount = true,
|
5067
|
+
env = "mainnet",
|
5068
|
+
walletUrl
|
5069
|
+
} = options;
|
5070
|
+
subscription == null ? void 0 : subscription.unsubscribe();
|
4989
5071
|
const state = selector.store.getState();
|
4990
5072
|
const group = getGroup(state);
|
5073
|
+
subscription = selector.store.observable.subscribe((state2) => {
|
5074
|
+
const walletId = state2.selectedWalletId;
|
5075
|
+
console.log("setupWalletSelectorModal walletId", walletId);
|
5076
|
+
if (!walletId)
|
5077
|
+
removeWalletButton();
|
5078
|
+
if (showWalletUIForNearAccount && walletId !== "btc-wallet") {
|
5079
|
+
selector.wallet().then((wallet) => {
|
5080
|
+
setupWalletButton({ env, nearWallet: wallet, walletUrl });
|
5081
|
+
});
|
5082
|
+
}
|
5083
|
+
});
|
4991
5084
|
if (group.includes("btc")) {
|
4992
5085
|
document.head.appendChild(document.createElement("style")).textContent = `
|
4993
5086
|
#near-wallet-selector-modal .options-list .btc-wallet {
|
@@ -4998,7 +5091,7 @@ function setupWalletSelectorModal(selector, options) {
|
|
4998
5091
|
const modal = (0, import_ref_modal_ui.setupModal)(selector, options);
|
4999
5092
|
const originalShow = modal.show.bind(modal);
|
5000
5093
|
modal.show = () => __async(this, null, function* () {
|
5001
|
-
const chain = group.length > 1 ? yield openChainModal() : group[0];
|
5094
|
+
const chain = group.length > 1 && showChainGroups ? yield openChainModal() : group[0];
|
5002
5095
|
if (chain === "btc") {
|
5003
5096
|
const module2 = state.modules.find((module3) => module3.id === "btc-wallet");
|
5004
5097
|
if (module2) {
|
@@ -5036,7 +5129,7 @@ function openChainModal() {
|
|
5036
5129
|
return div;
|
5037
5130
|
};
|
5038
5131
|
return yield Dialog.openModal({
|
5039
|
-
title: "Choose
|
5132
|
+
title: "Choose Wallet",
|
5040
5133
|
titleStyle: "font-size: 18px; font-weight: 600; color: #fff; text-align: center;padding-bottom: 10px;",
|
5041
5134
|
content
|
5042
5135
|
});
|
@@ -5055,7 +5148,7 @@ function getGroup(state) {
|
|
5055
5148
|
|
5056
5149
|
// src/index.ts
|
5057
5150
|
var getVersion = () => {
|
5058
|
-
return "0.5.
|
5151
|
+
return "0.5.56-beta";
|
5059
5152
|
};
|
5060
5153
|
if (typeof window !== "undefined") {
|
5061
5154
|
window.__BTC_WALLET_VERSION = getVersion();
|