@berachain/berajs 0.2.6-patch.1 → 0.2.6-patch.2

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.
Files changed (85) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +0 -0
  3. package/dist/actions/exports.cjs +1 -1
  4. package/dist/actions/exports.cjs.map +1 -1
  5. package/dist/actions/exports.mjs +1 -1
  6. package/dist/{chunk-FM3WDBFH.mjs → chunk-3ZTAIOHH.mjs} +2 -2
  7. package/dist/{chunk-HWOGQSNL.cjs → chunk-I4V54RRZ.cjs} +2 -2
  8. package/dist/{chunk-HWOGQSNL.cjs.map → chunk-I4V54RRZ.cjs.map} +1 -1
  9. package/dist/{chunk-COMMLZ3O.mjs → chunk-KRVNPZLF.mjs} +2 -2
  10. package/dist/{chunk-CF3LFNXG.cjs → chunk-NVOJIQUM.cjs} +2 -2
  11. package/dist/{chunk-CF3LFNXG.cjs.map → chunk-NVOJIQUM.cjs.map} +1 -1
  12. package/dist/{chunk-LNVR4BW6.cjs → chunk-QXNF3YT7.cjs} +2 -2
  13. package/dist/{chunk-LNVR4BW6.cjs.map → chunk-QXNF3YT7.cjs.map} +1 -1
  14. package/dist/{chunk-IBJOI5SN.mjs → chunk-WIN4PK2Z.mjs} +2 -2
  15. package/dist/contexts/exports.cjs +1 -1
  16. package/dist/contexts/exports.cjs.map +1 -1
  17. package/dist/contexts/exports.mjs +1 -1
  18. package/dist/hooks/exports.cjs +2 -2
  19. package/dist/hooks/exports.cjs.map +1 -1
  20. package/dist/hooks/exports.mjs +1 -1
  21. package/package.json +22 -23
  22. package/src/abi/exports.ts +0 -0
  23. package/src/abi/pyth/pyth.ts +0 -0
  24. package/src/actions/dex/getPoolHistoricalData.ts +0 -0
  25. package/src/actions/governance/getAllProposals.ts +0 -0
  26. package/src/actions/governance/getProposalDetails.ts +0 -0
  27. package/src/actions/honey/getHoneyFees.ts +0 -0
  28. package/src/actions/honey/getHoneyPreview.ts +0 -0
  29. package/src/actions/pol/getBGTGlobalInfo.ts +0 -0
  30. package/src/actions/pol/getBgtTokenTotalBoosts.ts +0 -0
  31. package/src/actions/pol/getBgtTokenTotalSupply.ts +0 -0
  32. package/src/actions/pol/getGlobalCuttingBoard.ts +0 -0
  33. package/src/actions/pol/getMarkets.ts +0 -0
  34. package/src/actions/pol/getRewardVaults.ts +0 -0
  35. package/src/actions/pol/getUserVaultsBalance.ts +0 -0
  36. package/src/actions/pol/getUserVaultsReward.ts +0 -0
  37. package/src/actions/pol/getVaultsSupply.ts +0 -0
  38. package/src/actions/tokens/getAllowances.ts +0 -0
  39. package/src/actions/tokens/getTokenInformation.ts +0 -0
  40. package/src/actions/tokens/getTokens.ts +0 -0
  41. package/src/actions/tokens/getWalletBalances.ts +0 -0
  42. package/src/contexts/exports.ts +0 -0
  43. package/src/enum/exports.ts +0 -0
  44. package/src/enum/polling.ts +0 -0
  45. package/src/enum/txnEnum.ts +0 -0
  46. package/src/errors/getErrorMessage.ts +0 -0
  47. package/src/hooks/dex/useCreatePool.ts +0 -0
  48. package/src/hooks/dex/useMultipleTokenApprovalsWithSlippage.ts +0 -0
  49. package/src/hooks/dex/usePoolHistoricalData.ts +0 -0
  50. package/src/hooks/exports.ts +0 -0
  51. package/src/hooks/perps/usePythUpdateFee.ts +0 -0
  52. package/src/hooks/pol/useBgtUnstakedBalance.ts +0 -0
  53. package/src/hooks/pol/usePollGlobalData.ts +0 -0
  54. package/src/hooks/pol/usePollMarkets.ts +0 -0
  55. package/src/hooks/pol/useRewardTokenToBeraRate.ts +0 -0
  56. package/src/hooks/pol/useRewardVault.ts +0 -0
  57. package/src/hooks/pol/useRewardVaults.ts +0 -0
  58. package/src/hooks/pol/useUserVaultInfo.ts +0 -0
  59. package/src/hooks/pol/useUserVaults.ts +0 -0
  60. package/src/hooks/pol/useVaultValidators.ts +0 -0
  61. package/src/hooks/tokens/usePollAllowances.ts +0 -0
  62. package/src/hooks/tokens/usePollBalance.ts +0 -0
  63. package/src/hooks/tokens/usePollWalletBalances.ts +0 -0
  64. package/src/hooks/tokens/useTokenInformation.ts +0 -0
  65. package/src/hooks/tokens/useTokens.ts +0 -0
  66. package/src/hooks/useContractWrite/index.ts +0 -0
  67. package/src/hooks/useContractWrite/stateReducer.ts +0 -0
  68. package/src/hooks/useContractWrite/types.ts +0 -0
  69. package/src/hooks/useContractWrite/useBeraContractWrite.ts +0 -0
  70. package/src/hooks/usePrevious.ts +0 -0
  71. package/src/hooks/validators/useApiValidator.ts +0 -0
  72. package/src/hooks/validators/useUserActiveValidators.ts +0 -0
  73. package/src/hooks/validators/useValidatorEstimatedBgtPerYear.ts +0 -0
  74. package/src/types/dex.d.ts +0 -0
  75. package/src/types/exports.ts +0 -0
  76. package/src/types/global.d.ts +0 -0
  77. package/src/types/staking.d.ts +0 -0
  78. package/src/utils/exports.ts +0 -0
  79. package/src/utils/filter.ts +0 -0
  80. package/src/utils/formatInputTokenValue.ts +0 -0
  81. package/src/utils/formatNumber.ts +0 -0
  82. package/src/utils/truncateHash.ts +0 -0
  83. /package/dist/{chunk-FM3WDBFH.mjs.map → chunk-3ZTAIOHH.mjs.map} +0 -0
  84. /package/dist/{chunk-COMMLZ3O.mjs.map → chunk-KRVNPZLF.mjs.map} +0 -0
  85. /package/dist/{chunk-IBJOI5SN.mjs.map → chunk-WIN4PK2Z.mjs.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/snowbera/Documents/workspace/monobera/packages/berajs/dist/hooks/exports.cjs","../../src/hooks/bend/useGetConvertToAssets.ts","../../src/hooks/dex/useAggregatorsQuotes.ts","../../src/actions/dex/aggregators/bex.ts","../../src/actions/dex/aggregators/bgt.ts","../../src/actions/dex/aggregators/enso/enso.ts","../../src/hooks/dex/useLiquidityMismatch.ts","../../src/hooks/tokens/useMultipleTokenInformation.ts"],"names":["useGetConvertToAssets","sharesAmount","vaultAddress","vaultChainId","options","publicClient","usePublicClient","swrResponse","useSWR","_","assertPublicClient","getConvertToAssets","DEFAULT_DEADLINE","STALE_PRICE_THRESHOLD","swapKind","SwapKind","BexAggregator","BaseAggregator","ChainId","getUriFromLink","address","isToken","priceImpact","onChainAmount","sorPaths","sorAmount","queryData","deltaFromSorAmount","formatEther","error","BeraError","p","BeraMonitoring","args","balancerApi","BalancerApi","tokenIn","tokenOut","amount","slippage","account","zeroAddress","wberaIsBera","tokenInV3","Token","tokenOutV3","tokenAmount","TokenAmount","RequestError","swap","Swap","queryOutput","callData","Slippage","params","functionName","decodeFunctionData","balancerVaultAbi","bex","RedeemBgtAggregator","beraToken","InvalidArgumentError","bgtRedeem","EnsoAggregator","aggregatorsFeeBps","proxyAggregatorsThroughVercel","rewardVault","tokenInAddress","tokenOutAddress","isTokenInNative","isTokenOutNative","inputAmountAfterFees"],"mappings":"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","file":"/Users/snowbera/Documents/workspace/monobera/packages/berajs/dist/hooks/exports.cjs","sourcesContent":[null,"import useSWR from \"swr\";\n\nimport { usePublicClient } from \"@berachain/wagmi/hooks\";\n\nimport type { GetConvertToAssetsProps } from \"../../actions/bend/getConvertToAssets\";\nimport { getConvertToAssets } from \"../../actions/bend/getConvertToAssets\";\nimport { assertPublicClient } from \"../../errors/assert\";\nimport type { DefaultHookOptions } from \"../../types/global\";\n\nexport const useGetConvertToAssets = (\n {\n sharesAmount,\n vaultAddress,\n vaultChainId,\n }: Omit<GetConvertToAssetsProps, \"publicClient\"> & { vaultChainId?: number },\n options?: DefaultHookOptions,\n) => {\n const publicClient = usePublicClient({ chainId: vaultChainId });\n const swrResponse = useSWR(\n publicClient && sharesAmount && vaultAddress\n ? [\"useGetConvertToAssets\", sharesAmount, vaultAddress, vaultChainId]\n : null,\n async ([_, sharesAmount, vaultAddress]) => {\n assertPublicClient(publicClient);\n\n return getConvertToAssets({\n sharesAmount,\n vaultAddress,\n publicClient,\n });\n },\n {\n ...options?.opts,\n },\n );\n\n return {\n ...swrResponse,\n refresh: () => {\n swrResponse.mutate();\n },\n };\n};\n","import { useMemo } from \"react\";\nimport { type Address, zeroAddress } from \"viem\";\n\nimport { defaultChainId } from \"@berachain/config/internal\";\n\nimport { useBeraWallet, usePublicClient } from \"@berachain/wagmi/hooks\";\n\nimport { bex } from \"../../actions/dex/aggregators/bex\";\nimport { bgtRedeem } from \"../../actions/dex/aggregators/bgt\";\nimport { enso } from \"../../actions/dex/aggregators/enso/enso\";\nimport { erc4626Deposit } from \"../../actions/dex/aggregators/erc4626\";\nimport { fly } from \"../../actions/dex/aggregators/fly\";\nimport { haiku } from \"../../actions/dex/aggregators/haiku\";\nimport { honeyNative } from \"../../actions/dex/aggregators/honey\";\nimport { kyberswap } from \"../../actions/dex/aggregators/kyberswap\";\nimport { oogabooga } from \"../../actions/dex/aggregators/oogabooga\";\nimport { openOcean } from \"../../actions/dex/aggregators/openOcean\";\nimport { wberaSwap } from \"../../actions/dex/aggregators/wbera\";\nimport { useBeraFlag } from \"../../contexts/BeraFlags/BeraFlags\";\nimport type { HoneyConfigContextReturn } from \"../../contexts/HoneyConfigProvider\";\nimport type { SwapReferrer } from \"../../enum/dex\";\nimport type { IRawAggregatorQuote, MinimalERC20 } from \"../../types/dex\";\nimport type { DefaultHookOptions } from \"../../types/global\";\nimport { parseBaseArgs } from \"../../utils/parseBaseArgs\";\nimport { isToken } from \"../../utils/tokens\";\nimport { useUnderlyingAsset } from \"../tokens/useUnderlyingAsset\";\nimport { useAggregatorsRouterFeeBps } from \"./useAggregatorsRouterFeeBps\";\nimport { useBexStatus } from \"./useBexStatus\";\nimport {\n getAggregatorsSWROptions,\n raw_useSingleAggregatorQuote,\n} from \"./useSingleAggregatorQuote\";\n\nconst AGGREGATORS = [\n oogabooga,\n fly,\n kyberswap,\n openOcean,\n haiku,\n enso,\n bex,\n honeyNative,\n erc4626Deposit,\n];\n\ntype IUseAggregatorsQuotesArgs = BeraJS.BaseFunctionArgs & {\n tokenIn: MinimalERC20;\n tokenOut: MinimalERC20;\n amount: string;\n slippage: number;\n referrer?: SwapReferrer;\n rewardVault?: Address;\n /**\n * Useful cause the collaterals are provided byt he honeyContext and this way we can\n * use the Provider only in the swap page where is needed.\n *\n * The collaterals for the honey mint/redeem aggregator.\n */\n honeyNativeState?: Pick<\n HoneyConfigContextReturn,\n \"collateralList\" | \"protocol\"\n >;\n};\n\nexport function useAggregatorsQuotes(\n args: IUseAggregatorsQuotesArgs,\n options?: DefaultHookOptions,\n) {\n const { address: account } = useBeraWallet();\n const proxyAggregatorsThroughVercel = useBeraFlag(\n \"proxyAggregatorsThroughVercel\",\n );\n const activeAggregators = useBeraFlag(\"aggregators\");\n const publicClient = usePublicClient();\n const { data: feeBps } = useAggregatorsRouterFeeBps();\n\n const isWrapOrUnwrap =\n (isToken(args.tokenIn.address, \"BERA\") ||\n isToken(args.tokenIn.address, \"WBERA\")) &&\n (isToken(args.tokenOut.address, \"BERA\") ||\n isToken(args.tokenOut.address, \"WBERA\"));\n\n const isBgtRedeem = isToken(args.tokenIn.address, \"BGT\", {\n chainId: defaultChainId,\n });\n\n const { data: underlyingToken } = useUnderlyingAsset({\n token: args.tokenOut,\n });\n\n /**\n * Whether it's a native swap (wrap/unwrap) or BGT redeem\n */\n const isNativeSwap = isWrapOrUnwrap || isBgtRedeem;\n\n const { config } = parseBaseArgs(args);\n\n const isMAEnabled = config.bex.aggregatorsRouter !== zeroAddress;\n\n const swrOptions = getAggregatorsSWROptions(options);\n\n const sharedArgs = {\n activeAggregators,\n isMAEnabled,\n underlyingToken,\n isNativeSwap,\n account,\n publicClient,\n proxyAggregatorsThroughVercel,\n feeBps,\n } as const;\n\n // we're using independent useSWRs so we can show quotes as they come\n // instead of waiting for all of them to load\n const oogaBogaResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: oogabooga,\n },\n { opts: swrOptions },\n );\n\n const flyResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: fly,\n },\n { opts: swrOptions },\n );\n\n const erc4626Result = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: erc4626Deposit,\n },\n { opts: swrOptions },\n );\n\n const kyberswapResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: kyberswap,\n },\n { opts: swrOptions },\n );\n\n const openOceanResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: openOcean,\n },\n { opts: swrOptions },\n );\n\n const haikuResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: haiku,\n },\n { opts: swrOptions },\n );\n\n const ensoResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: enso,\n },\n { opts: swrOptions },\n );\n\n const { protocol: bexProtocol } = useBexStatus();\n\n const bexResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: bex,\n },\n { opts: { ...swrOptions, isEnabled: bexProtocol.isPaused === false } },\n );\n\n const wberaSwapResult = raw_useSingleAggregatorQuote({\n ...sharedArgs,\n ...args,\n aggregator: wberaSwap,\n });\n\n const bgtRedeemResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: bgtRedeem,\n },\n { opts: swrOptions },\n );\n\n const honeyResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: honeyNative,\n },\n { opts: swrOptions },\n );\n\n const results = isWrapOrUnwrap\n ? [wberaSwapResult]\n : isBgtRedeem\n ? [bgtRedeemResult]\n : [\n oogaBogaResult,\n erc4626Result,\n flyResult,\n kyberswapResult,\n openOceanResult,\n haikuResult,\n ensoResult,\n honeyResult,\n bexProtocol.isPaused === false ? bexResult : null,\n ].filter((i): i is NonNullable<typeof i> => i !== null);\n\n const data = useMemo(() => {\n const error = results.reduce<(typeof results)[number][\"error\"]>(\n (error, result) => error || result.error,\n undefined,\n );\n\n const loadingAggregatorsNames = results\n .map((r, i) =>\n r.isLoading\n ? isNativeSwap\n ? wberaSwap.name\n : AGGREGATORS[i].name\n : null,\n )\n .filter(Boolean);\n\n const quotes = results\n .filter(\n (result) =>\n result !== undefined &&\n !result.isLoading &&\n !result.error &&\n result.data?.amountOut,\n )\n .map(({ data }) => data) as IRawAggregatorQuote[];\n\n const isLoading = quotes.length === 0 && loadingAggregatorsNames.length > 0;\n return { quotes, loadingAggregatorsNames, isLoading, error };\n }, [results]);\n\n return {\n ...data,\n refresh: () => results.map((r) => r.mutate()),\n };\n}\n","import {\n type Address,\n Slippage,\n type SorSwapResult,\n Swap,\n SwapKind,\n Token,\n TokenAmount,\n} from \"@berachain-foundation/berancer-sdk\";\nimport { decodeFunctionData, formatEther, zeroAddress } from \"viem\";\n\nimport { getUriFromLink } from \"@berachain/config\";\nimport { ChainId } from \"@berachain/config/internal\";\n\nimport { vaultAbi as balancerVaultAbi } from \"@berachain/abis/bex/vault\";\n\nimport { Aggregators } from \"../../../enum/dex\";\nimport { assertPublicClient } from \"../../../errors/assert\";\nimport { BeraError } from \"../../../errors/BeraError\";\nimport { BeraMonitoring } from \"../../../errors/BeraMonitoring\";\nimport { RequestError } from \"../../../errors/RequestError\";\nimport type { IAggregatorArgs, IRawAggregatorQuote } from \"../../../types/dex\";\nimport { isToken } from \"../../../utils/tokens\";\nimport { BalancerApi } from \"../b-sdk\";\nimport { BaseAggregator } from \"./base\";\n\n// Constants\nconst DEFAULT_DEADLINE = 60 * 5; // default transaction deadline in seconds\nconst STALE_PRICE_THRESHOLD = 0.05; // 5% threshold for stale prices\nconst swapKind = SwapKind.GivenIn;\n\nclass BexAggregator extends BaseAggregator {\n name = Aggregators.HubPools;\n supportedChains = [ChainId.MAINNET, ChainId.BEPOLIA];\n readonly url = getUriFromLink(this.config.api);\n readonly type = \"graphql\";\n\n /**\n * Helper function to convert zero address to wrapped token address\n */\n private convertZeroToWrapped(address: Address): Address {\n return isToken(address, \"BERA\") ? this.config.tokens.wbera : address;\n }\n\n /**\n * Helper to calculate price impact percentage\n */\n private calculatePriceImpact(priceImpact: {\n error: string | null;\n priceImpact?: string;\n }): number {\n if (priceImpact.error) {\n console.error(\"Swap price impact error\", priceImpact);\n return 0;\n }\n\n return Number(priceImpact.priceImpact);\n }\n\n /**\n * Helper to check for stale SOR prices\n */\n private checkStalePrices({\n onChainAmount,\n sorPaths,\n sorAmount,\n queryData,\n }: {\n onChainAmount: TokenAmount;\n sorPaths: { pools: string[] }[];\n sorAmount: string;\n queryData: IAggregatorArgs;\n }): void {\n // Check for stale prices\n const deltaFromSorAmount =\n Number.parseFloat(formatEther(onChainAmount.scale18)) /\n Number.parseFloat(sorAmount);\n\n if (Math.abs(1 - deltaFromSorAmount) > STALE_PRICE_THRESHOLD) {\n console.warn(\n \"SOR returned stale prices. Delta from return amount is more than 5%\",\n {\n deltaFromSorAmount,\n },\n );\n\n const error = new BeraError({\n reason: \"SOR_STALE_PRICES\",\n level: \"warning\",\n message:\n \"SOR returned stale prices. Delta from return amount is more than 5%\",\n extra: {\n deltaFromSorAmount,\n pools: sorPaths.map((p) => p.pools),\n onChainAmount: formatEther(onChainAmount.scale18),\n sorAmount,\n queryData,\n },\n fingerprint: [\"SOR_STALE_PRICES\"],\n });\n BeraMonitoring.captureException(error);\n }\n }\n\n async getQuote(args: IAggregatorArgs): Promise<IRawAggregatorQuote> {\n const balancerApi = new BalancerApi(\n this.url,\n // @ts-expect-error b-sdk has more chains than berajs\n this.chainId,\n );\n const {\n tokenIn,\n tokenOut,\n amount,\n slippage,\n account = zeroAddress,\n publicClient,\n } = args;\n this.assertChainSupport({ tokenIn, tokenOut });\n\n assertPublicClient(publicClient);\n\n const wberaIsBera = isToken(tokenIn, \"BERA\") || isToken(tokenOut, \"BERA\");\n\n // Initialize tokens\n const tokenInV3 = new Token(\n this.chainId,\n this.convertZeroToWrapped(tokenIn.address),\n tokenIn.decimals,\n );\n const tokenOutV3 = new Token(\n this.chainId,\n this.convertZeroToWrapped(tokenOut.address),\n tokenOut.decimals,\n );\n\n const tokenAmount = TokenAmount.fromRawAmount(\n tokenInV3,\n amount as `${number}`,\n );\n\n // swap paths\n const {\n paths: sorPaths,\n priceImpact,\n returnAmount: sorAmount,\n }: SorSwapResult = await balancerApi.sorSwapPaths.fetchSorSwapPaths({\n // @ts-expect-error b-sdk has more chains than berajs\n chainId: this.chainId,\n tokenIn: tokenInV3.address,\n tokenOut: tokenOutV3.address,\n swapKind,\n swapAmount: tokenAmount,\n });\n\n if (!sorPaths?.length) {\n throw new RequestError({\n response: undefined,\n endpoint: {\n url: this.url,\n name: this.name,\n type: this.type,\n },\n reason: BaseAggregator.PATH_NOT_FOUND_REASON,\n chainId: this.chainId,\n payload: {\n tokenIn: tokenInV3.address,\n tokenOut: tokenOutV3.address,\n swapKind,\n swapAmount: tokenAmount,\n },\n message: `No swap paths returned from Balancer API`,\n });\n }\n\n // execute swap query\n const swap = new Swap({\n chainId: this.chainId,\n paths: sorPaths,\n swapKind,\n userData: \"0x\" as `0x${string}`,\n });\n const queryOutput = await swap.query(publicClient.transport.url);\n\n if (!(\"expectedAmountOut\" in queryOutput)) {\n throw new Error(\"No Bex paths found\");\n }\n\n this.checkStalePrices({\n onChainAmount: queryOutput.expectedAmountOut,\n sorPaths,\n sorAmount,\n queryData: args,\n });\n\n // format quote response\n return {\n amountOut: queryOutput.expectedAmountOut.amount.toString(),\n amountIn: amount,\n allowanceRequirements: this.parseAllowanceRequirements({\n tokenIn,\n rawAmount: amount,\n spender: queryOutput.to,\n }),\n name: this.name,\n priceImpactPercentage: this.calculatePriceImpact(priceImpact),\n swapFeeBps: 0,\n getCalldata: ({ account }) => {\n // generate user transaction data\n const callData = swap.buildCall({\n slippage: Slippage.fromPercentage(slippage.toString() as `${number}`),\n deadline: BigInt(Math.round(Date.now() / 1000) + DEFAULT_DEADLINE),\n queryOutput,\n sender: account as Address,\n recipient: account as Address,\n wethIsEth: wberaIsBera,\n });\n\n const { args: params, functionName } = decodeFunctionData({\n abi: balancerVaultAbi,\n data: callData.callData,\n });\n\n return {\n params,\n functionName,\n abi: balancerVaultAbi,\n address: callData.to,\n value: callData.value || BigInt(0),\n };\n },\n };\n }\n}\n\nexport const bex = new BexAggregator();\n","import { ChainId } from \"@berachain/config/internal\";\n\nimport { Aggregators } from \"../../../enum/dex\";\nimport { InvalidArgumentError } from \"../../../errors/InvalidArgumentError\";\nimport type {\n IAggregatorArgs,\n IRawAggregatorQuote,\n MinimalERC20,\n} from \"../../../types/dex\";\nimport { beraToken, isToken } from \"../../../utils/tokens\";\nimport { BaseAggregator } from \"./base\";\n\nclass RedeemBgtAggregator extends BaseAggregator {\n name = Aggregators.RedeemBgt;\n supportedChains = [ChainId.MAINNET, ChainId.BEPOLIA];\n readonly type = \"rpc\";\n\n checkChainSupport({\n tokenIn,\n tokenOut,\n }: {\n tokenIn: MinimalERC20;\n tokenOut: MinimalERC20;\n }): boolean {\n if (!super.checkChainSupport({ tokenIn, tokenOut })) {\n return false;\n }\n\n return (\n // only supported on same chain\n tokenIn.chainId === tokenOut.chainId &&\n isToken(tokenIn, \"BGT\", { chainId: tokenIn.chainId }) &&\n isToken(tokenOut, \"BERA\")\n );\n }\n // handles native swaps: wrap and unwrap\n async getQuote({\n tokenIn,\n amount,\n }: Omit<\n IAggregatorArgs,\n \"slippage\" | \"feeBps\" | \"tokenOut\" | \"account\"\n >): Promise<IRawAggregatorQuote> {\n this.assertChainSupport({\n tokenIn,\n tokenOut: { ...beraToken, chainId: tokenIn.chainId },\n });\n\n if (!isToken(tokenIn, \"BGT\", { config: this.config })) {\n throw new InvalidArgumentError({\n property: \"tokenIn\",\n value: tokenIn,\n expected: \"BGT\",\n level: \"warning\",\n });\n }\n\n return {\n amountOut: amount,\n amountIn: amount,\n allowanceRequirements: [],\n name: Aggregators.RedeemBgt,\n isNativeSwap: true,\n swapFeeBps: 0,\n // not adding calldata here because it depends on the connected wallet\n // bgt redeem requires a receiver address\n // moreover this is a sensitive operation, better be sure of what data is being sent\n // by controlling it on the consumer side\n } as const;\n }\n}\n\nexport const bgtRedeem = new RedeemBgtAggregator();\n","import { zeroAddress } from \"viem\";\n\nimport { ChainId } from \"@berachain/config/internal\";\n\nimport aggregatorsRouterAbi from \"@berachain/abis/meta-aggregator/metaAggregatorV2\";\n\nimport { Aggregators } from \"../../../../enum/dex\";\nimport type {\n IAggregatorArgs,\n IRawAggregatorQuote,\n} from \"../../../../types/dex\";\nimport type { IContractWrite } from \"../../../../types/global\";\nimport { BaseAggregator } from \"../base\";\n\nclass EnsoAggregator extends BaseAggregator {\n name = Aggregators.Enso;\n supportedChains = [ChainId.MAINNET];\n readonly type = \"rest\";\n needsAccountForQuote = true;\n\n notFoundMessages: string[] = [\n \"Could not build shortcuts for route\",\n \"Could not quote shortcuts for route\",\n \"Swap not found for a required underlying of defi route,\",\n \"No route found from\",\n ];\n\n async getQuote({\n tokenIn,\n tokenOut,\n amount,\n slippage,\n account = zeroAddress,\n aggregatorsFeeBps,\n proxyAggregatorsThroughVercel = false,\n rewardVault,\n }: IAggregatorArgs): Promise<IRawAggregatorQuote> {\n this.assertChainSupport({ tokenIn, tokenOut });\n\n const {\n tokenInAddress,\n tokenOutAddress,\n isTokenInNative,\n isTokenOutNative,\n } = this.parseAddresses(tokenIn.address, tokenOut.address);\n\n const inputAmountAfterFees = this.getAmountAfterFees(\n amount,\n aggregatorsFeeBps,\n );\n\n this.url = proxyAggregatorsThroughVercel\n ? `/api/aggregators?aggregator=enso`\n : `${this.config.bex.aggregatorsProxyUrl}/enso/api/v1/shortcuts/route?`;\n\n const url = new URL(this.url);\n url.searchParams.set(\n \"fromAddress\",\n this.config.bex.aggregatorsRouterExecutor,\n );\n url.searchParams.set(\"receiver\", this.config.bex.aggregatorsRouterExecutor);\n url.searchParams.set(\"spender\", this.config.bex.aggregatorsRouterExecutor);\n url.searchParams.set(\"amountIn\", inputAmountAfterFees);\n url.searchParams.set(\"tokenIn\", tokenInAddress);\n url.searchParams.set(\"tokenOut\", tokenOutAddress);\n url.searchParams.set(\"chainId\", ChainId.MAINNET.toString());\n url.searchParams.set(\"slippage\", (Number(slippage) * 100).toString());\n url.searchParams.set(\"refundReceiver\", account);\n\n const response = await this.fetch(url);\n\n const quote = await response.json();\n\n const inputData = this.getInputData({\n tokenIn: tokenInAddress,\n amountIn: amount,\n isNative: isTokenInNative,\n });\n\n const outputData = {\n tokenOut: tokenOutAddress,\n receiver: account,\n minAmountOut: this.getMinAmountOut(quote.amountOut.toString(), slippage),\n isNative: isTokenOutNative,\n };\n\n const aggregatorData = {\n aggregator: quote.tx?.to,\n data: quote.tx?.data,\n };\n\n return {\n amountOut: quote.amountOut.toString(),\n amountIn: amount,\n allowanceRequirements: this.parseAllowanceRequirements({\n tokenIn,\n rawAmount: amount,\n spender: this.config.bex.aggregatorsRouter,\n }),\n name: this.name,\n swapFeeBps: aggregatorsFeeBps!,\n getCalldata: () =>\n ({\n params: [\n inputData,\n outputData,\n aggregatorData,\n {\n rewardVault: rewardVault ?? zeroAddress,\n isSwapAndStake: !!rewardVault,\n },\n ],\n functionName: \"swap\",\n abi: aggregatorsRouterAbi,\n // send full amount to router first, which will deduct the swap fee before executing trade\n value: isTokenInNative ? BigInt(amount) : BigInt(\"0\"),\n address: this.config.bex.aggregatorsRouter,\n }) satisfies Omit<\n IContractWrite<typeof aggregatorsRouterAbi, \"swap\">,\n \"message\" | \"actionType\"\n >,\n };\n }\n}\n\nexport const enso = new EnsoAggregator();\n","import { useEffect, useState } from \"react\";\nimport { PoolType } from \"@berachain-foundation/berancer-sdk\";\n\nimport { PoolCreationStep } from \"../../enum/dex\";\nimport type { TokenCurrentPriceMap, TokenWithAmount } from \"../../types/dex\";\nimport { wrapNativeTokens } from \"../../utils/tokenWrapping\";\nimport { type Oracle, OracleMode } from \"./useCreatePool\";\n\nconst DEFAULT_LIQUIDITY_MISMATCH_TOLERANCE_PERCENT = 0.05; // 5%\n\nexport type LiquidityMismatchInfo = {\n title: string | null;\n message: string | null;\n suggestWeighted?: boolean;\n};\n\ninterface UseLiquidityMismatchParams {\n currentStep: PoolCreationStep;\n tokenPrices?: TokenCurrentPriceMap;\n isLoadingTokenPrices: boolean;\n tokens: TokenWithAmount[] | null;\n weights: bigint[] | null;\n weightsError: string | null;\n poolType: PoolType;\n liquidityMismatchTolerancePercent?: number;\n oracles: Oracle[];\n}\n\n/**\n * Hook for detecting liquidity mismatches.\n *\n * @param {PoolCreationStep} currentStep - The current step of the pool creation process.\n * @param {Record<string, number>} tokenPrices - The current token prices.\n * @param {boolean} isLoadingTokenPrices - Whether the token prices are still loading.\n * @param {Array<{ address: string, amount: number }>} tokens - The tokens in the pool, including their addresses and amounts.\n * @param {Record<string, number>} weights - The per-token weights in the pool we are creating.\n * @param {string | null} weightsError - An error message for the weights indicating that the weights are invalid.\n * @param {string} poolType - The type of pool being created.\n * @param {number} liquidityMismatchTolerancePercent - The tolerance for liquidity mismatches in percent.\n * @returns {Object} The liquidity mismatch info.\n */\nexport const useLiquidityMismatch = ({\n currentStep,\n tokenPrices,\n isLoadingTokenPrices,\n tokens,\n weights,\n weightsError,\n poolType,\n liquidityMismatchTolerancePercent = DEFAULT_LIQUIDITY_MISMATCH_TOLERANCE_PERCENT,\n oracles,\n}: UseLiquidityMismatchParams): LiquidityMismatchInfo => {\n // NOTE: would be nice to use Maps/Records more in here, as the zipping/unzipping is cumbersome.\n // NOTE: if we pull in string literal for currentStep things would also be a bit clearer in here.\n const [liquidityMismatchInfo, setLiquidityMismatchInfo] =\n useState<LiquidityMismatchInfo>({ title: null, message: null });\n\n useEffect(() => {\n // If we are either using custom rate-providing oracles or have incorrect/loading token prices, we cant do validation.\n if (\n !tokenPrices ||\n isLoadingTokenPrices ||\n !tokens ||\n !weights ||\n weightsError ||\n tokens.some((token) => !token.address) ||\n oracles.some((oracle) => oracle.mode === OracleMode.Custom) // Oracles give prices on their own, we dont support that here yet.\n ) {\n setLiquidityMismatchInfo({ title: null, message: null });\n return;\n }\n\n // Calculate some basic metrics we'll use to determine per-token contributions and model potential losses from arbitrage.\n let totalLiquidityUSD = 0;\n const tokenUSDAmounts: number[] = [];\n const numTokens = tokens.length;\n const wrappedTokens = wrapNativeTokens(tokens);\n const tokenUSDPrices = wrappedTokens.map((token) => {\n const tokenPriceUSD =\n tokenPrices[token.address.toLowerCase()]?.price ?? 0;\n if (!tokenPriceUSD || tokenPriceUSD === 0) {\n tokenUSDAmounts.push(0);\n return null;\n }\n const tokenAmountUSD = tokenPriceUSD * Number.parseFloat(token.amount);\n tokenUSDAmounts.push(tokenAmountUSD);\n totalLiquidityUSD += tokenAmountUSD;\n return tokenPriceUSD;\n });\n\n // Doesn't matter what step it is, if we have missing token prices for tokens we have selected, we cant issue a real warning.\n if (\n tokenUSDPrices.some((price) => price === null) ||\n tokenUSDPrices.length !== numTokens\n ) {\n setLiquidityMismatchInfo({\n title: \"Missing token price data\",\n message: `One or more token(s) do not have valid market price data. Please verify that token market prices align with the pool\n weightings and your initial liquidity amounts.`,\n });\n return;\n }\n\n // Step 1 - During token selection we check for a deviation in the quote prices of the tokens selected (for stable pools).\n if (\n currentStep === PoolCreationStep.SELECT_TOKENS &&\n poolType === PoolType.ComposableStable\n ) {\n const normalizedUSDPrices = tokenUSDPrices.map(\n (priceUSD) => priceUSD! / tokenUSDPrices[0]!, // always normalize on the first token's price\n );\n const maxDifference =\n Math.max(...normalizedUSDPrices) - Math.min(...normalizedUSDPrices);\n\n if (maxDifference > liquidityMismatchTolerancePercent) {\n setLiquidityMismatchInfo({\n title: \"Selected tokens have a significant price deviation\",\n message: \"Did you mean to create a Weighted pool instead?\",\n suggestWeighted: true,\n });\n } else {\n setLiquidityMismatchInfo({ title: null, message: null });\n }\n\n return;\n }\n\n // Validation During Liquidity Input and onwards.\n if (\n totalLiquidityUSD === 0 ||\n tokenUSDAmounts.some((value) => value === 0)\n ) {\n // User has not yet entered fully their liquidity values, so return early.\n setLiquidityMismatchInfo({ title: null, message: null });\n return;\n }\n\n // Simulate arbitrage for the pool to determine potential losses from arbitrageurs.\n // NOTE: we assume shortfalls and excesses are losses, but in reality the actual losses would be more complex to realise.\n // Balancer does this similarily https://github.com/balancer/frontend-v2/blob/8563b8d33b6bff266148bd48d7ebc89f921374f4/src/components/cards/CreatePool/InitialLiquidity.vue#L75\n let totalLossUSD = 0;\n if (poolType === PoolType.ComposableStable) {\n const expectedPerTokenLiquidityUSD = totalLiquidityUSD / numTokens;\n tokenUSDAmounts.forEach((value) => {\n totalLossUSD += Math.abs(expectedPerTokenLiquidityUSD - value);\n });\n } else if (poolType === PoolType.Weighted) {\n tokenUSDAmounts.forEach((value, index) => {\n const weightProportion = Number(weights[index]) / 1e18;\n const expectedValueUSD = totalLiquidityUSD * weightProportion;\n totalLossUSD += Math.abs(expectedValueUSD - value);\n });\n }\n\n // We'll show a total loss if it's 90% or more\n const isTotalLoss = totalLossUSD >= totalLiquidityUSD * 0.9;\n totalLossUSD = Math.min(totalLossUSD, totalLiquidityUSD);\n const totalLossPercentage = totalLossUSD / totalLiquidityUSD;\n\n if (totalLossPercentage > liquidityMismatchTolerancePercent) {\n setLiquidityMismatchInfo({\n // If it's a total loss we dont display a percentage\n title: isTotalLoss\n ? \"You could lose all of your initial liquidity\"\n : `You could lose $${totalLossUSD.toFixed(2)} (~${(\n totalLossPercentage * 100\n ).toFixed(2)}%)`,\n message: `Based on the market token prices, the value of tokens does not align with the specified pool weights. \n This discrepancy could expose you to potential losses from arbitrageurs. ${\n poolType === PoolType.ComposableStable\n ? \"Did you mean to create a Weighted pool instead?\"\n : \"\"\n }`,\n suggestWeighted: poolType === PoolType.ComposableStable,\n });\n } else {\n // All good bb bb\n setLiquidityMismatchInfo({ title: null, message: null });\n }\n }, [\n currentStep,\n tokenPrices,\n isLoadingTokenPrices,\n tokens,\n weights,\n weightsError,\n poolType,\n liquidityMismatchTolerancePercent,\n oracles,\n ]);\n return liquidityMismatchInfo;\n};\n","import useSWRImmutable from \"swr/immutable\";\nimport { isAddress } from \"viem\";\n\nimport { defaultChainId } from \"@berachain/config/internal\";\n\nimport { usePublicClient } from \"@berachain/wagmi/hooks\";\n\nimport { getTokenInformation } from \"../../actions/tokens/getTokenInformation\";\nimport { assertPublicClient } from \"../../errors/assert\";\nimport type { Token } from \"../../types/dex\";\nimport type {\n DefaultHookOptions,\n DefaultHookReturnType,\n} from \"../../types/global\";\n\nexport type UseMultipleTokenInformationResponse = DefaultHookReturnType<\n Token[]\n>;\n\nexport type useMultipleTokenInformationArgs = {\n addresses: string[] | readonly string[] | undefined;\n chainId?: number;\n};\nexport function useMultipleTokenInformation(\n args: useMultipleTokenInformationArgs,\n options?: DefaultHookOptions,\n): UseMultipleTokenInformationResponse {\n const publicClient = usePublicClient();\n\n const QUERY_KEY =\n publicClient && args.addresses\n ? ([\n \"useMultipleTokenInformation\",\n args.addresses,\n args.chainId ?? defaultChainId,\n ] as const)\n : null;\n\n const swrResponse = useSWRImmutable<Token[], unknown, typeof QUERY_KEY>(\n QUERY_KEY,\n async ([, addresses, chainId]) => {\n // We already checked for publicClient in the QUERY_KEY\n // so we can safely assume that publicClient is defined\n // but we need this for correct type inference\n assertPublicClient(publicClient);\n\n return Promise.all(\n addresses.map(async (address) => {\n if (!address || !isAddress(address, { strict: false })) {\n throw new Error(\"Invalid address\");\n }\n\n const tk = await getTokenInformation({\n address: address,\n publicClient,\n chainId,\n });\n\n if (!tk) {\n throw new Error(`Token ${address} not found`);\n }\n\n return tk;\n }),\n );\n },\n { ...options?.opts },\n );\n\n return {\n ...swrResponse,\n refresh: () => swrResponse?.mutate?.(),\n };\n}\n"]}
1
+ {"version":3,"sources":["/Users/snowbera/Documents/workspace/monobera/packages/berajs/dist/hooks/exports.cjs","../../src/hooks/bend/useGetConvertToAssets.ts","../../src/hooks/dex/useAggregatorsQuotes.ts","../../src/actions/dex/aggregators/bex.ts","../../src/actions/dex/aggregators/bgt.ts","../../src/actions/dex/aggregators/enso/enso.ts","../../src/hooks/dex/useLiquidityMismatch.ts","../../src/hooks/tokens/useMultipleTokenInformation.ts"],"names":["useGetConvertToAssets","sharesAmount","vaultAddress","vaultChainId","options","publicClient","usePublicClient","swrResponse","useSWR","_","assertPublicClient","getConvertToAssets","DEFAULT_DEADLINE","STALE_PRICE_THRESHOLD","swapKind","SwapKind","BexAggregator","BaseAggregator","ChainId","getUriFromLink","address","isToken","priceImpact","onChainAmount","sorPaths","sorAmount","queryData","deltaFromSorAmount","formatEther","error","BeraError","p","BeraMonitoring","args","balancerApi","BalancerApi","tokenIn","tokenOut","amount","slippage","account","zeroAddress","wberaIsBera","tokenInV3","Token","tokenOutV3","tokenAmount","TokenAmount","RequestError","swap","Swap","queryOutput","callData","Slippage","params","functionName","decodeFunctionData","balancerVaultAbi","bex","RedeemBgtAggregator","beraToken","InvalidArgumentError","bgtRedeem","EnsoAggregator","aggregatorsFeeBps","proxyAggregatorsThroughVercel","rewardVault","tokenInAddress","tokenOutAddress","isTokenInNative","isTokenOutNative","inputAmountAfterFees"],"mappings":"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","file":"/Users/snowbera/Documents/workspace/monobera/packages/berajs/dist/hooks/exports.cjs","sourcesContent":[null,"import useSWR from \"swr\";\n\nimport { usePublicClient } from \"@berachain/wagmi/hooks\";\n\nimport type { GetConvertToAssetsProps } from \"../../actions/bend/getConvertToAssets\";\nimport { getConvertToAssets } from \"../../actions/bend/getConvertToAssets\";\nimport { assertPublicClient } from \"../../errors/assert\";\nimport type { DefaultHookOptions } from \"../../types/global\";\n\nexport const useGetConvertToAssets = (\n {\n sharesAmount,\n vaultAddress,\n vaultChainId,\n }: Omit<GetConvertToAssetsProps, \"publicClient\"> & { vaultChainId?: number },\n options?: DefaultHookOptions,\n) => {\n const publicClient = usePublicClient({ chainId: vaultChainId });\n const swrResponse = useSWR(\n publicClient && sharesAmount && vaultAddress\n ? [\"useGetConvertToAssets\", sharesAmount, vaultAddress, vaultChainId]\n : null,\n async ([_, sharesAmount, vaultAddress]) => {\n assertPublicClient(publicClient);\n\n return getConvertToAssets({\n sharesAmount,\n vaultAddress,\n publicClient,\n });\n },\n {\n ...options?.opts,\n },\n );\n\n return {\n ...swrResponse,\n refresh: () => {\n swrResponse.mutate();\n },\n };\n};\n","import { useMemo } from \"react\";\nimport { type Address, zeroAddress } from \"viem\";\n\nimport { defaultChainId } from \"@berachain/config/internal\";\n\nimport { useBeraWallet, usePublicClient } from \"@berachain/wagmi/hooks\";\n\nimport { bex } from \"../../actions/dex/aggregators/bex\";\nimport { bgtRedeem } from \"../../actions/dex/aggregators/bgt\";\nimport { enso } from \"../../actions/dex/aggregators/enso/enso\";\nimport { erc4626Deposit } from \"../../actions/dex/aggregators/erc4626\";\nimport { fly } from \"../../actions/dex/aggregators/fly\";\nimport { haiku } from \"../../actions/dex/aggregators/haiku\";\nimport { honeyNative } from \"../../actions/dex/aggregators/honey\";\nimport { kyberswap } from \"../../actions/dex/aggregators/kyberswap\";\nimport { oogabooga } from \"../../actions/dex/aggregators/oogabooga\";\nimport { openOcean } from \"../../actions/dex/aggregators/openOcean\";\nimport { wberaSwap } from \"../../actions/dex/aggregators/wbera\";\nimport { useBeraFlag } from \"../../contexts/BeraFlags/BeraFlags\";\nimport type { HoneyConfigContextReturn } from \"../../contexts/HoneyConfigProvider\";\nimport type { SwapReferrer } from \"../../enum/dex\";\nimport type { IRawAggregatorQuote, MinimalERC20 } from \"../../types/dex\";\nimport type { DefaultHookOptions } from \"../../types/global\";\nimport { parseBaseArgs } from \"../../utils/parseBaseArgs\";\nimport { isToken } from \"../../utils/tokens\";\nimport { useUnderlyingAsset } from \"../tokens/useUnderlyingAsset\";\nimport { useAggregatorsRouterFeeBps } from \"./useAggregatorsRouterFeeBps\";\nimport { useBexStatus } from \"./useBexStatus\";\nimport {\n getAggregatorsSWROptions,\n raw_useSingleAggregatorQuote,\n} from \"./useSingleAggregatorQuote\";\n\nconst AGGREGATORS = [\n oogabooga,\n fly,\n kyberswap,\n openOcean,\n haiku,\n enso,\n bex,\n honeyNative,\n erc4626Deposit,\n];\n\ntype IUseAggregatorsQuotesArgs = BeraJS.BaseFunctionArgs & {\n tokenIn: MinimalERC20;\n tokenOut: MinimalERC20;\n amount: string;\n slippage: number;\n referrer?: SwapReferrer;\n rewardVault?: Address;\n /**\n * Useful cause the collaterals are provided byt he honeyContext and this way we can\n * use the Provider only in the swap page where is needed.\n *\n * The collaterals for the honey mint/redeem aggregator.\n */\n honeyNativeState?: Pick<\n HoneyConfigContextReturn,\n \"collateralList\" | \"protocol\"\n >;\n};\n\nexport function useAggregatorsQuotes(\n args: IUseAggregatorsQuotesArgs,\n options?: DefaultHookOptions,\n) {\n const { address: account } = useBeraWallet();\n const proxyAggregatorsThroughVercel = useBeraFlag(\n \"proxyAggregatorsThroughVercel\",\n );\n const activeAggregators = useBeraFlag(\"aggregators\");\n const publicClient = usePublicClient();\n const { data: feeBps } = useAggregatorsRouterFeeBps();\n\n const isWrapOrUnwrap =\n (isToken(args.tokenIn.address, \"BERA\") ||\n isToken(args.tokenIn.address, \"WBERA\")) &&\n (isToken(args.tokenOut.address, \"BERA\") ||\n isToken(args.tokenOut.address, \"WBERA\"));\n\n const isBgtRedeem = isToken(args.tokenIn.address, \"BGT\", {\n chainId: defaultChainId,\n });\n\n const { data: underlyingToken } = useUnderlyingAsset({\n token: args.tokenOut,\n });\n\n /**\n * Whether it's a native swap (wrap/unwrap) or BGT redeem\n */\n const isNativeSwap = isWrapOrUnwrap || isBgtRedeem;\n\n const { config } = parseBaseArgs(args);\n\n const isMAEnabled = config.bex.aggregatorsRouter !== zeroAddress;\n\n const swrOptions = getAggregatorsSWROptions(options);\n\n const sharedArgs = {\n activeAggregators,\n isMAEnabled,\n underlyingToken,\n isNativeSwap,\n account,\n publicClient,\n proxyAggregatorsThroughVercel,\n feeBps,\n } as const;\n\n // we're using independent useSWRs so we can show quotes as they come\n // instead of waiting for all of them to load\n const oogaBogaResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: oogabooga,\n },\n { opts: swrOptions },\n );\n\n const flyResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: fly,\n },\n { opts: swrOptions },\n );\n\n const erc4626Result = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: erc4626Deposit,\n },\n { opts: swrOptions },\n );\n\n const kyberswapResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: kyberswap,\n },\n { opts: swrOptions },\n );\n\n const openOceanResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: openOcean,\n },\n { opts: swrOptions },\n );\n\n const haikuResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: haiku,\n },\n { opts: swrOptions },\n );\n\n const ensoResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: enso,\n },\n { opts: swrOptions },\n );\n\n const { protocol: bexProtocol } = useBexStatus();\n\n const bexResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: bex,\n },\n { opts: { ...swrOptions, isEnabled: bexProtocol.isPaused === false } },\n );\n\n const wberaSwapResult = raw_useSingleAggregatorQuote({\n ...sharedArgs,\n ...args,\n aggregator: wberaSwap,\n });\n\n const bgtRedeemResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: bgtRedeem,\n },\n { opts: swrOptions },\n );\n\n const honeyResult = raw_useSingleAggregatorQuote(\n {\n ...sharedArgs,\n ...args,\n aggregator: honeyNative,\n },\n { opts: swrOptions },\n );\n\n const results = isWrapOrUnwrap\n ? [wberaSwapResult]\n : isBgtRedeem\n ? [bgtRedeemResult]\n : [\n oogaBogaResult,\n erc4626Result,\n flyResult,\n kyberswapResult,\n openOceanResult,\n haikuResult,\n ensoResult,\n honeyResult,\n bexProtocol.isPaused === false ? bexResult : null,\n ].filter((i): i is NonNullable<typeof i> => i !== null);\n\n const data = useMemo(() => {\n const error = results.reduce<(typeof results)[number][\"error\"]>(\n (error, result) => error || result.error,\n undefined,\n );\n\n const loadingAggregatorsNames = results\n .map((r, i) =>\n r.isLoading\n ? isNativeSwap\n ? wberaSwap.name\n : AGGREGATORS[i].name\n : null,\n )\n .filter(Boolean);\n\n const quotes = results\n .filter(\n (result) =>\n result !== undefined &&\n !result.isLoading &&\n !result.error &&\n result.data?.amountOut,\n )\n .map(({ data }) => data) as IRawAggregatorQuote[];\n\n const isLoading = quotes.length === 0 && loadingAggregatorsNames.length > 0;\n return { quotes, loadingAggregatorsNames, isLoading, error };\n }, [results]);\n\n return {\n ...data,\n refresh: () => results.map((r) => r.mutate()),\n };\n}\n","import {\n type Address,\n Slippage,\n type SorSwapResult,\n Swap,\n SwapKind,\n Token,\n TokenAmount,\n} from \"@berachain-foundation/berancer-sdk\";\nimport { decodeFunctionData, formatEther, zeroAddress } from \"viem\";\n\nimport { getUriFromLink } from \"@berachain/config\";\nimport { ChainId } from \"@berachain/config/internal\";\n\nimport { vaultAbi as balancerVaultAbi } from \"@berachain/abis/bex/vault\";\n\nimport { Aggregators } from \"../../../enum/dex\";\nimport { assertPublicClient } from \"../../../errors/assert\";\nimport { BeraError } from \"../../../errors/BeraError\";\nimport { BeraMonitoring } from \"../../../errors/BeraMonitoring\";\nimport { RequestError } from \"../../../errors/RequestError\";\nimport type { IAggregatorArgs, IRawAggregatorQuote } from \"../../../types/dex\";\nimport { isToken } from \"../../../utils/tokens\";\nimport { BalancerApi } from \"../b-sdk\";\nimport { BaseAggregator } from \"./base\";\n\n// Constants\nconst DEFAULT_DEADLINE = 60 * 5; // default transaction deadline in seconds\nconst STALE_PRICE_THRESHOLD = 0.05; // 5% threshold for stale prices\nconst swapKind = SwapKind.GivenIn;\n\nclass BexAggregator extends BaseAggregator {\n name = Aggregators.HubPools;\n supportedChains = [ChainId.MAINNET, ChainId.BEPOLIA];\n readonly url = getUriFromLink(this.config.api);\n readonly type = \"graphql\";\n\n /**\n * Helper function to convert zero address to wrapped token address\n */\n private convertZeroToWrapped(address: Address): Address {\n return isToken(address, \"BERA\") ? this.config.tokens.wbera : address;\n }\n\n /**\n * Helper to calculate price impact percentage\n */\n private calculatePriceImpact(priceImpact: {\n error: string | null;\n priceImpact?: string;\n }): number {\n if (priceImpact.error) {\n console.error(\"Swap price impact error\", priceImpact);\n return 0;\n }\n\n return Number(priceImpact.priceImpact);\n }\n\n /**\n * Helper to check for stale SOR prices\n */\n private checkStalePrices({\n onChainAmount,\n sorPaths,\n sorAmount,\n queryData,\n }: {\n onChainAmount: TokenAmount;\n sorPaths: { pools: string[] }[];\n sorAmount: string;\n queryData: IAggregatorArgs;\n }): void {\n // Check for stale prices\n const deltaFromSorAmount =\n Number.parseFloat(formatEther(onChainAmount.scale18)) /\n Number.parseFloat(sorAmount);\n\n if (Math.abs(1 - deltaFromSorAmount) > STALE_PRICE_THRESHOLD) {\n console.warn(\n \"SOR returned stale prices. Delta from return amount is more than 5%\",\n {\n deltaFromSorAmount,\n },\n );\n\n const error = new BeraError({\n reason: \"SOR_STALE_PRICES\",\n level: \"warning\",\n message:\n \"SOR returned stale prices. Delta from return amount is more than 5%\",\n extra: {\n deltaFromSorAmount,\n pools: sorPaths.map((p) => p.pools),\n onChainAmount: formatEther(onChainAmount.scale18),\n sorAmount,\n queryData,\n },\n fingerprint: [\"SOR_STALE_PRICES\"],\n });\n BeraMonitoring.captureException(error);\n }\n }\n\n async getQuote(args: IAggregatorArgs): Promise<IRawAggregatorQuote> {\n const balancerApi = new BalancerApi(\n this.url,\n // @ts-expect-error b-sdk has more chains than berajs\n this.chainId,\n );\n const {\n tokenIn,\n tokenOut,\n amount,\n slippage,\n account = zeroAddress,\n publicClient,\n } = args;\n this.assertChainSupport({ tokenIn, tokenOut });\n\n assertPublicClient(publicClient);\n\n const wberaIsBera = isToken(tokenIn, \"BERA\") || isToken(tokenOut, \"BERA\");\n\n // Initialize tokens\n const tokenInV3 = new Token(\n this.chainId,\n this.convertZeroToWrapped(tokenIn.address),\n tokenIn.decimals,\n );\n const tokenOutV3 = new Token(\n this.chainId,\n this.convertZeroToWrapped(tokenOut.address),\n tokenOut.decimals,\n );\n\n const tokenAmount = TokenAmount.fromRawAmount(\n tokenInV3,\n amount as `${number}`,\n );\n\n // swap paths\n const {\n paths: sorPaths,\n priceImpact,\n returnAmount: sorAmount,\n }: SorSwapResult = await balancerApi.sorSwapPaths.fetchSorSwapPaths({\n // @ts-expect-error b-sdk has more chains than berajs\n chainId: this.chainId,\n tokenIn: tokenInV3.address,\n tokenOut: tokenOutV3.address,\n swapKind,\n swapAmount: tokenAmount,\n });\n\n if (!sorPaths?.length) {\n throw new RequestError({\n response: undefined,\n endpoint: {\n url: this.url,\n name: this.name,\n type: this.type,\n },\n reason: BaseAggregator.PATH_NOT_FOUND_REASON,\n chainId: this.chainId,\n payload: {\n tokenIn: tokenInV3.address,\n tokenOut: tokenOutV3.address,\n swapKind,\n swapAmount: tokenAmount,\n },\n message: `No swap paths returned from Balancer API`,\n });\n }\n\n // execute swap query\n const swap = new Swap({\n chainId: this.chainId,\n paths: sorPaths,\n swapKind,\n userData: \"0x\" as `0x${string}`,\n });\n const queryOutput = await swap.query(publicClient.transport.url);\n\n if (!(\"expectedAmountOut\" in queryOutput)) {\n throw new Error(\"No Bex paths found\");\n }\n\n this.checkStalePrices({\n onChainAmount: queryOutput.expectedAmountOut,\n sorPaths,\n sorAmount,\n queryData: args,\n });\n\n // format quote response\n return {\n amountOut: queryOutput.expectedAmountOut.amount.toString(),\n amountIn: amount,\n allowanceRequirements: this.parseAllowanceRequirements({\n tokenIn,\n rawAmount: amount,\n spender: queryOutput.to,\n }),\n name: this.name,\n priceImpactPercentage: this.calculatePriceImpact(priceImpact),\n swapFeeBps: 0,\n getCalldata: ({ account }) => {\n // generate user transaction data\n const callData = swap.buildCall({\n slippage: Slippage.fromPercentage(slippage.toString() as `${number}`),\n deadline: BigInt(Math.round(Date.now() / 1000) + DEFAULT_DEADLINE),\n queryOutput,\n sender: account as Address,\n recipient: account as Address,\n wethIsEth: wberaIsBera,\n });\n\n const { args: params, functionName } = decodeFunctionData({\n abi: balancerVaultAbi,\n data: callData.callData,\n });\n\n return {\n params,\n functionName,\n abi: balancerVaultAbi,\n address: callData.to,\n value: callData.value || BigInt(0),\n };\n },\n };\n }\n}\n\nexport const bex = new BexAggregator();\n","import { ChainId } from \"@berachain/config/internal\";\n\nimport { Aggregators } from \"../../../enum/dex\";\nimport { InvalidArgumentError } from \"../../../errors/InvalidArgumentError\";\nimport type {\n IAggregatorArgs,\n IRawAggregatorQuote,\n MinimalERC20,\n} from \"../../../types/dex\";\nimport { beraToken, isToken } from \"../../../utils/tokens\";\nimport { BaseAggregator } from \"./base\";\n\nclass RedeemBgtAggregator extends BaseAggregator {\n name = Aggregators.RedeemBgt;\n supportedChains = [ChainId.MAINNET, ChainId.BEPOLIA];\n readonly type = \"rpc\";\n\n checkChainSupport({\n tokenIn,\n tokenOut,\n }: {\n tokenIn: MinimalERC20;\n tokenOut: MinimalERC20;\n }): boolean {\n if (!super.checkChainSupport({ tokenIn, tokenOut })) {\n return false;\n }\n\n return (\n // only supported on same chain\n tokenIn.chainId === tokenOut.chainId &&\n isToken(tokenIn, \"BGT\", { chainId: tokenIn.chainId }) &&\n isToken(tokenOut, \"BERA\")\n );\n }\n // handles native swaps: wrap and unwrap\n async getQuote({\n tokenIn,\n amount,\n }: Omit<\n IAggregatorArgs,\n \"slippage\" | \"feeBps\" | \"tokenOut\" | \"account\"\n >): Promise<IRawAggregatorQuote> {\n this.assertChainSupport({\n tokenIn,\n tokenOut: { ...beraToken, chainId: tokenIn.chainId },\n });\n\n if (!isToken(tokenIn, \"BGT\", { config: this.config })) {\n throw new InvalidArgumentError({\n property: \"tokenIn\",\n value: tokenIn,\n expected: \"BGT\",\n level: \"warning\",\n });\n }\n\n return {\n amountOut: amount,\n amountIn: amount,\n allowanceRequirements: [],\n name: Aggregators.RedeemBgt,\n isNativeSwap: true,\n swapFeeBps: 0,\n // not adding calldata here because it depends on the connected wallet\n // bgt redeem requires a receiver address\n // moreover this is a sensitive operation, better be sure of what data is being sent\n // by controlling it on the consumer side\n } as const;\n }\n}\n\nexport const bgtRedeem = new RedeemBgtAggregator();\n","import { zeroAddress } from \"viem\";\n\nimport { ChainId } from \"@berachain/config/internal\";\n\nimport aggregatorsRouterAbi from \"@berachain/abis/meta-aggregator/metaAggregatorV2\";\n\nimport { Aggregators } from \"../../../../enum/dex\";\nimport type {\n IAggregatorArgs,\n IRawAggregatorQuote,\n} from \"../../../../types/dex\";\nimport type { IContractWrite } from \"../../../../types/global\";\nimport { BaseAggregator } from \"../base\";\n\nclass EnsoAggregator extends BaseAggregator {\n name = Aggregators.Enso;\n supportedChains = [ChainId.MAINNET];\n readonly type = \"rest\";\n needsAccountForQuote = true;\n\n notFoundMessages: string[] = [\n \"Could not build shortcuts for route\",\n \"Could not quote shortcuts for route\",\n \"Swap not found for a required underlying of defi route,\",\n \"No route found from\",\n ];\n\n async getQuote({\n tokenIn,\n tokenOut,\n amount,\n slippage,\n account = zeroAddress,\n aggregatorsFeeBps,\n proxyAggregatorsThroughVercel = false,\n rewardVault,\n }: IAggregatorArgs): Promise<IRawAggregatorQuote> {\n this.assertChainSupport({ tokenIn, tokenOut });\n\n const {\n tokenInAddress,\n tokenOutAddress,\n isTokenInNative,\n isTokenOutNative,\n } = this.parseAddresses(tokenIn.address, tokenOut.address);\n\n const inputAmountAfterFees = this.getAmountAfterFees(\n amount,\n aggregatorsFeeBps,\n );\n\n this.url = proxyAggregatorsThroughVercel\n ? `/api/aggregators?aggregator=enso`\n : `${this.config.bex.aggregatorsProxyUrl}/enso/api/v1/shortcuts/route?`;\n\n const url = new URL(this.url);\n url.searchParams.set(\n \"fromAddress\",\n this.config.bex.aggregatorsRouterExecutor,\n );\n url.searchParams.set(\"receiver\", this.config.bex.aggregatorsRouterExecutor);\n url.searchParams.set(\"spender\", this.config.bex.aggregatorsRouterExecutor);\n url.searchParams.set(\"amountIn\", inputAmountAfterFees);\n url.searchParams.set(\"tokenIn\", tokenInAddress);\n url.searchParams.set(\"tokenOut\", tokenOutAddress);\n url.searchParams.set(\"chainId\", ChainId.MAINNET.toString());\n url.searchParams.set(\"slippage\", (Number(slippage) * 100).toString());\n url.searchParams.set(\"refundReceiver\", account);\n\n const response = await this.fetch(url);\n\n const quote = await response.json();\n\n const inputData = this.getInputData({\n tokenIn: tokenInAddress,\n amountIn: amount,\n isNative: isTokenInNative,\n });\n\n const outputData = {\n tokenOut: tokenOutAddress,\n receiver: account,\n minAmountOut: this.getMinAmountOut(quote.amountOut.toString(), slippage),\n isNative: isTokenOutNative,\n };\n\n const aggregatorData = {\n aggregator: quote.tx?.to,\n data: quote.tx?.data,\n };\n\n return {\n amountOut: quote.amountOut.toString(),\n amountIn: amount,\n allowanceRequirements: this.parseAllowanceRequirements({\n tokenIn,\n rawAmount: amount,\n spender: this.config.bex.aggregatorsRouter,\n }),\n name: this.name,\n swapFeeBps: aggregatorsFeeBps!,\n getCalldata: () =>\n ({\n params: [\n inputData,\n outputData,\n aggregatorData,\n {\n rewardVault: rewardVault ?? zeroAddress,\n isSwapAndStake: !!rewardVault,\n },\n ],\n functionName: \"swap\",\n abi: aggregatorsRouterAbi,\n // send full amount to router first, which will deduct the swap fee before executing trade\n value: isTokenInNative ? BigInt(amount) : BigInt(\"0\"),\n address: this.config.bex.aggregatorsRouter,\n }) satisfies Omit<\n IContractWrite<typeof aggregatorsRouterAbi, \"swap\">,\n \"message\" | \"actionType\"\n >,\n };\n }\n}\n\nexport const enso = new EnsoAggregator();\n","import { useEffect, useState } from \"react\";\nimport { PoolType } from \"@berachain-foundation/berancer-sdk\";\n\nimport { PoolCreationStep } from \"../../enum/dex\";\nimport type { TokenCurrentPriceMap, TokenWithAmount } from \"../../types/dex\";\nimport { wrapNativeTokens } from \"../../utils/tokenWrapping\";\nimport { type Oracle, OracleMode } from \"./useCreatePool\";\n\nconst DEFAULT_LIQUIDITY_MISMATCH_TOLERANCE_PERCENT = 0.05; // 5%\n\nexport type LiquidityMismatchInfo = {\n title: string | null;\n message: string | null;\n suggestWeighted?: boolean;\n};\n\ninterface UseLiquidityMismatchParams {\n currentStep: PoolCreationStep;\n tokenPrices?: TokenCurrentPriceMap;\n isLoadingTokenPrices: boolean;\n tokens: TokenWithAmount[] | null;\n weights: bigint[] | null;\n weightsError: string | null;\n poolType: PoolType;\n liquidityMismatchTolerancePercent?: number;\n oracles: Oracle[];\n}\n\n/**\n * Hook for detecting liquidity mismatches.\n *\n * @param {PoolCreationStep} currentStep - The current step of the pool creation process.\n * @param {Record<string, number>} tokenPrices - The current token prices.\n * @param {boolean} isLoadingTokenPrices - Whether the token prices are still loading.\n * @param {Array<{ address: string, amount: number }>} tokens - The tokens in the pool, including their addresses and amounts.\n * @param {Record<string, number>} weights - The per-token weights in the pool we are creating.\n * @param {string | null} weightsError - An error message for the weights indicating that the weights are invalid.\n * @param {string} poolType - The type of pool being created.\n * @param {number} liquidityMismatchTolerancePercent - The tolerance for liquidity mismatches in percent.\n * @returns {Object} The liquidity mismatch info.\n */\nexport const useLiquidityMismatch = ({\n currentStep,\n tokenPrices,\n isLoadingTokenPrices,\n tokens,\n weights,\n weightsError,\n poolType,\n liquidityMismatchTolerancePercent = DEFAULT_LIQUIDITY_MISMATCH_TOLERANCE_PERCENT,\n oracles,\n}: UseLiquidityMismatchParams): LiquidityMismatchInfo => {\n // NOTE: would be nice to use Maps/Records more in here, as the zipping/unzipping is cumbersome.\n // NOTE: if we pull in string literal for currentStep things would also be a bit clearer in here.\n const [liquidityMismatchInfo, setLiquidityMismatchInfo] =\n useState<LiquidityMismatchInfo>({ title: null, message: null });\n\n useEffect(() => {\n // If we are either using custom rate-providing oracles or have incorrect/loading token prices, we cant do validation.\n if (\n !tokenPrices ||\n isLoadingTokenPrices ||\n !tokens ||\n !weights ||\n weightsError ||\n tokens.some((token) => !token.address) ||\n oracles.some((oracle) => oracle.mode === OracleMode.Custom) // Oracles give prices on their own, we dont support that here yet.\n ) {\n setLiquidityMismatchInfo({ title: null, message: null });\n return;\n }\n\n // Calculate some basic metrics we'll use to determine per-token contributions and model potential losses from arbitrage.\n let totalLiquidityUSD = 0;\n const tokenUSDAmounts: number[] = [];\n const numTokens = tokens.length;\n const wrappedTokens = wrapNativeTokens(tokens);\n const tokenUSDPrices = wrappedTokens.map((token) => {\n const tokenPriceUSD =\n tokenPrices[token.address.toLowerCase()]?.price ?? 0;\n if (!tokenPriceUSD || tokenPriceUSD === 0) {\n tokenUSDAmounts.push(0);\n return null;\n }\n const tokenAmountUSD = tokenPriceUSD * Number.parseFloat(token.amount);\n tokenUSDAmounts.push(tokenAmountUSD);\n totalLiquidityUSD += tokenAmountUSD;\n return tokenPriceUSD;\n });\n\n // Doesn't matter what step it is, if we have missing token prices for tokens we have selected, we cant issue a real warning.\n if (\n tokenUSDPrices.some((price) => price === null) ||\n tokenUSDPrices.length !== numTokens\n ) {\n setLiquidityMismatchInfo({\n title: \"Missing token price data\",\n message: `One or more token(s) do not have valid market price data. Please verify that token market prices align with the pool\n weightings and your initial liquidity amounts.`,\n });\n return;\n }\n\n // Step 1 - During token selection we check for a deviation in the quote prices of the tokens selected (for stable pools).\n if (\n currentStep === PoolCreationStep.SELECT_TOKENS &&\n poolType === PoolType.ComposableStable\n ) {\n const normalizedUSDPrices = tokenUSDPrices.map(\n (priceUSD) => priceUSD! / tokenUSDPrices[0]!, // always normalize on the first token's price\n );\n const maxDifference =\n Math.max(...normalizedUSDPrices) - Math.min(...normalizedUSDPrices);\n\n if (maxDifference > liquidityMismatchTolerancePercent) {\n setLiquidityMismatchInfo({\n title: \"Selected tokens have a significant price deviation\",\n message: \"Did you mean to create a Weighted pool instead?\",\n suggestWeighted: true,\n });\n } else {\n setLiquidityMismatchInfo({ title: null, message: null });\n }\n\n return;\n }\n\n // Validation During Liquidity Input and onwards.\n if (\n totalLiquidityUSD === 0 ||\n tokenUSDAmounts.some((value) => value === 0)\n ) {\n // User has not yet entered fully their liquidity values, so return early.\n setLiquidityMismatchInfo({ title: null, message: null });\n return;\n }\n\n // Simulate arbitrage for the pool to determine potential losses from arbitrageurs.\n // NOTE: we assume shortfalls and excesses are losses, but in reality the actual losses would be more complex to realise.\n // Balancer does this similarily https://github.com/balancer/frontend-v2/blob/8563b8d33b6bff266148bd48d7ebc89f921374f4/src/components/cards/CreatePool/InitialLiquidity.vue#L75\n let totalLossUSD = 0;\n if (poolType === PoolType.ComposableStable) {\n const expectedPerTokenLiquidityUSD = totalLiquidityUSD / numTokens;\n tokenUSDAmounts.forEach((value) => {\n totalLossUSD += Math.abs(expectedPerTokenLiquidityUSD - value);\n });\n } else if (poolType === PoolType.Weighted) {\n tokenUSDAmounts.forEach((value, index) => {\n const weightProportion = Number(weights[index]) / 1e18;\n const expectedValueUSD = totalLiquidityUSD * weightProportion;\n totalLossUSD += Math.abs(expectedValueUSD - value);\n });\n }\n\n // We'll show a total loss if it's 90% or more\n const isTotalLoss = totalLossUSD >= totalLiquidityUSD * 0.9;\n totalLossUSD = Math.min(totalLossUSD, totalLiquidityUSD);\n const totalLossPercentage = totalLossUSD / totalLiquidityUSD;\n\n if (totalLossPercentage > liquidityMismatchTolerancePercent) {\n setLiquidityMismatchInfo({\n // If it's a total loss we dont display a percentage\n title: isTotalLoss\n ? \"You could lose all of your initial liquidity\"\n : `You could lose $${totalLossUSD.toFixed(2)} (~${(\n totalLossPercentage * 100\n ).toFixed(2)}%)`,\n message: `Based on the market token prices, the value of tokens does not align with the specified pool weights. \n This discrepancy could expose you to potential losses from arbitrageurs. ${\n poolType === PoolType.ComposableStable\n ? \"Did you mean to create a Weighted pool instead?\"\n : \"\"\n }`,\n suggestWeighted: poolType === PoolType.ComposableStable,\n });\n } else {\n // All good bb bb\n setLiquidityMismatchInfo({ title: null, message: null });\n }\n }, [\n currentStep,\n tokenPrices,\n isLoadingTokenPrices,\n tokens,\n weights,\n weightsError,\n poolType,\n liquidityMismatchTolerancePercent,\n oracles,\n ]);\n return liquidityMismatchInfo;\n};\n","import useSWRImmutable from \"swr/immutable\";\nimport { isAddress } from \"viem\";\n\nimport { defaultChainId } from \"@berachain/config/internal\";\n\nimport { usePublicClient } from \"@berachain/wagmi/hooks\";\n\nimport { getTokenInformation } from \"../../actions/tokens/getTokenInformation\";\nimport { assertPublicClient } from \"../../errors/assert\";\nimport type { Token } from \"../../types/dex\";\nimport type {\n DefaultHookOptions,\n DefaultHookReturnType,\n} from \"../../types/global\";\n\nexport type UseMultipleTokenInformationResponse = DefaultHookReturnType<\n Token[]\n>;\n\nexport type useMultipleTokenInformationArgs = {\n addresses: string[] | readonly string[] | undefined;\n chainId?: number;\n};\nexport function useMultipleTokenInformation(\n args: useMultipleTokenInformationArgs,\n options?: DefaultHookOptions,\n): UseMultipleTokenInformationResponse {\n const publicClient = usePublicClient();\n\n const QUERY_KEY =\n publicClient && args.addresses\n ? ([\n \"useMultipleTokenInformation\",\n args.addresses,\n args.chainId ?? defaultChainId,\n ] as const)\n : null;\n\n const swrResponse = useSWRImmutable<Token[], unknown, typeof QUERY_KEY>(\n QUERY_KEY,\n async ([, addresses, chainId]) => {\n // We already checked for publicClient in the QUERY_KEY\n // so we can safely assume that publicClient is defined\n // but we need this for correct type inference\n assertPublicClient(publicClient);\n\n return Promise.all(\n addresses.map(async (address) => {\n if (!address || !isAddress(address, { strict: false })) {\n throw new Error(\"Invalid address\");\n }\n\n const tk = await getTokenInformation({\n address: address,\n publicClient,\n chainId,\n });\n\n if (!tk) {\n throw new Error(`Token ${address} not found`);\n }\n\n return tk;\n }),\n );\n },\n { ...options?.opts },\n );\n\n return {\n ...swrResponse,\n refresh: () => swrResponse?.mutate?.(),\n };\n}\n"]}
@@ -1,4 +1,4 @@
1
- import{a as Dt}from"../chunk-OGBD5YOG.mjs";import{A as zt,Aa as _o,B as jt,Ba as Qo,C as Zt,Ca as Mo,Da as Yo,E as Jt,Ea as Fo,F as fe,Fa as Go,G as Xt,Ga as Ko,H as Fe,I as to,J as oo,K as ge,L as so,N as ao,O as no,P as io,Q as lo,R as uo,T as po,U as mo,V as ie,W as co,X as be,Y as he,Z as fo,_ as go,a as Lt,aa as yo,ba as Ao,c as pe,ca as bo,da as ho,e as x,ea as Ro,f as Ht,fa as wo,g as ce,ga as ko,h as Nt,ha as Po,i as Vt,ia as Co,ja as Io,k as Wt,ka as Eo,l as _t,m as Qt,ma as So,n as V,na as xo,oa as Bo,pa as vo,q as Mt,qa as Oo,r as Yt,ra as Do,s as Ft,ta as Lo,u as Gt,v as Kt,va as Uo,w as qt,wa as Ho,x as $t,xa as No,y as Z,ya as Vo,za as Wo}from"../chunk-IBJOI5SN.mjs";import"../chunk-NLVWRMGD.mjs";import{c as _,e as Ge,g as te,l as U,m as hd,n as qo}from"../chunk-COMMLZ3O.mjs";import{a as z,c as Re}from"../chunk-FM3WDBFH.mjs";import"../chunk-NAXAZJJY.mjs";import"../chunk-T5FSQ3YE.mjs";import"../chunk-OGJMSGB2.mjs";import"../chunk-575OK77P.mjs";import{c as To}from"../chunk-BEKH5EYT.mjs";import{a as Ut,b as j,c as g,d as W,e as Qe,f as Me,g as Ae}from"../chunk-QRAIGQF2.mjs";import{b as we,c as $o}from"../chunk-MJZHJFZO.mjs";import{a as C,d as me,j as Ye,k as eo,l as ro,m as ye}from"../chunk-PLIH6KQM.mjs";import"../chunk-MK5NS5B5.mjs";import{a as E,b as N,d as de,e as k}from"../chunk-IDFMLLDY.mjs";import{f as L,g as ee,h as B}from"../chunk-74QD4JAH.mjs";import Cs from"swr";import{usePublicClient as Is}from"@berachain/wagmi/hooks";var zo=({sharesAmount:e,vaultAddress:t,vaultChainId:o},r)=>{let s=Is({chainId:o}),a=Cs(s&&e&&t?["useGetConvertToAssets",e,t,o]:null,async([i,n,l])=>(g(s),Lt({sharesAmount:n,vaultAddress:l,publicClient:s})),{...r?.opts});return{...a,refresh:()=>{a.mutate()}}};import{useMemo as Aa}from"react";import{zeroAddress as ba}from"viem";import{defaultChainId as ha}from"@berachain/config/internal";import{useBeraWallet as Ra,usePublicClient as wa}from"@berachain/wagmi/hooks";import{Slippage as Es,Swap as Ts,SwapKind as Ss,Token as jo,TokenAmount as xs}from"@berachain-foundation/berancer-sdk";import{decodeFunctionData as Bs,formatEther as Zo,zeroAddress as vs}from"viem";import{getUriFromLink as Os}from"@berachain/config";import{ChainId as Jo}from"@berachain/config/internal";import{vaultAbi as Xo}from"@berachain/abis/bex/vault";var Ds=300,Ls=.05,Ke=Ss.GivenIn,qe=class extends x{name="Hub Pools";supportedChains=[Jo.MAINNET,Jo.BEPOLIA];url=Os(this.config.api);type="graphql";convertZeroToWrapped(t){return k(t,"BERA")?this.config.tokens.wbera:t}calculatePriceImpact(t){return t.error?(console.error("Swap price impact error",t),0):Number(t.priceImpact)}checkStalePrices({onChainAmount:t,sorPaths:o,sorAmount:r,queryData:s}){let a=Number.parseFloat(Zo(t.scale18))/Number.parseFloat(r);if(Math.abs(1-a)>Ls){console.warn("SOR returned stale prices. Delta from return amount is more than 5%",{deltaFromSorAmount:a});let i=new L({reason:"SOR_STALE_PRICES",level:"warning",message:"SOR returned stale prices. Delta from return amount is more than 5%",extra:{deltaFromSorAmount:a,pools:o.map(n=>n.pools),onChainAmount:Zo(t.scale18),sorAmount:r,queryData:s},fingerprint:["SOR_STALE_PRICES"]});Ae.captureException(i)}}async getQuote(t){let o=new Ht(this.url,this.chainId),{tokenIn:r,tokenOut:s,amount:a,slippage:i,account:n=vs,publicClient:l}=t;this.assertChainSupport({tokenIn:r,tokenOut:s}),g(l);let u=k(r,"BERA")||k(s,"BERA"),m=new jo(this.chainId,this.convertZeroToWrapped(r.address),r.decimals),p=new jo(this.chainId,this.convertZeroToWrapped(s.address),s.decimals),c=xs.fromRawAmount(m,a),{paths:d,priceImpact:f,returnAmount:y}=await o.sorSwapPaths.fetchSorSwapPaths({chainId:this.chainId,tokenIn:m.address,tokenOut:p.address,swapKind:Ke,swapAmount:c});if(!d?.length)throw new ee({response:void 0,endpoint:{url:this.url,name:this.name,type:this.type},reason:x.PATH_NOT_FOUND_REASON,chainId:this.chainId,payload:{tokenIn:m.address,tokenOut:p.address,swapKind:Ke,swapAmount:c},message:"No swap paths returned from Balancer API"});let A=new Ts({chainId:this.chainId,paths:d,swapKind:Ke,userData:"0x"}),h=await A.query(l.transport.url);if(!("expectedAmountOut"in h))throw new Error("No Bex paths found");return this.checkStalePrices({onChainAmount:h.expectedAmountOut,sorPaths:d,sorAmount:y,queryData:t}),{amountOut:h.expectedAmountOut.amount.toString(),amountIn:a,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:r,rawAmount:a,spender:h.to}),name:this.name,priceImpactPercentage:this.calculatePriceImpact(f),swapFeeBps:0,getCalldata:({account:R})=>{let b=A.buildCall({slippage:Es.fromPercentage(i.toString()),deadline:BigInt(Math.round(Date.now()/1e3)+Ds),queryOutput:h,sender:R,recipient:R,wethIsEth:u}),{args:P,functionName:w}=Bs({abi:Xo,data:b.callData});return{params:P,functionName:w,abi:Xo,address:b.to,value:b.value||BigInt(0)}}}}},$e=new qe;import{ChainId as er}from"@berachain/config/internal";var ze=class extends x{name="RedeemBgt";supportedChains=[er.MAINNET,er.BEPOLIA];type="rpc";checkChainSupport({tokenIn:t,tokenOut:o}){return super.checkChainSupport({tokenIn:t,tokenOut:o})?t.chainId===o.chainId&&k(t,"BGT",{chainId:t.chainId})&&k(o,"BERA"):!1}async getQuote({tokenIn:t,amount:o}){if(this.assertChainSupport({tokenIn:t,tokenOut:{...N,chainId:t.chainId}}),!k(t,"BGT",{config:this.config}))throw new B({property:"tokenIn",value:t,expected:"BGT",level:"warning"});return{amountOut:o,amountIn:o,allowanceRequirements:[],name:"RedeemBgt",isNativeSwap:!0,swapFeeBps:0}}},tr=new ze;import{zeroAddress as or}from"viem";import{ChainId as rr}from"@berachain/config/internal";import Us from"@berachain/abis/meta-aggregator/metaAggregatorV2";var je=class extends x{name="Enso";supportedChains=[rr.MAINNET];type="rest";needsAccountForQuote=!0;notFoundMessages=["Could not build shortcuts for route","Could not quote shortcuts for route","Swap not found for a required underlying of defi route,","No route found from"];async getQuote({tokenIn:t,tokenOut:o,amount:r,slippage:s,account:a=or,aggregatorsFeeBps:i,proxyAggregatorsThroughVercel:n=!1,rewardVault:l}){this.assertChainSupport({tokenIn:t,tokenOut:o});let{tokenInAddress:u,tokenOutAddress:m,isTokenInNative:p,isTokenOutNative:c}=this.parseAddresses(t.address,o.address),d=this.getAmountAfterFees(r,i);this.url=n?"/api/aggregators?aggregator=enso":`${this.config.bex.aggregatorsProxyUrl}/enso/api/v1/shortcuts/route?`;let f=new URL(this.url);f.searchParams.set("fromAddress",this.config.bex.aggregatorsRouterExecutor),f.searchParams.set("receiver",this.config.bex.aggregatorsRouterExecutor),f.searchParams.set("spender",this.config.bex.aggregatorsRouterExecutor),f.searchParams.set("amountIn",d),f.searchParams.set("tokenIn",u),f.searchParams.set("tokenOut",m),f.searchParams.set("chainId",rr.MAINNET.toString()),f.searchParams.set("slippage",(Number(s)*100).toString()),f.searchParams.set("refundReceiver",a);let A=await(await this.fetch(f)).json(),h=this.getInputData({tokenIn:u,amountIn:r,isNative:p}),R={tokenOut:m,receiver:a,minAmountOut:this.getMinAmountOut(A.amountOut.toString(),s),isNative:c},b={aggregator:A.tx?.to,data:A.tx?.data};return{amountOut:A.amountOut.toString(),amountIn:r,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:this.config.bex.aggregatorsRouter}),name:this.name,swapFeeBps:i,getCalldata:()=>({params:[h,R,b,{rewardVault:l??or,isSwapAndStake:!!l}],functionName:"swap",abi:Us,value:BigInt(p?r:"0"),address:this.config.bex.aggregatorsRouter})}}},Ze=new je;import{erc4626Abi as sr,formatUnits as Hs}from"viem";import{wberaStakerVaultAbi as Ns}from"@berachain/abis/pol/wberaStakerVault";var Je=class extends x{name="Mint";supportedChains=null;type="rpc";checkChainSupport({tokenIn:t,tokenOut:o,underlyingToken:r}){return super.checkChainSupport({tokenIn:t,tokenOut:o,underlyingToken:r})&&!!r&&r?.chainId===o.chainId&&(k(r,t)||k(t,"BERA")&&k(o,"SWBERA"))}async getQuote({tokenIn:t,tokenOut:o,amount:r,underlyingToken:s,publicClient:a}){this.assertChainSupport({tokenIn:t,tokenOut:o,underlyingToken:s}),j(s,"underlyingToken"),g(a);let i=await a.readContract({address:o.address,abi:sr,functionName:"convertToShares",args:[BigInt(r)]}),n=k(o,"SWBERA")&&k(t,"BERA");return{amountOut:i.toString(),amountIn:r,allowanceRequirements:n?[]:[{token:t,spender:o.address,amount:{raw:r,formatted:Hs(BigInt(r),t.decimals)}}],name:"Mint",isNativeSwap:!1,swapFeeBps:0,getCalldata:({account:l})=>n?{abi:Ns,address:o.address,functionName:"depositNative",params:[BigInt(r),l],value:BigInt(r)}:{abi:sr,address:o.address,functionName:"deposit",contractName:"others.erc4626",params:[BigInt(r),l],value:0n}}}},Xe=new Je;import{zeroAddress as Vs}from"viem";import{ChainId as Ws}from"@berachain/config/internal";import _s from"@berachain/abis/meta-aggregator/metaAggregatorV2";var ar="https://api.fly.trade/aggregator",et=class extends x{name="Fly";supportedChains=[Ws.MAINNET];type="rest";notFoundMessages=["Couldn't recognize to token","Couldn't recognize from token","There is not enough liquidity. Amount is too high.","Routes were not found"];async getQuote({tokenIn:t,tokenOut:o,amount:r,slippage:s,account:a,aggregatorsFeeBps:i,rewardVault:n}){this.assertChainSupport({tokenIn:t,tokenOut:o});let{tokenInAddress:l,tokenOutAddress:u,isTokenInNative:m,isTokenOutNative:p}=this.parseAddresses(t.address,o.address),c=this.getAmountAfterFees(r,i),d=new URL(`${ar}/quote`);this.url=d.toString();let f=new URLSearchParams({fromTokenAddress:l,toTokenAddress:u,sellAmount:c,slippage:(s/100).toString(),gasless:"false",network:"berachain"});f.set("fromAddress",this.config.bex.aggregatorsRouterExecutor),f.set("toAddress",this.config.bex.aggregatorsRouterExecutor),d.search=f.toString();let A=await(await this.fetch(d)).json(),h={amountOut:A.amountOut,amountIn:r,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:this.config.bex.aggregatorsRouter}),name:this.name,swapFeeBps:i??0},R=new URL(`${ar}/transaction`);this.url=R.toString();let b=new URLSearchParams({quoteId:A.id,estimateGas:"false"});R.search=b.toString();let w=await(await this.fetch(R)).json();return{...h,getCalldata:({account:I})=>{let T=this.getInputData({tokenIn:l,amountIn:r,isNative:m}),S={tokenOut:u,receiver:I,minAmountOut:this.getMinAmountOut(A.amountOut,s),isNative:p},O={aggregator:w?.to,data:w?.data};return{params:[T,S,O,{rewardVault:n??Vs,isSwapAndStake:!!n}],functionName:"swap",abi:_s,value:k(t,"BERA")?BigInt(r):BigInt("0"),address:this.config.bex.aggregatorsRouter}}}}},tt=new et;import{formatUnits as Qs,parseUnits as Ms,zeroAddress as Ys}from"viem";import{ChainId as Fs}from"@berachain/config/internal";import Gs from"@berachain/abis/meta-aggregator/metaAggregatorV2";var ot=class extends x{name="Haiku";supportedChains=[Fs.MAINNET];type="rest";notFoundMessages=["token not found","Token is not supported","No route found for the given input or the liquidity is not enough","Invalid input amount. Please ensure the total amount of input is greater than 0.001 USD"];async getQuote({tokenIn:t,tokenOut:o,amount:r,slippage:s,aggregatorsFeeBps:a,proxyAggregatorsThroughVercel:i=!1,referrer:n,rewardVault:l}){if(t.decimals===void 0||o.decimals===void 0)throw new L({message:"Missing required params",level:"error"});this.assertChainSupport({tokenIn:t,tokenOut:o});let{tokenInAddress:u,tokenOutAddress:m,isTokenInNative:p,isTokenOutNative:c}=this.parseAddresses(t.address,o.address),d=this.getAmountAfterFees(r,a),f={intent:{allowancesMode:"approve",slippage:s/100,receiver:this.config.bex.aggregatorsRouterExecutor,input_positions:{[`bera:${u}`]:Qs(BigInt(d),t.decimals)},target_weights:{[`bera:${m}`]:1}}},y=n==="ZAP"?"zap-haiku":"haiku";this.url=i?"/api/aggregators?aggregator=haikuQuote":`${this.config.bex.aggregatorsProxyUrl}/${y}/v1/quoteIntent`;let h=await(await this.fetch(this.url,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(f)})).json(),R={amountOut:Ms(h.balances[0].amount,o.decimals).toString(),amountIn:r,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:this.config.bex.aggregatorsRouter}),name:this.name,swapFeeBps:a};this.url=i?"/api/aggregators?aggregator=haikuSolve":`${this.config.bex.aggregatorsProxyUrl}/${y}/v1/solveIntent`;let P=await(await this.fetch(this.url,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({quoteId:h.quoteId})})).json();return{...R,getCalldata:({account:w})=>{let I=this.getInputData({tokenIn:u,amountIn:r,isNative:p,isPermit2Approval:!0,permit2SpenderAddress:this.config.bex.haikuAgentAddress}),T={tokenOut:m,receiver:w,minAmountOut:this.getMinAmountOut(R.amountOut,s),isNative:c},S={aggregator:P.to,data:P.data};return{params:[I,T,S,{rewardVault:l??Ys,isSwapAndStake:!!l}],functionName:"swap",abi:Gs,value:BigInt(p?r:"0"),address:this.config.bex.aggregatorsRouter}}}}},rt=new ot;import{formatUnits as nr}from"viem";import{ChainId as Ks}from"@berachain/config/internal";function qs(e){return e?"previewMintHoney":"previewRedeemCollaterals"}var st=class extends x{name="Honey";supportedChains=[Ks.MAINNET];type="rpc";honeyToken=de(this);isHoneyNativeSwap({tokenIn:t,tokenOut:o,honeyNativeState:r,...s}){if(!r?.collateralList)return!1;let a=k(o,"HONEY",s),i=k(t,"HONEY",s);return!a&&!i?!1:r.collateralList.some(n=>k(n.address,a?t:o))}checkChainSupport({tokenIn:t,tokenOut:o,honeyNativeState:r}){return super.checkChainSupport({tokenIn:t,tokenOut:o})&&t.chainId===o.chainId&&this.isHoneyNativeSwap({tokenIn:t.address,tokenOut:o.address,honeyNativeState:r})}async getQuote({tokenIn:t,tokenOut:o,amount:r,publicClient:s,account:a,honeyNativeState:i}){let{collateralList:n}=i??{};if(!n)throw new B({message:"Invalid Honey Context state",property:"collaterals",value:n,expected:"TokenWithOrder[]"});g(s),this.assertChainSupport({tokenIn:t,tokenOut:o});let l=k(o,this.honeyToken),u=n,m=n.find(I=>k(I.address,l?t.address:o.address));if(!m)throw new L({message:"This collateral is not part of the Honey protocol"});let[p,c]=await Promise.all([fe({client:s,collateralList:[m]}),ge({client:s,isMint:l,collateralList:n,latestPrices:void 0,isPythWrapperEnabled:!1})]);if(!p)throw new L({message:"Failed to fetch the Honey vault balances"});if(c)return;let d=p[0],f=m.order;u.length>1&&f!==0&&(u.splice(f,1),u.unshift(m));let y=nr(BigInt(r),l?m.decimals:this.honeyToken.decimals),A={client:s,collateral:m,collateralList:n,amount:y,method:qs(l),latestPrices:void 0,isPythWrapperEnabled:!1},h=await Jt(A);if(!h)throw new L({message:"Failed to fetch the Honey preview"});let{honey:R,collaterals:b}=h;if(!(l?!0:new C(d?.balance.formatted??"0").gte(nr(b[m.address],m.decimals))))return;let w=await oo({state:{actionType:l?"mint":"redeem",fromAmount:[y],collaterals:u,isBasketModeEnabled:!1},collateralList:u,publicClient:s,priceFeedMap:void 0,isPythWrapperEnabled:!1});if(!w&&a)throw new L({message:"Failed to fetch the Honey swap payload"});return{amountIn:r,amountOut:l?R.toString():b[m.address].toString(),allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:this.config.bex.aggregatorsRouter}),name:"Honey",swapFeeBps:0,getCalldata:({account:I})=>w({account:I})}}},at=new st;import{zeroAddress as $s}from"viem";import{ChainId as zs}from"@berachain/config/internal";import js from"@berachain/abis/meta-aggregator/metaAggregatorV2";var nt=class extends x{name="KyberSwap";supportedChains=[zs.MAINNET];type="rest";notFoundMessages=["token not found","route not found","amountIn is greater than max allowed"];async getQuote({tokenIn:t,tokenOut:o,amount:r,slippage:s,aggregatorsFeeBps:a,proxyAggregatorsThroughVercel:i=!1,rewardVault:n}){this.assertChainSupport({tokenIn:t,tokenOut:o});let{isTokenInNative:l,isTokenOutNative:u,tokenInAddress:m,tokenOutAddress:p}=this.parseAddresses(t.address,o.address),c=this.getAmountAfterFees(r,a);this.url=i?"/api/aggregators?aggregator=kyberswapRoutes":`${this.config.bex.aggregatorsProxyUrl}/kyberswap/berachain/api/v1/routes`;let d=new URL(this.url);d.searchParams.set("tokenIn",m),d.searchParams.set("tokenOut",p),d.searchParams.set("amountIn",c),d.searchParams.set("slippageTolerance",(s/100).toString()),d.searchParams.set("to",this.config.bex.aggregatorsRouterExecutor),d.searchParams.set("clientData",JSON.stringify({source:"berachain"}));let y=await(await this.fetch(d)).json(),A={amountOut:y.data.routeSummary.amountOut,amountIn:r,name:this.name,swapFeeBps:a,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:this.config.bex.aggregatorsRouter})},h={routeSummary:y.data.routeSummary,sender:this.config.bex.aggregatorsRouterExecutor,recipient:this.config.bex.aggregatorsRouterExecutor,slippageTolerance:s*100,deadline:Math.floor(Date.now()/1e3)+300,source:"berachain"},R=d.searchParams.entries(),b=new URL(i?"/api/aggregators?aggregator=kyberswapBuild":`${this.config.bex.aggregatorsProxyUrl}/kyberswap/berachain/api/v1/route/build`);for(let[T,S]of R)b.searchParams.set(T,S);let w=await(await this.fetch(b,{method:"POST",body:JSON.stringify(h)})).json(),I=this.getInputData({tokenIn:m,amountIn:r,isNative:l});return{...A,getCalldata:({account:T})=>{let S={tokenOut:p,receiver:T,minAmountOut:this.getMinAmountOut(A.amountOut,s),isNative:u},O={aggregator:w.data.routerAddress,data:w.data.data};return{params:[I,S,O,{rewardVault:n??$s,isSwapAndStake:!!n}],functionName:"swap",abi:js,value:BigInt(l?r:"0"),address:this.config.bex.aggregatorsRouter}}}}},it=new nt;import{zeroAddress as Zs}from"viem";import{ChainId as Js}from"@berachain/config/internal";import Xs from"@berachain/abis/meta-aggregator/metaAggregatorV2";var lt=class extends x{name="Oogabooga";supportedChains=[Js.MAINNET];type="rest";async getQuote({tokenIn:t,tokenOut:o,amount:r,slippage:s,aggregatorsFeeBps:a,proxyAggregatorsThroughVercel:i=!1,rewardVault:n}){this.assertChainSupport({tokenIn:t,tokenOut:o});let{tokenInAddress:l,tokenOutAddress:u,isTokenInNative:m,isTokenOutNative:p}=this.parseAddresses(t.address,o.address),c=this.getAmountAfterFees(r,a),d=new URLSearchParams({tokenIn:l,tokenOut:u,amount:c,slippage:(s/100).toString(),to:this.config.bex.aggregatorsRouterExecutor,referrer:this.config.bex.aggregatorsRouter});this.url=i?`/api/aggregators?aggregator=oogabooga&${d.toString()}`:`${this.config.bex.aggregatorsProxyUrl}/oogabooga/v1/swap?${d.toString()}`;let y=await(await this.fetch(this.url)).json(),A={amountOut:y.assumedAmountOut,amountIn:r,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,spender:this.config.bex.aggregatorsRouter,rawAmount:r}),name:this.name,priceImpactPercentage:y.priceImpact,swapFeeBps:a};return{...A,getCalldata:({account:h})=>{let R=this.getInputData({tokenIn:l,amountIn:r,isNative:m}),b={tokenOut:u,receiver:h,minAmountOut:this.getMinAmountOut(A.amountOut,s),isNative:p},P={aggregator:y.tx?.to,data:y.tx?.data};return{params:[R,b,P,{rewardVault:n??Zs,isSwapAndStake:!!n}],functionName:"swap",abi:Xs,value:BigInt(m?r:"0"),address:this.config.bex.aggregatorsRouter}}}}},ut=new lt;import{zeroAddress as ir}from"viem";import{ChainId as lr}from"@berachain/config/internal";import ea from"@berachain/abis/meta-aggregator/metaAggregatorV2";var pt=class extends x{name="OpenOcean";supportedChains=[lr.MAINNET];type="rest";url="https://open-api.openocean.finance/v4/bera/swap";notFoundMessages=["No avail liquidity for the pair"];async getQuote({tokenIn:t,tokenOut:o,amount:r,slippage:s,account:a=ir,aggregatorsFeeBps:i,publicClient:n,rewardVault:l}){if(g(n),!t.decimals)throw new B({property:"tokenIn.decimals",value:t.decimals,expected:"number",chainId:this.chainId});this.assertChainSupport({tokenIn:t,tokenOut:o});let u=this.getAmountAfterFees(r,i),{tokenInAddress:m,tokenOutAddress:p,isTokenInNative:c,isTokenOutNative:d}=this.parseAddresses(t.address,o.address),f=(await n.getGasPrice()).toString(),y=new URLSearchParams({chain:lr.MAINNET.toString(),inTokenAddress:m,outTokenAddress:p,amountDecimals:u,slippage:s<.01?"0.01":s.toString(),account:this.config.bex.aggregatorsRouterExecutor,referrer:this.config.bex.aggregatorsRouter,gasPrice:f}),A=await this.fetch(`${this.url}?${y.toString()}`),h=await A.json();if(h.code!==200||!h.data){let b=this.notFoundMessages.some(P=>h.error.includes(P));throw new ee({response:A,endpoint:{url:this.url,name:this.name,type:this.type},cause:h,reason:b?x.PATH_NOT_FOUND_REASON:h.error})}let R={amountOut:h.data.outAmount,amountIn:r,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:this.config.bex.aggregatorsRouter}),name:this.name,swapFeeBps:i};return{...R,getCalldata:({account:b})=>{let P=this.getInputData({tokenIn:m,amountIn:r,isNative:c}),w={tokenOut:p,receiver:b,minAmountOut:this.getMinAmountOut(R.amountOut,s),isNative:d},I={aggregator:h.data.to,data:h.data.data};return{params:[P,w,I,{rewardVault:l??ir,isSwapAndStake:!!l}],functionName:"swap",abi:ea,value:BigInt(c?r:"0"),address:this.config.bex.aggregatorsRouter}}}}},mt=new pt;import{ChainId as ur}from"@berachain/config/internal";import{wberaAbi as pr}from"@berachain/abis/wbera";var dt=class extends x{name="Wrap";supportedChains=[ur.MAINNET,ur.BEPOLIA];type="rpc";checkChainSupport({tokenIn:t,tokenOut:o}){return t.chainId!==o.chainId||!super.checkChainSupport({tokenIn:t,tokenOut:o})?!1:k(t,"BERA")&&k(o,"WBERA")||k(t,"WBERA")&&k(o,"BERA")}async getQuote({tokenIn:t,tokenOut:o,amount:r}){this.assertChainSupport({tokenIn:t,tokenOut:o});let s=k(t,"BERA")&&k(o,"WBERA");return{amountOut:r,amountIn:r,allowanceRequirements:[],name:s?"Wrap":"Unwrap",isNativeSwap:!0,swapFeeBps:0,getCalldata:()=>s?{abi:pr,address:this.config.tokens.wbera,functionName:"deposit",params:[],value:BigInt(r)}:{abi:pr,address:this.config.tokens.wbera,functionName:"withdraw",params:[BigInt(r)],value:BigInt(0)}}}},ct=new dt;import ra from"swr/immutable";import{useConfig as sa}from"@berachain/wagmi/hooks";import{getPublicClient as ta}from"@wagmi/core";import{erc4626Abi as oa}from"viem";async function mr({token:e,wagmiConfig:t}){try{if(k(e,"BERA"))return null;let o=ta(t,{chainId:e.chainId});g(o);let r=await o.readContract({address:e.address,abi:oa,functionName:"asset"});return await Z({address:r,publicClient:o,chainId:e.chainId})}catch(o){let r=Ut({cause:o});if(r.reason==='The contract function "asset" reverted.')return null;throw r}}function dr({token:e}){let t=sa();return ra(e&&t&&!k(e,"BERA")?["useUnderlyingAsset",e]:null,async([,o])=>mr({token:o,wagmiConfig:t}))}import aa from"swr/immutable";import{zeroAddress as na}from"viem";import ia from"@berachain/abis/meta-aggregator/metaAggregatorV2";import{usePublicClient as la}from"@berachain/wagmi/hooks";var ke=()=>{let e=la(),{config:t}=E({chainId:e.chain?.id}),o=aa(e&&t.bex.aggregatorsRouter&&t.bex.aggregatorsRouter!==na?["useAggregatorsRouterFeeBps",t.bex.aggregatorsRouter]:null,async([,r])=>{let s=await e.readContract({address:r,abi:ia,functionName:"SWAP_FEE_RATE"});return Number(s)});return{...o,refresh:o.mutate}};import ua from"swr";import{parseUnits as pa,zeroAddress as ma}from"viem";import{useBeraWallet as da,usePublicClient as ca}from"@berachain/wagmi/hooks";var cr="useAggregatorsQuotes";function fa({aggregator:e,account:t,args:o,feeBps:r,options:s,activeAggregators:a,isMAEnabled:i}){if(s?.opts?.isEnabled!==void 0&&!s?.opts?.isEnabled||!Number(o.amount)||!e.checkChainSupport({tokenIn:o.tokenIn,tokenOut:o.tokenOut,underlyingToken:o.underlyingToken,honeyNativeState:o.honeyNativeState}))return null;let n=e.name,l=!["Hub Pools","Honey","Wrap","Unwrap","Mint"].includes(n);if(!i&&l)return null;let{tokenIn:u,tokenOut:m,amount:p,slippage:c,referrer:d,rewardVault:f}=o,y=pa(p,u.decimals).toString();if(!(e.name==="Wrap"||e.name==="RedeemBgt"||e.name==="Honey"||!a||a.includes(n.toLowerCase().replaceAll(" ","")))||e.name==="Honey"&&o.honeyNativeState?.protocol.isPaused)return null;let h=e.name==="Mint"||e.name==="Enso (Mint)";return l&&r===void 0?null:[cr,n,u,m,y,c,e.needsAccountForQuote?t:void 0,l?r:0,d,f,h?o.underlyingToken:void 0,e.name==="Honey"?o.honeyNativeState?.collateralList:void 0]}function ga({aggregator:e,publicClient:t,proxyAggregatorsThroughVercel:o}){return async([,,r,s,a,i,n,l,u,m,p,c])=>e.getQuote({tokenIn:r,tokenOut:s,amount:a,slippage:i,account:n,aggregatorsFeeBps:l,publicClient:t,proxyAggregatorsThroughVercel:o,referrer:u,rewardVault:m,underlyingToken:p,honeyNativeState:{collateralList:c??[]}})}function Q({feeBps:e,publicClient:t,account:o,proxyAggregatorsThroughVercel:r,activeAggregators:s,isMAEnabled:a,...i},n){return ua(fa({aggregator:i.aggregator,account:o,args:i,feeBps:e,options:n,activeAggregators:s,isMAEnabled:a}),ga({aggregator:i.aggregator,proxyAggregatorsThroughVercel:r,publicClient:t}),n?.opts)}function ft(e){return{refreshInterval:1e4,errorRetryCount:3,...e?.opts,onErrorRetry(t,o,r,s,a){if(e?.opts?.onErrorRetry?.(t,o,r,s,a),!(t instanceof L&&t.reason===x.PATH_NOT_FOUND_REASON)){if(t instanceof ee&&t.statusCode===403){console.warn(o[1],"returned error 403, stopping retries");return}a.retryCount>(r.errorRetryCount??3)||setTimeout(()=>{s()},r.errorRetryInterval??ye(10))}}}}function ya(e,t){let{address:o}=da(),r=_("proxyAggregatorsThroughVercel"),s=_("aggregators"),a=ca(),{data:i}=ke();if(e.aggregator.name!=="Wrap"&&!((k(e.tokenIn.address,"BERA")||k(e.tokenIn.address,"WBERA"))&&(k(e.tokenOut.address,"BERA")||k(e.tokenOut.address,"WBERA"))))return null;let{config:n}=E(e),l=n.bex.aggregatorsRouter!==ma;return Q({...e,aggregator:e.aggregator,feeBps:i,activeAggregators:s,account:o,isMAEnabled:l,publicClient:a,proxyAggregatorsThroughVercel:r},{...t,opts:ft(t)})}var ka=[ut,tt,it,mt,rt,Ze,$e,at,Xe];function jf(e,t){let{address:o}=Ra(),r=_("proxyAggregatorsThroughVercel"),s=_("aggregators"),a=wa(),{data:i}=ke(),n=(k(e.tokenIn.address,"BERA")||k(e.tokenIn.address,"WBERA"))&&(k(e.tokenOut.address,"BERA")||k(e.tokenOut.address,"WBERA")),l=k(e.tokenIn.address,"BGT",{chainId:ha}),{data:u}=dr({token:e.tokenOut}),m=n||l,{config:p}=E(e),c=p.bex.aggregatorsRouter!==ba,d=ft(t),f={activeAggregators:s,isMAEnabled:c,underlyingToken:u,isNativeSwap:m,account:o,publicClient:a,proxyAggregatorsThroughVercel:r,feeBps:i},y=Q({...f,...e,aggregator:ut},{opts:d}),A=Q({...f,...e,aggregator:tt},{opts:d}),h=Q({...f,...e,aggregator:Xe},{opts:d}),R=Q({...f,...e,aggregator:it},{opts:d}),b=Q({...f,...e,aggregator:mt},{opts:d}),P=Q({...f,...e,aggregator:rt},{opts:d}),w=Q({...f,...e,aggregator:Ze},{opts:d}),{protocol:I}=Ge(),T=Q({...f,...e,aggregator:$e},{opts:{...d,isEnabled:I.isPaused===!1}}),S=Q({...f,...e,aggregator:ct}),O=Q({...f,...e,aggregator:tr},{opts:d}),H=Q({...f,...e,aggregator:at},{opts:d}),v=n?[S]:l?[O]:[y,h,A,R,b,P,w,H,I.isPaused===!1?T:null].filter(M=>M!==null);return{...Aa(()=>{let M=v.reduce((D,q)=>D||q.error,void 0),$=v.map((D,q)=>D.isLoading?m?ct.name:ka[q].name:null).filter(Boolean),F=v.filter(D=>D!==void 0&&!D.isLoading&&!D.error&&D.data?.amountOut).map(({data:D})=>D),G=F.length===0&&$.length>0;return{quotes:F,loadingAggregatorsNames:$,isLoading:G,error:M}},[v]),refresh:()=>v.map(M=>M.mutate())}}import Pa from"swr";var Ca=({query:e}={})=>["useAllUserPools",e],fr=(e,t)=>{let o=Pa(Ca({query:e}),async([r,s])=>ce({...s,fetchPolicy:"no-cache"}),{refreshInterval:18e4,...t?.opts});return{...o,refresh:()=>{o.mutate()}}};import Ia from"swr";import{isAddress as Ea}from"viem";var Ta=({poolId:e,account:t})=>e?["usePool-api",e,t]:null;function gr({poolId:e,account:t}){let o=Ia(Ta({poolId:e,account:t}),async([,r,s])=>{if(s&&!Ea(s))throw new B({property:"account",value:s,expected:"Address"});return Nt({poolId:r,account:s})},{refreshInterval:1e5});return{...o,refresh:()=>{o.mutate()}}}import{useMemo as hr}from"react";import{PoolType as Pe}from"@berachain-foundation/berancer-sdk";import xa from"swr/immutable";import{formatUnits as Ba,keccak256 as va,parseUnits as Ce,zeroAddress as yt}from"viem";import{poolCreationHelperAbi as Rr}from"@berachain/abis/bex/poolCreationHelper";import{GetDedupedSubgraphPools as Oa}from"@berachain/graphql/dex/subgraph";import{PoolType as yr}from"@berachain-foundation/berancer-sdk";import{formatUnits as Sa}from"viem";var gt=e=>[...e].sort((t,o)=>t.address.toLowerCase().localeCompare(o.address.toLowerCase())),Ar=e=>e.length===0?"":gt(e).map(t=>t.symbol).join(" | "),br=(e,t,o)=>{let r;switch(o){case yr.ComposableStable:r="STABLE";break;default:r=o.toString().toUpperCase();break}return o===yr.Weighted?t.length===0?"":`${gt(e).map((s,a)=>{let i=t[a];return`${(Number.parseFloat(Sa(i,18))*100).toFixed(0)}${s.symbol}`}).join("-")}-${r}`:`${gt(e).map(s=>s.symbol).join("-")}-${r}`};var Da=.005,La=(o=>(o.None="None",o.Custom="Custom",o))(La||{}),Ua=({poolCreationHelper:e,poolCreateTokens:t,initialLiquidityTokens:o,swapFeePercentage:r,salt:s,poolName:a,poolSymbol:i,owner:n,amplification:l,oracles:u,message:m,actionType:p,gasLimit:c=Ye})=>{let d=t.map(w=>w.address.toLowerCase()).sort((w,I)=>w<I?-1:1),f=d.map(w=>{let I=o.find(v=>v.address.toLowerCase()===w||k(w,"WBERA")&&k(v.address,"BERA")),T=I?Ce(I.amount,I.decimals):0n,S=u.find(v=>v.tokenAddress.toLowerCase()===w.toLowerCase()),O=S?S.address:yt,H=BigInt(S?S.cacheDuration:100);return{amountIn:T,rateProvider:O,cacheDuration:H}}),y=f.map(w=>w.amountIn),A=f.map(w=>w.rateProvider),h=f.map(w=>w.cacheDuration),R=o.findIndex(w=>k(w.address,"BERA")),b=R!==-1?Ce(o[R].amount,o[R].decimals):0n,P=b>0n;return{address:e,abi:Rr,functionName:"createAndJoinStablePool",params:[a,i,d,BigInt(l),A,h,!1,r,y,n,s,P],message:m,actionType:p,value:b,gasLimit:c,track:{eventName:"hub_pool_create",eventData:{poolName:a,poolSymbol:i}}}},Ha=({poolCreationHelper:e,poolCreateTokens:t,initialLiquidityTokens:o,normalizedWeights:r,swapFeePercentage:s,salt:a,poolName:i,poolSymbol:n,owner:l,message:u,actionType:m,gasLimit:p=Ye})=>{let c=[],d=[],f=[],y=[];t.map((R,b)=>({createToken:R.address,joinToken:o[b].address,weight:r[b],amountIn:Ce(o[b].amount,o[b].decimals)})).sort((R,b)=>R.createToken.toLowerCase()<b.createToken.toLowerCase()?-1:1).forEach(R=>{c.push(R.createToken),d.push(R.joinToken),f.push(R.weight),y.push(R.amountIn)});let A=d.indexOf(yt),h=A!==-1?y[A]:0n;return{address:e,abi:Rr,functionName:"createAndJoinWeightedPool",params:[i,n,c,d,f,Array(c.length).fill(yt),s,y,l,a],message:u,actionType:m,value:h,gasLimit:p,track:{eventName:"hub_pool_create",eventData:{poolName:i,poolSymbol:n}}}},wg=({poolCreateTokens:e,initialLiquidityTokens:t,normalizedWeights:o,poolType:r,poolName:s,poolSymbol:a,swapFee:i,owner:n,amplification:l,oracles:u,weightsDuplicationThreshold:m=Da,...p})=>{let{data:c,error:d,isLoading:f}=xa(["useCreatePool__deduped_pool",e,r,o],async()=>{if(e.length===0||!r)return null;let R=pe("bex.subgraph",{});try{let b=we(e).map(I=>I.address.toLowerCase()).sort((I,T)=>I.toLowerCase()<T.toLowerCase()?-1:1);return(await R.query({query:Oa,variables:{tokens:b,type:r}})).data.pools.filter(I=>I.tokens?.every(T=>r===Pe.Weighted?b.includes(T.address)&&Math.abs(Number(T.weight)-Number(Ba(o[b.indexOf(T.address)],18)))<m:b.includes(T.address)||T.address===I.address))?.at(0)??null}catch{return null}}),{generatedPoolName:y,generatedPoolSymbol:A}=hr(()=>{if(!e)return{generatedPoolName:"",generatedPoolSymbol:""};let R=Ar(e),b=br(e,o,r);return{generatedPoolName:R,generatedPoolSymbol:b}},[e,o,r]),h=hr(()=>{if(!n||s===""||a===""||e.length!==t.length||e.length===0)return null;let R=Ce(i.toString(),16),b=va(Buffer.from(`${s}-${n}`)),{config:P}=E(p);return r===Pe.Weighted?Ha({poolCreationHelper:P.bex.poolCreationHelper,poolCreateTokens:e,initialLiquidityTokens:t,normalizedWeights:o,swapFeePercentage:R,salt:b,poolName:s,poolSymbol:a,owner:n,message:`Create pool ${s}`,actionType:"Create Pool"}):r===Pe.ComposableStable||r===Pe.MetaStable?Ua({poolCreationHelper:P.bex.poolCreationHelper,poolCreateTokens:e,initialLiquidityTokens:t,swapFeePercentage:R,salt:b,poolName:s,poolSymbol:a,owner:n,amplification:l,oracles:u,message:`Create pool ${s}`,actionType:"Create Pool"}):null},[e,t,o,r,i,s,a,n,l,u]);return{generatedPoolName:y,generatedPoolSymbol:A,isDupePool:!!c,dupePool:c,createPoolArgs:h,isLoadingPools:f,errorLoadingPools:d}};import Qa from"swr";import{usePublicClient as Ma}from"@berachain/wagmi/hooks";import{erc20Abi as Na,formatUnits as Va}from"viem";import{GetExploitedTokens as Wa}from"@berachain/graphql/dex/subgraph";var _a=1e-4;async function wr({token:e,publicClient:t,...o}){let r=pe("bex.subgraph",o),s=await t.readContract({address:e.address,abi:Na,functionName:"totalSupply"}),a=C(Va(s,e.decimals)).multipliedBy(_a),{data:i}=await r.query({query:Wa,variables:{token:e.address,balance:a.toFixed()}});return i.userInternalBalances.length>0}var Ya=e=>{let t=e?.filter(o=>o.address);return!t||t.length===0?null:["useExploitedTokens",t]},Og=({tokens:e})=>{let t=Ya(e),o=Ma(),r=Qa(o?t:null,async([,s])=>(g(o),(await Promise.all(s.map(i=>wr({token:i,publicClient:o})))).reduce((i,n,l)=>(n!==void 0&&(i[s[l].address]=n),i),{})));return{...r,refresh:()=>r.mutate()}};import Fa from"swr";var Ga=()=>{let e=Fa("useGlobalLiquidityAndSwapVolume",async()=>Vt());return{...e,data:{totalLiquidity:Number(e.data?.protocolMetricsAggregated.totalLiquidity),swapVolume24h:Number(e.data?.protocolMetricsAggregated.swapVolume24h)},refresh:()=>e.mutate()}};import{useEffect as Ka,useState as qa}from"react";import{PoolType as le}from"@berachain-foundation/berancer-sdk";var $a=.05,_g=({currentStep:e,tokenPrices:t,isLoadingTokenPrices:o,tokens:r,weights:s,weightsError:a,poolType:i,liquidityMismatchTolerancePercent:n=$a,oracles:l})=>{let[u,m]=qa({title:null,message:null});return Ka(()=>{if(!t||o||!r||!s||a||r.some(b=>!b.address)||l.some(b=>b.mode==="Custom")){m({title:null,message:null});return}let p=0,c=[],d=r.length,y=we(r).map(b=>{let P=t[b.address.toLowerCase()]?.price??0;if(!P||P===0)return c.push(0),null;let w=P*Number.parseFloat(b.amount);return c.push(w),p+=w,P});if(y.some(b=>b===null)||y.length!==d){m({title:"Missing token price data",message:`One or more token(s) do not have valid market price data. Please verify that token market prices align with the pool
1
+ import{a as Dt}from"../chunk-OGBD5YOG.mjs";import{A as zt,Aa as _o,B as jt,Ba as Qo,C as Zt,Ca as Mo,Da as Yo,E as Jt,Ea as Fo,F as fe,Fa as Go,G as Xt,Ga as Ko,H as Fe,I as to,J as oo,K as ge,L as so,N as ao,O as no,P as io,Q as lo,R as uo,T as po,U as mo,V as ie,W as co,X as be,Y as he,Z as fo,_ as go,a as Lt,aa as yo,ba as Ao,c as pe,ca as bo,da as ho,e as x,ea as Ro,f as Ht,fa as wo,g as ce,ga as ko,h as Nt,ha as Po,i as Vt,ia as Co,ja as Io,k as Wt,ka as Eo,l as _t,m as Qt,ma as So,n as V,na as xo,oa as Bo,pa as vo,q as Mt,qa as Oo,r as Yt,ra as Do,s as Ft,ta as Lo,u as Gt,v as Kt,va as Uo,w as qt,wa as Ho,x as $t,xa as No,y as Z,ya as Vo,za as Wo}from"../chunk-WIN4PK2Z.mjs";import"../chunk-NLVWRMGD.mjs";import{c as _,e as Ge,g as te,l as U,m as hd,n as qo}from"../chunk-KRVNPZLF.mjs";import{a as z,c as Re}from"../chunk-3ZTAIOHH.mjs";import"../chunk-NAXAZJJY.mjs";import"../chunk-T5FSQ3YE.mjs";import"../chunk-OGJMSGB2.mjs";import"../chunk-575OK77P.mjs";import{b as we,c as $o}from"../chunk-MJZHJFZO.mjs";import{a as C,d as me,j as Ye,k as eo,l as ro,m as ye}from"../chunk-PLIH6KQM.mjs";import"../chunk-MK5NS5B5.mjs";import{a as E,b as N,d as de,e as k}from"../chunk-IDFMLLDY.mjs";import{c as To}from"../chunk-BEKH5EYT.mjs";import{a as Ut,b as j,c as g,d as W,e as Qe,f as Me,g as Ae}from"../chunk-QRAIGQF2.mjs";import{f as L,g as ee,h as B}from"../chunk-74QD4JAH.mjs";import Cs from"swr";import{usePublicClient as Is}from"@berachain/wagmi/hooks";var zo=({sharesAmount:e,vaultAddress:t,vaultChainId:o},r)=>{let s=Is({chainId:o}),a=Cs(s&&e&&t?["useGetConvertToAssets",e,t,o]:null,async([i,n,l])=>(g(s),Lt({sharesAmount:n,vaultAddress:l,publicClient:s})),{...r?.opts});return{...a,refresh:()=>{a.mutate()}}};import{useMemo as Aa}from"react";import{zeroAddress as ba}from"viem";import{defaultChainId as ha}from"@berachain/config/internal";import{useBeraWallet as Ra,usePublicClient as wa}from"@berachain/wagmi/hooks";import{Slippage as Es,Swap as Ts,SwapKind as Ss,Token as jo,TokenAmount as xs}from"@berachain-foundation/berancer-sdk";import{decodeFunctionData as Bs,formatEther as Zo,zeroAddress as vs}from"viem";import{getUriFromLink as Os}from"@berachain/config";import{ChainId as Jo}from"@berachain/config/internal";import{vaultAbi as Xo}from"@berachain/abis/bex/vault";var Ds=300,Ls=.05,Ke=Ss.GivenIn,qe=class extends x{name="Hub Pools";supportedChains=[Jo.MAINNET,Jo.BEPOLIA];url=Os(this.config.api);type="graphql";convertZeroToWrapped(t){return k(t,"BERA")?this.config.tokens.wbera:t}calculatePriceImpact(t){return t.error?(console.error("Swap price impact error",t),0):Number(t.priceImpact)}checkStalePrices({onChainAmount:t,sorPaths:o,sorAmount:r,queryData:s}){let a=Number.parseFloat(Zo(t.scale18))/Number.parseFloat(r);if(Math.abs(1-a)>Ls){console.warn("SOR returned stale prices. Delta from return amount is more than 5%",{deltaFromSorAmount:a});let i=new L({reason:"SOR_STALE_PRICES",level:"warning",message:"SOR returned stale prices. Delta from return amount is more than 5%",extra:{deltaFromSorAmount:a,pools:o.map(n=>n.pools),onChainAmount:Zo(t.scale18),sorAmount:r,queryData:s},fingerprint:["SOR_STALE_PRICES"]});Ae.captureException(i)}}async getQuote(t){let o=new Ht(this.url,this.chainId),{tokenIn:r,tokenOut:s,amount:a,slippage:i,account:n=vs,publicClient:l}=t;this.assertChainSupport({tokenIn:r,tokenOut:s}),g(l);let u=k(r,"BERA")||k(s,"BERA"),m=new jo(this.chainId,this.convertZeroToWrapped(r.address),r.decimals),p=new jo(this.chainId,this.convertZeroToWrapped(s.address),s.decimals),c=xs.fromRawAmount(m,a),{paths:d,priceImpact:f,returnAmount:y}=await o.sorSwapPaths.fetchSorSwapPaths({chainId:this.chainId,tokenIn:m.address,tokenOut:p.address,swapKind:Ke,swapAmount:c});if(!d?.length)throw new ee({response:void 0,endpoint:{url:this.url,name:this.name,type:this.type},reason:x.PATH_NOT_FOUND_REASON,chainId:this.chainId,payload:{tokenIn:m.address,tokenOut:p.address,swapKind:Ke,swapAmount:c},message:"No swap paths returned from Balancer API"});let A=new Ts({chainId:this.chainId,paths:d,swapKind:Ke,userData:"0x"}),h=await A.query(l.transport.url);if(!("expectedAmountOut"in h))throw new Error("No Bex paths found");return this.checkStalePrices({onChainAmount:h.expectedAmountOut,sorPaths:d,sorAmount:y,queryData:t}),{amountOut:h.expectedAmountOut.amount.toString(),amountIn:a,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:r,rawAmount:a,spender:h.to}),name:this.name,priceImpactPercentage:this.calculatePriceImpact(f),swapFeeBps:0,getCalldata:({account:R})=>{let b=A.buildCall({slippage:Es.fromPercentage(i.toString()),deadline:BigInt(Math.round(Date.now()/1e3)+Ds),queryOutput:h,sender:R,recipient:R,wethIsEth:u}),{args:P,functionName:w}=Bs({abi:Xo,data:b.callData});return{params:P,functionName:w,abi:Xo,address:b.to,value:b.value||BigInt(0)}}}}},$e=new qe;import{ChainId as er}from"@berachain/config/internal";var ze=class extends x{name="RedeemBgt";supportedChains=[er.MAINNET,er.BEPOLIA];type="rpc";checkChainSupport({tokenIn:t,tokenOut:o}){return super.checkChainSupport({tokenIn:t,tokenOut:o})?t.chainId===o.chainId&&k(t,"BGT",{chainId:t.chainId})&&k(o,"BERA"):!1}async getQuote({tokenIn:t,amount:o}){if(this.assertChainSupport({tokenIn:t,tokenOut:{...N,chainId:t.chainId}}),!k(t,"BGT",{config:this.config}))throw new B({property:"tokenIn",value:t,expected:"BGT",level:"warning"});return{amountOut:o,amountIn:o,allowanceRequirements:[],name:"RedeemBgt",isNativeSwap:!0,swapFeeBps:0}}},tr=new ze;import{zeroAddress as or}from"viem";import{ChainId as rr}from"@berachain/config/internal";import Us from"@berachain/abis/meta-aggregator/metaAggregatorV2";var je=class extends x{name="Enso";supportedChains=[rr.MAINNET];type="rest";needsAccountForQuote=!0;notFoundMessages=["Could not build shortcuts for route","Could not quote shortcuts for route","Swap not found for a required underlying of defi route,","No route found from"];async getQuote({tokenIn:t,tokenOut:o,amount:r,slippage:s,account:a=or,aggregatorsFeeBps:i,proxyAggregatorsThroughVercel:n=!1,rewardVault:l}){this.assertChainSupport({tokenIn:t,tokenOut:o});let{tokenInAddress:u,tokenOutAddress:m,isTokenInNative:p,isTokenOutNative:c}=this.parseAddresses(t.address,o.address),d=this.getAmountAfterFees(r,i);this.url=n?"/api/aggregators?aggregator=enso":`${this.config.bex.aggregatorsProxyUrl}/enso/api/v1/shortcuts/route?`;let f=new URL(this.url);f.searchParams.set("fromAddress",this.config.bex.aggregatorsRouterExecutor),f.searchParams.set("receiver",this.config.bex.aggregatorsRouterExecutor),f.searchParams.set("spender",this.config.bex.aggregatorsRouterExecutor),f.searchParams.set("amountIn",d),f.searchParams.set("tokenIn",u),f.searchParams.set("tokenOut",m),f.searchParams.set("chainId",rr.MAINNET.toString()),f.searchParams.set("slippage",(Number(s)*100).toString()),f.searchParams.set("refundReceiver",a);let A=await(await this.fetch(f)).json(),h=this.getInputData({tokenIn:u,amountIn:r,isNative:p}),R={tokenOut:m,receiver:a,minAmountOut:this.getMinAmountOut(A.amountOut.toString(),s),isNative:c},b={aggregator:A.tx?.to,data:A.tx?.data};return{amountOut:A.amountOut.toString(),amountIn:r,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:this.config.bex.aggregatorsRouter}),name:this.name,swapFeeBps:i,getCalldata:()=>({params:[h,R,b,{rewardVault:l??or,isSwapAndStake:!!l}],functionName:"swap",abi:Us,value:BigInt(p?r:"0"),address:this.config.bex.aggregatorsRouter})}}},Ze=new je;import{erc4626Abi as sr,formatUnits as Hs}from"viem";import{wberaStakerVaultAbi as Ns}from"@berachain/abis/pol/wberaStakerVault";var Je=class extends x{name="Mint";supportedChains=null;type="rpc";checkChainSupport({tokenIn:t,tokenOut:o,underlyingToken:r}){return super.checkChainSupport({tokenIn:t,tokenOut:o,underlyingToken:r})&&!!r&&r?.chainId===o.chainId&&(k(r,t)||k(t,"BERA")&&k(o,"SWBERA"))}async getQuote({tokenIn:t,tokenOut:o,amount:r,underlyingToken:s,publicClient:a}){this.assertChainSupport({tokenIn:t,tokenOut:o,underlyingToken:s}),j(s,"underlyingToken"),g(a);let i=await a.readContract({address:o.address,abi:sr,functionName:"convertToShares",args:[BigInt(r)]}),n=k(o,"SWBERA")&&k(t,"BERA");return{amountOut:i.toString(),amountIn:r,allowanceRequirements:n?[]:[{token:t,spender:o.address,amount:{raw:r,formatted:Hs(BigInt(r),t.decimals)}}],name:"Mint",isNativeSwap:!1,swapFeeBps:0,getCalldata:({account:l})=>n?{abi:Ns,address:o.address,functionName:"depositNative",params:[BigInt(r),l],value:BigInt(r)}:{abi:sr,address:o.address,functionName:"deposit",contractName:"others.erc4626",params:[BigInt(r),l],value:0n}}}},Xe=new Je;import{zeroAddress as Vs}from"viem";import{ChainId as Ws}from"@berachain/config/internal";import _s from"@berachain/abis/meta-aggregator/metaAggregatorV2";var ar="https://api.fly.trade/aggregator",et=class extends x{name="Fly";supportedChains=[Ws.MAINNET];type="rest";notFoundMessages=["Couldn't recognize to token","Couldn't recognize from token","There is not enough liquidity. Amount is too high.","Routes were not found"];async getQuote({tokenIn:t,tokenOut:o,amount:r,slippage:s,account:a,aggregatorsFeeBps:i,rewardVault:n}){this.assertChainSupport({tokenIn:t,tokenOut:o});let{tokenInAddress:l,tokenOutAddress:u,isTokenInNative:m,isTokenOutNative:p}=this.parseAddresses(t.address,o.address),c=this.getAmountAfterFees(r,i),d=new URL(`${ar}/quote`);this.url=d.toString();let f=new URLSearchParams({fromTokenAddress:l,toTokenAddress:u,sellAmount:c,slippage:(s/100).toString(),gasless:"false",network:"berachain"});f.set("fromAddress",this.config.bex.aggregatorsRouterExecutor),f.set("toAddress",this.config.bex.aggregatorsRouterExecutor),d.search=f.toString();let A=await(await this.fetch(d)).json(),h={amountOut:A.amountOut,amountIn:r,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:this.config.bex.aggregatorsRouter}),name:this.name,swapFeeBps:i??0},R=new URL(`${ar}/transaction`);this.url=R.toString();let b=new URLSearchParams({quoteId:A.id,estimateGas:"false"});R.search=b.toString();let w=await(await this.fetch(R)).json();return{...h,getCalldata:({account:I})=>{let T=this.getInputData({tokenIn:l,amountIn:r,isNative:m}),S={tokenOut:u,receiver:I,minAmountOut:this.getMinAmountOut(A.amountOut,s),isNative:p},O={aggregator:w?.to,data:w?.data};return{params:[T,S,O,{rewardVault:n??Vs,isSwapAndStake:!!n}],functionName:"swap",abi:_s,value:k(t,"BERA")?BigInt(r):BigInt("0"),address:this.config.bex.aggregatorsRouter}}}}},tt=new et;import{formatUnits as Qs,parseUnits as Ms,zeroAddress as Ys}from"viem";import{ChainId as Fs}from"@berachain/config/internal";import Gs from"@berachain/abis/meta-aggregator/metaAggregatorV2";var ot=class extends x{name="Haiku";supportedChains=[Fs.MAINNET];type="rest";notFoundMessages=["token not found","Token is not supported","No route found for the given input or the liquidity is not enough","Invalid input amount. Please ensure the total amount of input is greater than 0.001 USD"];async getQuote({tokenIn:t,tokenOut:o,amount:r,slippage:s,aggregatorsFeeBps:a,proxyAggregatorsThroughVercel:i=!1,referrer:n,rewardVault:l}){if(t.decimals===void 0||o.decimals===void 0)throw new L({message:"Missing required params",level:"error"});this.assertChainSupport({tokenIn:t,tokenOut:o});let{tokenInAddress:u,tokenOutAddress:m,isTokenInNative:p,isTokenOutNative:c}=this.parseAddresses(t.address,o.address),d=this.getAmountAfterFees(r,a),f={intent:{allowancesMode:"approve",slippage:s/100,receiver:this.config.bex.aggregatorsRouterExecutor,input_positions:{[`bera:${u}`]:Qs(BigInt(d),t.decimals)},target_weights:{[`bera:${m}`]:1}}},y=n==="ZAP"?"zap-haiku":"haiku";this.url=i?"/api/aggregators?aggregator=haikuQuote":`${this.config.bex.aggregatorsProxyUrl}/${y}/v1/quoteIntent`;let h=await(await this.fetch(this.url,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(f)})).json(),R={amountOut:Ms(h.balances[0].amount,o.decimals).toString(),amountIn:r,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:this.config.bex.aggregatorsRouter}),name:this.name,swapFeeBps:a};this.url=i?"/api/aggregators?aggregator=haikuSolve":`${this.config.bex.aggregatorsProxyUrl}/${y}/v1/solveIntent`;let P=await(await this.fetch(this.url,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({quoteId:h.quoteId})})).json();return{...R,getCalldata:({account:w})=>{let I=this.getInputData({tokenIn:u,amountIn:r,isNative:p,isPermit2Approval:!0,permit2SpenderAddress:this.config.bex.haikuAgentAddress}),T={tokenOut:m,receiver:w,minAmountOut:this.getMinAmountOut(R.amountOut,s),isNative:c},S={aggregator:P.to,data:P.data};return{params:[I,T,S,{rewardVault:l??Ys,isSwapAndStake:!!l}],functionName:"swap",abi:Gs,value:BigInt(p?r:"0"),address:this.config.bex.aggregatorsRouter}}}}},rt=new ot;import{formatUnits as nr}from"viem";import{ChainId as Ks}from"@berachain/config/internal";function qs(e){return e?"previewMintHoney":"previewRedeemCollaterals"}var st=class extends x{name="Honey";supportedChains=[Ks.MAINNET];type="rpc";honeyToken=de(this);isHoneyNativeSwap({tokenIn:t,tokenOut:o,honeyNativeState:r,...s}){if(!r?.collateralList)return!1;let a=k(o,"HONEY",s),i=k(t,"HONEY",s);return!a&&!i?!1:r.collateralList.some(n=>k(n.address,a?t:o))}checkChainSupport({tokenIn:t,tokenOut:o,honeyNativeState:r}){return super.checkChainSupport({tokenIn:t,tokenOut:o})&&t.chainId===o.chainId&&this.isHoneyNativeSwap({tokenIn:t.address,tokenOut:o.address,honeyNativeState:r})}async getQuote({tokenIn:t,tokenOut:o,amount:r,publicClient:s,account:a,honeyNativeState:i}){let{collateralList:n}=i??{};if(!n)throw new B({message:"Invalid Honey Context state",property:"collaterals",value:n,expected:"TokenWithOrder[]"});g(s),this.assertChainSupport({tokenIn:t,tokenOut:o});let l=k(o,this.honeyToken),u=n,m=n.find(I=>k(I.address,l?t.address:o.address));if(!m)throw new L({message:"This collateral is not part of the Honey protocol"});let[p,c]=await Promise.all([fe({client:s,collateralList:[m]}),ge({client:s,isMint:l,collateralList:n,latestPrices:void 0,isPythWrapperEnabled:!1})]);if(!p)throw new L({message:"Failed to fetch the Honey vault balances"});if(c)return;let d=p[0],f=m.order;u.length>1&&f!==0&&(u.splice(f,1),u.unshift(m));let y=nr(BigInt(r),l?m.decimals:this.honeyToken.decimals),A={client:s,collateral:m,collateralList:n,amount:y,method:qs(l),latestPrices:void 0,isPythWrapperEnabled:!1},h=await Jt(A);if(!h)throw new L({message:"Failed to fetch the Honey preview"});let{honey:R,collaterals:b}=h;if(!(l?!0:new C(d?.balance.formatted??"0").gte(nr(b[m.address],m.decimals))))return;let w=await oo({state:{actionType:l?"mint":"redeem",fromAmount:[y],collaterals:u,isBasketModeEnabled:!1},collateralList:u,publicClient:s,priceFeedMap:void 0,isPythWrapperEnabled:!1});if(!w&&a)throw new L({message:"Failed to fetch the Honey swap payload"});return{amountIn:r,amountOut:l?R.toString():b[m.address].toString(),allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:this.config.bex.aggregatorsRouter}),name:"Honey",swapFeeBps:0,getCalldata:({account:I})=>w({account:I})}}},at=new st;import{zeroAddress as $s}from"viem";import{ChainId as zs}from"@berachain/config/internal";import js from"@berachain/abis/meta-aggregator/metaAggregatorV2";var nt=class extends x{name="KyberSwap";supportedChains=[zs.MAINNET];type="rest";notFoundMessages=["token not found","route not found","amountIn is greater than max allowed"];async getQuote({tokenIn:t,tokenOut:o,amount:r,slippage:s,aggregatorsFeeBps:a,proxyAggregatorsThroughVercel:i=!1,rewardVault:n}){this.assertChainSupport({tokenIn:t,tokenOut:o});let{isTokenInNative:l,isTokenOutNative:u,tokenInAddress:m,tokenOutAddress:p}=this.parseAddresses(t.address,o.address),c=this.getAmountAfterFees(r,a);this.url=i?"/api/aggregators?aggregator=kyberswapRoutes":`${this.config.bex.aggregatorsProxyUrl}/kyberswap/berachain/api/v1/routes`;let d=new URL(this.url);d.searchParams.set("tokenIn",m),d.searchParams.set("tokenOut",p),d.searchParams.set("amountIn",c),d.searchParams.set("slippageTolerance",(s/100).toString()),d.searchParams.set("to",this.config.bex.aggregatorsRouterExecutor),d.searchParams.set("clientData",JSON.stringify({source:"berachain"}));let y=await(await this.fetch(d)).json(),A={amountOut:y.data.routeSummary.amountOut,amountIn:r,name:this.name,swapFeeBps:a,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:this.config.bex.aggregatorsRouter})},h={routeSummary:y.data.routeSummary,sender:this.config.bex.aggregatorsRouterExecutor,recipient:this.config.bex.aggregatorsRouterExecutor,slippageTolerance:s*100,deadline:Math.floor(Date.now()/1e3)+300,source:"berachain"},R=d.searchParams.entries(),b=new URL(i?"/api/aggregators?aggregator=kyberswapBuild":`${this.config.bex.aggregatorsProxyUrl}/kyberswap/berachain/api/v1/route/build`);for(let[T,S]of R)b.searchParams.set(T,S);let w=await(await this.fetch(b,{method:"POST",body:JSON.stringify(h)})).json(),I=this.getInputData({tokenIn:m,amountIn:r,isNative:l});return{...A,getCalldata:({account:T})=>{let S={tokenOut:p,receiver:T,minAmountOut:this.getMinAmountOut(A.amountOut,s),isNative:u},O={aggregator:w.data.routerAddress,data:w.data.data};return{params:[I,S,O,{rewardVault:n??$s,isSwapAndStake:!!n}],functionName:"swap",abi:js,value:BigInt(l?r:"0"),address:this.config.bex.aggregatorsRouter}}}}},it=new nt;import{zeroAddress as Zs}from"viem";import{ChainId as Js}from"@berachain/config/internal";import Xs from"@berachain/abis/meta-aggregator/metaAggregatorV2";var lt=class extends x{name="Oogabooga";supportedChains=[Js.MAINNET];type="rest";async getQuote({tokenIn:t,tokenOut:o,amount:r,slippage:s,aggregatorsFeeBps:a,proxyAggregatorsThroughVercel:i=!1,rewardVault:n}){this.assertChainSupport({tokenIn:t,tokenOut:o});let{tokenInAddress:l,tokenOutAddress:u,isTokenInNative:m,isTokenOutNative:p}=this.parseAddresses(t.address,o.address),c=this.getAmountAfterFees(r,a),d=new URLSearchParams({tokenIn:l,tokenOut:u,amount:c,slippage:(s/100).toString(),to:this.config.bex.aggregatorsRouterExecutor,referrer:this.config.bex.aggregatorsRouter});this.url=i?`/api/aggregators?aggregator=oogabooga&${d.toString()}`:`${this.config.bex.aggregatorsProxyUrl}/oogabooga/v1/swap?${d.toString()}`;let y=await(await this.fetch(this.url)).json(),A={amountOut:y.assumedAmountOut,amountIn:r,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,spender:this.config.bex.aggregatorsRouter,rawAmount:r}),name:this.name,priceImpactPercentage:y.priceImpact,swapFeeBps:a};return{...A,getCalldata:({account:h})=>{let R=this.getInputData({tokenIn:l,amountIn:r,isNative:m}),b={tokenOut:u,receiver:h,minAmountOut:this.getMinAmountOut(A.amountOut,s),isNative:p},P={aggregator:y.tx?.to,data:y.tx?.data};return{params:[R,b,P,{rewardVault:n??Zs,isSwapAndStake:!!n}],functionName:"swap",abi:Xs,value:BigInt(m?r:"0"),address:this.config.bex.aggregatorsRouter}}}}},ut=new lt;import{zeroAddress as ir}from"viem";import{ChainId as lr}from"@berachain/config/internal";import ea from"@berachain/abis/meta-aggregator/metaAggregatorV2";var pt=class extends x{name="OpenOcean";supportedChains=[lr.MAINNET];type="rest";url="https://open-api.openocean.finance/v4/bera/swap";notFoundMessages=["No avail liquidity for the pair"];async getQuote({tokenIn:t,tokenOut:o,amount:r,slippage:s,account:a=ir,aggregatorsFeeBps:i,publicClient:n,rewardVault:l}){if(g(n),!t.decimals)throw new B({property:"tokenIn.decimals",value:t.decimals,expected:"number",chainId:this.chainId});this.assertChainSupport({tokenIn:t,tokenOut:o});let u=this.getAmountAfterFees(r,i),{tokenInAddress:m,tokenOutAddress:p,isTokenInNative:c,isTokenOutNative:d}=this.parseAddresses(t.address,o.address),f=(await n.getGasPrice()).toString(),y=new URLSearchParams({chain:lr.MAINNET.toString(),inTokenAddress:m,outTokenAddress:p,amountDecimals:u,slippage:s<.01?"0.01":s.toString(),account:this.config.bex.aggregatorsRouterExecutor,referrer:this.config.bex.aggregatorsRouter,gasPrice:f}),A=await this.fetch(`${this.url}?${y.toString()}`),h=await A.json();if(h.code!==200||!h.data){let b=this.notFoundMessages.some(P=>h.error.includes(P));throw new ee({response:A,endpoint:{url:this.url,name:this.name,type:this.type},cause:h,reason:b?x.PATH_NOT_FOUND_REASON:h.error})}let R={amountOut:h.data.outAmount,amountIn:r,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:this.config.bex.aggregatorsRouter}),name:this.name,swapFeeBps:i};return{...R,getCalldata:({account:b})=>{let P=this.getInputData({tokenIn:m,amountIn:r,isNative:c}),w={tokenOut:p,receiver:b,minAmountOut:this.getMinAmountOut(R.amountOut,s),isNative:d},I={aggregator:h.data.to,data:h.data.data};return{params:[P,w,I,{rewardVault:l??ir,isSwapAndStake:!!l}],functionName:"swap",abi:ea,value:BigInt(c?r:"0"),address:this.config.bex.aggregatorsRouter}}}}},mt=new pt;import{ChainId as ur}from"@berachain/config/internal";import{wberaAbi as pr}from"@berachain/abis/wbera";var dt=class extends x{name="Wrap";supportedChains=[ur.MAINNET,ur.BEPOLIA];type="rpc";checkChainSupport({tokenIn:t,tokenOut:o}){return t.chainId!==o.chainId||!super.checkChainSupport({tokenIn:t,tokenOut:o})?!1:k(t,"BERA")&&k(o,"WBERA")||k(t,"WBERA")&&k(o,"BERA")}async getQuote({tokenIn:t,tokenOut:o,amount:r}){this.assertChainSupport({tokenIn:t,tokenOut:o});let s=k(t,"BERA")&&k(o,"WBERA");return{amountOut:r,amountIn:r,allowanceRequirements:[],name:s?"Wrap":"Unwrap",isNativeSwap:!0,swapFeeBps:0,getCalldata:()=>s?{abi:pr,address:this.config.tokens.wbera,functionName:"deposit",params:[],value:BigInt(r)}:{abi:pr,address:this.config.tokens.wbera,functionName:"withdraw",params:[BigInt(r)],value:BigInt(0)}}}},ct=new dt;import ra from"swr/immutable";import{useConfig as sa}from"@berachain/wagmi/hooks";import{getPublicClient as ta}from"@wagmi/core";import{erc4626Abi as oa}from"viem";async function mr({token:e,wagmiConfig:t}){try{if(k(e,"BERA"))return null;let o=ta(t,{chainId:e.chainId});g(o);let r=await o.readContract({address:e.address,abi:oa,functionName:"asset"});return await Z({address:r,publicClient:o,chainId:e.chainId})}catch(o){let r=Ut({cause:o});if(r.reason==='The contract function "asset" reverted.')return null;throw r}}function dr({token:e}){let t=sa();return ra(e&&t&&!k(e,"BERA")?["useUnderlyingAsset",e]:null,async([,o])=>mr({token:o,wagmiConfig:t}))}import aa from"swr/immutable";import{zeroAddress as na}from"viem";import ia from"@berachain/abis/meta-aggregator/metaAggregatorV2";import{usePublicClient as la}from"@berachain/wagmi/hooks";var ke=()=>{let e=la(),{config:t}=E({chainId:e.chain?.id}),o=aa(e&&t.bex.aggregatorsRouter&&t.bex.aggregatorsRouter!==na?["useAggregatorsRouterFeeBps",t.bex.aggregatorsRouter]:null,async([,r])=>{let s=await e.readContract({address:r,abi:ia,functionName:"SWAP_FEE_RATE"});return Number(s)});return{...o,refresh:o.mutate}};import ua from"swr";import{parseUnits as pa,zeroAddress as ma}from"viem";import{useBeraWallet as da,usePublicClient as ca}from"@berachain/wagmi/hooks";var cr="useAggregatorsQuotes";function fa({aggregator:e,account:t,args:o,feeBps:r,options:s,activeAggregators:a,isMAEnabled:i}){if(s?.opts?.isEnabled!==void 0&&!s?.opts?.isEnabled||!Number(o.amount)||!e.checkChainSupport({tokenIn:o.tokenIn,tokenOut:o.tokenOut,underlyingToken:o.underlyingToken,honeyNativeState:o.honeyNativeState}))return null;let n=e.name,l=!["Hub Pools","Honey","Wrap","Unwrap","Mint"].includes(n);if(!i&&l)return null;let{tokenIn:u,tokenOut:m,amount:p,slippage:c,referrer:d,rewardVault:f}=o,y=pa(p,u.decimals).toString();if(!(e.name==="Wrap"||e.name==="RedeemBgt"||e.name==="Honey"||!a||a.includes(n.toLowerCase().replaceAll(" ","")))||e.name==="Honey"&&o.honeyNativeState?.protocol.isPaused)return null;let h=e.name==="Mint"||e.name==="Enso (Mint)";return l&&r===void 0?null:[cr,n,u,m,y,c,e.needsAccountForQuote?t:void 0,l?r:0,d,f,h?o.underlyingToken:void 0,e.name==="Honey"?o.honeyNativeState?.collateralList:void 0]}function ga({aggregator:e,publicClient:t,proxyAggregatorsThroughVercel:o}){return async([,,r,s,a,i,n,l,u,m,p,c])=>e.getQuote({tokenIn:r,tokenOut:s,amount:a,slippage:i,account:n,aggregatorsFeeBps:l,publicClient:t,proxyAggregatorsThroughVercel:o,referrer:u,rewardVault:m,underlyingToken:p,honeyNativeState:{collateralList:c??[]}})}function Q({feeBps:e,publicClient:t,account:o,proxyAggregatorsThroughVercel:r,activeAggregators:s,isMAEnabled:a,...i},n){return ua(fa({aggregator:i.aggregator,account:o,args:i,feeBps:e,options:n,activeAggregators:s,isMAEnabled:a}),ga({aggregator:i.aggregator,proxyAggregatorsThroughVercel:r,publicClient:t}),n?.opts)}function ft(e){return{refreshInterval:1e4,errorRetryCount:3,...e?.opts,onErrorRetry(t,o,r,s,a){if(e?.opts?.onErrorRetry?.(t,o,r,s,a),!(t instanceof L&&t.reason===x.PATH_NOT_FOUND_REASON)){if(t instanceof ee&&t.statusCode===403){console.warn(o[1],"returned error 403, stopping retries");return}a.retryCount>(r.errorRetryCount??3)||setTimeout(()=>{s()},r.errorRetryInterval??ye(10))}}}}function ya(e,t){let{address:o}=da(),r=_("proxyAggregatorsThroughVercel"),s=_("aggregators"),a=ca(),{data:i}=ke();if(e.aggregator.name!=="Wrap"&&!((k(e.tokenIn.address,"BERA")||k(e.tokenIn.address,"WBERA"))&&(k(e.tokenOut.address,"BERA")||k(e.tokenOut.address,"WBERA"))))return null;let{config:n}=E(e),l=n.bex.aggregatorsRouter!==ma;return Q({...e,aggregator:e.aggregator,feeBps:i,activeAggregators:s,account:o,isMAEnabled:l,publicClient:a,proxyAggregatorsThroughVercel:r},{...t,opts:ft(t)})}var ka=[ut,tt,it,mt,rt,Ze,$e,at,Xe];function jf(e,t){let{address:o}=Ra(),r=_("proxyAggregatorsThroughVercel"),s=_("aggregators"),a=wa(),{data:i}=ke(),n=(k(e.tokenIn.address,"BERA")||k(e.tokenIn.address,"WBERA"))&&(k(e.tokenOut.address,"BERA")||k(e.tokenOut.address,"WBERA")),l=k(e.tokenIn.address,"BGT",{chainId:ha}),{data:u}=dr({token:e.tokenOut}),m=n||l,{config:p}=E(e),c=p.bex.aggregatorsRouter!==ba,d=ft(t),f={activeAggregators:s,isMAEnabled:c,underlyingToken:u,isNativeSwap:m,account:o,publicClient:a,proxyAggregatorsThroughVercel:r,feeBps:i},y=Q({...f,...e,aggregator:ut},{opts:d}),A=Q({...f,...e,aggregator:tt},{opts:d}),h=Q({...f,...e,aggregator:Xe},{opts:d}),R=Q({...f,...e,aggregator:it},{opts:d}),b=Q({...f,...e,aggregator:mt},{opts:d}),P=Q({...f,...e,aggregator:rt},{opts:d}),w=Q({...f,...e,aggregator:Ze},{opts:d}),{protocol:I}=Ge(),T=Q({...f,...e,aggregator:$e},{opts:{...d,isEnabled:I.isPaused===!1}}),S=Q({...f,...e,aggregator:ct}),O=Q({...f,...e,aggregator:tr},{opts:d}),H=Q({...f,...e,aggregator:at},{opts:d}),v=n?[S]:l?[O]:[y,h,A,R,b,P,w,H,I.isPaused===!1?T:null].filter(M=>M!==null);return{...Aa(()=>{let M=v.reduce((D,q)=>D||q.error,void 0),$=v.map((D,q)=>D.isLoading?m?ct.name:ka[q].name:null).filter(Boolean),F=v.filter(D=>D!==void 0&&!D.isLoading&&!D.error&&D.data?.amountOut).map(({data:D})=>D),G=F.length===0&&$.length>0;return{quotes:F,loadingAggregatorsNames:$,isLoading:G,error:M}},[v]),refresh:()=>v.map(M=>M.mutate())}}import Pa from"swr";var Ca=({query:e}={})=>["useAllUserPools",e],fr=(e,t)=>{let o=Pa(Ca({query:e}),async([r,s])=>ce({...s,fetchPolicy:"no-cache"}),{refreshInterval:18e4,...t?.opts});return{...o,refresh:()=>{o.mutate()}}};import Ia from"swr";import{isAddress as Ea}from"viem";var Ta=({poolId:e,account:t})=>e?["usePool-api",e,t]:null;function gr({poolId:e,account:t}){let o=Ia(Ta({poolId:e,account:t}),async([,r,s])=>{if(s&&!Ea(s))throw new B({property:"account",value:s,expected:"Address"});return Nt({poolId:r,account:s})},{refreshInterval:1e5});return{...o,refresh:()=>{o.mutate()}}}import{useMemo as hr}from"react";import{PoolType as Pe}from"@berachain-foundation/berancer-sdk";import xa from"swr/immutable";import{formatUnits as Ba,keccak256 as va,parseUnits as Ce,zeroAddress as yt}from"viem";import{poolCreationHelperAbi as Rr}from"@berachain/abis/bex/poolCreationHelper";import{GetDedupedSubgraphPools as Oa}from"@berachain/graphql/dex/subgraph";import{PoolType as yr}from"@berachain-foundation/berancer-sdk";import{formatUnits as Sa}from"viem";var gt=e=>[...e].sort((t,o)=>t.address.toLowerCase().localeCompare(o.address.toLowerCase())),Ar=e=>e.length===0?"":gt(e).map(t=>t.symbol).join(" | "),br=(e,t,o)=>{let r;switch(o){case yr.ComposableStable:r="STABLE";break;default:r=o.toString().toUpperCase();break}return o===yr.Weighted?t.length===0?"":`${gt(e).map((s,a)=>{let i=t[a];return`${(Number.parseFloat(Sa(i,18))*100).toFixed(0)}${s.symbol}`}).join("-")}-${r}`:`${gt(e).map(s=>s.symbol).join("-")}-${r}`};var Da=.005,La=(o=>(o.None="None",o.Custom="Custom",o))(La||{}),Ua=({poolCreationHelper:e,poolCreateTokens:t,initialLiquidityTokens:o,swapFeePercentage:r,salt:s,poolName:a,poolSymbol:i,owner:n,amplification:l,oracles:u,message:m,actionType:p,gasLimit:c=Ye})=>{let d=t.map(w=>w.address.toLowerCase()).sort((w,I)=>w<I?-1:1),f=d.map(w=>{let I=o.find(v=>v.address.toLowerCase()===w||k(w,"WBERA")&&k(v.address,"BERA")),T=I?Ce(I.amount,I.decimals):0n,S=u.find(v=>v.tokenAddress.toLowerCase()===w.toLowerCase()),O=S?S.address:yt,H=BigInt(S?S.cacheDuration:100);return{amountIn:T,rateProvider:O,cacheDuration:H}}),y=f.map(w=>w.amountIn),A=f.map(w=>w.rateProvider),h=f.map(w=>w.cacheDuration),R=o.findIndex(w=>k(w.address,"BERA")),b=R!==-1?Ce(o[R].amount,o[R].decimals):0n,P=b>0n;return{address:e,abi:Rr,functionName:"createAndJoinStablePool",params:[a,i,d,BigInt(l),A,h,!1,r,y,n,s,P],message:m,actionType:p,value:b,gasLimit:c,track:{eventName:"hub_pool_create",eventData:{poolName:a,poolSymbol:i}}}},Ha=({poolCreationHelper:e,poolCreateTokens:t,initialLiquidityTokens:o,normalizedWeights:r,swapFeePercentage:s,salt:a,poolName:i,poolSymbol:n,owner:l,message:u,actionType:m,gasLimit:p=Ye})=>{let c=[],d=[],f=[],y=[];t.map((R,b)=>({createToken:R.address,joinToken:o[b].address,weight:r[b],amountIn:Ce(o[b].amount,o[b].decimals)})).sort((R,b)=>R.createToken.toLowerCase()<b.createToken.toLowerCase()?-1:1).forEach(R=>{c.push(R.createToken),d.push(R.joinToken),f.push(R.weight),y.push(R.amountIn)});let A=d.indexOf(yt),h=A!==-1?y[A]:0n;return{address:e,abi:Rr,functionName:"createAndJoinWeightedPool",params:[i,n,c,d,f,Array(c.length).fill(yt),s,y,l,a],message:u,actionType:m,value:h,gasLimit:p,track:{eventName:"hub_pool_create",eventData:{poolName:i,poolSymbol:n}}}},wg=({poolCreateTokens:e,initialLiquidityTokens:t,normalizedWeights:o,poolType:r,poolName:s,poolSymbol:a,swapFee:i,owner:n,amplification:l,oracles:u,weightsDuplicationThreshold:m=Da,...p})=>{let{data:c,error:d,isLoading:f}=xa(["useCreatePool__deduped_pool",e,r,o],async()=>{if(e.length===0||!r)return null;let R=pe("bex.subgraph",{});try{let b=we(e).map(I=>I.address.toLowerCase()).sort((I,T)=>I.toLowerCase()<T.toLowerCase()?-1:1);return(await R.query({query:Oa,variables:{tokens:b,type:r}})).data.pools.filter(I=>I.tokens?.every(T=>r===Pe.Weighted?b.includes(T.address)&&Math.abs(Number(T.weight)-Number(Ba(o[b.indexOf(T.address)],18)))<m:b.includes(T.address)||T.address===I.address))?.at(0)??null}catch{return null}}),{generatedPoolName:y,generatedPoolSymbol:A}=hr(()=>{if(!e)return{generatedPoolName:"",generatedPoolSymbol:""};let R=Ar(e),b=br(e,o,r);return{generatedPoolName:R,generatedPoolSymbol:b}},[e,o,r]),h=hr(()=>{if(!n||s===""||a===""||e.length!==t.length||e.length===0)return null;let R=Ce(i.toString(),16),b=va(Buffer.from(`${s}-${n}`)),{config:P}=E(p);return r===Pe.Weighted?Ha({poolCreationHelper:P.bex.poolCreationHelper,poolCreateTokens:e,initialLiquidityTokens:t,normalizedWeights:o,swapFeePercentage:R,salt:b,poolName:s,poolSymbol:a,owner:n,message:`Create pool ${s}`,actionType:"Create Pool"}):r===Pe.ComposableStable||r===Pe.MetaStable?Ua({poolCreationHelper:P.bex.poolCreationHelper,poolCreateTokens:e,initialLiquidityTokens:t,swapFeePercentage:R,salt:b,poolName:s,poolSymbol:a,owner:n,amplification:l,oracles:u,message:`Create pool ${s}`,actionType:"Create Pool"}):null},[e,t,o,r,i,s,a,n,l,u]);return{generatedPoolName:y,generatedPoolSymbol:A,isDupePool:!!c,dupePool:c,createPoolArgs:h,isLoadingPools:f,errorLoadingPools:d}};import Qa from"swr";import{usePublicClient as Ma}from"@berachain/wagmi/hooks";import{erc20Abi as Na,formatUnits as Va}from"viem";import{GetExploitedTokens as Wa}from"@berachain/graphql/dex/subgraph";var _a=1e-4;async function wr({token:e,publicClient:t,...o}){let r=pe("bex.subgraph",o),s=await t.readContract({address:e.address,abi:Na,functionName:"totalSupply"}),a=C(Va(s,e.decimals)).multipliedBy(_a),{data:i}=await r.query({query:Wa,variables:{token:e.address,balance:a.toFixed()}});return i.userInternalBalances.length>0}var Ya=e=>{let t=e?.filter(o=>o.address);return!t||t.length===0?null:["useExploitedTokens",t]},Og=({tokens:e})=>{let t=Ya(e),o=Ma(),r=Qa(o?t:null,async([,s])=>(g(o),(await Promise.all(s.map(i=>wr({token:i,publicClient:o})))).reduce((i,n,l)=>(n!==void 0&&(i[s[l].address]=n),i),{})));return{...r,refresh:()=>r.mutate()}};import Fa from"swr";var Ga=()=>{let e=Fa("useGlobalLiquidityAndSwapVolume",async()=>Vt());return{...e,data:{totalLiquidity:Number(e.data?.protocolMetricsAggregated.totalLiquidity),swapVolume24h:Number(e.data?.protocolMetricsAggregated.swapVolume24h)},refresh:()=>e.mutate()}};import{useEffect as Ka,useState as qa}from"react";import{PoolType as le}from"@berachain-foundation/berancer-sdk";var $a=.05,_g=({currentStep:e,tokenPrices:t,isLoadingTokenPrices:o,tokens:r,weights:s,weightsError:a,poolType:i,liquidityMismatchTolerancePercent:n=$a,oracles:l})=>{let[u,m]=qa({title:null,message:null});return Ka(()=>{if(!t||o||!r||!s||a||r.some(b=>!b.address)||l.some(b=>b.mode==="Custom")){m({title:null,message:null});return}let p=0,c=[],d=r.length,y=we(r).map(b=>{let P=t[b.address.toLowerCase()]?.price??0;if(!P||P===0)return c.push(0),null;let w=P*Number.parseFloat(b.amount);return c.push(w),p+=w,P});if(y.some(b=>b===null)||y.length!==d){m({title:"Missing token price data",message:`One or more token(s) do not have valid market price data. Please verify that token market prices align with the pool
2
2
  weightings and your initial liquidity amounts.`});return}if(e==="Select Tokens"&&i===le.ComposableStable){let b=y.map(w=>w/y[0]);Math.max(...b)-Math.min(...b)>n?m({title:"Selected tokens have a significant price deviation",message:"Did you mean to create a Weighted pool instead?",suggestWeighted:!0}):m({title:null,message:null});return}if(p===0||c.some(b=>b===0)){m({title:null,message:null});return}let A=0;if(i===le.ComposableStable){let b=p/d;c.forEach(P=>{A+=Math.abs(b-P)})}else i===le.Weighted&&c.forEach((b,P)=>{let w=Number(s[P])/1e18,I=p*w;A+=Math.abs(I-b)});let h=A>=p*.9;A=Math.min(A,p);let R=A/p;R>n?m({title:h?"You could lose all of your initial liquidity":`You could lose $${A.toFixed(2)} (~${(R*100).toFixed(2)}%)`,message:`Based on the market token prices, the value of tokens does not align with the specified pool weights.
3
3
  This discrepancy could expose you to potential losses from arbitrageurs. ${i===le.ComposableStable?"Did you mean to create a Weighted pool instead?":""}`,suggestWeighted:i===le.ComposableStable}):m({title:null,message:null})},[e,t,o,r,s,a,i,n,l]),u};import{formatEther as Er,isAddressEqual as hn}from"viem";import en from"swr";import{isAddress as kr,zeroAddress as tn}from"viem";import{rewardVaultAbi as on}from"@berachain/abis/pol/rewards/rewardVault";import{useBeraWallet as rn,usePublicClient as sn}from"@berachain/wagmi/hooks";import za from"swr/immutable";import{isAddress as ja,zeroAddress as Za}from"viem";import{rewardVaultFactoryAbi as Ja}from"@berachain/abis/pol/rewards/rewardVaultFactory";import{usePublicClient as Xa}from"@berachain/wagmi/hooks";var At=({tokenAddress:e},{isEnabled:t=!0}={})=>{let o=Xa(),r=o&&e&&ja(e)&&t?["useRewardVaultFromToken",e]:null,s=za(r,async([,a])=>{if(!a)throw new Error("useRewardVaultFromToken needs a valid token address");g(o);let{config:i}=E({chainId:o.chain.id}),n=await o.readContract({address:i.pol.factory,abi:Ja,functionName:"getVault",args:[a]});return n===Za?void 0:n});return{...s,refresh:()=>s.mutate()}};var Pr=({stakingToken:e,rewardVaultAddress:t},o)=>{let{address:r}=rn(),s=sn(),a=o?.opts?.isEnabled??!0,{data:i=t,error:n,mutate:l,isLoading:u}=At({tokenAddress:e},{isEnabled:!t&&a}),m=en(i&&r&&s&&kr(i)&&kr(r)&&a?["useVaultBalanceFromStakingToken",i,r]:null,async([,p,c])=>{if(g(s),p===tn)return{address:p,balance:0n};let d=await s.readContract({address:p,abi:on,functionName:"balanceOf",args:[c]});return{address:p,balance:d}});return{...m,refresh:()=>{l(),m.mutate()},isLoading:m.isLoading||u}};import mn from"swr";import{erc20Abi as dn,formatEther as cn,formatUnits as fn,isAddress as Ir,zeroAddress as gn}from"viem";import{defaultChainId as yn}from"@berachain/config/internal";import{useBeraWallet as An,usePublicClient as bn}from"@berachain/wagmi/hooks";import an from"swr/immutable";import{isAddress as nn,zeroAddress as ln}from"viem";import{defaultChainId as un}from"@berachain/config/internal";import{usePublicClient as pn}from"@berachain/wagmi/hooks";function Cr(e,t){let o=pn({chainId:e.chainId}),r=e?.address&&o&&nn(e.address)?["useTokenInformation",e.address,e.chainId]:null,s=an(r,async([a,i,n=un])=>k(i,"BERA")?{address:ln,decimals:N.decimals,name:N.name,symbol:N.symbol,chainId:n}:(g(o),await Z({address:i,publicClient:o,chainId:n})),{...t?.opts});return{...s,refresh:()=>s?.mutate?.()}}function Ie({address:e,owner:t,chainId:o=yn},r){let s=e;k(s,"ETH")&&(s=gn);let a=bn({chainId:o}),{address:i}=An(),n=t??i,l=(r?.opts?.isEnabled??!0)&&a&&n&&Ir(n)&&s&&Ir(s)?["usePollBalance",n,s,o]:null,{data:u,isLoading:m}=Cr({address:s,chainId:o}),p=k(s,"BERA"),{isLoading:c,data:d,error:f,...y}=mn(l,async([,R,b])=>(g(a),k(b,"BERA")?await a.getBalance({address:R}):await a.readContract({address:b,abi:dn,functionName:"balanceOf",args:[R]})),{refreshInterval:1e4}),A=!f&&d?k(s,"BERA")?cn(d):u&&!m?fn(d,u.decimals):void 0:void 0,h={chainId:o,balance:d?{raw:d.toString(),formatted:A??"0"}:{raw:"0",formatted:"0"},address:s,decimals:p?N.decimals:u?.decimals??0,symbol:p?N.symbol:u?.symbol??"",name:p?N.name:u?.name??""};return{...y,refresh:()=>{y.mutate()},isLoading:c||p?m:!1,error:f||!p?f:void 0,data:h}}var ky=({pool:e,vaultAddress:t},o)=>{let{data:r,...s}=Ie({address:e?.address}),{data:a,refresh:i}=Pr({stakingToken:e?.address,rewardVaultAddress:t??e?.rewardVault?.vaultAddress},o),n=e?Number.parseFloat(e?.dynamicData?.totalShares??"0"):0,l=e?.dynamicData?.totalLiquidity?Number(e?.dynamicData?.totalLiquidity??0):null,u=n&&l?l/Number(n):0,m=e?.tokens?.map(p=>({address:p.address,ratio:n?Number(p.balance)/Number(n):0}));return{data:{lpTokenPrice:u,lpBalance:r?{...r,usdValue:r?Number(r.balance.formatted)*u:void 0}:void 0,tokenBalances:e?.tokens?.map(p=>{let c=m?.find(y=>hn(y.address,p.address))?.ratio??0,d=c?C(r?.balance.formatted??"0").times(c):C(0),f=Number(p.balanceUSD)/Number(p.balance);return{...p,balance:{raw:d?.isGreaterThan(0)?d.times(10**p.decimals).toFixed(0).toString():"0",formatted:d.toString()},price:f,usdValue:Number.isNaN(f)||!d?void 0:Number.parseFloat(d.toString())*f}}),stakedBalance:a?.address?{...a,balance:{raw:a.balance.toString(),formatted:Er(a.balance)},usdValue:Number(Er(a.balance))*u}:void 0},...s,refresh:()=>{s.refresh?.(),i()}}};import{useMemo as Sr}from"react";import{parseUnits as Pn,zeroAddress as Cn}from"viem";import Rn from"swr";import{useBeraWallet as wn,useConfig as kn}from"@berachain/wagmi/hooks";function Tr(e,t){let o=kn(),{address:r}=wn(),s=o&&r&&e?.items?["usePollAllowances",r,e?.items]:null,a=Rn(s,async([,i,n])=>Eo({items:n,account:i,config:o}),{...t?.opts,refreshInterval:t?.opts?.refreshInterval??1e5});return{...a,refresh:()=>a?.mutate?.()}}function In({amount:e,decimals:t,slippage:o}){let r=Pn((o??0).toString(),t);return e+e*r/BigInt(100*10**t)}function En(e,t){let{slippage:o}=t??{},r=Sr(()=>e.filter(l=>l.token.address!==Cn).filter(l=>C(l.amount.formatted).gt(0)),[e]),{data:s,refresh:a,isLoading:i}=Tr({items:r});return{needsApproval:Sr(()=>s?.map(l=>{let u=r.find(p=>k(p.token.address,l.token));if(!u)throw new L({message:"Token not found when matching allowance in useMultipleTokenApprovalsWithSlippage",cause:{allowance:l,items:r}});let m=In({decimals:u.token.decimals,amount:BigInt(u.amount.raw),slippage:o});if(C(l.allowance.raw).lt(m))return{...u,needsApproval:!0,maxAmountIn:m,allowance:{raw:l.allowance.raw,formatted:l.allowance.formatted}}}).filter(l=>l!==void 0)??[],[s,o,r]),refresh:a,isLoading:i}}import{useMemo as Un}from"react";import Hn from"swr/immutable";import{formatUnits as Nn,isAddress as Vn}from"viem";import{usePublicClient as Wn}from"@berachain/wagmi/hooks";import Tn from"swr/immutable";import{isAddress as Sn}from"viem";import{defaultChainId as xn}from"@berachain/config/internal";import{usePublicClient as Bn}from"@berachain/wagmi/hooks";function xr(e,t){let o=Bn(),r=o&&e.addresses?["useMultipleTokenInformation",e.addresses,e.chainId??xn]:null,s=Tn(r,async([,a,i])=>(g(o),Promise.all(a.map(async n=>{if(!n||!Sn(n,{strict:!1}))throw new Error("Invalid address");let l=await Z({address:n,publicClient:o,chainId:i});if(!l)throw new Error(`Token ${n} not found`);return l}))),{...t?.opts});return{...s,refresh:()=>s?.mutate?.()}}import{useMemo as Ee}from"react";import On from"swr";import{isAddress as Dn,zeroAddress as Ln}from"viem";import{defaultChainId as re}from"@berachain/config/internal";import{useContext as vn}from"react";function oe(){let e=vn(qo);if(!e)throw new L({message:"useTokens must be used within a TokensProvider",level:"fatal"});return{...e,data:{tokenList:e.tokenList,customTokenList:e.userTokens,featuredTokenList:e.featuredTokens}}}function se({addressIn:e}={},t={opts:{refreshInterval:1e5,revalidateOnFocus:!0}}){let{tokenList:o,ensoTokens:r}=oe(),s=Ee(()=>{let p=[];return e&&p.push(...e.filter(c=>Dn(c))),p.map(c=>c.toLowerCase())},[o]),i=Ee(()=>{let p=new Set(o?.map(c=>c.address.toLowerCase()));return o.some(c=>k(c,"WBERA"))&&p.add(Ln),s?.some(c=>!p.has(c))},[s,o])?s:o.map(p=>p.address),n=i&&(t.opts?.isEnabled??!0)?["useTokenCurrentPrices",i.map(p=>p.toLowerCase())]:null,l=On(n,async([,p])=>Io({addressIn:p}),t.opts),u=Ee(()=>{if(!r)return{};let p=new Map([[re,new Map]]);for(let c of r)c.price===void 0||c.chainId!==re||p.get(re)?.set(c.address.toLowerCase(),{...c,price:c.price,chainId:re});return Object.fromEntries(i.map(c=>{let d=p.get(re)?.get(c)?.price;return d?[c.toLowerCase(),{price:d,chainId:re,updatedAt:Date.now()}]:[null,null]}))},[r]),m=Ee(()=>({...u,...l.data}),[u,l.data]);return{...l,data:m}}function _n(e){let t="poolId"in e?e.poolId?.slice(0,42):e.address;return Vn(t)&&t?["useOnChainPoolData",t]:null}function Br(e){let t=Wn(),o=e?.slice(0,42),r=_n({poolId:e}),{data:s,error:a,isLoading:i,mutate:n}=Hn(t?r:null,async([,d])=>Wt({poolId:d,publicClient:t})),{data:l,isLoading:u}=xr({addresses:s?.poolTokens[0]}),{data:m,isLoading:p}=se({addressIn:s?.poolTokens[0]});return{data:Un(()=>{if(!s||!l)return;let d={address:o.toLowerCase(),id:e.toLowerCase(),type:s.type,factory:s.factory,totalShares:s.totalSupply,totalLiquidity:"0",swapFee:s.swapFee,createTime:0,name:s.name,tokens:l.map((y,A)=>({address:y.address.toLowerCase(),name:y.name,decimals:y.decimals,symbol:y.symbol,index:A,weight:s.weights?.[A]??void 0,balance:Nn(BigInt(s.poolTokens[1][A]),y.decimals),token:{__typename:"Token",token:y,latestUSDPrice:m?.[y.address]}})),amplificationParameter:s?.amplificationParameter&&{currentFormattedValue:Number(s.amplificationParameter[0])/Number(s.amplificationParameter[2])}},f=d.tokens?.reduce((y,A)=>{let h=Number(m?.[A.address.toLowerCase()]?.price??0);return h?y+h*Number(A.balance):y},0);return d.totalLiquidity=f?.toString()??"",d},[s,l,m,o,e]),error:a,isLoading:i||u||p,mutate:n,refresh:()=>n()}}import Qn from"swr";import{vaultAbi as Mn}from"@berachain/abis/bex/vault";import{useBeraWallet as Yn,usePublicClient as Fn}from"@berachain/wagmi/hooks";var Gn=e=>{let{address:t}=Yn(),o=Fn(),r=t&&o?["usePollPoolCreationRelayerApproval",t,o.chain.id]:null,s=Qn(r,async([,i])=>{g(o);let{config:n}=E({chainId:o.chain.id});return await o.readContract({address:n.bex.vault,abi:Mn,functionName:"hasApprovedRelayer",args:[i,n.bex.poolCreationHelper]})},{...e?.opts});return{...s,refreshPoolCreationApproval:()=>{s.mutate()}}};function yA({poolId:e}){let t=gr({poolId:e}),{data:o,isLoading:r,refresh:s,error:a}=Br(e);return{data:[void 0,t.data,o],isLoading:t.isLoading||r,isError:t.error||a,refresh:()=>{t.refresh(),s()}}}import Kn from"swr/immutable";var RA=({poolId:e,typeInArray:t})=>Kn(e?["usePoolEvents",e,t]:null,async([,o,r])=>_t({poolId:o,typeInArray:r}),{refreshInterval:18e4});import qn from"swr";var IA=({poolId:e,...t},o)=>{let{config:r}=E(t),a=qn(e?["usePoolHistoricalData",e]:null,async([,i])=>await Qt({poolId:i,chain:r.bex.chainName}),o?.opts);return{...a,refresh:()=>void a.mutate()}};import{useMemo as vr}from"react";import $n from"swr";import{useBeraWallet as zn}from"@berachain/wagmi/hooks";var jn=({query:e}={})=>["useAllPools",e],OA=(e,t)=>{let{address:o}=zn(),{data:r,isLoading:s,mutate:a}=fr({userAddress:o,chain:e.chain}),{data:i,isLoading:n,mutate:l}=$n(jn({query:e}),async([p,c])=>ce(c),{refreshInterval:18e4,...t?.opts}),u=vr(()=>{if(!i||!r?.pools?.length)return i?.pools??[];let p=Object.fromEntries(r.pools.map(c=>[c.id.toLowerCase(),c]));return i.pools.map(c=>({...c,...p[c.id.toLowerCase()]||{}})).filter(Boolean)},[i,r]),m=vr(()=>({page:Math.ceil((e?.skip??0)/(e?.first??10)),pageSize:e?.first,count:Math.ceil((i?.count??0)/(e?.first??10))}),[i,e.skip,e.first]);return{pools:u??[],walletPools:i?.pools??[],isLoading:n||s,refresh:()=>{l(),a()},pagination:m}};import{useMemo as Jn}from"react";import{useCallback as Zn,useMemo as Or}from"react";import{defaultChainId as ae}from"@berachain/config/internal";function J({tokens:e}={},t={opts:{refreshInterval:1e5,revalidateOnFocus:!0}}){let{ensoTokens:o}=oe(),r=se({addressIn:e?.filter(n=>n.chainId===ae).map(n=>n.address)},t),s=Or(()=>{let n=[];if(!e)return[];let l=new Map;for(let u of e){let m=u.chainId??ae;l.has(m)||l.set(m,new Map),l.get(m)?.set(u.address.toLowerCase(),u)}if(r.data){for(let[u,m]of Object.entries(r.data))if(m&&l.get(m.chainId??ae)?.get(u.toLowerCase())&&m.price!==void 0){let p=l.get(m.chainId??ae)?.get(u.toLowerCase());if(!p)continue;n.push({...p,chainId:m.chainId,price:m.price})}}if(o)for(let u of o)u.price!==void 0&&u.chainId!==void 0&&n.push({...u,chainId:u.chainId,price:u.price});return n},[r.data,o,e]),a=Or(()=>{let n={};for(let l of s){let u=l.chainId??ae;n[u]||(n[u]={}),n[u][l.address.toLowerCase()]=l.price}return n},[s]),i=Zn(n=>n?a[n.chainId??ae]?.[n.address?.toLowerCase()]??void 0:void 0,[a]);return{isLoading:r.isLoading,data:s,priceMap:a,getTokenPrice:i}}function Te({tokenIn:e,tokenOut:t,formattedAmountIn:o,formattedAmountOut:r}){let{getTokenPrice:s,isLoading:a}=J({tokens:e&&t?[e,t]:void 0});return{data:Jn(()=>{if(!e||!t||!o||!r)return;let n=s(e),l=s(t);return!n||!l?null:$o(n.toString(),l.toString(),o,r)},[e,t,o,r]),isLoading:a}}import gi from"swr";import{parseUnits as kt}from"viem";import{defaultChainId as yi}from"@berachain/config/internal";import{useBeraWagmi as Ai,useBeraWallet as bi,usePublicClient as hi}from"@berachain/wagmi/hooks";import{formatUnits as Vr}from"viem";import{encodeFunctionData as ri,getAddress as si}from"viem";import{morphoAbi as Ur}from"@berachain/abis/bend/morpho";import{encodeFunctionData as Xn,erc20Abi as bt,ethAddress as Rt,formatUnits as ei,getAddress as ti,zeroAddress as oi}from"viem";function X(e){return e===oi?Rt:e}function ht(e){if(e!=null)return typeof e=="bigint"?e:BigInt(e)}var Dr=async({fromAddress:e,amountIn:t,tokenIn:o,chainId:r,ensoClient:s,bundle:a,publicClient:i})=>{let n=[];if(o!==Rt){let u=await s.getApprovalData({fromAddress:e,tokenAddress:o,chainId:r,amount:t}),m=!0;if(i&&(m=await i.readContract({address:o,abi:bt,functionName:"allowance",args:[e,u.spender]})<BigInt(t)),m){let p=ht(u.tx.value)??0n;n.push({to:u.tx.to,data:u.tx.data,value:p,gasLimit:BigInt(u.gas)})}}let l=ht(a.tx.value)??0n;return n.push({to:a.tx.to,data:a.tx.data,value:l,gasLimit:BigInt(a.gas)}),n},Lr=async({fromAddress:e,amountIn:t,tokenIn:o,bundle:r,publicClient:s})=>{let a=[],i=ti(r.tx.to),n=null;if(X(o.address)!==Rt){let m=await s.readContract({address:o.address,abi:bt,functionName:"allowance",args:[e,i]}),p=BigInt(t);if(m<p){let d=p.toString();n={token:o,amount:{raw:d,formatted:ei(p,o.decimals)},spender:i};let f=Xn({abi:bt,functionName:"approve",args:[i,p]});a.push({to:o.address,data:f,value:0n})}}let u=ht(r.tx.value)??0n;return a.push({to:r.tx.to,data:r.tx.data,value:u,gasLimit:r.gas?BigInt(r.gas):void 0}),{transactions:a,approval:n}};function ue(e){let t=new C(e).dividedBy(100),o=new C(1).minus(t);if(o.lte(0))throw new B({property:"slippage",value:e,expected:"a value lower than 100"});return o}function wt(e,t,o){return e.multipliedBy(new C(10).pow(o.decimals)).dividedBy(new C(10).pow(t.decimals))}async function Hr({publicClient:e,ensoWalletV2Factory:t,accountAddress:o}){return e.readContract({address:t,abi:Dt,functionName:"getAddress",args:[o]})}async function Nr({publicClient:e,primaryAddress:t,accountAddress:o,ensoWalletV2Address:r}){return e.readContract({address:t,abi:Ur,functionName:"isAuthorized",args:[o,r]})}async function Se({fromAddress:e,amountIn:t,tokenIn:o,primaryAddress:r,bundle:s,publicClient:a,ensoWalletV2Address:i,isAuthorized:n}){let{config:l}=E({}),{walletFlashloanAdapter:u}=l.enso;j(u,"config.enso.walletFlashloanAdapter");let{transactions:m,approval:p}=await Lr({fromAddress:e,amountIn:t,tokenIn:o,bundle:s,publicClient:a}),c=[];return n||c.push({to:r,data:ri({abi:Ur,functionName:"setAuthorization",args:[i,!0]}),value:0n}),c.push(...m),{transactions:c,approvals:p?[p]:[],ensoWalletFlashloanAdapter:si(u)}}var ai=25n,Wr=10000n;function ni({repayAmount:e,collateralPriceInLoanAsset:t,collateralToken:o,loanToken:r,slippage:s,currentCollateral:a}){let i=ue(s),n=new C(t);if(n.lte(0))throw new B({property:"collateralPriceInLoanAsset",value:t,expected:"a value greater than zero"});let l=new C(10).pow(r.decimals),u=new C(10).pow(o.decimals),c=new C(e).dividedBy(l).dividedBy(n).dividedBy(i).multipliedBy(u).integerValue(C.ROUND_UP);return c.lte(0)?"0":C.minimum(c,new C(a)).toFixed(0)}function ii({repayAmount:e,collateralToWithdraw:t,collateralToken:o,loanToken:r}){return{finalCollateral:Vr(BigInt(t),o.decimals),totalBorrow:Vr(BigInt(e),r.decimals)}}async function _r({fromAddress:e,repayAmount:t,collateralToken:o,loanToken:r,marketId:s,primaryAddress:a,chainId:i,ensoClient:n,slippage:l,publicClient:u,collateralPriceInLoanAsset:m,currentCollateral:p,currentDebt:c,ensoWalletV2Address:d,isAuthorized:f}){W(e,"fromAddress"),Qe(t,"repayAmount"),Qe(c,"currentDebt");let y=BigInt(t),A=BigInt(c),h=y>=A,R=X(o.address),b=X(r.address),P=(y*ai+(Wr-1n))/Wr,w=h?P:0n,I=(y+w).toString(),T=ni({repayAmount:I,collateralPriceInLoanAsset:m,collateralToken:o,loanToken:r,slippage:l,currentCollateral:p}),S=BigInt(T)>=BigInt(p),O=h&&w>0n&&!S;if(BigInt(T)<=0n)throw new B({property:"collateralToWithdraw",value:T,expected:"positive amount"});let H=[{protocol:"enso",action:"route",args:{tokenIn:R,tokenOut:b,amountIn:T,slippage:l*100}},{protocol:"bend",action:"repay",args:{primaryAddress:a,positionId:s,tokenIn:b,amountIn:{useOutputOfCallAt:0},onBehalfOf:e}}],v=H.length,Y=O?[{protocol:"enso",action:"balance",args:{token:b}},{protocol:"enso",action:"route",args:{tokenIn:b,tokenOut:R,amountIn:{useOutputOfCallAt:v},slippage:l*100}},{protocol:"bend",action:"deposit",args:{primaryAddress:a,positionId:s,tokenIn:R,amountIn:{useOutputOfCallAt:v+1},onBehalfOf:e}}]:[],M=[...H,...Y,{protocol:"bend",action:"withdraw",args:{primaryAddress:a,positionId:s,tokenOut:R,amountOut:T,onBehalfOf:e}}],F=[{protocol:"bend",action:"flashloan",args:{flashloanToken:R,flashloanAmount:T,tokenOut:b,callback:M}}],G=await n.getBundleData({fromAddress:e,receiver:e,spender:e,chainId:i,routingStrategy:"ensowallet-v2"},F),{transactions:D}=await Se({fromAddress:e,amountIn:"0",tokenIn:o,primaryAddress:a,bundle:G,publicClient:u,ensoWalletV2Address:d,isAuthorized:f});return{bundle:G,transactions:D,positionEstimate:ii({repayAmount:t,collateralToWithdraw:T,collateralToken:o,loanToken:r})}}import li from"swr";import{getAddress as ui}from"viem";import{useBeraWallet as pi,usePublicClient as mi}from"@berachain/wagmi/hooks";function xe({chainId:e}){let{address:t}=pi(),o=mi({chainId:e}),{config:r}=E({}),s=r.enso.walletV2Factory;return li(t&&s?["useEnsoWalletV2Address",t,s]:null,async([i,n,l])=>(g(o),Hr({publicClient:o,ensoWalletV2Factory:ui(l),accountAddress:n})),{refreshInterval:18e4})}import di from"swr";import{useBeraWallet as ci,usePublicClient as fi}from"@berachain/wagmi/hooks";function Be({chainId:e,primaryAddress:t,ensoWalletV2Address:o}){let{address:r}=ci(),s=fi({chainId:e});return di(r&&t&&o?["useIsBendAuthorized",r,t,o]:null,async([i,n,l,u])=>(g(s),Nr({publicClient:s,primaryAddress:l,accountAddress:n,ensoWalletV2Address:u})),{refreshInterval:18e4})}function Sb({collateralToken:e,loanToken:t,marketId:o,primaryAddress:r,repayAmount:s,slippage:a,chainId:i,collateralPriceInLoanAsset:n,currentCollateral:l,currentDebt:u},m){let{address:p}=bi(),{account:{chainId:c}={}}=Ai(),d=i??c??yi,f=hi({chainId:d}),{data:y}=xe({chainId:d}),{data:A}=Be({chainId:d,primaryAddress:r,ensoWalletV2Address:y}),h=e&&t&&o&&r&&s&&y&&A!==void 0&&e.address!==t.address&&Number(s)>0&&a!==void 0&&n!==void 0&&l&&u&&Number(u)>0&&p&&(m?.opts?.isEnabled??!0)?["useBendDemultiply",p,e,t,o,r,d,s,a,n,l,u,y,A]:null;return gi(h,async([R,b,P,w,I,T,S,O,H,v,Y,M,$,F])=>{g(f);let G=kt(O,w.decimals).toString(),D=kt(Y,P.decimals).toString(),q=kt(M,w.decimals).toString();return _r({fromAddress:b,repayAmount:G,collateralToken:P,loanToken:w,marketId:I,primaryAddress:T,chainId:S,ensoClient:z(),slippage:H,publicClient:f,collateralPriceInLoanAsset:v,currentCollateral:D,currentDebt:q,ensoWalletV2Address:$,isAuthorized:F})},{...m?.opts,refreshInterval:1e5})}import ki from"swr";import{parseUnits as Pt}from"viem";import{defaultChainId as Pi}from"@berachain/config/internal";import{useBeraWagmi as Ci,useBeraWallet as Ii,usePublicClient as Ei}from"@berachain/wagmi/hooks";function Ri({rawSupplyCollateralAmount:e,rawCurrentCollateralAmount:t,rawCurrentBorrowAmount:o,formattedCollateralPriceInLoanAsset:r,collateralToken:s,loanToken:a,leverageMultiplier:i,slippage:n}){let l=Math.max(i,1);if(l<=1)return"0";let u=ue(n),m=new C(r);if(m.lte(0))throw new B({property:"formattedCollateralPriceInLoanAsset",value:r,expected:"a value greater than zero"});let p=wt(m,s,a),c=new C(1).minus(new C(1).dividedBy(l)),d=new C(t).plus(e),f=new C(o),y=new C(1).minus(c.multipliedBy(u));if(y.lte(0))throw new B({property:"leverageMultiplier",value:i,expected:"a lower leverage target for current slippage"});let A=c.multipliedBy(d).multipliedBy(p).minus(f).dividedBy(y);if(A.lte(0))return"0";let h=A.integerValue(C.ROUND_UP);return h.lte(0)?"0":h.toFixed(0)}function wi({rawSupplyCollateralAmount:e,collateralToken:t,loanToken:o,rawBorrowAmount:r,formattedCollateralPriceInLoanAsset:s,slippage:a}){let i=new C(10).pow(t.decimals),n=new C(10).pow(o.decimals),l=new C(e),u=new C(r);if(u.lte(0))return{finalCollateral:l.dividedBy(i).toFixed(),totalBorrow:"0"};let m=ue(a),p=wt(new C(s),t,o),c=p.lte(0)?new C(0):u.multipliedBy(m).dividedBy(p),d=l.plus(c).dividedBy(i),f=u.dividedBy(n);return{finalCollateral:d.toFixed(),totalBorrow:f.toFixed()}}async function Qr({fromAddress:e,rawSupplyCollateralAmount:t,rawCurrentCollateralAmount:o,rawCurrentBorrowAmount:r,collateralToken:s,loanToken:a,marketId:i,primaryAddress:n,chainId:l,ensoClient:u,slippage:m,leverageMultiplier:p,publicClient:c,formattedCollateralPriceInLoanAsset:d,ensoWalletV2Address:f,isAuthorized:y}){W(e,"fromAddress");let A=X(s.address),h=X(a.address),R=Ri({rawSupplyCollateralAmount:t,rawCurrentCollateralAmount:o,rawCurrentBorrowAmount:r,formattedCollateralPriceInLoanAsset:d,collateralToken:s,loanToken:a,leverageMultiplier:p,slippage:m}),b=0,P=1,w=[{protocol:"bend",action:"deposit",args:{primaryAddress:n,positionId:i,tokenIn:A,amountIn:t,onBehalfOf:e}}],I=[{protocol:"bend",action:"flashloan",args:{flashloanToken:h,flashloanAmount:R,tokenIn:A,amountIn:t,tokenOut:h,callback:[{protocol:"enso",action:"route",args:{tokenIn:h,tokenOut:A,amountIn:R,slippage:m*100}},{protocol:"enso",action:"balance",args:{token:A}},{protocol:"bend",action:"deposit",args:{primaryAddress:n,positionId:i,tokenIn:A,amountIn:{useOutputOfCallAt:P},onBehalfOf:e}},{protocol:"bend",action:"borrow",args:{primaryAddress:n,positionId:i,collateral:A,tokenOut:h,amountOut:R,onBehalfOf:e}}]}}],T=R==="0"?w:I,S=await u.getBundleData({fromAddress:e,receiver:e,spender:e,chainId:l,routingStrategy:"ensowallet-v2"},T),{transactions:O}=await Se({fromAddress:e,amountIn:t,tokenIn:s,primaryAddress:n,bundle:S,publicClient:c,ensoWalletV2Address:f,isAuthorized:y});return{bundle:S,transactions:O,positionEstimate:wi({rawSupplyCollateralAmount:t,collateralToken:s,loanToken:a,rawBorrowAmount:R,formattedCollateralPriceInLoanAsset:d,slippage:m})}}function Gb({collateralToken:e,loanToken:t,marketId:o,primaryAddress:r,formattedSupplyCollateralAmount:s,formattedCurrentCollateralAmount:a,formattedCurrentBorrowAmount:i,leverageMultiplier:n,slippage:l,chainId:u,formattedCollateralPriceInLoanAsset:m},p){let{address:c}=Ii(),{account:{chainId:d}={}}=Ci(),f=u??d??Pi,y=Ei({chainId:f}),{data:A}=xe({chainId:f}),{data:h}=Be({chainId:f,primaryAddress:r,ensoWalletV2Address:A}),R=e&&t&&o&&r&&A&&h!==void 0&&e.address!==t.address&&l!==void 0&&n!==void 0&&m!==void 0&&(Number(s??0)>0||n>1&&(Number(a??0)>0||Number(s??0)>0))&&c&&(p?.opts?.isEnabled??!0)?["useBendMultiply",c,e,t,o,r,f,s??"",a??"",i??"",n,l,m,A,h]:null;return ki(R,async([b,P,w,I,T,S,O,H,v,Y,M,$,F,G,D])=>{g(y);let q=Pt(H||"0",w.decimals).toString(),_e=Pt(v||"0",w.decimals).toString(),Ps=Pt(Y||"0",I.decimals).toString();return Qr({fromAddress:P,rawSupplyCollateralAmount:q,rawCurrentCollateralAmount:_e,rawCurrentBorrowAmount:Ps,collateralToken:w,loanToken:I,marketId:T,primaryAddress:S,chainId:O,ensoClient:z(),slippage:$,leverageMultiplier:M,publicClient:y,formattedCollateralPriceInLoanAsset:F,ensoWalletV2Address:G,isAuthorized:D})},{...p?.opts,refreshInterval:1e5})}import Ti from"swr";import{formatEther as Si,parseUnits as xi,zeroAddress as Yr}from"viem";import{defaultChainId as Bi}from"@berachain/config/internal";import{useBeraWallet as vi,usePublicClient as Oi}from"@berachain/wagmi/hooks";import{ethAddress as Mr,zeroAddress as Ct}from"viem";var It=class extends x{name="Enso (Mint)";supportedChains=null;type="rest";needsAccountForQuote=!0;notFoundMessages=["Could not build shortcuts for route","Could not quote shortcuts for route","Swap not found for a required underlying of defi route,","No route found from"];async getQuote({tokenIn:t,tokenOut:o,amount:r,slippage:s,account:a=Ct,aggregatorsFeeBps:i,proxyAggregatorsThroughVercel:n=!1,rewardVault:l,underlyingToken:u}){this.assertChainSupport({tokenIn:t,tokenOut:o}),W(a,"account");let m=z({useProxy:!n});t.address===Ct&&(t.address=Mr),o.address===Ct&&(o.address=Mr);let p=u??o,c=[{protocol:"enso",action:"route",args:{tokenIn:t.address,tokenOut:p.address,destinationChainId:t.chainId===p.chainId?void 0:p.chainId,refundReceiver:a,amountIn:r,slippage:s*100}}];if(u&&c.push({protocol:"erc4626",action:"deposit",args:{amountIn:{useOutputOfCallAt:0},tokenIn:u.address,primaryAddress:o.address,tokenOut:o.address}}),l){let A=c.length;c.push({protocol:"enso",action:"balance",args:{token:o.address}},{protocol:"erc20",action:"approve",args:{amount:{useOutputOfCallAt:A},spender:l,token:o.address}},{protocol:"enso",action:"call",args:{address:l,args:[a,{useOutputOfCallAt:A}],method:"stakeOnBehalf",abi:"function stakeOnBehalf(address account, uint256 amount) external"}},{protocol:"enso",action:"balance",args:{token:l}})}let d=await m.getBundleData({fromAddress:a,receiver:a,spender:a,chainId:t.chainId,routingStrategy:"router"},c),f=l?.toLowerCase()??o.address.toLowerCase();return{amountOut:d.minAmountsOut[f]??d.amountsOut[f]??"0",amountIn:r,allowanceRequirements:this.parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:d.tx.to}),name:this.name,swapFeeBps:0,priceImpactPercentage:d.priceImpact?d.priceImpact/100:null,getCalldata:()=>({address:d.tx.to,data:d.tx.data,value:BigInt(d.tx.value??0)})}}},ve=new It;function uh({tokenIn:e,loanToken:t,bendVault:o,rewardVault:r,amount:s,slippage:a},i){let{getTokenPrice:n}=J({tokens:e&&t?[e,t]:void 0}),l=Di({tokenIn:e,loanToken:t,bendVault:o,rewardVault:r,amount:s?xi(s,e?.decimals??18).toString():void 0,slippage:a},i),{data:u}=zo({sharesAmount:BigInt(l.data?.amountOut??0),vaultAddress:o.address}),{data:m}=Te({tokenIn:e,tokenOut:t,formattedAmountIn:s,formattedAmountOut:u?.formatted??"0"}),p=e?.chainId&&e.chainId!==Bi,{data:c,isLoading:d}=Ie({address:Yr,chainId:p?e?.chainId:void 0},{opts:{isEnabled:!!p}}),f=l.data?.getCalldata?.({account:Yr})?.value??0n,y=c?.balance??{raw:"0",formatted:"0"},A=p&&f>0n&&!d&&f>BigInt(y.raw),h=p&&f>0n?Si(f):void 0;return{...l,zapSupplyAmount:u,priceImpact:m,hasInsufficientNativeBalance:A,isCrossChain:p,nativeFee:h,refresh:()=>{l.mutate()}}}function Di({tokenIn:e,loanToken:t,bendVault:o,rewardVault:r,amount:s,slippage:a},i){let{address:n}=vi(),l=!!e&&!!t&&!!o&&!!s&&!!n&&!k(t.address,e.address)&&e.chainId&&Number(s)>0&&!!a,u=Oi();return Ti(l?["useBendZapSupply",e,t,o,r,s,a]:null,async([,p,c,d,f,y,A])=>(g(u),W(n,"fromAddress"),W(p?.address,"tokenInAddress"),j(p?.chainId,"tokenInChainId"),await ve.getQuote({tokenIn:p,tokenOut:d,underlyingToken:c,amount:y,slippage:A,account:n,rewardVault:f})),{...i?.opts,refreshInterval:1e5})}import{getPublicClient as Qi}from"@wagmi/core";import Mi from"swr";import{parseUnits as Yi}from"viem";import{defaultChainId as Fi}from"@berachain/config/internal";import{useBeraWallet as Gi,useConfig as Ki}from"@berachain/wagmi/hooks";import{ethAddress as Li,zeroAddress as Ui}from"viem";async function Fr({fromAddress:e,amountIn:t,tokenIn:o,tokenOut:r,chainId:s,ensoClient:a,destinationChainId:i,slippage:n,publicClient:l}){if(!e)throw new B({property:"fromAddress",value:e,expected:"address"});r===Ui&&(r=Li);let u={protocol:"enso",action:"route",args:{tokenIn:o,tokenOut:r,amountIn:t,slippage:n*100}};i&&i!==s&&(u.args={...u.args,destinationChainId:i,refundReceiver:e});let m=await a.getBundleData({fromAddress:e,receiver:e,spender:e,chainId:s,routingStrategy:"router"},[u]),p=await Dr({fromAddress:e,amountIn:t,tokenIn:o,chainId:s,ensoClient:a,bundle:m,publicClient:l});return{bundle:m,transactions:p}}import{useMemo as Hi}from"react";import Ni from"swr";import{useBeraWallet as Vi,useConfig as Wi,usePublicClient as _i}from"@berachain/wagmi/hooks";function Oe(e,t){let o=_i(),r=Wi(),{address:s}=Vi(),{tokenList:a,refresh:i}=oe(),n=e?.walletAddress??s,l=Hi(()=>new Map((e?.tokens??a)?.map(p=>[p.address.toLowerCase(),p])??[]),[a,e?.tokens]),u=o&&a!==void 0&&n?["usePollWalletBalances",n,Array.from(l.values())]:null,m=Ni(u,async([,p,c])=>Re({account:p,tokenList:c,wagmiConfig:r}),{refreshInterval:1e5,...t?.opts});return{...m,refresh:()=>{m?.mutate?.(),i()}}}function Bh({tokenIn:e,tokenOut:t,amount:o,slippage:r}){let{address:s}=Gi(),a=Ki(),i=z(),{refresh:n}=Oe(),l=!!e&&!!t&&!!o&&Number(o)>0&&!!r&&!!s&&!!e.chainId,m=Mi(l?["useEnsoSwapBundle",e,t,o,r]:null,async([,p,c,d,f])=>{W(s,"fromAddress"),W(p?.address,"tokenInAddress"),j(p?.chainId,"tokenInChainId"),W(c?.address,"tokenOutAddress"),Me(d,"amount"),Me(f,"slippage");let y=Qi(a,{chainId:p.chainId});g(y);let A=Yi(d,p.decimals).toString();return Fr({fromAddress:s,amountIn:A,tokenIn:p.address,tokenOut:c.address,chainId:p.chainId,ensoClient:i,destinationChainId:Fi,slippage:f,publicClient:y})},{refreshInterval:1e5,isEnabled:l});return{...m,refresh:()=>{m.mutate(),n()}}}import qi from"swr";import{formatUnits as $i,parseUnits as zi}from"viem";import{chainConfigs as ji,defaultChainId as Zi}from"@berachain/config/internal";import{useBeraWallet as Ji}from"@berachain/wagmi/hooks";function Vh({inputToken:e,amount:t,underlyingToken:o,slippage:r,tokenOut:s},a){let{address:i}=Ji(),n=i??ji[Zi].bex.aggregatorsRouterExecutor,u=!!e&&!!t&&Number(t)>0&&!!e.chainId&&!!o&&!!r?["useZapStakeBera",e,t,n,r,o,s]:null,m=qi(u,async([,c,d,f,y,A,h])=>{let R=zi(d,c.decimals).toString();return ve.getQuote({account:f,amount:R,tokenIn:c,underlyingToken:A,tokenOut:h,slippage:y})},{...a?.opts,refreshInterval:1e5}),{data:p}=Te({tokenIn:e,tokenOut:s,formattedAmountIn:t,formattedAmountOut:$i(BigInt(m.data?.amountOut??"0"),s.decimals)});return{...m,data:{...m.data,priceImpactPercentage:p,isCrossChain:e&&s.chainId!==e?.chainId},refresh:()=>{m.mutate()}}}import{useCallback as Et,useEffect as al,useState as nl}from"react";import Xi from"gray-matter";import{encodeFunctionData as Le,erc20Abi as el,parseAbiItem as tl,toHex as ol}from"viem";import{beraChefAbi as rl}from"@berachain/abis/pol/rewards/beraChef";import{rewardVaultAbi as sl}from"@berachain/abis/pol/rewards/rewardVault";function De(e){return Object.values(e).some(t=>Array.isArray(t)?t.some(o=>typeof o=="object"&&o!==null?De(o):!!o):typeof t=="object"&&t!==null?De(t):!!t)}var Gr=({proposal:e,currentTopic:t,onError:o})=>{let r=Yt(e,t),s=[];if(r.actions=e.actions.map((n,l)=>{let u={};if(u.target=V({fieldOrType:"address",value:n.target}),n.type==="custom-action")if(n.input==="ABI")if(u.ABI=V({fieldOrType:"abi",value:n.ABI}),!n.functionSignature)u.functionSignature="Required";else try{let p=tl(n.functionSignature);p.type!=="function"?(console.error("parsedSignatureAbi is not a function",p),u.functionSignature="Invalid ABI"):(u.args=p.inputs.map((c,d)=>{try{return"components"in c?V({fieldOrType:c.type,value:n.args?.[d],components:c.components}):V({fieldOrType:c.type,value:n.args?.[d]})}catch{return null}}),u.args.some(c=>c)||(s[l]=Le({abi:[p],args:n.args})))}catch{u.functionSignature="Invalid ABI"}else if(n.input==="rawCalldata")u.rawCalldata=V({fieldOrType:"hex",value:n.rawCalldata}),s[l]=n.rawCalldata;else if(n.input==="message")u.message=V({fieldOrType:"string",value:n.message}),s[l]=ol(n.message);else throw new Error("Invalid input type");else if(n.type==="whitelist-reward-vault"||n.type==="blacklist-reward-vault"){if(u.vault=V({fieldOrType:"address",value:n.vault}),!u.vault){let p=n.type==="whitelist-reward-vault";s[l]=Le({abi:rl,functionName:"setVaultWhitelistedStatus",args:[n.vault,p,""]})}}else n.type==="whitelist-reward-vault-incentive"?(u.token=V({fieldOrType:"address",value:n.token}),u.minIncentiveRate=V({fieldOrType:"uint256",value:n.minIncentiveRate}),u.managerAddress=V({fieldOrType:"address",value:n.managerAddress}),!u.token&&!u.minIncentiveRate&&!u.managerAddress&&(s[l]=Le({abi:sl,functionName:"whitelistIncentiveToken",args:[n.token,BigInt(n.minIncentiveRate),n.managerAddress]}))):n.type==="erc20-transfer"&&(u.amount=V({fieldOrType:"uint256",value:n.amount}),u.to=V({fieldOrType:"address",value:n.to}),!u.amount&&!u.to&&(s[l]=Le({abi:el,functionName:"transfer",args:[n.to,BigInt(n.amount)]})));return De(u)?u:null}),o?.(r),Object.getOwnPropertyNames(r).map(n=>r[n]).some(n=>Array.isArray(n)?n.filter(l=>l).length>0:n===null?!1:!!n)){console.warn("Proposal has errors",r);return}if(s.length===0)throw new Error("No actions submitted in proposal");let a=new URL(e.forumLink),i=Xi.stringify(e.description,{title:e.title,topics:Array.from(e.topic.values()),forumLink:a.toString(),version:"1.0.0","content-encoding":"utf-8","content-type":"text/markdown",actions:e.actions.map(n=>{let l={type:n.type};return n.type==="custom-action"&&(l.inputType=n.input),l})});return[e.actions.map(n=>n.target),e.actions.map(n=>n.value??0n),s,i]};var Kr={type:"custom-action",target:"",ABI:"",value:0n,functionSignature:"",args:[],input:"ABI",rawCalldata:"0x",message:""},il=({initialData:e={},currentTopic:t,onError:o})=>{let[r,s]=nl({title:"",description:"",forumLink:"",actions:[Kr],...e,topic:new Set});al(()=>{s(l=>({...l,topic:new Set([t.id])}))},[t]);let a=Et(()=>{s(l=>({...l,actions:[...l.actions,Kr]}))},[]),i=Et(l=>{s(u=>{let m=[...u.actions];return m.splice(l,1),{...u,actions:m}})},[s]),n=Et(()=>r?Gr({proposal:r,currentTopic:t,onError:o}):void 0,[r,t]);return{proposal:r,setProposal:s,addProposalAction:a,removeProposalAction:i,computeParamsAndErrors:n}};import ml from"swr/immutable";import{formatUnits as dl}from"viem";import{bgtAbi as cl}from"@berachain/abis/pol/bgt";import{useBeraWallet as fl,usePublicClient as gl}from"@berachain/wagmi/hooks";import ll from"swr/immutable";import{berachainGovernanceAbi as ul}from"@berachain/abis/gov/berachainGovernance";import{usePublicClient as pl}from"@berachain/wagmi/hooks";var qr=({proposalId:e})=>{let t=pl();return ll(t&&e?["useProposalSnapshot",e]:null,async([,r])=>{g(t);let{config:s}=E({chainId:t.chain.id});return(await t.readContract({abi:ul,address:s.governance.governor,functionName:"proposalSnapshot",args:[BigInt(r)]})).toString()})};var mR=e=>{let{address:t}=fl(),o=gl(),r=e.wallet||t,{data:s}=qr({proposalId:e.proposalId}),a=e.timepoint||s;return ml(a&&o&&r?["useGetPastVotes",a,r]:null,async([,n,l])=>{g(o);let{config:u}=E({chainId:o.chain.id});if(Number(n)>Date.now()/1e3)throw new Error("timepoint is in the future");let m=await o.readContract({abi:cl,address:u.tokens.bgt,functionName:"getPastVotes",args:[l,BigInt(n)]});return dl(m,18)})};import yl from"swr";import{isAddress as Al}from"viem";import{berachainGovernanceAbi as bl}from"@berachain/abis/gov/berachainGovernance";import{useBeraWallet as hl,usePublicClient as Rl}from"@berachain/wagmi/hooks";var hR=({proposalId:e,wallet:t})=>{let{address:o}=hl(),r=Rl(),s=t||o;return yl(r&&s&&Al(s)?["useHasVoted",e,s]:null,([,a,i])=>{g(r);let{config:n}=E({chainId:r.chain.id});return r.readContract({address:n.governance.governor,abi:bl,functionName:"hasVoted",args:[BigInt(a),i]})})};import wl from"swr";import{timeLockAbi as kl}from"@berachain/abis/gov/timeLock";import{usePublicClient as Pl}from"@berachain/wagmi/hooks";var $r="0xfd643c72710c63c0180259aba6b2d05451e3591a24e58b62239378085726f783";var SR=({account:e,...t})=>{let o=Pl(),{config:r}=E(t);return wl(e&&o?["useCancellerRole",e]:null,async([,a])=>(g(o),await o.readContract({abi:kl,address:r.governance.timelock,functionName:"hasRole",args:[$r,a]})),{refreshInterval:18e4,revalidateOnFocus:!1})};import{useEffect as zr,useMemo as Cl,useState as Il}from"react";import El from"swr/infinite";import{Proposal_OrderBy as Tl,ProposalStatus as K}from"@berachain/graphql/governance";var jr=10,Sl=e=>{switch(e){case K.QuorumNotReached:return[K.Active,K.Pending];case K.PendingQueue:case K.Defeated:return[K.Active];case K.PendingExecution:return[K.InQueue];default:return[e]}};function xl(e,t={}){let o=2*(t.perPage??jr);return(r,s)=>{if(r!==0&&s&&s.length<o)return null;let a=t.status_in?.flatMap(Sl).filter((i,n,l)=>l.indexOf(i)===n);return["usePollAllProposals",r,e,t.where,a,t.orderBy,t.orderDirection,o,t.text]}}function LR(e,t){let o=t?.autoRefresh??!1,r=e.perPage??jr,s=2*r,a=xl(e.topic,e);async function i(d){if(!d)return[];let[,f,y,A,h,R,b,P,w]=d;return(await Mt({where:{topics_contains:[y],status_in:h?.length?h:void 0,...A},orderBy:R,orderDirection:b,text:w,perPage:P,offset:f*P})??[]).filter(Boolean)}let n=El(a,i,{initialSize:1,refreshInterval:t?.opts?.refreshInterval??18e4,...t?.opts}),l=Cl(()=>{if(!n.data)return[];let d=n.data.flat().filter(y=>y?e.status_in?.length?e.status_in.includes(y.status):!0:!1).sort((y,A)=>{if(!e.text)return 0;if(e.orderBy===Tl.CreatedAt){let h=Number(A.createdAt)-Number(y.createdAt);return e.orderDirection==="asc"?h:-h}return 0}),f=[];for(let y=0;y<d.length;y+=r)f.push(d.slice(y,y+r));return f},[n.data,e,r]),u=n.data?.[n.data.length-1],m=!!u&&u.length===s,[p,c]=Il(Date.now()/1e3);return zr(()=>{if(!o)return;let d=setInterval(()=>{c(Date.now()/1e3)},1e4);return()=>clearInterval(d)},[o]),zr(()=>{if(!n.data)return;let d=!1;for(let f of n.data.flat()){switch(f.status){case K.Pending:p>=Number(f.voteStartAt)&&(d=!0);break;case K.Active:p>=Number(f.voteEndAt)&&(d=!0);break;case K.InQueue:Date.now()/1e3+1>=Number(f.queueEnd)&&(d=!0);break;default:break}if(d)break}d&&n.mutate()},[n.data,p]),{...n,data:l,hasMore:m}}import{useEffect as Zr,useState as Bl}from"react";import vl from"swr";import{ProposalStatus as Tt}from"@berachain/graphql/governance";import{usePublicClient as Ol}from"@berachain/wagmi/hooks";var MR=(e,t)=>{let o=t?.autoRefresh??!1,r=Ol(),a=vl(e&&r?["usePollProposal",e]:null,([,l])=>(g(r),Ft({proposalId:l,client:r})),{...t?.opts,refreshInterval:t?.opts?.refreshInterval??18e4}),[i,n]=Bl(Date.now());return Zr(()=>{if(!o)return;let l=setInterval(()=>{n(Date.now()/1e3)},1e4);return()=>clearInterval(l)},[]),Zr(()=>{if(a.data!==void 0)switch(a.data.status){case Tt.Pending:i>=Number(a.data.voteStartAt)&&a.mutate();break;case Tt.Active:i>=Number(a.data.voteEndAt)&&a.mutate();break;case Tt.InQueue:Date.now()/1e3+1>=Number(a.data.queueEnd)&&a.mutate();break}},[a.data?.status,i]),{...a,refresh:()=>a?.mutate?.()}};import Dl from"swr";import{formatEther as Ll}from"viem";import{berachainGovernanceAbi as Ul}from"@berachain/abis/gov/berachainGovernance";import{usePublicClient as Hl}from"@berachain/wagmi/hooks";var zR=e=>{let t=Hl(),r=Dl(t?["usePollProposalThreshold",e]:null,async([,s])=>{g(t);let a=await t.readContract({address:s,abi:Ul,functionName:"proposalThreshold"});return{votesThreshold:Ll(a)}},{refreshInterval:18e4});return{...r,refresh:r.mutate}};import Nl from"swr/infinite";var Ue=1e3,XR=(e,t)=>Nl(Vl(e,t),async([o,r])=>Kt({variables:{...e,limit:Ue,offset:Ue*r}}),{parallel:!0,initialSize:Number.POSITIVE_INFINITY}),Vl=({...e},t)=>o=>o>Math.floor(t/Ue)?null:["usePollProposalVotes",o,Ue,e.proposalId,e.orderBy,e.orderDirection];import Wl from"swr";import{formatEther as _l}from"viem";import{bgtAbi as Jr}from"@berachain/abis/pol/bgt";import{useBeraWallet as Ql,usePublicClient as Ml}from"@berachain/wagmi/hooks";var iw=e=>{let{address:t}=Ql(),o=Ml(),s=Wl(t?["usePollUserDelegates",t]:null,async([,a])=>{g(o);let{config:i}=E({chainId:o.chain.id});if(!o||!a)throw new Error("usePollUserDelegates needs publicClient and account");let[n,l]=await Promise.all([o.readContract({address:i.tokens.bgt,abi:Jr,functionName:"delegates",args:[a]}),o.readContract({address:i.tokens.bgt,abi:Jr,functionName:"getVotes",args:[a]})]);return{delegate:n,currentVotes:_l(l)}},{...e?.opts,refreshInterval:e?.opts?.refreshInterval??18e4});return{...s,refresh:()=>s?.mutate?.()}};import Yl from"swr";import{usePublicClient as Fl,useTransactionReceipt as Gl}from"@berachain/wagmi/hooks";var dw=e=>{let{data:t}=Gl({hash:e}),o=Fl();return Yl(t&&o?["useProposalFromTx",e]:null,async([,a])=>{if(!t)throw new Error("Transaction not found");if(t.transactionHash!==a)throw new Error("Transaction hash mismatch");return Gt({tx:t,publicClient:o})})};import Kl from"swr/immutable";import{berachainGovernanceAbi as ql}from"@berachain/abis/gov/berachainGovernance";import{usePublicClient as $l}from"@berachain/wagmi/hooks";var zl={0:"pending",1:"active",2:"canceled",3:"defeated",4:"succeeded",5:"queued",6:"expired",7:"executed"},bw=({proposalId:e,governorAddress:t})=>{let o=$l();return Kl(t&&o&&e?["useProposalState",e]:null,async([,s])=>{g(o);let a=await o.readContract({abi:ql,address:t,functionName:"state",args:[BigInt(s)]});return zl[a]})};import jl from"swr";import{timeLockAbi as Zl}from"@berachain/abis/gov/timeLock";import{usePublicClient as Jl}from"@berachain/wagmi/hooks";var Xl={0:"unset",1:"waiting",2:"ready",3:"done"};function Cw({proposalTimelockId:e,timelockAddress:t}){let o=Jl();return jl(t&&o&&e?["useProposalTimelockState",e,t]:null,async([,s,a])=>{g(o);let i=await o.readContract({abi:Zl,address:a,functionName:"getOperationState",args:[s]});return Xl[i]},{refreshInterval:18e4})}import ou from"swr";import{usePublicClient as ru}from"@berachain/wagmi/hooks";import{formatEther as eu}from"viem";import{berachainGovernanceAbi as tu}from"@berachain/abis/gov/berachainGovernance";async function St({at:e,publicClient:t,...o}){let{config:r}=E(o);g(t);let s=await t.readContract({address:r.governance.governor,abi:tu,functionName:"quorum",blockTag:"pending",args:[BigInt(e??Math.floor(Date.now()/1e3))]});return eu(s)}function Lw({at:e},{isEnabled:t=!0}){let o=Math.floor(Date.now()/1e3),r=ru(),s=t&&r?["useQuorum",Number(e)>o?"now":e]:null,a=ou(s,async([,i])=>i==="now"?St({publicClient:r}):St({at:i,publicClient:r}));return{...a,data:a.data?Number(a.data):void 0}}import au from"swr";import{usePublicClient as nu}from"@berachain/wagmi/hooks";import su from"swr";function ne({priceFeedMap:e},t){let o=e?Object.values(e):null,r=(t?.opts?.isEnabled??!0)&&o?["usePythLatestPrices",o]:null;return su(r,async([a,i])=>await Xt({priceFeedId:i}))}var Xr=({asset:e,amount:t,isMint:o,isBasketModeEnabled:r},s)=>{let a=nu(),{priceFeedMap:i,flags:n}=U(),{data:l}=ne({priceFeedMap:e?.address&&i?{[e.address]:i[e.address]}:void 0},{opts:{isEnabled:n.isPythWrapperEnabled&&!!e?.address}}),u=t&&e&&(n.isPythWrapperEnabled&&l?.prices.length||!n.isPythWrapperEnabled)?["useCappedGlobally",t,e,l,n.isPythWrapperEnabled,r]:null,m=au(u,async([p,c,d,f,y,A])=>A?!1:(g(a),await jt({client:a,asset:d,amount:o?c:`-${c}`,isMint:o,latestPrices:f,isPythWrapperEnabled:y})),{...s?.opts,refreshInterval:0});return{...m,refresh:()=>void m.mutate()}};import iu from"swr";import{usePublicClient as lu}from"@berachain/wagmi/hooks";var es=({asset:e,amount:t,isMint:o,isBasketModeEnabled:r},s)=>{let a=lu(),{collateralList:i,referenceCollateral:n}=U(),u=iu(e&&t?["useCappedRelatively",e,t,i,n]:null,async([m,p,c,d,f])=>{if(r)return!1;if(g(a),!o){let y=`-${c}`;return f.address!==p?!1:(await Promise.all(d.map(h=>Fe({client:a,asset:h.address,amount:y,isMint:o,referenceCollateral:f})))).some(h=>h)}return await Fe({client:a,asset:p,amount:c,isMint:o,referenceCollateral:f})},{refreshInterval:0,...s?.opts});return{...u,refresh:()=>void u.mutate()}};import uu from"swr";import{usePublicClient as pu}from"@berachain/wagmi/hooks";var ok=({collateralList:e},t)=>{let o=pu(),s=uu(o&&e?["useCollateralWeights",e]:void 0,async([a,i])=>(g(o),await $t({client:o,collateralList:i})),{...t?.opts,refreshInterval:t?.opts?.refreshInterval??1e5});return{...s,refresh:()=>void s.mutate()}};import{useMemo as xt}from"react";import mu from"swr";import{useBeraWallet as du,useConfig as cu,usePublicClient as fu}from"@berachain/wagmi/hooks";var ts=()=>{let e=fu(),{address:t}=du(),{collateralList:o}=U(),r=cu(),a=mu(t&&o&&e?["useHoneyBalances",t,o]:null,async([i,n,l])=>{g(e);let u=[...l??[],de({})];return(await Re({account:n,tokenList:u,wagmiConfig:r}))?.reduce((c,d)=>(c[d.address]=d,c),{})},{refreshInterval:1e4});return{...a,refresh:()=>a.mutate()}};import gu from"swr";import{usePublicClient as yu}from"@berachain/wagmi/hooks";var os=e=>{let t=yu(),{collateralList:o}=U(),s=gu(o&&t?["useHoneyVaultsBalance",o]:null,async([a,i])=>(g(t),await fe({client:t,collateralList:i})),{...e?.opts,refreshInterval:1e5});return{...s,refresh:()=>void s.mutate()}};import Au from"swr";import{usePublicClient as bu}from"@berachain/wagmi/hooks";var rs=({collateral:e},t)=>{let o=bu(),{priceFeedMap:r,flags:s}=U(),{data:a}=ne({priceFeedMap:e?.address?{[e.address]:r[e.address]}:void 0},{opts:{isEnabled:s.isPythWrapperEnabled&&!!e?.address}}),i=o&&e&&(s.isPythWrapperEnabled&&a?.prices.length||!s.isPythWrapperEnabled)?["useIsBadCollateralAsset",e,a,s.isPythWrapperEnabled]:null,n=Au(i,async([l,u,m,p])=>(g(o),await zt({client:o,collateral:u,latestPrices:m,isPythWrapperEnabled:p})),{...t?.opts,refreshInterval:t?.opts?.refreshInterval??1e5});return{...n,refresh:()=>void n.mutate()}};var ss=({lowerThan:e,vaultsBalances:t,state:o,collateralList:r})=>{if(!(o.actionType==="mint")&&!o.isBasketModeEnabled){let a=t?.find(l=>l.address.toLowerCase()===o.collaterals[0].address.toLowerCase()),i=new C(a?.balance.formatted??"0").lte(e),n=r.filter(l=>{let u=t?.find(m=>m.address.toLowerCase()===l.address.toLowerCase());return new C(u?.balance.formatted??"0").lte(e)});return{isLow:i,isLiquidityLowCollaterals:n}}return{isLow:!1,isLiquidityLowCollaterals:[]}},hu=({vaultsBalances:e,redeemedVaultBalance:t,state:o,collateralList:r})=>{if(!(o.actionType==="mint")&&e&&t){let a=r.filter(i=>{let n=e.find(u=>u.address.toLowerCase()===i.address.toLowerCase()),l=o.toAmount[o.collaterals.indexOf(i)];return new C(n?.balance.formatted??"0").lt(l??"0")});return{isMore:!!a.find(i=>k(i,o.collaterals[0])),isRedeemMoreThanLiquidityCollaterals:a}}return{isMore:!1,isRedeemMoreThanLiquidityCollaterals:void 0}};function Ru({state:e,honeyBalances:t,...o}){let{config:r}=E(o),s=e.actionType==="mint";return!s&&t?new C(e.fromAmount[0]).gt(t[r.honey.token]?.balance.formatted??"0"):s&&t&&e.isBasketModeEnabled!==void 0&&e.collaterals.length>0?e.isBasketModeEnabled?e.collaterals.some((a,i)=>{let n=e.fromAmount[i];return new C(t[a.address]?.balance.formatted).lt(n)}):new C(t[e.collaterals[0].address]?.balance.formatted).lt(e.fromAmount[0]):!1}var Lk=({actionType:e,collaterals:t,fromAmount:o,toAmount:r,isBasketModeEnabled:s})=>{let a={actionType:e,collaterals:t,fromAmount:o,toAmount:r,isBasketModeEnabled:s},i=e==="mint",{data:n}=rs({collateral:t[0]}),{collateralList:l}=U(),{isBlacklisted:u,isDepegged:m}=n??{isBlacklisted:!1,isDepegged:!1},{data:p}=Xr({asset:t[0],amount:i?o[0]:r[0],isMint:i,isBasketModeEnabled:s}),{data:c}=es({asset:t[0]?.address,amount:i?o[0]:r[0],isMint:i,isBasketModeEnabled:s}),{data:d}=ts(),{data:f}=os(),y=t[0]?.address,A=f?.find(I=>I.address.toLowerCase()===y.toLowerCase()),[h,R]=xt(()=>{let I=ss({lowerThan:1,vaultsBalances:f,state:a,collateralList:l}),T=ss({lowerThan:1e3,vaultsBalances:f,state:a,collateralList:l});return[I,T]},[f,a]),{isMore:b,isRedeemMoreThanLiquidityCollaterals:P}=xt(()=>hu({vaultsBalances:f,redeemedVaultBalance:A,state:a,collateralList:l}),[f,A,a,l]),w=xt(()=>Ru({state:a,honeyBalances:d}),[a,d]);return{isLiquidityDepleted:h.isLow,isLiquidityDepletedCollaterals:h.isLiquidityLowCollaterals,isRedeemMoreThanLiquidity:b,isRedeemMoreThanLiquidityCollaterals:P,isLowLiquidity:R.isLow,isLiquidityLowCollaterals:R.isLiquidityLowCollaterals,isBlacklisted:a.isBasketModeEnabled?!1:u,isDepegged:a.isBasketModeEnabled?!1:m,isCappedGlobally:p,isCappedRelatively:c,isExceedingBalance:w}};import wu from"swr";function Vk({days:e}){let t=wu(["useHoneyChartData",e],async([o,r])=>await qt({days:r}));return{...t,refresh:()=>t.mutate()}}import ku from"swr";function Yk(){let e=ku(["useHoneyGlobalData"],()=>Zt()),t=e.data?.honeySnapshots.reduce((o,r)=>new C(r.totalVolume).plus(o),new C(0));return{...e,data:{...e.data,dailyVolume:t},refresh:()=>e.mutate()}}import{useEffect as Iu,useReducer as Eu}from"react";import{formatUnits as ns}from"viem";import{defaultChainId as Tu}from"@berachain/config/internal";import Pu from"swr";import{usePublicClient as Cu}from"@berachain/wagmi/hooks";function as({state:e},t){let o=Cu(),{priceFeedMap:r,flags:s,collateralList:a}=U(),{data:i}=ne({priceFeedMap:r},{opts:{isEnabled:s.isPythWrapperEnabled&&!!a.length}}),n=e.actionType==="mint",l=o&&e&&a.length>0&&(s.isPythWrapperEnabled&&i?.prices.length||!s.isPythWrapperEnabled)?["useIsBasketModeEnabled",n,i,s.isPythWrapperEnabled,a]:null,u=Pu(l,async([m,p,c,d,f])=>(g(o),await ge({client:o,isMint:p,collateralList:f,latestPrices:c,isPythWrapperEnabled:d})),{...t?.opts,refreshInterval:t?.opts?.refreshInterval??1e4});return{...u,data:u.data,refresh:()=>void u.mutate()}}var Su={actionType:"mint",collaterals:[],fromAmount:[],toAmount:[],isBasketModeEnabled:!1,isTyping:!1,isSubmitting:!1,isLoading:!1};function is(e,t){switch(t.type){case"RESET_AMOUNTS":return{...e,fromAmount:[],toAmount:[]};case"ACTION_TYPE_CHANGE":return is({...e,actionType:t.value},{type:"RESET_AMOUNTS"});case"COLLATERALS_CHANGE":return{...e,collaterals:t.value,fromAmount:[],toAmount:[]};case"FROM_AMOUNT_CHANGE":{let o=e.fromAmount;return o[t.index]=t.value,{...e,fromAmount:o}}case"TO_AMOUNT_CHANGE":{let o=e.toAmount;return o[t.index]=t.value,{...e,toAmount:o}}case"PREVIEW_CHANGE":{let o=t.value,r=e.actionType==="mint",s=e.collaterals.map((i,n)=>t.changedAsset===i.address?r?e.fromAmount[n]:e.toAmount[n]:o.collaterals[i.address]?ns(o.collaterals[i.address],i.decimals):e.isBasketModeEnabled?"0":""),a=k(t.changedAsset,"HONEY",{chainId:Tu})?r?e.toAmount[0]:e.fromAmount[0]:o.honey?ns(o.honey,18):e.isBasketModeEnabled?"0":"";return{...e,fromAmount:r?s:[a],toAmount:r?[a]:s}}case"IS_BASKET_MODE_ENABLED_CHANGE":return{...e,isBasketModeEnabled:t.value,fromAmount:[],toAmount:[]};case"IS_TYPING_CHANGE":return{...e,isTyping:t.value};case"IS_SUBMITTING_CHANGE":return{...e,isSubmitting:t.value};case"IS_LOADING_CHANGE":return{...e,isLoading:t.value};default:throw new Error(`Unknown action type: ${t}`)}}var sP=()=>{let{collateralList:e}=U(),[t,o]=Eu(is,Su,s=>({...s,collaterals:e})),{data:r}=as({state:t});return Iu(()=>{r!==void 0&&t.isBasketModeEnabled!==r&&(o({type:"IS_LOADING_CHANGE",value:!0}),o({type:"IS_BASKET_MODE_ENABLED_CHANGE",value:r}),o({type:"IS_LOADING_CHANGE",value:!1}))},[r]),{state:t,dispatch:o}};import xu from"swr/immutable";import{usePublicClient as Bu}from"@berachain/wagmi/hooks";var mP=({pythPriceFeedCalldata:e,tokenListLength:t},o)=>{let r=Bu(),s=(o?.opts?.isEnabled??!0)&&e&&e.length>0?["usePythUpdateFee",e]:null,{data:a=eo(t),isLoading:i}=xu(s,async([n,l])=>(g(r),await to({client:r,priceFeedId:l})));return{QUERY_KEY:s,data:a,isLoading:i}};import{useMemo as vu}from"react";function gP(e){return vu(()=>{if(e)return no(e)},[e])}import Ou from"swr";import{formatEther as Du}from"viem";import{bgtAbi as Lu}from"@berachain/abis/pol/bgt";import{useBeraWallet as Uu,usePublicClient as Hu}from"@berachain/wagmi/hooks";var Nu=e=>{let{address:t}=Uu(),o=Hu(),s=Ou(t&&o?["useBgtUnstakedBalance",t]:null,async([,a])=>{g(o);let{config:i}=E({chainId:o.chain.id}),n=await o.readContract({address:i.tokens.bgt,abi:Lu,functionName:"unboostedBalanceOf",args:[a]});return Du(n)},{...e,refreshInterval:e?.opts?.refreshInterval??1e5});return{...s,refresh:()=>s.mutate()}};import Vu from"swr";import{formatUnits as Wu}from"viem";import{useBeraWallet as _u,usePublicClient as Qu}from"@berachain/wagmi/hooks";var Mu=()=>{let{address:e}=_u(),t=Qu(),r=Vu(e&&t?["useClaimableFees",e]:null,async([,s])=>{g(t);let{config:a}=E({chainId:t.chain.id}),i=await Ro({account:s,vaultAddress:a.pol.staker,publicClient:t});return Wu(i,18)},{refreshInterval:18e4*2});return{...r,refresh:()=>r?.mutate?.()}};import{GqlRewardVaultOrderBy as Ku,GqlRewardVaultOrderDirection as qu}from"@berachain/graphql/pol/api";import Yu from"swr";import{usePublicClient as Fu}from"@berachain/wagmi/hooks";var Gu=(e,t=!1)=>["useRewardVaults",e,t],Bt=(e,t)=>{let o=Gu(e.filter,e.onChainIncentives),r=Fu(),s=Yu(t?.opts?.isEnabled??!0?o:null,async([,a,i])=>await lo({filter:a,publicClient:i?r:void 0}),{...t?.opts});return{...s,refresh:s.mutate}};var NP=(e={},{isEnabled:t=!0}={})=>{let o=Bt({filter:{orderBy:Ku.Apr,orderDirection:qu.Desc,pageSize:1,where:e}},{opts:{refreshInterval:0,revalidateOnFocus:!1,refreshWhenOffline:!1,isEnabled:t}});return{isLoading:o.isLoading,highestApr:o.data?.gaugeList[0].dynamicData?.apr,refresh:o.mutate}};import $u from"swr";import{usePublicClient as zu}from"@berachain/wagmi/hooks";var ls=e=>{let t=zu(),o=$u(t?"usePollGlobalData":null,async()=>(g(t),uo(t)),{revalidateOnFocus:!1,...e?.opts});return{...o,refresh:o.mutate}};import ju from"swr/immutable";var Zu=()=>"usePollMarkets",KP=e=>{let t=Zu(),o=ju(t,async()=>await po(),{...e?.opts});return{...o,refresh:()=>o.mutate()}};import Ju from"swr/immutable";import{isAddress as Xu}from"viem";import{usePublicClient as ep}from"@berachain/wagmi/hooks";function XP({receiptTokenAddresses:e,account:t,version:o},r){let s=ep(),a=e&&t&&s&&Xu(t)&&o?["useQueuedBeraUnlock",e,t,o]:null,i=Ju(a,async([,n,l,u])=>(g(s),await Promise.all(n.map(async m=>await Ao({contractAddress:m,accountAddress:l,publicClient:s,version:u}))).then(m=>m.flat())),{refreshInterval:1e4,...r?.opts});return{...i,refresh:()=>i.mutate()}}import tp from"swr";import{isAddress as op}from"viem";import{defaultChainId as rp}from"@berachain/config/internal";import{usePublicClient as sp}from"@berachain/wagmi/hooks";var lC=({address:e},t)=>{let o=e?["useRewardTokenToBeraRate",e]:null,r=sp({chainId:rp});return tp(o,async([s,a])=>{if(!a||!op(a))throw new B({property:"address",value:a,expected:"Address"});return g(r),ie({address:a,publicClient:r})},{...t?.opts})};import cp from"swr";import np from"swr";import{erc20Abi as ip,formatUnits as lp,isAddress as up}from"viem";import{beraChefAbi as pp}from"@berachain/abis/pol/rewards/beraChef";import{usePublicClient as mp}from"@berachain/wagmi/hooks";import{erc20Abi as He,formatUnits as ap}from"viem";async function Ne({address:e,publicClient:t}){g(t);let[o,r,s,a]=await t.multicall({contracts:[{address:e,abi:He,functionName:"decimals"},{address:e,abi:He,functionName:"name"},{address:e,abi:He,functionName:"symbol"},{address:e,abi:He,functionName:"totalSupply"}],allowFailure:!0});return{address:e,decimals:o.result,name:r.result,symbol:s.result,totalSupply:a.result!==void 0?o.status==="success"?ap(a.result,o.result):a.result.toString():void 0}}var dp=e=>e&&up(e)?["onChainRewardVault",e.toLowerCase()]:null,us=({address:e},t)=>{let o=mp(),r=t.opts?.isEnabled??!0,s=dp(e);return np(r&&o?s:null,async([,a])=>{g(o);let{config:i}=E({chainId:o.chain.id}),n=await he({address:a,publicClient:o}),[l,u,m]=await Promise.all([be({address:a,stakingToken:n,publicClient:o}),o.readContract({address:i.pol.beraChef,abi:pp,functionName:"isWhitelistedVault",args:[a]}),o.readContract({address:n,abi:ip,functionName:"balanceOf",args:[a]})]),[p,c]=await Promise.all([Ne({address:n,publicClient:o}),Promise.all(l.map(d=>Z({address:d.token,chainId:o.chain.id,publicClient:o})))]);if(!p)throw new Error("Staking token not found");return{id:a,address:a,vaultAddress:a,stakingToken:{address:n,name:p.name??"",symbol:p.symbol??"",decimals:p.decimals??0},stakingTokenAmount:lp(m,p.decimals??18),isVaultWhitelisted:u,activeIncentives:l.map((d,f)=>({active:!!d.remainingAmount,remainingAmount:d.remainingAmount,remainingAmountUsd:"0",incentiveRate:d.incentiveRate,incentiveRateUsd:"0",tokenAddress:d.token,token:c[f]}))}})};var fp=e=>e?["useRewardVault",e.toLowerCase()]:null,TC=(e,t)=>{let o=fp(e),r=cp(o,async([i,n])=>co({address:n}),{...t?.opts}),s=t?.opts?.isEnabled??((!!r.error||!r.isLoading)&&!r.data),a=us({address:e},{opts:{...t?.opts,isEnabled:s}});return{data:a.data??r.data,error:a.error??r.error,isLoading:a.isLoading||r.isLoading,isValidating:a.isValidating??r.isValidating,refresh:()=>{r.mutate(),a.mutate()}}};import gp from"swr";import{usePublicClient as yp}from"@berachain/wagmi/hooks";function DC({address:e,stakingToken:t}){let o=yp(),s=gp(o&&e&&t?["useRewardVaultIncentives",e,t]:null,async([,a,i])=>(g(o),await be({address:a,stakingToken:i,publicClient:o})));return{...s,refresh:()=>s?.mutate?.()}}import Ap from"swr";import{usePublicClient as bp}from"@berachain/wagmi/hooks";var hp=(e,t)=>{let o=bp(),s=Ap(o&&e?["useRewardVaultRewards",e]:null,async([,a])=>(g(o),await ao(a,o)),{...t?.opts});return{...s,refresh:()=>s?.mutate?.()}};import Rp from"swr";var Ve=e=>{let t=[],o="";for(let r of e){if(!r.timestamp&&!r._timestamp)continue;let s=(r?.timestamp??r?._timestamp??0)*1e3,a=new Date(s),i=a.toDateString();if(i!==o){let n=new Date(a.setHours(0,0,0,0)).getTime()/1e3;t.push({...r,timestamp:n,_timestamp:n}),o=i}}return t};function FC({range:e}){let o=Rp(e?["useStakedAPR",e]:null,async([,r])=>{let s=await go({range:r});return Ve(s.sort((i,n)=>i.timestamp-n.timestamp)).map(i=>({_timestamp:i.timestamp,apr:i.apr}))});return{...o,refresh:()=>o.mutate()}}import{useMemo as We}from"react";import vt from"swr";import{useBeraWallet as wp,usePublicClient as kp}from"@berachain/wagmi/hooks";var rI=e=>{let t=_("swberaAprWindow"),o=kp(),{address:r}=wp(),s=We(()=>e.map(b=>b.receiptToken),[e]),a=We(()=>e.map(b=>b.inputTokens[0]),[e]),i=t?["useStakedData:apr",t]:null,{data:n}=vt(i,async([,b])=>fo({window:b}),{refreshInterval:1e5}),{data:l,isLoading:u}=Oe({tokens:s}),{getTokenPrice:m}=J({tokens:a}),p=o&&s.length>0?["useStakedData:exchangeRates",s]:null,{data:c}=vt(p,async([,b])=>(g(o),Promise.all(b.map(P=>ie({address:P.address,publicClient:o})))),{refreshInterval:1e5}),d=We(()=>{if(!(!l||!c))return e.map((b,P)=>{let w=b.inputTokens[0],I=l.find(Y=>Y.address===b.receiptToken.address)?.balance.raw??"0",T=c[P]??0,S=m(w)??0,H=new C(I).multipliedBy(T).dividedBy(10**w.decimals),v=H.multipliedBy(S);return{token:w,apr:n??0,stakedAmount:H.toNumber(),stakedAmountUsd:v.toNumber(),earnedAmount:0,earnedAmountUsd:0,isLoadingEarnings:!0}})},[l,c,e,n,m]),f=r&&o&&e.length>0?["useStakedData:positions",r,e]:null,{data:y,isLoading:A,isValidating:h}=vt(f,async([,b,P])=>(g(o),Promise.all(P.map(async w=>{let I=w.receiptToken,[T,S]=await Promise.all([io({address:I.address,account:b}),ie({address:I.address,publicClient:o})]);return{earnings:T,exchangeRate:S}}))),{refreshInterval:1e4}),R=We(()=>{if(!(!y||!l))return e.map((b,P)=>{let w=b.inputTokens[0],I=b.receiptToken,{earnings:T,exchangeRate:S}=y[P],O=m(w)??0,H=l.find(_e=>_e.address===I.address)?.balance.raw??"0",v=S??0,Y=new C(T.earningsTotal).minus(T.earningsRealized),F=new C(H).multipliedBy(v).minus(Y).dividedBy(10**w.decimals),G=Y.dividedBy(10**w.decimals),D=F.multipliedBy(O),q=G.multipliedBy(O);return{token:w,apr:n??0,stakedAmount:F.toNumber(),earnedAmount:G.toNumber(),stakedAmountUsd:D.toNumber(),earnedAmountUsd:q.toNumber()}})},[y,l,e,n,m]);return{balances:d,data:R,isLoading:u&&A,isLoadingBalances:u,isLoadingPositions:A,isValidatingPositions:h}};import Pp from"swr";async function ps({address:e,range:t}){let o=new Date,r=new Date(o.getTime()-Number(t)*24*60*60*1e3),{config:s}=E({}),a=`${s.staking}/vaults/${e}/total-assets-by-day?start=${r.toISOString().split("T")[0]}`;return me({url:a,type:"rest"})}function mI({range:e,addresses:t}){let r=Pp(e?["useStakedSnapshots",e,t]:null,async([,s,a])=>{let[...i]=await Promise.all([...a.map(async n=>{let l=await ps({address:n,range:s}),u=Ve(l.sort((m,p)=>m._timestamp-p._timestamp));return{[n]:u}})]);return i.reduce((n,l)=>({...n,...l}),{})});return{...r,refresh:()=>r.mutate()}}import Cp from"swr";import{usePublicClient as Ip}from"@berachain/wagmi/hooks";var bI=(e=[])=>{let t=Ip(),o=te(),r=e.length>0&&t&&o?["useStakingVaultMetadata",e,t,o]:null;return Cp(r,async([,s,a,i])=>(g(a),Promise.all(s.map(n=>yo({address:n.address,underlyingAsset:n.underlyingAsset,publicClient:a,blockTime:i})))),{refreshInterval:1e4})};import Ep from"swr";import{usePublicClient as Tp}from"@berachain/wagmi/hooks";function PI({vaultAddresses:e}){let t=Tp(),o=Ep(e&&t?["useTotalStakedAmount",e]:null,([,r])=>bo({vaultAddresses:r,publicClient:t}));return{...o,refresh:()=>o.mutate()}}import Sp from"swr";import{useBeraWallet as xp,usePublicClient as Bp}from"@berachain/wagmi/hooks";var vp=(e,t)=>{let{address:o}=xp(),r=Bp(),s=o&&r&&e.vaultAddress?["useUserVaultInfo",o,e.vaultAddress]:null,a=Sp(s,async([,i,n])=>(g(r),wo({account:i,vaultAddress:n,publicClient:r})),{...t,refreshInterval:t?.opts?.refreshInterval??1e5});return{...a,refresh:()=>a.mutate()}};import Op from"swr";import{useBeraWallet as Dp,usePublicClient as Lp}from"@berachain/wagmi/hooks";var Up=e=>{let{address:t}=Dp(),o=Lp(),s=Op(t&&o?["useUserVaults",t]:null,async([,a])=>(g(o),await ko({account:a,publicClient:o})),{...e,refreshInterval:e?.opts?.refreshInterval??1e5,keepPreviousData:!0});return{...s,refresh:()=>s?.mutate?.()}};import Hp from"swr";import{usePublicClient as Np}from"@berachain/wagmi/hooks";var WI=e=>{let t=Np();return Hp(e&&t?["useVaultAddress",e]:null,async([,r])=>{g(t);let[s]=await Promise.all([he({address:r,publicClient:t})]);return{stakeToken:s,address:r}})};import Vp from"swr";var YI=({vault:e,range:t,resolution:o})=>{let s=Vp(e?["useVaultHistory",e,t,o]:null,([,a,i,n])=>Po({vault:a,range:i,resolution:n}));return{...s,refresh:()=>s.mutate()}};import Wp from"swr";var _p=(e,t)=>{let r=Wp(e?["useVaultValidators",e]:null,async([,s])=>await Co({address:s}),{...t?.opts});return{...r,refresh:()=>r.mutate()}};import{zeroAddress as Qp}from"viem";function ms({address:e},t){let o=se({addressIn:e?[e]:void 0},t);return{...o,data:e?o.data?.[e.toLowerCase()]:void 0}}function JI(e){return ms({address:Qp},e)}import Mp from"swr/immutable";import{isAddress as Yp,zeroAddress as Fp}from"viem";import{usePublicClient as Gp}from"@berachain/wagmi/hooks";var aE=(e,t)=>{let o=Gp(),r=e?.address&&o&&Yp(e.address)?["useStakingTokenInformation",e.address]:null,s=Mp(r,async([a,i])=>k(i,"BERA")?{address:Fp,decimals:N.decimals,name:N.name,symbol:N.symbol}:await Ne({address:i,publicClient:o}),{...t?.opts});return{...s,refresh:()=>s?.mutate?.()}};function lE({token:e},t){let{isLoading:o,priceMap:r}=J({tokens:e?[e]:void 0},t);return{data:e?r[e.chainId]?.[e.address.toLowerCase()]:void 0,isLoading:o}}import Kp from"swr";import{erc20Abi as qp}from"viem";import{usePublicClient as $p}from"@berachain/wagmi/hooks";function fE({address:e}){let t=$p();return Kp(e&&t?["useTotalSupply",e]:null,([,o])=>(g(t),t.readContract({address:o,abi:qp,functionName:"totalSupply",args:[]})))}import zp from"swr/immutable";import{useBlockNumber as jp,usePublicClient as Zp}from"@berachain/wagmi/hooks";function PE(e){let t=Zp(),{config:o}=E({chainId:t?.chain.id}),{data:r,isLoading:s}=jp({cacheTime:ye(o.averageBlockTime)}),{data:a}=zp(r&&t&&Number(e)>0?["useBlockToTimestamp",e,r]:null,async([,n,l])=>(g(t),so({block:n,currentBlock:l,blockTime:i,publicClient:t}))),i=te();if(a)return Number(a.timestamp);if(!(s||!r))return Math.floor(ro(Date.now())+i*(Number(e)-Number(r)))}import{useCallback as cs,useReducer as Jp}from"react";import{useBeraWagmi as Xp,useConfig as em}from"@berachain/wagmi/hooks";var Ot={confirmState:"idle",txnHash:"",message:""},ds=(e,t)=>{switch(t.type){case"confirm_sending":return{...e,confirmState:"loading"};case"confirm_receipt":return{...e,confirmState:"success"};case"confirm_error":return{...e,confirmState:"fail"};case"confirm_submitting":return{...e,confirmState:"submitting"};case"confirm_reset":return{...Ot};default:return e}};function tm({onlyPermissionless:e,onSuccess:t,onError:o,onLoading:r,onWarning:s,onSubmission:a}={}){let[i,n]=Jp(ds,Ot),{account:l,onSmartAccountRejection:u}=Xp(),m=em(),p=l?.wallet?.isContract?6e4*10:12e4,c=cs(()=>{n({type:"confirm_reset"})},[]),d=_("enableSimulateCalls"),f=cs(y=>{if(e&&!y.permissionless){let A=new To({message:"Trying to send a non-permissionless transaction with an overridden account",displayMessage:"You can't send this transaction with an overridden account. Please reset the account in the settings popover.",level:"info",input:y});throw s?.(A,y),o?.(A,y),A}return So({wagmiConfig:m,...y,txConfirmationTimeout:p,enableSimulateCalls:d,onLoading(...A){n({type:"confirm_sending"}),y.onLoading?.(y),r?.(...A)},onWarning(...A){y.onWarning?.(A[0],y),s?.(...A)},onSubmission(...A){n({type:"confirm_submitting"}),y.onSubmission?.(A[0],y),a?.(...A)},onSuccess(...A){n({type:"confirm_receipt"}),y.onSuccess?.(A[0],y),t?.(...A)},onError(...A){n({type:"confirm_error"}),y.onError?.(A[0],y),A[0].reason==="AtomicReadyWalletRejectedUpgradeError"&&u(),o?.(...A)}})},[m,r,s,a,t,o,e,d]);return{isLoading:i.confirmState==="loading",isSubmitting:i.confirmState==="submitting",isSuccess:i.confirmState==="success",isError:i.confirmState==="fail",write:f,reset:c}}var om=tm;import rm from"swr/immutable";import{isAddress as sm,zeroAddress as am}from"viem";import{chainId as nm}from"@berachain/config/internal";async function im(e){let t=await me({url:`https://api.routescan.io/v2/network/testnet/evm/${nm}/etherscan/api?module=contract&action=getabi&address=${e}`,type:"rest",name:"RouteScan"});if(t.status==="0")throw new Error(t.result);return t.result}var QE=e=>rm(e&&sm(e)&&e!==am?["useGetVerifiedAbi",e]:null,()=>e?im(e):Promise.resolve(""),{});import{useCallback as fs,useEffect as lm,useState as um}from"react";function FE({key:e,defaultValue:t}){let o=fs(()=>{if(typeof window>"u")return t;let i=window.history.state?.[e];return i!==void 0?i:t},[e,t]),[r,s]=um(o()),a=fs(i=>{let n=o(),l=i instanceof Function?i(n):i,m={...window.history.state||{},[e]:l};window.history.replaceState(m,""),s(l)},[e,o]);return lm(()=>{if(window.history.state?.[e]===void 0){let l={...window.history.state||{},[e]:t};window.history.replaceState(l,"")}},[e,t]),[r,a]}import{useEffect as pm,useRef as mm}from"react";function qE(e){let t=mm(void 0);return pm(()=>{t.current=e}),t.current}import dm from"swr";var cm=({variables:e}={})=>["useAllValidators",e],JE=(e,t)=>{let{config:o}=E(e),r=dm(cm({variables:e}),async([,s])=>await xo({variables:{chain:o.bex.chainName,...s}}),{refreshInterval:18e4,...t?.opts});return{...r,refresh:()=>r.mutate()}};import fm from"swr";function oT({allocation:e}){return fm(e?["useApiEnrichedAllocation",e]:null,([,t])=>Bo({allocation:t}))}import gm from"swr";import{isHex as ym}from"viem";var Am=e=>e?["useApiValidator",e]:null,gs=(e,t)=>{let o=Am(e),r=t?.opts?.isEnabled??!0,s=gm(r&&e?o:null,async([,a])=>{if(!a||!ym(a))throw new Error(`Invalid validator ID: ${a}`);return vo({id:a})},{...t?.opts});return{...s,refresh:()=>s.mutate()}};import hm from"swr";import{usePublicClient as Rm}from"@berachain/wagmi/hooks";import{rewardAllocatorFactoryAbi as bm}from"@berachain/abis/pol/rewards/rewardAllocatorFactory";async function ys({publicClient:e,...t}){let{config:o}=E(t),r=await e.readContract({abi:bm,address:o.pol.rewardAllocationFactory,functionName:"getBaselineAllocation"}),s=r.startBlock!==0n?await e.getBlock({blockNumber:r.startBlock}):{timestamp:0};return Do(r,Number(s.timestamp))}function yT(){let e=Rm();return hm(e?["baselineRewardAllocation"]:null,()=>(g(e),ys({publicClient:e})))}import wm from"swr";var km=({pubKey:e,first:t=1})=>{let r=wm(e?["useDailyValidatorBlockStats",e,t]:null,async([,s,a])=>await Oo({pubKey:s,first:a}),{refreshInterval:18e4});return{...r,refresh:()=>r.mutate()}};import Pm from"swr";import{usePublicClient as Cm}from"@berachain/wagmi/hooks";function Im(e){let t=Cm(),r=Pm(t?["useDefaultRewardAllocation"]:null,async()=>(g(t),await Uo({client:t})),{...e?.opts});return{...r,refresh:()=>r.mutate()}}import{useMemo as bs}from"react";import Sm from"swr";import{useBeraWallet as xm,usePublicClient as Bm}from"@berachain/wagmi/hooks";import{zeroAddress as Em}from"viem";import{beraChefAbi as Tm}from"@berachain/abis/pol/rewards/beraChef";async function As({client:e,pubKey:t,...o}){let{config:r}=E(o);try{let s=await e.readContract({address:r.pol.beraChef,abi:Tm,functionName:"valRewardAllocator",args:[t]});return s===Em?null:s}catch(s){throw console.log("getValidatorRewardAllocatorAddress:",s),s}}function hs(e,t){return!e||!t?!1:t.operator?.toLowerCase()===e.toLowerCase()}function vm(e,t){return!e||!t?!1:t.rewardAllocator?t.rewardAllocator.toLowerCase()===e.toLowerCase():hs(e,t)}function Om({pubKey:e,account:t},o){let r=Bm(),s=_("mockValidatorOperator"),a=_("mockValidatorRewardAllocator"),i=r&&e?["useManagedValidatorRole",e]:null,{address:n}=xm(),l=t??n,u=Sm(i,async([,c])=>{g(r);let[d,f]=await Promise.all([Yo({client:r,pubKey:c}),As({client:r,pubKey:c})]);return{operator:d??null,rewardAllocator:f}},{...o?.opts}),m=bs(()=>s||hs(l,u.data),[l,s,u.data]),p=bs(()=>a||vm(l,u.data),[l,a,u.data]);return{...u,data:u.data?{...u.data,hasOperatorRole:m,hasRewardAllocatorRole:p}:void 0,refresh:()=>u.mutate()}}import Dm from"swr";import{keccak256 as Lm}from"viem";import{beaconDepositAbi as Um}from"@berachain/abis/pol/beaconDeposit";import{bgtAbi as Hm}from"@berachain/abis/pol/bgt";import{beraChefAbi as Nm}from"@berachain/abis/pol/rewards/beraChef";import{usePublicClient as Vm}from"@berachain/wagmi/hooks";var Rs=({pubkey:e},t)=>{let o=Vm(),r=e?["useOnChainValidator",e]:null,s=t.opts?.isEnabled??!0,a=Dm(s&&o?r:null,async([,i])=>{g(o);let{config:n}=E({chainId:o.chain.id}),[l,u,m]=await Promise.all([o.readContract({address:n.depositContract,abi:Um,functionName:"getOperator",args:[i]}),o?.readContract({address:n.tokens.bgt,abi:Hm,functionName:"boostees",args:[i]}),o.readContract({address:n.pol.beraChef,abi:Nm,functionName:"getActiveRewardAllocation",args:[i]})]);return{id:Lm(i),pubkey:i,operator:l,votingPower:Number(u)}});return{...a,refresh:()=>{a.mutate()}}};import Wm from"swr";import{usePublicClient as _m}from"@berachain/wagmi/hooks";var ZT=({valPubKey:e,options:t})=>{let o=_m(),s=(t?.opts?.isEnabled??!0)&&o&&e?["useStakingPoolBatch",e]:null,a=Wm(s,async([,i])=>(g(o),await Ho({client:o,valPubKey:i})),{refreshInterval:1e4,...t?.opts});return{...a,refresh:()=>a.mutate()}};import Qm from"swr";import{useBeraWallet as Mm,usePublicClient as Ym}from"@berachain/wagmi/hooks";var Fm=e=>{let{address:t}=Mm(),o=Ym(),s=Qm(o&&t?["useUserActiveValidators",t]:null,async([,a])=>await Vo({account:a,publicClient:o}),{...e,refreshInterval:e?.opts?.refreshInterval??18e4,keepPreviousData:!0});return{...s,refresh:()=>s?.mutate?.()}};import Gm from"swr";import{useBeraWallet as Km,usePublicClient as qm}from"@berachain/wagmi/hooks";var $m=({pubkey:e,...t})=>{let{address:o}=Km(),r=qm(),s=t.account??o,i=Gm(s&&e?["useUserBoostsOnValidator",e,s]:null,async([,n,l])=>await No({account:l,pubkey:n,publicClient:r}),{refreshInterval:1e5});return{...i,refresh:()=>i.mutate()}};import{useCallback as zm,useMemo as jm}from"react";import ks from"swr";import{useBeraWallet as Zm}from"@berachain/wagmi/hooks";var ws=e=>{let t=new Set;return e.forEach(o=>{Array.isArray(o.rewards)&&o.rewards.forEach(r=>{r.token&&t.add(r.token)})}),t};var Jm=()=>{let{address:e}=Zm(),o=ks(e?["useUserClaimableIncentives",e]:null,async([,l])=>{if(!l)throw new L({message:"useUserClaimableIncentives needs a logged in account",level:"error"});return await ho({account:l})},{revalidateOnFocus:!1,revalidateOnReconnect:!1,revalidateIfStale:!1,refreshInterval:18e4}),r=o?.data,s=jm(()=>{if(r){if(!Array.isArray(r)){Ae.captureException(new L({message:"Incorrect aggregated incentives data receieved.",level:"error",extra:{allRewards:r,account:e}}));return}return ws(r)}},[r,e]),i=ks(e&&r?["useUserClaimableIncentives",e,r]:null,async([,l,u])=>{if(!l)throw new B({property:"account",value:l,expected:"Address"});if(!u)return[];if(!Array.isArray(u))throw new B({message:"Incorrect aggregated incentives data receieved to calculate proofs.",property:"allRewards",value:u,expected:"Array",level:"error"});let m=new Set(u.map(c=>c.validator)),p=Array.from(m);return await Promise.all(p.map(async c=>({...await mo({account:l,validator:c,page:1,perPage:1e4}),validator:c})))},{revalidateOnFocus:!1,revalidateOnReconnect:!1,revalidateIfStale:!1,refreshInterval:18e4}),n=zm(()=>{o?.mutate(),i?.mutate()},[o,i]);return{...i,isLoading:o?.isLoading||i?.isLoading,tokenMap:s,refresh:n}};import Xm from"swr/immutable";var RS=({account:e,validatorAddress:t})=>{let r=Xm(e?["useUserStakingPositions",e,t]:null,async([s,a,i])=>{let n=await Wo(a);return i?n.filter(l=>l.validatorAddress.toLowerCase()===i.toLowerCase()):n});return{...r,refresh:()=>{r.mutate()}}};import{keccak256 as ed}from"viem";function IS({pubkey:e},t){let{data:{validator:o,uptime:r}={},isLoading:s,error:a}=gs(ed(e),t),{data:i,isLoading:n,error:l}=Rs({pubkey:e},t);return{data:{uptime:r,validator:o||i?{...o,...i,operator:i?.operator??o?.operator,dynamicData:{activeBoostAmount:i?.dynamicData?.activeBoostAmount??o?.dynamicData?.activeBoostAmount??"",queuedBoostAmount:o?.dynamicData?.queuedBoostAmount??"",usersActiveBoostCount:o?.dynamicData?.usersActiveBoostCount??0,usersQueuedBoostCount:o?.dynamicData?.usersQueuedBoostCount??0,allTimeDistributedBGTAmount:o?.dynamicData?.allTimeDistributedBGTAmount??"0",rewardRate:i?.dynamicData?.rewardRate??o?.dynamicData?.rewardRate??"",stakedBeraAmount:o?.dynamicData?.stakedBeraAmount??"",lastDayDistributedBGTAmount:o?.dynamicData?.lastDayDistributedBGTAmount??"",activeBoostAmountRank:o?.dynamicData?.activeBoostAmountRank??0,boostApr:o?.dynamicData?.boostApr??0,commissionOnIncentives:o?.dynamicData?.commissionOnIncentives??0},id:i?.id??o?.id,pubkey:i?.pubkey??o?.pubkey,metadata:i?.metadata??o?.metadata,rewardAllocationWeights:i?.rewardAllocationWeights??o?.rewardAllocationWeights??[]}:null},isLoading:s||n,error:a||l}}import td from"swr";function od({pubkey:e,dayRange:t}){let r=td(e&&t?["useValidatorAnalytics",e,t]:null,async([,s,a])=>await _o({pubkey:s,dayRange:a}),{refreshInterval:18e4});return{...r,refresh:()=>r.mutate()}}import rd from"swr";import{usePublicClient as sd}from"@berachain/wagmi/hooks";var ad=(e,t)=>{let o=sd(),s=rd(o&&e?["useValidatorCommission",e]:null,async([,a])=>await Qo({client:o,pubKey:a}),{...t?.opts});return{...s,refresh:()=>s.mutate()}};var nd=e=>{let{data:t,isLoading:o}=ls(),r=te();return{data:t?Mo(e,Number(t?.totalStakedBeraAmount),r):void 0,isLoading:o}};import id from"swr";import{usePublicClient as ld}from"@berachain/wagmi/hooks";function ud(e,t){let o=ld(),s=id(o&&e?["useValidatorQueuedCommission",e]:null,async([,a])=>(g(o),await Fo({client:o,pubKey:a})),{...t?.opts});return{...s,refresh:()=>s.mutate()}}import pd from"swr";import{usePublicClient as md}from"@berachain/wagmi/hooks";var dd=(e,t)=>{let o=md(),s=pd(o&&e?["useValidatorQueuedOperatorAddress",e]:null,async([,a])=>await Go({client:o,pubKey:a}),{...t?.opts});return{...s,refresh:()=>s.mutate()}};import cd from"swr";import{usePublicClient as fd}from"@berachain/wagmi/hooks";var gd=(e,t)=>{let o=fd(),s=cd(o&&e?["useValidatorQueuedRewardAllocation",e]:null,async([,a])=>await Ko({client:o,pubKey:a}),{...t?.opts});return{...s,refresh:()=>s.mutate()}};import yd from"swr";import{usePublicClient as Ad}from"@berachain/wagmi/hooks";function bd(e,t){let o=Ad(),s=yd(o&&e?["useValidatorRewardAllocation",e]:null,async([,a])=>await Lo({client:o,pubKey:a}),{...t?.opts});return{...s,refresh:()=>s.mutate()}}export{La as OracleMode,cr as USE_AGGREGATORS_QUOTES_QUERY_KEY,is as reducer,jf as useAggregatorsQuotes,ke as useAggregatorsRouterFeeBps,fr as useAllUserPools,Ca as useAllUserPoolsQueryKey,JE as useAllValidators,cm as useAllValidatorsQueryKey,oT as useApiEnrichedAllocation,gr as useApiPool,Ta as useApiPoolQueryKey,gs as useApiValidator,Am as useApiValidatorQueryKey,yT as useBaselineRewardAllocation,Sb as useBendDemultiply,Gb as useBendMultiply,uh as useBendZapSupply,Di as useBendZapSupplyHelper,om as useBeraContractWrite,JI as useBeraCurrentPrice,Ge as useBexStatus,gP as useBgtAprSimulation,Nu as useBgtUnstakedBalance,PE as useBlockToTimestamp,Xr as useCappedGlobally,es as useCappedRelatively,Mu as useClaimableFees,ok as useCollateralWeights,wg as useCreatePool,il as useCreateProposal,km as useDailyValidatorBlockStats,Im as useDefaultRewardAllocation,Bh as useEnsoSwapBundle,hd as useEnsoUserTokensWithBalances,Og as useExploitedTokens,Ya as useExploitedTokensQueryKey,zo as useGetConvertToAssets,mR as useGetPastVotes,QE as useGetVerifiedAbi,Ga as useGlobalLiquidityAndSwapVolume,hR as useHasVoted,NP as useHighestVaultsAPR,FE as useHistoryState,Lk as useHoneyAlerts,ts as useHoneyBalances,Vk as useHoneyChartData,Yk as useHoneyGlobalData,sP as useHoneySwapState,os as useHoneyVaultsBalance,rs as useIsBadCollateralAsset,as as useIsBasketModeEnabled,SR as useIsCanceller,_g as useLiquidityMismatch,ky as useLpPosition,Om as useManagedValidatorRole,En as useMultipleTokenApprovalsWithSlippage,xr as useMultipleTokenInformation,Br as useOnChainPoolData,_n as useOnChainPoolDataQueryKey,Rs as useOnChainValidator,LR as usePollAllProposals,xl as usePollAllProposalsQueryKey,Tr as usePollAllowances,Ie as usePollBalance,ls as usePollGlobalData,KP as usePollMarkets,Zu as usePollMarketsQueryKey,Gn as usePollPoolCreationRelayerApproval,MR as usePollProposal,zR as usePollProposalThreshold,XR as usePollProposalVotes,Vl as usePollProposalVotesQueryKey,iw as usePollUserDelegates,Oe as usePollWalletBalances,yA as usePool,RA as usePoolEvents,IA as usePoolHistoricalData,OA as usePools,jn as usePoolsQueryKey,qE as usePrevious,Te as usePriceImpact,dw as useProposalFromTx,qr as useProposalSnapshot,bw as useProposalState,Cw as useProposalTimelockState,ne as usePythLatestPrices,mP as usePythUpdateFee,XP as useQueuedBeraUnlock,Lw as useQuorum,lC as useRewardTokenToBeraRate,TC as useRewardVault,Pr as useRewardVaultBalanceFromStakingToken,At as useRewardVaultFromToken,DC as useRewardVaultIncentives,fp as useRewardVaultQueryKey,hp as useRewardVaultRewards,Bt as useRewardVaults,Gu as useRewardVaultsQueryKey,ya as useSingleAggregatorQuote,FC as useStakedAPR,rI as useStakedData,mI as useStakedSnapshots,ZT as useStakingPoolBatch,aE as useStakingTokenInformation,bI as useStakingVaultsMetadata,ms as useTokenCurrentPrice,se as useTokenCurrentPrices,Cr as useTokenInformation,lE as useTokenPrice,J as useTokenPrices,oe as useTokens,PI as useTotalStakedAmount,fE as useTotalSupply,Fm as useUserActiveValidators,$m as useUserBoostsOnValidator,Jm as useUserClaimableIncentives,RS as useUserStakingPositions,vp as useUserVaultInfo,Up as useUserVaults,IS as useValidator,od as useValidatorAnalytics,ad as useValidatorCommission,nd as useValidatorEstimatedBgtPerYear,ud as useValidatorQueuedCommission,dd as useValidatorQueuedOperatorAddress,gd as useValidatorQueuedRewardAllocation,bd as useValidatorRewardAllocation,WI as useVaultAddress,YI as useVaultHistory,_p as useVaultValidators,Vh as useZapStakeBera};
4
4
  //# sourceMappingURL=exports.mjs.map