@t2000/sdk 0.21.9 → 0.21.11

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 CHANGED
@@ -2327,14 +2327,6 @@ var T2000 = class _T2000 extends eventemitter3.EventEmitter {
2327
2327
  if (route.priceImpact > 0.05) {
2328
2328
  console.warn(`[swap] High price impact: ${(route.priceImpact * 100).toFixed(2)}%`);
2329
2329
  }
2330
- const toEntry = Object.entries(SUPPORTED_ASSETS).find(([, v]) => v.type === toType);
2331
- const toDecimals = toEntry ? toEntry[1].decimals : toType === "0x2::sui::SUI" ? 9 : 6;
2332
- let preBalance = 0n;
2333
- try {
2334
- const bal = await this.client.getBalance({ owner: this._address, coinType: toType });
2335
- preBalance = BigInt(bal.totalBalance);
2336
- } catch {
2337
- }
2338
2330
  const gasResult = await executeWithGas(this.client, this._signer, async () => {
2339
2331
  const tx = new transactions.Transaction();
2340
2332
  tx.setSender(this._address);
@@ -2357,17 +2349,35 @@ var T2000 = class _T2000 extends eventemitter3.EventEmitter {
2357
2349
  tx.transferObjects([outputCoin], this._address);
2358
2350
  return tx;
2359
2351
  });
2352
+ const toEntry = Object.entries(SUPPORTED_ASSETS).find(([, v]) => v.type === toType);
2353
+ const toDecimals = toEntry ? toEntry[1].decimals : toType === "0x2::sui::SUI" ? 9 : 6;
2360
2354
  const fromAmount = Number(route.amountIn) / 10 ** fromDecimals;
2361
2355
  let toAmount = Number(route.amountOut) / 10 ** toDecimals;
2362
- try {
2363
- const postBal = await this.client.getBalance({ owner: this._address, coinType: toType });
2364
- const postBalance = BigInt(postBal.totalBalance);
2365
- const diff = postBalance - preBalance;
2366
- if (diff > 0n) {
2367
- toAmount = Number(diff) / 10 ** toDecimals;
2356
+ const toTypeSuffix = toType.split("::").slice(1).join("::");
2357
+ for (let attempt = 0; attempt < 4; attempt++) {
2358
+ try {
2359
+ const txBlock = await this.client.getTransactionBlock({
2360
+ digest: gasResult.digest,
2361
+ options: { showBalanceChanges: true }
2362
+ });
2363
+ const changes = txBlock.balanceChanges ?? [];
2364
+ const received = changes.find((c) => {
2365
+ if (BigInt(c.amount) <= 0n) return false;
2366
+ const ownerAddr = c.owner?.AddressOwner;
2367
+ if (!ownerAddr || ownerAddr.toLowerCase() !== this._address.toLowerCase()) return false;
2368
+ if (c.coinType === toType) return true;
2369
+ return c.coinType.endsWith(toTypeSuffix);
2370
+ });
2371
+ if (received) {
2372
+ const actual = Number(BigInt(received.amount)) / 10 ** toDecimals;
2373
+ if (actual > 0) {
2374
+ toAmount = actual;
2375
+ break;
2376
+ }
2377
+ }
2378
+ } catch {
2368
2379
  }
2369
- } catch {
2370
- console.warn("[swap] Could not read post-swap balance, using route estimate");
2380
+ if (attempt < 3) await new Promise((r) => setTimeout(r, 600));
2371
2381
  }
2372
2382
  const fromName = fromEntry ? fromEntry[0] : this._resolveTokenName(fromType, params.from);
2373
2383
  const toName = toEntry ? toEntry[0] : this._resolveTokenName(toType, params.to);