@meteora-ag/dlmm 1.0.39-rc.2 → 1.0.39-rc.21

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.d.ts CHANGED
@@ -5316,7 +5316,7 @@ declare class DLMM {
5316
5316
  * @returns {Promise<Transaction>}
5317
5317
  */
5318
5318
  syncWithMarketPrice(marketPrice: number, owner: PublicKey): Promise<Transaction>;
5319
- getLastPrice(): Promise<string>;
5319
+ getMaxPrice(minPrice: string, binArrays?: BinArrayAccount[]): Promise<number>;
5320
5320
  /** Private static method */
5321
5321
  private static getBinArrays;
5322
5322
  private static getClaimableLMReward;
package/dist/index.js CHANGED
@@ -9087,7 +9087,7 @@ var DLMM = class {
9087
9087
  swapForY,
9088
9088
  activeId,
9089
9089
  this.lbPair,
9090
- _optionalChain([this, 'access', _58 => _58.binArrayBitmapExtension, 'optionalAccess', _59 => _59.account]),
9090
+ _nullishCoalesce(_optionalChain([this, 'access', _58 => _58.binArrayBitmapExtension, 'optionalAccess', _59 => _59.account]), () => ( null)),
9091
9091
  binArrays
9092
9092
  );
9093
9093
  if (binArrayAccountToSwap == null) {
@@ -9903,27 +9903,29 @@ var DLMM = class {
9903
9903
  lastValidBlockHeight
9904
9904
  }).add(syncWithMarketPriceTx);
9905
9905
  }
9906
- async getLastPrice() {
9907
- const { price } = await this.getActiveBin();
9908
- const binArrays = await this.getBinArrays();
9909
- let count = 0;
9910
- let binPriceWithLastLiquidity = price;
9911
- while (count <= binArrays.length - 1) {
9912
- const binArray = binArrays[count];
9906
+ async getMaxPrice(minPrice, binArrays) {
9907
+ const _binArrays = binArrays || await this.getBinArrays();
9908
+ const sortedBinArrays = _binArrays.sort(
9909
+ ({ account: { index: indexA } }, { account: { index: indexB } }) => indexA.toNumber() - indexB.toNumber()
9910
+ );
9911
+ let count = sortedBinArrays.length - 1;
9912
+ let binPriceWithLastLiquidity = minPrice;
9913
+ while (count >= 0) {
9914
+ const binArray = sortedBinArrays[count];
9913
9915
  if (binArray) {
9914
- const bins = binArray.account.bins;
9915
- if (bins[bins.length - 1].liquiditySupply.gt(new (0, _anchor.BN)(0))) {
9916
- count++;
9916
+ const bins = binArray.account.bins.reverse();
9917
+ if (bins.every(({ amountX }) => amountX.isZero())) {
9918
+ count--;
9917
9919
  } else {
9918
- const lastBinWithLiquidityIndex = bins.findIndex(
9919
- ({ liquiditySupply }) => liquiditySupply.isZero()
9920
+ const lastBinWithLiquidityIndex = bins.findLastIndex(
9921
+ ({ amountX }) => !amountX.isZero()
9920
9922
  );
9921
- binPriceWithLastLiquidity = bins[lastBinWithLiquidityIndex - 1].price.toString();
9922
- count = binArrays.length;
9923
+ binPriceWithLastLiquidity = bins[lastBinWithLiquidityIndex].price.toString();
9924
+ count = -1;
9923
9925
  }
9924
9926
  }
9925
9927
  }
9926
- return binPriceWithLastLiquidity;
9928
+ return Number(binPriceWithLastLiquidity) / (2 ** 64 - 1);
9927
9929
  }
9928
9930
  /** Private static method */
9929
9931
  static async getBinArrays(program, lbPairPubkey) {