@t2000/sdk 0.21.8 → 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.cjs CHANGED
@@ -2353,13 +2353,21 @@ var T2000 = class _T2000 extends eventemitter3.EventEmitter {
2353
2353
  const toDecimals = toEntry ? toEntry[1].decimals : toType === "0x2::sui::SUI" ? 9 : 6;
2354
2354
  const fromAmount = Number(route.amountIn) / 10 ** fromDecimals;
2355
2355
  let toAmount = Number(route.amountOut) / 10 ** toDecimals;
2356
- const changes = gasResult.balanceChanges ?? [];
2357
- const received = changes.find(
2358
- (c) => c.coinType === toType && BigInt(c.amount) > 0n && c.owner.AddressOwner === this._address
2359
- );
2360
- if (received) {
2361
- const actual = Number(BigInt(received.amount)) / 10 ** toDecimals;
2362
- if (actual > 0) toAmount = actual;
2356
+ try {
2357
+ const txBlock = await this.client.getTransactionBlock({
2358
+ digest: gasResult.digest,
2359
+ options: { showBalanceChanges: true }
2360
+ });
2361
+ const changes = txBlock.balanceChanges ?? [];
2362
+ const received = changes.find(
2363
+ (c) => c.coinType === toType && BigInt(c.amount) > 0n && c.owner.AddressOwner === this._address
2364
+ );
2365
+ if (received) {
2366
+ const actual = Number(BigInt(received.amount)) / 10 ** toDecimals;
2367
+ if (actual > 0) toAmount = actual;
2368
+ }
2369
+ } catch {
2370
+ console.warn("[swap] Could not read balance changes, using route estimate");
2363
2371
  }
2364
2372
  const fromName = fromEntry ? fromEntry[0] : this._resolveTokenName(fromType, params.from);
2365
2373
  const toName = toEntry ? toEntry[0] : this._resolveTokenName(toType, params.to);