@t2000/sdk 0.21.9 → 0.21.10

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.js CHANGED
@@ -2325,14 +2325,6 @@ var T2000 = class _T2000 extends EventEmitter {
2325
2325
  if (route.priceImpact > 0.05) {
2326
2326
  console.warn(`[swap] High price impact: ${(route.priceImpact * 100).toFixed(2)}%`);
2327
2327
  }
2328
- const toEntry = Object.entries(SUPPORTED_ASSETS).find(([, v]) => v.type === toType);
2329
- const toDecimals = toEntry ? toEntry[1].decimals : toType === "0x2::sui::SUI" ? 9 : 6;
2330
- let preBalance = 0n;
2331
- try {
2332
- const bal = await this.client.getBalance({ owner: this._address, coinType: toType });
2333
- preBalance = BigInt(bal.totalBalance);
2334
- } catch {
2335
- }
2336
2328
  const gasResult = await executeWithGas(this.client, this._signer, async () => {
2337
2329
  const tx = new Transaction();
2338
2330
  tx.setSender(this._address);
@@ -2355,17 +2347,25 @@ var T2000 = class _T2000 extends EventEmitter {
2355
2347
  tx.transferObjects([outputCoin], this._address);
2356
2348
  return tx;
2357
2349
  });
2350
+ const toEntry = Object.entries(SUPPORTED_ASSETS).find(([, v]) => v.type === toType);
2351
+ const toDecimals = toEntry ? toEntry[1].decimals : toType === "0x2::sui::SUI" ? 9 : 6;
2358
2352
  const fromAmount = Number(route.amountIn) / 10 ** fromDecimals;
2359
2353
  let toAmount = Number(route.amountOut) / 10 ** toDecimals;
2360
2354
  try {
2361
- const postBal = await this.client.getBalance({ owner: this._address, coinType: toType });
2362
- const postBalance = BigInt(postBal.totalBalance);
2363
- const diff = postBalance - preBalance;
2364
- if (diff > 0n) {
2365
- toAmount = Number(diff) / 10 ** toDecimals;
2355
+ const txBlock = await this.client.getTransactionBlock({
2356
+ digest: gasResult.digest,
2357
+ options: { showBalanceChanges: true }
2358
+ });
2359
+ const changes = txBlock.balanceChanges ?? [];
2360
+ const received = changes.find(
2361
+ (c) => c.coinType === toType && BigInt(c.amount) > 0n && c.owner.AddressOwner === this._address
2362
+ );
2363
+ if (received) {
2364
+ const actual = Number(BigInt(received.amount)) / 10 ** toDecimals;
2365
+ if (actual > 0) toAmount = actual;
2366
2366
  }
2367
2367
  } catch {
2368
- console.warn("[swap] Could not read post-swap balance, using route estimate");
2368
+ console.warn("[swap] Could not read balance changes, using route estimate");
2369
2369
  }
2370
2370
  const fromName = fromEntry ? fromEntry[0] : this._resolveTokenName(fromType, params.from);
2371
2371
  const toName = toEntry ? toEntry[0] : this._resolveTokenName(toType, params.to);