@berachain/berajs 0.2.8-beta.6 → 0.2.8-beta.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/actions/exports.cjs +1 -1
- package/dist/actions/exports.cjs.map +1 -1
- package/dist/actions/exports.d.cts +95 -50
- package/dist/actions/exports.d.ts +95 -50
- package/dist/actions/exports.mjs +1 -1
- package/dist/actions/exports.mjs.map +1 -1
- package/dist/{chunk-G4CNETLS.mjs → chunk-6K252BGM.mjs} +2 -2
- package/dist/{chunk-I7M43BB4.cjs → chunk-D6L7LTA2.cjs} +2 -2
- package/dist/chunk-D6L7LTA2.cjs.map +1 -0
- package/dist/{chunk-T5FSQ3YE.mjs → chunk-JDZGYU5T.mjs} +2 -2
- package/dist/{chunk-T5FSQ3YE.mjs.map → chunk-JDZGYU5T.mjs.map} +1 -1
- package/dist/{chunk-7EAKCNQT.cjs → chunk-JLFBRMOF.cjs} +2 -2
- package/dist/{chunk-7EAKCNQT.cjs.map → chunk-JLFBRMOF.cjs.map} +1 -1
- package/dist/chunk-MASD43N5.mjs +4 -0
- package/dist/chunk-MASD43N5.mjs.map +1 -0
- package/dist/chunk-MGGPHKA2.cjs +4 -0
- package/dist/{chunk-WD4B3SXS.cjs.map → chunk-MGGPHKA2.cjs.map} +1 -1
- package/dist/{chunk-S5VOCVBR.mjs → chunk-UENDEN3M.mjs} +2 -2
- package/dist/{chunk-E32UP4GV.cjs → chunk-UFIM7WQ4.cjs} +2 -2
- package/dist/{chunk-E32UP4GV.cjs.map → chunk-UFIM7WQ4.cjs.map} +1 -1
- package/dist/contexts/exports.cjs +1 -1
- package/dist/contexts/exports.mjs +1 -1
- package/dist/enum/exports.cjs +1 -1
- package/dist/enum/exports.d.cts +1 -1
- package/dist/enum/exports.d.ts +1 -1
- package/dist/enum/exports.mjs +1 -1
- package/dist/{getValidatorQueuedOperatorAddress-DUZOmxLV.d.ts → getValidatorQueuedOperatorAddress-BcyxE9uw.d.ts} +2 -2
- package/dist/{getValidatorQueuedOperatorAddress-BQXkSFd9.d.cts → getValidatorQueuedOperatorAddress-Cql_D50j.d.cts} +2 -2
- package/dist/{global.d-SU9Epq0M.d.ts → global.d-5w_lvl2J.d.ts} +1 -1
- package/dist/{global.d-6aSWIkV_.d.cts → global.d-B7IeayVX.d.cts} +1 -1
- package/dist/hooks/exports.cjs +3 -3
- package/dist/hooks/exports.cjs.map +1 -1
- package/dist/hooks/exports.d.cts +4 -4
- package/dist/hooks/exports.d.ts +4 -4
- package/dist/hooks/exports.mjs +3 -3
- package/dist/hooks/exports.mjs.map +1 -1
- package/dist/{txnEnum-CCuQUFlh.d.cts → txnEnum-7_o92X3N.d.cts} +2 -0
- package/dist/{txnEnum-CCuQUFlh.d.ts → txnEnum-7_o92X3N.d.ts} +2 -0
- package/dist/types/exports.d.cts +2 -2
- package/dist/types/exports.d.ts +2 -2
- package/package.json +4 -4
- package/src/actions/clients/getApolloClient.ts +11 -4
- package/src/actions/dex/getOnChainPool.ts +1 -1
- package/src/actions/enso/getBendMultiplyBundle.ts +9 -2
- package/src/actions/enso/util.ts +6 -8
- package/src/actions/governance/checkProposalField.ts +108 -54
- package/src/actions/governance/computeActualStatus.ts +7 -3
- package/src/actions/governance/getAllProposals.ts +15 -8
- package/src/actions/governance/getBodyErrors.ts +13 -5
- package/src/actions/governance/getDecodedFunctionData.ts +27 -19
- package/src/actions/governance/getProposalDetails.ts +8 -4
- package/src/actions/governance/getProposalFromTx.ts +19 -10
- package/src/actions/governance/getProposalParams.ts +17 -17
- package/src/actions/governance/getProposalVotes.ts +7 -3
- package/src/actions/governance/getQuorum.ts +7 -7
- package/src/actions/governance/parseProposalBody.ts +19 -9
- package/src/actions/pol/getRewardVaultIncentives.ts +2 -2
- package/src/actions/tokens/getTokenInformation.ts +8 -15
- package/src/enum/txnEnum.ts +2 -0
- package/dist/chunk-5NDYN2IB.mjs +0 -4
- package/dist/chunk-5NDYN2IB.mjs.map +0 -1
- package/dist/chunk-I7M43BB4.cjs.map +0 -1
- package/dist/chunk-WD4B3SXS.cjs +0 -4
- /package/dist/{chunk-G4CNETLS.mjs.map → chunk-6K252BGM.mjs.map} +0 -0
- /package/dist/{chunk-S5VOCVBR.mjs.map → chunk-UENDEN3M.mjs.map} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/pong/coding/monobera/packages/berajs/dist/chunk-7EAKCNQT.cjs","../src/contexts/BeraFlags/BeraFlags.tsx","../src/contexts/BexStatusProvider.tsx","../src/contexts/block-time-provider.tsx","../src/contexts/HoneyConfigProvider.tsx","../src/hooks/enso/useEnsoUserTokensWithBalances.ts","../src/actions/enso/getEnsoUserTokensWithBalances.ts","../src/contexts/TokensProvider.tsx","../src/utils/formatTokenList.ts"],"names":["BeraFlagContext","createContext","BeraFlagsProvider","children","flags","aggregators","swberaAprWindow","jsx","defaultFlags","value","isFlagEnabled","key","useBeraFlags","context","useContext","useBeraFlag","BexStateContext","useBexStatus","BeraError","BexStatusProvider","isVaultPaused","labels","factories","poolState","setPoolState","useState","disablePoolWithdrawals","disablePoolDeposits","useBlockTime","BlockTimeContext","mainnet","BlockTimeProvider","blockTime","args","config","parseBaseArgs","HoneyConfigContext","HoneyConfigProvider","props","useHoneyConfig","getEnsoUserTokensWithBalances","account","wagmiConfig","chainId","ensoClient","tokens","balance","isToken","beraToken","formatUnits","tokenByChainId","a","balances","chainTokens","chainConfig","getChains","chain","multicallAddress","BeraMonitoring","InvalidArgumentError","multicall","token","getBalanceCall","tokensWithBalances","index","initBeraError","flattenedBalances","result","b","aValue","useEnsoUserTokensWithBalances","options","fromAddress","useBeraWallet","useConfig","isEnabled","swrResponse","useSWR","getEnsoClient","formatTokenList","defaultTokenList","externalList","defaultList","featuredTokenList","tag","mergedList","item","i","TokenContext","TokensProvider","defaultTokens","edgeConfigTokenList","userTokens","onAddToken","onRemoveToken","ensoTokens","refresh","tokenList","useMemo","t","tk"],"mappings":"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","file":"/Users/pong/coding/monobera/packages/berajs/dist/chunk-7EAKCNQT.cjs","sourcesContent":[null,"import { createContext, useContext } from \"react\";\n\nimport {\n type EdgeConfigSchema,\n isFlagEnabled,\n} from \"@berachain/config/internal/edge-config\";\n\nimport { type BeraFlags, defaultFlags } from \"./defaultFlags\";\n\nexport type { BeraFlags };\n\nexport type BeraFlagsContextReturn = BeraFlags & {\n /**\n * A list of aggregators that are enabled. If not provided, all aggregators are enabled.\n */\n aggregators: string[] | undefined;\n swberaAprWindow: Exclude<\n EdgeConfigSchema[\"pol\"][\"swberaAprWindow\"],\n undefined\n >;\n};\n\nconst BeraFlagContext = createContext<BeraFlagsContextReturn | undefined>(\n undefined,\n);\n\nexport function BeraFlagsProvider({\n children,\n flags,\n aggregators,\n swberaAprWindow = \"DAY\",\n}: {\n children: React.ReactNode;\n flags: BeraFlags;\n aggregators?: NonNullable<EdgeConfigSchema[\"bex\"]>[\"aggregators\"];\n swberaAprWindow?: EdgeConfigSchema[\"pol\"][\"swberaAprWindow\"];\n}) {\n return (\n <BeraFlagContext.Provider\n value={{\n ...defaultFlags,\n ...flags,\n aggregators: aggregators\n ? Object.entries(aggregators)\n .filter(([, value]) => isFlagEnabled(value))\n .map(([key]) => key)\n : undefined,\n swberaAprWindow,\n }}\n >\n {children}\n </BeraFlagContext.Provider>\n );\n}\n\nexport function useBeraFlags() {\n const context = useContext(BeraFlagContext);\n if (!context) {\n throw new Error(\"BeraFlagsProvider not found\");\n }\n return context;\n}\n\nexport function useBeraFlag<T extends keyof BeraFlagsContextReturn>(\n key: T,\n): BeraFlagsContextReturn[T] {\n const flags = useBeraFlags();\n return flags[key];\n}\n","import {\n createContext,\n type Dispatch,\n type PropsWithChildren,\n type SetStateAction,\n useContext,\n useState,\n} from \"react\";\nimport type { Hex } from \"viem\";\n\nimport type { EdgeConfigSchema } from \"@berachain/config/internal/edge-config\";\n\nimport { BeraError } from \"../errors/BeraError\";\n\ntype FactoryStatus = {\n /**\n * If the composable stable factory is enabled\n */\n composableStable: \"paused\" | \"enabled\";\n /**\n * If the weighted factory is enabled\n */\n weighted: \"paused\" | \"enabled\";\n};\nexport interface BexStatusProviderProps {\n isVaultPaused: boolean;\n pool?: {\n id: Hex;\n isInRecoveryMode: boolean;\n isPaused: boolean;\n };\n factories: FactoryStatus;\n labels?: NonNullable<EdgeConfigSchema[\"bex\"]>[\"emergencyLabels\"];\n}\n\nexport const BexStateContext = createContext<{\n protocol: {\n isPaused: boolean;\n factories: FactoryStatus & { allPaused: boolean };\n };\n onPoolChange: Dispatch<SetStateAction<BexStatusProviderProps[\"pool\"]>>;\n pool?: {\n id: Hex;\n isInRecoveryMode: boolean;\n isPaused: boolean;\n disablePoolWithdrawals: boolean;\n disablePoolDeposits: boolean;\n };\n labels?: NonNullable<EdgeConfigSchema[\"bex\"]>[\"emergencyLabels\"];\n}>({\n protocol: {\n isPaused: false,\n factories: {\n composableStable: \"enabled\",\n weighted: \"enabled\",\n allPaused: false,\n },\n },\n onPoolChange: () => {},\n pool: undefined,\n});\n\n/**\n * @description Determines the status of a pool or vault and returns the appropriate messages and flags to disable functionality.\n * More information here https://www.notion.so/berachain/BEX-RecoveryMode-and-Pause-explained-17c6120abced80e0985dd589b57ff018\n *\n * @returns status flags to enable/disable/notify users across the BEX\n *\n **/\nexport function useBexStatus() {\n const context = useContext(BexStateContext);\n\n if (!context) {\n throw new BeraError({\n level: \"fatal\",\n message: \"BexStateContext is not defined\",\n });\n }\n\n return context;\n}\n\nexport function BexStatusProvider({\n children,\n isVaultPaused,\n labels,\n factories,\n}: PropsWithChildren<BexStatusProviderProps>) {\n const [poolState, setPoolState] = useState<BexStatusProviderProps[\"pool\"]>();\n // Determine whether to disable withdrawals for a pool (vault pause does not impact this)\n const disablePoolWithdrawals =\n (poolState?.isPaused && !poolState?.isInRecoveryMode) ?? false;\n\n // Determine whether to disable deposits for a pool (vault pause does not impact this)\n const disablePoolDeposits = isVaultPaused || poolState?.isPaused;\n\n // TODO: we dont yet support anything to disable staking/unstaking within reward vaults if they get paused\n\n return (\n <BexStateContext.Provider\n value={{\n protocol: {\n isPaused: isVaultPaused,\n factories: {\n ...factories,\n allPaused:\n factories.composableStable === \"paused\" &&\n factories.weighted === \"paused\",\n },\n },\n labels,\n onPoolChange: setPoolState,\n pool: poolState\n ? {\n ...poolState,\n disablePoolWithdrawals: !!disablePoolWithdrawals,\n disablePoolDeposits: !!disablePoolDeposits,\n }\n : undefined,\n }}\n >\n {children}\n </BexStateContext.Provider>\n );\n}\n","import { createContext, type PropsWithChildren, useContext } from \"react\";\n\nimport { mainnet } from \"@berachain/config/mainnet\";\n\nimport { parseBaseArgs } from \"../utils/parseBaseArgs\";\n\n/**\n * Average berachain block time in seconds\n */\nexport function useBlockTime(): number {\n return useContext(BlockTimeContext);\n}\n\nexport const BlockTimeContext = createContext<number>(\n // this is the default block time for berachain, but actually overridden by the block time provider\n mainnet.averageBlockTime,\n);\n\nexport function BlockTimeProvider({\n children,\n blockTime,\n ...args\n}: PropsWithChildren<{\n blockTime?: number;\n}> &\n BeraJS.BaseFunctionArgs) {\n const { config } = parseBaseArgs(args);\n\n return (\n <BlockTimeContext.Provider value={blockTime ?? config.averageBlockTime}>\n {children}\n </BlockTimeContext.Provider>\n );\n}\n","import { createContext, useContext } from \"react\";\n\nimport type { HoneyFeeMap } from \"../actions/honey/getHoneyFees\";\nimport type { TokenWithMetadata } from \"../types/dex\";\nimport type { PythPriceFeedMap } from \"../types/honeySwap\";\n\nexport const HoneyConfigContext = createContext<\n HoneyConfigContextReturn | undefined\n>(undefined);\n\nexport type TokenWithOrder = TokenWithMetadata & {\n order: number;\n};\nexport interface HoneyConfigContextReturn {\n /**\n * Map of the Pyth price feed ids for each collateral\n */\n priceFeedMap: PythPriceFeedMap;\n /**\n * This is the list of all the collaterals that are supported by the Honey protocol\n */\n collateralList: TokenWithOrder[];\n /**\n * This is the main collateral that is used to calculate the relative cap limit\n */\n referenceCollateral: TokenWithOrder;\n /**\n * An object that maps the redeem/mint rate for each collateral and the weighted rates for the basket mode\n */\n feeMap: HoneyFeeMap;\n flags: {\n /**\n * If true, mint/redeem will also update pyth prices\n */\n isPythWrapperEnabled: boolean;\n };\n /**\n * Honey protocol configs\n */\n protocol: {\n /**\n * Honey protocol paused state\n */\n isPaused: boolean;\n /**\n * The label for the Honey protocol paused message\n */\n pausedBannerLabel?: string;\n };\n}\n\nexport interface HoneyConfigProviderProps extends HoneyConfigContextReturn {\n children: React.ReactNode;\n}\n\nexport function HoneyConfigProvider({\n children,\n ...props\n}: HoneyConfigProviderProps) {\n return (\n <HoneyConfigContext.Provider value={props}>\n {children}\n </HoneyConfigContext.Provider>\n );\n}\n\nexport function useHoneyConfig() {\n const context = useContext(HoneyConfigContext);\n if (!context) {\n throw new Error(\"useHoneyConfig must be used within a HoneyConfigProvider\");\n }\n return context;\n}\n","import useSWR from \"swr\";\n\nimport { useBeraWallet, useConfig } from \"@berachain/wagmi/hooks\";\n\nimport { getEnsoClient } from \"../../actions/clients/getEnsoClient\";\nimport { getEnsoUserTokensWithBalances } from \"../../actions/enso/getEnsoUserTokensWithBalances\";\nimport { POLLING } from \"../../enum/polling\";\nimport type { BalanceToken } from \"../../types/dex\";\nimport type { DefaultHookOptions } from \"../../types/global\";\n\nexport function useEnsoUserTokensWithBalances(\n { chainId }: { chainId?: number } = {},\n options?: DefaultHookOptions,\n) {\n const { address: fromAddress } = useBeraWallet();\n const wagmiConfig = useConfig();\n const isEnabled = !!fromAddress && (options?.opts?.isEnabled ?? true);\n\n const QUERY_KEY =\n isEnabled && wagmiConfig\n ? ([\"useEnsoUserTokensWithBalances\", fromAddress, chainId] as const)\n : null;\n\n const swrResponse = useSWR(\n QUERY_KEY,\n async ([, fromAddress, chainId]): Promise<BalanceToken[]> =>\n getEnsoUserTokensWithBalances({\n account: fromAddress,\n wagmiConfig,\n chainId: chainId ?? \"all\",\n ensoClient: getEnsoClient(),\n }),\n {\n refreshInterval: POLLING.NORMAL,\n isEnabled,\n ...options?.opts,\n },\n );\n return {\n ...swrResponse,\n refresh: () => swrResponse.mutate(),\n };\n}\n","import type { EnsoClient } from \"@ensofinance/sdk\";\nimport { type Config, getChains, multicall } from \"@wagmi/core\";\nimport { type Address, formatUnits } from \"viem\";\n\nimport { BeraMonitoring } from \"../../errors/BeraMonitoring\";\nimport { InvalidArgumentError } from \"../../errors/InvalidArgumentError\";\nimport { initBeraError } from \"../../errors/initBeraError\";\nimport type { BalanceToken } from \"../../types/dex\";\nimport { beraToken, isToken } from \"../../utils/tokens\";\nimport { getBalanceCall } from \"../tokens/getWalletBalances\";\n\n/**\n * Get user balances for each supported chain.\n *\n * This uses enso's balance endpoint to get the balances and RPC to get fresh balances.\n */\nexport async function getEnsoUserTokensWithBalances({\n account,\n wagmiConfig,\n chainId,\n ensoClient,\n}: {\n account: Address;\n wagmiConfig: Config;\n chainId: number | \"all\";\n ensoClient: EnsoClient;\n}): Promise<BalanceToken[]> {\n const ensoBalances = await ensoClient.getBalances({\n useEoa: true,\n chainId: chainId ?? \"all\",\n eoaAddress: account,\n });\n\n const tokens: BalanceToken[] = ensoBalances.map(\n (balance) =>\n ({\n name: balance.name,\n symbol: balance.symbol,\n decimals: balance.decimals,\n address: isToken(balance.token, \"ETH\")\n ? beraToken.address\n : balance.token,\n logoURI: balance.logoUri,\n balance: {\n raw: balance.amount.toString(),\n formatted: formatUnits(BigInt(balance.amount), balance.decimals),\n },\n\n chainId: Number(\n // @ts-expect-error - balance.chainId is defined just not typed by enso\n balance.chainId,\n ),\n price: Number(balance.price),\n }) as const satisfies BalanceToken,\n );\n\n const tokenByChainId = Object.groupBy(tokens, (a) => a.chainId ?? 0);\n\n const balances = await Promise.allSettled(\n Object.entries(tokenByChainId).map(async ([chainId, chainTokens]) => {\n if (!chainTokens) return undefined;\n const chainConfig = getChains(wagmiConfig).find(\n (chain) => chain.id === Number(chainId),\n );\n\n if (!chainConfig) {\n // if we've queried a chain that is not supported, we need to return undefined\n return undefined;\n }\n\n const multicall3 = chainConfig.contracts?.multicall3;\n\n const multicallAddress = multicall3?.address;\n\n if (!multicallAddress) {\n // if multicall is not supported on this chain, we need to use the enso balance\n // first let's report the error, as this is likely unexpected\n BeraMonitoring.captureException(\n new InvalidArgumentError({\n property: \"multicallAddress\",\n value: multicallAddress,\n expected: \"Address\",\n chainId: Number(chainId),\n }),\n );\n\n // we can return the tokens as is, as the balance is already set from the enso client\n return chainTokens;\n }\n\n const balances = await multicall(wagmiConfig, {\n chainId: Number(chainId),\n contracts: chainTokens.map((token) =>\n getBalanceCall({\n token,\n account,\n multicallAddress,\n }),\n ),\n allowFailure: true,\n });\n\n const tokensWithBalances: BalanceToken[] = [];\n\n for (let index = 0; index < chainTokens.length; index++) {\n const token = chainTokens[index];\n if (balances[index].status === \"success\") {\n const balance = balances[index].result;\n\n tokensWithBalances.push({\n ...token,\n balance: {\n raw: balance?.toString() ?? \"0\",\n formatted: formatUnits(balance ?? 0n, token.decimals),\n },\n });\n } else {\n console.error(\"error getting balance\", balances[index].error);\n BeraMonitoring.captureException(\n initBeraError({ cause: balances[index].error }),\n );\n // uses enso balance as fallback\n tokensWithBalances.push(token);\n }\n }\n\n return tokensWithBalances;\n }),\n );\n\n const flattenedBalances: BalanceToken[] = [];\n for (const result of balances) {\n if (result.status === \"fulfilled\") {\n flattenedBalances.push(...(result.value ?? []));\n } else {\n BeraMonitoring.captureException(initBeraError({ cause: result.reason }));\n }\n }\n\n return flattenedBalances.sort((a, b) => {\n const aValue = Number(a.balance.formatted) * (a.price ?? 0);\n const bValue = Number(b.balance.formatted) * (b.price ?? 0);\n return bValue - aValue;\n });\n}\n","import { createContext, type PropsWithChildren, useMemo } from \"react\";\n\nimport {\n type EdgeConfigSchema,\n isFlagEnabled,\n} from \"@berachain/config/internal/edge-config\";\n\nimport { useEnsoUserTokensWithBalances } from \"../hooks/enso/useEnsoUserTokensWithBalances\";\nimport type { BalanceToken, Token, TokenWithMetadata } from \"../types/dex\";\nimport { formatTokenList } from \"../utils/formatTokenList\";\n\nexport interface TokensProviderContext {\n tokenList: TokenWithMetadata[];\n userTokens: Token[];\n featuredTokens: TokenWithMetadata[];\n onRemoveToken: (token: Token) => void;\n onAddToken: (token: Token) => void;\n refresh: () => void;\n ensoTokens: BalanceToken[] | undefined;\n}\n\nexport const TokenContext = createContext<TokensProviderContext | undefined>(\n undefined,\n);\n\nexport interface TokensProviderProps\n extends Omit<\n TokensProviderContext,\n \"tokenList\" | \"onAddToken\" | \"featuredTokens\" | \"ensoTokens\"\n > {\n onAddToken: (\n token: Token,\n context: {\n defaultTokens: TokenWithMetadata[];\n userTokens: Token[];\n tokenList: TokenWithMetadata[];\n },\n ) => void;\n defaultTokens: TokenWithMetadata[];\n edgeConfigTokenList: EdgeConfigSchema[\"tokens\"];\n}\n\nexport function TokensProvider({\n children,\n defaultTokens,\n edgeConfigTokenList,\n userTokens,\n onAddToken,\n onRemoveToken,\n}: PropsWithChildren<Omit<TokensProviderProps, \"refresh\">>) {\n const { data: ensoTokens, refresh } = useEnsoUserTokensWithBalances();\n\n const { tokenList = [], featuredTokenList = [] } = useMemo(\n () =>\n formatTokenList({\n defaultTokenList: [\n ...defaultTokens,\n ...(edgeConfigTokenList?.filter((token) =>\n isFlagEnabled(token.enabled),\n ) as TokenWithMetadata[]),\n ],\n externalList: [\n ...userTokens,\n ...(ensoTokens ?? []).map((t) => ({\n ...t,\n balance: undefined,\n price: undefined,\n })),\n ],\n }),\n [defaultTokens, userTokens, edgeConfigTokenList, ensoTokens],\n );\n\n return (\n <TokenContext.Provider\n value={{\n tokenList,\n userTokens,\n featuredTokens: featuredTokenList,\n ensoTokens,\n onAddToken(tk) {\n onAddToken(tk, { defaultTokens, userTokens, tokenList });\n },\n onRemoveToken,\n refresh: () => {\n refresh();\n },\n }}\n >\n {children}\n </TokenContext.Provider>\n );\n}\n","import type { Token, TokenWithMetadata } from \"../types/dex\";\nimport { isToken } from \"./tokens\";\n\nexport interface FormatTokenListReturnType {\n /**\n * Token list including custom tokens\n */\n tokenList: Token[];\n /**\n * Custom token list (added by the user)\n */\n customTokenList?: Token[];\n /**\n * Featured token list\n */\n featuredTokenList?: Token[];\n}\n\nfunction formatTokenList({\n defaultTokenList = [],\n externalList = [],\n}: {\n defaultTokenList: TokenWithMetadata[];\n externalList?: Token[];\n}): FormatTokenListReturnType {\n if (defaultTokenList.length === 0) {\n return {\n tokenList: externalList,\n customTokenList: externalList,\n featuredTokenList: [],\n };\n }\n\n const defaultList = defaultTokenList.map((token) => {\n return { ...token, default: true };\n });\n\n const featuredTokenList = defaultList.filter((token) => {\n return token.tags?.some((tag) => tag === \"featured\");\n });\n\n const mergedList = [...defaultList, ...externalList];\n\n const uniqueList = mergedList.filter(\n (item, index) => mergedList.findIndex((i) => isToken(i, item)) === index,\n );\n\n return {\n tokenList: uniqueList,\n customTokenList: externalList,\n featuredTokenList,\n };\n}\n\nexport { formatTokenList };\n"]}
|
|
1
|
+
{"version":3,"sources":["/Users/pong/coding/monobera/packages/berajs/dist/chunk-JLFBRMOF.cjs","../src/contexts/BeraFlags/BeraFlags.tsx","../src/contexts/BexStatusProvider.tsx","../src/contexts/block-time-provider.tsx","../src/contexts/HoneyConfigProvider.tsx","../src/hooks/enso/useEnsoUserTokensWithBalances.ts","../src/actions/enso/getEnsoUserTokensWithBalances.ts","../src/contexts/TokensProvider.tsx","../src/utils/formatTokenList.ts"],"names":["BeraFlagContext","createContext","BeraFlagsProvider","children","flags","aggregators","swberaAprWindow","jsx","defaultFlags","value","isFlagEnabled","key","useBeraFlags","context","useContext","useBeraFlag","BexStateContext","useBexStatus","BeraError","BexStatusProvider","isVaultPaused","labels","factories","poolState","setPoolState","useState","disablePoolWithdrawals","disablePoolDeposits","useBlockTime","BlockTimeContext","mainnet","BlockTimeProvider","blockTime","args","config","parseBaseArgs","HoneyConfigContext","HoneyConfigProvider","props","useHoneyConfig","getEnsoUserTokensWithBalances","account","wagmiConfig","chainId","ensoClient","tokens","balance","isToken","beraToken","formatUnits","tokenByChainId","a","balances","chainTokens","chainConfig","getChains","chain","multicallAddress","BeraMonitoring","InvalidArgumentError","multicall","token","getBalanceCall","tokensWithBalances","index","initBeraError","flattenedBalances","result","b","aValue","useEnsoUserTokensWithBalances","options","fromAddress","useBeraWallet","useConfig","isEnabled","swrResponse","useSWR","getEnsoClient","formatTokenList","defaultTokenList","externalList","defaultList","featuredTokenList","tag","mergedList","item","i","TokenContext","TokensProvider","defaultTokens","edgeConfigTokenList","userTokens","onAddToken","onRemoveToken","ensoTokens","refresh","tokenList","useMemo","t","tk"],"mappings":"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","file":"/Users/pong/coding/monobera/packages/berajs/dist/chunk-JLFBRMOF.cjs","sourcesContent":[null,"import { createContext, useContext } from \"react\";\n\nimport {\n type EdgeConfigSchema,\n isFlagEnabled,\n} from \"@berachain/config/internal/edge-config\";\n\nimport { type BeraFlags, defaultFlags } from \"./defaultFlags\";\n\nexport type { BeraFlags };\n\nexport type BeraFlagsContextReturn = BeraFlags & {\n /**\n * A list of aggregators that are enabled. If not provided, all aggregators are enabled.\n */\n aggregators: string[] | undefined;\n swberaAprWindow: Exclude<\n EdgeConfigSchema[\"pol\"][\"swberaAprWindow\"],\n undefined\n >;\n};\n\nconst BeraFlagContext = createContext<BeraFlagsContextReturn | undefined>(\n undefined,\n);\n\nexport function BeraFlagsProvider({\n children,\n flags,\n aggregators,\n swberaAprWindow = \"DAY\",\n}: {\n children: React.ReactNode;\n flags: BeraFlags;\n aggregators?: NonNullable<EdgeConfigSchema[\"bex\"]>[\"aggregators\"];\n swberaAprWindow?: EdgeConfigSchema[\"pol\"][\"swberaAprWindow\"];\n}) {\n return (\n <BeraFlagContext.Provider\n value={{\n ...defaultFlags,\n ...flags,\n aggregators: aggregators\n ? Object.entries(aggregators)\n .filter(([, value]) => isFlagEnabled(value))\n .map(([key]) => key)\n : undefined,\n swberaAprWindow,\n }}\n >\n {children}\n </BeraFlagContext.Provider>\n );\n}\n\nexport function useBeraFlags() {\n const context = useContext(BeraFlagContext);\n if (!context) {\n throw new Error(\"BeraFlagsProvider not found\");\n }\n return context;\n}\n\nexport function useBeraFlag<T extends keyof BeraFlagsContextReturn>(\n key: T,\n): BeraFlagsContextReturn[T] {\n const flags = useBeraFlags();\n return flags[key];\n}\n","import {\n createContext,\n type Dispatch,\n type PropsWithChildren,\n type SetStateAction,\n useContext,\n useState,\n} from \"react\";\nimport type { Hex } from \"viem\";\n\nimport type { EdgeConfigSchema } from \"@berachain/config/internal/edge-config\";\n\nimport { BeraError } from \"../errors/BeraError\";\n\ntype FactoryStatus = {\n /**\n * If the composable stable factory is enabled\n */\n composableStable: \"paused\" | \"enabled\";\n /**\n * If the weighted factory is enabled\n */\n weighted: \"paused\" | \"enabled\";\n};\nexport interface BexStatusProviderProps {\n isVaultPaused: boolean;\n pool?: {\n id: Hex;\n isInRecoveryMode: boolean;\n isPaused: boolean;\n };\n factories: FactoryStatus;\n labels?: NonNullable<EdgeConfigSchema[\"bex\"]>[\"emergencyLabels\"];\n}\n\nexport const BexStateContext = createContext<{\n protocol: {\n isPaused: boolean;\n factories: FactoryStatus & { allPaused: boolean };\n };\n onPoolChange: Dispatch<SetStateAction<BexStatusProviderProps[\"pool\"]>>;\n pool?: {\n id: Hex;\n isInRecoveryMode: boolean;\n isPaused: boolean;\n disablePoolWithdrawals: boolean;\n disablePoolDeposits: boolean;\n };\n labels?: NonNullable<EdgeConfigSchema[\"bex\"]>[\"emergencyLabels\"];\n}>({\n protocol: {\n isPaused: false,\n factories: {\n composableStable: \"enabled\",\n weighted: \"enabled\",\n allPaused: false,\n },\n },\n onPoolChange: () => {},\n pool: undefined,\n});\n\n/**\n * @description Determines the status of a pool or vault and returns the appropriate messages and flags to disable functionality.\n * More information here https://www.notion.so/berachain/BEX-RecoveryMode-and-Pause-explained-17c6120abced80e0985dd589b57ff018\n *\n * @returns status flags to enable/disable/notify users across the BEX\n *\n **/\nexport function useBexStatus() {\n const context = useContext(BexStateContext);\n\n if (!context) {\n throw new BeraError({\n level: \"fatal\",\n message: \"BexStateContext is not defined\",\n });\n }\n\n return context;\n}\n\nexport function BexStatusProvider({\n children,\n isVaultPaused,\n labels,\n factories,\n}: PropsWithChildren<BexStatusProviderProps>) {\n const [poolState, setPoolState] = useState<BexStatusProviderProps[\"pool\"]>();\n // Determine whether to disable withdrawals for a pool (vault pause does not impact this)\n const disablePoolWithdrawals =\n (poolState?.isPaused && !poolState?.isInRecoveryMode) ?? false;\n\n // Determine whether to disable deposits for a pool (vault pause does not impact this)\n const disablePoolDeposits = isVaultPaused || poolState?.isPaused;\n\n // TODO: we dont yet support anything to disable staking/unstaking within reward vaults if they get paused\n\n return (\n <BexStateContext.Provider\n value={{\n protocol: {\n isPaused: isVaultPaused,\n factories: {\n ...factories,\n allPaused:\n factories.composableStable === \"paused\" &&\n factories.weighted === \"paused\",\n },\n },\n labels,\n onPoolChange: setPoolState,\n pool: poolState\n ? {\n ...poolState,\n disablePoolWithdrawals: !!disablePoolWithdrawals,\n disablePoolDeposits: !!disablePoolDeposits,\n }\n : undefined,\n }}\n >\n {children}\n </BexStateContext.Provider>\n );\n}\n","import { createContext, type PropsWithChildren, useContext } from \"react\";\n\nimport { mainnet } from \"@berachain/config/mainnet\";\n\nimport { parseBaseArgs } from \"../utils/parseBaseArgs\";\n\n/**\n * Average berachain block time in seconds\n */\nexport function useBlockTime(): number {\n return useContext(BlockTimeContext);\n}\n\nexport const BlockTimeContext = createContext<number>(\n // this is the default block time for berachain, but actually overridden by the block time provider\n mainnet.averageBlockTime,\n);\n\nexport function BlockTimeProvider({\n children,\n blockTime,\n ...args\n}: PropsWithChildren<{\n blockTime?: number;\n}> &\n BeraJS.BaseFunctionArgs) {\n const { config } = parseBaseArgs(args);\n\n return (\n <BlockTimeContext.Provider value={blockTime ?? config.averageBlockTime}>\n {children}\n </BlockTimeContext.Provider>\n );\n}\n","import { createContext, useContext } from \"react\";\n\nimport type { HoneyFeeMap } from \"../actions/honey/getHoneyFees\";\nimport type { TokenWithMetadata } from \"../types/dex\";\nimport type { PythPriceFeedMap } from \"../types/honeySwap\";\n\nexport const HoneyConfigContext = createContext<\n HoneyConfigContextReturn | undefined\n>(undefined);\n\nexport type TokenWithOrder = TokenWithMetadata & {\n order: number;\n};\nexport interface HoneyConfigContextReturn {\n /**\n * Map of the Pyth price feed ids for each collateral\n */\n priceFeedMap: PythPriceFeedMap;\n /**\n * This is the list of all the collaterals that are supported by the Honey protocol\n */\n collateralList: TokenWithOrder[];\n /**\n * This is the main collateral that is used to calculate the relative cap limit\n */\n referenceCollateral: TokenWithOrder;\n /**\n * An object that maps the redeem/mint rate for each collateral and the weighted rates for the basket mode\n */\n feeMap: HoneyFeeMap;\n flags: {\n /**\n * If true, mint/redeem will also update pyth prices\n */\n isPythWrapperEnabled: boolean;\n };\n /**\n * Honey protocol configs\n */\n protocol: {\n /**\n * Honey protocol paused state\n */\n isPaused: boolean;\n /**\n * The label for the Honey protocol paused message\n */\n pausedBannerLabel?: string;\n };\n}\n\nexport interface HoneyConfigProviderProps extends HoneyConfigContextReturn {\n children: React.ReactNode;\n}\n\nexport function HoneyConfigProvider({\n children,\n ...props\n}: HoneyConfigProviderProps) {\n return (\n <HoneyConfigContext.Provider value={props}>\n {children}\n </HoneyConfigContext.Provider>\n );\n}\n\nexport function useHoneyConfig() {\n const context = useContext(HoneyConfigContext);\n if (!context) {\n throw new Error(\"useHoneyConfig must be used within a HoneyConfigProvider\");\n }\n return context;\n}\n","import useSWR from \"swr\";\n\nimport { useBeraWallet, useConfig } from \"@berachain/wagmi/hooks\";\n\nimport { getEnsoClient } from \"../../actions/clients/getEnsoClient\";\nimport { getEnsoUserTokensWithBalances } from \"../../actions/enso/getEnsoUserTokensWithBalances\";\nimport { POLLING } from \"../../enum/polling\";\nimport type { BalanceToken } from \"../../types/dex\";\nimport type { DefaultHookOptions } from \"../../types/global\";\n\nexport function useEnsoUserTokensWithBalances(\n { chainId }: { chainId?: number } = {},\n options?: DefaultHookOptions,\n) {\n const { address: fromAddress } = useBeraWallet();\n const wagmiConfig = useConfig();\n const isEnabled = !!fromAddress && (options?.opts?.isEnabled ?? true);\n\n const QUERY_KEY =\n isEnabled && wagmiConfig\n ? ([\"useEnsoUserTokensWithBalances\", fromAddress, chainId] as const)\n : null;\n\n const swrResponse = useSWR(\n QUERY_KEY,\n async ([, fromAddress, chainId]): Promise<BalanceToken[]> =>\n getEnsoUserTokensWithBalances({\n account: fromAddress,\n wagmiConfig,\n chainId: chainId ?? \"all\",\n ensoClient: getEnsoClient(),\n }),\n {\n refreshInterval: POLLING.NORMAL,\n isEnabled,\n ...options?.opts,\n },\n );\n return {\n ...swrResponse,\n refresh: () => swrResponse.mutate(),\n };\n}\n","import type { EnsoClient } from \"@ensofinance/sdk\";\nimport { type Config, getChains, multicall } from \"@wagmi/core\";\nimport { type Address, formatUnits } from \"viem\";\n\nimport { BeraMonitoring } from \"../../errors/BeraMonitoring\";\nimport { InvalidArgumentError } from \"../../errors/InvalidArgumentError\";\nimport { initBeraError } from \"../../errors/initBeraError\";\nimport type { BalanceToken } from \"../../types/dex\";\nimport { beraToken, isToken } from \"../../utils/tokens\";\nimport { getBalanceCall } from \"../tokens/getWalletBalances\";\n\n/**\n * Get user balances for each supported chain.\n *\n * This uses enso's balance endpoint to get the balances and RPC to get fresh balances.\n */\nexport async function getEnsoUserTokensWithBalances({\n account,\n wagmiConfig,\n chainId,\n ensoClient,\n}: {\n account: Address;\n wagmiConfig: Config;\n chainId: number | \"all\";\n ensoClient: EnsoClient;\n}): Promise<BalanceToken[]> {\n const ensoBalances = await ensoClient.getBalances({\n useEoa: true,\n chainId: chainId ?? \"all\",\n eoaAddress: account,\n });\n\n const tokens: BalanceToken[] = ensoBalances.map(\n (balance) =>\n ({\n name: balance.name,\n symbol: balance.symbol,\n decimals: balance.decimals,\n address: isToken(balance.token, \"ETH\")\n ? beraToken.address\n : balance.token,\n logoURI: balance.logoUri,\n balance: {\n raw: balance.amount.toString(),\n formatted: formatUnits(BigInt(balance.amount), balance.decimals),\n },\n\n chainId: Number(\n // @ts-expect-error - balance.chainId is defined just not typed by enso\n balance.chainId,\n ),\n price: Number(balance.price),\n }) as const satisfies BalanceToken,\n );\n\n const tokenByChainId = Object.groupBy(tokens, (a) => a.chainId ?? 0);\n\n const balances = await Promise.allSettled(\n Object.entries(tokenByChainId).map(async ([chainId, chainTokens]) => {\n if (!chainTokens) return undefined;\n const chainConfig = getChains(wagmiConfig).find(\n (chain) => chain.id === Number(chainId),\n );\n\n if (!chainConfig) {\n // if we've queried a chain that is not supported, we need to return undefined\n return undefined;\n }\n\n const multicall3 = chainConfig.contracts?.multicall3;\n\n const multicallAddress = multicall3?.address;\n\n if (!multicallAddress) {\n // if multicall is not supported on this chain, we need to use the enso balance\n // first let's report the error, as this is likely unexpected\n BeraMonitoring.captureException(\n new InvalidArgumentError({\n property: \"multicallAddress\",\n value: multicallAddress,\n expected: \"Address\",\n chainId: Number(chainId),\n }),\n );\n\n // we can return the tokens as is, as the balance is already set from the enso client\n return chainTokens;\n }\n\n const balances = await multicall(wagmiConfig, {\n chainId: Number(chainId),\n contracts: chainTokens.map((token) =>\n getBalanceCall({\n token,\n account,\n multicallAddress,\n }),\n ),\n allowFailure: true,\n });\n\n const tokensWithBalances: BalanceToken[] = [];\n\n for (let index = 0; index < chainTokens.length; index++) {\n const token = chainTokens[index];\n if (balances[index].status === \"success\") {\n const balance = balances[index].result;\n\n tokensWithBalances.push({\n ...token,\n balance: {\n raw: balance?.toString() ?? \"0\",\n formatted: formatUnits(balance ?? 0n, token.decimals),\n },\n });\n } else {\n console.error(\"error getting balance\", balances[index].error);\n BeraMonitoring.captureException(\n initBeraError({ cause: balances[index].error }),\n );\n // uses enso balance as fallback\n tokensWithBalances.push(token);\n }\n }\n\n return tokensWithBalances;\n }),\n );\n\n const flattenedBalances: BalanceToken[] = [];\n for (const result of balances) {\n if (result.status === \"fulfilled\") {\n flattenedBalances.push(...(result.value ?? []));\n } else {\n BeraMonitoring.captureException(initBeraError({ cause: result.reason }));\n }\n }\n\n return flattenedBalances.sort((a, b) => {\n const aValue = Number(a.balance.formatted) * (a.price ?? 0);\n const bValue = Number(b.balance.formatted) * (b.price ?? 0);\n return bValue - aValue;\n });\n}\n","import { createContext, type PropsWithChildren, useMemo } from \"react\";\n\nimport {\n type EdgeConfigSchema,\n isFlagEnabled,\n} from \"@berachain/config/internal/edge-config\";\n\nimport { useEnsoUserTokensWithBalances } from \"../hooks/enso/useEnsoUserTokensWithBalances\";\nimport type { BalanceToken, Token, TokenWithMetadata } from \"../types/dex\";\nimport { formatTokenList } from \"../utils/formatTokenList\";\n\nexport interface TokensProviderContext {\n tokenList: TokenWithMetadata[];\n userTokens: Token[];\n featuredTokens: TokenWithMetadata[];\n onRemoveToken: (token: Token) => void;\n onAddToken: (token: Token) => void;\n refresh: () => void;\n ensoTokens: BalanceToken[] | undefined;\n}\n\nexport const TokenContext = createContext<TokensProviderContext | undefined>(\n undefined,\n);\n\nexport interface TokensProviderProps\n extends Omit<\n TokensProviderContext,\n \"tokenList\" | \"onAddToken\" | \"featuredTokens\" | \"ensoTokens\"\n > {\n onAddToken: (\n token: Token,\n context: {\n defaultTokens: TokenWithMetadata[];\n userTokens: Token[];\n tokenList: TokenWithMetadata[];\n },\n ) => void;\n defaultTokens: TokenWithMetadata[];\n edgeConfigTokenList: EdgeConfigSchema[\"tokens\"];\n}\n\nexport function TokensProvider({\n children,\n defaultTokens,\n edgeConfigTokenList,\n userTokens,\n onAddToken,\n onRemoveToken,\n}: PropsWithChildren<Omit<TokensProviderProps, \"refresh\">>) {\n const { data: ensoTokens, refresh } = useEnsoUserTokensWithBalances();\n\n const { tokenList = [], featuredTokenList = [] } = useMemo(\n () =>\n formatTokenList({\n defaultTokenList: [\n ...defaultTokens,\n ...(edgeConfigTokenList?.filter((token) =>\n isFlagEnabled(token.enabled),\n ) as TokenWithMetadata[]),\n ],\n externalList: [\n ...userTokens,\n ...(ensoTokens ?? []).map((t) => ({\n ...t,\n balance: undefined,\n price: undefined,\n })),\n ],\n }),\n [defaultTokens, userTokens, edgeConfigTokenList, ensoTokens],\n );\n\n return (\n <TokenContext.Provider\n value={{\n tokenList,\n userTokens,\n featuredTokens: featuredTokenList,\n ensoTokens,\n onAddToken(tk) {\n onAddToken(tk, { defaultTokens, userTokens, tokenList });\n },\n onRemoveToken,\n refresh: () => {\n refresh();\n },\n }}\n >\n {children}\n </TokenContext.Provider>\n );\n}\n","import type { Token, TokenWithMetadata } from \"../types/dex\";\nimport { isToken } from \"./tokens\";\n\nexport interface FormatTokenListReturnType {\n /**\n * Token list including custom tokens\n */\n tokenList: Token[];\n /**\n * Custom token list (added by the user)\n */\n customTokenList?: Token[];\n /**\n * Featured token list\n */\n featuredTokenList?: Token[];\n}\n\nfunction formatTokenList({\n defaultTokenList = [],\n externalList = [],\n}: {\n defaultTokenList: TokenWithMetadata[];\n externalList?: Token[];\n}): FormatTokenListReturnType {\n if (defaultTokenList.length === 0) {\n return {\n tokenList: externalList,\n customTokenList: externalList,\n featuredTokenList: [],\n };\n }\n\n const defaultList = defaultTokenList.map((token) => {\n return { ...token, default: true };\n });\n\n const featuredTokenList = defaultList.filter((token) => {\n return token.tags?.some((tag) => tag === \"featured\");\n });\n\n const mergedList = [...defaultList, ...externalList];\n\n const uniqueList = mergedList.filter(\n (item, index) => mergedList.findIndex((i) => isToken(i, item)) === index,\n );\n\n return {\n tokenList: uniqueList,\n customTokenList: externalList,\n featuredTokenList,\n };\n}\n\nexport { formatTokenList };\n"]}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import{a as Oe}from"./chunk-NLVWRMGD.mjs";import{B as $e,D as K,F as ve,a as k,b as ue,c as Qe,d as Ue,e as de,j as Be,k as Le,l as S,m as Me,r as He,y as te,z as Je}from"./chunk-ESAVA5OD.mjs";import{a as c,b as ce,d as We,e as V}from"./chunk-5W7UKRHX.mjs";import{a as De,b as _e,c as H}from"./chunk-SSPFPAWX.mjs";import{a as D,b as j,c as v,d as Pe,g as M}from"./chunk-CWKDFUFR.mjs";import{c as le,d as qe,e as ee,f as B,g as $,h as x}from"./chunk-RSDCKN4Q.mjs";import{formatEther as Ut}from"viem";import{metaMorphoV11Abi as Wt}from"@berachain/abis/bend-metamorpho/metaMorphoV11";async function go({sharesAmount:e,vaultAddress:t,publicClient:r}){let a=await r.readContract({address:t,abi:Wt,functionName:"convertToAssets",args:[e]});return{raw:a,formatted:Ut(a)}}import{ApolloClient as Lt,ServerError as Ot}from"@apollo/client";import{appConfig as Mt}from"@berachain/config/internal";var me=class extends Lt{url;constructor(t){super(t),this.url=t.url}async query(t){let r=Ht(t.query),a={url:this.url,type:"graphql"},o={"operation.type":"query","operation.source.url":a.url,"operation.source.type":a.type,"operation.source.queryName":r};try{let i=()=>super.query(t),s=await De.startSpan({name:`GraphQL ${r}`,op:"BeraApolloClient.query",attributes:o},i);if(s.error||s.data===void 0)throw new B({level:"fatal",tags:o,message:"Bera Apollo Client: No data returned from query, but error should be thrown since errorPolicy is none"});return{data:s.data}}catch(i){throw!Mt.env.isProduction&&console.error("BeraApolloClient error",i),Ot.is(i)?new $({response:i.response,cause:i,statusCode:i.statusCode,endpoint:a,tags:o}):i instanceof TypeError?new $({level:"fatal",reason:"TypeError",response:i,cause:i,endpoint:a,tags:o}):new $({response:i,tags:o,cause:i,endpoint:a})}}};function Ht(e){return e.definitions.find(r=>r.kind==="OperationDefinition")?.name?.value}import{InMemoryCache as _t}from"@apollo/client";import{HttpLink as Jt}from"@apollo/client/link/http";import{getUriFromLink as je}from"@berachain/config";import{currentDapp as $t}from"@berachain/config/internal";import jt from"@berachain/graphql/dex/api";import{gql as Fo}from"@apollo/client";function Kt(e){let t=typeof e=="string"?void 0:e.headers,r=!!$t,a=process.env.VERCEL_ENV==="test";return{uri:je(e),headers:{...t,"x-graphql-client-name":`berachain.${r?"dapps":a?"test":"berajs"}`,"x-graphql-client-version":`${process.env.VERCEL_TARGET_ENV}.${process.env.VERCEL_GIT_COMMIT_SHA}`}}}function _(e,{ssrMode:t,inMemoryCacheOptions:r}={}){let a=je(e),o=typeof e=="string"?void 0:e.headers;return new me({url:a,link:new Jt({uri:a,headers:o}),defaultOptions:{query:{errorPolicy:"none",fetchPolicy:"no-cache"}},cache:new _t(r),ssrMode:t})}function b(e,{...t}){let{config:r}=c(t);switch(e){case"api":return _(Kt(r.api),{inMemoryCacheOptions:{possibleTypes:jt.possibleTypes}});case"bend.whisk":if(!r.bend.whiskApi)throw new B({message:"Bend whisk API is not configured on this chain",level:"error"});return _(r.bend.whiskApi);case"honey.subgraph":return _(r.honey.subgraph);case"pol.subgraph":return _(r.pol.subgraph);case"pol.fees":return _(r.pol.feesSubgraph);case"governance.subgraph":return _(r.governance.subgraph);case"bex.subgraph":return _(r.bex.subgraph)}}import{formatUnits as Yt,isAddress as Ke,zeroAddress as zt}from"viem";var Ye=class e{static PATH_NOT_FOUND_REASON="NO_SWAP_PATHS";needsAccountForQuote=!1;notFoundMessages=[];config;chainId;constructor(t={}){let{config:r,chainId:a}=c(t);this.config=r,this.chainId=a}url="";parseAddresses(t,r){if(!Ke(t)||!Ke(r))throw new B({message:`Invalid address: ${t} or ${r}`,level:"error"});return{tokenInAddress:V(t,"BERA")?this.config.tokens.wbera:t,tokenOutAddress:V(r,"BERA")?this.config.tokens.wbera:r,isTokenInNative:V(t,"BERA"),isTokenOutNative:V(r,"BERA")}}getAmountAfterFees(t,r){if(r===void 0)throw new B({message:"aggregatorsFeeBps is required",level:"error"});let a=new k(t).times(r).dividedBy(1e4).toFixed(0,k.ROUND_DOWN);return new k(t).minus(a).toFixed(0,k.ROUND_DOWN)}getInputData({tokenIn:t,amountIn:r,isNative:a,isPermit2Approval:o=!1,permit2SpenderAddress:i}){return{tokenIn:t,amountIn:BigInt(r),isNative:a,isPermit2Approval:o,permit2SpenderAddress:i??zt}}getMinAmountOut(t,r){if(r===void 0)throw new B({message:"slippage is required",level:"error"});let a=new k(t).times(1-r/100);return a.isNaN()||a.isZero()?0n:BigInt(a.toFixed(0))}parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:a}){return V(t,"BERA")?[]:[{token:t,amount:{raw:r,formatted:Yt(BigInt(r),t.decimals)},spender:a}]}checkChainSupport({tokenIn:t,tokenOut:r}){return this.supportedChains===null?!0:this.supportedChains.includes(t.chainId)&&this.supportedChains.includes(r.chainId)}assertChainSupport({tokenIn:t,tokenOut:r,underlyingToken:a}){if(!this.checkChainSupport({tokenIn:t,tokenOut:r,underlyingToken:a}))throw new B({message:`${this.name} does not support tokens chain ID: ${t.chainId} and ${r.chainId}`,level:"error"})}async fetch(t,r){try{return Qe({url:t,name:this.name,type:this.type},{method:"GET",headers:{"Content-Type":"application/json"},...r})}catch(a){let o=D({cause:a});throw this.notFoundMessages.some(i=>o.message.includes(i))&&(o.reason=e.PATH_NOT_FOUND_REASON),o}}};import{API_CHAIN_NAMES as Xt,BALANCER_QUERIES as Zt,BALANCER_RELAYER as er,BalancerApi as Mo,CHAINS as tr,COMPOSABLE_STABLE_POOL_FACTORY as rr,NATIVE_ASSETS as ar,Token as or,VAULT as nr,WEIGHTED_POOL_FACTORY_BALANCER_V2 as ir}from"@berachain-foundation/berancer-sdk";import{zeroAddress as Re}from"viem";import{berachain as ze,berachainBepolia as sr}from"viem/chains";import{chainConfigs as lr}from"@berachain/config/internal";for(let e of Object.keys(lr)){let{config:t,chainId:r}=c({chainId:Number(e)});Xt[r]=t.bex.chainName,tr[r]=r===ze.id?ze:sr,er[r]=t.bex.relayer,nr[r]=t.bex.vault,Zt[r]=t.bex.queries,ir[r]=Re,rr[r]=Re;let a=new or(r,Re,ce.decimals,ce.name,ce.symbol,t.tokens.wbera);ar[r]=a}import{GetPools as ur}from"@berachain/graphql/dex/api";import{GqlPoolOrderBy as cr,GqlPoolOrderDirection as dr}from"@berachain/graphql/pol/api";async function en({textSearch:e,chain:t,first:r,orderBy:a,orderDirection:o,skip:i,fetchPolicy:s,userAddress:n,blacklistedPoolIds:l,...d}={}){let{config:u}=c(d),f=await b("api",d).query({query:ur,variables:{textSearch:e,chain:t??u.bex.chainName,first:r,orderBy:a??cr.TotalLiquidity,orderDirection:o??dr.Desc,skip:i,userAddress:n,blacklistedPoolIds:l},fetchPolicy:s});return{pools:f.data.poolGetPools??[],count:f.data.count??0}}import{GetPool as mr}from"@berachain/graphql/dex/api";async function nn({poolId:e,account:t,...r}){let{config:a}=c(r),s=(await b("api",r).query({query:mr,variables:{id:e,userAddress:t,chain:a.bex.chainName},fetchPolicy:"no-cache"})).data.poolGetPool;if(!s)throw new Error(`Pool not found for id: ${e} and user ${t}`);return s}import{GetGlobalLiquidityAndSwapVolume as pr}from"@berachain/graphql/dex/api";async function dn(e={}){let{config:t}=c(e);return(await b("api",e).query({query:pr,variables:{chain:t.bex.chainName}})).data}import{weightedPoolV4Abi_V2 as fr}from"@berachain-foundation/berancer-sdk";async function Xe({publicClient:e,poolAddress:t}){let r=fr,a=await e.multicall({contracts:[{address:t,abi:r,functionName:"inRecoveryMode"},{address:t,abi:r,functionName:"getPausedState"}],allowFailure:!1});return{isPoolInRecoveryMode:a[0],isPoolPaused:a[1][0]}}import{stablePoolAbi_V3 as gr,vaultV2Abi as br,weightedPoolFactoryAbi_V3 as Ze,weightedPoolV4Abi_V2 as pe}from"@berachain-foundation/berancer-sdk";import{erc20Abi as et,formatEther as tt,formatUnits as yr,isAddress as Ar,isHex as hr}from"viem";import{GqlPoolType as rt}from"@berachain/graphql/pol/api";async function Pn({poolId:e,publicClient:t,...r}){let{config:a}=c(r),o=e.slice(0,42);if(!Ar(o)||!hr(e))throw new x({property:"poolId",value:e,expected:"Hex"});try{let[i,s,n,l,d,u,m,f,g]=await Promise.all([t.readContract({address:o,abi:et,functionName:"name"}),t.readContract({address:a.bex.vault,abi:br,functionName:"getPoolTokens",args:[e]}),t.readContract({address:o,abi:et,functionName:"totalSupply"}),t.readContract({address:o,abi:pe,functionName:"getSwapFeePercentage"}),t.readContract({address:o,abi:pe,functionName:"version"}),t.readContract({address:o,abi:pe,functionName:"decimals"}),t.readContract({address:a.bex.factories.composableStable,abi:Ze,functionName:"isPoolFromFactory",args:[o]}),t.readContract({address:a.bex.factories.weighted,abi:Ze,functionName:"isPoolFromFactory",args:[o]}),Xe({publicClient:t,poolAddress:o})]),p=Number(u),A=JSON.parse(d),h,P,y;if(m?[h,y]=await Promise.all([t.readContract({address:o,abi:[{type:"function",name:"getActualSupply",stateMutability:"view",inputs:[],outputs:[{type:"uint256"}]}],functionName:"getActualSupply"}),t.readContract({address:o,abi:gr,functionName:"getAmplificationParameter"})]):A.name==="WeightedPool"&&(P=await t.readContract({address:o,abi:pe,functionName:"getNormalizedWeights"})),!m&&!f)throw new Error(`Pool ${o} is not a valid BEX pool`);return{name:i,address:o,id:e,poolTokens:[s[0],s[1].map(String),Number(s[2])],totalSupply:yr(h??n,p),swapFee:tt(l),decimals:p,weights:P?.map(I=>tt(I)),version:A,factory:m?a.bex.factories.composableStable:a.bex.factories.weighted,type:m?rt.Stable:rt.Weighted,amplificationParameter:y?[Number(y[0]),y[1],Number(y[2])]:void 0,pausedState:g}}catch(i){throw D({cause:i})}}import{GetPoolEvents as wr}from"@berachain/graphql/dex/api";async function Sn({poolId:e,typeInArray:t,...r}){let{config:a}=c(r);return(await b("api",r).query({query:wr,variables:{poolId:e,typeIn:t,chain:a.bex.chainName}})).data}import{isHex as Cr}from"viem";import{GetPoolHistoricalData as Pr}from"@berachain/graphql/dex/api";async function Fn({poolId:e,chain:t,...r}){if(!e||!Cr(e))throw new x({property:"poolId",value:e,expected:"hex string"});let a=b("api",r),{data:o}=await a.query({query:Pr,variables:{poolId:e,chain:t}});return o.poolGetSnapshots}import{isAddress as at,isHex as Br}from"viem";function Y({fieldOrType:e,value:t,required:r=!0,baseUrl:a,components:o}){if(!["bool","string"].includes(e)&&r&&(t==null||t===""))return"Required";if(e.startsWith("uint")||e.startsWith("int")){if(typeof t!="string")return"Invalid amount";try{let s=BigInt(t);if(e.startsWith("uint")&&s<0n)return"Negative amount"}catch{return"Invalid amount"}return null}switch(e){case"string":return t!==void 0&&typeof t!="string"?"Invalid amount":null;case"bool":return typeof t!="boolean"?"Invalid amount":null;case"title":return typeof t!="string"||t.length===0?"Required":null;case"description":return typeof t!="string"||t.length===0?"Required":null;case"forumLink":{if(typeof t!="string"||t.length===0)return"Required";if(!URL.canParse(t))return"Invalid address";let s=new URL(a);return t.startsWith(s.toString())?null:"Must be a berachain forum link"}case"address":return typeof t!="string"||!at(t,{strict:!0})?"Invalid address":null;case"hex":return typeof t!="string"||!Br(t,{strict:!0})?"Invalid address":null;case"abi":if(typeof t!="string")return"Invalid ABI";try{JSON.parse(t)}catch{return"Invalid ABI"}return null;case"action":return typeof t!="string"||!at(t,{strict:!0})?"Invalid address":null;case"tuple":if(typeof t=="object"&&Array.isArray(o)){let s={};for(let n of o){let l=n,d=l.name;s[d]=Y({fieldOrType:l.type,value:t[d],components:l.components})}return Object.values(s).every(n=>n===null)?null:s}return null;case"tuple[]":if(Array.isArray(t)){let s=t.map(n=>Y({fieldOrType:"tuple",value:n,components:o}));return s.every(n=>n===null)?null:s}return null;case"logoURI":return t===void 0||t===""?null:typeof t!="string"||!URL.canParse(t)||new URL(t).protocol!=="https:"?"Must be HTTPS or IPFS":null;case"url":return t===void 0||t===""?null:typeof t!="string"||!URL.canParse(t)||new URL(t).protocol!=="https:"?"Must be HTTPS":null;default:return console.error(`Invalid field or type: ${e}`),null}}import{ProposalStatus as C}from"@berachain/graphql/governance";var vr=!1,Qn=[C.Active,C.PendingQueue,C.PendingExecution,C.Defeated,C.QuorumNotReached];function fe(e,t){let r=Date.now()/1e3;if(t!==void 0){if(e.status===C.CanceledByGuardian)return C.CanceledByGuardian;if(t===2)return Number(e.voteStartAt)<r?C.CanceledByUser:C.CanceledByGuardian;if(t===3)return e.pollResult?!e.quorum||BigInt(e.quorum)>BigInt(e.pollResult.totalTowardsQuorum)?C.QuorumNotReached:C.Defeated:C.QuorumNotReached;if(t===4)return C.PendingQueue;if(t===5)return Number(e.queueEnd)<Date.now()/1e3?C.PendingExecution:C.InQueue;if(t===6)return console.warn("Unexpected expired state on proposal id: ",e.id),C.Defeated}return e.status===C.InQueue&&Number(e.queueEnd)<Date.now()/1e3?C.PendingExecution:vr&&t===1&&e.quorum&&BigInt(e.quorum)<BigInt(e.pollResult.totalTowardsQuorum)&&Number(e.pollResult.forPercentage)>Number(e.pollResult.againstPercentage)?C.PendingQueue:e.status===C.Pending?Number(e.voteStartAt)<r&&Number(e.voteEndAt)>r?C.Active:Number(e.voteEndAt)<r?e.pollResult?!e.quorum||BigInt(e.quorum)>BigInt(e.pollResult.totalTowardsQuorum)?C.QuorumNotReached:e.pollResult?.against>e.pollResult?.for?C.Defeated:C.PendingQueue:C.QuorumNotReached:C.Pending:e.status===C.Active&&Number(e.voteEndAt)<r?!e.quorum||BigInt(e.quorum)>BigInt(e.pollResult.totalTowardsQuorum)?C.QuorumNotReached:BigInt(e.pollResult?.against??0n)>BigInt(e.pollResult?.for??0n)?C.Defeated:C.PendingQueue:e.status===C.InQueue&&Number(e.queueEnd)<Date.now()/1e3?C.PendingExecution:e.status}import{GetProposals as Rr,SearchProposals as Vr}from"@berachain/graphql/governance";async function Mn({where:e,orderBy:t,orderDirection:r,offset:a=0,perPage:o=20,text:i,...s}){try{if(o>1e3)throw new Error("perPage must be less than 1000");let n=b("governance.subgraph",s),[l]=await Promise.all([i?n.query({query:Vr,variables:{offset:a,limit:o,where:e,text:i}}):n.query({query:Rr,variables:{offset:a,limit:o,where:e,orderBy:t,orderDirection:r}})]);return l.data.proposals.map(d=>({...d,status:fe(d)}))}catch(n){throw console.error("getAllProposals:",n),n}}function Jn({proposal:e,currentTopic:t}){let r={};return r.title=Y({fieldOrType:"title",value:e.title}),r.description=Y({fieldOrType:"description",value:e.description}),r.forumLink=Y({fieldOrType:"forumLink",value:e.forumLink,baseUrl:t.forumLink}),r}import{GetProposal as Sr}from"@berachain/graphql/governance";async function zn({proposalId:e,...t}){let a=await b("governance.subgraph",t).query({query:Sr,variables:{id:e}});if(a.data.proposal)return{...a.data.proposal,status:fe(a.data.proposal)}}import ot from"gray-matter";function kr(e){let t=/#(?:([\w-]+)# )?(.+)\n([\s\S]*)/,r=e.match(t);if(r){let a=r[1]||null,o=r[2],i=r[3].replace(`
|
|
2
|
+
`,"<br />");return{type:a,title:o,content:i}}throw new Error("Invalid proposal body")}function nt(e){if(!e)return{isFrontMatter:!1,data:{title:"Loading..."},content:"",matter:"",language:"",orig:"",stringify:()=>""};let t=e?.description??"";if(ot.test(t))return{...ot(t),isFrontMatter:!0};try{let r=kr(t);return{isFrontMatter:!1,data:{title:r.title},content:r.content,matter:"",language:"",orig:t,stringify:()=>t}}catch{return{isFrontMatter:!1,data:{title:e?.description?.split(`
|
|
3
|
+
`)[0].slice(0,100)},content:t,matter:"",language:"",orig:t,stringify:()=>t}}}import{parseEventLogs as Nr}from"viem";import{berachainGovernanceAbi as Gr}from"@berachain/abis/gov/berachainGovernance";import{ProposalStatus as xr}from"@berachain/graphql/governance";async function ii(e){v(e.publicClient);let t;"tx"in e?t=e.tx:t=await e.publicClient.getTransactionReceipt({hash:e.txHash});let r=t?.logs?Nr({abi:Gr,logs:t.logs,eventName:"ProposalCreated"})?.at(0):void 0;if(!t||!r)return null;let a=await e.publicClient.getBlock({blockNumber:t.blockNumber}),o=nt({description:r?.args.description});return{id:String(r.args.proposalId),proposalId:String(r?.args.proposalId),createdAt:a.timestamp.toString(),title:o.data.title,createdAtBlock:a.timestamp.toString(),voteStartAt:String(r?.args.voteStart),voteEndAt:String(r?.args.voteEnd),proposer:r?.args.proposer,description:o.content,unverifiedForumLink:o.data.forumLink,pollResult:{for:"0",forVotersCount:0,forPercentage:"0",against:"0",againstVotersCount:0,againstPercentage:"0",abstain:"0",abstainVotersCount:0,abstainPercentage:"0",total:"0",totalVotersCount:0,totalTowardsQuorum:"0"},status:xr.Pending,quorum:null,topics:o.data.topics,votes:[],executableCalls:r?.args.targets.map((i,s)=>({__typename:"ExecutableCall",id:`${t.transactionHash}-${s}`,target:i,value:String(r?.args.values[s]),calldata:r?.args.calldatas[s]})),timelock:void 0}}import{GetProposalVotes as Tr}from"@berachain/graphql/governance";async function ci({variables:e,...t}){return b("governance.subgraph",t).query({query:Tr,variables:e})}import{Aggregation_Interval as Fr,GetChartData as Er}from"@berachain/graphql/honey";async function fi({days:e,...t}){return(await b("honey.subgraph",t).query({query:Er,variables:{interval:Fr.Day,first:e}})).data}import{honeyFactoryAbi as Ir}from"@berachain/abis/honey/honeyFactory";async function Ai({client:e,collateralList:t,...r}){let{config:a}=c(r);try{let o=await e.readContract({address:a.honey.factory,abi:Ir,functionName:"getWeights"});return t.reduce((s,n,l)=>Object.assign(s,{[n.address]:o[l]}),{})}catch(o){throw console.log(o),o}}import{erc20Abi as Ve}from"viem";async function it({address:e,publicClient:t,chainId:r}){try{v(t);let[a,o,i]=await Promise.all([t.readContract({address:e,abi:Ve,functionName:"decimals"}),t.readContract({address:e,abi:Ve,functionName:"name"}),t.readContract({address:e,abi:Ve,functionName:"symbol"})]);return{address:e,decimals:a,name:o,symbol:i,chainId:r}}catch(a){throw D({cause:a})}}import{honeyFactoryAbi as Se}from"@berachain/abis/honey/honeyFactory";async function ke({client:e,tokenData:t,preferredCollateralOrder:r,...a}){let{config:o}=c(a),[i,s]=await Promise.all([e.readContract({address:o.honey.factory,abi:Se,functionName:"numRegisteredAssets"}),e.readContract({address:o.honey.factory,abi:Se,functionName:"referenceCollateral"})]),n=[];for(let f=0;f<i;f++)n.push(e.readContract({address:o.honey.factory,abi:Se,functionName:"registeredAssets",args:[BigInt(f)]}));let l=await Promise.all(n),u=(await Promise.all(l.map(f=>{let g=t?.find(p=>V(p,f));return g||it({address:f,chainId:o.chainId,publicClient:e})}))).filter(f=>!!f).sort((f,g)=>l.indexOf(f.address)-l.indexOf(g.address)).map((f,g)=>({...f,order:g}));if(r?.length){let f=[];for(let g of r){let p=u.find(A=>V(A.address,g.address));p&&(f.push(p),u.splice(u.indexOf(p),1))}u.unshift(...f)}let m=u.find(f=>V(f,s));if(!u)throw new Error("Collateral tokens not found");if(!m)throw new Error("Reference collateral address not found");return{collaterals:u,referenceCollateral:m}}import{parseUnits as qr}from"viem";import{honeyFactoryAbi as st}from"@berachain/abis/honey/honeyFactory";import{honeyFactoryReaderAbi as Dr}from"@berachain/abis/honey/honeyFactoryReader";async function lt({client:e,collateral:t,latestPrices:r,isPythWrapperEnabled:a,...o}){let{config:i}=c(o);try{let s=e.readContract({address:i.honey.factory,abi:st,functionName:"isBadCollateralAsset",args:[t.address]}),n=e.readContract({address:i.honey.factory,abi:st,functionName:"isPegged",args:[t.address]});if(a&&r){let u=r.prices.map(m=>qr(m,18));n=e.readContract({address:i.honey.reader,abi:Dr,functionName:"isPeggedWithPrice",args:[t.address,u[0]]})}let[l,d]=await Promise.all([s,n]);return{isBlacklisted:l,isDepegged:!d}}catch(s){throw console.log(s),s}}import{parseEther as ct}from"viem";import{honeyFactoryAbi as Wr}from"@berachain/abis/honey/honeyFactory";import{parseEther as Qr}from"viem";import{collateralVaultAbi as Ur}from"@berachain/abis/honey/collateralVault";import{honeyFactoryAbi as ut}from"@berachain/abis/honey/honeyFactory";async function re({client:e,asset:t,amount:r,...a}){let{config:o}=c(a);try{let[i,s]=await Promise.all([e.readContract({address:o.honey.factory,abi:ut,functionName:"vaults",args:[t]}),e.readContract({address:o.honey.factory,abi:ut,functionName:"collectedFees",args:[o.honey.factory,t]})]);return await e.readContract({address:i,abi:Ur,functionName:"balanceOf",args:[o.honey.factory]})+Qr(r??"0")-s}catch(i){throw console.log(i),i}}var Lr=ct("1");async function $i({client:e,asset:t,amount:r,isMint:a,isPythWrapperEnabled:o,latestPrices:i,...s}){let{config:n}=c(s);try{let l=await e.readContract({address:n.honey.factory,abi:Wr,functionName:"globalCap"});if(l>=Lr)return!1;let[{collaterals:d},u]=await Promise.all([ke({client:e}),Or({client:e,asset:t,amount:r,latestPrices:i,isPythWrapperEnabled:o})]);if(!u)return;for(let m in u)if((a&&V(d[m],t)||!a&&V(d[m],t))&&u[m]>l-de)return!0;return!1}catch(l){throw console.log(l),l}}async function Or({client:e,asset:t,amount:r,latestPrices:a,isPythWrapperEnabled:o}){let{collaterals:i}=await ke({client:e}),s=0n,n=[];for(let l of i){let d=await lt({client:e,collateral:t,latestPrices:a,isPythWrapperEnabled:o});if(d?.isBlacklisted||d?.isDepegged)continue;let u=await re({client:e,asset:l.address,amount:V(l,t)?r:"0"});u&&(s+=u,n.push(u))}if(s===0n)return n;for(let l in i)n[l]=ct(n[l].toString())/s;return n}import{GetGlobalData as Mr}from"@berachain/graphql/honey";async function zi({...e}={}){return(await b("honey.subgraph",e).query({query:Mr})).data}import{parseUnits as dt}from"viem";import{honeyFactoryReaderAbi as mt}from"@berachain/abis/honey/honeyFactoryReader";var Hr=(l=>(l.Mint="previewMintHoney",l.MintWithPrice="previewMintHoneyWithPrices",l.RequiredCollateral="previewMintCollaterals",l.RequiredCollateralWithPrice="previewMintCollateralsWithPrices",l.Redeem="previewRedeemCollaterals",l.RedeemWithPrice="previewRedeemCollateralsWithPrices",l.HoneyToRedeem="previewRedeemHoney",l.HoneyToRedeemWithPrice="previewRedeemHoneyWithPrices",l))(Hr||{});async function rs({client:e,collateral:t,collateralList:r,amount:a,method:o,latestPrices:i,isPythWrapperEnabled:s,...n}){let{config:l}=c(n);try{let d=o==="previewMintHoney"||o==="previewRedeemHoney"||o==="previewMintHoneyWithPrices"||o==="previewRedeemHoneyWithPrices",u=dt(a,d?t.decimals:18),m,f=[t.address,u];if(s&&i){let p=i.prices.map(A=>dt(A,18));f=[t.address,u,p]}if(d){let p=await e.readContract({address:l.honey.reader,abi:mt,functionName:o,args:f});m={collaterals:p[0],honey:p[1]}}else m={collaterals:await e.readContract({address:l.honey.reader,abi:mt,functionName:o,args:f}),honey:u};let g=r.reduce((p,A)=>{let h=A.order;return A.address===t.address&&m.collaterals[h]===BigInt(0)?Object.assign(p,{[A.address]:m.collaterals[0]}):Object.assign(p,{[A.address]:m.collaterals[h]})},{});return g[t.address]===BigInt(0)&&(g[t.address]=m.collaterals[0]),{collaterals:g,honey:m.honey}}catch(d){throw console.log("error",d),d}}import{formatUnits as _r}from"viem";import{collateralVaultAbi as Ne}from"@berachain/abis/honey/collateralVault";import{honeyFactoryAbi as pt}from"@berachain/abis/honey/honeyFactory";async function ls({client:e,collateralList:t,honeyFactoryAddress:r,...a}){let{config:o}=c(a),i=r??o.honey.factory;return await Promise.all(t.map(async n=>{let l=await e.readContract({address:o.honey.factory,abi:pt,functionName:"vaults",args:[n.address]}),[d,u,[m,f]]=await Promise.all([e.readContract({address:l,abi:Ne,functionName:"balanceOf",args:[i]}),e.readContract({address:i,abi:pt,functionName:"collectedAssetFees",args:[n.address]}),e.readContract({address:l,abi:Ne,functionName:"custodyInfo"})]),g=await e.readContract({address:l,abi:Ne,functionName:"convertToAssets",args:[d-u]});return{...n,balance:{raw:g.toString(),formatted:_r(g,n.decimals)},vault:m?f:l}}))}import{HermesClient as Jr}from"@pythnetwork/hermes-client";import{formatUnits as $r}from"viem";var jr="https://hermes.pyth.network";async function ft({priceFeedId:e}){let r=await new Jr(jr,{}).getLatestPriceUpdates(e,{encoding:"hex",parsed:!0});return{calldata:r.binary.data.map(a=>`0x${a}`),prices:r.parsed?.flatMap(a=>$r(BigInt(a.price.price),a.price.expo*-1))??[]}}import{parseEther as Kr}from"viem";import{honeyFactoryAbi as Yr}from"@berachain/abis/honey/honeyFactory";async function As({client:e,asset:t,amount:r,isMint:a,referenceCollateral:o,...i}){let{config:s}=c(i);if(t===o.address)return!1;try{let[n]=await Promise.all([e.readContract({address:s.honey.factory,abi:Yr,functionName:"relativeCap",args:[t]})]),[l,d]=await Promise.all([re({client:e,asset:t,amount:a?r:void 0}),re({client:e,asset:o.address,amount:a?void 0:r})]);return d===0n?l!==0n:Kr((l??0n).toString())/(d??0n)>=n-de}catch(n){throw console.log(n),n}}async function gt({client:e,priceFeedId:t,...r}){let{config:a}=c(r);try{return await e.readContract({address:a.external.pyth,abi:Oe,functionName:"getUpdateFee",args:[t]})}catch(o){throw console.error("getPythUpdateFee",o),o}}import{parseUnits as bt}from"viem";import{honeyFactoryAbi as zr}from"@berachain/abis/honey/honeyFactory";import{honeyFactoryPythWrapperAbi as Xr}from"@berachain/abis/honey/honeyFactoryPythWrapper";var xs=async({state:e,publicClient:t,priceFeedMap:r,collateralList:a,isPythWrapperEnabled:o,...i})=>{let{config:s}=c(i),n=We(i),{actionType:l,fromAmount:d,collaterals:u,isBasketModeEnabled:m}=e,f=o?s.honey.pythWrapper:s.honey.factory,g=a.map(p=>p.address);if(d[0]&&g.length){let p=l==="mint";if(o&&t&&r){let h=(await ft({priceFeedId:Object.values(r)})).calldata,P=0n;try{P=await gt({client:t,priceFeedId:h})}catch{P=Le(u.length)}return({account:y})=>{let I=[h,u[0]?.address,bt(d[0],(p?u[0]?.decimals:n?.decimals)??18),y,!!m];return{address:f,abi:Xr,functionName:p?"mint":"redeem",params:I,value:P}}}return({account:A})=>{let h=[u[0]?.address,bt(d[0],(p?u[0]?.decimals:n?.decimals)??18),A,!!m];return{value:0n,address:f,abi:zr,functionName:p?"mint":"redeem",params:h}}}throw new Error("Something went wrong while creating the Honey swap payload")};import{parseUnits as Zr}from"viem";import{honeyFactoryAbi as ea}from"@berachain/abis/honey/honeyFactory";import{honeyFactoryReaderAbi as ta}from"@berachain/abis/honey/honeyFactoryReader";async function Ds({client:e,isMint:t,collateralList:r,latestPrices:a,isPythWrapperEnabled:o,...i}){let{config:s}=c(i);if(o&&a){if(r.length===0)return;let l=a.prices.map(u=>Zr(u,18));return await e.readContract({address:s.honey.reader,abi:ta,functionName:"isBasketModeEnabledWithPrices",args:[t,l]})}return await e.readContract({address:s.honey.factory,abi:ea,functionName:"isBasketModeEnabled",args:[t]})}async function Ls({block:e,currentBlock:t,blockTime:r,publicClient:a}){if(j(e,"block"),v(a),t>e){let i=await a.getBlock({blockNumber:BigInt(e),includeTransactions:!1});return{timestamp:Number(i.timestamp)}}return{timestamp:S(Date.now())+r*(Number(e)-Number(t))}}import{formatUnits as Ge}from"viem";import{rewardVaultAbi as z}from"@berachain/abis/pol/rewards/rewardVault";var ra=(a=>(a.Duration="duration",a.TargetRate="targetRate",a.TargetApr="targetApr",a))(ra||{});async function Js(e,t){let[r,a,o,i,s,n]=await Promise.all([t.readContract({address:e,abi:z,functionName:"rewardsDuration"}),t.readContract({address:e,abi:z,functionName:"rewardVaultManager"}),t.readContract({address:e,abi:z,functionName:"rewardRate"}),t.readContract({address:e,abi:z,functionName:"periodFinish"}),t.readContract({address:e,abi:z,functionName:"targetRewardsPerSecond"}),t.readContract({address:e,abi:z,functionName:"minRewardDurationForTargetRate"})]),l=o*(i-BigInt(S(Date.now())))/10n**18n;return{rewardsDuration:Number(r),mode:s===0n?"duration":"targetRate",manager:a,rewardRate:Ge(o,36),periodFinish:Number(i),availableRewards:Ge(l,18),minRewardDurationForTargetRate:Number(n),targetRewardsPerSecond:Ge(s,36)}}function ge(e,t,r){return e?r*t*te(1)/e:null}function aa(e,t,r){return r?e*r/(t*te(1)):0}function Ks({availableRewards:e,periodFinish:t,tvl:r,bgtPrice:a,MIN_REWARD_DURATION:o,MAX_REWARD_DURATION:i,...s}){let n=S(Date.now());if(n>t)return{apr:0,duration:0,rewardRate:0,targetRate:null,periodFinish:0,mode:null};if(s.mode==="targetRate"||s.mode==="targetApr"){let m,{minRewardDurationForTargetRate:f,currentDuration:g}=s;if(s.mode==="targetRate"?m=s.rewardRate:m=aa(s.apr,a,r),m===0){let h=Math.min(g,i),P=e?e/h:0;return{apr:ge(r,a,P),duration:h,rewardRate:P,targetRate:null,periodFinish:h+n,mode:"duration"}}let p=f||o,A=e?e/m:0;if(A<p){let h=e?e/p:0;return{apr:ge(r,a,h),duration:p,rewardRate:h,targetRate:h.toString(),periodFinish:p+n,mode:null}}return{apr:ge(r,a,m),duration:A,rewardRate:m,targetRate:m.toString(),periodFinish:A+n,mode:null}}let{duration:l}=s,d=e/l;return{apr:ge(r,a,d),mode:null,targetRate:null,duration:l,rewardRate:d,periodFinish:l+n}}async function Zs({address:e,account:t,...r}){let{config:a}=c(r),o=`${a.staking}/vaults/${e}/earnings/${t}`;return Ue({url:o,type:"rest"})}import{formatUnits as oa}from"viem";import{rewardVaultAbi as na}from"@berachain/abis/pol/rewards/rewardVault";import{GetVaults as ia}from"@berachain/graphql/pol/api";async function be({filter:e,publicClient:t,...r}={}){let o=await b("api",r).query({query:ia,variables:e}),i=await Promise.allSettled(o.data.polGetRewardVaults.vaults.map(async n=>{if(t)return Promise.allSettled(n.activeIncentives.map(l=>t.readContract({abi:na,address:n.address,functionName:"incentives",args:[l.tokenAddress]})))})),s=o.data.polGetRewardVaults.vaults.map((n,l)=>{let d=0,u=n.activeIncentives.map((m,f)=>{let g=Number(m.remainingAmountUsd)&&Number(m.remainingAmount)?Number(m.remainingAmountUsd)/Number(m.remainingAmount):0,p=i[l]?.status==="fulfilled"&&i[l]?.value?.[f]?.status==="fulfilled"?oa(BigInt(i[l].value[f].value[2]),m.token.decimals):m.remainingAmount;return d+=Number(p)*Number(g),{...m,remainingAmount:p}});return{...n,dynamicData:{...n.dynamicData,allTimeReceivedBGTAmount:n.dynamicData?.allTimeReceivedBGTAmount??"0",bgtCapturePercentage:n.dynamicData?.bgtCapturePercentage??"0",activeIncentivesValueUsd:d.toString(),activeIncentivesRateUsd:n.dynamicData?.activeIncentivesRateUsd??"0",bgtCapturePerBlock:n.dynamicData?.bgtCapturePerBlock??"0"},activeIncentives:u}});return{pagination:o.data.polGetRewardVaults.pagination,gaugeList:s}}import{GlobalData as sa}from"@berachain/graphql/pol/api";async function yt(e={}){let{config:t}=c(e),a=await b("api",e).query({query:sa,variables:{chain:t.bex.chainName}});return{...a.data.polGetGlobalInfo,top3EmittingValidators:a.data.top3EmittingValidators.validators,allValidatorsCount:a.data.allValidatorsCount.pagination.totalCount}}import{formatEther as la}from"viem";import{bgtAbi as ua}from"@berachain/abis/pol/bgt";async function At({publicClient:e,...t}){let{config:r}=c(t);v(e);try{let a=await e.readContract({address:r.tokens.bgt,abi:ua,functionName:"totalBoosts",args:[]});return la(a)}catch(a){throw console.log(a),a}}import{erc20Abi as ca,formatEther as da}from"viem";async function ht({publicClient:e,...t}){let{config:r}=c(t);v(e);try{let a=await e.readContract({address:r.tokens.bgt,abi:ca,functionName:"totalSupply",args:[]});return da(a??0n)}catch(a){throw console.log(a),a}}import{GqlRewardVaultOrderBy as ma,GqlRewardVaultOrderDirection as pa}from"@berachain/graphql/pol/api";async function wt(e){let{gaugeList:t}=await be({filter:{orderBy:ma.Apr,orderDirection:pa.Desc,pageSize:e,where:{includeNonWhitelisted:!1}}});return t}async function kl(e){let[t,r,a,o]=await Promise.allSettled([yt(),wt(300),ht({publicClient:e}),At({publicClient:e})]);return t.status==="rejected"&&M.captureException(D({cause:t.reason,level:"warning"})),r.status==="rejected"&&M.captureException(D({cause:r.reason,level:"warning"})),a.status==="rejected"&&M.captureException(D({cause:a.reason,level:"warning"})),o.status==="rejected"&&M.captureException(D({cause:o.reason,level:"warning"})),{bgtTotalSupply:a.status==="fulfilled"?a.value:void 0,globalCuttingBoard:r.status==="fulfilled"?r.value:[],bgtTotalBoosts:o.status==="fulfilled"?o.value:void 0,...t.status==="fulfilled"?t.value:{}}}import{GetIncentiveFeeClaimStats as fa}from"@berachain/graphql/pol/fees";async function Ct({...e}){let t=b("pol.fees",e),{data:r}=await t.query({query:fa});if(r.incentiveFeeClaims.length>0){let a=r?.incentiveFeeClaims.reduce((s,n)=>s+Number(n.payoutAmount),3e4),i=(r?.incentiveFeeClaims.filter(s=>Number(s.timestamp)/1e3>Date.now()-He(1))).reduce((s,n)=>s+Number(n.payoutAmount),0);return{sumAllClaims:a,sumClaimsInLast24Hours:i}}return{sumAllClaims:0,sumClaimsInLast24Hours:0}}async function Il(e={}){let{config:t}=c(e);try{let a=await(await fetch(t.lists.rewardVaultList)).json();if(!a.protocols)throw new Error("Missing protocols in market list");return{marketList:a.protocols,marketDictionary:a.protocols.reduce((o,i)=>(o[i.name]=i,o),{})}}catch(r){throw console.error("Error fetching validator information",r),r}}async function Wl({account:e,validator:t,page:r=1,perPage:a=1e3,...o}){let{config:i}=c(o),s=await fetch(`${i.pol.bribeBoostApi}/api/v1/wallets/${e.toLowerCase()}/proofs/validator/${t.toLowerCase()}?page=${r}&per_page=${a}`,{cache:"no-store"});if(!s.ok){let l=await ue(s);throw new B({message:"Failed to fetch proofs on server",cause:{error:l,result:s,account:e,validator:t},reason:l?.reason})}return await s.json()}import{formatUnits as ga,parseUnits as ba}from"viem";import{wberaStakerVaultAbi as ya}from"@berachain/abis/pol/wberaStakerVault";async function _l({address:e,publicClient:t}){return v(t),t.readContract({address:e,abi:ya,functionName:"previewRedeem",args:[ba("1",18)]}).then(r=>Number(ga(r,18))).catch(()=>0)}import{GetRewardVault as Aa}from"@berachain/graphql/pol/api";async function zl({address:e,chainName:t,...r}){let{config:a}=c(r),o=t??a.bex.chainName,i=b("api",r),{data:s}=await i.query({query:Aa,variables:{vaultId:e,chain:o}});if(!s?.rewardVault)throw new _e({resource:"Reward vault",id:e,chainId:a.chainId});return s.rewardVault}import{isSameAddress as Pt}from"@berachain-foundation/berancer-sdk";import{erc20Abi as ye,formatUnits as ae}from"viem";import{rewardVaultAbi as xe}from"@berachain/abis/pol/rewards/rewardVault";function oe(e,t){return e.status==="success"?e.result:t}async function ou({address:e,stakingToken:t,publicClient:r}){let a=await r.readContract({address:e,abi:xe,functionName:"getWhitelistedTokens"}),i=a.findIndex(n=>Pt(t,n))!==-1?await r.readContract({address:e,abi:xe,functionName:"totalSupply"}):0n,s=await Promise.allSettled(a.map(async n=>{let[l,d,u,m,f]=await r.multicall({allowFailure:!0,contracts:[{address:e,abi:xe,functionName:"incentives",args:[n]},{address:n,abi:ye,functionName:"decimals"},{address:n,abi:ye,functionName:"name"},{address:n,abi:ye,functionName:"symbol"},{address:n,abi:ye,functionName:"balanceOf",args:[e]}]});if(l.status==="failure")throw new B({cause:l.error,message:"Failed to get incentive info. This is not possible.",level:"error",extra:{token:n,address:e}});let[g,p,A,h]=l.result,P=oe(d,18);return{token:n,manager:h,minIncentiveRate:ae(g,P),incentiveRate:ae(p,P),remainingAmount:ae(A,P),name:oe(u,void 0),symbol:oe(m,void 0),decimals:P,pendingAmount:Pt(t,n)?ae(oe(f,0n)-i-A,P):ae(oe(f,0n)-A,P)}}));return s.forEach((n,l)=>{n.status==="rejected"&&M.captureException(new B({reason:n.reason,message:"Incorrect incentives token received.",level:"error",extra:{token:a[l],address:e,error:n.reason}}))}),s.map(n=>n.status==="fulfilled"?n.value:null).filter(n=>n!==null)}import{rewardVaultAbi as ha}from"@berachain/abis/pol/rewards/rewardVault";async function su({address:e,publicClient:t}){return await t.readContract({address:e,abi:ha,functionName:"stakeToken"})}import{GetSWberaVaultMetadata as wa,GqlSWberaVaultMetadataResolution as Bt}from"@berachain/graphql/pol/api";function Ca(e){return e==="DAY"?Bt.OneDay:Bt.SevenDays}async function mu({window:e,...t}){let{config:r}=c(t),a=b("api",t);try{let o=await a.query({query:wa,variables:{chain:r.bex.chainName,resolution:Ca(e??"DAY")}}),{apr:i}=o.data.polGetSWberaVaultMetadata;return Number(i)}catch(o){throw console.error("Failed to get SW Bera APR",o),o}}import{GetSWberaVaultSnapshots as Pa,GqlVaultSnapshotDataRange as Ba}from"@berachain/graphql/pol/api";async function yu({chain:e,range:t=Ba.ThirtyDays,...r}={}){let{config:a}=c(r),o=b("api",r);try{return(await o.query({query:Pa,variables:{chain:e??a.bex.chainName,range:t}})).data.polGetSWberaVaultSnapshots}catch(i){throw console.error("Failed to get SW Bera Snapshots",i),i}}import{wberaStakerVaultAbi as va}from"@berachain/abis/pol/wberaStakerVault";async function ne({publicClient:e,address:t}){let r=await e.readContract({address:t,abi:va,functionName:"WITHDRAWAL_COOLDOWN"});return Number(r)}import{erc20Abi as Ae,erc4626Abi as ie}from"viem";async function Vu({address:e,underlyingAsset:t,publicClient:r,blockTime:a}){v(r);let o=26;try{let i=await r.getBlock({blockTag:"latest"}),s=Math.floor(o*60*60/a),n=i.number-BigInt(s),[l,d,u,m,f,g,p,A,h,P,y]=await Promise.all([r.readContract({address:e,abi:ie,functionName:"totalAssets"}),r.readContract({address:e,abi:ie,functionName:"totalSupply"}),r.readContract({address:e,abi:ie,functionName:"previewRedeem",args:[10n**18n],blockNumber:i.number}),r.readContract({address:t,abi:Ae,functionName:"balanceOf",args:[e]}),r.readContract({address:e,abi:ie,functionName:"totalAssets",blockNumber:n}),r.readContract({address:e,abi:Ae,functionName:"totalSupply",blockNumber:n}),r.readContract({address:e,abi:ie,functionName:"previewRedeem",args:[10n**18n],blockNumber:n}),r.readContract({address:t,abi:Ae,functionName:"balanceOf",args:[e],blockNumber:n}),r.readContract({address:t,abi:Ae,functionName:"totalSupply"}),ne({publicClient:r,address:e}),Ct({})]),I=new k(p.toString()),N=new k(u.toString());return{address:e,current:{exchangeRate:N.toString(),totalSupply:new k(d.toString()).dividedBy(1e18).toString(),totalAssets:new k(l.toString()).dividedBy(1e18).toString(),tvl:new k(m.toString()).dividedBy(1e18).toString()},previous:{exchangeRate:I.toString(),totalSupply:new k(g.toString()).dividedBy(1e18).toString(),totalAssets:new k(f.toString()).dividedBy(1e18).toString(),tvl:new k(A.toString()).dividedBy(1e18).toString()},totalWBeraIssued:new k(h.toString()).dividedBy(1e18).toString(),lockPeriod:P,totalBuyBacks:y.sumAllClaims,totalBuyBacksInLast24Hours:y.sumClaimsInLast24Hours}}catch(i){throw console.error("Failed to get SW Bera Vault Metadata",i),i}}import{wberaStakerVaultAbi as he}from"@berachain/abis/pol/wberaStakerVault";function vt(e){let t=Date.now(),r=e*1e3-t;if(r<=0)return;let a=S(r);return $e(a,!0,!0)}async function Fu({contractAddress:e,accountAddress:t,publicClient:r,version:a}){let o=[];function i(s,n){let[l,d,u]=s,m=l,f=Number(u)+Number(n),g=S(Date.now()),p=f-g;if(m>0){let A=vt(p<=0?0:f);o.push({receiptTokenAddress:e,withdrawalAmount:m,timeRemaining:A})}}switch(a){case"V1":{let[s,n]=await Promise.all([r.readContract({address:e,abi:he,functionName:"withdrawalRequests",args:[t]}),ne({publicClient:r,address:e})]);return i(s,n),o}case"V2":{let[s,n]=await Promise.all([r.readContract({address:e,abi:he,functionName:"getERC721WithdrawalRequestIds",args:[t]}),ne({publicClient:r,address:e})]);if(V(e,"SWBERA")){let u=await r.readContract({address:e,abi:he,functionName:"withdrawalRequests",args:[t]});i(u,n)}let d=(await Promise.all(s.map(async u=>{let m=await r.readContract({address:e,abi:he,functionName:"getERC721WithdrawalRequest",args:[u]}),{assets:f,requestTime:g}=m;if(!f||!g)throw new Error("Invalid withdrawal request");let p=f,A=Number(g)+Number(n),h=S(Date.now()),P=A-h;if(p>0){let y=vt(P<=0?0:A);return{withdrawalAmount:p,timeRemaining:y,withdrawalRequestId:u,receiptTokenAddress:e}}return null}))).filter(u=>u!==null);return o.push(...d),o}}}import{wberaStakerVaultAbi as Ra}from"@berachain/abis/pol/wberaStakerVault";async function Du({vaultAddresses:e,publicClient:t}){v(t);try{let r=await Promise.all(e.map(async o=>t.readContract({address:o,abi:Ra,functionName:"totalAssets"})));return e.reduce((o,i,s)=>(o[i]=r[s],o),{})}catch(r){throw console.error("Failed to get total staked amount",r),r}}async function Ou({account:e,...t}){let{config:r}=c(t),a=await fetch(`${r.pol.bribeBoostApi}/api/v1/wallets/${e.toLowerCase()}/rewards/aggregation`,{cache:"no-store"});if(!a.ok){let o=await ue(a);throw new B({message:"Failed to fetch incentives on server",cause:{error:o,result:a,account:e},reason:o?.error})}return a.json()}import{rewardVaultAbi as Va}from"@berachain/abis/pol/rewards/rewardVault";async function Rt({account:e,vaultAddress:t,publicClient:r}){if(!r)throw new Error("Missing public client");if(!e)throw new Error("Missing user account");if(!t)throw new Error("Missing vault address");return r.readContract({address:t,abi:Va,functionName:"earned",args:[e]})}import{formatEther as Te}from"viem";import{rewardVaultAbi as Vt}from"@berachain/abis/pol/rewards/rewardVault";async function St({account:e,vaultAddress:t,publicClient:r}){v(r),Pe(e,"account"),Pe(t,"vaultAddress");try{let[a,o]=await Promise.all([r.readContract({address:t,abi:Vt,functionName:"balanceOf",args:[e]}),r.readContract({address:t,abi:Vt,functionName:"getTotalDelegateStaked",args:[e]})]);return{balance:a,delegated:o}}catch(a){throw console.log(a),a}}import{rewardVaultAbi as Sa}from"@berachain/abis/pol/rewards/rewardVault";async function kt({vaultAddress:e,publicClient:t}){if(!t)throw new Error("Missing public client");if(!e)throw new Error("Missing vault address");try{return await t.readContract({address:e,abi:Sa,functionName:"totalSupply",args:[]})}catch(r){throw console.log(r),r}}async function tc({account:e,vaultAddress:t,publicClient:r}){let[a,o,i]=await Promise.all([St({account:e,vaultAddress:t,publicClient:r}),Rt({account:e,vaultAddress:t,publicClient:r}),kt({vaultAddress:t,publicClient:r})]),s=a.balance-a.delegated,n=i>0n?Number(Number.parseFloat(Te(a.balance))/Number.parseFloat(Te(i))).toString():"0";return{balance:a.balance,delegatedBalance:a.delegated,withdrawableBalance:s,rewards:Te(o),percentage:n}}import{formatUnits as Fe}from"viem";import{rewardVaultAbi as Nt}from"@berachain/abis/pol/rewards/rewardVault";import{GetUserVaults as ka}from"@berachain/graphql/pol/api";async function cc({account:e,publicClient:t,...r}){let{config:a}=c(r),s=(await b("api",r).query({query:ka,variables:{userId:e,chain:a.bex.chainName}})).data?.userVaultDeposits?.deposits;if(!s)return{totalBgtRewards:"0",vaults:[],totalStakedValue:0};let[n,l]=await Promise.all([t.multicall({allowFailure:!1,contracts:s.map(g=>({address:g.vaultAddress,abi:Nt,functionName:"earned",args:[e]}))}),t.multicall({allowFailure:!1,contracts:s.map(g=>({address:g.vaultAddress,abi:Nt,functionName:"balanceOf",args:[e]}))})]),{userVaults:d,total:u}=s.reduce((g,p,A)=>{let h=n[A],P=l[A];if(g.total+=h,!p.vault)return M.captureException(new B({message:"Deposit data from API is missing vault",level:"error",extra:{deposit:p}})),console.error("Deposit data from API is missing vault",p),g;if(h>0n||P>0n){let y=p.vault.dynamicData?.tvl&&Number(p.vault.stakingTokenAmount)!==0?Number(p.vault.dynamicData?.tvl??0)/Number(p.vault.stakingTokenAmount):null;g.userVaults.push({...p,vault:p.vault,unclaimedBgt:Fe(h,18),formattedBalance:Fe(P,p.vault.stakingToken.decimals),stakingTokenPrice:y})}return g},{userVaults:[],total:0n}),m=[...d].sort((g,p)=>{if(g.vault.isVaultWhitelisted&&!p.vault.isVaultWhitelisted)return-1;if(!g.vault.isVaultWhitelisted&&p.vault.isVaultWhitelisted)return 1;let A=Number.parseFloat(g.unclaimedBgt);return Number.parseFloat(p.unclaimedBgt)-A});return{totalStakedValue:m.reduce((g,p)=>{let A=Number(p.vault.dynamicData?.tvl??0);if(A===0)return g;let h=Number.parseFloat(p.vault.stakingTokenAmount),P=A/h;return g+P*Number(p.formattedBalance)},0),totalBgtRewards:Fe(u,18),vaults:m}}import{GetVaultHistory as Na}from"@berachain/graphql/pol/api";async function gc({vault:e,chain:t,...r}){let{config:a}=c(r);return(await b("api",r).query({query:Na,variables:{...r,vaultId:e,chain:t??a.bex.chainName}})).data.polGetRewardVaultSnapshots}import{GetVaultValidators as Ga}from"@berachain/graphql/pol/api";async function hc({address:e,onlyActiveValidators:t,...r}){return(await b("api",r).query({query:Ga,variables:{vaultId:e,isActive:t}})).data.validators.validators??[]}import{getAddress as xa,zeroAddress as Ta}from"viem";import{GetTokenCurrentPrices as Fa}from"@berachain/graphql/dex/api";async function Sc({addressIn:e,...t}){let{config:r,chainId:a}=c(t),o=e.map(n=>n.toLowerCase()).filter((n,l,d)=>n&&d.indexOf(n)===l),i=b("api",t),{data:s}=await i.query({query:Fa,variables:{chains:[r.bex.chainName],addressIn:o}});return s.tokenGetCurrentPrices.reduce((n,l)=>{if(!l.price||!l.address)return n;let d=l.address;return n[xa(d)]={price:K(l.price.toString()),updatedAt:l.updatedAt,chainId:a},n[d.toLowerCase()]={price:K(l.price.toString()),updatedAt:l.updatedAt,chainId:a},V(d,"WBERA")&&(n[Ta]={price:K(l.price.toString()),updatedAt:l.updatedAt,chainId:a},n[r.tokens.bgt.toLowerCase()]={price:K(l.price.toString()),updatedAt:l.updatedAt,chainId:a},n[r.tokens.bgt]={price:K(l.price.toString()),updatedAt:l.updatedAt,chainId:a}),n},{})}import{getPublicClient as Ea}from"@wagmi/core";import{erc20Abi as Ia,formatUnits as qa}from"viem";async function Tc({items:e,account:t,config:r}){j(e,"items"),j(r,"config"),j(t,"account");let a=Object.groupBy(e,i=>i.token.chainId);return(await Promise.allSettled(Object.entries(a).map(async([i,s])=>{if(!s)return[];let n=Ea(r,{chainId:Number(i)});return v(n,`publicClient ${i}`),(await n.multicall({contracts:s.map(u=>({address:u.token.address,abi:Ia,functionName:"allowance",args:[t,u.spender]}))})).map((u,m)=>{let f=s[m];return u.error?void 0:{token:f.token,spender:f.spender,amount:f.amount,allowance:{raw:u.result.toString(),formatted:qa(u.result,f.token.decimals)},needsApproval:u.result<BigInt(f.amount.raw)}}).filter(u=>!!u)}))).flatMap(i=>i.status==="fulfilled"?i.value:void 0).filter(i=>!!i)}import{getPublicClient as Ua,getWalletClient as Wa,switchChain as La}from"@wagmi/core";import{BaseError as Oa,createWalletClient as Ma,decodeErrorResult as Ha,HttpRequestError as _a,http as Ja}from"viem";import{ChainId as $a,defaultChainId as Tt}from"@berachain/config/internal";import{AbiFunctionSignatureNotFoundError as Da,decodeFunctionData as Qa}from"viem";async function Gt({publicClient:e,abi:t,...r}){let a=[...le,...t??[]],o,i,s,n,l,d,u;if("txHash"in r){let m=await e.getTransaction({hash:r.txHash});if(!m.to)throw new x({property:"tx",value:m,expected:"Transaction",message:"Trying to get revert reason for a contract creation"});l=m.input,i=m.to,s=m.from,n=m.value,o=m.blockNumber}else if(o=r.blockNumber,i=r.to,s=r.account,n=r.value,"data"in r)l=r.data;else if("functionName"in r&&"args"in r)d=r.functionName,u=r.args;else if(!n)throw new x({property:"dataOrFunctionNameAndArgs",value:r,expected:"Hex or FunctionName and Args"});try{if(!a)if(l)await e.call({data:l,to:i,account:s,blockNumber:o,value:n});else throw new Error("Data is required if abi is not provided");if("functionName"in r&&"args"in r&&r.functionName)d=r.functionName,u=r.args;else if(l){if(!a){let m=await e.call({data:l,to:i,account:s,blockNumber:o,value:n});throw new Error(`Getting revert reason for successful simulation. Data: ${l}`,{cause:m})}try{let m=Qa({abi:a,data:l});d=m.functionName,u=m.args}catch(m){throw m instanceof Da&&await e.call({data:l,to:i,account:s,blockNumber:o,value:n}),new Error("Data is required if abi is not provided")}}else throw new Error("No data or function name and args provided");throw a&&d?(await e.simulateContract({functionName:d,args:u,abi:a,address:i,account:s,blockNumber:o}),new H({message:"Getting revert reason for successful simulation",functionName:d,to:i,txHash:"txHash"in r?r.txHash:void 0,input:r})):new Error("No data or function name and args provided")}catch(m){if(m instanceof Error)return ee({error:m,abi:a,revertIfUnknown:!0});throw m}}var ja=Me(1),xt=(e,t)=>e*(100n+BigInt(t))/100n;function Ee({nonceResult:e,onWarning:t}){if(e.status==="fulfilled"){if(e.value&&e.value>Number.MAX_SAFE_INTEGER){t?.(new B({message:"Nonce is too large. No nonce will be provided to avoid IntegerOutOfRangeError.",cause:e.value,level:"debug"}));return}return e.value}}function Ka(e=Tt){return e===$a.BEPOLIA?process.env.NEXT_PUBLIC_80069_ANVIL_IMPERSONATE_ACCOUNT==="true":process.env.NEXT_PUBLIC_80094_ANVIL_IMPERSONATE_ACCOUNT==="true"}async function ed(e){if(process.env.NODE_ENV==="development"&&!e.contractName&&e.address&&!("calls"in e||e.calls))throw console.warn("beraWriteContract: Contract name is required. Either update the contract mapping in devrel or provide a contract name in ContractName enum","This is a development error and will be thrown in development mode only."),new x({property:"contractName",value:e.contractName,expected:"ContractName",displayMessage:`[DEV] Contract name is required as it's not mapped in the devrel's contract mapping ${e.address}`,level:"error"});let{address:t,calls:r,value:a,gasLimit:o,onLoading:i,onSuccess:s,onWarning:n,onError:l,onSubmission:d,wagmiConfig:u,walletClient:m,account:f,txConfirmationTimeout:g=12e4,chainId:p=Tt,impersonateAccount:A=Ka(p),errorsAbi:h=[],pollingInterval:P=ja,...y}=e;i?.(e);let I="data"in y?y.data:void 0,N=[...le,...h,..."abi"in y&&y.abi&&Array.isArray(y.abi)?y.abi:[]],T=m;if(!u){l?.(new x({property:"wagmiConfig",value:u,expected:"Config"}),e);return}if(!(T?.account?.type==="local"))try{await La(u,{chainId:p})}catch(R){let G=R;l?.(new B({cause:G,displayMessage:"There was an error switching to the chain."}),e);return}if(!T)try{T=await Wa(u,{chainId:p})}catch(R){l?.(new B({cause:R,displayMessage:"There was an error connecting to the wallet."}),e);return}if(!T){l?.(new x({displayMessage:"There was an error connecting to the wallet.",property:"walletClient",value:T,expected:"WalletClient"}),e);return}let q=f||T.account;if(!q){l?.(new x({property:"account",value:q,expected:"Account"}),e);return}let se=typeof q=="string"?q:q.address,W=Ua(u,{chainId:p});try{v(W)}catch(R){l?.(R,e);return}if(A){let R=ve(p);await R.impersonateAccount({address:se}),T=Ma({transport:Ja(R.transport.url),account:q,chain:T.chain})}let F,Z={calls:"calls"in y?y.calls:void 0,params:"params"in y?y.params:void 0,value:a,data:"data"in y?y.data:void 0};try{let R=W.getTransactionCount({address:se,blockTag:"latest"}).catch(()=>{}),G={account:se,to:t,address:t,chainId:p,value:a};if(r){let E=r.map(w=>{if("abi"in w&&Array.isArray(N)&&N.push(...w.abi),"data"in w)return{to:w.address,data:w.data,value:w.value??0n};if("abi"in w&&"functionName"in w){let L="params"in w?w.params:void 0;return{to:w.address,abi:w.abi,functionName:w.functionName,args:L,value:w.value??0n}}return{to:w.address,value:w.value??0n}});if(e.enableSimulateCalls){let w=await W.simulateCalls({calls:E,account:q}),L=w.results.findIndex(O=>O.status==="failure");if(L!==-1){if(w.block.number===null)throw new x({property:"blockNumber",value:w.block.number,expected:"bigint",message:"Block number is null"});let O=w.results[L],{reason:Ce}=O.data&&O.data!=="0x"?{reason:qe(Ha({data:O.data,abi:N}))}:ee({error:O.error,revertIfUnknown:!1,abi:N});l?.(new H({cause:O.error,txHash:F,chainId:p,reason:Ce,abi:N,input:Z,blockNumber:w.block.number}),e);return}}if(process.env.NODE_ENV==="test")throw new x({displayMessage:"Batch calls are not supported in test environment",expected:"not test",property:"NODE_ENV",value:process.env.NODE_ENV,level:"fatal"});let Q=await T.sendCalls({calls:E,account:q,forceAtomic:!0});d?.({id:Q.id},e);let U=await T.waitForCallsStatus({id:Q.id,pollingInterval:P,timeout:g});if(U.status==="success"){let w=U.receipts?.[0];if(!w)throw new B({message:"Call status is success but no receipt was found",cause:U,level:"error",reason:"CALL_STATUS_SUCCESS_BUT_NO_RECEIPT"});return s?.(w,e),w}throw console.error("wallet_sendCalls: Call failed",U),new H({cause:U,level:"error",input:Z,txHash:F,abi:N,chainId:p})}if(I){let[E,Q,U]=await Promise.allSettled([W.call({...G,data:I}),o??W.estimateGas({...G,data:I}),R]);if(E.status==="rejected")throw E.reason;let w=Q.status==="fulfilled"?xt(Q.value,10):Be;F=await T.sendTransaction({data:I,to:t,account:q,gas:w,chainId:p,nonce:Ee({nonceResult:U,onWarning(L){n?.(L,e)}}),value:a}),d?.({txHash:F},e)}else if("abi"in y&&"functionName"in y){let{abi:E,functionName:Q}=y,U="params"in y?y.params:void 0,[w,L,O]=await Promise.allSettled([W.simulateContract({...G,abi:N,functionName:Q,args:U,account:q}),o??W.estimateContractGas({...G,abi:N,functionName:Q,args:U}),R]);if(w.status==="rejected")throw w.reason;let Ce=o??(L.status==="fulfilled"?xt(L.value,10):Be);F=await T.writeContract({...w.value.request,chainId:p,gas:Ce,nonce:Ee({nonceResult:O,onWarning(Qt){n?.(Qt,e)}})}),d?.({txHash:F},e)}else{let[E]=await Promise.allSettled([R]);F=await T.sendTransaction({chainId:p,to:t,value:a,account:q,nonce:Ee({nonceResult:E,onWarning(Q){n?.(Q,e)}})}),d?.({txHash:F},e)}process.env.NODE_ENV==="test"&&await ve(p).mine({blocks:1});let J=await W.waitForTransactionReceipt({hash:F,pollingInterval:P,timeout:g,confirmations:1});if(J.status==="success")s?.(J,e);else{let E=await Gt({publicClient:W,blockNumber:J.blockNumber,to:t,account:se,abi:N,args:"params"in y?y.params:void 0,functionName:"functionName"in y?y.functionName:void 0,value:a,data:I});process.env.NODE_ENV==="test"&&console.error("beraWriteContract: Revert reason",E),l?.(new H({reason:E.reason,txHash:F,receipt:J,to:t,functionName:"functionName"in y?y.functionName:void 0,input:Z,chainId:p,abi:N,blockNumber:J.blockNumber}),e)}return J}catch(R){if(R instanceof B)l?.(R,e);else if(R instanceof Error){let G=ee({error:R,revertIfUnknown:!1,abi:N});if(G&&G.rootCause instanceof Oa&&"url"in G.rootCause){l?.(new $({cause:G.rootCause,response:void 0,endpoint:{url:G.rootCause.url,type:"rpc"},statusCode:G.rootCause instanceof _a?G.rootCause.status:void 0}),e);return}l?.(new H({cause:R,to:t,txHash:F,chainId:p,abi:N,functionName:"functionName"in y?y.functionName:void 0,input:Z}),e)}else l?.(new H({cause:R,txHash:F,to:t,chainId:p,functionName:"functionName"in y?y.functionName:void 0,input:Z,abi:N}),e)}}import{GetValidators as Ya}from"@berachain/graphql/pol/api";async function Ft({variables:e={},...t}={}){let{config:r}=c(t);return(await b("api",t).query({query:Ya,variables:{chain:r.bex.chainName,...e}})).data}import{isAddressEqual as za}from"viem";async function ld({allocation:e}){let t=await be({filter:{where:{vaultAddressIn:e.weights.map(a=>a.receiver)}}}),r=e?.start.blockNumber??0;return e?.weights.map(a=>({percentage:a.percentage,receiver:a.receiver,startBlock:r,receivingVault:t?.gaugeList.find(o=>za(o.address,a.receiver))}))}import{GetValidator as Xa}from"@berachain/graphql/pol/api";async function pd({id:e,...t}){let{config:r}=c(t);return(await b("api",t).query({query:Xa,variables:{id:e,chain:r.bex.chainName}})).data}import{GetValidatorBlockStats as Za}from"@berachain/graphql/pol/subgraph";async function yd({pubKey:e,first:t=1,...r}){let a=b("pol.subgraph",r);try{return(await a.query({query:Za,variables:{pubKey:e,first:t}})).data}catch(o){throw console.error("GetValidatorBlockStats:",o),o}}import{beraChefAbi as Et}from"@berachain/abis/pol/rewards/beraChef";function X(e,t){return{start:{blockNumber:Number(e.startBlock),timestamp:e.startBlock!==0n?t:0},weights:e.weights.map(r=>({receiver:r.receiver,percentage:Number(r.percentageNumerator)/1e4}))}}function eo(e,t){return e.start.blockNumber===t.start.blockNumber&&e.weights.every((r,a)=>r.percentage===t.weights[a].percentage)}async function Cd({client:e,pubKey:t,...r}){let{config:a}=c(r);try{let[o,i]=await Promise.all([e.readContract({address:a.pol.beraChef,abi:Et,functionName:"getActiveRewardAllocation",args:[t]}),e.readContract({address:a.pol.beraChef,abi:Et,functionName:"getSetActiveRewardAllocation",args:[t]})]),[s,n]=await Promise.all([o.startBlock!==0n?e.getBlock({blockNumber:BigInt(o.startBlock)}):{timestamp:0},i.startBlock!==0n?e.getBlock({blockNumber:BigInt(i.startBlock)}):{timestamp:0}]),l=X(o,Number(s.timestamp)),d=X(i,Number(n.timestamp)),u=!1;return d.start.blockNumber===0?u=!0:u=!eo(d,l),{activeRewardAllocation:l,setRewardAllocation:d,isBaseline:u,isNeverSet:d?.start.blockNumber===0}}catch(o){throw console.log("getValidatorRewardAllocation:",o),o}}import{beraChefAbi as to}from"@berachain/abis/pol/rewards/beraChef";function Vd(e){return e.start.blockNumber===0}async function Sd({client:e,...t}){let{config:r}=c(t),a=await e.readContract({address:r.pol.beraChef,abi:to,functionName:"getDefaultRewardAllocation",args:[]});return X({...a,startBlock:0n},0)}async function Nd({client:e,valPubKey:t}){return 5614}import{formatEther as we}from"viem";import{bgtAbi as Ie}from"@berachain/abis/pol/bgt";async function It({account:e,pubkey:t,publicClient:r,...a}){let{config:o}=c(a);if(!e)throw new Error("account is required");if(!r)throw new Error("publicClient is required");let[i,s,n]=await Promise.all([r.readContract({address:o.tokens.bgt,abi:Ie,functionName:"boosted",args:[e,t]}),r.readContract({address:o.tokens.bgt,abi:Ie,functionName:"boostedQueue",args:[e,t]}),r.readContract({address:o.tokens.bgt,abi:Ie,functionName:"dropBoostQueue",args:[e,t]})]),l=i-n[1];return{pubkey:t,droppableBoostAmount:we(l),activeBoostAmount:we(i),queuedBoostAmount:we(s[1]),queuedDropBoostAmount:we(n[1]),queuedBoostStartBlock:s[0],queuedDropBoostStartBlock:n[0],hasPendingBoosts:s[1]>0n||n[1]>0n,hasActiveBoosts:i>0n,hasDroppableBoosts:l>0n}}import{formatEther as ao,parseEther as Dt}from"viem";import{GetUserValidatorInformation as ro}from"@berachain/graphql/pol/api";async function qt({account:e,...t}){let{config:r}=c(t);return b("api",t).query({query:ro,variables:{address:e.toLowerCase(),chain:r.bex.chainName}})}async function Hd({account:e,publicClient:t,chain:r,...a}){let{config:o}=c(a),i=r??o.bex.chainName,s=await qt({account:e}),[n,l]=await Promise.all([Ft({variables:{chain:i,where:{idIn:s.data.polGetValidatorBoosts.boosts.map(d=>d.validatorId)}}}),Promise.all(s.data.polGetValidatorBoosts.boosts.filter(d=>!!d.validator).map(d=>It({account:e,pubkey:d.validator.pubkey,publicClient:t})))]);return n?.validators.validators.map(d=>{let u=l.find(f=>f.pubkey.toLowerCase()===d.pubkey.toLowerCase());if(!u)throw new Error("User deposited not found");let m=Dt(u?.activeBoostAmount??"0")-Dt(u?.queuedDropBoostAmount);return{...d,userBoosts:{pubkey:u.pubkey,activeBoostAmount:u?.activeBoostAmount,queuedBoostAmount:u?.queuedBoostAmount,queuedBoostStartBlock:Number(u?.queuedBoostStartBlock),queuedDropBoostAmount:u?.queuedDropBoostAmount,queuedDropBoostStartBlock:Number(u?.queuedDropBoostStartBlock),droppableBoostAmount:ao(m),hasPendingBoosts:Number(u?.queuedBoostAmount)>0||Number(u?.queuedDropBoostAmount)>0,hasActiveBoosts:Number(u?.activeBoostAmount)>0,hasDroppableBoosts:m>0n}}})}var oo=[{validatorAddress:"0x8f51e63d9921a461be29e73dca1c2385e1adc5943fbb36ded4ba96025ee8a783184d1118da08171f6ea831153c878a6d",earning:.045,staked:{amount:16114000000000000000n,formattedAmount:"161.14"},rewards:{amount:15214000000000000000n,formattedAmount:"152.14"}},{staked:{amount:141514000000000000000n,formattedAmount:"1415.14"},validatorAddress:"0x97b21253b17f4e814fe7505c15c18e68c85ab2477274ad370a762df50e3eb4cb1a48451e089bc22e158d7448549a8ab9",earning:.045,rewards:{amount:15414000000000000000n,formattedAmount:"154.14"},queueData:{stake:[{amount:16159000000000000000n,formattedAmount:"161.59"}],unstake:[{amount:16159000000000000000n,formattedAmount:"161.59",timestamp:S(Date.now()-72e6)}]}},{staked:{amount:141514000000000000000n,formattedAmount:"1415.14"},validatorAddress:"0xa2705d6b27891f3f5651f26547d1bb79e256f95f249d1ad717cef087d77d38b037e5d6dbaa2538930fd0731ec9b02f3a",earning:.145,rewards:{amount:15414000000000000000n,formattedAmount:"154.14"},queueData:{unstake:[{amount:16159000000000000000n,formattedAmount:"161.59",timestamp:S(Date.now()-72e6)}]}},{staked:{amount:141514000000000000000n,formattedAmount:"1415.14"},validatorAddress:"0xa2705d6b27891f3f5651f26547d1bb79e256f95f249d1ad717cef087d77d38b037e5d6dbaa2538930fd0731ec9b02f3a",earning:.145,rewards:{amount:15414000000000000000n,formattedAmount:"154.14"},queueData:{unstake:[{amount:16159000000000000000n,formattedAmount:"161.59",timestamp:S(Date.now()-72e6)}]}},{staked:{amount:141514000000000000000n,formattedAmount:"1415.14"},validatorAddress:"0xa2705d6b27891f3f5651f26547d1bb79e256f95f249d1ad717cef087d77d38b037e5d6dbaa2538930fd0731ec9b02f3a",earning:.145,rewards:{amount:15414000000000000000n,formattedAmount:"154.14"},queueData:{unstake:[{amount:16159000000000000000n,formattedAmount:"161.59",timestamp:S(Date.now()-72e6)}]}},{staked:{amount:141514000000000000000n,formattedAmount:"1415.14"},validatorAddress:"0xa2705d6b27891f3f5651f26547d1bb79e256f95f249d1ad717cef087d77d38b037e5d6dbaa2538930fd0731ec9b02f3a",earning:.145,rewards:{amount:15414000000000000000n,formattedAmount:"154.14"},queueData:{unstake:[{amount:16159000000000000000n,formattedAmount:"161.59",timestamp:S(Date.now()-72e6)}]}},{staked:{amount:141514000000000000000n,formattedAmount:"1415.14"},validatorAddress:"0xa2705d6b27891f3f5651f26547d1bb79e256f95f249d1ad717cef087d77d38b037e5d6dbaa2538930fd0731ec9b02f3a",earning:.145,rewards:{amount:15414000000000000000n,formattedAmount:"154.14"},queueData:{unstake:[{amount:16159000000000000000n,formattedAmount:"161.59",timestamp:S(Date.now()-72e6)}]}},{staked:{amount:241514000000000000000n,formattedAmount:"2415.14"},validatorAddress:"0xa4e4b63514f54d61da5197359f11ff1fc2930788ba2ffdd30c2fc059cbe0221020197bf9446b16ac347f36c7517a8686",earning:.145,rewards:{amount:15414000000000000000n,formattedAmount:"154.14"},queueData:{unstake:[{amount:1159000000000000000n,formattedAmount:"11.59",timestamp:S(Date.now()-36e6)}]}},{validatorAddress:"0xb0511ec039591e98bd4e183ba70b85572214a7ad8ca1a43e96ad3495d3821054927bc542e5482ec9733e35b7ef0b1f03",earning:.045,staked:{amount:141514000000000000000n,formattedAmount:"1415.14"},rewards:{amount:15414000000000000000n,formattedAmount:"154.14"},queueData:{stake:[{amount:1159000000000000000n,formattedAmount:"11.59"}]}}];async function $d(e){return await new Promise(t=>setTimeout(t,2e3)),e==="0x4C368fFE3650379d6318C8d4630bc51f8Ad12bB6"?oo:[]}import{GetValidatorAnalytics as no}from"@berachain/graphql/pol/subgraph";async function Xd({pubkey:e,dayRange:t,...r}){return(await b("pol.subgraph",r).query({query:no,variables:{pubKey:e,timestamp:Je(t).toString()}})).data}import{beraChefAbi as io}from"@berachain/abis/pol/rewards/beraChef";async function rm({client:e,pubKey:t,...r}){let{config:a}=c(r),o=await e.readContract({address:a.pol.beraChef,abi:io,functionName:"getValCommissionOnIncentiveTokens",args:[t]});return Number(o??0n)/1e4}var nm=(e,t,r)=>{if(!t||!e)return 0;let a=te(1)/r;return(t?a*(Number(e.dynamicData?.stakedBeraAmount)/t):0)*Number.parseFloat(e.dynamicData?.rewardRate??"0")};import{beaconDepositAbi as so}from"@berachain/abis/pol/beaconDeposit";async function um({client:e,pubKey:t,...r}){let{config:a}=c(r);try{return await e.readContract({address:a.depositContract,abi:so,functionName:"getOperator",args:[t]})}catch(o){throw console.log("getValidatorOperatorAddress:",o),o}}import{beraChefAbi as lo}from"@berachain/abis/pol/rewards/beraChef";async function pm({client:e,pubKey:t,...r}){let{config:a}=c(r),o=await e.readContract({address:a.pol.beraChef,abi:lo,functionName:"getValQueuedCommissionOnIncentiveTokens",args:[t]});return{blockNumberLast:o.blockNumberLast,commissionRate:Number(o.commissionRate)/1e4}}import{beaconDepositAbi as uo}from"@berachain/abis/pol/beaconDeposit";async function ym({client:e,pubKey:t,...r}){let{config:a}=c(r);try{return await e.readContract({address:a.depositContract,abi:uo,functionName:"queuedOperator",args:[t]})}catch(o){throw console.log("getValidatorQueuedOperatorAddress:",o),o}}import{beraChefAbi as co}from"@berachain/abis/pol/rewards/beraChef";async function Pm({client:e,pubKey:t,...r}){let{config:a}=c(r);try{let o=await e.readContract({address:a.pol.beraChef,abi:co,functionName:"getQueuedRewardAllocation",args:[t]});return X(o,0)}catch(o){throw console.log("getValidatorQueuedRewardAllocation:",o),o}}export{go as a,me as b,b as c,Fo as d,Ye as e,Mo as f,en as g,nn as h,dn as i,Xe as j,Pn as k,Sn as l,Fn as m,Y as n,Qn as o,fe as p,Mn as q,Jn as r,zn as s,nt as t,ii as u,ci as v,fi as w,Ai as x,it as y,ke as z,lt as A,$i as B,zi as C,Hr as D,rs as E,ls as F,ft as G,As as H,gt as I,xs as J,Ds as K,Ls as L,ra as M,Js as N,Ks as O,Zs as P,be as Q,kl as R,Ct as S,Il as T,Wl as U,_l as V,zl as W,ou as X,su as Y,mu as Z,yu as _,ne as $,Vu as aa,Fu as ba,Du as ca,Ou as da,Rt as ea,tc as fa,cc as ga,gc as ha,hc as ia,Sc as ja,Tc as ka,Ka as la,ed as ma,Ft as na,ld as oa,pd as pa,yd as qa,X as ra,eo as sa,Cd as ta,Vd as ua,Sd as va,Nd as wa,It as xa,Hd as ya,$d as za,Xd as Aa,rm as Ba,nm as Ca,um as Da,pm as Ea,ym as Fa,Pm as Ga};
|
|
4
|
+
//# sourceMappingURL=chunk-MASD43N5.mjs.map
|