@kimafinance/kima-transaction-widget 1.4.5 → 1.4.7
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/dist/index.cjs +480 -530
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +2 -1
- package/dist/index.d.ts +2 -1
- package/dist/index.js +313 -376
- package/dist/index.js.map +1 -1
- package/dist/metafile-cjs.json +1 -1
- package/dist/metafile-esm.json +1 -1
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
|
@@ -45,8 +45,8 @@ __export(index_exports, {
|
|
|
45
45
|
module.exports = __toCommonJS(index_exports);
|
|
46
46
|
|
|
47
47
|
// src/KimaProvider.tsx
|
|
48
|
-
var
|
|
49
|
-
var
|
|
48
|
+
var React48 = __toESM(require("react"), 1);
|
|
49
|
+
var import_react59 = require("react");
|
|
50
50
|
var import_react_redux19 = require("react-redux");
|
|
51
51
|
|
|
52
52
|
// src/store/index.tsx
|
|
@@ -1402,6 +1402,40 @@ var KimaNetwork = ({ width = 120, height = 15, ...rest }) => {
|
|
|
1402
1402
|
};
|
|
1403
1403
|
var KimaNetwork_default = KimaNetwork;
|
|
1404
1404
|
|
|
1405
|
+
// src/assets/icons/CFX.tsx
|
|
1406
|
+
var import_react40 = __toESM(require("react"), 1);
|
|
1407
|
+
var CFX = ({ width = 30, height = 30, ...rest }) => {
|
|
1408
|
+
return /* @__PURE__ */ import_react40.default.createElement(
|
|
1409
|
+
"svg",
|
|
1410
|
+
{
|
|
1411
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
1412
|
+
width,
|
|
1413
|
+
height,
|
|
1414
|
+
viewBox: "0 0 1766.6 2212",
|
|
1415
|
+
fill: "none",
|
|
1416
|
+
...rest
|
|
1417
|
+
},
|
|
1418
|
+
/* @__PURE__ */ import_react40.default.createElement("g", null, /* @__PURE__ */ import_react40.default.createElement("g", null, /* @__PURE__ */ import_react40.default.createElement(
|
|
1419
|
+
"polygon",
|
|
1420
|
+
{
|
|
1421
|
+
fill: "#181818",
|
|
1422
|
+
fillRule: "evenodd",
|
|
1423
|
+
clipRule: "evenodd",
|
|
1424
|
+
points: "0,1309.5 879.5,426.3 1766.6,1317.2 1766.6,892.7 887.1,0 1,895.7"
|
|
1425
|
+
}
|
|
1426
|
+
), /* @__PURE__ */ import_react40.default.createElement(
|
|
1427
|
+
"polygon",
|
|
1428
|
+
{
|
|
1429
|
+
fill: "#181818",
|
|
1430
|
+
fillRule: "evenodd",
|
|
1431
|
+
clipRule: "evenodd",
|
|
1432
|
+
points: "203.6,1528.4 875.6,2212 1555.4,1528.4 1348,1317.2 879.5,1789.6 626,1528.4 1090.7,1052.2 882.4,845.8"
|
|
1433
|
+
}
|
|
1434
|
+
)))
|
|
1435
|
+
);
|
|
1436
|
+
};
|
|
1437
|
+
var CFX_default = CFX;
|
|
1438
|
+
|
|
1405
1439
|
// src/utils/constants.tsx
|
|
1406
1440
|
var import_networks = require("@reown/appkit/networks");
|
|
1407
1441
|
var ChainName = /* @__PURE__ */ ((ChainName2) => {
|
|
@@ -1418,6 +1452,7 @@ var ChainName = /* @__PURE__ */ ((ChainName2) => {
|
|
|
1418
1452
|
ChainName2["FIAT"] = "FIAT";
|
|
1419
1453
|
ChainName2["BTC"] = "BTC";
|
|
1420
1454
|
ChainName2["BERA"] = "BERA";
|
|
1455
|
+
ChainName2["CFX"] = "CFX";
|
|
1421
1456
|
return ChainName2;
|
|
1422
1457
|
})(ChainName || {});
|
|
1423
1458
|
var CHAIN_NAMES_TO_APPKIT_NETWORK_MAINNET = {
|
|
@@ -1428,7 +1463,9 @@ var CHAIN_NAMES_TO_APPKIT_NETWORK_MAINNET = {
|
|
|
1428
1463
|
["BSC" /* BSC */]: import_networks.bsc,
|
|
1429
1464
|
["OPT" /* OPTIMISM */]: import_networks.optimism,
|
|
1430
1465
|
["ARB" /* ARBITRUM */]: import_networks.arbitrum,
|
|
1431
|
-
["ZKE" /* POLYGON_ZKEVM */]: import_networks.polygonZkEvm
|
|
1466
|
+
["ZKE" /* POLYGON_ZKEVM */]: import_networks.polygonZkEvm,
|
|
1467
|
+
["BERA" /* BERA */]: import_networks.berachain,
|
|
1468
|
+
["CFX" /* CFX */]: import_networks.confluxESpace
|
|
1432
1469
|
};
|
|
1433
1470
|
var CHAIN_NAMES_TO_APPKIT_NETWORK_TESTNET = {
|
|
1434
1471
|
["ETH" /* ETHEREUM */]: import_networks.sepolia,
|
|
@@ -1439,7 +1476,8 @@ var CHAIN_NAMES_TO_APPKIT_NETWORK_TESTNET = {
|
|
|
1439
1476
|
["OPT" /* OPTIMISM */]: import_networks.optimismSepolia,
|
|
1440
1477
|
["ARB" /* ARBITRUM */]: import_networks.arbitrumSepolia,
|
|
1441
1478
|
["ZKE" /* POLYGON_ZKEVM */]: import_networks.polygonZkEvmCardona,
|
|
1442
|
-
["BERA" /* BERA */]: import_networks.berachainBepolia
|
|
1479
|
+
["BERA" /* BERA */]: import_networks.berachainBepolia,
|
|
1480
|
+
["CFX" /* CFX */]: import_networks.confluxESpaceTestnet
|
|
1443
1481
|
};
|
|
1444
1482
|
var CHAIN_NAMES_TO_STRING = {
|
|
1445
1483
|
["ETH" /* ETHEREUM */]: "Ethereum",
|
|
@@ -1454,7 +1492,8 @@ var CHAIN_NAMES_TO_STRING = {
|
|
|
1454
1492
|
["FIAT" /* FIAT */]: "Pay with FIAT",
|
|
1455
1493
|
["BTC" /* BTC */]: "Bitcoin",
|
|
1456
1494
|
["BASE" /* BASE */]: "Base",
|
|
1457
|
-
["BERA" /* BERA */]: "Bera"
|
|
1495
|
+
["BERA" /* BERA */]: "Bera",
|
|
1496
|
+
["CFX" /* CFX */]: "Conflux"
|
|
1458
1497
|
};
|
|
1459
1498
|
var CHAIN_STRING_TO_NAME = {
|
|
1460
1499
|
["Ethereum"]: "ETH" /* ETHEREUM */,
|
|
@@ -1469,7 +1508,8 @@ var CHAIN_STRING_TO_NAME = {
|
|
|
1469
1508
|
["Pay with FIAT"]: "FIAT" /* FIAT */,
|
|
1470
1509
|
["Bitcoin"]: "BTC" /* BTC */,
|
|
1471
1510
|
["Base"]: "BASE" /* BASE */,
|
|
1472
|
-
["Bera"]: "BERA" /* BERA
|
|
1511
|
+
["Bera"]: "BERA" /* BERA */,
|
|
1512
|
+
["Conflux"]: "CFX" /* CFX */
|
|
1473
1513
|
};
|
|
1474
1514
|
var networkOptions = [
|
|
1475
1515
|
{
|
|
@@ -1493,6 +1533,11 @@ var networkOptions = [
|
|
|
1493
1533
|
label: "Bitcoin",
|
|
1494
1534
|
icon: BTC_default
|
|
1495
1535
|
},
|
|
1536
|
+
{
|
|
1537
|
+
id: "CFX" /* CFX */,
|
|
1538
|
+
label: "Conflux",
|
|
1539
|
+
icon: CFX_default
|
|
1540
|
+
},
|
|
1496
1541
|
{
|
|
1497
1542
|
id: "ETH" /* ETHEREUM */,
|
|
1498
1543
|
label: "Ethereum",
|
|
@@ -1536,7 +1581,7 @@ var networkOptions = [
|
|
|
1536
1581
|
];
|
|
1537
1582
|
var CLUSTER = "devnet";
|
|
1538
1583
|
var SOLANA_HOST = (0, import_web3.clusterApiUrl)(CLUSTER);
|
|
1539
|
-
var isEVMChain = (chainId) => chainId === "ETH" /* ETHEREUM */ || chainId === "POL" /* POLYGON */ || chainId === "AVX" /* AVALANCHE */ || chainId === "BSC" /* BSC */ || chainId === "OPT" /* OPTIMISM */ || chainId === "ARB" /* ARBITRUM */ || chainId === "ZKE" /* POLYGON_ZKEVM */ || chainId === "BASE" /* BASE */ || chainId === "BERA" /* BERA */;
|
|
1584
|
+
var isEVMChain = (chainId) => chainId === "ETH" /* ETHEREUM */ || chainId === "POL" /* POLYGON */ || chainId === "AVX" /* AVALANCHE */ || chainId === "BSC" /* BSC */ || chainId === "OPT" /* OPTIMISM */ || chainId === "ARB" /* ARBITRUM */ || chainId === "ZKE" /* POLYGON_ZKEVM */ || chainId === "BASE" /* BASE */ || chainId === "BERA" /* BERA */ || chainId === "CFX" /* CFX */;
|
|
1540
1585
|
var lightDemoAccounts = {
|
|
1541
1586
|
EVM: "0x1150bd27bA25fa13806C98324F201dfe815A4502",
|
|
1542
1587
|
// EVM: '0x10962c43ea1bfE1186Dbf59985Df4E1ce94Ca4a9', // personal for testing
|
|
@@ -1545,7 +1590,15 @@ var lightDemoAccounts = {
|
|
|
1545
1590
|
TRX: "TBVn4bsBN4DhtZ7D3vEVpAyqkvdFn7zmpU"
|
|
1546
1591
|
// TRX: 'TL6yGtzbHfQdBRFYh4TLFoU5iiPMmpQtur' // personal for testing
|
|
1547
1592
|
};
|
|
1548
|
-
var lightDemoNetworks = [
|
|
1593
|
+
var lightDemoNetworks = [
|
|
1594
|
+
"ARB",
|
|
1595
|
+
"AVX",
|
|
1596
|
+
"BASE",
|
|
1597
|
+
"OPT",
|
|
1598
|
+
"BSC",
|
|
1599
|
+
"SOL",
|
|
1600
|
+
"TRX"
|
|
1601
|
+
];
|
|
1549
1602
|
|
|
1550
1603
|
// src/interface.tsx
|
|
1551
1604
|
var NetworkOptions = /* @__PURE__ */ ((NetworkOptions4) => {
|
|
@@ -2098,7 +2151,7 @@ var useGetEnvOptions = ({
|
|
|
2098
2151
|
};
|
|
2099
2152
|
|
|
2100
2153
|
// plugins/evm/index.tsx
|
|
2101
|
-
var
|
|
2154
|
+
var import_react48 = __toESM(require("react"), 1);
|
|
2102
2155
|
|
|
2103
2156
|
// plugins/PluginBase.ts
|
|
2104
2157
|
var PluginBase = class {
|
|
@@ -2135,10 +2188,10 @@ var PluginBase = class {
|
|
|
2135
2188
|
};
|
|
2136
2189
|
|
|
2137
2190
|
// plugins/evm/features/walletConnect/WalletProvider.tsx
|
|
2138
|
-
var
|
|
2191
|
+
var import_react42 = __toESM(require("react"), 1);
|
|
2139
2192
|
|
|
2140
2193
|
// plugins/evm/config/modalConfig.ts
|
|
2141
|
-
var
|
|
2194
|
+
var import_react41 = require("@reown/appkit/react");
|
|
2142
2195
|
var import_networks2 = require("@reown/appkit/networks");
|
|
2143
2196
|
var import_appkit_adapter_ethers = require("@reown/appkit-adapter-ethers");
|
|
2144
2197
|
var appkitMainnetChains = [
|
|
@@ -2148,7 +2201,8 @@ var appkitMainnetChains = [
|
|
|
2148
2201
|
import_networks2.base,
|
|
2149
2202
|
import_networks2.arbitrum,
|
|
2150
2203
|
import_networks2.optimism,
|
|
2151
|
-
import_networks2.avalanche
|
|
2204
|
+
import_networks2.avalanche,
|
|
2205
|
+
import_networks2.confluxESpace
|
|
2152
2206
|
];
|
|
2153
2207
|
var appkitTestnetChains = [
|
|
2154
2208
|
import_networks2.sepolia,
|
|
@@ -2158,7 +2212,8 @@ var appkitTestnetChains = [
|
|
|
2158
2212
|
import_networks2.arbitrumSepolia,
|
|
2159
2213
|
import_networks2.optimismSepolia,
|
|
2160
2214
|
import_networks2.avalancheFuji,
|
|
2161
|
-
import_networks2.berachainBepolia
|
|
2215
|
+
import_networks2.berachainBepolia,
|
|
2216
|
+
import_networks2.confluxESpaceTestnet
|
|
2162
2217
|
];
|
|
2163
2218
|
var metadata = {
|
|
2164
2219
|
name: "Kima Transaction Widget",
|
|
@@ -2173,7 +2228,7 @@ var setupAppKit = (projectId, networkOption) => {
|
|
|
2173
2228
|
return appKitModel;
|
|
2174
2229
|
}
|
|
2175
2230
|
const networks = networkOption === "mainnet" /* mainnet */ ? appkitMainnetChains : appkitTestnetChains;
|
|
2176
|
-
appKitModel = (0,
|
|
2231
|
+
appKitModel = (0, import_react41.createAppKit)({
|
|
2177
2232
|
adapters: [new import_appkit_adapter_ethers.EthersAdapter()],
|
|
2178
2233
|
metadata,
|
|
2179
2234
|
networks,
|
|
@@ -2199,17 +2254,17 @@ var WalletProvider = ({
|
|
|
2199
2254
|
walletConnectProjectId,
|
|
2200
2255
|
isLoading
|
|
2201
2256
|
}) => {
|
|
2202
|
-
const [isReady, setIsReady] = (0,
|
|
2203
|
-
(0,
|
|
2257
|
+
const [isReady, setIsReady] = (0, import_react42.useState)(false);
|
|
2258
|
+
(0, import_react42.useEffect)(() => {
|
|
2204
2259
|
if (!isLoading && networkOption) {
|
|
2205
2260
|
setupAppKit(walletConnectProjectId, networkOption);
|
|
2206
2261
|
setIsReady(true);
|
|
2207
2262
|
}
|
|
2208
2263
|
}, [networkOption, isLoading, walletConnectProjectId]);
|
|
2209
2264
|
if (!isReady) {
|
|
2210
|
-
return /* @__PURE__ */
|
|
2265
|
+
return /* @__PURE__ */ import_react42.default.createElement(import_react42.default.Fragment, null);
|
|
2211
2266
|
}
|
|
2212
|
-
return /* @__PURE__ */
|
|
2267
|
+
return /* @__PURE__ */ import_react42.default.createElement(import_react42.default.Fragment, null, children);
|
|
2213
2268
|
};
|
|
2214
2269
|
var WalletProvider_default = WalletProvider;
|
|
2215
2270
|
|
|
@@ -2252,124 +2307,13 @@ var selectCCTransactionIdSeed = (state) => state.option.ccTransactionIdSeed;
|
|
|
2252
2307
|
var selectCCTransactionStatus = (state) => state.option.ccTransactionStatus;
|
|
2253
2308
|
var selectCCTransactionRetrying = (state) => state.option.ccTransactionRetrying;
|
|
2254
2309
|
|
|
2255
|
-
// plugins/evm/utils/constants.tsx
|
|
2256
|
-
var import_web32 = require("@solana/web3.js");
|
|
2257
|
-
|
|
2258
|
-
// plugins/evm/assets/icons/Cross.tsx
|
|
2259
|
-
var import_react42 = __toESM(require("react"), 1);
|
|
2260
|
-
|
|
2261
|
-
// plugins/evm/assets/icons/Minimize.tsx
|
|
2262
|
-
var import_react43 = __toESM(require("react"), 1);
|
|
2263
|
-
|
|
2264
|
-
// plugins/evm/assets/icons/FooterLogo.tsx
|
|
2265
|
-
var import_react44 = __toESM(require("react"), 1);
|
|
2266
|
-
|
|
2267
|
-
// plugins/evm/assets/icons/Check.tsx
|
|
2268
|
-
var import_react45 = __toESM(require("react"), 1);
|
|
2269
|
-
|
|
2270
|
-
// plugins/evm/assets/icons/Warning.tsx
|
|
2271
|
-
var import_react46 = __toESM(require("react"), 1);
|
|
2272
|
-
|
|
2273
|
-
// plugins/evm/assets/icons/ArrowRight.tsx
|
|
2274
|
-
var import_react47 = __toESM(require("react"), 1);
|
|
2275
|
-
|
|
2276
|
-
// plugins/evm/assets/icons/Arrow.tsx
|
|
2277
|
-
var import_react48 = __toESM(require("react"), 1);
|
|
2278
|
-
|
|
2279
|
-
// plugins/evm/assets/icons/Lock.tsx
|
|
2280
|
-
var import_react49 = __toESM(require("react"), 1);
|
|
2281
|
-
|
|
2282
|
-
// plugins/evm/assets/icons/Ethereum.tsx
|
|
2283
|
-
var import_react50 = __toESM(require("react"), 1);
|
|
2284
|
-
|
|
2285
|
-
// plugins/evm/assets/icons/Solana.tsx
|
|
2286
|
-
var import_react51 = __toESM(require("react"), 1);
|
|
2287
|
-
|
|
2288
|
-
// plugins/evm/assets/icons/Polygon.tsx
|
|
2289
|
-
var import_react52 = __toESM(require("react"), 1);
|
|
2290
|
-
|
|
2291
|
-
// plugins/evm/assets/icons/Polygon_zkEVM.tsx
|
|
2292
|
-
var import_react53 = __toESM(require("react"), 1);
|
|
2293
|
-
|
|
2294
|
-
// plugins/evm/assets/icons/Loader.tsx
|
|
2295
|
-
var import_react54 = __toESM(require("react"), 1);
|
|
2296
|
-
|
|
2297
|
-
// plugins/evm/assets/icons/Error.tsx
|
|
2298
|
-
var import_react55 = __toESM(require("react"), 1);
|
|
2299
|
-
|
|
2300
|
-
// plugins/evm/assets/icons/Avalanche.tsx
|
|
2301
|
-
var import_react56 = __toESM(require("react"), 1);
|
|
2302
|
-
|
|
2303
|
-
// plugins/evm/assets/icons/Arbitrum.tsx
|
|
2304
|
-
var import_react57 = __toESM(require("react"), 1);
|
|
2305
|
-
|
|
2306
|
-
// plugins/evm/assets/icons/Optimism.tsx
|
|
2307
|
-
var import_react58 = __toESM(require("react"), 1);
|
|
2308
|
-
|
|
2309
|
-
// plugins/evm/assets/icons/USDC.tsx
|
|
2310
|
-
var import_react59 = __toESM(require("react"), 1);
|
|
2311
|
-
|
|
2312
|
-
// plugins/evm/assets/icons/USDT.tsx
|
|
2313
|
-
var import_react60 = __toESM(require("react"), 1);
|
|
2314
|
-
|
|
2315
|
-
// plugins/evm/assets/icons/USDK.tsx
|
|
2316
|
-
var import_react61 = __toESM(require("react"), 1);
|
|
2317
|
-
|
|
2318
|
-
// plugins/evm/assets/icons/Fuse.tsx
|
|
2319
|
-
var import_react62 = __toESM(require("react"), 1);
|
|
2320
|
-
|
|
2321
|
-
// plugins/evm/assets/icons/Celo.tsx
|
|
2322
|
-
var import_react63 = __toESM(require("react"), 1);
|
|
2323
|
-
|
|
2324
|
-
// plugins/evm/assets/icons/GoodDollar.tsx
|
|
2325
|
-
var import_react64 = __toESM(require("react"), 1);
|
|
2326
|
-
|
|
2327
|
-
// plugins/evm/assets/icons/Copy.tsx
|
|
2328
|
-
var import_react65 = __toESM(require("react"), 1);
|
|
2329
|
-
|
|
2330
|
-
// plugins/evm/assets/icons/Bank.tsx
|
|
2331
|
-
var import_react66 = __toESM(require("react"), 1);
|
|
2332
|
-
|
|
2333
|
-
// plugins/evm/assets/icons/BSC.tsx
|
|
2334
|
-
var import_react67 = __toESM(require("react"), 1);
|
|
2335
|
-
|
|
2336
|
-
// plugins/evm/assets/icons/KEUR.tsx
|
|
2337
|
-
var import_react68 = __toESM(require("react"), 1);
|
|
2338
|
-
|
|
2339
|
-
// plugins/evm/assets/icons/Tron.tsx
|
|
2340
|
-
var import_react69 = __toESM(require("react"), 1);
|
|
2341
|
-
|
|
2342
|
-
// plugins/evm/assets/icons/BTC.tsx
|
|
2343
|
-
var import_react70 = __toESM(require("react"), 1);
|
|
2344
|
-
|
|
2345
|
-
// plugins/evm/assets/icons/Wallet.tsx
|
|
2346
|
-
var import_react71 = __toESM(require("react"), 1);
|
|
2347
|
-
|
|
2348
|
-
// plugins/evm/assets/icons/Explorer.tsx
|
|
2349
|
-
var import_react72 = __toESM(require("react"), 1);
|
|
2350
|
-
|
|
2351
|
-
// plugins/evm/assets/icons/ExternalUrl.tsx
|
|
2352
|
-
var import_react73 = __toESM(require("react"), 1);
|
|
2353
|
-
|
|
2354
|
-
// plugins/evm/assets/icons/Base.tsx
|
|
2355
|
-
var import_react74 = __toESM(require("react"), 1);
|
|
2356
|
-
|
|
2357
|
-
// plugins/evm/assets/icons/Bera.tsx
|
|
2358
|
-
var import_react75 = __toESM(require("react"), 1);
|
|
2359
|
-
|
|
2360
|
-
// plugins/evm/utils/constants.tsx
|
|
2361
|
-
var import_networks3 = require("@reown/appkit/networks");
|
|
2362
|
-
var CLUSTER2 = "devnet";
|
|
2363
|
-
var SOLANA_HOST2 = (0, import_web32.clusterApiUrl)(CLUSTER2);
|
|
2364
|
-
var isEVMChain2 = (chainId) => chainId === "ETH" /* ETHEREUM */ || chainId === "POL" /* POLYGON */ || chainId === "AVX" /* AVALANCHE */ || chainId === "BSC" /* BSC */ || chainId === "OPT" /* OPTIMISM */ || chainId === "ARB" /* ARBITRUM */ || chainId === "ZKE" /* POLYGON_ZKEVM */ || chainId === "BASE" /* BASE */ || chainId === "BERA" /* BERA */;
|
|
2365
|
-
|
|
2366
2310
|
// plugins/evm/core/hooks/useEvmProvider.ts
|
|
2367
|
-
var
|
|
2311
|
+
var import_react43 = require("@reown/appkit/react");
|
|
2368
2312
|
var import_ethers = require("ethers");
|
|
2369
2313
|
var useEvmProvider = () => {
|
|
2370
2314
|
const { externalProvider } = useKimaContext();
|
|
2371
|
-
const { walletProvider: appkitProvider } = (0,
|
|
2372
|
-
const appkitAccountInfo = (0,
|
|
2315
|
+
const { walletProvider: appkitProvider } = (0, import_react43.useAppKitProvider)("eip155");
|
|
2316
|
+
const appkitAccountInfo = (0, import_react43.useAppKitAccount)();
|
|
2373
2317
|
const walletAddress = externalProvider?.signer instanceof import_ethers.JsonRpcSigner && externalProvider.signer.address || appkitAccountInfo?.address;
|
|
2374
2318
|
const walletProvider = externalProvider?.provider instanceof import_ethers.BrowserProvider ? externalProvider.provider : appkitProvider;
|
|
2375
2319
|
return {
|
|
@@ -2383,7 +2327,7 @@ var import_viem = require("viem");
|
|
|
2383
2327
|
|
|
2384
2328
|
// src/utils/functions.tsx
|
|
2385
2329
|
var import_ethers2 = require("ethers");
|
|
2386
|
-
var
|
|
2330
|
+
var import_web32 = require("@solana/web3.js");
|
|
2387
2331
|
var import_tronweb = require("tronweb");
|
|
2388
2332
|
var getShortenedAddress = (address) => {
|
|
2389
2333
|
const is0x = (addr) => addr?.startsWith("0x");
|
|
@@ -2450,7 +2394,7 @@ var isValidExternalProvider = (externalProvider) => {
|
|
|
2450
2394
|
return false;
|
|
2451
2395
|
}
|
|
2452
2396
|
if (type === "solana") {
|
|
2453
|
-
if (!isSolProvider(provider) || !(signer instanceof
|
|
2397
|
+
if (!isSolProvider(provider) || !(signer instanceof import_web32.PublicKey))
|
|
2454
2398
|
return false;
|
|
2455
2399
|
}
|
|
2456
2400
|
if (type === "tron") {
|
|
@@ -2460,7 +2404,7 @@ var isValidExternalProvider = (externalProvider) => {
|
|
|
2460
2404
|
return true;
|
|
2461
2405
|
};
|
|
2462
2406
|
var isSolProvider = (provider) => {
|
|
2463
|
-
return provider && provider.connection instanceof
|
|
2407
|
+
return provider && provider.connection instanceof import_web32.Connection && typeof provider.signTransaction === "function";
|
|
2464
2408
|
};
|
|
2465
2409
|
var isTronProvider = (provider) => {
|
|
2466
2410
|
return provider && provider.tronWeb instanceof import_tronweb.TronWeb && typeof provider.signTransaction === "function";
|
|
@@ -2578,7 +2522,7 @@ function useBalance() {
|
|
|
2578
2522
|
const { pools } = useGetPools_default(backendUrl, networkOption);
|
|
2579
2523
|
const { walletAddress, walletProvider } = useEvmProvider();
|
|
2580
2524
|
const userAddress = mode === "light" /* light */ ? lightDemoAccounts.EVM : walletAddress;
|
|
2581
|
-
const enabled = !!userAddress && !!tokenOptions && !!selectedCoin && pools.length > 0 &&
|
|
2525
|
+
const enabled = !!userAddress && !!tokenOptions && !!selectedCoin && pools.length > 0 && isEVMChain(sourceChain.shortName) && (!!walletProvider || mode === "light" /* light */);
|
|
2582
2526
|
const { data: allowanceData } = (0, import_react_query3.useQuery)({
|
|
2583
2527
|
queryKey: [
|
|
2584
2528
|
"evmAllowance",
|
|
@@ -2603,7 +2547,7 @@ function useBalance() {
|
|
|
2603
2547
|
|
|
2604
2548
|
// plugins/evm/core/hooks/useNativeBalance.ts
|
|
2605
2549
|
var import_react_query4 = require("@tanstack/react-query");
|
|
2606
|
-
var
|
|
2550
|
+
var import_react44 = require("@reown/appkit/react");
|
|
2607
2551
|
|
|
2608
2552
|
// plugins/evm/utils/getBalance.ts
|
|
2609
2553
|
var import_ethers3 = require("ethers");
|
|
@@ -2637,9 +2581,9 @@ var getEvmBalance = async (input) => {
|
|
|
2637
2581
|
var import_react_redux2 = require("react-redux");
|
|
2638
2582
|
var useNativeEvmBalance = () => {
|
|
2639
2583
|
const { externalProvider } = useKimaContext();
|
|
2640
|
-
const appkitAccountInfo = (0,
|
|
2584
|
+
const appkitAccountInfo = (0, import_react44.useAppKitAccount)();
|
|
2641
2585
|
const { address: appkitAddress } = appkitAccountInfo || {};
|
|
2642
|
-
const { walletProvider } = (0,
|
|
2586
|
+
const { walletProvider } = (0, import_react44.useAppKitProvider)("eip155");
|
|
2643
2587
|
const sourceChain = (0, import_react_redux2.useSelector)(selectSourceChain);
|
|
2644
2588
|
const networkOption = (0, import_react_redux2.useSelector)(selectNetworkOption);
|
|
2645
2589
|
const walletAddress = externalProvider?.signer?.address || appkitAddress;
|
|
@@ -2670,9 +2614,9 @@ var useNativeEvmBalance = () => {
|
|
|
2670
2614
|
var useNativeBalance_default = useNativeEvmBalance;
|
|
2671
2615
|
|
|
2672
2616
|
// plugins/evm/core/hooks/useIsWalletReady.tsx
|
|
2673
|
-
var
|
|
2617
|
+
var import_react45 = require("react");
|
|
2674
2618
|
var import_react_redux4 = require("react-redux");
|
|
2675
|
-
var
|
|
2619
|
+
var import_react46 = require("@reown/appkit/react");
|
|
2676
2620
|
|
|
2677
2621
|
// plugins/evm/utils/switchNetworkEthers.tsx
|
|
2678
2622
|
var import_ethers4 = require("ethers");
|
|
@@ -2780,16 +2724,16 @@ function useIsWalletReady() {
|
|
|
2780
2724
|
const backendUrl = (0, import_react_redux4.useSelector)(selectBackendUrl);
|
|
2781
2725
|
const mode = (0, import_react_redux4.useSelector)(selectMode);
|
|
2782
2726
|
const { data: chains } = useChainData(backendUrl);
|
|
2783
|
-
const { walletProvider: appkitProvider } = (0,
|
|
2784
|
-
const appkitAccountInfo = (0,
|
|
2785
|
-
const { chainId: walletChainId } = (0,
|
|
2727
|
+
const { walletProvider: appkitProvider } = (0, import_react46.useAppKitProvider)("eip155");
|
|
2728
|
+
const appkitAccountInfo = (0, import_react46.useAppKitAccount)();
|
|
2729
|
+
const { chainId: walletChainId } = (0, import_react46.useAppKitNetwork)();
|
|
2786
2730
|
const { address: walletAddress, isConnected: appkitIsConnected } = appkitAccountInfo || {};
|
|
2787
2731
|
const isConnected = appkitIsConnected && walletAddress !== void 0;
|
|
2788
2732
|
const sourceChain = (0, import_react_redux4.useSelector)(selectSourceChain);
|
|
2789
|
-
const [isReady, setIsReady] = (0,
|
|
2790
|
-
const [statusMessage, setStatusMessage] = (0,
|
|
2791
|
-
const [connectedAddress, setConnectedAddress] = (0,
|
|
2792
|
-
const switchNetwork = (0,
|
|
2733
|
+
const [isReady, setIsReady] = (0, import_react45.useState)(false);
|
|
2734
|
+
const [statusMessage, setStatusMessage] = (0, import_react45.useState)("Wallet not connected");
|
|
2735
|
+
const [connectedAddress, setConnectedAddress] = (0, import_react45.useState)("");
|
|
2736
|
+
const switchNetwork = (0, import_react45.useCallback)(async () => {
|
|
2793
2737
|
logger_default.debug("useIsWalletReady:EVM:Attempting to switch network...", {
|
|
2794
2738
|
hasProvider: !!appkitProvider,
|
|
2795
2739
|
sourceChain,
|
|
@@ -2809,7 +2753,7 @@ function useIsWalletReady() {
|
|
|
2809
2753
|
}
|
|
2810
2754
|
}
|
|
2811
2755
|
}, [appkitProvider, sourceChain]);
|
|
2812
|
-
(0,
|
|
2756
|
+
(0, import_react45.useEffect)(() => {
|
|
2813
2757
|
const resolveConnection = async () => {
|
|
2814
2758
|
if (mode === "light" /* light */) {
|
|
2815
2759
|
const demoAddress = lightDemoAccounts.EVM;
|
|
@@ -3002,9 +2946,9 @@ function useEvmAllowance() {
|
|
|
3002
2946
|
}
|
|
3003
2947
|
|
|
3004
2948
|
// plugins/evm/core/hooks/useDisconnectWallet.tsx
|
|
3005
|
-
var
|
|
2949
|
+
var import_react47 = require("@reown/appkit/react");
|
|
3006
2950
|
function useDisconnectWallet() {
|
|
3007
|
-
const { disconnect } = (0,
|
|
2951
|
+
const { disconnect } = (0, import_react47.useDisconnect)();
|
|
3008
2952
|
return { disconnectWallet: disconnect };
|
|
3009
2953
|
}
|
|
3010
2954
|
var useDisconnectWallet_default = useDisconnectWallet;
|
|
@@ -3032,7 +2976,7 @@ var EvmPlugin = class extends PluginBase {
|
|
|
3032
2976
|
walletConnectProjectId,
|
|
3033
2977
|
isLoading
|
|
3034
2978
|
}) => {
|
|
3035
|
-
return /* @__PURE__ */
|
|
2979
|
+
return /* @__PURE__ */ import_react48.default.createElement(
|
|
3036
2980
|
WalletProvider_default,
|
|
3037
2981
|
{
|
|
3038
2982
|
children,
|
|
@@ -3048,17 +2992,17 @@ var evmPlugin = new EvmPlugin(store);
|
|
|
3048
2992
|
var evm_default = evmPlugin;
|
|
3049
2993
|
|
|
3050
2994
|
// plugins/solana/index.tsx
|
|
3051
|
-
var
|
|
2995
|
+
var import_react51 = __toESM(require("react"), 1);
|
|
3052
2996
|
|
|
3053
2997
|
// plugins/solana/features/walletConnect/WalletProvider.tsx
|
|
3054
|
-
var
|
|
2998
|
+
var import_react49 = __toESM(require("react"), 1);
|
|
3055
2999
|
var import_wallet_adapter_react = require("@solana/wallet-adapter-react");
|
|
3056
3000
|
var import_wallet_adapter_wallets = require("@solana/wallet-adapter-wallets");
|
|
3057
3001
|
|
|
3058
3002
|
// plugins/solana/utils/constants.tsx
|
|
3059
|
-
var
|
|
3003
|
+
var import_web33 = require("@solana/web3.js");
|
|
3060
3004
|
function getHostEndpoint(networkOption) {
|
|
3061
|
-
return networkOption === "mainnet" ? "https://solana-rpc.publicnode.com" : (0,
|
|
3005
|
+
return networkOption === "mainnet" ? "https://solana-rpc.publicnode.com" : (0, import_web33.clusterApiUrl)("devnet");
|
|
3062
3006
|
}
|
|
3063
3007
|
var networkOptions2 = [
|
|
3064
3008
|
{
|
|
@@ -3079,7 +3023,7 @@ var WalletProvider2 = ({
|
|
|
3079
3023
|
logger_default.debug(
|
|
3080
3024
|
`WalletProvider initialized with projectId: ${walletConnectProjectId}`
|
|
3081
3025
|
);
|
|
3082
|
-
return /* @__PURE__ */
|
|
3026
|
+
return /* @__PURE__ */ import_react49.default.createElement(import_wallet_adapter_react.ConnectionProvider, { endpoint }, /* @__PURE__ */ import_react49.default.createElement(
|
|
3083
3027
|
import_wallet_adapter_react.WalletProvider,
|
|
3084
3028
|
{
|
|
3085
3029
|
autoConnect: false,
|
|
@@ -3102,10 +3046,10 @@ var import_wallet_adapter_react2 = require("@solana/wallet-adapter-react");
|
|
|
3102
3046
|
var import_react_query7 = require("@tanstack/react-query");
|
|
3103
3047
|
|
|
3104
3048
|
// plugins/solana/utils/getSolBalance.tsx
|
|
3105
|
-
var
|
|
3049
|
+
var import_web34 = require("@solana/web3.js");
|
|
3106
3050
|
var getSolBalance = async (connection, publicKey) => {
|
|
3107
3051
|
try {
|
|
3108
|
-
const balance = await connection.getBalance(publicKey) /
|
|
3052
|
+
const balance = await connection.getBalance(publicKey) / import_web34.LAMPORTS_PER_SOL;
|
|
3109
3053
|
logger_default.debug("(NEW) SOL balance:", balance);
|
|
3110
3054
|
return balance ?? 0;
|
|
3111
3055
|
} catch (error) {
|
|
@@ -3115,7 +3059,7 @@ var getSolBalance = async (connection, publicKey) => {
|
|
|
3115
3059
|
};
|
|
3116
3060
|
|
|
3117
3061
|
// plugins/solana/core/hooks/useGetSolBalance.tsx
|
|
3118
|
-
var
|
|
3062
|
+
var import_web35 = require("@solana/web3.js");
|
|
3119
3063
|
var import_react_redux6 = require("react-redux");
|
|
3120
3064
|
function useGetSolBalance() {
|
|
3121
3065
|
const { externalProvider } = useKimaContext();
|
|
@@ -3123,7 +3067,7 @@ function useGetSolBalance() {
|
|
|
3123
3067
|
const { connection: internalConnection } = (0, import_wallet_adapter_react2.useConnection)();
|
|
3124
3068
|
const sourceNetwork = (0, import_react_redux6.useSelector)(selectSourceChain);
|
|
3125
3069
|
const isSolanaPublicKey = (key) => {
|
|
3126
|
-
return key instanceof
|
|
3070
|
+
return key instanceof import_web35.PublicKey;
|
|
3127
3071
|
};
|
|
3128
3072
|
const publicKey = isSolanaPublicKey(externalProvider?.signer) ? externalProvider.signer : internalPublicKey;
|
|
3129
3073
|
const connection = externalProvider?.provider.connection || internalConnection;
|
|
@@ -3149,7 +3093,7 @@ var import_react_redux8 = require("react-redux");
|
|
|
3149
3093
|
|
|
3150
3094
|
// plugins/solana/utils/getTokenAllowance.tsx
|
|
3151
3095
|
var import_spl_token = require("@solana/spl-token");
|
|
3152
|
-
var
|
|
3096
|
+
var import_web36 = require("@solana/web3.js");
|
|
3153
3097
|
var getTokenAllowance2 = async ({
|
|
3154
3098
|
tokenOptions,
|
|
3155
3099
|
selectedCoin,
|
|
@@ -3160,7 +3104,7 @@ var getTokenAllowance2 = async ({
|
|
|
3160
3104
|
try {
|
|
3161
3105
|
const tokenAddress = getTokenAddress(tokenOptions, selectedCoin, "SOL");
|
|
3162
3106
|
const poolAddress = getPoolAddress(pools, "SOL");
|
|
3163
|
-
const mintPublicKey = new
|
|
3107
|
+
const mintPublicKey = new import_web36.PublicKey(tokenAddress);
|
|
3164
3108
|
const tokenAccountAddress = await (0, import_spl_token.getAssociatedTokenAddress)(
|
|
3165
3109
|
mintPublicKey,
|
|
3166
3110
|
userPublicKey
|
|
@@ -3186,7 +3130,7 @@ var import_react_query8 = require("@tanstack/react-query");
|
|
|
3186
3130
|
// plugins/solana/core/hooks/useSolanaProvider.ts
|
|
3187
3131
|
var import_react_redux7 = require("react-redux");
|
|
3188
3132
|
var import_wallet_adapter_react3 = require("@solana/wallet-adapter-react");
|
|
3189
|
-
var
|
|
3133
|
+
var import_web37 = require("@solana/web3.js");
|
|
3190
3134
|
var useSolanaProvider = () => {
|
|
3191
3135
|
const sourceChain = (0, import_react_redux7.useSelector)(selectSourceChain);
|
|
3192
3136
|
const { externalProvider } = useKimaContext();
|
|
@@ -3196,8 +3140,8 @@ var useSolanaProvider = () => {
|
|
|
3196
3140
|
signTransaction: internalSignTransaction,
|
|
3197
3141
|
signMessage: internalSignMessage
|
|
3198
3142
|
} = (0, import_wallet_adapter_react3.useWallet)();
|
|
3199
|
-
const isSolanaProvider = sourceChain.shortName === "SOL" && externalProvider?.type === "solana" && externalProvider.provider && externalProvider.signer instanceof
|
|
3200
|
-
const userPublicKey = isSolanaProvider && externalProvider && externalProvider.signer instanceof
|
|
3143
|
+
const isSolanaProvider = sourceChain.shortName === "SOL" && externalProvider?.type === "solana" && externalProvider.provider && externalProvider.signer instanceof import_web37.PublicKey;
|
|
3144
|
+
const userPublicKey = isSolanaProvider && externalProvider && externalProvider.signer instanceof import_web37.PublicKey ? externalProvider?.signer : sourceChain.shortName === "SOL" ? internalPublicKey : null;
|
|
3201
3145
|
const signTransaction = isSolanaProvider && externalProvider && "signTransaction" in externalProvider.provider ? externalProvider.provider.signTransaction : sourceChain.shortName === "SOL" ? internalSignTransaction : void 0;
|
|
3202
3146
|
const signMessage = isSolanaProvider && externalProvider && "signMessage" in externalProvider.provider ? externalProvider.provider.signMessage : sourceChain.shortName === "SOL" ? internalSignMessage : void 0;
|
|
3203
3147
|
const connection = isSolanaProvider && externalProvider && "connection" in externalProvider.provider ? externalProvider.provider.connection : sourceChain.shortName === "SOL" ? internalConnection : void 0;
|
|
@@ -3210,7 +3154,7 @@ var useSolanaProvider = () => {
|
|
|
3210
3154
|
};
|
|
3211
3155
|
|
|
3212
3156
|
// plugins/solana/core/hooks/useBalance.tsx
|
|
3213
|
-
var
|
|
3157
|
+
var import_web38 = require("@solana/web3.js");
|
|
3214
3158
|
var emptyResult2 = {};
|
|
3215
3159
|
function useBalance2() {
|
|
3216
3160
|
const sourceChain = (0, import_react_redux8.useSelector)(selectSourceChain);
|
|
@@ -3222,7 +3166,7 @@ function useBalance2() {
|
|
|
3222
3166
|
const { pools } = useGetPools_default(backendUrl, networkOption);
|
|
3223
3167
|
const { connection, userPublicKey } = useSolanaProvider();
|
|
3224
3168
|
const resolvedAddress = mode === "light" /* light */ ? lightDemoAccounts.SOL : userPublicKey;
|
|
3225
|
-
const publicKey = resolvedAddress ? new
|
|
3169
|
+
const publicKey = resolvedAddress ? new import_web38.PublicKey(resolvedAddress) : void 0;
|
|
3226
3170
|
const { data: allowanceData } = (0, import_react_query8.useQuery)({
|
|
3227
3171
|
queryKey: [
|
|
3228
3172
|
"solanaAllowance",
|
|
@@ -3249,7 +3193,7 @@ function useBalance2() {
|
|
|
3249
3193
|
|
|
3250
3194
|
// plugins/solana/core/hooks/useSolanaAllowance.tsx
|
|
3251
3195
|
var import_spl_token2 = require("@solana/spl-token");
|
|
3252
|
-
var
|
|
3196
|
+
var import_web39 = require("@solana/web3.js");
|
|
3253
3197
|
var import_react_query9 = require("@tanstack/react-query");
|
|
3254
3198
|
function useSolanaAllowance() {
|
|
3255
3199
|
const queryClient2 = (0, import_react_query9.useQueryClient)();
|
|
@@ -3265,7 +3209,7 @@ function useSolanaAllowance() {
|
|
|
3265
3209
|
const { pools } = useGetPools_default(backendUrl, networkOption);
|
|
3266
3210
|
const { userPublicKey, signTransaction, signMessage, connection } = useSolanaProvider();
|
|
3267
3211
|
const allowanceData = useBalance2();
|
|
3268
|
-
const publicKey = mode === "light" /* light */ ? new
|
|
3212
|
+
const publicKey = mode === "light" /* light */ ? new import_web39.PublicKey(lightDemoAccounts.SOL) : userPublicKey;
|
|
3269
3213
|
const signSolanaMessage = async (data) => {
|
|
3270
3214
|
if (!signMessage) {
|
|
3271
3215
|
logger_default.warn("useSolanaAllowance: Missing Solana provider setup");
|
|
@@ -3297,20 +3241,20 @@ function useSolanaAllowance() {
|
|
|
3297
3241
|
const tokenAddress = getTokenAddress(tokenOptions, selectedCoin, "SOL");
|
|
3298
3242
|
try {
|
|
3299
3243
|
const tokenAccountAddress = await (0, import_spl_token2.getAssociatedTokenAddress)(
|
|
3300
|
-
new
|
|
3244
|
+
new import_web39.PublicKey(tokenAddress),
|
|
3301
3245
|
publicKey
|
|
3302
3246
|
);
|
|
3303
3247
|
const amount = isCancel ? 0n : allowanceNumber;
|
|
3304
3248
|
logger_default.debug("useSolanaAllowance: Approving amount:", amount);
|
|
3305
3249
|
const approveInstruction = (0, import_spl_token2.createApproveInstruction)(
|
|
3306
3250
|
tokenAccountAddress,
|
|
3307
|
-
new
|
|
3251
|
+
new import_web39.PublicKey(poolAddress),
|
|
3308
3252
|
publicKey,
|
|
3309
3253
|
amount,
|
|
3310
3254
|
[],
|
|
3311
3255
|
import_spl_token2.TOKEN_PROGRAM_ID
|
|
3312
3256
|
);
|
|
3313
|
-
const transaction = new
|
|
3257
|
+
const transaction = new import_web39.Transaction().add(approveInstruction);
|
|
3314
3258
|
transaction.feePayer = publicKey;
|
|
3315
3259
|
transaction.recentBlockhash = (await connection.getLatestBlockhash()).blockhash;
|
|
3316
3260
|
const signedTransaction = await signTransaction(transaction);
|
|
@@ -3345,7 +3289,7 @@ function useSolanaAllowance() {
|
|
|
3345
3289
|
}
|
|
3346
3290
|
|
|
3347
3291
|
// plugins/solana/core/hooks/useIsWalletReady.tsx
|
|
3348
|
-
var
|
|
3292
|
+
var import_react50 = require("react");
|
|
3349
3293
|
var import_wallet_adapter_react4 = require("@solana/wallet-adapter-react");
|
|
3350
3294
|
var import_react_redux10 = require("react-redux");
|
|
3351
3295
|
var import_react_redux11 = require("react-redux");
|
|
@@ -3360,7 +3304,7 @@ function useIsWalletReady2() {
|
|
|
3360
3304
|
const { externalProvider } = useKimaContext();
|
|
3361
3305
|
const { publicKey: solanaAddress } = (0, import_wallet_adapter_react4.useWallet)();
|
|
3362
3306
|
const sourceChain = (0, import_react_redux10.useSelector)(selectSourceChain);
|
|
3363
|
-
(0,
|
|
3307
|
+
(0, import_react50.useEffect)(() => {
|
|
3364
3308
|
if (sourceChain.shortName !== "SOL") return;
|
|
3365
3309
|
if (mode === "light" /* light */) {
|
|
3366
3310
|
dispatch(setSourceAddress(lightDemoAccounts.SOL));
|
|
@@ -3368,7 +3312,7 @@ function useIsWalletReady2() {
|
|
|
3368
3312
|
}
|
|
3369
3313
|
solanaAddress && dispatch(setSourceAddress(solanaAddress.toBase58()));
|
|
3370
3314
|
}, [mode, solanaAddress, sourceChain]);
|
|
3371
|
-
return (0,
|
|
3315
|
+
return (0, import_react50.useMemo)(() => {
|
|
3372
3316
|
if (mode === "light" /* light */)
|
|
3373
3317
|
return createWalletStatus(
|
|
3374
3318
|
true,
|
|
@@ -3422,7 +3366,7 @@ var SolanaPlugin = class extends PluginBase {
|
|
|
3422
3366
|
networkOption,
|
|
3423
3367
|
walletConnectProjectId
|
|
3424
3368
|
}) => {
|
|
3425
|
-
return /* @__PURE__ */
|
|
3369
|
+
return /* @__PURE__ */ import_react51.default.createElement(
|
|
3426
3370
|
WalletProvider_default2,
|
|
3427
3371
|
{
|
|
3428
3372
|
networkOption,
|
|
@@ -3436,10 +3380,10 @@ var solanaPlugin = new SolanaPlugin(store);
|
|
|
3436
3380
|
var solana_default = solanaPlugin;
|
|
3437
3381
|
|
|
3438
3382
|
// plugins/tron/index.tsx
|
|
3439
|
-
var
|
|
3383
|
+
var import_react56 = __toESM(require("react"), 1);
|
|
3440
3384
|
|
|
3441
3385
|
// plugins/tron/features/walletConnect/WalletProvider.tsx
|
|
3442
|
-
var
|
|
3386
|
+
var import_react52 = __toESM(require("react"), 1);
|
|
3443
3387
|
var import_tronwallet_adapter_react_hooks = require("@tronweb3/tronwallet-adapter-react-hooks");
|
|
3444
3388
|
var import_tronwallet_adapter_ledger = require("@tronweb3/tronwallet-adapter-ledger");
|
|
3445
3389
|
var import_tronwallet_adapter_tronlink = require("@tronweb3/tronwallet-adapter-tronlink");
|
|
@@ -3448,7 +3392,7 @@ var import_tronwallet_adapter_tokenpocket = require("@tronweb3/tronwallet-adapte
|
|
|
3448
3392
|
var import_tronwallet_abstract_adapter = require("@tronweb3/tronwallet-abstract-adapter");
|
|
3449
3393
|
var import_react_hot_toast = require("react-hot-toast");
|
|
3450
3394
|
var WalletProvider3 = ({ children, networkOption }) => {
|
|
3451
|
-
const adapters = (0,
|
|
3395
|
+
const adapters = (0, import_react52.useMemo)(
|
|
3452
3396
|
() => [
|
|
3453
3397
|
new import_tronwallet_adapter_tronlink.TronLinkAdapter(),
|
|
3454
3398
|
new import_tronwallet_adapter_ledger.LedgerAdapter({ accountNumber: 2 }),
|
|
@@ -3478,7 +3422,7 @@ var WalletProvider3 = ({ children, networkOption }) => {
|
|
|
3478
3422
|
adapters[0].switchChain("0x2b6653dc");
|
|
3479
3423
|
}
|
|
3480
3424
|
};
|
|
3481
|
-
return /* @__PURE__ */
|
|
3425
|
+
return /* @__PURE__ */ import_react52.default.createElement(
|
|
3482
3426
|
import_tronwallet_adapter_react_hooks.WalletProvider,
|
|
3483
3427
|
{
|
|
3484
3428
|
adapters,
|
|
@@ -3492,7 +3436,7 @@ var WalletProvider3 = ({ children, networkOption }) => {
|
|
|
3492
3436
|
var WalletProvider_default3 = WalletProvider3;
|
|
3493
3437
|
|
|
3494
3438
|
// plugins/tron/core/hooks/useGetTrxBalance.tsx
|
|
3495
|
-
var
|
|
3439
|
+
var import_react53 = require("react");
|
|
3496
3440
|
var import_react_redux12 = require("react-redux");
|
|
3497
3441
|
var import_react_query10 = require("@tanstack/react-query");
|
|
3498
3442
|
|
|
@@ -3531,7 +3475,7 @@ function useGetTronBalance() {
|
|
|
3531
3475
|
const networkOption = (0, import_react_redux12.useSelector)(selectNetworkOption);
|
|
3532
3476
|
const { wallet } = (0, import_tronwallet_adapter_react_hooks2.useWallet)();
|
|
3533
3477
|
const sourceNetwork = (0, import_react_redux12.useSelector)(selectSourceChain);
|
|
3534
|
-
const tronWeb = (0,
|
|
3478
|
+
const tronWeb = (0, import_react53.useMemo)(
|
|
3535
3479
|
() => networkOption === "testnet" /* testnet */ ? tronWebTestnet : tronWebMainnet,
|
|
3536
3480
|
[networkOption]
|
|
3537
3481
|
);
|
|
@@ -3560,7 +3504,7 @@ var import_react_query12 = require("@tanstack/react-query");
|
|
|
3560
3504
|
var import_react_redux13 = require("react-redux");
|
|
3561
3505
|
var import_tronweb4 = require("tronweb");
|
|
3562
3506
|
var import_tronwallet_adapter_react_hooks3 = require("@tronweb3/tronwallet-adapter-react-hooks");
|
|
3563
|
-
var
|
|
3507
|
+
var import_react54 = require("react");
|
|
3564
3508
|
var useTronProvider = () => {
|
|
3565
3509
|
const { externalProvider } = useKimaContext();
|
|
3566
3510
|
const networkOption = (0, import_react_redux13.useSelector)(selectNetworkOption);
|
|
@@ -3571,7 +3515,7 @@ var useTronProvider = () => {
|
|
|
3571
3515
|
signMessage: internalSignMessage
|
|
3572
3516
|
} = (0, import_tronwallet_adapter_react_hooks3.useWallet)();
|
|
3573
3517
|
const isTronProvider2 = sourceChain.shortName === "TRX" && externalProvider?.type === "tron" && externalProvider.provider.tronWeb instanceof import_tronweb4.TronWeb && typeof externalProvider.signer === "string";
|
|
3574
|
-
const tronWeb = (0,
|
|
3518
|
+
const tronWeb = (0, import_react54.useMemo)(() => {
|
|
3575
3519
|
if (isTronProvider2)
|
|
3576
3520
|
return externalProvider.provider.tronWeb;
|
|
3577
3521
|
return networkOption === "mainnet" ? tronWebMainnet : tronWebTestnet;
|
|
@@ -3959,7 +3903,7 @@ function useTronAllowance() {
|
|
|
3959
3903
|
}
|
|
3960
3904
|
|
|
3961
3905
|
// plugins/tron/core/hooks/useIsWalletReady.tsx
|
|
3962
|
-
var
|
|
3906
|
+
var import_react55 = require("react");
|
|
3963
3907
|
var import_tronwallet_adapter_react_hooks4 = require("@tronweb3/tronwallet-adapter-react-hooks");
|
|
3964
3908
|
var import_react_redux16 = require("react-redux");
|
|
3965
3909
|
var import_react_redux17 = require("react-redux");
|
|
@@ -3974,7 +3918,7 @@ function useIsWalletReady3() {
|
|
|
3974
3918
|
const sourceChain = (0, import_react_redux17.useSelector)(selectSourceChain);
|
|
3975
3919
|
const { externalProvider } = useKimaContext();
|
|
3976
3920
|
const { address: internalTronAddress } = (0, import_tronwallet_adapter_react_hooks4.useWallet)();
|
|
3977
|
-
(0,
|
|
3921
|
+
(0, import_react55.useEffect)(() => {
|
|
3978
3922
|
if (sourceChain.shortName !== "TRX") return;
|
|
3979
3923
|
if (mode === "light" /* light */) {
|
|
3980
3924
|
dispatch(setSourceAddress(lightDemoAccounts.TRX));
|
|
@@ -3982,7 +3926,7 @@ function useIsWalletReady3() {
|
|
|
3982
3926
|
}
|
|
3983
3927
|
internalTronAddress && dispatch(setSourceAddress(internalTronAddress));
|
|
3984
3928
|
}, [mode, internalTronAddress, sourceChain]);
|
|
3985
|
-
return (0,
|
|
3929
|
+
return (0, import_react55.useMemo)(() => {
|
|
3986
3930
|
if (mode === "light" /* light */)
|
|
3987
3931
|
return createWalletStatus2(
|
|
3988
3932
|
true,
|
|
@@ -4036,7 +3980,7 @@ var TronPlugin = class extends PluginBase {
|
|
|
4036
3980
|
networkOption,
|
|
4037
3981
|
walletConnectProjectId
|
|
4038
3982
|
}) => {
|
|
4039
|
-
return /* @__PURE__ */
|
|
3983
|
+
return /* @__PURE__ */ import_react56.default.createElement(
|
|
4040
3984
|
WalletProvider_default3,
|
|
4041
3985
|
{
|
|
4042
3986
|
networkOption,
|
|
@@ -4050,16 +3994,16 @@ var tronPlugin = new TronPlugin(store);
|
|
|
4050
3994
|
var tron_default = tronPlugin;
|
|
4051
3995
|
|
|
4052
3996
|
// plugins/credit-card/index.tsx
|
|
4053
|
-
var
|
|
3997
|
+
var import_react58 = __toESM(require("react"), 1);
|
|
4054
3998
|
|
|
4055
3999
|
// plugins/credit-card/core/hooks/useIsProviderReady.tsx
|
|
4056
4000
|
var import_react_redux18 = require("react-redux");
|
|
4057
|
-
var
|
|
4001
|
+
var import_react57 = require("react");
|
|
4058
4002
|
var useIsProviderReady = () => {
|
|
4059
|
-
const [isReady, setIsReady] = (0,
|
|
4003
|
+
const [isReady, setIsReady] = (0, import_react57.useState)(false);
|
|
4060
4004
|
const dispatch = (0, import_react_redux18.useDispatch)();
|
|
4061
4005
|
const sourceChain = (0, import_react_redux18.useSelector)(selectSourceChain);
|
|
4062
|
-
(0,
|
|
4006
|
+
(0, import_react57.useEffect)(() => {
|
|
4063
4007
|
if (sourceChain.compatibility === "CC" /* CC */) {
|
|
4064
4008
|
logger_default.debug("CC:useIsProviderReady: dispatching changes from fiat...");
|
|
4065
4009
|
dispatch(setSourceAddress(""));
|
|
@@ -4108,7 +4052,7 @@ var CreditCardPlugin = class extends PluginBase {
|
|
|
4108
4052
|
return chain.compatibility === "CC";
|
|
4109
4053
|
};
|
|
4110
4054
|
Provider = ({ children }) => {
|
|
4111
|
-
return /* @__PURE__ */
|
|
4055
|
+
return /* @__PURE__ */ import_react58.default.createElement(import_react58.default.Fragment, null, children);
|
|
4112
4056
|
};
|
|
4113
4057
|
};
|
|
4114
4058
|
var creditCardPlugin = new CreditCardPlugin(store);
|
|
@@ -4118,18 +4062,18 @@ var credit_card_default = creditCardPlugin;
|
|
|
4118
4062
|
initializePlugins([evm_default, solana_default, tron_default, credit_card_default]);
|
|
4119
4063
|
|
|
4120
4064
|
// src/KimaProvider.tsx
|
|
4121
|
-
var
|
|
4065
|
+
var import_web310 = require("@solana/web3.js");
|
|
4122
4066
|
var import_ethers5 = require("ethers");
|
|
4123
4067
|
var queryClient = new import_react_query13.QueryClient();
|
|
4124
|
-
var KimaContext = (0,
|
|
4068
|
+
var KimaContext = (0, import_react59.createContext)(void 0);
|
|
4125
4069
|
var useKimaContext = () => {
|
|
4126
|
-
const context = (0,
|
|
4070
|
+
const context = (0, import_react59.useContext)(KimaContext);
|
|
4127
4071
|
if (!context) {
|
|
4128
4072
|
throw new Error("useKimaContext must be used within a KimaProvider");
|
|
4129
4073
|
}
|
|
4130
4074
|
return context;
|
|
4131
4075
|
};
|
|
4132
|
-
var InternalKimaProvider =
|
|
4076
|
+
var InternalKimaProvider = React48.memo(
|
|
4133
4077
|
({ kimaBackendUrl, walletConnectProjectId, children, logLevel }) => {
|
|
4134
4078
|
const { data: envOptions, isLoading } = useGetEnvOptions({
|
|
4135
4079
|
kimaBackendUrl
|
|
@@ -4138,12 +4082,12 @@ var InternalKimaProvider = React81.memo(
|
|
|
4138
4082
|
logger_default.debug("internalkimaprovider: isLoading: ", isLoading);
|
|
4139
4083
|
const plugins = (0, import_react_redux19.useSelector)(selectAllPlugins, (prev, next) => prev === next);
|
|
4140
4084
|
logger_default.debug("Registered Plugins:", plugins);
|
|
4141
|
-
const WrappedProviders = (0,
|
|
4085
|
+
const WrappedProviders = (0, import_react59.useMemo)(() => {
|
|
4142
4086
|
return plugins.reduce((acc, pluginData) => {
|
|
4143
4087
|
const plugin = getPluginProvider(pluginData.id);
|
|
4144
4088
|
if (plugin) {
|
|
4145
4089
|
const { Provider: Provider3 } = plugin;
|
|
4146
|
-
return /* @__PURE__ */
|
|
4090
|
+
return /* @__PURE__ */ React48.createElement(
|
|
4147
4091
|
Provider3,
|
|
4148
4092
|
{
|
|
4149
4093
|
key: plugin.data.id,
|
|
@@ -4157,12 +4101,12 @@ var InternalKimaProvider = React81.memo(
|
|
|
4157
4101
|
return acc;
|
|
4158
4102
|
}, children);
|
|
4159
4103
|
}, [plugins, walletConnectProjectId, envOptions, isLoading]);
|
|
4160
|
-
return /* @__PURE__ */
|
|
4104
|
+
return /* @__PURE__ */ React48.createElement(React48.Fragment, null, WrappedProviders);
|
|
4161
4105
|
}
|
|
4162
4106
|
);
|
|
4163
4107
|
var KimaProvider = ({
|
|
4164
4108
|
walletConnectProjectId,
|
|
4165
|
-
children = /* @__PURE__ */
|
|
4109
|
+
children = /* @__PURE__ */ React48.createElement(React48.Fragment, null),
|
|
4166
4110
|
externalProvider,
|
|
4167
4111
|
kimaBackendUrl = "http://localhost:3001",
|
|
4168
4112
|
logLevel,
|
|
@@ -4182,7 +4126,7 @@ var KimaProvider = ({
|
|
|
4182
4126
|
validExternalProvider = externalProvider;
|
|
4183
4127
|
if (externalProvider.type === "evm" && externalProvider.signer instanceof import_ethers5.JsonRpcSigner)
|
|
4184
4128
|
sourceAddress = externalProvider.signer.address;
|
|
4185
|
-
if (externalProvider.type === "solana" && externalProvider.signer instanceof
|
|
4129
|
+
if (externalProvider.type === "solana" && externalProvider.signer instanceof import_web310.PublicKey)
|
|
4186
4130
|
sourceAddress = externalProvider.signer.toBase58();
|
|
4187
4131
|
if (externalProvider.type === "tron" && typeof externalProvider.signer === "string")
|
|
4188
4132
|
sourceAddress = externalProvider.signer;
|
|
@@ -4197,7 +4141,7 @@ var KimaProvider = ({
|
|
|
4197
4141
|
errorHandler,
|
|
4198
4142
|
switchChainHandler
|
|
4199
4143
|
};
|
|
4200
|
-
return /* @__PURE__ */
|
|
4144
|
+
return /* @__PURE__ */ React48.createElement(import_react_query13.QueryClientProvider, { client: queryClient }, /* @__PURE__ */ React48.createElement(import_react_redux19.Provider, { store }, /* @__PURE__ */ React48.createElement(KimaContext.Provider, { value: kimaContext }, /* @__PURE__ */ React48.createElement(
|
|
4201
4145
|
InternalKimaProvider,
|
|
4202
4146
|
{
|
|
4203
4147
|
kimaBackendUrl,
|
|
@@ -4209,17 +4153,17 @@ var KimaProvider = ({
|
|
|
4209
4153
|
var KimaProvider_default = KimaProvider;
|
|
4210
4154
|
|
|
4211
4155
|
// src/components/KimaTransactionWidget.tsx
|
|
4212
|
-
var
|
|
4156
|
+
var import_react108 = __toESM(require("react"), 1);
|
|
4213
4157
|
|
|
4214
4158
|
// src/components/KimaWidgetWrapper.tsx
|
|
4215
|
-
var
|
|
4159
|
+
var import_react105 = __toESM(require("react"), 1);
|
|
4216
4160
|
var import_react_redux58 = require("react-redux");
|
|
4217
4161
|
|
|
4218
4162
|
// src/components/TransactionWidget.tsx
|
|
4219
|
-
var
|
|
4163
|
+
var import_react89 = __toESM(require("react"), 1);
|
|
4220
4164
|
|
|
4221
4165
|
// src/components/reusable/Progressbar.tsx
|
|
4222
|
-
var
|
|
4166
|
+
var import_react60 = __toESM(require("react"), 1);
|
|
4223
4167
|
var import_react_redux20 = require("react-redux");
|
|
4224
4168
|
var stepInfo = [
|
|
4225
4169
|
{
|
|
@@ -4240,12 +4184,12 @@ var stepInfo = [
|
|
|
4240
4184
|
];
|
|
4241
4185
|
var Progressbar = ({ step, errorStep, setFocus, loadingStep }) => {
|
|
4242
4186
|
const theme = (0, import_react_redux20.useSelector)(selectTheme);
|
|
4243
|
-
return /* @__PURE__ */
|
|
4187
|
+
return /* @__PURE__ */ import_react60.default.createElement("div", { className: "kima-progressbar" }, /* @__PURE__ */ import_react60.default.createElement(
|
|
4244
4188
|
"div",
|
|
4245
4189
|
{
|
|
4246
4190
|
className: `value step-${step * 100 / 4}`
|
|
4247
4191
|
}
|
|
4248
|
-
), /* @__PURE__ */
|
|
4192
|
+
), /* @__PURE__ */ import_react60.default.createElement("div", { className: "step-indicators" }, stepInfo.map((item, index) => /* @__PURE__ */ import_react60.default.createElement(
|
|
4249
4193
|
"div",
|
|
4250
4194
|
{
|
|
4251
4195
|
key: item.title,
|
|
@@ -4256,14 +4200,14 @@ var Progressbar = ({ step, errorStep, setFocus, loadingStep }) => {
|
|
|
4256
4200
|
if (index < 4) setFocus(index);
|
|
4257
4201
|
}
|
|
4258
4202
|
},
|
|
4259
|
-
/* @__PURE__ */
|
|
4203
|
+
/* @__PURE__ */ import_react60.default.createElement("div", { className: "step-info" }, step < index && /* @__PURE__ */ import_react60.default.createElement(Lock_default, null), step >= index ? index === loadingStep ? /* @__PURE__ */ import_react60.default.createElement(Loader_default, { className: "loader" }) : index === errorStep ? /* @__PURE__ */ import_react60.default.createElement(Warning_default, null) : /* @__PURE__ */ import_react60.default.createElement(Check_default, null) : null, /* @__PURE__ */ import_react60.default.createElement("span", null, item.title))
|
|
4260
4204
|
))));
|
|
4261
4205
|
};
|
|
4262
4206
|
var Progressbar_default = Progressbar;
|
|
4263
4207
|
|
|
4264
4208
|
// src/components/reusable/ExternalLink.tsx
|
|
4265
|
-
var
|
|
4266
|
-
var ExternalLink = ({ to, children, className, rest }) => /* @__PURE__ */
|
|
4209
|
+
var import_react61 = __toESM(require("react"), 1);
|
|
4210
|
+
var ExternalLink = ({ to, children, className, rest }) => /* @__PURE__ */ import_react61.default.createElement(
|
|
4267
4211
|
"a",
|
|
4268
4212
|
{
|
|
4269
4213
|
className,
|
|
@@ -4277,20 +4221,20 @@ var ExternalLink = ({ to, children, className, rest }) => /* @__PURE__ */ import
|
|
|
4277
4221
|
var ExternalLink_default = ExternalLink;
|
|
4278
4222
|
|
|
4279
4223
|
// src/components/reusable/NetworkLabel.tsx
|
|
4280
|
-
var
|
|
4224
|
+
var import_react62 = __toESM(require("react"), 1);
|
|
4281
4225
|
var import_react_redux21 = require("react-redux");
|
|
4282
4226
|
|
|
4283
4227
|
// src/components/reusable/PrimaryButton.tsx
|
|
4284
|
-
var
|
|
4228
|
+
var import_react65 = __toESM(require("react"), 1);
|
|
4285
4229
|
|
|
4286
4230
|
// src/assets/loading/180-ring.tsx
|
|
4287
|
-
var
|
|
4231
|
+
var import_react63 = __toESM(require("react"), 1);
|
|
4288
4232
|
var Loading180Ring = ({
|
|
4289
4233
|
width = 24,
|
|
4290
4234
|
height = 24,
|
|
4291
4235
|
fill = "white"
|
|
4292
4236
|
}) => {
|
|
4293
|
-
return /* @__PURE__ */
|
|
4237
|
+
return /* @__PURE__ */ import_react63.default.createElement(
|
|
4294
4238
|
"svg",
|
|
4295
4239
|
{
|
|
4296
4240
|
width,
|
|
@@ -4299,7 +4243,7 @@ var Loading180Ring = ({
|
|
|
4299
4243
|
viewBox: "0 0 24 24",
|
|
4300
4244
|
xmlns: "http://www.w3.org/2000/svg"
|
|
4301
4245
|
},
|
|
4302
|
-
/* @__PURE__ */
|
|
4246
|
+
/* @__PURE__ */ import_react63.default.createElement("path", { d: "M12,4a8,8,0,0,1,7.89,6.7A1.53,1.53,0,0,0,21.38,12h0a1.5,1.5,0,0,0,1.48-1.75,11,11,0,0,0-21.72,0A1.5,1.5,0,0,0,2.62,12h0a1.53,1.53,0,0,0,1.49-1.3A8,8,0,0,1,12,4Z" }, /* @__PURE__ */ import_react63.default.createElement(
|
|
4303
4247
|
"animateTransform",
|
|
4304
4248
|
{
|
|
4305
4249
|
attributeName: "transform",
|
|
@@ -4314,7 +4258,7 @@ var Loading180Ring = ({
|
|
|
4314
4258
|
var ring_default = Loading180Ring;
|
|
4315
4259
|
|
|
4316
4260
|
// src/assets/loading/6-dots-scale.tsx
|
|
4317
|
-
var
|
|
4261
|
+
var import_react64 = __toESM(require("react"), 1);
|
|
4318
4262
|
|
|
4319
4263
|
// src/components/reusable/PrimaryButton.tsx
|
|
4320
4264
|
var PrimaryButton = ({
|
|
@@ -4325,7 +4269,7 @@ var PrimaryButton = ({
|
|
|
4325
4269
|
disabled = false,
|
|
4326
4270
|
ref
|
|
4327
4271
|
}) => {
|
|
4328
|
-
return /* @__PURE__ */
|
|
4272
|
+
return /* @__PURE__ */ import_react65.default.createElement("div", { className: "primary-button-wrapper" }, /* @__PURE__ */ import_react65.default.createElement(
|
|
4329
4273
|
"button",
|
|
4330
4274
|
{
|
|
4331
4275
|
className: `primary-button ${className}`,
|
|
@@ -4333,14 +4277,14 @@ var PrimaryButton = ({
|
|
|
4333
4277
|
ref,
|
|
4334
4278
|
disabled
|
|
4335
4279
|
},
|
|
4336
|
-
isLoading && /* @__PURE__ */
|
|
4280
|
+
isLoading && /* @__PURE__ */ import_react65.default.createElement("div", { className: "loading-indicator" }, /* @__PURE__ */ import_react65.default.createElement(ring_default, { width: 24, height: 24, fill: "white" })),
|
|
4337
4281
|
children
|
|
4338
4282
|
));
|
|
4339
4283
|
};
|
|
4340
4284
|
var PrimaryButton_default = PrimaryButton;
|
|
4341
4285
|
|
|
4342
4286
|
// src/components/reusable/SecondaryButton.tsx
|
|
4343
|
-
var
|
|
4287
|
+
var import_react66 = __toESM(require("react"), 1);
|
|
4344
4288
|
var SecondaryButton = ({
|
|
4345
4289
|
className,
|
|
4346
4290
|
clickHandler,
|
|
@@ -4349,7 +4293,7 @@ var SecondaryButton = ({
|
|
|
4349
4293
|
style,
|
|
4350
4294
|
disabled = false,
|
|
4351
4295
|
isLoading
|
|
4352
|
-
}) => /* @__PURE__ */
|
|
4296
|
+
}) => /* @__PURE__ */ import_react66.default.createElement(
|
|
4353
4297
|
"button",
|
|
4354
4298
|
{
|
|
4355
4299
|
className: `secondary-button ${className} ${theme}`,
|
|
@@ -4357,26 +4301,26 @@ var SecondaryButton = ({
|
|
|
4357
4301
|
...style,
|
|
4358
4302
|
disabled
|
|
4359
4303
|
},
|
|
4360
|
-
isLoading && /* @__PURE__ */
|
|
4304
|
+
isLoading && /* @__PURE__ */ import_react66.default.createElement("div", { className: "loading-indicator" }, /* @__PURE__ */ import_react66.default.createElement(ring_default, { width: 24, height: 24, fill: "black" })),
|
|
4361
4305
|
children
|
|
4362
4306
|
);
|
|
4363
4307
|
var SecondaryButton_default = SecondaryButton;
|
|
4364
4308
|
|
|
4365
4309
|
// src/components/reusable/Dropdown.tsx
|
|
4366
|
-
var
|
|
4310
|
+
var import_react67 = __toESM(require("react"), 1);
|
|
4367
4311
|
var import_react_redux22 = require("react-redux");
|
|
4368
4312
|
var import_react_redux23 = require("react-redux");
|
|
4369
4313
|
|
|
4370
4314
|
// src/components/reusable/WalletButton.tsx
|
|
4371
|
-
var
|
|
4315
|
+
var import_react73 = __toESM(require("react"), 1);
|
|
4372
4316
|
var import_react_redux25 = require("react-redux");
|
|
4373
4317
|
|
|
4374
4318
|
// src/hooks/useGetCurrentPlugin.tsx
|
|
4375
|
-
var
|
|
4319
|
+
var import_react69 = require("react");
|
|
4376
4320
|
var import_react_redux24 = require("react-redux");
|
|
4377
4321
|
|
|
4378
4322
|
// plugins/default/index.tsx
|
|
4379
|
-
var
|
|
4323
|
+
var import_react68 = __toESM(require("react"), 1);
|
|
4380
4324
|
var DefaultPlugin = class extends PluginBase {
|
|
4381
4325
|
constructor(store2) {
|
|
4382
4326
|
super({
|
|
@@ -4411,7 +4355,7 @@ var DefaultPlugin = class extends PluginBase {
|
|
|
4411
4355
|
networkOption,
|
|
4412
4356
|
walletConnectProjectId
|
|
4413
4357
|
}) => {
|
|
4414
|
-
return /* @__PURE__ */
|
|
4358
|
+
return /* @__PURE__ */ import_react68.default.createElement("div", null, children);
|
|
4415
4359
|
};
|
|
4416
4360
|
};
|
|
4417
4361
|
var defaultPlugin = new DefaultPlugin(store);
|
|
@@ -4419,10 +4363,10 @@ var default_default = defaultPlugin;
|
|
|
4419
4363
|
|
|
4420
4364
|
// src/hooks/useGetCurrentPlugin.tsx
|
|
4421
4365
|
var useGetCurrentPlugin = () => {
|
|
4422
|
-
const [currentPlugin, setCurrentPlugin] = (0,
|
|
4366
|
+
const [currentPlugin, setCurrentPlugin] = (0, import_react69.useState)(default_default);
|
|
4423
4367
|
const isIndexed = (0, import_react_redux24.useSelector)(selectPluginIsIndexed);
|
|
4424
4368
|
const sourceChain = (0, import_react_redux24.useSelector)(selectSourceChain);
|
|
4425
|
-
(0,
|
|
4369
|
+
(0, import_react69.useEffect)(() => {
|
|
4426
4370
|
if (!isIndexed) return;
|
|
4427
4371
|
const plugin = getPlugin(sourceChain.shortName);
|
|
4428
4372
|
if (plugin) setCurrentPlugin(plugin);
|
|
@@ -4481,13 +4425,13 @@ function useBalance4() {
|
|
|
4481
4425
|
}
|
|
4482
4426
|
|
|
4483
4427
|
// src/hooks/useWidth.tsx
|
|
4484
|
-
var
|
|
4428
|
+
var import_react70 = require("react");
|
|
4485
4429
|
var useWidth = () => {
|
|
4486
|
-
const [width, setWidth] = (0,
|
|
4430
|
+
const [width, setWidth] = (0, import_react70.useState)(0);
|
|
4487
4431
|
const updateWidth = (width2) => {
|
|
4488
4432
|
setWidth(width2);
|
|
4489
4433
|
};
|
|
4490
|
-
(0,
|
|
4434
|
+
(0, import_react70.useEffect)(() => {
|
|
4491
4435
|
const handleResize = () => {
|
|
4492
4436
|
setWidth(window.innerWidth);
|
|
4493
4437
|
};
|
|
@@ -4501,19 +4445,19 @@ var useWidth_default = useWidth;
|
|
|
4501
4445
|
// src/components/reusable/WalletButton.tsx
|
|
4502
4446
|
var import_wallet_adapter_react6 = require("@solana/wallet-adapter-react");
|
|
4503
4447
|
var import_tronwallet_adapter_react_hooks6 = require("@tronweb3/tronwallet-adapter-react-hooks");
|
|
4504
|
-
var
|
|
4448
|
+
var import_react74 = require("@reown/appkit/react");
|
|
4505
4449
|
|
|
4506
4450
|
// src/components/reusable/CopyButton.tsx
|
|
4507
|
-
var
|
|
4451
|
+
var import_react71 = __toESM(require("react"), 1);
|
|
4508
4452
|
var CopyButton = ({ text }) => {
|
|
4509
|
-
const [copyClicked, setCopyClicked] = (0,
|
|
4510
|
-
(0,
|
|
4453
|
+
const [copyClicked, setCopyClicked] = (0, import_react71.useState)(false);
|
|
4454
|
+
(0, import_react71.useEffect)(() => {
|
|
4511
4455
|
if (!copyClicked) return;
|
|
4512
4456
|
setTimeout(() => {
|
|
4513
4457
|
setCopyClicked(false);
|
|
4514
4458
|
}, 2e3);
|
|
4515
4459
|
}, [copyClicked]);
|
|
4516
|
-
return /* @__PURE__ */
|
|
4460
|
+
return /* @__PURE__ */ import_react71.default.createElement(
|
|
4517
4461
|
"span",
|
|
4518
4462
|
{
|
|
4519
4463
|
className: "copy-btn",
|
|
@@ -4522,7 +4466,7 @@ var CopyButton = ({ text }) => {
|
|
|
4522
4466
|
navigator.clipboard.writeText(text);
|
|
4523
4467
|
}
|
|
4524
4468
|
},
|
|
4525
|
-
copyClicked ? /* @__PURE__ */
|
|
4469
|
+
copyClicked ? /* @__PURE__ */ import_react71.default.createElement(Check_default, null) : /* @__PURE__ */ import_react71.default.createElement(Copy_default, null)
|
|
4526
4470
|
);
|
|
4527
4471
|
};
|
|
4528
4472
|
var CopyButton_default = CopyButton;
|
|
@@ -4608,9 +4552,9 @@ var isAddressCompatible = (address, shortName) => {
|
|
|
4608
4552
|
};
|
|
4609
4553
|
|
|
4610
4554
|
// src/hooks/useHideActivityTab.tsx
|
|
4611
|
-
var
|
|
4555
|
+
var import_react72 = require("react");
|
|
4612
4556
|
function useHideWuiListItem(isModalOpen) {
|
|
4613
|
-
(0,
|
|
4557
|
+
(0, import_react72.useEffect)(() => {
|
|
4614
4558
|
const modalSelector = "w3m-modal";
|
|
4615
4559
|
let observer;
|
|
4616
4560
|
const hideFirstWuiListItem = (parent) => {
|
|
@@ -4688,14 +4632,14 @@ var WalletButton = ({
|
|
|
4688
4632
|
/*, connectBitcoinWallet*/
|
|
4689
4633
|
} = useIsWalletReady4();
|
|
4690
4634
|
const { balance, decimals } = useBalance4();
|
|
4691
|
-
const { open } = (0,
|
|
4692
|
-
const { open: isModalOpen } = (0,
|
|
4635
|
+
const { open } = (0, import_react74.useAppKit)();
|
|
4636
|
+
const { open: isModalOpen } = (0, import_react74.useAppKitState)();
|
|
4693
4637
|
const { width, updateWidth } = useWidth_default();
|
|
4694
4638
|
useHideActivityTab_default(isModalOpen);
|
|
4695
4639
|
const { kimaBackendUrl } = useKimaContext();
|
|
4696
4640
|
const { data: envOptions } = useGetEnvOptions({ kimaBackendUrl });
|
|
4697
4641
|
const networkOption = envOptions?.env || "testnet" /* testnet */;
|
|
4698
|
-
(0,
|
|
4642
|
+
(0, import_react73.useEffect)(() => {
|
|
4699
4643
|
logger_default.debug("WalletBalance:", {
|
|
4700
4644
|
balance,
|
|
4701
4645
|
connectedAddress,
|
|
@@ -4704,7 +4648,7 @@ var WalletButton = ({
|
|
|
4704
4648
|
externalProvider
|
|
4705
4649
|
});
|
|
4706
4650
|
}, [balance, connectedAddress, isReady, externalProvider, networkOption]);
|
|
4707
|
-
(0,
|
|
4651
|
+
(0, import_react73.useEffect)(() => {
|
|
4708
4652
|
if (width === 0) {
|
|
4709
4653
|
updateWidth(window.innerWidth);
|
|
4710
4654
|
}
|
|
@@ -4732,29 +4676,29 @@ var WalletButton = ({
|
|
|
4732
4676
|
logger_default.error("Failed to open AppKitModal", error);
|
|
4733
4677
|
}
|
|
4734
4678
|
};
|
|
4735
|
-
const errorMessage = (0,
|
|
4679
|
+
const errorMessage = (0, import_react73.useMemo)(() => {
|
|
4736
4680
|
if (!isReady) return statusMessage;
|
|
4737
4681
|
if (compliantOption && sourceCompliant !== null && !sourceCompliant?.isCompliant)
|
|
4738
4682
|
return `Source address has ${sourceCompliant?.results?.[0].result?.risk_score} risk`;
|
|
4739
4683
|
return "";
|
|
4740
4684
|
}, [isReady, statusMessage, sourceCompliant, compliantOption]);
|
|
4741
|
-
const isConnected = (0,
|
|
4685
|
+
const isConnected = (0, import_react73.useMemo)(() => {
|
|
4742
4686
|
return isReady && !initialSelection;
|
|
4743
4687
|
}, [isReady, initialSelection]);
|
|
4744
|
-
(0,
|
|
4688
|
+
(0, import_react73.useEffect)(() => {
|
|
4745
4689
|
if (!isReady) {
|
|
4746
4690
|
dispatch(setSourceAddress(""));
|
|
4747
4691
|
return;
|
|
4748
4692
|
}
|
|
4749
4693
|
dispatch(setSourceAddress(connectedAddress));
|
|
4750
4694
|
}, [isReady]);
|
|
4751
|
-
return /* @__PURE__ */
|
|
4695
|
+
return /* @__PURE__ */ import_react73.default.createElement(
|
|
4752
4696
|
"div",
|
|
4753
4697
|
{
|
|
4754
4698
|
className: `wallet-button ${isConnected ? "connected" : "disconnected"} ${theme.colorMode} ${errorBelow ? "error-below" : ""}`,
|
|
4755
4699
|
"data-testid": "connect-wallet-btn"
|
|
4756
4700
|
},
|
|
4757
|
-
/* @__PURE__ */
|
|
4701
|
+
/* @__PURE__ */ import_react73.default.createElement("div", { className: "info-wrapper" }, /* @__PURE__ */ import_react73.default.createElement(
|
|
4758
4702
|
"button",
|
|
4759
4703
|
{
|
|
4760
4704
|
className: `${isConnected ? "connected" : "disconnected"} ${width < 640 && "shortened"} ${theme.colorMode}`,
|
|
@@ -4764,21 +4708,21 @@ var WalletButton = ({
|
|
|
4764
4708
|
isConnected && !placeholder ? width >= 640 ? `${connectedAddress || ""}` : getShortenedAddress(connectedAddress || "") : "",
|
|
4765
4709
|
!isConnected && mode === "light" /* light */ && "Select Network to Load Account",
|
|
4766
4710
|
!isConnected && mode !== "light" /* light */ && initialSelection && "Select Network to Connect",
|
|
4767
|
-
!isConnected && mode !== "light" /* light */ && !initialSelection && /* @__PURE__ */
|
|
4711
|
+
!isConnected && mode !== "light" /* light */ && !initialSelection && /* @__PURE__ */ import_react73.default.createElement(Wallet_default, null),
|
|
4768
4712
|
!isConnected && mode !== "light" /* light */ && !initialSelection && "Connect Wallet"
|
|
4769
|
-
), isConnected && !placeholder && /* @__PURE__ */
|
|
4770
|
-
isConnected && !placeholder && balance !== void 0 && decimals !== void 0 ? /* @__PURE__ */
|
|
4713
|
+
), isConnected && !placeholder && /* @__PURE__ */ import_react73.default.createElement(CopyButton_default, { text: connectedAddress })),
|
|
4714
|
+
isConnected && !placeholder && balance !== void 0 && decimals !== void 0 ? /* @__PURE__ */ import_react73.default.createElement("p", { className: "balance-info" }, formatUSD(bigIntToNumber({ value: balance, decimals })), " ", selectedCoin, " available") : null
|
|
4771
4715
|
);
|
|
4772
4716
|
};
|
|
4773
4717
|
var WalletButton_default = WalletButton;
|
|
4774
4718
|
|
|
4775
4719
|
// src/components/reusable/CoinDropdown.tsx
|
|
4776
|
-
var
|
|
4720
|
+
var import_react77 = __toESM(require("react"), 1);
|
|
4777
4721
|
var import_react_redux28 = require("react-redux");
|
|
4778
4722
|
var import_react_redux29 = require("react-redux");
|
|
4779
4723
|
|
|
4780
4724
|
// src/hooks/useCurrencyOptions.tsx
|
|
4781
|
-
var
|
|
4725
|
+
var import_react75 = require("react");
|
|
4782
4726
|
var import_react_redux26 = require("react-redux");
|
|
4783
4727
|
var import_react_redux27 = require("react-redux");
|
|
4784
4728
|
function useCurrencyOptions(isSourceChain) {
|
|
@@ -4789,14 +4733,14 @@ function useCurrencyOptions(isSourceChain) {
|
|
|
4789
4733
|
const chain = isSourceChain ? sourceChain : targetChain;
|
|
4790
4734
|
const transactionOption = (0, import_react_redux26.useSelector)(selectTransactionOption);
|
|
4791
4735
|
const networks = (0, import_react_redux26.useSelector)(selectNetworks);
|
|
4792
|
-
const output = (0,
|
|
4736
|
+
const output = (0, import_react75.useMemo)(() => {
|
|
4793
4737
|
logger_default.debug("useCurrencyOptions: networks: ", networks);
|
|
4794
4738
|
const networkTokenList = networks.find((network) => network.id === chain.id) || networks[0];
|
|
4795
4739
|
logger_default.debug("useCurrencyOptions: networkTokenList: ", networkTokenList, chain);
|
|
4796
4740
|
return !!networks ? { tokenList: networkTokenList?.supportedTokens } : { tokenList: [] };
|
|
4797
4741
|
}, [networks, chain]);
|
|
4798
4742
|
const { tokenList } = output;
|
|
4799
|
-
(0,
|
|
4743
|
+
(0, import_react75.useEffect)(() => {
|
|
4800
4744
|
if (!tokenList.length) return;
|
|
4801
4745
|
if (mode === "payment" /* payment */ && !isSourceChain) return;
|
|
4802
4746
|
const [firstToken] = tokenList;
|
|
@@ -4810,7 +4754,7 @@ function useCurrencyOptions(isSourceChain) {
|
|
|
4810
4754
|
}
|
|
4811
4755
|
|
|
4812
4756
|
// src/components/reusable/TokenIcon.tsx
|
|
4813
|
-
var
|
|
4757
|
+
var import_react76 = __toESM(require("react"), 1);
|
|
4814
4758
|
var COIN_LIST = {
|
|
4815
4759
|
KEUR: KEUR_default,
|
|
4816
4760
|
KIMAUSD: USDK_default,
|
|
@@ -4832,22 +4776,22 @@ function TokenIcon({
|
|
|
4832
4776
|
logger_default.warn(`Token icon not found for symbol: ${symbol}`);
|
|
4833
4777
|
return null;
|
|
4834
4778
|
}
|
|
4835
|
-
return /* @__PURE__ */
|
|
4779
|
+
return /* @__PURE__ */ import_react76.default.createElement("div", { className: "icon-wrapper" }, /* @__PURE__ */ import_react76.default.createElement(Icon, { width, height }));
|
|
4836
4780
|
}
|
|
4837
4781
|
|
|
4838
4782
|
// src/components/reusable/CoinDropdown.tsx
|
|
4839
4783
|
var CoinDropdown = ({
|
|
4840
4784
|
isSourceChain = true
|
|
4841
4785
|
}) => {
|
|
4842
|
-
const ref = (0,
|
|
4786
|
+
const ref = (0, import_react77.useRef)();
|
|
4843
4787
|
const dispatch = (0, import_react_redux29.useDispatch)();
|
|
4844
|
-
const [collapsed, setCollapsed] = (0,
|
|
4788
|
+
const [collapsed, setCollapsed] = (0, import_react77.useState)(true);
|
|
4845
4789
|
const sourceCurrency = (0, import_react_redux28.useSelector)(selectSourceCurrency);
|
|
4846
4790
|
const targetCurrency = (0, import_react_redux28.useSelector)(selectTargetCurrency);
|
|
4847
4791
|
const { tokenList } = useCurrencyOptions(isSourceChain);
|
|
4848
4792
|
const theme = (0, import_react_redux28.useSelector)(selectTheme);
|
|
4849
4793
|
const tokenSymbol = isSourceChain ? sourceCurrency : targetCurrency;
|
|
4850
|
-
(0,
|
|
4794
|
+
(0, import_react77.useEffect)(() => {
|
|
4851
4795
|
const bodyMouseDowntHandler = (e) => {
|
|
4852
4796
|
if (ref?.current && !ref.current.contains(e.target)) {
|
|
4853
4797
|
setCollapsed(true);
|
|
@@ -4865,41 +4809,41 @@ var CoinDropdown = ({
|
|
|
4865
4809
|
dispatch(setTargetCurrency(symbol));
|
|
4866
4810
|
}
|
|
4867
4811
|
};
|
|
4868
|
-
return /* @__PURE__ */
|
|
4812
|
+
return /* @__PURE__ */ import_react77.default.createElement(
|
|
4869
4813
|
"div",
|
|
4870
4814
|
{
|
|
4871
4815
|
className: `coin-dropdown ${theme.colorMode} ${collapsed ? "collapsed" : "toggled"}`,
|
|
4872
4816
|
onClick: () => setCollapsed((prev) => !prev),
|
|
4873
4817
|
ref
|
|
4874
4818
|
},
|
|
4875
|
-
/* @__PURE__ */
|
|
4876
|
-
/* @__PURE__ */
|
|
4819
|
+
/* @__PURE__ */ import_react77.default.createElement("div", { className: "coin-wrapper" }, /* @__PURE__ */ import_react77.default.createElement(TokenIcon, { symbol: tokenSymbol, width: 24, height: 24 }), /* @__PURE__ */ import_react77.default.createElement("span", { className: "coin" }, tokenSymbol)),
|
|
4820
|
+
/* @__PURE__ */ import_react77.default.createElement(
|
|
4877
4821
|
"div",
|
|
4878
4822
|
{
|
|
4879
4823
|
className: `coin-menu ${theme.colorMode} ${collapsed ? "collapsed" : "toggled"}`
|
|
4880
4824
|
},
|
|
4881
|
-
tokenList.map((token) => /* @__PURE__ */
|
|
4825
|
+
tokenList.map((token) => /* @__PURE__ */ import_react77.default.createElement(
|
|
4882
4826
|
"div",
|
|
4883
4827
|
{
|
|
4884
4828
|
className: `coin-item ${theme.colorMode}`,
|
|
4885
4829
|
key: token.symbol,
|
|
4886
4830
|
onClick: () => handleDropdownItemClick(token.symbol)
|
|
4887
4831
|
},
|
|
4888
|
-
/* @__PURE__ */
|
|
4889
|
-
/* @__PURE__ */
|
|
4832
|
+
/* @__PURE__ */ import_react77.default.createElement(TokenIcon, { symbol: token.symbol, width: 24, height: 24 }),
|
|
4833
|
+
/* @__PURE__ */ import_react77.default.createElement("p", null, token.symbol)
|
|
4890
4834
|
))
|
|
4891
4835
|
),
|
|
4892
|
-
/* @__PURE__ */
|
|
4836
|
+
/* @__PURE__ */ import_react77.default.createElement("div", { className: `dropdown-icon ${collapsed ? "toggled" : "collapsed"}` }, /* @__PURE__ */ import_react77.default.createElement(Arrow_default, { fill: "none" }))
|
|
4893
4837
|
);
|
|
4894
4838
|
};
|
|
4895
4839
|
var CoinDropdown_default = CoinDropdown;
|
|
4896
4840
|
|
|
4897
4841
|
// src/components/reusable/ConfirmDetails.tsx
|
|
4898
|
-
var
|
|
4842
|
+
var import_react80 = __toESM(require("react"), 1);
|
|
4899
4843
|
var import_react_redux31 = require("react-redux");
|
|
4900
4844
|
|
|
4901
4845
|
// src/components/reusable/ChainIcon.tsx
|
|
4902
|
-
var
|
|
4846
|
+
var import_react78 = __toESM(require("react"), 1);
|
|
4903
4847
|
var chainIcons = {
|
|
4904
4848
|
ETH: Ethereum_default,
|
|
4905
4849
|
POL: Polygon_default,
|
|
@@ -4913,19 +4857,20 @@ var chainIcons = {
|
|
|
4913
4857
|
SOL: Solana_default,
|
|
4914
4858
|
FIAT: Bank_default,
|
|
4915
4859
|
BERA: Bera_default,
|
|
4860
|
+
CFX: CFX_default,
|
|
4916
4861
|
CC: CreditCard_default
|
|
4917
4862
|
};
|
|
4918
4863
|
function ChainIcon({ symbol }) {
|
|
4919
4864
|
const Icon = symbol === "FIAT" ? chainIcons["CC"] : chainIcons[symbol];
|
|
4920
4865
|
if (!Icon) {
|
|
4921
4866
|
logger_default.warn(`Chain icon not found for symbol: ${symbol}`);
|
|
4922
|
-
return /* @__PURE__ */
|
|
4867
|
+
return /* @__PURE__ */ import_react78.default.createElement("div", null);
|
|
4923
4868
|
}
|
|
4924
|
-
return /* @__PURE__ */
|
|
4869
|
+
return /* @__PURE__ */ import_react78.default.createElement("div", { className: "icon" }, /* @__PURE__ */ import_react78.default.createElement(Icon, null));
|
|
4925
4870
|
}
|
|
4926
4871
|
|
|
4927
4872
|
// src/components/reusable/FeeDeductionRadioButtons.tsx
|
|
4928
|
-
var
|
|
4873
|
+
var import_react79 = __toESM(require("react"), 1);
|
|
4929
4874
|
var import_react_redux30 = require("react-redux");
|
|
4930
4875
|
var FeeDeductionRadioButtons = ({ disabled }) => {
|
|
4931
4876
|
const dispatch = (0, import_react_redux30.useDispatch)();
|
|
@@ -4942,7 +4887,7 @@ var FeeDeductionRadioButtons = ({ disabled }) => {
|
|
|
4942
4887
|
const handleChange = (value) => {
|
|
4943
4888
|
dispatch(setFeeDeduct(value));
|
|
4944
4889
|
};
|
|
4945
|
-
return /* @__PURE__ */
|
|
4890
|
+
return /* @__PURE__ */ import_react79.default.createElement("div", { className: `fee-deduction-radio-container ${theme.colorMode}` }, /* @__PURE__ */ import_react79.default.createElement("div", { className: "fee-options" }, Number(amount) - totalFee > 0 && /* @__PURE__ */ import_react79.default.createElement("label", { className: `fee-option ${disabled ? "disabled" : ""}` }, /* @__PURE__ */ import_react79.default.createElement(
|
|
4946
4891
|
"input",
|
|
4947
4892
|
{
|
|
4948
4893
|
type: "radio",
|
|
@@ -4951,11 +4896,11 @@ var FeeDeductionRadioButtons = ({ disabled }) => {
|
|
|
4951
4896
|
disabled,
|
|
4952
4897
|
onChange: () => handleChange(true)
|
|
4953
4898
|
}
|
|
4954
|
-
), /* @__PURE__ */
|
|
4899
|
+
), /* @__PURE__ */ import_react79.default.createElement("span", { className: `radio-label ${theme.colorMode}` }, `Pay $${formatterFloat.format(
|
|
4955
4900
|
Number(amount)
|
|
4956
4901
|
)} ${sourceCurrency} in ${sourceNetwork.name} to receive $${formatterFloat.format(
|
|
4957
4902
|
Number(amount) - totalFee
|
|
4958
|
-
)} ${targetCurrency} in ${targetNetwork.name}`)), /* @__PURE__ */
|
|
4903
|
+
)} ${targetCurrency} in ${targetNetwork.name}`)), /* @__PURE__ */ import_react79.default.createElement("label", { className: `fee-option ${disabled ? "disabled" : ""}` }, /* @__PURE__ */ import_react79.default.createElement(
|
|
4959
4904
|
"input",
|
|
4960
4905
|
{
|
|
4961
4906
|
type: "radio",
|
|
@@ -4964,7 +4909,7 @@ var FeeDeductionRadioButtons = ({ disabled }) => {
|
|
|
4964
4909
|
disabled,
|
|
4965
4910
|
onChange: () => handleChange(false)
|
|
4966
4911
|
}
|
|
4967
|
-
), /* @__PURE__ */
|
|
4912
|
+
), /* @__PURE__ */ import_react79.default.createElement("span", { className: `radio-label ${theme.colorMode}` }, `Pay $${formatterFloat.format(
|
|
4968
4913
|
Number(amount) + totalFee
|
|
4969
4914
|
)} ${sourceCurrency} in ${sourceNetwork.name} to receive $${formatterFloat.format(
|
|
4970
4915
|
Number(amount)
|
|
@@ -4990,14 +4935,14 @@ var ConfirmDetails = ({
|
|
|
4990
4935
|
const bankDetails = (0, import_react_redux31.useSelector)(selectBankDetails);
|
|
4991
4936
|
const signature = (0, import_react_redux31.useSelector)(selectSignature);
|
|
4992
4937
|
const networkOptions3 = (0, import_react_redux31.useSelector)(selectNetworks);
|
|
4993
|
-
const [feeCollapsed, setFeeCollapsed] = (0,
|
|
4938
|
+
const [feeCollapsed, setFeeCollapsed] = (0, import_react80.useState)(true);
|
|
4994
4939
|
const transactionOption = (0, import_react_redux31.useSelector)(selectTransactionOption);
|
|
4995
4940
|
const { connectedAddress } = useIsWalletReady4();
|
|
4996
|
-
const originNetworkOption = (0,
|
|
4941
|
+
const originNetworkOption = (0, import_react80.useMemo)(
|
|
4997
4942
|
() => networkOptions3.filter((network) => network.id === originNetwork.id)[0],
|
|
4998
4943
|
[networkOptions3, originNetwork]
|
|
4999
4944
|
);
|
|
5000
|
-
const targetNetworkOption = (0,
|
|
4945
|
+
const targetNetworkOption = (0, import_react80.useMemo)(
|
|
5001
4946
|
() => networkOptions3.filter(
|
|
5002
4947
|
(network) => network.shortName === (mode === "payment" /* payment */ ? transactionOption?.targetChain : targetNetwork.shortName)
|
|
5003
4948
|
)[0],
|
|
@@ -5006,16 +4951,16 @@ var ConfirmDetails = ({
|
|
|
5006
4951
|
const sourceCurrency = (0, import_react_redux31.useSelector)(selectSourceCurrency);
|
|
5007
4952
|
const targetCurrency = (0, import_react_redux31.useSelector)(selectTargetCurrency);
|
|
5008
4953
|
const { width, updateWidth } = useWidth_default();
|
|
5009
|
-
(0,
|
|
4954
|
+
(0, import_react80.useEffect)(() => {
|
|
5010
4955
|
width === 0 && updateWidth(window.innerWidth);
|
|
5011
4956
|
}, []);
|
|
5012
|
-
return /* @__PURE__ */
|
|
4957
|
+
return /* @__PURE__ */ import_react80.default.createElement("div", { className: `confirm-details ${theme.colorMode}` }, /* @__PURE__ */ import_react80.default.createElement("p", null, "Step ", isApproved ? "2" : "1", "\xA0of 2\xA0\xA0\xA0", isApproved ? "Submit transaction" : originNetwork.shortName === "FIAT" /* FIAT */ ? "Bank Details" : "Approval"), originNetwork.shortName === "FIAT" /* FIAT */ ? /* @__PURE__ */ import_react80.default.createElement("div", null, /* @__PURE__ */ import_react80.default.createElement("div", { className: "detail-item" }, /* @__PURE__ */ import_react80.default.createElement("span", { className: "label" }, "IBAN:"), /* @__PURE__ */ import_react80.default.createElement("span", { className: `kima-card-network-label ${theme.colorMode}` }, /* @__PURE__ */ import_react80.default.createElement(ChainIcon, { symbol: originNetworkOption?.shortName }), "FIAT"), /* @__PURE__ */ import_react80.default.createElement("p", null, "ES6621000418401234567891")), /* @__PURE__ */ import_react80.default.createElement("div", { className: "detail-item" }, /* @__PURE__ */ import_react80.default.createElement("span", { className: "label" }, "Recipient:"), /* @__PURE__ */ import_react80.default.createElement("p", null, "Kima Sandbox")), /* @__PURE__ */ import_react80.default.createElement("div", { className: "detail-item" }, /* @__PURE__ */ import_react80.default.createElement("span", { className: "label" }, "BIC:"), /* @__PURE__ */ import_react80.default.createElement("p", null, "CAIXESBBXXX")), /* @__PURE__ */ import_react80.default.createElement("div", { className: "detail-item" }, /* @__PURE__ */ import_react80.default.createElement("span", { className: "label" }, "Description:"), /* @__PURE__ */ import_react80.default.createElement("p", { className: "signature" }, signature))) : /* @__PURE__ */ import_react80.default.createElement("div", { className: "detail-item" }, /* @__PURE__ */ import_react80.default.createElement("span", { className: "label" }, "Source ", originNetwork.shortName !== "CC" && "wallet", ":"), /* @__PURE__ */ import_react80.default.createElement("div", { className: "network-details" }, /* @__PURE__ */ import_react80.default.createElement("div", { className: "kima-card-network-container" }, /* @__PURE__ */ import_react80.default.createElement("span", { className: `kima-card-network-label ${theme.colorMode}` }, /* @__PURE__ */ import_react80.default.createElement(ChainIcon, { symbol: originNetworkOption?.shortName }), originNetworkOption.name)), originNetwork.shortName !== "CC" && /* @__PURE__ */ import_react80.default.createElement("p", { className: theme.colorMode }, dAppOption === "LPDrain" /* LPDrain */ ? targetAddress : connectedAddress))), /* @__PURE__ */ import_react80.default.createElement("div", { className: "detail-item amount" }, /* @__PURE__ */ import_react80.default.createElement("span", { className: "amount-container" }, /* @__PURE__ */ import_react80.default.createElement("div", { className: "amount-details" }, /* @__PURE__ */ import_react80.default.createElement("span", null, "Amount to Transfer "), /* @__PURE__ */ import_react80.default.createElement("div", { className: "coin-details" }, /* @__PURE__ */ import_react80.default.createElement("p", null, formatBigInt(txValues.allowanceAmount), " ", sourceCurrency))), /* @__PURE__ */ import_react80.default.createElement("div", { className: "amount-details" }, /* @__PURE__ */ import_react80.default.createElement("span", null, "Total Fees"), /* @__PURE__ */ import_react80.default.createElement(
|
|
5013
4958
|
"div",
|
|
5014
4959
|
{
|
|
5015
4960
|
className: "fee-collapse",
|
|
5016
4961
|
onClick: () => setFeeCollapsed(!feeCollapsed)
|
|
5017
4962
|
},
|
|
5018
|
-
/* @__PURE__ */
|
|
4963
|
+
/* @__PURE__ */ import_react80.default.createElement(
|
|
5019
4964
|
MiniArrow_default,
|
|
5020
4965
|
{
|
|
5021
4966
|
width: 15,
|
|
@@ -5026,16 +4971,16 @@ var ConfirmDetails = ({
|
|
|
5026
4971
|
}
|
|
5027
4972
|
}
|
|
5028
4973
|
),
|
|
5029
|
-
/* @__PURE__ */
|
|
5030
|
-
)), /* @__PURE__ */
|
|
4974
|
+
/* @__PURE__ */ import_react80.default.createElement("span", { className: "service-fee" }, formatBigInt(totalFee), " ", sourceCurrency)
|
|
4975
|
+
)), /* @__PURE__ */ import_react80.default.createElement("div", { className: `fee-breakdown ${feeCollapsed ? "collapsed" : ""}` }, /* @__PURE__ */ import_react80.default.createElement("div", { className: "amount-details" }, /* @__PURE__ */ import_react80.default.createElement("span", null, originNetwork.shortName === "CC" ? "Credit Card Processing Fee" : `Source Network Fee (${originNetwork.shortName})`), /* @__PURE__ */ import_react80.default.createElement("span", { className: "service-fee" }, formatBigInt(sourceFee), " ", sourceCurrency)), /* @__PURE__ */ import_react80.default.createElement("div", { className: "amount-details" }, /* @__PURE__ */ import_react80.default.createElement("span", null, "Target Network Fee (", targetNetwork.shortName, ")"), /* @__PURE__ */ import_react80.default.createElement("span", { className: "service-fee" }, formatBigInt(targetFee), " ", targetCurrency)), /* @__PURE__ */ import_react80.default.createElement("div", { className: "amount-details" }, /* @__PURE__ */ import_react80.default.createElement("span", null, "KIMA Service Fee"), /* @__PURE__ */ import_react80.default.createElement("span", { className: "service-fee" }, formatBigInt(kimaFee), " ", sourceCurrency))), /* @__PURE__ */ import_react80.default.createElement("div", { className: "amount-details" }, /* @__PURE__ */ import_react80.default.createElement("span", null, "Target Transfer Amount"), /* @__PURE__ */ import_react80.default.createElement("span", { className: "service-fee" }, formatBigInt(txValues.submitAmount), " ", targetCurrency)))), targetNetwork.shortName === "FIAT" /* FIAT */ ? /* @__PURE__ */ import_react80.default.createElement("div", null, /* @__PURE__ */ import_react80.default.createElement("div", { className: "detail-item" }, /* @__PURE__ */ import_react80.default.createElement("span", { className: "label" }, "IBAN:"), /* @__PURE__ */ import_react80.default.createElement("p", null, bankDetails.iban), /* @__PURE__ */ import_react80.default.createElement("span", { className: `kima-card-network-label ${theme.colorMode}` }, /* @__PURE__ */ import_react80.default.createElement(ChainIcon, { symbol: targetNetworkOption?.shortName }), "FIAT")), /* @__PURE__ */ import_react80.default.createElement("div", { className: "detail-item" }, /* @__PURE__ */ import_react80.default.createElement("span", { className: "label" }, "Recipient:"), /* @__PURE__ */ import_react80.default.createElement("p", null, bankDetails.recipient))) : /* @__PURE__ */ import_react80.default.createElement("div", { className: "detail-item" }, /* @__PURE__ */ import_react80.default.createElement("span", { className: "label" }, "Target wallet:"), /* @__PURE__ */ import_react80.default.createElement("div", { className: "network-details" }, /* @__PURE__ */ import_react80.default.createElement("div", { className: "kima-card-network-container" }, /* @__PURE__ */ import_react80.default.createElement("span", { className: `kima-card-network-label ${theme.colorMode}` }, /* @__PURE__ */ import_react80.default.createElement(ChainIcon, { symbol: targetNetworkOption?.shortName }), targetNetworkOption?.name)), /* @__PURE__ */ import_react80.default.createElement("p", { className: theme.colorMode }, mode === "light" /* light */ ? targetNetwork.shortName === "SOL" ? lightDemoAccounts.SOL : targetNetwork.shortName === "TRX" ? lightDemoAccounts.TRX : lightDemoAccounts.EVM : dAppOption === "LPDrain" /* LPDrain */ ? connectedAddress : targetAddress))), mode === "bridge" /* bridge */ && BigInt(totalFee.value) > BigInt(0) ? (
|
|
5031
4976
|
// <FeeDeductionSlider />
|
|
5032
|
-
/* @__PURE__ */
|
|
4977
|
+
/* @__PURE__ */ import_react80.default.createElement(FeeDeductionRadioButtons_default, { disabled: feeOptionDisabled })
|
|
5033
4978
|
) : null);
|
|
5034
4979
|
};
|
|
5035
4980
|
var ConfirmDetails_default = ConfirmDetails;
|
|
5036
4981
|
|
|
5037
4982
|
// src/components/reusable/AddressInput.tsx
|
|
5038
|
-
var
|
|
4983
|
+
var import_react81 = __toESM(require("react"), 1);
|
|
5039
4984
|
var import_react_redux32 = require("react-redux");
|
|
5040
4985
|
var AddressInput = ({
|
|
5041
4986
|
theme,
|
|
@@ -5048,7 +4993,7 @@ var AddressInput = ({
|
|
|
5048
4993
|
const targetChain = (0, import_react_redux32.useSelector)(selectTargetChain);
|
|
5049
4994
|
const { connectedAddress: sourceAddress, isReady } = useIsWalletReady4();
|
|
5050
4995
|
const targetAddress = (0, import_react_redux32.useSelector)(selectTargetAddress);
|
|
5051
|
-
(0,
|
|
4996
|
+
(0, import_react81.useEffect)(() => {
|
|
5052
4997
|
if (mode === "payment" /* payment */) return;
|
|
5053
4998
|
if (mode === "light" /* light */ && !initialSelection) {
|
|
5054
4999
|
if (isEVMChain(targetChain.shortName))
|
|
@@ -5074,7 +5019,7 @@ var AddressInput = ({
|
|
|
5074
5019
|
mode,
|
|
5075
5020
|
dispatch
|
|
5076
5021
|
]);
|
|
5077
|
-
return /* @__PURE__ */
|
|
5022
|
+
return /* @__PURE__ */ import_react81.default.createElement(
|
|
5078
5023
|
"input",
|
|
5079
5024
|
{
|
|
5080
5025
|
className: `kima-address-input ${theme}`,
|
|
@@ -5089,11 +5034,11 @@ var AddressInput = ({
|
|
|
5089
5034
|
var AddressInput_default = AddressInput;
|
|
5090
5035
|
|
|
5091
5036
|
// src/components/reusable/CustomCheckbox.tsx
|
|
5092
|
-
var
|
|
5037
|
+
var import_react82 = __toESM(require("react"), 1);
|
|
5093
5038
|
var import_react_redux33 = require("react-redux");
|
|
5094
5039
|
|
|
5095
5040
|
// src/components/reusable/StepBox.tsx
|
|
5096
|
-
var
|
|
5041
|
+
var import_react83 = __toESM(require("react"), 1);
|
|
5097
5042
|
var import_react_redux34 = require("react-redux");
|
|
5098
5043
|
var stepInfo2 = [
|
|
5099
5044
|
{
|
|
@@ -5117,69 +5062,69 @@ var StepBox = ({ step, errorStep, loadingStep, data }) => {
|
|
|
5117
5062
|
const explorerUrl = (0, import_react_redux34.useSelector)(selectKimaExplorer);
|
|
5118
5063
|
const networkOption = (0, import_react_redux34.useSelector)(selectNetworkOption);
|
|
5119
5064
|
const networks = (0, import_react_redux34.useSelector)(selectNetworks);
|
|
5120
|
-
const sourceChain = (0,
|
|
5065
|
+
const sourceChain = (0, import_react83.useMemo)(() => {
|
|
5121
5066
|
const sourceKey = data?.sourceChain === "FIAT" ? "CC" : data?.sourceChain;
|
|
5122
5067
|
return networks.find((network) => network.shortName === sourceKey);
|
|
5123
5068
|
}, [data, networks]);
|
|
5124
|
-
const targetChain = (0,
|
|
5069
|
+
const targetChain = (0, import_react83.useMemo)(
|
|
5125
5070
|
() => networks.find((network) => network.shortName === data?.targetChain),
|
|
5126
5071
|
[data, networks]
|
|
5127
5072
|
);
|
|
5128
|
-
return /* @__PURE__ */
|
|
5073
|
+
return /* @__PURE__ */ import_react83.default.createElement("div", { className: "kima-stepbox" }, /* @__PURE__ */ import_react83.default.createElement("div", { className: `content-wrapper ${theme.colorMode}` }, stepInfo2.map((item, index) => /* @__PURE__ */ import_react83.default.createElement("div", { key: item.title, className: "step-item" }, /* @__PURE__ */ import_react83.default.createElement(
|
|
5129
5074
|
"div",
|
|
5130
5075
|
{
|
|
5131
5076
|
className: `info-item
|
|
5132
5077
|
${step >= index ? index === loadingStep ? "active" : index === errorStep ? "error" : "completed" : ""}
|
|
5133
5078
|
${step < index && "locked"} ${theme.colorMode}`
|
|
5134
5079
|
},
|
|
5135
|
-
step < index && /* @__PURE__ */
|
|
5136
|
-
step >= index ? index === loadingStep ? /* @__PURE__ */
|
|
5137
|
-
/* @__PURE__ */
|
|
5138
|
-
), index === 0 && data?.kimaTxHash ? /* @__PURE__ */
|
|
5080
|
+
step < index && /* @__PURE__ */ import_react83.default.createElement(Lock_default, null),
|
|
5081
|
+
step >= index ? index === loadingStep ? /* @__PURE__ */ import_react83.default.createElement(Loader_default, { className: "loader" }) : index === errorStep ? /* @__PURE__ */ import_react83.default.createElement(Warning_default, null) : /* @__PURE__ */ import_react83.default.createElement(Check_default, null) : null,
|
|
5082
|
+
/* @__PURE__ */ import_react83.default.createElement("p", null, item.title)
|
|
5083
|
+
), index === 0 && data?.kimaTxHash ? /* @__PURE__ */ import_react83.default.createElement("div", { className: `info-item ${theme.colorMode}` }, /* @__PURE__ */ import_react83.default.createElement("div", { className: "icon" }, /* @__PURE__ */ import_react83.default.createElement(USDK_default, { width: 30, height: 30 })), /* @__PURE__ */ import_react83.default.createElement("p", { className: "chain-name" }, "Kima TX Hash:"), /* @__PURE__ */ import_react83.default.createElement("p", null, /* @__PURE__ */ import_react83.default.createElement(
|
|
5139
5084
|
ExternalLink_default,
|
|
5140
5085
|
{
|
|
5141
5086
|
to: `${explorerUrl}/transactions/?tx=${data?.kimaTxHash}`
|
|
5142
5087
|
},
|
|
5143
5088
|
getShortenedAddress(data?.kimaTxHash || "")
|
|
5144
|
-
), /* @__PURE__ */
|
|
5089
|
+
), /* @__PURE__ */ import_react83.default.createElement(CopyButton_default, { text: data?.kimaTxHash }))) : null, index === 1 && data?.tssPullHash && sourceChain?.shortName !== "CC" ? /* @__PURE__ */ import_react83.default.createElement(
|
|
5145
5090
|
"div",
|
|
5146
5091
|
{
|
|
5147
5092
|
className: `info-item ${theme.colorMode} source-chain ${step >= 3 ? "paid" : ""}`
|
|
5148
5093
|
},
|
|
5149
|
-
/* @__PURE__ */
|
|
5150
|
-
/* @__PURE__ */
|
|
5151
|
-
/* @__PURE__ */
|
|
5094
|
+
/* @__PURE__ */ import_react83.default.createElement(ChainIcon, { symbol: data.sourceChain }),
|
|
5095
|
+
/* @__PURE__ */ import_react83.default.createElement("p", { className: "chain-name" }, sourceChain?.name, " TX Hash:"),
|
|
5096
|
+
/* @__PURE__ */ import_react83.default.createElement("p", null, /* @__PURE__ */ import_react83.default.createElement(
|
|
5152
5097
|
ExternalLink_default,
|
|
5153
5098
|
{
|
|
5154
5099
|
to: `${sourceChain?.blockExplorers?.default.url}/${data?.sourceChain === "TRX" /* TRON */ ? "#/transaction" : "tx"}/${data?.tssPullHash}${data?.sourceChain === "SOL" /* SOLANA */ && networkOption === "testnet" /* testnet */ ? "?cluster=devnet" : ""}`
|
|
5155
5100
|
},
|
|
5156
5101
|
getShortenedAddress(data?.tssPullHash || "")
|
|
5157
|
-
), /* @__PURE__ */
|
|
5158
|
-
) : null, index === 3 && data?.tssRefundHash ? /* @__PURE__ */
|
|
5102
|
+
), /* @__PURE__ */ import_react83.default.createElement(CopyButton_default, { text: data?.tssPullHash || "" }))
|
|
5103
|
+
) : null, index === 3 && data?.tssRefundHash ? /* @__PURE__ */ import_react83.default.createElement("div", { className: `info-item ${theme.colorMode} target-chain` }, /* @__PURE__ */ import_react83.default.createElement(ChainIcon, { symbol: data.sourceChain }), /* @__PURE__ */ import_react83.default.createElement("p", { className: "chain-name" }, sourceChain?.name, " TX Hash:"), /* @__PURE__ */ import_react83.default.createElement("p", null, /* @__PURE__ */ import_react83.default.createElement(
|
|
5159
5104
|
ExternalLink_default,
|
|
5160
5105
|
{
|
|
5161
5106
|
to: `${sourceChain?.blockExplorers?.default.url}/${data?.sourceChain === "TRX" /* TRON */ ? "#/transaction" : "tx"}/${data?.tssRefundHash}${data?.sourceChain === "SOL" /* SOLANA */ && networkOption === "testnet" /* testnet */ ? "?cluster=devnet" : ""}`
|
|
5162
5107
|
},
|
|
5163
5108
|
getShortenedAddress(data?.tssRefundHash || "")
|
|
5164
|
-
), /* @__PURE__ */
|
|
5109
|
+
), /* @__PURE__ */ import_react83.default.createElement(CopyButton_default, { text: data?.tssRefundHash || "" }))) : null, index === 3 && data?.tssReleaseHash ? /* @__PURE__ */ import_react83.default.createElement("div", { className: `info-item ${theme.colorMode} target-chain` }, /* @__PURE__ */ import_react83.default.createElement(ChainIcon, { symbol: data.targetChain }), /* @__PURE__ */ import_react83.default.createElement("p", { className: "chain-name" }, targetChain?.name, " TX Hash:"), /* @__PURE__ */ import_react83.default.createElement("p", null, /* @__PURE__ */ import_react83.default.createElement(
|
|
5165
5110
|
ExternalLink_default,
|
|
5166
5111
|
{
|
|
5167
5112
|
to: `${targetChain?.blockExplorers?.default.url}/${data?.targetChain === "TRX" /* TRON */ ? "#/transaction" : "tx"}/${data?.tssReleaseHash}${data?.targetChain === "SOL" /* SOLANA */ && networkOption === "testnet" /* testnet */ ? "?cluster=devnet" : ""}`
|
|
5168
5113
|
},
|
|
5169
5114
|
getShortenedAddress(data?.tssReleaseHash || "")
|
|
5170
|
-
), /* @__PURE__ */
|
|
5115
|
+
), /* @__PURE__ */ import_react83.default.createElement(CopyButton_default, { text: data?.tssReleaseHash || "" }))) : null))));
|
|
5171
5116
|
};
|
|
5172
5117
|
var StepBox_default = StepBox;
|
|
5173
5118
|
|
|
5174
5119
|
// src/components/reusable/BankInput.tsx
|
|
5175
|
-
var
|
|
5120
|
+
var import_react84 = __toESM(require("react"), 1);
|
|
5176
5121
|
var import_react_redux35 = require("react-redux");
|
|
5177
5122
|
var import_react_redux36 = require("react-redux");
|
|
5178
5123
|
var BankInput = () => {
|
|
5179
5124
|
const dispatch = (0, import_react_redux35.useDispatch)();
|
|
5180
5125
|
const theme = (0, import_react_redux36.useSelector)(selectTheme);
|
|
5181
5126
|
const bankDetails = (0, import_react_redux36.useSelector)(selectBankDetails);
|
|
5182
|
-
return /* @__PURE__ */
|
|
5127
|
+
return /* @__PURE__ */ import_react84.default.createElement("div", { className: "bank-input" }, /* @__PURE__ */ import_react84.default.createElement("div", { className: `form-item ${theme.colorMode}` }, /* @__PURE__ */ import_react84.default.createElement("span", { className: "label" }, "IBAN:"), /* @__PURE__ */ import_react84.default.createElement(
|
|
5183
5128
|
"input",
|
|
5184
5129
|
{
|
|
5185
5130
|
className: "kima-address-input",
|
|
@@ -5187,7 +5132,7 @@ var BankInput = () => {
|
|
|
5187
5132
|
value: bankDetails.iban,
|
|
5188
5133
|
onChange: (e) => dispatch(setBankDetails({ ...bankDetails, iban: e.target.value }))
|
|
5189
5134
|
}
|
|
5190
|
-
)), /* @__PURE__ */
|
|
5135
|
+
)), /* @__PURE__ */ import_react84.default.createElement("div", { className: `form-item ${theme.colorMode}` }, /* @__PURE__ */ import_react84.default.createElement("span", { className: "label" }, "Recipient:"), /* @__PURE__ */ import_react84.default.createElement(
|
|
5191
5136
|
"input",
|
|
5192
5137
|
{
|
|
5193
5138
|
className: "kima-address-input",
|
|
@@ -5202,7 +5147,7 @@ var BankInput = () => {
|
|
|
5202
5147
|
var BankInput_default = BankInput;
|
|
5203
5148
|
|
|
5204
5149
|
// src/components/reusable/TxButton.tsx
|
|
5205
|
-
var
|
|
5150
|
+
var import_react85 = __toESM(require("react"), 1);
|
|
5206
5151
|
var import_react_redux37 = require("react-redux");
|
|
5207
5152
|
var import_react_redux38 = require("react-redux");
|
|
5208
5153
|
var TxButton = ({ theme }) => {
|
|
@@ -5211,14 +5156,14 @@ var TxButton = ({ theme }) => {
|
|
|
5211
5156
|
dispatch(setPendingTxPopup(true));
|
|
5212
5157
|
};
|
|
5213
5158
|
const txCount = (0, import_react_redux38.useSelector)(selectPendingTxs);
|
|
5214
|
-
return /* @__PURE__ */
|
|
5159
|
+
return /* @__PURE__ */ import_react85.default.createElement(
|
|
5215
5160
|
"button",
|
|
5216
5161
|
{
|
|
5217
5162
|
className: `secondary-button tx-button ${theme.colorMode}`,
|
|
5218
5163
|
onClick: handleClick
|
|
5219
5164
|
},
|
|
5220
5165
|
txCount,
|
|
5221
|
-
/* @__PURE__ */
|
|
5166
|
+
/* @__PURE__ */ import_react85.default.createElement(
|
|
5222
5167
|
ring_default,
|
|
5223
5168
|
{
|
|
5224
5169
|
height: 16,
|
|
@@ -5237,7 +5182,7 @@ var import_react_redux43 = require("react-redux");
|
|
|
5237
5182
|
var import_react_hot_toast3 = require("react-hot-toast");
|
|
5238
5183
|
|
|
5239
5184
|
// src/hooks/useGetTxData.ts
|
|
5240
|
-
var
|
|
5185
|
+
var import_react86 = require("react");
|
|
5241
5186
|
var import_react_query14 = require("@tanstack/react-query");
|
|
5242
5187
|
|
|
5243
5188
|
// src/services/transactionApi.ts
|
|
@@ -5328,7 +5273,7 @@ var getTxData = async ({
|
|
|
5328
5273
|
// src/hooks/useGetTxData.ts
|
|
5329
5274
|
var POLLING_INTERVAL_MS = 1e3 * 10;
|
|
5330
5275
|
var useGetTxData = (txId, dAppOption, backendUrl) => {
|
|
5331
|
-
const refPollForUpdates = (0,
|
|
5276
|
+
const refPollForUpdates = (0, import_react86.useRef)(false);
|
|
5332
5277
|
const isLP = dAppOption === "LPAdd" /* LPAdd */ || dAppOption === "LPDrain" /* LPDrain */;
|
|
5333
5278
|
const validTxId = typeof txId === "number" ? txId > 0 : txId.toString().length > 0;
|
|
5334
5279
|
const result = (0, import_react_query14.useQuery)({
|
|
@@ -5345,17 +5290,17 @@ var useGetTxData = (txId, dAppOption, backendUrl) => {
|
|
|
5345
5290
|
var useGetTxData_default = useGetTxData;
|
|
5346
5291
|
|
|
5347
5292
|
// src/components/reusable/TransactionStatusMessage.tsx
|
|
5348
|
-
var
|
|
5293
|
+
var import_react87 = __toESM(require("react"), 1);
|
|
5349
5294
|
var TransactionStatusMessage = ({
|
|
5350
5295
|
isCompleted,
|
|
5351
5296
|
transactionId
|
|
5352
5297
|
}) => {
|
|
5353
|
-
return /* @__PURE__ */
|
|
5298
|
+
return /* @__PURE__ */ import_react87.default.createElement("div", { className: "transaction-status-message" }, /* @__PURE__ */ import_react87.default.createElement("h2", null, isCompleted !== "Completed" /* COMPLETED */ && "Your transaction is currently being processed.", " ", "Please copy the Transaction ID below for future reference. You can use this ID to track the transaction status or resolve any issues if needed."), /* @__PURE__ */ import_react87.default.createElement("span", { className: "transaction-copy" }, /* @__PURE__ */ import_react87.default.createElement("h3", null, transactionId), /* @__PURE__ */ import_react87.default.createElement(CopyButton_default, { text: transactionId })));
|
|
5354
5299
|
};
|
|
5355
5300
|
var TransactionStatusMessage_default = TransactionStatusMessage;
|
|
5356
5301
|
|
|
5357
5302
|
// src/components/reusable/TransactionSearch.tsx
|
|
5358
|
-
var
|
|
5303
|
+
var import_react88 = __toESM(require("react"), 1);
|
|
5359
5304
|
var import_react_redux39 = require("react-redux");
|
|
5360
5305
|
var import_react_redux40 = require("react-redux");
|
|
5361
5306
|
var import_react_hot_toast2 = __toESM(require("react-hot-toast"), 1);
|
|
@@ -5363,12 +5308,12 @@ var TransactionSearch = () => {
|
|
|
5363
5308
|
const theme = (0, import_react_redux39.useSelector)(selectTheme);
|
|
5364
5309
|
const backendUrl = (0, import_react_redux39.useSelector)(selectBackendUrl);
|
|
5365
5310
|
const dispatch = (0, import_react_redux40.useDispatch)();
|
|
5366
|
-
const [transactionId, setTransactionId] = (0,
|
|
5367
|
-
const refPollForUpdates = (0,
|
|
5311
|
+
const [transactionId, setTransactionId] = (0, import_react88.useState)("");
|
|
5312
|
+
const refPollForUpdates = (0, import_react88.useRef)(false);
|
|
5368
5313
|
const handleSearch = async () => {
|
|
5369
5314
|
if (transactionId.length <= 0)
|
|
5370
5315
|
return import_react_hot_toast2.default.error("You must provide a valid transaction id", {
|
|
5371
|
-
icon: /* @__PURE__ */
|
|
5316
|
+
icon: /* @__PURE__ */ import_react88.default.createElement(Error_default, null)
|
|
5372
5317
|
});
|
|
5373
5318
|
try {
|
|
5374
5319
|
const data = await getTxData({
|
|
@@ -5385,11 +5330,11 @@ var TransactionSearch = () => {
|
|
|
5385
5330
|
logger_default.error("Error searching transaction: ", error);
|
|
5386
5331
|
return import_react_hot_toast2.default.error(
|
|
5387
5332
|
"Transaction not found. Please check for the proper transaction id.",
|
|
5388
|
-
{ icon: /* @__PURE__ */
|
|
5333
|
+
{ icon: /* @__PURE__ */ import_react88.default.createElement(Error_default, null) }
|
|
5389
5334
|
);
|
|
5390
5335
|
}
|
|
5391
5336
|
};
|
|
5392
|
-
return /* @__PURE__ */
|
|
5337
|
+
return /* @__PURE__ */ import_react88.default.createElement("div", { className: "form-item transaction-search" }, /* @__PURE__ */ import_react88.default.createElement("div", { className: "transaction-input" }, /* @__PURE__ */ import_react88.default.createElement("span", { className: "label" }, "Search Transaction:"), /* @__PURE__ */ import_react88.default.createElement(
|
|
5393
5338
|
"input",
|
|
5394
5339
|
{
|
|
5395
5340
|
className: `${theme.colorMode}`,
|
|
@@ -5399,18 +5344,18 @@ var TransactionSearch = () => {
|
|
|
5399
5344
|
onChange: (e) => setTransactionId(e.target.value),
|
|
5400
5345
|
spellCheck: false
|
|
5401
5346
|
}
|
|
5402
|
-
)), /* @__PURE__ */
|
|
5347
|
+
)), /* @__PURE__ */ import_react88.default.createElement(SecondaryButton_default, { clickHandler: handleSearch }, "Search"));
|
|
5403
5348
|
};
|
|
5404
5349
|
var TransactionSearch_default = TransactionSearch;
|
|
5405
5350
|
|
|
5406
5351
|
// src/components/TransactionWidget.tsx
|
|
5407
5352
|
var TransactionWidget = ({ theme }) => {
|
|
5408
|
-
const [step, setStep] = (0,
|
|
5409
|
-
const [focus, setFocus] = (0,
|
|
5410
|
-
const [errorStep, setErrorStep] = (0,
|
|
5411
|
-
const [errorMessage, setErrorMessage] = (0,
|
|
5412
|
-
const [loadingStep, setLoadingStep] = (0,
|
|
5413
|
-
const [minimized, setMinimized] = (0,
|
|
5353
|
+
const [step, setStep] = (0, import_react89.useState)(0);
|
|
5354
|
+
const [focus, setFocus] = (0, import_react89.useState)(-1);
|
|
5355
|
+
const [errorStep, setErrorStep] = (0, import_react89.useState)(-1);
|
|
5356
|
+
const [errorMessage, setErrorMessage] = (0, import_react89.useState)("");
|
|
5357
|
+
const [loadingStep, setLoadingStep] = (0, import_react89.useState)(-1);
|
|
5358
|
+
const [minimized, setMinimized] = (0, import_react89.useState)(false);
|
|
5414
5359
|
const dispatch = (0, import_react_redux43.useDispatch)();
|
|
5415
5360
|
const mode = (0, import_react_redux42.useSelector)(selectMode);
|
|
5416
5361
|
const feeDeduct = (0, import_react_redux42.useSelector)(selectFeeDeduct);
|
|
@@ -5428,42 +5373,42 @@ var TransactionWidget = ({ theme }) => {
|
|
|
5428
5373
|
const { successHandler, closeHandler } = useKimaContext();
|
|
5429
5374
|
const backendUrl = (0, import_react_redux42.useSelector)(selectBackendUrl);
|
|
5430
5375
|
const { data, error } = useGetTxData_default(txId, dAppOption, backendUrl);
|
|
5431
|
-
const transactionSourceChain = (0,
|
|
5376
|
+
const transactionSourceChain = (0, import_react89.useMemo)(
|
|
5432
5377
|
() => networks.find(
|
|
5433
5378
|
(network) => network.shortName === (mode === "status" /* status */ ? data?.sourceChain === "FIAT" ? "CC" : data?.sourceChain : sourceChain.shortName)
|
|
5434
5379
|
),
|
|
5435
5380
|
[data, mode, sourceChain]
|
|
5436
5381
|
);
|
|
5437
|
-
const transactionTargetChain = (0,
|
|
5382
|
+
const transactionTargetChain = (0, import_react89.useMemo)(
|
|
5438
5383
|
() => networks.find(
|
|
5439
5384
|
(network) => network.shortName === (mode === "status" /* status */ ? data?.targetChain : targetChain.shortName)
|
|
5440
5385
|
),
|
|
5441
5386
|
[data, mode, targetChain]
|
|
5442
5387
|
);
|
|
5443
|
-
const isValidTxId = (0,
|
|
5388
|
+
const isValidTxId = (0, import_react89.useMemo)(() => {
|
|
5444
5389
|
return !(!txId || typeof txId === "string" && txId.length === 0 || typeof txId === "number" && txId < 0);
|
|
5445
5390
|
}, [txId]);
|
|
5446
|
-
const isEmptyStatus = (0,
|
|
5391
|
+
const isEmptyStatus = (0, import_react89.useMemo)(() => {
|
|
5447
5392
|
if (!data) return true;
|
|
5448
5393
|
return data?.amount === "";
|
|
5449
5394
|
}, [data]);
|
|
5450
5395
|
const { data: chainData } = useChainData(backendUrl);
|
|
5451
|
-
(0,
|
|
5396
|
+
(0, import_react89.useEffect)(() => {
|
|
5452
5397
|
if (!data || data.status !== "Completed" /* COMPLETED */) return;
|
|
5453
5398
|
successHandler && successHandler({
|
|
5454
5399
|
txId
|
|
5455
5400
|
});
|
|
5456
5401
|
}, [data]);
|
|
5457
|
-
(0,
|
|
5402
|
+
(0, import_react89.useEffect)(() => {
|
|
5458
5403
|
if (error)
|
|
5459
5404
|
import_react_hot_toast3.toast.error(
|
|
5460
5405
|
"The provided transaction id is not valid, please use a different one or contact support for further assistance",
|
|
5461
5406
|
{
|
|
5462
|
-
icon: /* @__PURE__ */
|
|
5407
|
+
icon: /* @__PURE__ */ import_react89.default.createElement(Error_default, null)
|
|
5463
5408
|
}
|
|
5464
5409
|
);
|
|
5465
5410
|
}, [error]);
|
|
5466
|
-
(0,
|
|
5411
|
+
(0, import_react89.useEffect)(() => {
|
|
5467
5412
|
if (!data) {
|
|
5468
5413
|
setStep(0);
|
|
5469
5414
|
setLoadingStep(0);
|
|
@@ -5483,7 +5428,7 @@ var TransactionWidget = ({ theme }) => {
|
|
|
5483
5428
|
setErrorStep(1);
|
|
5484
5429
|
setLoadingStep(-1);
|
|
5485
5430
|
logger_default.error("transaction failed:", data.failReason);
|
|
5486
|
-
import_react_hot_toast3.toast.error("Unavailable", { icon: /* @__PURE__ */
|
|
5431
|
+
import_react_hot_toast3.toast.error("Unavailable", { icon: /* @__PURE__ */ import_react89.default.createElement(Error_default, null) });
|
|
5487
5432
|
setErrorMessage("Unavailable");
|
|
5488
5433
|
} else if (status === "Paid" /* PAID */) {
|
|
5489
5434
|
setStep(3);
|
|
@@ -5494,7 +5439,7 @@ var TransactionWidget = ({ theme }) => {
|
|
|
5494
5439
|
import_react_hot_toast3.toast.error(
|
|
5495
5440
|
"Failed to release tokens to target! Starting refund process.",
|
|
5496
5441
|
{
|
|
5497
|
-
icon: /* @__PURE__ */
|
|
5442
|
+
icon: /* @__PURE__ */ import_react89.default.createElement(Error_default, null)
|
|
5498
5443
|
}
|
|
5499
5444
|
);
|
|
5500
5445
|
setErrorMessage(
|
|
@@ -5505,7 +5450,7 @@ var TransactionWidget = ({ theme }) => {
|
|
|
5505
5450
|
setErrorStep(3);
|
|
5506
5451
|
setLoadingStep(-1);
|
|
5507
5452
|
import_react_hot_toast3.toast.error("Failed to refund tokens to source!", {
|
|
5508
|
-
icon: /* @__PURE__ */
|
|
5453
|
+
icon: /* @__PURE__ */ import_react89.default.createElement(Error_default, null)
|
|
5509
5454
|
});
|
|
5510
5455
|
setErrorMessage("Failed to refund tokens to source!");
|
|
5511
5456
|
} else if (status === "RefundCompleted" /* REFUNDCOMPLETED */) {
|
|
@@ -5513,7 +5458,7 @@ var TransactionWidget = ({ theme }) => {
|
|
|
5513
5458
|
setErrorStep(3);
|
|
5514
5459
|
setLoadingStep(-1);
|
|
5515
5460
|
import_react_hot_toast3.toast.success("Refund completed!", {
|
|
5516
|
-
icon: /* @__PURE__ */
|
|
5461
|
+
icon: /* @__PURE__ */ import_react89.default.createElement(Error_default, null)
|
|
5517
5462
|
});
|
|
5518
5463
|
setErrorMessage("Refund completed!");
|
|
5519
5464
|
} else if (status === "FailedToPay" /* FAILEDTOPAY */) {
|
|
@@ -5522,7 +5467,7 @@ var TransactionWidget = ({ theme }) => {
|
|
|
5522
5467
|
setLoadingStep(-1);
|
|
5523
5468
|
logger_default.error("transaction failed:", data.failReason);
|
|
5524
5469
|
import_react_hot_toast3.toast.error("Failed to release tokens to target!", {
|
|
5525
|
-
icon: /* @__PURE__ */
|
|
5470
|
+
icon: /* @__PURE__ */ import_react89.default.createElement(Error_default, null)
|
|
5526
5471
|
});
|
|
5527
5472
|
setErrorMessage("Failed to release tokens to target!");
|
|
5528
5473
|
} else if (status === "FailedToPull" /* FAILEDTOPULL */) {
|
|
@@ -5530,7 +5475,7 @@ var TransactionWidget = ({ theme }) => {
|
|
|
5530
5475
|
setErrorStep(1);
|
|
5531
5476
|
setLoadingStep(-1);
|
|
5532
5477
|
logger_default.error("transaction failed:", data.failReason);
|
|
5533
|
-
import_react_hot_toast3.toast.error("Failed to pull tokens from source!", { icon: /* @__PURE__ */
|
|
5478
|
+
import_react_hot_toast3.toast.error("Failed to pull tokens from source!", { icon: /* @__PURE__ */ import_react89.default.createElement(Error_default, null) });
|
|
5534
5479
|
setErrorMessage("Failed to pull tokens from source!");
|
|
5535
5480
|
} else if (status === "Completed" /* COMPLETED */) {
|
|
5536
5481
|
setStep(4);
|
|
@@ -5591,7 +5536,7 @@ var TransactionWidget = ({ theme }) => {
|
|
|
5591
5536
|
dispatch(setTxId(-1));
|
|
5592
5537
|
dispatch(setSubmitted(false));
|
|
5593
5538
|
};
|
|
5594
|
-
return /* @__PURE__ */
|
|
5539
|
+
return /* @__PURE__ */ import_react89.default.createElement(import_react_redux41.Provider, { store }, /* @__PURE__ */ import_react89.default.createElement(
|
|
5595
5540
|
"div",
|
|
5596
5541
|
{
|
|
5597
5542
|
className: `kima-card transaction-card ${theme.colorMode} ${minimized ? "minimized" : ""}`,
|
|
@@ -5599,17 +5544,17 @@ var TransactionWidget = ({ theme }) => {
|
|
|
5599
5544
|
background: theme.colorMode === "light" /* light */ ? theme.backgroundColorLight : theme.backgroundColorDark
|
|
5600
5545
|
}
|
|
5601
5546
|
},
|
|
5602
|
-
/* @__PURE__ */
|
|
5547
|
+
/* @__PURE__ */ import_react89.default.createElement("div", { className: "kima-card-header" }, /* @__PURE__ */ import_react89.default.createElement("div", { className: "topbar" }, /* @__PURE__ */ import_react89.default.createElement("div", { className: "title" }, isValidTxId && !error ? /* @__PURE__ */ import_react89.default.createElement("div", { className: "transaction-title" }, mode !== "status" /* status */ ? data?.status === "Completed" /* COMPLETED */ ? "Transferred " : "Transfering " : isEmptyStatus ? "Fetching transaction status " : data?.status === "Completed" /* COMPLETED */ ? "Transfered " : "Transfering ", mode !== "status" /* status */ ? Number(amount) !== 0 ? transactionSourceChain?.shortName === "CC" ? bigIntToNumber(txValues.allowanceAmount).toFixed(2) : formatBigInt(txValues.allowanceAmount) : "" : data?.amount || "", " ", mode !== "status" /* status */ ? `${sourceSymbol} ` : isEmptyStatus ? "" : `(${data?.sourceSymbol})`, /* @__PURE__ */ import_react89.default.createElement("div", { className: "title-icon" }, /* @__PURE__ */ import_react89.default.createElement(
|
|
5603
5548
|
ChainIcon,
|
|
5604
5549
|
{
|
|
5605
5550
|
symbol: transactionSourceChain?.shortName
|
|
5606
5551
|
}
|
|
5607
|
-
)), " ", mode !== "status" /* status */ ? `${transactionSourceChain?.name}` : isEmptyStatus ? "" : `${data?.sourceChain === "FIAT" ? "CC" : data?.sourceChain}`, " ", mode !== "status" /* status */ ? `\u2192 ` : isEmptyStatus ? "" : `\u2192 `, mode !== "status" /* status */ ? Number(amount) !== 0 ? transactionSourceChain?.shortName === "CC" ? bigIntToNumber(txValues.submitAmount).toFixed(2) : formatBigInt(txValues.submitAmount) : "" : data?.amount || "", " ", mode !== "status" /* status */ ? `${targetSymbol}${" "}` : isEmptyStatus ? "" : `${data?.targetSymbol}${" "}`, /* @__PURE__ */
|
|
5552
|
+
)), " ", mode !== "status" /* status */ ? `${transactionSourceChain?.name}` : isEmptyStatus ? "" : `${data?.sourceChain === "FIAT" ? "CC" : data?.sourceChain}`, " ", mode !== "status" /* status */ ? `\u2192 ` : isEmptyStatus ? "" : `\u2192 `, mode !== "status" /* status */ ? Number(amount) !== 0 ? transactionSourceChain?.shortName === "CC" ? bigIntToNumber(txValues.submitAmount).toFixed(2) : formatBigInt(txValues.submitAmount) : "" : data?.amount || "", " ", mode !== "status" /* status */ ? `${targetSymbol}${" "}` : isEmptyStatus ? "" : `${data?.targetSymbol}${" "}`, /* @__PURE__ */ import_react89.default.createElement("div", { className: "title-icon" }, /* @__PURE__ */ import_react89.default.createElement(
|
|
5608
5553
|
ChainIcon,
|
|
5609
5554
|
{
|
|
5610
5555
|
symbol: transactionTargetChain?.shortName
|
|
5611
5556
|
}
|
|
5612
|
-
)), " ", mode !== "status" /* status */ ? `${transactionTargetChain?.name}${" "}` : isEmptyStatus ? "" : `${data?.targetChain} ${" "}`) : /* @__PURE__ */
|
|
5557
|
+
)), " ", mode !== "status" /* status */ ? `${transactionTargetChain?.name}${" "}` : isEmptyStatus ? "" : `${data?.targetChain} ${" "}`) : /* @__PURE__ */ import_react89.default.createElement("div", null, /* @__PURE__ */ import_react89.default.createElement("h3", { className: "transaction" }, "Transaction Status"))), !minimized ? /* @__PURE__ */ import_react89.default.createElement("div", { className: "control-buttons" }, /* @__PURE__ */ import_react89.default.createElement(
|
|
5613
5558
|
"button",
|
|
5614
5559
|
{
|
|
5615
5560
|
className: "icon-button minimize",
|
|
@@ -5617,9 +5562,9 @@ var TransactionWidget = ({ theme }) => {
|
|
|
5617
5562
|
setMinimized(true);
|
|
5618
5563
|
}
|
|
5619
5564
|
},
|
|
5620
|
-
/* @__PURE__ */
|
|
5621
|
-
), !isValidTxId || loadingStep < 0 || error ? /* @__PURE__ */
|
|
5622
|
-
isValidTxId && !error ? /* @__PURE__ */
|
|
5565
|
+
/* @__PURE__ */ import_react89.default.createElement(Minimize_default, null)
|
|
5566
|
+
), !isValidTxId || loadingStep < 0 || error ? /* @__PURE__ */ import_react89.default.createElement("button", { className: "reset-button", onClick: resetForm }, "Reset") : null) : /* @__PURE__ */ import_react89.default.createElement("div", { className: "control-buttons" }, /* @__PURE__ */ import_react89.default.createElement("div", { className: "maximize", onClick: () => setMinimized(false) }, "View")))),
|
|
5567
|
+
isValidTxId && !error ? /* @__PURE__ */ import_react89.default.createElement("div", { className: "kima-card-content" }, /* @__PURE__ */ import_react89.default.createElement("div", { className: "transaction-content" }, /* @__PURE__ */ import_react89.default.createElement(
|
|
5623
5568
|
Progressbar_default,
|
|
5624
5569
|
{
|
|
5625
5570
|
step,
|
|
@@ -5628,7 +5573,7 @@ var TransactionWidget = ({ theme }) => {
|
|
|
5628
5573
|
setFocus,
|
|
5629
5574
|
loadingStep
|
|
5630
5575
|
}
|
|
5631
|
-
), /* @__PURE__ */
|
|
5576
|
+
), /* @__PURE__ */ import_react89.default.createElement(
|
|
5632
5577
|
StepBox_default,
|
|
5633
5578
|
{
|
|
5634
5579
|
step,
|
|
@@ -5636,14 +5581,14 @@ var TransactionWidget = ({ theme }) => {
|
|
|
5636
5581
|
loadingStep,
|
|
5637
5582
|
data
|
|
5638
5583
|
}
|
|
5639
|
-
)), !error && !isEmptyStatus && /* @__PURE__ */
|
|
5584
|
+
)), !error && !isEmptyStatus && /* @__PURE__ */ import_react89.default.createElement(
|
|
5640
5585
|
TransactionStatusMessage_default,
|
|
5641
5586
|
{
|
|
5642
5587
|
isCompleted: data?.status,
|
|
5643
5588
|
transactionId: txId.toString()
|
|
5644
5589
|
}
|
|
5645
|
-
)) : /* @__PURE__ */
|
|
5646
|
-
/* @__PURE__ */
|
|
5590
|
+
)) : /* @__PURE__ */ import_react89.default.createElement("div", { className: "kima-card-content" }, /* @__PURE__ */ import_react89.default.createElement("h4", { className: "subtitle" }, "You can follow the status of a previous submitted transaction by entering the provided transaction id"), /* @__PURE__ */ import_react89.default.createElement("div", { className: "single-form" }, /* @__PURE__ */ import_react89.default.createElement(TransactionSearch_default, null))),
|
|
5591
|
+
/* @__PURE__ */ import_react89.default.createElement(
|
|
5647
5592
|
import_react_hot_toast3.Toaster,
|
|
5648
5593
|
{
|
|
5649
5594
|
position: "top-right",
|
|
@@ -5670,29 +5615,29 @@ var TransactionWidget = ({ theme }) => {
|
|
|
5670
5615
|
}
|
|
5671
5616
|
}
|
|
5672
5617
|
),
|
|
5673
|
-
/* @__PURE__ */
|
|
5618
|
+
/* @__PURE__ */ import_react89.default.createElement("div", { className: "floating-footer status" }, /* @__PURE__ */ import_react89.default.createElement("div", { className: `items ${theme.colorMode}` }, /* @__PURE__ */ import_react89.default.createElement("span", null, "Powered by"), /* @__PURE__ */ import_react89.default.createElement(KimaNetwork_default, null)))
|
|
5674
5619
|
));
|
|
5675
5620
|
};
|
|
5676
5621
|
|
|
5677
5622
|
// src/components/TransferWidget.tsx
|
|
5678
|
-
var
|
|
5623
|
+
var import_react102 = __toESM(require("react"), 1);
|
|
5679
5624
|
var import_react_redux56 = require("react-redux");
|
|
5680
5625
|
|
|
5681
5626
|
// src/components/reusable/SingleForm.tsx
|
|
5682
|
-
var
|
|
5627
|
+
var import_react91 = __toESM(require("react"), 1);
|
|
5683
5628
|
var import_react_hot_toast4 = require("react-hot-toast");
|
|
5684
5629
|
var import_react_redux46 = require("react-redux");
|
|
5685
5630
|
|
|
5686
5631
|
// src/components/primary/NetworkSelector.tsx
|
|
5687
|
-
var
|
|
5632
|
+
var import_react90 = __toESM(require("react"), 1);
|
|
5688
5633
|
var import_react_redux44 = require("react-redux");
|
|
5689
5634
|
var NetworkSelector = ({
|
|
5690
5635
|
type,
|
|
5691
5636
|
initialSelection,
|
|
5692
5637
|
setInitialSelection
|
|
5693
5638
|
}) => {
|
|
5694
|
-
const [collapsed, setCollapsed] = (0,
|
|
5695
|
-
const ref = (0,
|
|
5639
|
+
const [collapsed, setCollapsed] = (0, import_react90.useState)(true);
|
|
5640
|
+
const ref = (0, import_react90.useRef)(null);
|
|
5696
5641
|
const dispatch = (0, import_react_redux44.useDispatch)();
|
|
5697
5642
|
const theme = (0, import_react_redux44.useSelector)(selectTheme);
|
|
5698
5643
|
const networkOptions3 = (0, import_react_redux44.useSelector)(selectNetworks);
|
|
@@ -5701,14 +5646,14 @@ var NetworkSelector = ({
|
|
|
5701
5646
|
const targetNetwork = (0, import_react_redux44.useSelector)(selectTargetChain);
|
|
5702
5647
|
const { switchChainHandler } = useKimaContext();
|
|
5703
5648
|
const isOriginSelector = type === "origin";
|
|
5704
|
-
const networks = (0,
|
|
5649
|
+
const networks = (0, import_react90.useMemo)(() => {
|
|
5705
5650
|
return networkOptions3.filter((network) => {
|
|
5706
5651
|
const isSameAsSource = isOriginSelector ? false : network.shortName === sourceNetwork.shortName;
|
|
5707
5652
|
const isAllowedInLightMode = mode !== "light" /* light */ || lightDemoNetworks.includes(network.shortName);
|
|
5708
5653
|
return network.supportedLocations.includes(type) && !isSameAsSource && isAllowedInLightMode;
|
|
5709
5654
|
});
|
|
5710
5655
|
}, [networkOptions3, sourceNetwork, type, mode]);
|
|
5711
|
-
const selectedNetwork = (0,
|
|
5656
|
+
const selectedNetwork = (0, import_react90.useMemo)(() => {
|
|
5712
5657
|
if (initialSelection) {
|
|
5713
5658
|
return {
|
|
5714
5659
|
shortName: "",
|
|
@@ -5727,7 +5672,7 @@ var NetworkSelector = ({
|
|
|
5727
5672
|
isOriginSelector,
|
|
5728
5673
|
initialSelection
|
|
5729
5674
|
]);
|
|
5730
|
-
(0,
|
|
5675
|
+
(0, import_react90.useEffect)(() => {
|
|
5731
5676
|
if (!networks.length || selectedNetwork.shortName) return;
|
|
5732
5677
|
const fallbackNetwork = networks[0];
|
|
5733
5678
|
if (isOriginSelector) {
|
|
@@ -5759,7 +5704,7 @@ var NetworkSelector = ({
|
|
|
5759
5704
|
type === "origin" ? setInitialSelection((prev) => ({ ...prev, sourceSelection: false })) : setInitialSelection((prev) => ({ ...prev, targetSelection: false }));
|
|
5760
5705
|
setCollapsed(true);
|
|
5761
5706
|
};
|
|
5762
|
-
(0,
|
|
5707
|
+
(0, import_react90.useEffect)(() => {
|
|
5763
5708
|
const handleOutsideClick = (e) => {
|
|
5764
5709
|
if (ref.current && !ref.current.contains(e.target)) {
|
|
5765
5710
|
setCollapsed(true);
|
|
@@ -5770,7 +5715,7 @@ var NetworkSelector = ({
|
|
|
5770
5715
|
document.removeEventListener("mousedown", handleOutsideClick);
|
|
5771
5716
|
};
|
|
5772
5717
|
}, []);
|
|
5773
|
-
(0,
|
|
5718
|
+
(0, import_react90.useEffect)(() => {
|
|
5774
5719
|
if (mode !== "light" /* light */) return;
|
|
5775
5720
|
if (isEVMChain(targetNetwork.shortName)) {
|
|
5776
5721
|
dispatch(setTargetAddress(lightDemoAccounts.EVM));
|
|
@@ -5780,20 +5725,20 @@ var NetworkSelector = ({
|
|
|
5780
5725
|
dispatch(setTargetAddress(lightDemoAccounts.TRX));
|
|
5781
5726
|
}
|
|
5782
5727
|
}, [sourceNetwork, targetNetwork, mode]);
|
|
5783
|
-
return /* @__PURE__ */
|
|
5728
|
+
return /* @__PURE__ */ import_react90.default.createElement(
|
|
5784
5729
|
"div",
|
|
5785
5730
|
{
|
|
5786
5731
|
className: `network-dropdown ${theme?.colorMode ?? ""} ${collapsed ? "collapsed" : "toggled"}`,
|
|
5787
5732
|
onClick: () => setCollapsed((prev) => !prev),
|
|
5788
5733
|
ref
|
|
5789
5734
|
},
|
|
5790
|
-
/* @__PURE__ */
|
|
5791
|
-
/* @__PURE__ */
|
|
5735
|
+
/* @__PURE__ */ import_react90.default.createElement("div", { className: "network-wrapper" }, /* @__PURE__ */ import_react90.default.createElement(ChainIcon, { symbol: selectedNetwork.shortName }), /* @__PURE__ */ import_react90.default.createElement("span", null, selectedNetwork.name)),
|
|
5736
|
+
/* @__PURE__ */ import_react90.default.createElement(
|
|
5792
5737
|
"div",
|
|
5793
5738
|
{
|
|
5794
5739
|
className: `network-menu custom-scrollbar ${theme?.colorMode ?? ""} ${collapsed ? "collapsed" : "toggled"}`
|
|
5795
5740
|
},
|
|
5796
|
-
networks.filter((network) => network.shortName !== selectedNetwork.shortName).map((network) => /* @__PURE__ */
|
|
5741
|
+
networks.filter((network) => network.shortName !== selectedNetwork.shortName).map((network) => /* @__PURE__ */ import_react90.default.createElement(
|
|
5797
5742
|
"div",
|
|
5798
5743
|
{
|
|
5799
5744
|
key: network.id,
|
|
@@ -5805,15 +5750,15 @@ var NetworkSelector = ({
|
|
|
5805
5750
|
}
|
|
5806
5751
|
}
|
|
5807
5752
|
},
|
|
5808
|
-
network.disabled ? /* @__PURE__ */
|
|
5809
|
-
/* @__PURE__ */
|
|
5810
|
-
network.disabled && /* @__PURE__ */
|
|
5753
|
+
network.disabled ? /* @__PURE__ */ import_react90.default.createElement(Warning_default, { width: 25, height: 25 }) : /* @__PURE__ */ import_react90.default.createElement(ChainIcon, { symbol: network.shortName }),
|
|
5754
|
+
/* @__PURE__ */ import_react90.default.createElement("p", null, network.name),
|
|
5755
|
+
network.disabled && /* @__PURE__ */ import_react90.default.createElement("span", { className: "tooltip" }, "Temporarily unavailable")
|
|
5811
5756
|
))
|
|
5812
5757
|
),
|
|
5813
|
-
/* @__PURE__ */
|
|
5758
|
+
/* @__PURE__ */ import_react90.default.createElement("div", { className: `dropdown-icon ${collapsed ? "toggled" : "collapsed"}` }, /* @__PURE__ */ import_react90.default.createElement(Arrow_default, { fill: "none" }))
|
|
5814
5759
|
);
|
|
5815
5760
|
};
|
|
5816
|
-
var NetworkSelector_default =
|
|
5761
|
+
var NetworkSelector_default = import_react90.default.memo(NetworkSelector);
|
|
5817
5762
|
|
|
5818
5763
|
// src/components/reusable/SingleForm.tsx
|
|
5819
5764
|
var import_viem6 = require("viem");
|
|
@@ -5940,7 +5885,7 @@ var SingleForm = ({
|
|
|
5940
5885
|
const targetNetwork = (0, import_react_redux46.useSelector)(selectTargetChain);
|
|
5941
5886
|
const targetAddress = (0, import_react_redux46.useSelector)(selectTargetAddress);
|
|
5942
5887
|
const { isReady } = useIsWalletReady4();
|
|
5943
|
-
const [amountValue, setAmountValue] = (0,
|
|
5888
|
+
const [amountValue, setAmountValue] = (0, import_react91.useState)("");
|
|
5944
5889
|
const amount = (0, import_react_redux46.useSelector)(selectAmount);
|
|
5945
5890
|
const sourceCurrency = (0, import_react_redux46.useSelector)(selectSourceCurrency);
|
|
5946
5891
|
const targetCurrency = (0, import_react_redux46.useSelector)(selectTargetCurrency);
|
|
@@ -5960,18 +5905,18 @@ var SingleForm = ({
|
|
|
5960
5905
|
targetSymbol: targetCurrency,
|
|
5961
5906
|
backendUrl
|
|
5962
5907
|
});
|
|
5963
|
-
(0,
|
|
5908
|
+
(0, import_react91.useEffect)(() => {
|
|
5964
5909
|
if (fees) {
|
|
5965
5910
|
dispatch(setServiceFee(fees));
|
|
5966
5911
|
}
|
|
5967
5912
|
}, [fees, dispatch]);
|
|
5968
5913
|
const { kimaBackendUrl } = useKimaContext();
|
|
5969
5914
|
const { data: envOptions } = useGetEnvOptions({ kimaBackendUrl });
|
|
5970
|
-
const errorMessage = (0,
|
|
5915
|
+
const errorMessage = (0, import_react91.useMemo)(
|
|
5971
5916
|
() => compliantOption && targetCompliant !== null && !targetCompliant?.isCompliant ? `Target address has ${targetCompliant.results?.[0].result.risk_score} risk` : "",
|
|
5972
5917
|
[compliantOption, targetCompliant]
|
|
5973
5918
|
);
|
|
5974
|
-
const maxValue = (0,
|
|
5919
|
+
const maxValue = (0, import_react91.useMemo)(() => {
|
|
5975
5920
|
if (mode === "light" /* light */)
|
|
5976
5921
|
return BigInt(
|
|
5977
5922
|
envOptions?.transferLimitMaxUSDT ? parseFloat(envOptions?.transferLimitMaxUSDT) : 1e3
|
|
@@ -5981,11 +5926,11 @@ var SingleForm = ({
|
|
|
5981
5926
|
const intAmount = (0, import_viem6.parseUnits)(amount, totalFee.decimals);
|
|
5982
5927
|
return balance - intAmount;
|
|
5983
5928
|
}, [balance, totalFee, feeDeduct]);
|
|
5984
|
-
(0,
|
|
5929
|
+
(0, import_react91.useEffect)(() => {
|
|
5985
5930
|
if (!errorMessage) return;
|
|
5986
5931
|
import_react_hot_toast4.toast.error(errorMessage);
|
|
5987
5932
|
}, [errorMessage]);
|
|
5988
|
-
(0,
|
|
5933
|
+
(0, import_react91.useEffect)(() => {
|
|
5989
5934
|
if (amountValue && amount !== "") return;
|
|
5990
5935
|
setAmountValue(amount);
|
|
5991
5936
|
}, [amount]);
|
|
@@ -6013,10 +5958,10 @@ var SingleForm = ({
|
|
|
6013
5958
|
setAmountValue(truncated);
|
|
6014
5959
|
dispatch(setAmount(truncated));
|
|
6015
5960
|
};
|
|
6016
|
-
const isConnected = (0,
|
|
5961
|
+
const isConnected = (0, import_react91.useMemo)(() => {
|
|
6017
5962
|
return isReady && !initialSelection.sourceSelection;
|
|
6018
5963
|
}, [isReady, initialSelection]);
|
|
6019
|
-
return /* @__PURE__ */
|
|
5964
|
+
return /* @__PURE__ */ import_react91.default.createElement("div", { className: "single-form" }, /* @__PURE__ */ import_react91.default.createElement("div", { className: "form-item" }, /* @__PURE__ */ import_react91.default.createElement("span", { className: "label" }, "Source Network:"), /* @__PURE__ */ import_react91.default.createElement("div", { className: "items" }, /* @__PURE__ */ import_react91.default.createElement(
|
|
6020
5965
|
NetworkSelector_default,
|
|
6021
5966
|
{
|
|
6022
5967
|
type: "origin",
|
|
@@ -6025,20 +5970,20 @@ var SingleForm = ({
|
|
|
6025
5970
|
setInitialSelection
|
|
6026
5971
|
}
|
|
6027
5972
|
}
|
|
6028
|
-
), /* @__PURE__ */
|
|
5973
|
+
), /* @__PURE__ */ import_react91.default.createElement(CoinDropdown_default, null))), /* @__PURE__ */ import_react91.default.createElement(
|
|
6029
5974
|
"div",
|
|
6030
5975
|
{
|
|
6031
5976
|
className: `dynamic-area ${sourceNetwork.shortName === "FIAT" /* FIAT */ ? "reverse" : "1"}`
|
|
6032
5977
|
},
|
|
6033
|
-
sourceNetwork.compatibility !== "CC" /* CC */ && /* @__PURE__ */
|
|
5978
|
+
sourceNetwork.compatibility !== "CC" /* CC */ && /* @__PURE__ */ import_react91.default.createElement(
|
|
6034
5979
|
"div",
|
|
6035
5980
|
{
|
|
6036
5981
|
className: `form-item wallet-button-item ${isConnected && "connected"}`
|
|
6037
5982
|
},
|
|
6038
|
-
/* @__PURE__ */
|
|
6039
|
-
/* @__PURE__ */
|
|
5983
|
+
/* @__PURE__ */ import_react91.default.createElement("span", { className: "label" }, "Wallet:"),
|
|
5984
|
+
/* @__PURE__ */ import_react91.default.createElement(WalletButton_default, { initialSelection: initialSelection.sourceSelection })
|
|
6040
5985
|
),
|
|
6041
|
-
mode !== "payment" /* payment */ && /* @__PURE__ */
|
|
5986
|
+
mode !== "payment" /* payment */ && /* @__PURE__ */ import_react91.default.createElement("div", { className: "form-item" }, /* @__PURE__ */ import_react91.default.createElement("span", { className: "label" }, "Target Network:"), /* @__PURE__ */ import_react91.default.createElement("div", { className: "items" }, /* @__PURE__ */ import_react91.default.createElement(
|
|
6042
5987
|
NetworkSelector_default,
|
|
6043
5988
|
{
|
|
6044
5989
|
type: "target",
|
|
@@ -6047,29 +5992,29 @@ var SingleForm = ({
|
|
|
6047
5992
|
setInitialSelection
|
|
6048
5993
|
}
|
|
6049
5994
|
}
|
|
6050
|
-
), /* @__PURE__ */
|
|
6051
|
-
), mode === "bridge" /* bridge */ && sourceNetwork.shortName !== "FIAT" /* FIAT */ ? targetNetwork.shortName === "FIAT" /* FIAT */ ? /* @__PURE__ */
|
|
5995
|
+
), /* @__PURE__ */ import_react91.default.createElement(CoinDropdown_default, { isSourceChain: false })))
|
|
5996
|
+
), mode === "bridge" /* bridge */ && sourceNetwork.shortName !== "FIAT" /* FIAT */ ? targetNetwork.shortName === "FIAT" /* FIAT */ ? /* @__PURE__ */ import_react91.default.createElement(BankInput_default, null) : /* @__PURE__ */ import_react91.default.createElement("div", { className: `form-item ${theme.colorMode}` }, /* @__PURE__ */ import_react91.default.createElement("span", { className: "label" }, "Target Address:"), /* @__PURE__ */ import_react91.default.createElement(
|
|
6052
5997
|
AddressInput_default,
|
|
6053
5998
|
{
|
|
6054
5999
|
theme: theme.colorMode,
|
|
6055
6000
|
placeholder: "Target address",
|
|
6056
6001
|
initialSelection
|
|
6057
6002
|
}
|
|
6058
|
-
)) : null, mode === "light" /* light */ && /* @__PURE__ */
|
|
6003
|
+
)) : null, mode === "light" /* light */ && /* @__PURE__ */ import_react91.default.createElement(
|
|
6059
6004
|
"div",
|
|
6060
6005
|
{
|
|
6061
6006
|
className: `form-item wallet-button-item ${!initialSelection.targetSelection && "connected"}`,
|
|
6062
6007
|
style: { display: "flex", alignItems: "center" }
|
|
6063
6008
|
},
|
|
6064
|
-
/* @__PURE__ */
|
|
6065
|
-
/* @__PURE__ */
|
|
6009
|
+
/* @__PURE__ */ import_react91.default.createElement("span", { className: "label" }, "Target Wallet:"),
|
|
6010
|
+
/* @__PURE__ */ import_react91.default.createElement(
|
|
6066
6011
|
WalletButton_default,
|
|
6067
6012
|
{
|
|
6068
6013
|
initialSelection: initialSelection.targetSelection,
|
|
6069
6014
|
placeholder: true
|
|
6070
6015
|
}
|
|
6071
6016
|
)
|
|
6072
|
-
), mode === "bridge" /* bridge */ && /* @__PURE__ */
|
|
6017
|
+
), mode === "bridge" /* bridge */ && /* @__PURE__ */ import_react91.default.createElement("div", { className: `form-item ${theme.colorMode}` }, /* @__PURE__ */ import_react91.default.createElement("span", { className: "label" }, "Amount:"), /* @__PURE__ */ import_react91.default.createElement("div", { className: `amount-label-container items ${theme.colorMode}` }, /* @__PURE__ */ import_react91.default.createElement(
|
|
6073
6018
|
"input",
|
|
6074
6019
|
{
|
|
6075
6020
|
className: `${theme.colorMode}`,
|
|
@@ -6078,7 +6023,7 @@ var SingleForm = ({
|
|
|
6078
6023
|
value: amountValue || "",
|
|
6079
6024
|
onChange: (e) => onAmountChange(e.target.value)
|
|
6080
6025
|
}
|
|
6081
|
-
), /* @__PURE__ */
|
|
6026
|
+
), /* @__PURE__ */ import_react91.default.createElement("div", { className: "max-disclaimer" }, sourceNetwork.shortName !== "CC" && /* @__PURE__ */ import_react91.default.createElement("span", { className: "max-button", onClick: onMaxClick }, "Max"), +totalFee !== -1 && /* @__PURE__ */ import_react91.default.createElement("p", { className: "fee-amount" }, "Est fees:", " ", /* @__PURE__ */ import_react91.default.createElement("span", { className: `${isLoadingFees ? "loading" : ""}` }, " ", isLoadingFees ? "" : `$ ${formatBigInt(totalFee)} USD`))))));
|
|
6082
6027
|
};
|
|
6083
6028
|
var SingleForm_default = SingleForm;
|
|
6084
6029
|
|
|
@@ -6127,11 +6072,11 @@ function useAllowance2({
|
|
|
6127
6072
|
var import_react_hot_toast5 = require("react-hot-toast");
|
|
6128
6073
|
|
|
6129
6074
|
// plugins/solana/components/SolanaWalletConnectModal.tsx
|
|
6130
|
-
var
|
|
6075
|
+
var import_react94 = __toESM(require("react"), 1);
|
|
6131
6076
|
var import_react_redux49 = require("react-redux");
|
|
6132
6077
|
|
|
6133
6078
|
// plugins/solana/components/SolanaWalletSelect.tsx
|
|
6134
|
-
var
|
|
6079
|
+
var import_react92 = __toESM(require("react"), 1);
|
|
6135
6080
|
var import_react_redux47 = require("react-redux");
|
|
6136
6081
|
var import_wallet_adapter_react7 = require("@solana/wallet-adapter-react");
|
|
6137
6082
|
var import_wallet_adapter_base = require("@solana/wallet-adapter-base");
|
|
@@ -6139,9 +6084,9 @@ var SolanaWalletSelect = () => {
|
|
|
6139
6084
|
const theme = (0, import_react_redux47.useSelector)(selectTheme);
|
|
6140
6085
|
const sourceChain = (0, import_react_redux47.useSelector)(selectSourceChain);
|
|
6141
6086
|
const dispatch = (0, import_react_redux47.useDispatch)();
|
|
6142
|
-
const sliderRef = (0,
|
|
6087
|
+
const sliderRef = (0, import_react92.useRef)();
|
|
6143
6088
|
const { wallet, wallets, select, connect, connected } = (0, import_wallet_adapter_react7.useWallet)();
|
|
6144
|
-
const [detected, undetected] = (0,
|
|
6089
|
+
const [detected, undetected] = (0, import_react92.useMemo)(() => {
|
|
6145
6090
|
const detected2 = [];
|
|
6146
6091
|
const undetected2 = [];
|
|
6147
6092
|
for (const wallet2 of wallets) {
|
|
@@ -6153,7 +6098,7 @@ var SolanaWalletSelect = () => {
|
|
|
6153
6098
|
}
|
|
6154
6099
|
return [detected2, undetected2];
|
|
6155
6100
|
}, [wallets]);
|
|
6156
|
-
(0,
|
|
6101
|
+
(0, import_react92.useEffect)(() => {
|
|
6157
6102
|
let isDown = false;
|
|
6158
6103
|
let startX;
|
|
6159
6104
|
let scrollLeft;
|
|
@@ -6179,7 +6124,7 @@ var SolanaWalletSelect = () => {
|
|
|
6179
6124
|
sliderRef.current.scrollLeft = scrollLeft - walk;
|
|
6180
6125
|
});
|
|
6181
6126
|
}, []);
|
|
6182
|
-
const handleWalletClick = (0,
|
|
6127
|
+
const handleWalletClick = (0, import_react92.useCallback)(
|
|
6183
6128
|
(walletName) => {
|
|
6184
6129
|
logger_default.debug(
|
|
6185
6130
|
"SolanaWalletSelect: handleWalletClick: walletName: ",
|
|
@@ -6189,7 +6134,7 @@ var SolanaWalletSelect = () => {
|
|
|
6189
6134
|
},
|
|
6190
6135
|
[select]
|
|
6191
6136
|
);
|
|
6192
|
-
(0,
|
|
6137
|
+
(0, import_react92.useEffect)(() => {
|
|
6193
6138
|
logger_default.debug("SolanaWalletSelect: useEffect: wallet: ", wallet);
|
|
6194
6139
|
if (!wallet) return;
|
|
6195
6140
|
if (sourceChain.shortName !== "SOL") {
|
|
@@ -6205,28 +6150,28 @@ var SolanaWalletSelect = () => {
|
|
|
6205
6150
|
}
|
|
6206
6151
|
dispatch(setSolanaConnectModal(false));
|
|
6207
6152
|
}, [wallet, sourceChain]);
|
|
6208
|
-
return /* @__PURE__ */
|
|
6153
|
+
return /* @__PURE__ */ import_react92.default.createElement("div", { className: `wallet-select` }, /* @__PURE__ */ import_react92.default.createElement("div", { className: "slide-area hide-scrollbar", ref: sliderRef }, /* @__PURE__ */ import_react92.default.createElement("div", { className: "wallet-container" }, detected.map((wallet2, index) => /* @__PURE__ */ import_react92.default.createElement(
|
|
6209
6154
|
"div",
|
|
6210
6155
|
{
|
|
6211
6156
|
className: `card-item ${theme.colorMode}`,
|
|
6212
6157
|
onClick: () => handleWalletClick(wallet2.adapter.name),
|
|
6213
6158
|
key: `${wallet2.adapter.name}-${index}`
|
|
6214
6159
|
},
|
|
6215
|
-
/* @__PURE__ */
|
|
6216
|
-
)), undetected.map((wallet2, index) => /* @__PURE__ */
|
|
6160
|
+
/* @__PURE__ */ import_react92.default.createElement("div", { className: "wallet-item" }, /* @__PURE__ */ import_react92.default.createElement("img", { src: wallet2.adapter.icon, alt: wallet2.adapter.name }), /* @__PURE__ */ import_react92.default.createElement("span", null, wallet2.adapter.name))
|
|
6161
|
+
)), undetected.map((wallet2, index) => /* @__PURE__ */ import_react92.default.createElement(
|
|
6217
6162
|
ExternalLink_default,
|
|
6218
6163
|
{
|
|
6219
6164
|
to: wallet2.adapter.url,
|
|
6220
6165
|
className: `card-item ${theme.colorMode}`,
|
|
6221
6166
|
key: `${wallet2.adapter.name}-${index}`
|
|
6222
6167
|
},
|
|
6223
|
-
/* @__PURE__ */
|
|
6168
|
+
/* @__PURE__ */ import_react92.default.createElement("div", { className: "wallet-item" }, /* @__PURE__ */ import_react92.default.createElement("img", { src: wallet2.adapter.icon, alt: wallet2.adapter.name }), /* @__PURE__ */ import_react92.default.createElement("span", null, "Install ", wallet2.adapter.name))
|
|
6224
6169
|
)))));
|
|
6225
6170
|
};
|
|
6226
6171
|
var SolanaWalletSelect_default = SolanaWalletSelect;
|
|
6227
6172
|
|
|
6228
6173
|
// plugins/solana/components/AccountDetailsModal.tsx
|
|
6229
|
-
var
|
|
6174
|
+
var import_react93 = __toESM(require("react"), 1);
|
|
6230
6175
|
var import_react_redux48 = require("react-redux");
|
|
6231
6176
|
var import_wallet_adapter_react8 = require("@solana/wallet-adapter-react");
|
|
6232
6177
|
var AccountDetailsModal = () => {
|
|
@@ -6239,7 +6184,7 @@ var AccountDetailsModal = () => {
|
|
|
6239
6184
|
const { disconnect: solanaWalletDisconnect } = (0, import_wallet_adapter_react8.useWallet)();
|
|
6240
6185
|
const { balance: solBalance } = useGetSolBalance_default();
|
|
6241
6186
|
const networkDetails = networkOptions2[0];
|
|
6242
|
-
const explorerUrl = (0,
|
|
6187
|
+
const explorerUrl = (0, import_react93.useMemo)(() => {
|
|
6243
6188
|
return `https://solscan.io/account/${walletAddress}?cluster=${networkOption === "mainnet" ? "mainnet" : "devnet"}`;
|
|
6244
6189
|
}, [walletAddress, networkOption]);
|
|
6245
6190
|
const handleDisconnect = () => {
|
|
@@ -6247,25 +6192,25 @@ var AccountDetailsModal = () => {
|
|
|
6247
6192
|
dispatch(setAccountDetailsModal(false));
|
|
6248
6193
|
};
|
|
6249
6194
|
if (sourceChain.shortName !== "SOL") return;
|
|
6250
|
-
return /* @__PURE__ */
|
|
6195
|
+
return /* @__PURE__ */ import_react93.default.createElement(
|
|
6251
6196
|
"div",
|
|
6252
6197
|
{
|
|
6253
6198
|
className: `kima-modal ${theme.colorMode} ${accountDetailsModal && "open"}`
|
|
6254
6199
|
},
|
|
6255
|
-
/* @__PURE__ */
|
|
6256
|
-
/* @__PURE__ */
|
|
6200
|
+
/* @__PURE__ */ import_react93.default.createElement("div", { className: "modal-overlay" }),
|
|
6201
|
+
/* @__PURE__ */ import_react93.default.createElement("div", { className: `modal-content-container ${theme.colorMode}` }, /* @__PURE__ */ import_react93.default.createElement("div", { className: "kima-card-header" }, /* @__PURE__ */ import_react93.default.createElement("div", { className: "topbar" }, /* @__PURE__ */ import_react93.default.createElement("div", { className: "title" }, /* @__PURE__ */ import_react93.default.createElement("h3", null, "Account Details")), /* @__PURE__ */ import_react93.default.createElement("div", { className: "control-buttons" }, /* @__PURE__ */ import_react93.default.createElement(
|
|
6257
6202
|
"button",
|
|
6258
6203
|
{
|
|
6259
6204
|
className: "cross-icon-button",
|
|
6260
6205
|
onClick: () => dispatch(setAccountDetailsModal(false))
|
|
6261
6206
|
},
|
|
6262
|
-
/* @__PURE__ */
|
|
6207
|
+
/* @__PURE__ */ import_react93.default.createElement(
|
|
6263
6208
|
Cross_default,
|
|
6264
6209
|
{
|
|
6265
6210
|
fill: theme.colorMode === "light" ? "black" : "white"
|
|
6266
6211
|
}
|
|
6267
6212
|
)
|
|
6268
|
-
)))), /* @__PURE__ */
|
|
6213
|
+
)))), /* @__PURE__ */ import_react93.default.createElement("div", { className: "modal-content" }, /* @__PURE__ */ import_react93.default.createElement("div", { className: "summary" }, networkDetails && /* @__PURE__ */ import_react93.default.createElement(networkDetails.icon, { width: 60, height: 60 }), /* @__PURE__ */ import_react93.default.createElement("div", { className: "address" }, /* @__PURE__ */ import_react93.default.createElement("h2", null, getShortenedAddress(walletAddress || "")), /* @__PURE__ */ import_react93.default.createElement(CopyButton_default, { text: walletAddress })), /* @__PURE__ */ import_react93.default.createElement("h3", null, formatterFloat.format(Number(solBalance)), " $SOL")), /* @__PURE__ */ import_react93.default.createElement(SecondaryButton_default, { className: "block-explorer" }, /* @__PURE__ */ import_react93.default.createElement(ExternalLink_default, { className: "link", to: explorerUrl }, /* @__PURE__ */ import_react93.default.createElement(Explorer_default, { fill: "#778DA3" }), /* @__PURE__ */ import_react93.default.createElement("p", null, "Block explorer"), /* @__PURE__ */ import_react93.default.createElement(ExternalUrl_default, { fill: "#778DA3" }))), /* @__PURE__ */ import_react93.default.createElement(PrimaryButton_default, { clickHandler: handleDisconnect }, "Discconect")))
|
|
6269
6214
|
);
|
|
6270
6215
|
};
|
|
6271
6216
|
var AccountDetailsModal_default = AccountDetailsModal;
|
|
@@ -6275,18 +6220,18 @@ var SolanaWalletConnectModal = () => {
|
|
|
6275
6220
|
const dispatch = (0, import_react_redux49.useDispatch)();
|
|
6276
6221
|
const theme = (0, import_react_redux49.useSelector)(selectTheme);
|
|
6277
6222
|
const connectModal = (0, import_react_redux49.useSelector)(selectSolanaConnectModal);
|
|
6278
|
-
return /* @__PURE__ */
|
|
6223
|
+
return /* @__PURE__ */ import_react94.default.createElement("div", null, /* @__PURE__ */ import_react94.default.createElement(AccountDetailsModal_default, null), /* @__PURE__ */ import_react94.default.createElement(
|
|
6279
6224
|
"div",
|
|
6280
6225
|
{
|
|
6281
6226
|
className: `kima-modal wallet-connect ${connectModal ? "open" : ""}`
|
|
6282
6227
|
},
|
|
6283
|
-
/* @__PURE__ */
|
|
6228
|
+
/* @__PURE__ */ import_react94.default.createElement("div", { className: `modal-content-container ${theme.colorMode}` }, /* @__PURE__ */ import_react94.default.createElement("div", { className: "kima-card-header" }, /* @__PURE__ */ import_react94.default.createElement("div", { className: "topbar" }, /* @__PURE__ */ import_react94.default.createElement("div", { className: "title" }, /* @__PURE__ */ import_react94.default.createElement("h3", null, "Connect Wallet")), /* @__PURE__ */ import_react94.default.createElement("div", { className: "control-buttons" }, /* @__PURE__ */ import_react94.default.createElement(
|
|
6284
6229
|
"button",
|
|
6285
6230
|
{
|
|
6286
6231
|
className: "cross-icon-button",
|
|
6287
6232
|
onClick: () => dispatch(setSolanaConnectModal(false))
|
|
6288
6233
|
},
|
|
6289
|
-
/* @__PURE__ */
|
|
6234
|
+
/* @__PURE__ */ import_react94.default.createElement(
|
|
6290
6235
|
Cross_default,
|
|
6291
6236
|
{
|
|
6292
6237
|
width: 30,
|
|
@@ -6294,17 +6239,17 @@ var SolanaWalletConnectModal = () => {
|
|
|
6294
6239
|
fill: theme.colorMode === "light" ? "black" : "white"
|
|
6295
6240
|
}
|
|
6296
6241
|
)
|
|
6297
|
-
)))), /* @__PURE__ */
|
|
6242
|
+
)))), /* @__PURE__ */ import_react94.default.createElement("div", { className: "modal-content" }, /* @__PURE__ */ import_react94.default.createElement(SolanaWalletSelect_default, null)))
|
|
6298
6243
|
));
|
|
6299
6244
|
};
|
|
6300
6245
|
var SolanaWalletConnectModal_default = SolanaWalletConnectModal;
|
|
6301
6246
|
|
|
6302
6247
|
// plugins/tron/components/TronWalletConnectModal.tsx
|
|
6303
|
-
var
|
|
6248
|
+
var import_react97 = __toESM(require("react"), 1);
|
|
6304
6249
|
var import_react_redux52 = require("react-redux");
|
|
6305
6250
|
|
|
6306
6251
|
// plugins/tron/components/AccountDetailsModal.tsx
|
|
6307
|
-
var
|
|
6252
|
+
var import_react95 = __toESM(require("react"), 1);
|
|
6308
6253
|
var import_react_redux50 = require("react-redux");
|
|
6309
6254
|
var import_tronwallet_adapter_react_hooks7 = require("@tronweb3/tronwallet-adapter-react-hooks");
|
|
6310
6255
|
var AccountDetailsModal2 = () => {
|
|
@@ -6317,11 +6262,11 @@ var AccountDetailsModal2 = () => {
|
|
|
6317
6262
|
const { disconnect: tronWalletDisconnect } = (0, import_tronwallet_adapter_react_hooks7.useWallet)();
|
|
6318
6263
|
const { balance: tronBalance } = useGetTrxBalance_default();
|
|
6319
6264
|
const selectedNetwork = (0, import_react_redux50.useSelector)(selectSourceChain);
|
|
6320
|
-
const networkDetails = (0,
|
|
6265
|
+
const networkDetails = (0, import_react95.useMemo)(
|
|
6321
6266
|
() => networkOptions.find(({ id }) => id === selectedNetwork.shortName),
|
|
6322
6267
|
[selectedNetwork]
|
|
6323
6268
|
);
|
|
6324
|
-
const explorerUrl = (0,
|
|
6269
|
+
const explorerUrl = (0, import_react95.useMemo)(() => {
|
|
6325
6270
|
return `https://${networkOption === "testnet" && "nile."}tronscan.io/#/address/${connectedAddress}`;
|
|
6326
6271
|
}, [connectedAddress, networkOption]);
|
|
6327
6272
|
const handleDisconnect = () => {
|
|
@@ -6329,37 +6274,37 @@ var AccountDetailsModal2 = () => {
|
|
|
6329
6274
|
dispatch(setAccountDetailsModal(false));
|
|
6330
6275
|
};
|
|
6331
6276
|
if (sourcheChain.shortName !== "TRX") return;
|
|
6332
|
-
return /* @__PURE__ */
|
|
6277
|
+
return /* @__PURE__ */ import_react95.default.createElement(
|
|
6333
6278
|
"div",
|
|
6334
6279
|
{
|
|
6335
6280
|
className: `kima-modal ${theme.colorMode} ${accountDetailsModal && "open"}`
|
|
6336
6281
|
},
|
|
6337
|
-
/* @__PURE__ */
|
|
6338
|
-
/* @__PURE__ */
|
|
6282
|
+
/* @__PURE__ */ import_react95.default.createElement("div", { className: "modal-overlay" }),
|
|
6283
|
+
/* @__PURE__ */ import_react95.default.createElement("div", { className: `modal-content-container ${theme.colorMode}` }, /* @__PURE__ */ import_react95.default.createElement("div", { className: "kima-card-header" }, /* @__PURE__ */ import_react95.default.createElement("div", { className: "topbar" }, /* @__PURE__ */ import_react95.default.createElement("div", { className: "title" }, /* @__PURE__ */ import_react95.default.createElement("h3", null, "Account Details")), /* @__PURE__ */ import_react95.default.createElement("div", { className: "control-buttons" }, /* @__PURE__ */ import_react95.default.createElement(
|
|
6339
6284
|
"button",
|
|
6340
6285
|
{
|
|
6341
6286
|
className: "cross-icon-button",
|
|
6342
6287
|
onClick: () => dispatch(setAccountDetailsModal(false))
|
|
6343
6288
|
},
|
|
6344
|
-
/* @__PURE__ */
|
|
6289
|
+
/* @__PURE__ */ import_react95.default.createElement(
|
|
6345
6290
|
Cross_default,
|
|
6346
6291
|
{
|
|
6347
6292
|
fill: theme.colorMode === "light" ? "black" : "white"
|
|
6348
6293
|
}
|
|
6349
6294
|
)
|
|
6350
|
-
)))), /* @__PURE__ */
|
|
6295
|
+
)))), /* @__PURE__ */ import_react95.default.createElement("div", { className: "modal-content" }, /* @__PURE__ */ import_react95.default.createElement("div", { className: "summary" }, networkDetails && /* @__PURE__ */ import_react95.default.createElement(networkDetails.icon, { width: 60, height: 60 }), /* @__PURE__ */ import_react95.default.createElement("div", { className: "address" }, /* @__PURE__ */ import_react95.default.createElement("h2", null, getShortenedAddress(connectedAddress || "")), /* @__PURE__ */ import_react95.default.createElement(CopyButton_default, { text: connectedAddress })), /* @__PURE__ */ import_react95.default.createElement("h3", null, formatterFloat.format(Number(tronBalance)), " ", selectedNetwork.shortName)), /* @__PURE__ */ import_react95.default.createElement(SecondaryButton_default, { className: "block-explorer" }, /* @__PURE__ */ import_react95.default.createElement(ExternalLink_default, { className: "link", to: explorerUrl }, /* @__PURE__ */ import_react95.default.createElement(Explorer_default, { fill: "#778DA3" }), /* @__PURE__ */ import_react95.default.createElement("p", null, "Block explorer"), /* @__PURE__ */ import_react95.default.createElement(ExternalUrl_default, { fill: "#778DA3" }))), /* @__PURE__ */ import_react95.default.createElement(PrimaryButton_default, { clickHandler: handleDisconnect }, "Disconnect")))
|
|
6351
6296
|
);
|
|
6352
6297
|
};
|
|
6353
6298
|
var AccountDetailsModal_default2 = AccountDetailsModal2;
|
|
6354
6299
|
|
|
6355
6300
|
// plugins/tron/components/TronWalletSelect.tsx
|
|
6356
|
-
var
|
|
6301
|
+
var import_react96 = __toESM(require("react"), 1);
|
|
6357
6302
|
var import_react_redux51 = require("react-redux");
|
|
6358
6303
|
var import_tronwallet_adapter_react_hooks8 = require("@tronweb3/tronwallet-adapter-react-hooks");
|
|
6359
6304
|
var import_tronwallet_abstract_adapter2 = require("@tronweb3/tronwallet-abstract-adapter");
|
|
6360
6305
|
var TronWalletSelect = () => {
|
|
6361
6306
|
const theme = (0, import_react_redux51.useSelector)(selectTheme);
|
|
6362
|
-
const sliderRef = (0,
|
|
6307
|
+
const sliderRef = (0, import_react96.useRef)();
|
|
6363
6308
|
const dispatch = (0, import_react_redux51.useDispatch)();
|
|
6364
6309
|
const {
|
|
6365
6310
|
wallets,
|
|
@@ -6368,7 +6313,7 @@ var TronWalletSelect = () => {
|
|
|
6368
6313
|
connect,
|
|
6369
6314
|
connected
|
|
6370
6315
|
} = (0, import_tronwallet_adapter_react_hooks8.useWallet)();
|
|
6371
|
-
const [detected, undetected] = (0,
|
|
6316
|
+
const [detected, undetected] = (0, import_react96.useMemo)(() => {
|
|
6372
6317
|
const detected2 = [];
|
|
6373
6318
|
const undetected2 = [];
|
|
6374
6319
|
for (const wallet of wallets) {
|
|
@@ -6380,7 +6325,7 @@ var TronWalletSelect = () => {
|
|
|
6380
6325
|
}
|
|
6381
6326
|
return [detected2, undetected2];
|
|
6382
6327
|
}, [wallets]);
|
|
6383
|
-
(0,
|
|
6328
|
+
(0, import_react96.useEffect)(() => {
|
|
6384
6329
|
let isDown = false;
|
|
6385
6330
|
let startX;
|
|
6386
6331
|
let scrollLeft;
|
|
@@ -6406,28 +6351,28 @@ var TronWalletSelect = () => {
|
|
|
6406
6351
|
sliderRef.current.scrollLeft = scrollLeft - walk;
|
|
6407
6352
|
});
|
|
6408
6353
|
}, []);
|
|
6409
|
-
(0,
|
|
6354
|
+
(0, import_react96.useEffect)(() => {
|
|
6410
6355
|
connected && dispatch(setTronConnectModal(false));
|
|
6411
6356
|
}, [connected]);
|
|
6412
6357
|
const connectWallet = async (walletName) => {
|
|
6413
6358
|
currentWallet?.adapter.name === walletName ? await connect() : select(walletName);
|
|
6414
6359
|
};
|
|
6415
|
-
return /* @__PURE__ */
|
|
6360
|
+
return /* @__PURE__ */ import_react96.default.createElement("div", { className: `wallet-select` }, /* @__PURE__ */ import_react96.default.createElement("div", { className: "slide-area hide-scrollbar", ref: sliderRef }, /* @__PURE__ */ import_react96.default.createElement("div", { className: "wallet-container" }, detected.map((wallet, index) => /* @__PURE__ */ import_react96.default.createElement(
|
|
6416
6361
|
"div",
|
|
6417
6362
|
{
|
|
6418
6363
|
className: `card-item ${theme.colorMode}`,
|
|
6419
6364
|
onClick: () => connectWallet(wallet.adapter.name),
|
|
6420
6365
|
key: `${wallet.adapter.name}-${index}`
|
|
6421
6366
|
},
|
|
6422
|
-
/* @__PURE__ */
|
|
6423
|
-
)), undetected.map((wallet, index) => /* @__PURE__ */
|
|
6367
|
+
/* @__PURE__ */ import_react96.default.createElement("div", { className: "wallet-item" }, /* @__PURE__ */ import_react96.default.createElement("img", { src: wallet.adapter.icon, alt: wallet.adapter.name }), /* @__PURE__ */ import_react96.default.createElement("span", null, wallet.adapter.name))
|
|
6368
|
+
)), undetected.map((wallet, index) => /* @__PURE__ */ import_react96.default.createElement(
|
|
6424
6369
|
ExternalLink_default,
|
|
6425
6370
|
{
|
|
6426
6371
|
to: wallet.adapter.url,
|
|
6427
6372
|
className: `card-item ${theme.colorMode}`,
|
|
6428
6373
|
key: `${wallet.adapter.name}-${index}`
|
|
6429
6374
|
},
|
|
6430
|
-
/* @__PURE__ */
|
|
6375
|
+
/* @__PURE__ */ import_react96.default.createElement("div", { className: "wallet-item" }, /* @__PURE__ */ import_react96.default.createElement("img", { src: wallet.adapter.icon, alt: wallet.adapter.name }), /* @__PURE__ */ import_react96.default.createElement("span", null, "Install ", wallet.adapter.name))
|
|
6431
6376
|
)))));
|
|
6432
6377
|
};
|
|
6433
6378
|
var TronWalletSelect_default = TronWalletSelect;
|
|
@@ -6437,31 +6382,31 @@ var TronWalletConnectModal = () => {
|
|
|
6437
6382
|
const dispatch = (0, import_react_redux52.useDispatch)();
|
|
6438
6383
|
const theme = (0, import_react_redux52.useSelector)(selectTheme);
|
|
6439
6384
|
const connectModal = (0, import_react_redux52.useSelector)(selectTronConnectModal);
|
|
6440
|
-
return /* @__PURE__ */
|
|
6385
|
+
return /* @__PURE__ */ import_react97.default.createElement("div", null, /* @__PURE__ */ import_react97.default.createElement(AccountDetailsModal_default2, null), /* @__PURE__ */ import_react97.default.createElement(
|
|
6441
6386
|
"div",
|
|
6442
6387
|
{
|
|
6443
6388
|
className: `kima-modal wallet-connect ${theme.colorMode} ${connectModal ? "open" : ""}`
|
|
6444
6389
|
},
|
|
6445
|
-
/* @__PURE__ */
|
|
6446
|
-
/* @__PURE__ */
|
|
6390
|
+
/* @__PURE__ */ import_react97.default.createElement("div", { className: "modal-overlay" }),
|
|
6391
|
+
/* @__PURE__ */ import_react97.default.createElement("div", { className: `modal-content-container ${theme.colorMode}` }, /* @__PURE__ */ import_react97.default.createElement("div", { className: "kima-card-header" }, /* @__PURE__ */ import_react97.default.createElement("div", { className: "topbar" }, /* @__PURE__ */ import_react97.default.createElement("div", { className: "title" }, /* @__PURE__ */ import_react97.default.createElement("h3", null, "Connect Wallet")), /* @__PURE__ */ import_react97.default.createElement("div", { className: "control-buttons" }, /* @__PURE__ */ import_react97.default.createElement(
|
|
6447
6392
|
"button",
|
|
6448
6393
|
{
|
|
6449
6394
|
className: "icon-button",
|
|
6450
6395
|
onClick: () => dispatch(setTronConnectModal(false))
|
|
6451
6396
|
},
|
|
6452
|
-
/* @__PURE__ */
|
|
6397
|
+
/* @__PURE__ */ import_react97.default.createElement(
|
|
6453
6398
|
Cross_default,
|
|
6454
6399
|
{
|
|
6455
6400
|
fill: theme.colorMode === "light" ? "black" : "white"
|
|
6456
6401
|
}
|
|
6457
6402
|
)
|
|
6458
|
-
)))), /* @__PURE__ */
|
|
6403
|
+
)))), /* @__PURE__ */ import_react97.default.createElement("div", { className: "modal-content" }, /* @__PURE__ */ import_react97.default.createElement(TronWalletSelect_default, null)))
|
|
6459
6404
|
));
|
|
6460
6405
|
};
|
|
6461
6406
|
var TronWalletConnectModal_default = TronWalletConnectModal;
|
|
6462
6407
|
|
|
6463
6408
|
// src/hooks/useValidateTransaction.tsx
|
|
6464
|
-
var
|
|
6409
|
+
var import_react98 = require("react");
|
|
6465
6410
|
var import_viem7 = require("viem");
|
|
6466
6411
|
var import_react_redux53 = require("react-redux");
|
|
6467
6412
|
var import_loglevel2 = __toESM(require("loglevel"), 1);
|
|
@@ -6490,7 +6435,7 @@ var useValidateTransaction = (inputs) => {
|
|
|
6490
6435
|
const { data: envOptions } = useGetEnvOptions({ kimaBackendUrl });
|
|
6491
6436
|
const mode = (0, import_react_redux53.useSelector)(selectMode);
|
|
6492
6437
|
const networkOption = (0, import_react_redux53.useSelector)(selectNetworkOption);
|
|
6493
|
-
const maxValue = (0,
|
|
6438
|
+
const maxValue = (0, import_react98.useMemo)(() => {
|
|
6494
6439
|
import_loglevel2.default.debug("useValidateTransaction: maxValue: ", inputs);
|
|
6495
6440
|
if (!balance) return BigInt(0);
|
|
6496
6441
|
if (totalFee <= BigInt(0)) return balance;
|
|
@@ -6607,7 +6552,7 @@ var useValidateTransaction_default = useValidateTransaction;
|
|
|
6607
6552
|
// src/hooks/useSubmitTransaction.tsx
|
|
6608
6553
|
var import_react_redux54 = require("react-redux");
|
|
6609
6554
|
var import_react_query16 = require("@tanstack/react-query");
|
|
6610
|
-
var
|
|
6555
|
+
var import_react99 = require("react");
|
|
6611
6556
|
var useSubmitTransaction = () => {
|
|
6612
6557
|
const dispatch = (0, import_react_redux54.useDispatch)();
|
|
6613
6558
|
const backendUrl = (0, import_react_redux54.useSelector)(selectBackendUrl);
|
|
@@ -6616,7 +6561,8 @@ var useSubmitTransaction = () => {
|
|
|
6616
6561
|
const feeDeduct = (0, import_react_redux54.useSelector)(selectFeeDeduct);
|
|
6617
6562
|
const txValues = feeDeduct ? transactionValues.feeFromTarget : transactionValues.feeFromOrigin;
|
|
6618
6563
|
const ccTransactionIdSeed = (0, import_react_redux54.useSelector)(selectCCTransactionIdSeed);
|
|
6619
|
-
const
|
|
6564
|
+
const submitted = (0, import_react_redux54.useSelector)(selectSubmitted);
|
|
6565
|
+
const [isSubmitting, setIsSubmitting] = (0, import_react99.useState)(false);
|
|
6620
6566
|
const mutation = (0, import_react_query16.useMutation)({
|
|
6621
6567
|
mutationFn: async (signature) => {
|
|
6622
6568
|
setIsSubmitting(true);
|
|
@@ -6672,11 +6618,11 @@ var useSubmitTransaction = () => {
|
|
|
6672
6618
|
},
|
|
6673
6619
|
retry: (failureCount, error) => {
|
|
6674
6620
|
console.log("cc retry", failureCount, error, mutation.isSuccess);
|
|
6675
|
-
if (mutation.isSuccess) {
|
|
6621
|
+
if (mutation.isSuccess || submitted) {
|
|
6676
6622
|
dispatch(setCCTransactionRetrying(false));
|
|
6677
6623
|
return false;
|
|
6678
6624
|
}
|
|
6679
|
-
const shouldRetry = transactionValues.originChain === "CC" && failureCount <
|
|
6625
|
+
const shouldRetry = transactionValues.originChain === "CC" && failureCount < 10;
|
|
6680
6626
|
if (shouldRetry) {
|
|
6681
6627
|
dispatch(setCCTransactionRetrying(true));
|
|
6682
6628
|
dispatch(setCCTransactionStatus("error-generic"));
|
|
@@ -6771,7 +6717,7 @@ function useDisconnectWallet5() {
|
|
|
6771
6717
|
}
|
|
6772
6718
|
|
|
6773
6719
|
// src/components/reusable/WarningModal.tsx
|
|
6774
|
-
var
|
|
6720
|
+
var import_react100 = __toESM(require("react"), 1);
|
|
6775
6721
|
var WarningModal = ({
|
|
6776
6722
|
message,
|
|
6777
6723
|
cancelButtonText = "Cancel",
|
|
@@ -6779,14 +6725,14 @@ var WarningModal = ({
|
|
|
6779
6725
|
onAcknowledge,
|
|
6780
6726
|
onCancel
|
|
6781
6727
|
}) => {
|
|
6782
|
-
return /* @__PURE__ */
|
|
6728
|
+
return /* @__PURE__ */ import_react100.default.createElement("div", { className: "warning-modal-overlay" }, /* @__PURE__ */ import_react100.default.createElement("div", { className: "warning-modal" }, /* @__PURE__ */ import_react100.default.createElement("h3", null, "Warning"), /* @__PURE__ */ import_react100.default.createElement("p", null, message), /* @__PURE__ */ import_react100.default.createElement("div", { className: "warning-modal-buttons" }, /* @__PURE__ */ import_react100.default.createElement(
|
|
6783
6729
|
SecondaryButton_default,
|
|
6784
6730
|
{
|
|
6785
6731
|
className: "warning-modal-cancel",
|
|
6786
6732
|
clickHandler: onCancel
|
|
6787
6733
|
},
|
|
6788
6734
|
cancelButtonText
|
|
6789
|
-
), /* @__PURE__ */
|
|
6735
|
+
), /* @__PURE__ */ import_react100.default.createElement(
|
|
6790
6736
|
PrimaryButton_default,
|
|
6791
6737
|
{
|
|
6792
6738
|
className: "warning-modal-acknowledge",
|
|
@@ -6798,7 +6744,7 @@ var WarningModal = ({
|
|
|
6798
6744
|
var WarningModal_default = WarningModal;
|
|
6799
6745
|
|
|
6800
6746
|
// src/components/reusable/CCWidget.tsx
|
|
6801
|
-
var
|
|
6747
|
+
var import_react101 = __toESM(require("react"), 1);
|
|
6802
6748
|
var import_react_redux55 = require("react-redux");
|
|
6803
6749
|
var import_uuid = require("uuid");
|
|
6804
6750
|
|
|
@@ -6833,8 +6779,9 @@ var CCWidget = ({ submitCallback }) => {
|
|
|
6833
6779
|
const ccTransactionStatus = (0, import_react_redux55.useSelector)(selectCCTransactionStatus);
|
|
6834
6780
|
const networkOption = (0, import_react_redux55.useSelector)(selectNetworkOption);
|
|
6835
6781
|
const { transactionValues } = (0, import_react_redux55.useSelector)(selectServiceFee);
|
|
6836
|
-
const randomUserIdRef = (0,
|
|
6837
|
-
const ccTransactionIdSeedRef = (0,
|
|
6782
|
+
const randomUserIdRef = (0, import_react101.useRef)((0, import_uuid.v4)());
|
|
6783
|
+
const ccTransactionIdSeedRef = (0, import_react101.useRef)((0, import_uuid.v4)());
|
|
6784
|
+
const ccTransactionSubmittedRef = (0, import_react101.useRef)(false);
|
|
6838
6785
|
const { data: envOptions, isLoading: isEnvLoading } = useGetEnvOptions({
|
|
6839
6786
|
kimaBackendUrl: backendUrl
|
|
6840
6787
|
});
|
|
@@ -6844,30 +6791,33 @@ var CCWidget = ({ submitCallback }) => {
|
|
|
6844
6791
|
isLoading: isTransactionIdLoading,
|
|
6845
6792
|
error
|
|
6846
6793
|
} = useCCTransactionId(backendUrl, ccTransactionIdSeedRef.current);
|
|
6847
|
-
(0,
|
|
6794
|
+
(0, import_react101.useEffect)(() => {
|
|
6848
6795
|
dispatch(setCCTransactionIdSeed(ccTransactionIdSeedRef.current));
|
|
6849
6796
|
dispatch(setCCTransactionId(data?.transactionId));
|
|
6850
6797
|
}, [dispatch, data, isTransactionIdLoading]);
|
|
6851
6798
|
const txValues = feeDeduct ? transactionValues.feeFromTarget : transactionValues.feeFromOrigin;
|
|
6852
|
-
const allowanceAmount = (0,
|
|
6799
|
+
const allowanceAmount = (0, import_react101.useMemo)(
|
|
6853
6800
|
() => formatBigInt(txValues.allowanceAmount),
|
|
6854
6801
|
[txValues]
|
|
6855
6802
|
);
|
|
6856
|
-
const [isLoading, setIsLoading] = (0,
|
|
6857
|
-
const baseUrl = (0,
|
|
6803
|
+
const [isLoading, setIsLoading] = (0, import_react101.useState)(true);
|
|
6804
|
+
const baseUrl = (0, import_react101.useMemo)(
|
|
6858
6805
|
() => `https://widget${networkOption === "testnet" /* testnet */ ? "-sandbox" : ""}.depasify.com`,
|
|
6859
6806
|
[networkOption]
|
|
6860
6807
|
);
|
|
6861
|
-
(0,
|
|
6808
|
+
(0, import_react101.useEffect)(() => {
|
|
6862
6809
|
const handleMessage = (event) => {
|
|
6863
6810
|
if (event.origin !== baseUrl) {
|
|
6864
6811
|
return;
|
|
6865
6812
|
}
|
|
6866
6813
|
logger_default.info("postMessage: new message: ", event);
|
|
6867
6814
|
if (event.data.type === "isCompleted") {
|
|
6868
|
-
console.log("cc widget isCompleted");
|
|
6815
|
+
console.log("cc widget isCompleted", ccTransactionSubmittedRef.current);
|
|
6869
6816
|
dispatch(setCCTransactionStatus("success"));
|
|
6870
|
-
|
|
6817
|
+
if (!ccTransactionSubmittedRef.current) {
|
|
6818
|
+
ccTransactionSubmittedRef.current = true;
|
|
6819
|
+
submitCallback();
|
|
6820
|
+
}
|
|
6871
6821
|
}
|
|
6872
6822
|
if (event.data.type === "isFailed") {
|
|
6873
6823
|
dispatch(setCCTransactionStatus("failed"));
|
|
@@ -6876,10 +6826,10 @@ var CCWidget = ({ submitCallback }) => {
|
|
|
6876
6826
|
window.addEventListener("message", handleMessage);
|
|
6877
6827
|
return () => window.removeEventListener("message", handleMessage);
|
|
6878
6828
|
}, []);
|
|
6879
|
-
(0,
|
|
6829
|
+
(0, import_react101.useEffect)(() => {
|
|
6880
6830
|
if (error) dispatch(setCCTransactionStatus("error-id"));
|
|
6881
6831
|
}, [dispatch, error]);
|
|
6882
|
-
return /* @__PURE__ */
|
|
6832
|
+
return /* @__PURE__ */ import_react101.default.createElement("div", { className: `cc-widget ${isLoading ? "loading" : ""}` }, (isLoading || isTransactionIdLoading || isEnvLoading || ccTransactionStatus === "success") && /* @__PURE__ */ import_react101.default.createElement("div", { className: "cc-widget-loader" }, /* @__PURE__ */ import_react101.default.createElement(ring_default, { width: 50, height: 50, fill: "#86b8ce" })), /* @__PURE__ */ import_react101.default.createElement(
|
|
6883
6833
|
"iframe",
|
|
6884
6834
|
{
|
|
6885
6835
|
width: isLoading || isTransactionIdLoading || ccTransactionStatus === "success" || error ? 0 : "100%",
|
|
@@ -6908,11 +6858,11 @@ var TransferWidget = ({
|
|
|
6908
6858
|
paymentTitleOption
|
|
6909
6859
|
}) => {
|
|
6910
6860
|
const dispatch = (0, import_react_redux56.useDispatch)();
|
|
6911
|
-
const mainRef = (0,
|
|
6912
|
-
const [signature, setSignature2] = (0,
|
|
6913
|
-
const [formStep, setFormStep] = (0,
|
|
6914
|
-
const [warningModalOpen, setWarningModalOpen] = (0,
|
|
6915
|
-
const [resetModalOpen, setResetModalOpen] = (0,
|
|
6861
|
+
const mainRef = (0, import_react102.useRef)(null);
|
|
6862
|
+
const [signature, setSignature2] = (0, import_react102.useState)("");
|
|
6863
|
+
const [formStep, setFormStep] = (0, import_react102.useState)(0);
|
|
6864
|
+
const [warningModalOpen, setWarningModalOpen] = (0, import_react102.useState)(null);
|
|
6865
|
+
const [resetModalOpen, setResetModalOpen] = (0, import_react102.useState)(false);
|
|
6916
6866
|
const networkOption = (0, import_react_redux56.useSelector)(selectNetworkOption);
|
|
6917
6867
|
const dAppOption = (0, import_react_redux56.useSelector)(selectDappOption);
|
|
6918
6868
|
const mode = (0, import_react_redux56.useSelector)(selectMode);
|
|
@@ -6931,11 +6881,11 @@ var TransferWidget = ({
|
|
|
6931
6881
|
const feeDeduct = (0, import_react_redux56.useSelector)(selectFeeDeduct);
|
|
6932
6882
|
const txValues = feeDeduct ? transactionValues.feeFromTarget : transactionValues.feeFromOrigin;
|
|
6933
6883
|
const { keplrHandler, closeHandler } = useKimaContext();
|
|
6934
|
-
const [isCancellingApprove, setCancellingApprove] = (0,
|
|
6935
|
-
const [isApproving, setApproving] = (0,
|
|
6936
|
-
const [isSigning, setSigning] = (0,
|
|
6937
|
-
const [feeOptionDisabled, setFeeOptionDisabled] = (0,
|
|
6938
|
-
const [initialSelection, setInitialSelection] = (0,
|
|
6884
|
+
const [isCancellingApprove, setCancellingApprove] = (0, import_react102.useState)(false);
|
|
6885
|
+
const [isApproving, setApproving] = (0, import_react102.useState)(false);
|
|
6886
|
+
const [isSigning, setSigning] = (0, import_react102.useState)(false);
|
|
6887
|
+
const [feeOptionDisabled, setFeeOptionDisabled] = (0, import_react102.useState)(false);
|
|
6888
|
+
const [initialSelection, setInitialSelection] = (0, import_react102.useState)({
|
|
6939
6889
|
sourceSelection: true,
|
|
6940
6890
|
targetSelection: true
|
|
6941
6891
|
});
|
|
@@ -6997,7 +6947,7 @@ var TransferWidget = ({
|
|
|
6997
6947
|
targetSymbol: targetCurrency,
|
|
6998
6948
|
backendUrl
|
|
6999
6949
|
});
|
|
7000
|
-
(0,
|
|
6950
|
+
(0, import_react102.useEffect)(() => {
|
|
7001
6951
|
if (fees) {
|
|
7002
6952
|
dispatch(setServiceFee(fees));
|
|
7003
6953
|
}
|
|
@@ -7009,7 +6959,7 @@ var TransferWidget = ({
|
|
|
7009
6959
|
}
|
|
7010
6960
|
}, [fees, mode, transactionOption, dispatch]);
|
|
7011
6961
|
const { submitTransaction, isSubmitting } = useSubmitTransaction_default();
|
|
7012
|
-
const isBackButtonEnabled = (0,
|
|
6962
|
+
const isBackButtonEnabled = (0, import_react102.useMemo)(() => {
|
|
7013
6963
|
if (formStep !== 0) {
|
|
7014
6964
|
if (sourceChain.shortName === "CC") {
|
|
7015
6965
|
return ccTransactionStatus === "idle" || ccTransactionStatus === "failed";
|
|
@@ -7018,25 +6968,25 @@ var TransferWidget = ({
|
|
|
7018
6968
|
}
|
|
7019
6969
|
return false;
|
|
7020
6970
|
}, [ccTransactionStatus, sourceChain, formStep]);
|
|
7021
|
-
const isSubmitButtonEnabled = (0,
|
|
6971
|
+
const isSubmitButtonEnabled = (0, import_react102.useMemo)(() => {
|
|
7022
6972
|
if (submitted) return false;
|
|
7023
6973
|
if (sourceChain.shortName === "CC") {
|
|
7024
6974
|
return ccTransactionStatus === "idle";
|
|
7025
6975
|
}
|
|
7026
6976
|
return true;
|
|
7027
6977
|
}, [sourceChain, ccTransactionStatus]);
|
|
7028
|
-
const submit = (0,
|
|
6978
|
+
const submit = (0, import_react102.useCallback)(async () => {
|
|
7029
6979
|
try {
|
|
7030
6980
|
await submitTransaction(signature);
|
|
7031
6981
|
} catch (err) {
|
|
7032
|
-
import_react_hot_toast5.toast.error("Failed to submit transaction", { icon: /* @__PURE__ */
|
|
6982
|
+
import_react_hot_toast5.toast.error("Failed to submit transaction", { icon: /* @__PURE__ */ import_react102.default.createElement(Error_default, null) });
|
|
7033
6983
|
dispatch(setCCTransactionStatus("error-generic"));
|
|
7034
6984
|
}
|
|
7035
6985
|
}, [signature, submitTransaction]);
|
|
7036
6986
|
const handleSubmit = async () => {
|
|
7037
6987
|
const { error: error2, message: validationMessage } = validate(true);
|
|
7038
6988
|
if (error2 === "ValidationError" /* Error */) {
|
|
7039
|
-
return import_react_hot_toast5.toast.error(validationMessage, { icon: /* @__PURE__ */
|
|
6989
|
+
return import_react_hot_toast5.toast.error(validationMessage, { icon: /* @__PURE__ */ import_react102.default.createElement(Error_default, null) });
|
|
7040
6990
|
}
|
|
7041
6991
|
if (sourceChain.shortName === "CC") {
|
|
7042
6992
|
dispatch(setCCTransactionStatus("initialized"));
|
|
@@ -7085,7 +7035,7 @@ var TransferWidget = ({
|
|
|
7085
7035
|
if (error2 !== "ValidationError" /* Error */ && formStep > 0) {
|
|
7086
7036
|
return handleSubmit();
|
|
7087
7037
|
}
|
|
7088
|
-
import_react_hot_toast5.toast.error(validationMessage, { icon: /* @__PURE__ */
|
|
7038
|
+
import_react_hot_toast5.toast.error(validationMessage, { icon: /* @__PURE__ */ import_react102.default.createElement(Error_default, null) });
|
|
7089
7039
|
mainRef.current?.click();
|
|
7090
7040
|
};
|
|
7091
7041
|
const onBack = () => {
|
|
@@ -7160,7 +7110,7 @@ var TransferWidget = ({
|
|
|
7160
7110
|
}
|
|
7161
7111
|
await disconnectWallet();
|
|
7162
7112
|
};
|
|
7163
|
-
return /* @__PURE__ */
|
|
7113
|
+
return /* @__PURE__ */ import_react102.default.createElement(
|
|
7164
7114
|
"div",
|
|
7165
7115
|
{
|
|
7166
7116
|
className: `kima-card ${theme.colorMode}`,
|
|
@@ -7168,7 +7118,7 @@ var TransferWidget = ({
|
|
|
7168
7118
|
background: theme.colorMode === "light" /* light */ ? theme.backgroundColorLight : theme.backgroundColorDark
|
|
7169
7119
|
}
|
|
7170
7120
|
},
|
|
7171
|
-
resetModalOpen && /* @__PURE__ */
|
|
7121
|
+
resetModalOpen && /* @__PURE__ */ import_react102.default.createElement(
|
|
7172
7122
|
WarningModal_default,
|
|
7173
7123
|
{
|
|
7174
7124
|
message: "Are you sure you want to reset the widget?",
|
|
@@ -7180,7 +7130,7 @@ var TransferWidget = ({
|
|
|
7180
7130
|
onCancel: () => setResetModalOpen(false)
|
|
7181
7131
|
}
|
|
7182
7132
|
),
|
|
7183
|
-
warningModalOpen && /* @__PURE__ */
|
|
7133
|
+
warningModalOpen && /* @__PURE__ */ import_react102.default.createElement(
|
|
7184
7134
|
WarningModal_default,
|
|
7185
7135
|
{
|
|
7186
7136
|
message: warningModalOpen.message,
|
|
@@ -7194,14 +7144,14 @@ var TransferWidget = ({
|
|
|
7194
7144
|
}
|
|
7195
7145
|
}
|
|
7196
7146
|
),
|
|
7197
|
-
mode === "payment" /* payment */ && !transactionOption && /* @__PURE__ */
|
|
7198
|
-
/* @__PURE__ */
|
|
7147
|
+
mode === "payment" /* payment */ && !transactionOption && /* @__PURE__ */ import_react102.default.createElement("h2", { className: "invalid-option-banner" }, "We're unable to process your payment. Please ensure the necessary transaction details are provided. Contact support if the issue persists."),
|
|
7148
|
+
/* @__PURE__ */ import_react102.default.createElement("div", { className: "transfer-card" }, /* @__PURE__ */ import_react102.default.createElement("div", { className: "kima-card-header" }, /* @__PURE__ */ import_react102.default.createElement("div", { className: "topbar" }, /* @__PURE__ */ import_react102.default.createElement("div", { className: "title" }, /* @__PURE__ */ import_react102.default.createElement("h3", { style: { marginRight: "5px" } }, formStep === 0 ? titleOption?.initialTitle ? titleOption.initialTitle : mode === "payment" /* payment */ ? "New Purchase" : "New Transfer" : titleOption?.confirmTitle ? titleOption.confirmTitle : mode === "payment" /* payment */ ? "Confirm Purchase" : "Transfer Details")), /* @__PURE__ */ import_react102.default.createElement("div", { className: "control-buttons" }, pendingTxs > 0 ? /* @__PURE__ */ import_react102.default.createElement(TxButton_default, { theme }) : null, /* @__PURE__ */ import_react102.default.createElement(
|
|
7199
7149
|
ExternalLink_default,
|
|
7200
7150
|
{
|
|
7201
7151
|
to: helpURL ? helpURL : networkOption === "testnet" /* testnet */ ? "https://docs.kima.network/kima-network/try-kima-with-the-demo-app" : "https://support.kima.network"
|
|
7202
7152
|
},
|
|
7203
|
-
/* @__PURE__ */
|
|
7204
|
-
), sourceChain.shortName === "CC" && formStep > 0 && /* @__PURE__ */
|
|
7153
|
+
/* @__PURE__ */ import_react102.default.createElement("div", { className: "menu-button" }, "I need help")
|
|
7154
|
+
), sourceChain.shortName === "CC" && formStep > 0 && /* @__PURE__ */ import_react102.default.createElement(ExternalLink_default, { to: "https://docs.kima.network/kima-network/supported-fiat#unsupported-countries-credit-cards" }, /* @__PURE__ */ import_react102.default.createElement("div", { className: "menu-button" }, "Unsupported Countries")), formStep === 0 && mode !== "payment" /* payment */ && /* @__PURE__ */ import_react102.default.createElement(
|
|
7205
7155
|
"button",
|
|
7206
7156
|
{
|
|
7207
7157
|
className: "reset-button",
|
|
@@ -7209,7 +7159,7 @@ var TransferWidget = ({
|
|
|
7209
7159
|
disabled: isApproving || isSubmitting || isSigning
|
|
7210
7160
|
},
|
|
7211
7161
|
"Reset"
|
|
7212
|
-
))), mode === "payment" /* payment */ && paymentTitleOption?.title && /* @__PURE__ */
|
|
7162
|
+
))), mode === "payment" /* payment */ && paymentTitleOption?.title && /* @__PURE__ */ import_react102.default.createElement("h4", { className: "subtitle" }, paymentTitleOption.title)), /* @__PURE__ */ import_react102.default.createElement("div", { className: "kima-card-content", ref: mainRef }, formStep === 0 ? /* @__PURE__ */ import_react102.default.createElement(
|
|
7213
7163
|
SingleForm_default,
|
|
7214
7164
|
{
|
|
7215
7165
|
...{
|
|
@@ -7222,7 +7172,7 @@ var TransferWidget = ({
|
|
|
7222
7172
|
setInitialSelection
|
|
7223
7173
|
}
|
|
7224
7174
|
}
|
|
7225
|
-
) : ccTransactionStatus !== "idle" ? /* @__PURE__ */
|
|
7175
|
+
) : ccTransactionStatus !== "idle" ? /* @__PURE__ */ import_react102.default.createElement(CCWidget_default, { submitCallback: submit }) : /* @__PURE__ */ import_react102.default.createElement(
|
|
7226
7176
|
ConfirmDetails_default,
|
|
7227
7177
|
{
|
|
7228
7178
|
...{
|
|
@@ -7230,12 +7180,12 @@ var TransferWidget = ({
|
|
|
7230
7180
|
feeOptionDisabled
|
|
7231
7181
|
}
|
|
7232
7182
|
}
|
|
7233
|
-
)), /* @__PURE__ */
|
|
7183
|
+
)), /* @__PURE__ */ import_react102.default.createElement(
|
|
7234
7184
|
"div",
|
|
7235
7185
|
{
|
|
7236
7186
|
className: `kima-card-footer ${mode === "bridge" /* bridge */ && formStep !== 0 && "confirm"}`
|
|
7237
7187
|
},
|
|
7238
|
-
/* @__PURE__ */
|
|
7188
|
+
/* @__PURE__ */ import_react102.default.createElement("div", { className: `button-group` }, isBackButtonEnabled && /* @__PURE__ */ import_react102.default.createElement(
|
|
7239
7189
|
SecondaryButton_default,
|
|
7240
7190
|
{
|
|
7241
7191
|
clickHandler: onBack,
|
|
@@ -7243,7 +7193,7 @@ var TransferWidget = ({
|
|
|
7243
7193
|
disabled: isApproving || isSubmitting || isSigning
|
|
7244
7194
|
},
|
|
7245
7195
|
formStep > 0 && ccTransactionStatus !== "initialized" ? "Back" : "Cancel"
|
|
7246
|
-
), !!allowance && allowance > 0 && formStep !== 0 && sourceChain.shortName !== "CC" && mode !== "light" /* light */ ? /* @__PURE__ */
|
|
7196
|
+
), !!allowance && allowance > 0 && formStep !== 0 && sourceChain.shortName !== "CC" && mode !== "light" /* light */ ? /* @__PURE__ */ import_react102.default.createElement(
|
|
7247
7197
|
SecondaryButton_default,
|
|
7248
7198
|
{
|
|
7249
7199
|
clickHandler: onCancelApprove,
|
|
@@ -7252,7 +7202,7 @@ var TransferWidget = ({
|
|
|
7252
7202
|
disabled: isCancellingApprove || isApproving || isSubmitting || isSigning
|
|
7253
7203
|
},
|
|
7254
7204
|
isCancellingApprove ? "Cancelling Approval" : "Cancel Approve"
|
|
7255
|
-
) : null, isSubmitButtonEnabled && /* @__PURE__ */
|
|
7205
|
+
) : null, isSubmitButtonEnabled && /* @__PURE__ */ import_react102.default.createElement(
|
|
7256
7206
|
PrimaryButton_default,
|
|
7257
7207
|
{
|
|
7258
7208
|
clickHandler: onNext,
|
|
@@ -7261,7 +7211,7 @@ var TransferWidget = ({
|
|
|
7261
7211
|
},
|
|
7262
7212
|
getButtonLabel()
|
|
7263
7213
|
))
|
|
7264
|
-
), /* @__PURE__ */
|
|
7214
|
+
), /* @__PURE__ */ import_react102.default.createElement(SolanaWalletConnectModal_default, null), /* @__PURE__ */ import_react102.default.createElement(TronWalletConnectModal_default, null), /* @__PURE__ */ import_react102.default.createElement(
|
|
7265
7215
|
import_react_hot_toast5.Toaster,
|
|
7266
7216
|
{
|
|
7267
7217
|
position: "top-right",
|
|
@@ -7286,19 +7236,19 @@ var TransferWidget = ({
|
|
|
7286
7236
|
}
|
|
7287
7237
|
}
|
|
7288
7238
|
}
|
|
7289
|
-
), /* @__PURE__ */
|
|
7239
|
+
), /* @__PURE__ */ import_react102.default.createElement("div", { className: "floating-footer" }, /* @__PURE__ */ import_react102.default.createElement("div", { className: `items ${theme.colorMode}` }, /* @__PURE__ */ import_react102.default.createElement("span", null, "Powered by"), /* @__PURE__ */ import_react102.default.createElement(KimaNetwork_default, null))))
|
|
7290
7240
|
);
|
|
7291
7241
|
};
|
|
7292
7242
|
|
|
7293
7243
|
// src/components/KimaWidgetWrapper.tsx
|
|
7294
|
-
var
|
|
7244
|
+
var import_react106 = require("@reown/appkit/react");
|
|
7295
7245
|
|
|
7296
7246
|
// src/hooks/useDebugMode.ts
|
|
7297
|
-
var
|
|
7247
|
+
var import_react103 = require("react");
|
|
7298
7248
|
var useDebugCode = (sequence = ["D", "E", "B", "U", "G"]) => {
|
|
7299
|
-
const [debugMode, setDebugMode] = (0,
|
|
7300
|
-
const [, setInputSequence] = (0,
|
|
7301
|
-
(0,
|
|
7249
|
+
const [debugMode, setDebugMode] = (0, import_react103.useState)(false);
|
|
7250
|
+
const [, setInputSequence] = (0, import_react103.useState)([]);
|
|
7251
|
+
(0, import_react103.useEffect)(() => {
|
|
7302
7252
|
const onKeyDown = (e) => {
|
|
7303
7253
|
setInputSequence((prev) => {
|
|
7304
7254
|
const next = [...prev, e.key].slice(-sequence.length);
|
|
@@ -7325,7 +7275,7 @@ var useDebugCode = (sequence = ["D", "E", "B", "U", "G"]) => {
|
|
|
7325
7275
|
};
|
|
7326
7276
|
|
|
7327
7277
|
// src/components/ErrorWidget.tsx
|
|
7328
|
-
var
|
|
7278
|
+
var import_react104 = __toESM(require("react"), 1);
|
|
7329
7279
|
var import_react_redux57 = require("react-redux");
|
|
7330
7280
|
var ErrorWidget = ({
|
|
7331
7281
|
theme,
|
|
@@ -7338,7 +7288,7 @@ var ErrorWidget = ({
|
|
|
7338
7288
|
const ccTransactionId = (0, import_react_redux57.useSelector)(selectCCTransactionId);
|
|
7339
7289
|
const isCreditCardSource = sourceChain.shortName === "CC";
|
|
7340
7290
|
const isRetrying = (0, import_react_redux57.useSelector)(selectCCTransactionRetrying);
|
|
7341
|
-
return /* @__PURE__ */
|
|
7291
|
+
return /* @__PURE__ */ import_react104.default.createElement(
|
|
7342
7292
|
"div",
|
|
7343
7293
|
{
|
|
7344
7294
|
className: `kima-card ${theme.colorMode}`,
|
|
@@ -7346,7 +7296,7 @@ var ErrorWidget = ({
|
|
|
7346
7296
|
background: theme.colorMode === "light" /* light */ ? theme.backgroundColorLight : theme.backgroundColorDark
|
|
7347
7297
|
}
|
|
7348
7298
|
},
|
|
7349
|
-
/* @__PURE__ */
|
|
7299
|
+
/* @__PURE__ */ import_react104.default.createElement("div", { className: "transfer-card" }, /* @__PURE__ */ import_react104.default.createElement("div", { className: "kima-card-header" }, /* @__PURE__ */ import_react104.default.createElement("div", { className: "topbar" }, /* @__PURE__ */ import_react104.default.createElement("div", { className: "title" }, /* @__PURE__ */ import_react104.default.createElement("h3", null, title))), /* @__PURE__ */ import_react104.default.createElement("h4", { className: "subtitle" })), /* @__PURE__ */ import_react104.default.createElement("div", { className: "kima-card-content error" }, isCreditCardSource && !isRetrying && /* @__PURE__ */ import_react104.default.createElement(Error_default, { width: 40, height: 40 }), message && message !== "" && /* @__PURE__ */ import_react104.default.createElement("h2", null, message), isCreditCardSource && /* @__PURE__ */ import_react104.default.createElement(
|
|
7350
7300
|
"div",
|
|
7351
7301
|
{
|
|
7352
7302
|
style: {
|
|
@@ -7355,8 +7305,8 @@ var ErrorWidget = ({
|
|
|
7355
7305
|
flexDirection: "column"
|
|
7356
7306
|
}
|
|
7357
7307
|
},
|
|
7358
|
-
isRetrying ? /* @__PURE__ */
|
|
7359
|
-
ccTransactionId && /* @__PURE__ */
|
|
7308
|
+
isRetrying ? /* @__PURE__ */ import_react104.default.createElement("p", null, "The transaction is being retried in the background. This may take a few moments. If the issue persists, please contact support and provide the transaction ID below for reference.") : /* @__PURE__ */ import_react104.default.createElement("p", null, "This credit card transaction has failed. Please check the details and try again. If the issue persists, please contact support and provide the transaction ID below for reference."),
|
|
7309
|
+
ccTransactionId && /* @__PURE__ */ import_react104.default.createElement(
|
|
7360
7310
|
"div",
|
|
7361
7311
|
{
|
|
7362
7312
|
style: {
|
|
@@ -7366,7 +7316,7 @@ var ErrorWidget = ({
|
|
|
7366
7316
|
justifyContent: "center"
|
|
7367
7317
|
}
|
|
7368
7318
|
},
|
|
7369
|
-
/* @__PURE__ */
|
|
7319
|
+
/* @__PURE__ */ import_react104.default.createElement(
|
|
7370
7320
|
"code",
|
|
7371
7321
|
{
|
|
7372
7322
|
style: {
|
|
@@ -7377,10 +7327,10 @@ var ErrorWidget = ({
|
|
|
7377
7327
|
},
|
|
7378
7328
|
ccTransactionId
|
|
7379
7329
|
),
|
|
7380
|
-
/* @__PURE__ */
|
|
7330
|
+
/* @__PURE__ */ import_react104.default.createElement(CopyButton_default, { text: ccTransactionId })
|
|
7381
7331
|
),
|
|
7382
|
-
isRetrying && /* @__PURE__ */
|
|
7383
|
-
)), backButtonEnabled && /* @__PURE__ */
|
|
7332
|
+
isRetrying && /* @__PURE__ */ import_react104.default.createElement(ring_default, { width: 30, height: 30, fill: "#86b8ce" })
|
|
7333
|
+
)), backButtonEnabled && /* @__PURE__ */ import_react104.default.createElement(
|
|
7384
7334
|
"div",
|
|
7385
7335
|
{
|
|
7386
7336
|
style: {
|
|
@@ -7389,8 +7339,8 @@ var ErrorWidget = ({
|
|
|
7389
7339
|
marginTop: 16
|
|
7390
7340
|
}
|
|
7391
7341
|
},
|
|
7392
|
-
/* @__PURE__ */
|
|
7393
|
-
), /* @__PURE__ */
|
|
7342
|
+
/* @__PURE__ */ import_react104.default.createElement(PrimaryButton_default, { clickHandler: backButtonFunction }, "Back")
|
|
7343
|
+
), /* @__PURE__ */ import_react104.default.createElement("div", { className: "kima-card-footer" }), /* @__PURE__ */ import_react104.default.createElement("div", { className: "floating-footer" }, /* @__PURE__ */ import_react104.default.createElement("div", { className: `items ${theme.colorMode}` }, /* @__PURE__ */ import_react104.default.createElement("span", null, "Powered by"), /* @__PURE__ */ import_react104.default.createElement(FooterLogo_default, { width: 50, fill: "black" }), /* @__PURE__ */ import_react104.default.createElement("strong", null, "Network"))))
|
|
7394
7344
|
);
|
|
7395
7345
|
};
|
|
7396
7346
|
var ErrorWidget_default = ErrorWidget;
|
|
@@ -7413,13 +7363,13 @@ var KimaWidgetWrapper = ({
|
|
|
7413
7363
|
const { kimaBackendUrl } = useKimaContext();
|
|
7414
7364
|
const submitted = (0, import_react_redux58.useSelector)(selectSubmitted);
|
|
7415
7365
|
const dispatch = (0, import_react_redux58.useDispatch)();
|
|
7416
|
-
const { setThemeMode, setThemeVariables } = (0,
|
|
7366
|
+
const { setThemeMode, setThemeVariables } = (0, import_react106.useAppKitTheme)();
|
|
7417
7367
|
const sourceChain = (0, import_react_redux58.useSelector)(selectSourceChain);
|
|
7418
7368
|
const ccTransactionStatus = (0, import_react_redux58.useSelector)(selectCCTransactionStatus);
|
|
7419
7369
|
const ccTransactionRetrying = (0, import_react_redux58.useSelector)(selectCCTransactionRetrying);
|
|
7420
7370
|
const networkOption = envOptions?.env;
|
|
7421
7371
|
const kimaExplorer = envOptions?.kimaExplorer || "https://explorer.sardis.kima.network";
|
|
7422
|
-
(0,
|
|
7372
|
+
(0, import_react105.useEffect)(() => {
|
|
7423
7373
|
dispatch(setTheme(theme));
|
|
7424
7374
|
setThemeMode(theme.colorMode === "light" /* light */ ? "light" : "dark");
|
|
7425
7375
|
setThemeVariables({
|
|
@@ -7460,7 +7410,7 @@ var KimaWidgetWrapper = ({
|
|
|
7460
7410
|
dispatch(setSubmitted(false));
|
|
7461
7411
|
}
|
|
7462
7412
|
}, [theme, transactionOption, mode, networkOption, chainData]);
|
|
7463
|
-
(0,
|
|
7413
|
+
(0, import_react105.useEffect)(() => {
|
|
7464
7414
|
if (!chainData?.length) return;
|
|
7465
7415
|
indexPluginsByChain(chainData);
|
|
7466
7416
|
}, [chainData]);
|
|
@@ -7468,9 +7418,9 @@ var KimaWidgetWrapper = ({
|
|
|
7468
7418
|
console.log("widget wrapper", submitted, ccTransactionStatus);
|
|
7469
7419
|
if (submitted) {
|
|
7470
7420
|
logger_default.debug("will return transaction widget on cc success");
|
|
7471
|
-
return /* @__PURE__ */
|
|
7421
|
+
return /* @__PURE__ */ import_react105.default.createElement(TransactionWidget, { theme });
|
|
7472
7422
|
} else if (ccTransactionStatus === "error-id") {
|
|
7473
|
-
return /* @__PURE__ */
|
|
7423
|
+
return /* @__PURE__ */ import_react105.default.createElement(
|
|
7474
7424
|
ErrorWidget_default,
|
|
7475
7425
|
{
|
|
7476
7426
|
theme,
|
|
@@ -7484,7 +7434,7 @@ var KimaWidgetWrapper = ({
|
|
|
7484
7434
|
}
|
|
7485
7435
|
);
|
|
7486
7436
|
} else if (ccTransactionStatus === "error-generic") {
|
|
7487
|
-
return /* @__PURE__ */
|
|
7437
|
+
return /* @__PURE__ */ import_react105.default.createElement(
|
|
7488
7438
|
ErrorWidget_default,
|
|
7489
7439
|
{
|
|
7490
7440
|
theme,
|
|
@@ -7498,7 +7448,7 @@ var KimaWidgetWrapper = ({
|
|
|
7498
7448
|
}
|
|
7499
7449
|
);
|
|
7500
7450
|
}
|
|
7501
|
-
return /* @__PURE__ */
|
|
7451
|
+
return /* @__PURE__ */ import_react105.default.createElement(
|
|
7502
7452
|
TransferWidget,
|
|
7503
7453
|
{
|
|
7504
7454
|
theme,
|
|
@@ -7508,7 +7458,7 @@ var KimaWidgetWrapper = ({
|
|
|
7508
7458
|
}
|
|
7509
7459
|
);
|
|
7510
7460
|
}
|
|
7511
|
-
return submitted ? /* @__PURE__ */
|
|
7461
|
+
return submitted ? /* @__PURE__ */ import_react105.default.createElement(TransactionWidget, { theme }) : /* @__PURE__ */ import_react105.default.createElement(
|
|
7512
7462
|
TransferWidget,
|
|
7513
7463
|
{
|
|
7514
7464
|
theme,
|
|
@@ -7524,9 +7474,9 @@ var KimaWidgetWrapper_default = KimaWidgetWrapper;
|
|
|
7524
7474
|
var import_react_redux59 = require("react-redux");
|
|
7525
7475
|
|
|
7526
7476
|
// src/SkeletonLoader.tsx
|
|
7527
|
-
var
|
|
7477
|
+
var import_react107 = __toESM(require("react"), 1);
|
|
7528
7478
|
var SkeletonLoader = ({ theme }) => {
|
|
7529
|
-
return /* @__PURE__ */
|
|
7479
|
+
return /* @__PURE__ */ import_react107.default.createElement(
|
|
7530
7480
|
"div",
|
|
7531
7481
|
{
|
|
7532
7482
|
className: `kima-card ${theme.colorMode}`,
|
|
@@ -7534,7 +7484,7 @@ var SkeletonLoader = ({ theme }) => {
|
|
|
7534
7484
|
background: theme.colorMode === "light" /* light */ ? theme.backgroundColorLight : theme.backgroundColorDark
|
|
7535
7485
|
}
|
|
7536
7486
|
},
|
|
7537
|
-
/* @__PURE__ */
|
|
7487
|
+
/* @__PURE__ */ import_react107.default.createElement("div", { className: "transfer-card" }, /* @__PURE__ */ import_react107.default.createElement("div", { className: "kima-card-header" }, /* @__PURE__ */ import_react107.default.createElement("div", { className: "topbar" }, /* @__PURE__ */ import_react107.default.createElement("div", { className: "title skeleton" }, /* @__PURE__ */ import_react107.default.createElement("h3", null))), /* @__PURE__ */ import_react107.default.createElement("h4", { className: "subtitle" })), /* @__PURE__ */ import_react107.default.createElement("div", { className: "kima-card-content skeleton" }, /* @__PURE__ */ import_react107.default.createElement("div", { className: "skeleton" }), /* @__PURE__ */ import_react107.default.createElement("div", { className: "skeleton" }), /* @__PURE__ */ import_react107.default.createElement("div", { className: "skeleton" }), /* @__PURE__ */ import_react107.default.createElement("div", { className: "skeleton" }), /* @__PURE__ */ import_react107.default.createElement("div", { className: "skeleton" })), /* @__PURE__ */ import_react107.default.createElement("div", { className: `kima-card-footer` }, /* @__PURE__ */ import_react107.default.createElement("div", { className: `button-group skeleton` }, /* @__PURE__ */ import_react107.default.createElement("div", { className: "skeleton" }))), /* @__PURE__ */ import_react107.default.createElement("div", { className: "floating-footer" }, /* @__PURE__ */ import_react107.default.createElement("div", { className: `items ${theme.colorMode}` }, /* @__PURE__ */ import_react107.default.createElement("span", null, "Powered by"), /* @__PURE__ */ import_react107.default.createElement(FooterLogo_default, { width: 50, fill: "black" }), /* @__PURE__ */ import_react107.default.createElement("strong", null, "Network"))))
|
|
7538
7488
|
);
|
|
7539
7489
|
};
|
|
7540
7490
|
var SkeletonLoader_default = SkeletonLoader;
|
|
@@ -7553,7 +7503,7 @@ var KimaTransactionWidget = ({
|
|
|
7553
7503
|
}) => {
|
|
7554
7504
|
const dispatch = (0, import_react_redux59.useDispatch)();
|
|
7555
7505
|
const { kimaBackendUrl } = useKimaContext();
|
|
7556
|
-
const [hydrated, setHydrated] = (0,
|
|
7506
|
+
const [hydrated, setHydrated] = (0, import_react108.useState)(false);
|
|
7557
7507
|
const {
|
|
7558
7508
|
data: envOptions,
|
|
7559
7509
|
error: envOptionsError,
|
|
@@ -7564,26 +7514,26 @@ var KimaTransactionWidget = ({
|
|
|
7564
7514
|
error: chainDataError,
|
|
7565
7515
|
isLoading: isLoadingChainData
|
|
7566
7516
|
} = useChainData(kimaBackendUrl);
|
|
7567
|
-
(0,
|
|
7517
|
+
(0, import_react108.useEffect)(() => {
|
|
7568
7518
|
if (typeof window !== "undefined") setHydrated(true);
|
|
7569
7519
|
}, []);
|
|
7570
|
-
(0,
|
|
7520
|
+
(0, import_react108.useEffect)(() => {
|
|
7571
7521
|
if (!isLoadingChainData && chainData) {
|
|
7572
7522
|
dispatch(setSourceChain(chainData[0]));
|
|
7573
7523
|
dispatch(setTargetChain(chainData[1]));
|
|
7574
7524
|
}
|
|
7575
7525
|
}, [chainData]);
|
|
7576
|
-
(0,
|
|
7526
|
+
(0, import_react108.useEffect)(() => {
|
|
7577
7527
|
if (theme?.colorMode) {
|
|
7578
7528
|
dispatch(setTheme(theme));
|
|
7579
7529
|
}
|
|
7580
7530
|
}, [theme?.colorMode]);
|
|
7581
7531
|
if (!hydrated || !theme?.colorMode)
|
|
7582
|
-
return /* @__PURE__ */
|
|
7532
|
+
return /* @__PURE__ */ import_react108.default.createElement(ring_default, { width: 20, height: 20, fill: "#86b8ce" });
|
|
7583
7533
|
if (isLoadingEnvs || isLoadingChainData)
|
|
7584
|
-
return /* @__PURE__ */
|
|
7534
|
+
return /* @__PURE__ */ import_react108.default.createElement(SkeletonLoader_default, { theme });
|
|
7585
7535
|
if (envOptionsError || !envOptions)
|
|
7586
|
-
return /* @__PURE__ */
|
|
7536
|
+
return /* @__PURE__ */ import_react108.default.createElement(
|
|
7587
7537
|
ErrorWidget_default,
|
|
7588
7538
|
{
|
|
7589
7539
|
theme,
|
|
@@ -7592,7 +7542,7 @@ var KimaTransactionWidget = ({
|
|
|
7592
7542
|
}
|
|
7593
7543
|
);
|
|
7594
7544
|
if (chainDataError || !chainData)
|
|
7595
|
-
return /* @__PURE__ */
|
|
7545
|
+
return /* @__PURE__ */ import_react108.default.createElement(
|
|
7596
7546
|
ErrorWidget_default,
|
|
7597
7547
|
{
|
|
7598
7548
|
theme,
|
|
@@ -7600,7 +7550,7 @@ var KimaTransactionWidget = ({
|
|
|
7600
7550
|
message: "There was an error loading the chain data from the backend. Please check that the backend is running properly and the widget points to the corresponding url." /* ChainLoadingError */
|
|
7601
7551
|
}
|
|
7602
7552
|
);
|
|
7603
|
-
return /* @__PURE__ */
|
|
7553
|
+
return /* @__PURE__ */ import_react108.default.createElement(
|
|
7604
7554
|
KimaWidgetWrapper_default,
|
|
7605
7555
|
{
|
|
7606
7556
|
...{
|