import type { Address } from "@coral-xyz/anchor"; import type { Percentage } from "@orca-so/common-sdk"; import { TransactionBuilder } from "@orca-so/common-sdk"; import type { PublicKey } from "@solana/web3.js"; import type { WhirlpoolContext } from "../context"; import type { ByTokenAmountsParams, DevFeeSwapInput, SwapInput } from "../instructions"; import type { TokenAccountInfo, TokenInfo, WhirlpoolData, WhirlpoolRewardInfo } from "../types/public"; import type { Whirlpool } from "../whirlpool-client"; export declare class WhirlpoolImpl implements Whirlpool { readonly ctx: WhirlpoolContext; readonly address: PublicKey; readonly tokenAInfo: TokenInfo; readonly tokenBInfo: TokenInfo; private tokenVaultAInfo; private tokenVaultBInfo; private rewardInfos; private data; constructor(ctx: WhirlpoolContext, address: PublicKey, tokenAInfo: TokenInfo, tokenBInfo: TokenInfo, tokenVaultAInfo: TokenAccountInfo, tokenVaultBInfo: TokenAccountInfo, rewardInfos: WhirlpoolRewardInfo[], data: WhirlpoolData); getAddress(): PublicKey; getData(): WhirlpoolData; getTokenAInfo(): TokenInfo; getTokenBInfo(): TokenInfo; getTokenVaultAInfo(): TokenAccountInfo; getTokenVaultBInfo(): TokenAccountInfo; getRewardInfos(): WhirlpoolRewardInfo[]; refreshData(): Promise; openPosition(tickLower: number, tickUpper: number, liquidityInput: ByTokenAmountsParams, wallet?: Address, funder?: Address, positionMint?: PublicKey, tokenProgramId?: PublicKey, resolveATA?: boolean): Promise<{ positionMint: PublicKey; tx: TransactionBuilder; }>; openPositionWithMetadata(tickLower: number, tickUpper: number, liquidityInput: ByTokenAmountsParams, sourceWallet?: Address, funder?: Address, positionMint?: PublicKey, tokenProgramId?: PublicKey, resolveATA?: boolean): Promise<{ positionMint: PublicKey; tx: TransactionBuilder; }>; initTickArrayForTicks(ticks: number[], funder?: Address, opts?: import("@orca-so/common-sdk").SimpleAccountFetchOptions, tickArrayType?: "dynamic" | "fixed"): Promise; closePosition(positionAddress: Address, slippageTolerance: Percentage, destinationWallet?: Address, positionWallet?: Address, payer?: Address, usePriceSlippage?: boolean): Promise; swap(quote: SwapInput, sourceWallet?: Address): Promise; swapWithDevFees(quote: DevFeeSwapInput, devFeeWallet: PublicKey, wallet?: PublicKey | undefined, payer?: PublicKey | undefined): Promise; getOpenPositionWithOptMetadataTx(tickLower: number, tickUpper: number, liquidityInput: ByTokenAmountsParams, wallet: PublicKey, funder: PublicKey, tokenProgramId: PublicKey, withMetadata?: boolean, positionMint?: PublicKey, resolveATA?: boolean): Promise<{ positionMint: PublicKey; tx: TransactionBuilder; }>; getClosePositionIx(positionAddress: PublicKey, slippageTolerance: Percentage, destinationWallet: PublicKey, positionWallet: PublicKey, payerKey: PublicKey, usePriceSlippage?: boolean): Promise; private refresh; }