@berachain/berajs 0.2.0 → 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (131) hide show
  1. package/dist/{transactionStore-BvStaXf3.d.ts → BexStatusProvider-nS3NcdxI.d.cts} +1 -41
  2. package/dist/{transactionStore-CQrGYSY2.d.cts → BexStatusProvider-nS3NcdxI.d.ts} +1 -41
  3. package/dist/abi/exports.cjs.map +1 -1
  4. package/dist/actions/exports.cjs +1 -1
  5. package/dist/actions/exports.cjs.map +1 -1
  6. package/dist/actions/exports.d.cts +4 -5
  7. package/dist/actions/exports.d.ts +4 -5
  8. package/dist/actions/exports.mjs +1 -1
  9. package/dist/{chunk-OS5AJMYJ.cjs → chunk-22J3YJDN.cjs} +2 -2
  10. package/dist/chunk-22J3YJDN.cjs.map +1 -0
  11. package/dist/{chunk-MTS5SZLA.mjs → chunk-2LL3P5PN.mjs} +2 -2
  12. package/dist/chunk-3YXSUBA5.mjs +2 -0
  13. package/dist/{chunk-H2QSRMVS.mjs.map → chunk-3YXSUBA5.mjs.map} +1 -1
  14. package/dist/chunk-55L7STYD.mjs +2 -0
  15. package/dist/chunk-55L7STYD.mjs.map +1 -0
  16. package/dist/{chunk-BOYZVULX.cjs → chunk-6LDOG5RL.cjs} +2 -2
  17. package/dist/chunk-6LDOG5RL.cjs.map +1 -0
  18. package/dist/{chunk-UQUWMHVF.cjs → chunk-7LNBSOVV.cjs} +2 -2
  19. package/dist/chunk-7LNBSOVV.cjs.map +1 -0
  20. package/dist/{chunk-ZQRACIGR.mjs → chunk-7SMWQ6SN.mjs} +2 -2
  21. package/dist/{chunk-7GWTHOLO.mjs → chunk-7WRTK7RJ.mjs} +2 -2
  22. package/dist/chunk-A4UDYSB6.mjs +4 -0
  23. package/dist/chunk-A4UDYSB6.mjs.map +1 -0
  24. package/dist/chunk-AX2YQQFQ.mjs +2 -0
  25. package/dist/chunk-AX2YQQFQ.mjs.map +1 -0
  26. package/dist/chunk-C6ZGUO4H.cjs +2 -0
  27. package/dist/chunk-C6ZGUO4H.cjs.map +1 -0
  28. package/dist/chunk-CYKCYPFR.cjs.map +1 -1
  29. package/dist/chunk-ECRMUMTA.mjs +2 -0
  30. package/dist/chunk-ECRMUMTA.mjs.map +1 -0
  31. package/dist/{chunk-ZAKA4TGK.cjs → chunk-FCWDGE62.cjs} +2 -2
  32. package/dist/chunk-FCWDGE62.cjs.map +1 -0
  33. package/dist/chunk-FL2N3XHK.cjs.map +1 -1
  34. package/dist/chunk-MUCEYO3E.cjs +4 -0
  35. package/dist/chunk-MUCEYO3E.cjs.map +1 -0
  36. package/dist/chunk-OIYXOKTT.cjs.map +1 -1
  37. package/dist/chunk-P2Q7CMUD.cjs +2 -0
  38. package/dist/chunk-P2Q7CMUD.cjs.map +1 -0
  39. package/dist/chunk-PKXAW6MO.cjs +2 -0
  40. package/dist/chunk-PKXAW6MO.cjs.map +1 -0
  41. package/dist/chunk-SWMJQOH6.cjs.map +1 -1
  42. package/dist/{chunk-YQGZMWDT.mjs → chunk-THATXCJK.mjs} +2 -2
  43. package/dist/chunk-VP7XUOSI.cjs.map +1 -1
  44. package/dist/chunk-VXL2ZZ4X.cjs.map +1 -1
  45. package/dist/chunk-WRFDB3QJ.cjs.map +1 -1
  46. package/dist/chunk-XNJLSA6P.cjs.map +1 -1
  47. package/dist/chunk-YZV5LKIP.cjs +2 -0
  48. package/dist/chunk-YZV5LKIP.cjs.map +1 -0
  49. package/dist/contexts/exports.cjs +1 -1
  50. package/dist/contexts/exports.cjs.map +1 -1
  51. package/dist/contexts/exports.d.cts +2 -10
  52. package/dist/contexts/exports.d.ts +2 -10
  53. package/dist/contexts/exports.mjs +1 -1
  54. package/dist/contexts/exports.mjs.map +1 -1
  55. package/dist/enum/exports.cjs.map +1 -1
  56. package/dist/enum/exports.d.cts +1 -2
  57. package/dist/enum/exports.d.ts +1 -2
  58. package/dist/errors/exports.cjs +1 -1
  59. package/dist/errors/exports.cjs.map +1 -1
  60. package/dist/errors/exports.d.cts +25 -2
  61. package/dist/errors/exports.d.ts +25 -2
  62. package/dist/errors/exports.mjs +1 -1
  63. package/dist/{getValidatorQueuedOperatorAddress-It0GsdvQ.d.cts → getValidatorQueuedOperatorAddress-Dstyaomr.d.cts} +1 -1
  64. package/dist/{getValidatorQueuedOperatorAddress-BX35p2Lv.d.ts → getValidatorQueuedOperatorAddress-RW4OMcD1.d.ts} +1 -1
  65. package/dist/{global.d-Ba-NIojH.d.cts → global.d-CN6l2b9E.d.cts} +1 -2
  66. package/dist/{global.d-By70bEv2.d.ts → global.d-wYu8G8IQ.d.ts} +1 -2
  67. package/dist/hooks/exports.cjs +2 -2
  68. package/dist/hooks/exports.cjs.map +1 -1
  69. package/dist/hooks/exports.d.cts +7 -15
  70. package/dist/hooks/exports.d.ts +7 -15
  71. package/dist/hooks/exports.mjs +3 -3
  72. package/dist/hooks/exports.mjs.map +1 -1
  73. package/dist/{txnEnum-BYNbCxla.d.ts → txnEnum-BlBYhNRl.d.cts} +74 -1
  74. package/dist/{txnEnum-BYNbCxla.d.cts → txnEnum-BlBYhNRl.d.ts} +74 -1
  75. package/dist/types/exports.cjs.map +1 -1
  76. package/dist/types/exports.d.cts +2 -3
  77. package/dist/types/exports.d.ts +2 -3
  78. package/dist/utils/exports.cjs +1 -1
  79. package/dist/utils/exports.cjs.map +1 -1
  80. package/dist/utils/exports.mjs +1 -1
  81. package/dist/utils/exports.mjs.map +1 -1
  82. package/package.json +6 -6
  83. package/src/actions/dex/aggregators/haiku.ts +1 -1
  84. package/src/actions/dex/aggregators/oogabooga.ts +1 -1
  85. package/src/actions/pol/getEarnedStakedBeraVault.ts +1 -1
  86. package/src/actions/pol/getStakingDailyAssets.ts +4 -1
  87. package/src/actions/tokens/getWalletBalances.integration.test.ts +1 -1
  88. package/src/contexts/exports.ts +0 -1
  89. package/src/data/contracts.ts +1 -1
  90. package/src/errors/BeraError.ts +11 -2
  91. package/src/errors/RequestError.ts +27 -1
  92. package/src/errors/errorMap.ts +7 -6
  93. package/src/errors/getErrorMessage.ts +59 -20
  94. package/src/errors/getRevertReason.integration.test.ts +1 -1
  95. package/src/hooks/exports.ts +0 -4
  96. package/src/hooks/pol/useStakedData.ts +1 -1
  97. package/dist/chunk-7SC4VD3U.cjs +0 -2
  98. package/dist/chunk-7SC4VD3U.cjs.map +0 -1
  99. package/dist/chunk-BHNQX4XC.mjs +0 -2
  100. package/dist/chunk-BHNQX4XC.mjs.map +0 -1
  101. package/dist/chunk-BOYZVULX.cjs.map +0 -1
  102. package/dist/chunk-C3G5KXCH.mjs +0 -2
  103. package/dist/chunk-C3G5KXCH.mjs.map +0 -1
  104. package/dist/chunk-G6NA6NSM.mjs +0 -4
  105. package/dist/chunk-G6NA6NSM.mjs.map +0 -1
  106. package/dist/chunk-H2QSRMVS.mjs +0 -2
  107. package/dist/chunk-IJM76AWK.cjs +0 -4
  108. package/dist/chunk-IJM76AWK.cjs.map +0 -1
  109. package/dist/chunk-MUNAP5TM.cjs +0 -2
  110. package/dist/chunk-MUNAP5TM.cjs.map +0 -1
  111. package/dist/chunk-OS5AJMYJ.cjs.map +0 -1
  112. package/dist/chunk-TJWKS54T.mjs +0 -2
  113. package/dist/chunk-TJWKS54T.mjs.map +0 -1
  114. package/dist/chunk-UQUWMHVF.cjs.map +0 -1
  115. package/dist/chunk-UXUWSRVV.cjs +0 -2
  116. package/dist/chunk-UXUWSRVV.cjs.map +0 -1
  117. package/dist/chunk-WTCBORPB.cjs +0 -2
  118. package/dist/chunk-WTCBORPB.cjs.map +0 -1
  119. package/dist/chunk-ZAKA4TGK.cjs.map +0 -1
  120. package/dist/contracts-CQIPk0Jc.d.cts +0 -74
  121. package/dist/contracts-CQIPk0Jc.d.ts +0 -74
  122. package/src/contexts/TransactionStoreContext.tsx +0 -87
  123. package/src/hooks/transactions/transactionStore.ts +0 -296
  124. package/src/hooks/transactions/transactionStore.unit.test.ts +0 -561
  125. package/src/hooks/transactions/useAddRecentTransaction.ts +0 -29
  126. package/src/hooks/transactions/useRecentTransactions.ts +0 -27
  127. package/src/hooks/transactions/useSetTransactionStatus.ts +0 -31
  128. /package/dist/{chunk-MTS5SZLA.mjs.map → chunk-2LL3P5PN.mjs.map} +0 -0
  129. /package/dist/{chunk-ZQRACIGR.mjs.map → chunk-7SMWQ6SN.mjs.map} +0 -0
  130. /package/dist/{chunk-7GWTHOLO.mjs.map → chunk-7WRTK7RJ.mjs.map} +0 -0
  131. /package/dist/{chunk-YQGZMWDT.mjs.map → chunk-THATXCJK.mjs.map} +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/errors/errorMap.ts","../src/errors/getErrorMessage.ts","../src/errors/BeraError.ts","../src/errors/parseViemError.ts","../src/abi/utils/bundler3errors.ts","../src/abi/utils/erc20errors.ts","../src/abi/utils/openChainErrors.ts","../src/abi/utils/commonAbiErrors.ts","../src/errors/RequestError.ts","../src/errors/InvalidArgumentError.ts"],"sourcesContent":["export interface ErrorType {\n /**\n * Keywords to match in the error message. Use carefully. Do not use this for contract revert reasons\n * as they might match to other error messages.\n *\n * For instance InsufficientBalance might match to InsufficientBalanceToPayPythFee if used as keyword.\n */\n keywords?: string[];\n /**\n * The exact error code or contract revert reason.\n */\n reasons?: string[];\n errorMSG: string;\n}\n\nexport interface ErrorCategory {\n [key: string]: ErrorType;\n}\n\ninterface ErrorMessages {\n [key: string]: ErrorCategory | string;\n}\n\nexport const GENERAL_ERROR = \"Something went wrong. Please try again later.\";\n\nexport const errorMsgMap = {\n ERC20: {\n NOT_ENOUGH_BALANCE: {\n reasons: [\"NotEnoughBalance\"],\n errorMSG: \"You do not have enough balance to perform this action.\",\n },\n InsufficientBalance: {\n reasons: [\"InsufficientBalance\"],\n errorMSG: \"Insufficient token balance\",\n },\n INSUFFICIENT_ALLOWANCE: {\n reasons: [\n \"0x13be252b\",\n \"InsufficientAllowance\",\n \"ERC20InsufficientAllowance\",\n ],\n errorMSG: \"You do not have enough allowance to perform this action.\",\n },\n SIGNATURE_EXPIRED: {\n reasons: [\"SignatureExpired\"],\n errorMSG: \"Transaction took too long to complete. Please try again.\",\n },\n },\n HTTP: {\n RATE_LIMITED_429: {\n reasons: [\"429\"],\n errorMSG: \"Too many requests. Please try again later.\",\n },\n },\n ENSO: {\n COULD_NOT_BUILD_SHORTCUT: {\n keywords: [\n \"Could not build shortcuts for route\",\n \"Could not quote shortcuts for route\",\n ],\n\n errorMSG:\n \"There was an error building the zap route. Try with lower amounts.\",\n },\n NOT_ENOUGH_LIQUIDITY: {\n keywords: [\n \"Swap not found for a required underlying of defi route, please make sure your amountIn is within an acceptable range\",\n ],\n\n errorMSG:\n \"The amount you’re trying to swap might be too high. Please make sure that your amount is within an acceptable range.\",\n },\n NO_ROUTE_FOUND: {\n keywords: [\"No route found from\"],\n errorMSG: \"No swap route found for the given tokens.\",\n },\n },\n RPC: {\n INSUFFICIENT_FUNDS: {\n reasons: [\"InsufficientFundsError\"],\n keywords: [\n \"The total cost (gas * gas fee + value) of executing this transaction exceeds the balance of the account.\",\n ],\n errorMSG: \"Insufficient BERA balance to perform this action.\",\n },\n GAS_PRICE: {\n keywords: [\"gasLimit\"],\n errorMSG:\n \"It seems an RPC error has occurred while estimating gas. Please try your request later.\",\n },\n JSON_RPC: {\n keywords: [\"JSON-RPC\"],\n\n errorMSG:\n \"It seems an RPC error has occurred. Please try your request one more later.\",\n },\n NOT_ENOUGH_GAS: {\n keywords: [\"insufficient funds for gas * price + value:\"],\n errorMSG: \"Gas balance is insufficient to cover the transaction cost.\",\n },\n HASH: {\n keywords: [\"hash\"],\n\n errorMSG:\n \"It seems an RPC error has occurred. Please check if your transaction was finalized. If not, please try again.\",\n },\n USER_REJECTION: {\n reasons: [\"UserRejectedRequestError\"],\n keywords: [\"User denied transaction signature\"],\n errorMSG: \"You rejected the transaction.\",\n },\n SMART_UPGRADE_REJECTION: {\n reasons: [\"AtomicReadyWalletRejectedUpgradeError\"],\n errorMSG:\n \"You've declined to upgrade to batch transactions for now, try again for the traditional method.\",\n },\n CHAIN_MISMATCH: {\n reasons: [\"ChainMismatchError\"],\n errorMSG:\n \"Wallet seems to be on the wrong chain, please refresh the page and try again.\",\n },\n },\n EIP7702: {\n SESSION_KEY_EXPIRED: {\n reasons: [\"SessionKeyExpired\"],\n errorMSG: \"Session key has expired. Please create a new one.\",\n },\n CALL_POLICY_VIOLATED: {\n reasons: [\"CallPolicyViolated\"],\n errorMSG: \"Call policy violated. Please check your call policies.\",\n },\n },\n HONEY: {\n BLACKLISTED_WALLET: {\n reasons: [\"BlacklistedWallet\", \"0x265693b4\"],\n errorMSG: \"Your wallet is blacklisted from minting or redeeming HONEY.\",\n },\n LIQUIDITY_ERROR: {\n reasons: [\"0x4656425a\"],\n errorMSG:\n \"You are trying to redeem more than the liquidity available in the vault.\",\n },\n },\n // NOTE: these codes are from https://github.com/balancer/balancer-v2-monorepo/blob/master/pkg/balancer-js/src/utils/errors.ts\n // ... and additionally from https://docs.balancer.fi/reference/contracts/error-codes.html\n // NOTE: descriptions are generated by GPT where not available.\n BEX: {\n SLIPPAGE_EXCEEDED: {\n reasons: [\"SlippageExceeded\", \"TooMuchSlippage\"],\n errorMSG:\n \"Price changed while executing the transaction and exceeded the allowed slippage.\",\n },\n // math\n BAL000: {\n reasons: [\"BAL#000\"],\n errorMSG: \"Addition overflow occurred during calculation. (BEX#000)\",\n },\n BAL001: {\n reasons: [\"BAL#001\"],\n errorMSG: \"Subtraction overflow occurred during calculation. (BEX#001)\",\n },\n BAL002: {\n reasons: [\"BAL#002\"],\n errorMSG: \"Subtraction underflow occurred during calculation. (BEX#002)\",\n },\n BAL003: {\n reasons: [\"BAL#003\"],\n errorMSG:\n \"Multiplication overflow occurred during calculation. (BEX#003)\",\n },\n BAL004: {\n reasons: [\"BAL#004\"],\n errorMSG: \"Attempted division by zero. (BEX#004)\",\n },\n BAL005: {\n reasons: [\"BAL#005\"],\n errorMSG: \"Multiplication overflow during FixedPoint Division. (BEX#005)\",\n },\n BAL006: {\n reasons: [\"BAL#006\"],\n errorMSG: \"Invalid x in ExpMath.pow(x, y). (BEX#006)\",\n },\n BAL007: {\n reasons: [\"BAL#007\"],\n errorMSG: \"Invalid y in ExpMath.pow(x, y). (BEX#007)\",\n },\n BAL008: {\n reasons: [\"BAL#008\"],\n errorMSG:\n \"In LogExpMath.pow(x, y), error computing x^y as exp(y * ln(x)). (BEX#008)\",\n },\n BAL009: {\n reasons: [\"BAL#009\"],\n errorMSG: \"In LogExpMath.exp(x) = e^x; x out of bounds. (BEX#009)\",\n },\n // Input\n BAL100: {\n reasons: [\"BAL#100\"],\n errorMSG: \"Value is out of acceptable bounds. (BEX#100)\",\n },\n BAL101: {\n reasons: [\"BAL#101\"],\n errorMSG:\n \"Tokens must be sorted in address order on pool registration. (BEX#101)\",\n },\n BAL102: {\n reasons: [\"BAL#102\"],\n errorMSG:\n \"Tokens must be sorted in address order on pool registration. (BEX#102)\",\n },\n BAL103: {\n reasons: [\"BAL#103\"],\n errorMSG: \"Parallel array inputs must have the same length. (BEX#103)\",\n },\n BAL104: {\n reasons: [\"BAL#104\"],\n errorMSG: \"Address to be interpreted as a token cannot be 0. (BEX#104)\",\n },\n BAL105: {\n reasons: [\"BAL#105\"],\n errorMSG: \"Insufficient byte length. (BEX#105)\",\n },\n // Shared Pools\n BAL200: {\n reasons: [\"BAL#200\"],\n errorMSG: \"All pools must contain at least two tokens. (BEX#200)\",\n },\n BAL201: {\n reasons: [\"BAL#201\"],\n errorMSG:\n \"Token count exceeds the maximum for a given pool type. (BEX#201)\",\n },\n BAL202: {\n reasons: [\"BAL#202\"],\n errorMSG: \"Swap fee percentage exceeds the maximum allowed. (BEX#202)\",\n },\n BAL203: {\n reasons: [\"BAL#203\"],\n errorMSG: \"Swap fee percentage is below the minimum allowed. (BEX#203)\",\n },\n BAL204: {\n reasons: [\"BAL#204\"],\n errorMSG:\n \"Pool initialization failed: a small amount of BPT is minted to the zero address to maintain mathematical consistency. If initial balances are too low, the initialization process may fail. (BEX#204)\",\n },\n BAL205: {\n reasons: [\"BAL#205\"],\n errorMSG:\n \"User attempted to execute a callback intended for the vault contract. (BEX#205)\",\n },\n BAL206: {\n reasons: [\"BAL#206\"],\n errorMSG:\n \"Pools must be initialized with a special 'Init' join, before they can be joined by LPs. (BEX#206)\",\n },\n BAL207: {\n reasons: [\"BAL#207\"],\n errorMSG:\n \"Slippage/front-running protection check failed on a pool exit. (BEX#207)\",\n },\n BAL208: {\n reasons: [\"BAL#208\"],\n errorMSG: \"Minimum BPT output amount not met. (BEX#208)\",\n },\n BAL209: {\n reasons: [\"BAL#209\"],\n errorMSG:\n \"Slippage/front-running protection check failed on a pool join. (BEX#209)\",\n },\n BAL210: {\n reasons: [\"BAL#210\"],\n errorMSG:\n \"Pools with oracles are limited to two tokens. A pool with the TWO_TOKEN specialization must have exactly two tokens. (BEX#210)\",\n },\n BAL211: {\n reasons: [\"BAL#211\"],\n errorMSG:\n \"The pool factory is disabled and new pools cannot be created at this time. (BEX#211)\",\n },\n // Pools\n BAL300: {\n reasons: [\"BAL#300\"],\n errorMSG:\n \"The amplification parameter is below the minimum allowed. (BEX#300)\",\n },\n BAL301: {\n reasons: [\"BAL#301\"],\n errorMSG:\n \"The amplification parameter exceeds the maximum allowed. (BEX#301)\",\n },\n BAL302: {\n reasons: [\"BAL#302\"],\n errorMSG: \"The weight parameter is below the minimum allowed. (BEX#302)\",\n },\n BAL303: {\n reasons: [\"BAL#303\"],\n errorMSG:\n \"The number of stable tokens exceeds the maximum allowed. (BEX#303)\",\n },\n BAL304: {\n reasons: [\"BAL#304\"],\n errorMSG: \"The amount of tokens in would unbalance the pool. (BEX#304)\",\n },\n BAL305: {\n reasons: [\"BAL#305\"],\n errorMSG: \"The amount of tokens out would unbalance the pool. (BEX#305)\",\n },\n BAL306: {\n reasons: [\"BAL#306\"],\n errorMSG:\n \"Disproportionate pool exit would unbalance the pool. (BEX#306)\",\n },\n BAL307: {\n reasons: [\"BAL#307\"],\n errorMSG:\n \"Disproportionate pool join would unbalance the pool. (BEX#307)\",\n },\n BAL308: {\n reasons: [\"BAL#308\"],\n errorMSG: \"Normalized weights do not add to 1.0 exactly. (BEX#308)\",\n },\n BAL309: {\n reasons: [\"BAL#309\"],\n errorMSG: \"Invalid token provided for operation. (BEX#309)\",\n },\n BAL310: {\n reasons: [\"BAL#310\"],\n errorMSG: \"Unhandled pool join operation for this pool type. (BEX#310)\",\n },\n BAL311: {\n reasons: [\"BAL#311\"],\n errorMSG: \"Pool balances must be > 0. (BEX#311)\",\n },\n BAL312: {\n reasons: [\"BAL#312\"],\n errorMSG:\n \"Invalid query for oracle data ('ago' timestamp was not in the past). (BEX#312)\",\n },\n BAL313: {\n reasons: [\"BAL#313\"],\n errorMSG: \"Oracle has no data to query. (BEX#313)\",\n },\n BAL314: {\n reasons: [\"BAL#314\"],\n errorMSG:\n \"Oracle query data is before its earliest data sample. (BEX#314)\",\n },\n BAL315: {\n reasons: [\"BAL#315\"],\n errorMSG:\n \"Cannot query an oracle sample outside the buffer of 1024. (BEX#315)\",\n },\n BAL316: {\n reasons: [\"BAL#316\"],\n errorMSG: \"Oracle query window must have non-zero duration. (BEX#316)\",\n },\n BAL317: {\n reasons: [\"BAL#317\"],\n errorMSG:\n \"Amplification parameter change has less than the minimum duration. (BEX#317)\",\n },\n BAL318: {\n reasons: [\"BAL#318\"],\n errorMSG:\n \"Cannot start an amplification parameter update if one is already ongoing. (BEX#318)\",\n },\n BAL319: {\n reasons: [\"BAL#319\"],\n errorMSG:\n \"The requested amplification parameter change is too fast (cannot halve or double over less than a day). (BEX#319)\",\n },\n BAL320: {\n reasons: [\"BAL#320\"],\n errorMSG:\n \"Cannot cancel an update if there isn't one already ongoing. (BEX#320)\",\n },\n BAL321: {\n reasons: [\"BAL#321\"],\n errorMSG: \"Stable pool invariant calculation did not converge. (BEX#321)\",\n },\n BAL322: {\n reasons: [\"BAL#322\"],\n errorMSG: \"Stable pool balance calculation did not converge. (BEX#322)\",\n },\n BAL323: {\n reasons: [\"BAL#323\"],\n errorMSG: \"Relayer must be a valid contract. (BEX#323)\",\n },\n BAL324: {\n reasons: [\"BAL#324\"],\n errorMSG: \"Base pool relayer was not called correctly. (BEX#324)\",\n },\n BAL325: {\n reasons: [\"BAL#325\"],\n errorMSG:\n \"Rebalancing relayer operation re-entered unexpectedly. (BEX#325)\",\n },\n BAL326: {\n reasons: [\"BAL#326\"],\n errorMSG:\n \"Detected time travel in gradual updates (start > end time in a gradual weights update). (BEX#326)\",\n },\n BAL327: {\n reasons: [\"BAL#327\"],\n errorMSG: \"Swaps are disabled for this pool. (BEX#327)\",\n },\n BAL328: {\n reasons: [\"BAL#328\"],\n errorMSG: \"Caller is not the owner of the LBP. (BEX#328)\",\n },\n BAL329: {\n reasons: [\"BAL#329\"],\n errorMSG:\n \"Rate returned from a rateProvider must fit within 128 bits. (BEX#329)\",\n },\n BAL330: {\n reasons: [\"BAL#330\"],\n errorMSG:\n \"Investment pools only allow proportional joins and exits when swaps are disabled (to prevent unbalancing the pool). (BEX#330)\",\n },\n BAL331: {\n reasons: [\"BAL#331\"],\n errorMSG:\n \"Gradual weight update duration too short (minimum 1 day). (BEX#331)\",\n },\n BAL332: {\n reasons: [\"BAL#332\"],\n errorMSG: \"Invalid Linear Pool operating range. (BEX#332)\",\n },\n BAL333: {\n reasons: [\"BAL#333\"],\n errorMSG: \"Linear Pool max balance must fit in 112 bits. (BEX#333)\",\n },\n BAL334: {\n reasons: [\"BAL#334\"],\n errorMSG:\n \"Unhandled pool join/exit operation for linear pool type. (BEX#334)\",\n },\n BAL335: {\n reasons: [\"BAL#335\"],\n errorMSG:\n \"Cannot reset Linear Pool targets if pool is unbalanced. (BEX#335)\",\n },\n BAL336: {\n reasons: [\"BAL#336\"],\n errorMSG: \"Unhandled pool exit operation for this pool type. (BEX#336)\",\n },\n BAL337: {\n reasons: [\"BAL#337\"],\n errorMSG:\n \"Management fees can only be collected by the pool owner. (BEX#337)\",\n },\n BAL338: {\n reasons: [\"BAL#338\"],\n errorMSG:\n \"Management swap fee percentage exceeded the maximum. (BEX#338)\",\n },\n BAL339: {\n reasons: [\"BAL#339\"],\n errorMSG:\n \"Unhandled pool join/exit operation for managed pool type. (BEX#339)\",\n },\n BAL340: {\n reasons: [\"BAL#340\"],\n errorMSG:\n \"Unhandled pool join/exit operation for phantom pool type. (BEX#340)\",\n },\n BAL341: {\n reasons: [\"BAL#341\"],\n errorMSG: \"Token does not have a valid rate provider. (BEX#341)\",\n },\n BAL342: {\n reasons: [\"BAL#342\"],\n errorMSG: \"Invalid pool initialization parameters provided. (BEX#342)\",\n },\n BAL343: {\n reasons: [\"BAL#343\"],\n errorMSG:\n \"Value is out of the new target range for the operation. (BEX#343)\",\n },\n BAL344: {\n reasons: [\"BAL#344\"],\n errorMSG: \"This feature is currently disabled. (BEX#344)\",\n },\n BAL345: {\n reasons: [\"BAL#345\"],\n errorMSG: \"The pool controller is uninitialized. (BEX#345)\",\n },\n BAL346: {\n reasons: [\"BAL#346\"],\n errorMSG: \"Cannot set swap fee during an ongoing fee change. (BEX#346)\",\n },\n BAL347: {\n reasons: [\"BAL#347\"],\n errorMSG: \"Cannot set swap fee during pending fee changes. (BEX#347)\",\n },\n BAL348: {\n reasons: [\"BAL#348\"],\n errorMSG: \"Cannot change tokens during a weight change. (BEX#348)\",\n },\n BAL349: {\n reasons: [\"BAL#349\"],\n errorMSG: \"Cannot change tokens during pending weight changes. (BEX#349)\",\n },\n BAL350: {\n reasons: [\"BAL#350\"],\n errorMSG: \"Weight parameter exceeds the maximum allowed. (BEX#350)\",\n },\n BAL351: {\n reasons: [\"BAL#351\"],\n errorMSG: \"Unauthorized join operation. (BEX#351)\",\n },\n BAL352: {\n reasons: [\"BAL#352\"],\n errorMSG:\n \"Management AUM fee percentage exceeded the maximum allowed. (BEX#352)\",\n },\n BAL353: {\n reasons: [\"BAL#353\"],\n errorMSG: \"Fractional target values are not supported. (BEX#353)\",\n },\n BAL354: {\n reasons: [\"BAL#354\"],\n errorMSG:\n \"Adding or removing BPT is not allowed in this context. (BEX#354)\",\n },\n BAL355: {\n reasons: [\"BAL#355\"],\n errorMSG: \"Invalid circuit breaker bounds configuration. (BEX#355)\",\n },\n BAL356: {\n reasons: [\"BAL#356\"],\n errorMSG: \"The circuit breaker has been triggered. (BEX#356)\",\n },\n BAL357: {\n reasons: [\"BAL#357\"],\n errorMSG: \"Malicious query detected and reverted. (BEX#357)\",\n },\n BAL358: {\n reasons: [\"BAL#358\"],\n errorMSG:\n \"Joins and exits are currently disabled for this pool. (BEX#358)\",\n },\n // Lib\n BAL400: {\n reasons: [\"BAL#400\"],\n errorMSG: \"Reentrancy detected. (BEX#400)\",\n },\n BAL401: {\n reasons: [\"BAL#401\"],\n errorMSG: \"The sender is not allowed to perform this action. (BEX#401)\",\n },\n BAL402: {\n reasons: [\"BAL#402\"],\n errorMSG: \"The contract is currently paused. (BEX#402)\",\n },\n BAL403: {\n reasons: [\"BAL#403\"],\n errorMSG: \"The pause window has expired. (BEX#403)\",\n },\n BAL404: {\n reasons: [\"BAL#404\"],\n errorMSG:\n \"The maximum pause window duration has been exceeded. (BEX#404)\",\n },\n BAL405: {\n reasons: [\"BAL#405\"],\n errorMSG:\n \"The maximum buffer period duration has been exceeded. (BEX#405)\",\n },\n BAL406: {\n reasons: [\"BAL#406\"],\n errorMSG: \"The account has insufficient balance. (BEX#406)\",\n },\n BAL407: {\n reasons: [\"BAL#407\"],\n errorMSG: \"The account has insufficient allowance. (BEX#407)\",\n },\n BAL408: {\n reasons: [\"BAL#408\"],\n errorMSG: \"ERC20: Transfer from zero address. (BEX#408)\",\n },\n BAL409: {\n reasons: [\"BAL#409\"],\n errorMSG: \"ERC20: Transfer to zero address. (BEX#409)\",\n },\n BAL410: {\n reasons: [\"BAL#410\"],\n errorMSG: \"ERC20: Mint to zero address. (BEX#410)\",\n },\n BAL411: {\n reasons: [\"BAL#411\"],\n errorMSG: \"ERC20: Burn from zero address. (BEX#411)\",\n },\n BAL412: {\n reasons: [\"BAL#412\"],\n errorMSG: \"ERC20: Approve from zero address. (BEX#412)\",\n },\n BAL413: {\n reasons: [\"BAL#413\"],\n errorMSG: \"ERC20: Approve to zero address. (BEX#413)\",\n },\n BAL414: {\n reasons: [\"BAL#414\"],\n errorMSG: \"ERC20: Transfer exceeds allowance. (BEX#414)\",\n },\n BAL415: {\n reasons: [\"BAL#415\"],\n errorMSG: \"ERC20: Decreased allowance below zero. (BEX#415)\",\n },\n BAL416: {\n reasons: [\"BAL#416\"],\n errorMSG: \"ERC20: Transfer exceeds balance. (BEX#416)\",\n },\n BAL417: {\n reasons: [\"BAL#417\"],\n errorMSG: \"ERC20: Burn exceeds allowance. (BEX#417)\",\n },\n BAL418: {\n reasons: [\"BAL#418\"],\n errorMSG: \"SafeERC20: Call failed. (BEX#418)\",\n },\n BAL419: {\n reasons: [\"BAL#419\"],\n errorMSG: \"Address has insufficient balance. (BEX#419)\",\n },\n BAL420: {\n reasons: [\"BAL#420\"],\n errorMSG: \"Address cannot send value. (BEX#420)\",\n },\n BAL421: {\n reasons: [\"BAL#421\"],\n errorMSG: \"SafeCast: Value cannot fit into int256. (BEX#421)\",\n },\n BAL422: {\n reasons: [\"BAL#422\"],\n errorMSG: \"AccessControl: Grant sender is not an admin. (BEX#422)\",\n },\n BAL423: {\n reasons: [\"BAL#423\"],\n errorMSG: \"AccessControl: Revoke sender is not an admin. (BEX#423)\",\n },\n BAL424: {\n reasons: [\"BAL#424\"],\n errorMSG:\n \"AccessControl: Renounce sender not allowed for accounts other than self. (BEX#424)\",\n },\n BAL425: {\n reasons: [\"BAL#425\"],\n errorMSG: \"Buffer period has expired. (BEX#425)\",\n },\n BAL426: {\n reasons: [\"BAL#426\"],\n errorMSG: \"Caller is not the owner. (BEX#426)\",\n },\n BAL427: {\n reasons: [\"BAL#427\"],\n errorMSG: \"New owner cannot be zero address. (BEX#427)\",\n },\n BAL428: {\n reasons: [\"BAL#428\"],\n errorMSG: \"Code deployment failed. (BEX#428)\",\n },\n BAL429: {\n reasons: [\"BAL#429\"],\n errorMSG: \"Call to non-contract address. (BEX#429)\",\n },\n BAL430: {\n reasons: [\"BAL#430\"],\n errorMSG: \"Low-level call failed. (BEX#430)\",\n },\n BAL431: {\n reasons: [\"BAL#431\"],\n errorMSG: \"The contract is not paused. (BEX#431)\",\n },\n BAL432: {\n reasons: [\"BAL#432\"],\n errorMSG: \"Address is already allowlisted. (BEX#432)\",\n },\n BAL433: {\n reasons: [\"BAL#433\"],\n errorMSG: \"Address is not allowlisted. (BEX#433)\",\n },\n BAL434: {\n reasons: [\"BAL#434\"],\n errorMSG: \"ERC20: Burn exceeds balance. (BEX#434)\",\n },\n BAL435: {\n reasons: [\"BAL#435\"],\n errorMSG: \"Invalid operation. (BEX#435)\",\n },\n BAL436: {\n reasons: [\"BAL#436\"],\n errorMSG: \"Codec overflow detected. (BEX#436)\",\n },\n BAL437: {\n reasons: [\"BAL#437\"],\n errorMSG: \"The system is in recovery mode. (BEX#437)\",\n },\n BAL438: {\n reasons: [\"BAL#438\"],\n errorMSG: \"The system is not in recovery mode. (BEX#438)\",\n },\n BAL439: {\n reasons: [\"BAL#439\"],\n errorMSG: \"Induced failure. (BEX#439)\",\n },\n BAL440: {\n reasons: [\"BAL#440\"],\n errorMSG: \"Expired signature. (BEX#440)\",\n },\n BAL441: {\n reasons: [\"BAL#441\"],\n errorMSG: \"Malformed signature. (BEX#441)\",\n },\n BAL442: {\n reasons: [\"BAL#442\"],\n errorMSG: \"SafeCast: Value cannot fit into uint64. (BEX#442)\",\n },\n BAL443: {\n reasons: [\"BAL#443\"],\n errorMSG: \"Unhandled fee type. (BEX#443)\",\n },\n BAL444: {\n reasons: [\"BAL#444\"],\n errorMSG: \"ERC20: Burn from zero address. (BEX#444)\",\n },\n // Vault\n BAL500: {\n reasons: [\"BAL#500\"],\n errorMSG: \"Invalid pool ID. (BEX#500)\",\n },\n BAL501: {\n reasons: [\"BAL#501\"],\n errorMSG: \"Caller is not the pool. (BEX#501)\",\n },\n BAL502: {\n reasons: [\"BAL#502\"],\n errorMSG: \"Sender is not the asset manager. (BEX#502)\",\n },\n BAL503: {\n reasons: [\"BAL#503\"],\n errorMSG: \"User does not allow the relayer. (BEX#503)\",\n },\n BAL504: {\n reasons: [\"BAL#504\"],\n errorMSG: \"Invalid signature. (BEX#504)\",\n },\n BAL505: {\n reasons: [\"BAL#505\"],\n errorMSG: \"Exit would yield fewer than the minimum tokens out. (BEX#505)\",\n },\n BAL506: {\n reasons: [\"BAL#506\"],\n errorMSG: \"Join would cost more than the maximum tokens in. (BEX#506)\",\n },\n BAL507: {\n reasons: [\"BAL#507\"],\n errorMSG: \"Swap violates user-supplied limits. (BEX#507)\",\n },\n BAL508: {\n reasons: [\"BAL#508\"],\n errorMSG: \"Swap transaction not mined within the deadline. (BEX#508)\",\n },\n BAL509: {\n reasons: [\"BAL#509\"],\n errorMSG: \"Cannot swap the same token. (BEX#509)\",\n },\n BAL510: {\n reasons: [\"BAL#510\"],\n errorMSG: \"Unknown amount in the first swap of a batch. (BEX#510)\",\n },\n BAL511: {\n reasons: [\"BAL#511\"],\n errorMSG: \"Malconstructed multihop swap. (BEX#511)\",\n },\n BAL512: {\n reasons: [\"BAL#512\"],\n errorMSG: \"Internal balance overflow. (BEX#512)\",\n },\n BAL513: {\n reasons: [\"BAL#513\"],\n errorMSG: \"Insufficient internal balance. (BEX#513)\",\n },\n BAL514: {\n reasons: [\"BAL#514\"],\n errorMSG: \"Invalid BERA internal balance. (BEX#514)\",\n },\n BAL515: {\n reasons: [\"BAL#515\"],\n errorMSG:\n \"Flashloan must repay the loan in the same transaction. (BEX#515)\",\n },\n BAL516: {\n reasons: [\"BAL#516\"],\n errorMSG: \"Insufficient BERA balance. (BEX#516)\",\n },\n BAL517: {\n reasons: [\"BAL#517\"],\n errorMSG: \"Unallocated BERA. (BEX#517)\",\n },\n BAL518: {\n reasons: [\"BAL#518\"],\n errorMSG:\n \"Relayers cannot receive BERA directly (only through the Vault). (BEX#518)\",\n },\n BAL519: {\n reasons: [\"BAL#519\"],\n errorMSG: \"Cannot use BERA sentinel for internal balance. (BEX#519)\",\n },\n BAL520: {\n reasons: [\"BAL#520\"],\n errorMSG: \"Tokens mismatch. (BEX#520)\",\n },\n BAL521: {\n reasons: [\"BAL#521\"],\n errorMSG: \"Token is not registered. (BEX#521)\",\n },\n BAL522: {\n reasons: [\"BAL#522\"],\n errorMSG: \"Token is already registered. (BEX#522)\",\n },\n BAL523: {\n reasons: [\"BAL#523\"],\n errorMSG: \"Tokens are already set. (BEX#523)\",\n },\n BAL524: {\n reasons: [\"BAL#524\"],\n errorMSG: \"Tokens length must be 2. (BEX#524)\",\n },\n BAL525: {\n reasons: [\"BAL#525\"],\n errorMSG: \"Nonzero token balance detected. (BEX#525)\",\n },\n BAL526: {\n reasons: [\"BAL#526\"],\n errorMSG: \"Balance total overflow detected. (BEX#526)\",\n },\n BAL527: {\n reasons: [\"BAL#527\"],\n errorMSG: \"Pool has no tokens. (BEX#527)\",\n },\n BAL528: {\n reasons: [\"BAL#528\"],\n errorMSG: \"Insufficient flash loan balance. (BEX#528)\",\n },\n // Fees\n BAL600: {\n reasons: [\"BAL#600\"],\n errorMSG: \"Swap fee percentage is too high. (BEX#600)\",\n },\n BAL601: {\n reasons: [\"BAL#601\"],\n errorMSG: \"Flash loan fee percentage is too high. (BEX#601)\",\n },\n BAL602: {\n reasons: [\"BAL#602\"],\n errorMSG: \"Insufficient flash loan fee amount. (BEX#602)\",\n },\n // FeeSplitter\n BAL700: {\n reasons: [\"BAL#700\"],\n errorMSG: \"Splitter fee percentage is too high. (BEX#700)\",\n },\n // Misc\n BAL998: {\n reasons: [\"BAL#998\"],\n errorMSG: \"Unimplemented functionality. (BEX#998)\",\n },\n BAL999: {\n reasons: [\"BAL#999\"],\n errorMSG: \"An unexpected error occurred. (BEX#999)\",\n },\n // SoR swap paths\n NO_SWAP_PATHS: {\n keywords: [\"No swap paths returned\"],\n errorMSG: \"No swap paths were found.\",\n },\n },\n AGGREGATOR: {\n NOT_ENOUGH_LIQUIDITY: {\n keywords: [\"Not enough liquidity\"],\n errorMSG: \"Not enough liquidity. Try a lower amount.\",\n },\n },\n POL: {\n REWARD_VAULT_FACTORY: {\n reasons: [\"VaultAlreadyExists\"],\n errorMSG:\n \"Failed to create action. An action already exists with this staking token.\",\n },\n NOT_REWARD_VAULT_MANAGER: {\n reasons: [\"NotRewardVaultManager\"],\n errorMSG: \"You are not the manager of this action.\",\n },\n NOT_INCENTIVE_MANAGER: {\n reasons: [\"NotIncentiveManager\"],\n errorMSG: \"You are not the incentive manager of this token.\",\n },\n DURATION_CHANGE_NOT_ALLOWED: {\n reasons: [\"DurationChangeNotAllowed\"],\n errorMSG: \"You cannot change the duration of this action.\",\n },\n INVALID_PROOF: {\n reasons: [\"InvalidProof\"],\n errorMSG: \"Tokens already claimed or invalid proof.\",\n },\n CONTRACT_PAUSED: {\n reasons: [\"EnforcedPause\"],\n errorMSG: \"The contract you're interacting with is temporarily paused.\",\n },\n DISTRIBUTION_PAUSED: {\n reasons: [\"DistributionEnforcedPause\"],\n errorMSG: \"Distribution is temporarily paused.\",\n },\n INVALID_VALIDATOR_COMMISSION: {\n reasons: [\"InvalidCommissionValue\"],\n errorMSG: \"Invalid commission percentage.\",\n },\n NOT_REWARD_ALLOCATOR: {\n reasons: [\"NotRewardAllocator\"],\n errorMSG: \"You are not the reward allocator of this validator.\",\n },\n NOT_OPERATOR: {\n reasons: [\"NotOperator\"],\n errorMSG: \"You are not the operator of this validator.\",\n },\n INVALID_REWARD_ALLOCATION: {\n reasons: [\"InvalidRewardAllocationWeights\"],\n errorMSG: \"Invalid reward allocation weights.\",\n },\n NOT_REWARD_DURATION_MANAGER: {\n reasons: [\"NotRewardDurationManager\"],\n errorMSG: \"You are not the reward duration manager of this validator.\",\n },\n },\n BEND: {\n INSUFFICIENT_POSITION: {\n keywords: [\"insufficient position\"],\n errorMSG: \"Insufficient position\",\n },\n INSUFFICIENT_LIQUIDITY: {\n keywords: [\"insufficient liquidity on market\"],\n errorMSG: \"Insufficient liquidity on market.\",\n },\n ALL_CAPS_REACHED: {\n reasons: [\"AllCapsReached\"],\n errorMSG: \"All caps reached on vault.\",\n },\n AboveMaxTimelock: {\n reasons: [\"AboveMaxTimelock\"],\n errorMSG: \"Above max timelock\",\n },\n AddressEmptyCode: {\n reasons: [\"AddressEmptyCode\"],\n errorMSG: \"Address empty code\",\n },\n AddressInsufficientBalance: {\n reasons: [\"AddressInsufficientBalance\"],\n errorMSG: \"Address insufficient balance\",\n },\n AllCapsReached: {\n reasons: [\"AllCapsReached\"],\n errorMSG: \"All caps reached\",\n },\n AlreadyPending: {\n reasons: [\"AlreadyPending\"],\n errorMSG: \"Already pending\",\n },\n AlreadySet: {\n reasons: [\"AlreadySet\"],\n errorMSG: \"Already set\",\n },\n BelowMinTimelock: {\n reasons: [\"BelowMinTimelock\"],\n errorMSG: \"Below min timelock\",\n },\n DuplicateMarket: {\n reasons: [\"DuplicateMarket\"],\n errorMSG: \"Duplicate market\",\n },\n ECDSAInvalidSignature: {\n reasons: [\"ECDSAInvalidSignature\"],\n errorMSG: \"Invalid ECDSA signature\",\n },\n ECDSAInvalidSignatureLength: {\n reasons: [\"ECDSAInvalidSignatureLength\"],\n errorMSG: \"Invalid ECDSA signature length\",\n },\n ECDSAInvalidSignatureS: {\n reasons: [\"ECDSAInvalidSignatureS\"],\n errorMSG: \"Invalid ECDSA signature S value\",\n },\n ERC20InsufficientBalance: {\n reasons: [\"ERC20InsufficientBalance\"],\n errorMSG: \"ERC20 insufficient balance\",\n },\n ERC20InvalidApprover: {\n reasons: [\"ERC20InvalidApprover\"],\n errorMSG: \"ERC20 invalid approver\",\n },\n ERC20InvalidReceiver: {\n reasons: [\"ERC20InvalidReceiver\"],\n errorMSG: \"ERC20 invalid receiver\",\n },\n ERC20InvalidSender: {\n reasons: [\"ERC20InvalidSender\"],\n errorMSG: \"ERC20 invalid sender\",\n },\n ERC20InvalidSpender: {\n reasons: [\"ERC20InvalidSpender\"],\n errorMSG: \"ERC20 invalid spender\",\n },\n ERC2612ExpiredSignature: {\n reasons: [\"ERC2612ExpiredSignature\"],\n errorMSG: \"ERC2612 expired signature\",\n },\n ERC2612InvalidSigner: {\n reasons: [\"ERC2612InvalidSigner\"],\n errorMSG: \"ERC2612 invalid signer\",\n },\n ERC4626ExceededMaxDeposit: {\n reasons: [\"ERC4626ExceededMaxDeposit\"],\n errorMSG: \"ERC4626 exceeded max deposit\",\n },\n ERC4626ExceededMaxMint: {\n reasons: [\"ERC4626ExceededMaxMint\"],\n errorMSG: \"ERC4626 exceeded max mint\",\n },\n ERC4626ExceededMaxRedeem: {\n reasons: [\"ERC4626ExceededMaxRedeem\"],\n errorMSG: \"ERC4626 exceeded max redeem\",\n },\n ERC4626ExceededMaxWithdraw: {\n reasons: [\"ERC4626ExceededMaxWithdraw\"],\n errorMSG: \"ERC4626 exceeded max withdraw\",\n },\n FailedInnerCall: {\n reasons: [\"FailedInnerCall\"],\n errorMSG: \"Failed inner call\",\n },\n InconsistentAsset: {\n reasons: [\"InconsistentAsset\"],\n errorMSG: \"Inconsistent asset\",\n },\n InconsistentReallocation: {\n reasons: [\"InconsistentReallocation\"],\n errorMSG: \"Inconsistent reallocation\",\n },\n InvalidAccountNonce: {\n reasons: [\"InvalidAccountNonce\"],\n errorMSG: \"Invalid account nonce\",\n },\n InvalidMarketRemovalNonZeroCap: {\n reasons: [\"InvalidMarketRemovalNonZeroCap\"],\n errorMSG: \"Invalid market removal (non-zero cap)\",\n },\n InvalidMarketRemovalNonZeroSupply: {\n reasons: [\"InvalidMarketRemovalNonZeroSupply\"],\n errorMSG: \"Invalid market removal (non-zero supply)\",\n },\n InvalidMarketRemovalTimelockNotElapsed: {\n reasons: [\"InvalidMarketRemovalTimelockNotElapsed\"],\n errorMSG: \"Invalid market removal (timelock not elapsed)\",\n },\n InvalidShortString: {\n reasons: [\"InvalidShortString\"],\n errorMSG: \"Invalid short string\",\n },\n MarketNotCreated: {\n reasons: [\"MarketNotCreated\"],\n errorMSG: \"Market not created\",\n },\n MarketNotEnabled: {\n reasons: [\"MarketNotEnabled\"],\n errorMSG: \"Market not enabled\",\n },\n MathOverflowedMulDiv: {\n reasons: [\"MathOverflowedMulDiv\"],\n errorMSG: \"Math overflow\",\n },\n MaxFeeExceeded: {\n reasons: [\"MaxFeeExceeded\"],\n errorMSG: \"Max fee exceeded\",\n },\n MaxQueueLengthExceeded: {\n reasons: [\"MaxQueueLengthExceeded\"],\n errorMSG: \"Max queue length exceeded\",\n },\n NoPendingValue: {\n reasons: [\"NoPendingValue\"],\n errorMSG: \"No pending value\",\n },\n NonZeroCap: {\n reasons: [\"NonZeroCap\"],\n errorMSG: \"Non-zero cap\",\n },\n NotAllocatorRole: {\n reasons: [\"NotAllocatorRole\"],\n errorMSG: \"Not allocator role\",\n },\n NotCuratorNorGuardianRole: {\n reasons: [\"NotCuratorNorGuardianRole\"],\n errorMSG: \"Not curator or guardian role\",\n },\n NotCuratorRole: {\n reasons: [\"NotCuratorRole\"],\n errorMSG: \"Not curator role\",\n },\n NotEnoughLiquidity: {\n reasons: [\"NotEnoughLiquidity\"],\n errorMSG: \"Not enough liquidity\",\n },\n NotGuardianRole: {\n reasons: [\"NotGuardianRole\"],\n errorMSG: \"Not guardian role\",\n },\n OwnableInvalidOwner: {\n reasons: [\"OwnableInvalidOwner\"],\n errorMSG: \"Invalid owner\",\n },\n OwnableUnauthorizedAccount: {\n reasons: [\"OwnableUnauthorizedAccount\"],\n errorMSG: \"Unauthorized account\",\n },\n PendingCap: {\n reasons: [\"PendingCap\"],\n errorMSG: \"Pending cap\",\n },\n PendingRemoval: {\n reasons: [\"PendingRemoval\"],\n errorMSG: \"Pending removal\",\n },\n SafeCastOverflowedUintDowncast: {\n reasons: [\"SafeCastOverflowedUintDowncast\"],\n errorMSG: \"SafeCast overflow\",\n },\n SafeERC20FailedOperation: {\n reasons: [\"SafeERC20FailedOperation\"],\n errorMSG: \"SafeERC20 failed operation\",\n },\n StringTooLong: {\n reasons: [\"StringTooLong\"],\n errorMSG: \"String too long\",\n },\n SupplyCapExceeded: {\n reasons: [\"SupplyCapExceeded\"],\n errorMSG: \"Supply cap exceeded\",\n },\n TimelockNotElapsed: {\n reasons: [\"TimelockNotElapsed\"],\n errorMSG: \"Timelock not elapsed\",\n },\n UnauthorizedMarket: {\n reasons: [\"UnauthorizedMarket\"],\n errorMSG: \"Unauthorized market\",\n },\n ZeroAddress: {\n reasons: [\"ZeroAddress\"],\n errorMSG: \"Zero address\",\n },\n ZeroFeeRecipient: {\n reasons: [\"ZeroFeeRecipient\"],\n errorMSG: \"Zero fee recipient\",\n },\n },\n} as const satisfies ErrorMessages;\n","import { type ErrorCategory, errorMsgMap, GENERAL_ERROR } from \"./errorMap\";\n\n/**\n * Resolves a user-friendly displayMessage by matching `reason` and `message` against `errorMap.ts`.\n *\n * This is the bridge between the automatic reason detection pipeline (parseViemError) and\n * the user-facing error messages. Called by the BeraError constructor.\n *\n * ## Matching priority:\n * 1. **Exact reason match** (preferred): checks `errorType.reasons` for an exact string match.\n * This is the most reliable path — contract revert reasons like \"NotEnoughBalance\" or \"BAL#508\"\n * are matched deterministically.\n * 2. **Keyword fallback**: checks `errorType.keywords` for substring matches in `message`.\n * Use sparingly — keyword matching can cause false positives (e.g. \"InsufficientBalance\"\n * keyword would also match \"InsufficientBalanceToPayPythFee\").\n * 3. **GENERAL_ERROR fallback**: \"Something went wrong. Please try again later.\"\n *\n * To ensure new contract errors get good displayMessages, add their reason to `errorMap.ts`.\n * The reason is auto-detected by parseViemError — you only need to map it to a message here.\n */\nexport function getErrorMessage({\n reason,\n message,\n}: {\n reason?: string | null;\n message?: string;\n}): string {\n for (const category in errorMsgMap) {\n const categoryKey = category as keyof typeof errorMsgMap;\n const errors = errorMsgMap[categoryKey] as ErrorCategory;\n\n for (const type in errors) {\n const errorType = errors[type];\n\n // Priority 1: Exact reason match (deterministic, preferred for contract revert reasons)\n if (reason) {\n if (\n errorType?.reasons?.some((r) => {\n return r === reason;\n })\n ) {\n return errorType.errorMSG;\n }\n }\n\n // Priority 2: Keyword substring match on message (fallback, use carefully)\n if (\n errorType?.keywords?.some((keyword) => {\n return message?.includes(keyword.toLowerCase().trim());\n })\n ) {\n return errorType.errorMSG;\n }\n }\n }\n\n // Priority 3: No match found — return generic fallback\n return GENERAL_ERROR;\n}\n","import { type Abi, BaseError } from \"viem\";\n\nimport { appConfig } from \"@berachain/config/internal\";\n\nimport { GENERAL_ERROR } from \"./errorMap\";\nimport { getErrorMessage } from \"./getErrorMessage\";\nimport { parseViemError, rpcErrorToReason } from \"./parseViemError\";\nimport type { SeverityLevel } from \"./severity\";\n\nexport interface IBeraErrorArgs {\n message?: string;\n displayMessage?: string;\n cause?: unknown;\n reason?: string;\n chainId?: number;\n fingerprint?: string[];\n /**\n * The level of the error to be used for error reporting.\n */\n level?: SeverityLevel;\n tags?: {\n [key in TagsKey]?: Primitive;\n };\n extra?: Record<string, unknown>;\n /**\n * Optional ABI to be used to parse the error.\n */\n abi?: Abi;\n}\n\ntype Primitive = number | string | boolean | bigint | symbol | null | undefined;\n\n/**\n * An helper type to make sure we only use the allowed tags. Sync this with docs/errors.md\n */\ntype TagsKey =\n | \"wallet.chain\"\n | \"wallet.connector\"\n | \"wallet.address\"\n | \"error.reason\"\n | \"operation.type\"\n | \"operation.key\"\n | \"operation.txn.functionName\"\n | \"operation.txn.to\"\n | \"operation.txn.status\"\n | \"operation.source.url\"\n | \"operation.source.name\"\n | \"operation.source.queryName\"\n | \"operation.source.type\";\n\n/**\n * Base error class for the entire berajs SDK.\n *\n * All errors should be a BeraError or one of its subclasses. Unknown errors should be\n * normalized via `initBeraError({ cause })`.\n *\n * Key design: the constructor runs an **automatic reason detection pipeline** when `reason`\n * is not explicitly provided. It calls `parseViemError` on the `cause` to extract a\n * machine-readable reason code (e.g. \"NotEnoughBalance\", \"BAL#508\", \"UserRejectedRequestError\").\n * That reason is then matched against `errorMap.ts` to resolve a user-friendly `displayMessage`.\n *\n * This means: for most viem errors, you only need to pass `cause` and everything else\n * (reason, displayMessage, level) is derived automatically.\n *\n * @see parseViemError — the reason extraction engine\n * @see errorMap.ts — reason → displayMessage mapping\n * @see initBeraError — normalizes any error into a BeraError (preferred entry point)\n */\nexport class BeraError extends Error {\n /**\n * A human-readable message that can be displayed to end user.\n *\n * In berachain dapps, this is shown in the error pop-up.\n */\n displayMessage: string;\n\n /**\n * The cause of the error.\n *\n * This is typically the error that was thrown.\n */\n cause: unknown;\n\n /**\n * The chain id of the error.\n */\n chainId?: number;\n\n /**\n * The code for the reason for the error.\n *\n * This is typically the error code can be found in the errorMap.ts file. I.e. NotEnoughBalance or BAL#508\n */\n reason: string | null = null;\n\n /**\n * The fingerprint for the error.\n *\n * This is typically used to group errors in Sentry.\n */\n fingerprint: string[] | undefined;\n\n private _tags: {\n [key: string | TagsKey]: Primitive;\n } = {};\n\n set tags(tags: {\n [key: string | TagsKey]: Primitive;\n }) {\n this._tags = tags;\n }\n\n get tags(): {\n [key: string | TagsKey]: Primitive;\n } {\n return {\n ...this._tags,\n \"error.displayMessage\": this.displayMessage,\n \"error.reason\": this.reason,\n \"error.level\": this.level,\n };\n }\n\n level: SeverityLevel = \"error\";\n\n extra: Record<string, unknown> = {};\n\n constructor({\n message: m,\n displayMessage: dm,\n cause,\n reason,\n level,\n abi,\n tags,\n chainId,\n fingerprint,\n }: IBeraErrorArgs) {\n let message = m;\n\n if (!message) {\n if (cause instanceof BaseError) {\n // Using shortMesage as it doesn't include the payload.\n message = cause.shortMessage;\n } else if (cause instanceof Error) {\n message = cause.message;\n } else if (\n typeof cause === \"object\" &&\n cause !== null &&\n \"message\" in cause &&\n typeof cause.message === \"string\"\n ) {\n // this covers responses from HTTP requests\n message = cause.message;\n }\n }\n super(message, {\n cause,\n });\n\n this.name = \"BeraError\";\n\n this.fingerprint = fingerprint;\n\n this.cause = cause;\n\n this.chainId = chainId;\n\n // ── Automatic reason detection ──────────────────────────────────────\n // If `reason` was provided explicitly, use it directly.\n // Otherwise, attempt to extract it from the `cause` by unwrapping the viem error chain.\n // parseViemError walks nested errors (ContractFunctionExecutionError →\n // ContractFunctionRevertedError → RpcRequestError) and decodes revert data using ABI.\n // The extracted reason (e.g. \"NotEnoughBalance\", \"BAL#508\") is the key that drives\n // displayMessage resolution and Sentry fingerprinting.\n if (reason) {\n this.reason = reason;\n } else if (cause instanceof Error) {\n try {\n const parsed = parseViemError({\n error: cause,\n revertIfUnknown: true,\n abi,\n });\n\n this.reason = parsed?.reason ?? null;\n } catch {\n // parseViemError throws when it can't identify the error type and revertIfUnknown=true.\n // In that case, reason stays null and displayMessage falls back to GENERAL_ERROR.\n }\n }\n\n // ── Level inference ─────────────────────────────────────────────────\n // User rejections are \"info\" (not actionable by devs), everything else defaults to \"error\".\n if (level) {\n this.level = level;\n } else if (this.reason === rpcErrorToReason(\"UserRejectedRequestError\")) {\n this.level = \"info\";\n } else {\n this.level = \"error\";\n }\n\n // ── displayMessage resolution ─────────────────────────────────────────\n // Priority:\n // 1. Explicit `displayMessage` passed by caller\n // 2. Cascaded from a BeraError cause (if it has a non-generic message)\n // 3. Looked up from errorMap.ts using the detected `reason` and `message`\n // 4. GENERAL_ERROR fallback: \"Something went wrong. Please try again later.\"\n let displayMessage = dm;\n\n if (\n this.cause instanceof BeraError &&\n this.cause.displayMessage !== GENERAL_ERROR\n ) {\n // Cascade: inner BeraError already resolved a good displayMessage, reuse it\n displayMessage = this.cause.displayMessage;\n }\n\n if (!displayMessage) {\n // Match reason (exact) or message (keyword) against errorMap.ts\n displayMessage = getErrorMessage(this);\n }\n\n this.displayMessage = displayMessage ?? GENERAL_ERROR;\n\n this.tags = {\n ...this.tags,\n ...tags,\n };\n // Useful for debugging in development or on vercel preview links\n if (!appConfig.env.isProduction && process.env.NODE_ENV !== \"test\") {\n console.group(\"BeraError thrown\");\n console.debug(\"Level\", this.level);\n console.debug(\"Reason\", this.reason);\n console.debug(\"Message\", this.message);\n console.debug(\"Display Message\", this.displayMessage);\n console.debug(\"Cause\", this.cause);\n console.groupEnd();\n }\n }\n}\n","import {\n type Abi,\n AtomicReadyWalletRejectedUpgradeError,\n BaseError,\n ContractFunctionExecutionError,\n ContractFunctionRevertedError,\n type DecodeErrorResultReturnType,\n decodeErrorResult,\n HttpRequestError,\n type ProviderRpcErrorCode,\n RpcRequestError,\n TransactionExecutionError,\n UserRejectedRequestError,\n} from \"viem\";\n\nimport { commonAbiErrors } from \"~/abi/utils/commonAbiErrors\";\n\n/**\n * Duck-type check for viem's BaseError.\n *\n * We can't always rely on `instanceof BaseError` because viem errors may originate\n * from a different version of the `viem` package (e.g. in dependency tree mismatches).\n * The duck-type fallback checks for the structural shape that all viem errors share:\n * `shortMessage`, `message`, and `details`.\n */\nfunction isBaseError(error: unknown): error is BaseError {\n if (error instanceof BaseError) {\n return true;\n }\n\n if (\n error instanceof Error &&\n \"shortMessage\" in error &&\n \"message\" in error &&\n \"details\" in error\n ) {\n return true;\n }\n\n return false;\n}\n\n/**\n * Type-guard for specific viem error types.\n *\n * Uses both `instanceof` and `error.name` to handle cases where the error\n * was created by a different viem version (name-based fallback).\n */\nfunction isViemError<T extends Error>(\n error: Error,\n name: T[\"name\"],\n shouldBeInstanceOf: new (...args: any[]) => T,\n): error is T {\n if (error instanceof shouldBeInstanceOf) {\n return true;\n }\n\n if (error.name === name) {\n return true;\n }\n\n return false;\n}\n\n/**\n * Extracts a human-readable reason string from a decoded Solidity error.\n *\n * Solidity has two kinds of revert errors:\n * - `revert(\"some message\")` → decoded as `Error(string)` where the message is in `args[0]`.\n * In this case we return the string argument (e.g. `\"BAL#508\"`).\n * - `revert CustomError(...)` → decoded as `CustomError(...)` where `errorName` is the\n * custom error name. In this case we return `errorName` (e.g. `\"NotEnoughBalance\"`).\n *\n * The returned string is used as the `reason` field in BeraError and is matched against\n * `errorMap.ts` to resolve a user-friendly `displayMessage`.\n */\nexport function parseDecodedError<const abi extends Abi | readonly unknown[]>(\n error: DecodeErrorResultReturnType<abi>,\n): string | undefined {\n if (\n error.errorName === \"Error\" &&\n Array.isArray(error.args) &&\n error.args?.at(0)\n ) {\n // Solidity `revert(\"message\")` — the message string is the reason\n return error.args?.at(0) as string;\n }\n\n // Custom error `revert CustomError(...)` — the error name is the reason\n return error.errorName;\n}\n\n/**\n * The reason extraction engine — recursively unwraps viem error chains to extract\n * a machine-readable `reason` string.\n *\n * This function is the core of the automatic reason detection system. It is called by:\n * - `BeraError` constructor (when `reason` is not manually provided)\n * - `initBeraError` (to detect if the error is a RequestError)\n * - `getRevertReason` (after replaying a failed on-chain transaction)\n *\n * ## Viem error chain structure\n *\n * Viem errors are deeply nested. The typical chains look like:\n *\n * **From `simulateContract`:**\n * ```\n * ContractFunctionExecutionError ← wrapper, skipped\n * └── ContractFunctionRevertedError ← reason extracted here (cause.reason / cause.signature)\n * ```\n *\n * **From `publicClient.call` (raw call):**\n * ```\n * CallExecutionError ← wrapper, skipped\n * └── ExecutionRevertedError ← wrapper, skipped\n * └── RpcRequestError ← reason decoded from cause.data using ABI\n * ```\n *\n * **From `writeContract` / `sendTransaction`:**\n * ```\n * TransactionExecutionError ← checked for special wallet errors\n * └── UserRejectedRequestError ← \"UserRejectedRequestError\"\n * └── AtomicReadyWalletRejectedUpgradeError ← \"AtomicReadyWalletRejectedUpgradeError\"\n * ```\n *\n * **From RPC transport failures:**\n * ```\n * ContractFunctionExecutionError ← wrapper, skipped\n * └── HttpRequestError ← \"HttpRequestError(status:<code>)\", isRequestError=true\n * ```\n *\n * The function walks `cause.cause` in a while loop until it finds an error type it can\n * extract a reason from, or runs out of nested causes.\n *\n * ## Parameters\n *\n * @param error - Any Error instance (typically a viem BaseError).\n * @param abi - Optional contract ABI. Merged with `commonAbiErrors` to decode revert data.\n * Passing the correct ABI enables decoding custom error names (e.g. \"SlippageExceeded\")\n * instead of falling back to hex selectors (e.g. \"0xa3b1e29f\").\n * @param revertIfUnknown - If true, throws when the error doesn't match any known pattern.\n * The BeraError constructor calls with `true`; `initBeraError` calls with `false`.\n *\n * @returns `{ reason, rootCause, isRequestError? }` where:\n * - `reason` is the extracted error code/name (matched against errorMap.ts for displayMessage)\n * - `rootCause` is the deepest error in the chain that was identified\n * - `isRequestError` is true if the error is an HTTP/RPC transport failure\n */\nexport function parseViemError({\n error,\n abi,\n revertIfUnknown = true,\n}: {\n error: Error;\n abi?: Abi;\n revertIfUnknown: boolean;\n}): {\n reason: string | undefined;\n rootCause: unknown;\n isRequestError?: boolean;\n} {\n // If it's not a viem-shaped error, either rethrow or return the message as-is\n if (!isBaseError(error)) {\n if (revertIfUnknown) {\n throw error;\n }\n\n if (error instanceof BaseError) {\n return { reason: error.shortMessage, rootCause: error };\n }\n\n return { reason: error.message, rootCause: error };\n }\n\n // Begin unwrapping the nested error chain\n let cause: unknown = error;\n\n // Walk the nested viem error chain from outermost to innermost.\n // Each iteration checks for known error types and either extracts the reason or\n // skips the wrapper to go deeper into `cause.cause`.\n while (isBaseError(cause)) {\n // ── Step 1: Skip wrapper errors that don't carry reason data ────────────\n // ContractFunctionExecutionError is a top-level wrapper from simulateContract/writeContract.\n // The actual revert info is in its nested cause.\n if (\n isViemError(\n cause,\n \"ContractFunctionExecutionError\",\n ContractFunctionExecutionError,\n )\n ) {\n cause = cause.cause;\n continue;\n }\n\n // ── Step 2: Check for wallet-level errors ──────────────────────────────\n // TransactionExecutionError wraps errors from wallet interactions (sendTransaction).\n // Check for EIP-7702 smart wallet upgrade rejection specifically.\n if (\n isViemError(cause, \"TransactionExecutionError\", TransactionExecutionError)\n ) {\n if (cause.cause instanceof AtomicReadyWalletRejectedUpgradeError) {\n return {\n reason: \"AtomicReadyWalletRejectedUpgradeError\",\n rootCause: cause.cause,\n };\n }\n }\n\n // ── Step 3: RpcRequestError — from raw `publicClient.call` ─────────────\n // Error chain: CallExecutionError → ExecutionRevertedError → RpcRequestError\n // The revert data is in `cause.data` as raw hex bytes.\n // We decode it using the provided ABI + commonAbiErrors to get the error name.\n if (isViemError(cause, \"RpcRequestError\", RpcRequestError)) {\n if (!cause.data) {\n // No revert data available — check if there's a nested message (special RPC cases)\n if (\n typeof cause.cause === \"object\" &&\n cause.cause &&\n \"message\" in cause.cause &&\n typeof cause.cause.message === \"string\"\n ) {\n return { reason: cause.cause.message, rootCause: cause.cause };\n }\n\n throw new Error(\"No data\", { cause });\n }\n\n // Decode the raw revert bytes into a structured error using ABI.\n // commonAbiErrors includes Error(string) and Panic(uint256) so standard reverts\n // are always decodable even without a user-provided ABI.\n const decodedError = decodeErrorResult({\n data: cause.data as `0x${string}`,\n abi: [...commonAbiErrors, ...(abi ?? [])],\n });\n\n return {\n reason: parseDecodedError(decodedError) ?? cause.shortMessage,\n rootCause: cause,\n };\n }\n\n // ── Step 4: ContractFunctionRevertedError — from `simulateContract` ────\n // Error chain: ContractFunctionExecutionError → ContractFunctionRevertedError\n // Viem already decoded the revert using the ABI passed to simulateContract.\n // `cause.reason` is the decoded error name (e.g. \"NotEnoughBalance\").\n // `cause.signature` is the 4-byte selector fallback (e.g. \"0x13be252b\").\n // `cause.data?.errorName` is another fallback from the decoded data.\n if (\n isViemError(\n cause,\n \"ContractFunctionRevertedError\",\n ContractFunctionRevertedError,\n )\n ) {\n return {\n reason:\n cause.reason ??\n cause.signature ??\n cause.data?.errorName ??\n cause.shortMessage,\n rootCause: cause,\n };\n }\n\n // ── Step 5: UserRejectedRequestError — wallet popup dismissed ──────────\n // The user clicked \"Reject\" in their wallet. Level is set to \"info\" by BeraError constructor.\n if (\n isViemError(cause, \"UserRejectedRequestError\", UserRejectedRequestError)\n ) {\n return { reason: \"UserRejectedRequestError\", rootCause: cause };\n }\n\n // ── Step 6: HttpRequestError — RPC transport failure ───────────────────\n // The RPC endpoint returned an HTTP error (e.g. 502, 503).\n // Flagged as isRequestError so initBeraError can wrap it in a RequestError.\n if (isViemError(cause, \"HttpRequestError\", HttpRequestError)) {\n return {\n reason: `HttpRequestError(status:${cause.status})`,\n rootCause: cause,\n isRequestError: true,\n };\n }\n\n // ── Step 7: End of chain — no deeper cause to unwrap ───────────────────\n if (!cause.cause) {\n return { reason: cause.name, rootCause: cause };\n }\n\n // Keep unwrapping\n cause = cause.cause;\n }\n\n if (!revertIfUnknown) {\n return { reason: undefined, rootCause: cause };\n }\n\n // Cannot use BeraError here because of circular dependency\n throw new Error(\"UnknownErrorInGetRevertReason\", {\n cause: cause,\n });\n}\n\n/**\n * Returns the error code thrown by RpcError.\n *\n * @see {@link RpcError}\n * @param errCode - The error code to get the name for.\n * @returns The name of the error code.\n */\nexport function rpcErrorToReason(\n errCode:\n | number\n | ProviderRpcErrorCode\n // Here we add errors for which we know the code\n | \"UserRejectedRequestError\",\n): string {\n switch (errCode) {\n // Actually this should not get here if UserRejectedRequestError is thrown\n case \"UserRejectedRequestError\":\n case 4001:\n return \"UserRejectedRequestError\";\n default:\n return `RPC_ERROR_${errCode}`;\n }\n}\n","export const bundler3errorsAbi = [\n { inputs: [], name: \"AlreadyInitiated\", type: \"error\" },\n { inputs: [], name: \"EmptyBundle\", type: \"error\" },\n { inputs: [], name: \"IncorrectReenterHash\", type: \"error\" },\n { inputs: [], name: \"MissingExpectedReenter\", type: \"error\" },\n] as const;\n","/**\n * A list of ERC20 error codes according to eip-6093 and solady.\n *\n * This is needed since viem erc20Abi does not include error codes.\n */\nexport const erc20errorsAbi = [\n { inputs: [], name: \"AllowanceOverflow\", type: \"error\" },\n { inputs: [], name: \"AllowanceUnderflow\", type: \"error\" },\n { inputs: [], name: \"ETHTransferFailed\", type: \"error\" },\n { inputs: [], name: \"InsufficientAllowance\", type: \"error\" },\n { inputs: [], name: \"InsufficientBalance\", type: \"error\" },\n { inputs: [], name: \"InvalidPermit\", type: \"error\" },\n { inputs: [], name: \"Permit2AllowanceIsFixedAtInfinity\", type: \"error\" },\n { inputs: [], name: \"PermitExpired\", type: \"error\" },\n { inputs: [], name: \"TotalSupplyOverflow\", type: \"error\" },\n { name: \"AllowanceOverflow\", type: \"error\", inputs: [] },\n { name: \"AllowanceUnderflow\", type: \"error\", inputs: [] },\n { name: \"InsufficientAllowance\", type: \"error\", inputs: [] },\n { name: \"InsufficientBalance\", type: \"error\", inputs: [] },\n { name: \"InvalidPermit\", type: \"error\", inputs: [] },\n { name: \"Permit2AllowanceIsFixedAtInfinity\", type: \"error\", inputs: [] },\n { name: \"PermitExpired\", type: \"error\", inputs: [] },\n { name: \"TotalSupplyOverflow\", type: \"error\", inputs: [] },\n { name: \"ECDSAInvalidSignature\", type: \"error\", inputs: [] },\n {\n name: \"ECDSAInvalidSignatureLength\",\n type: \"error\",\n inputs: [{ type: \"uint256\" }],\n },\n {\n name: \"ECDSAInvalidSignatureS\",\n type: \"error\",\n inputs: [{ type: \"bytes32\" }],\n },\n {\n name: \"ERC20InsufficientAllowance\",\n type: \"error\",\n inputs: [{ type: \"address\" }, { type: \"uint256\" }, { type: \"uint256\" }],\n },\n {\n name: \"ERC20InsufficientBalance\",\n type: \"error\",\n inputs: [{ type: \"address\" }, { type: \"uint256\" }, { type: \"uint256\" }],\n },\n {\n name: \"ERC20InvalidApprover\",\n type: \"error\",\n inputs: [{ type: \"address\" }],\n },\n {\n name: \"ERC20InvalidReceiver\",\n type: \"error\",\n inputs: [{ type: \"address\" }],\n },\n { name: \"ERC20InvalidSender\", type: \"error\", inputs: [{ type: \"address\" }] },\n { name: \"ERC20InvalidSpender\", type: \"error\", inputs: [{ type: \"address\" }] },\n {\n name: \"ERC2612ExpiredSignature\",\n type: \"error\",\n inputs: [{ type: \"uint256\" }],\n },\n {\n name: \"ERC2612InvalidSigner\",\n type: \"error\",\n inputs: [{ type: \"address\" }, { type: \"address\" }],\n },\n {\n name: \"InvalidAccountNonce\",\n type: \"error\",\n inputs: [{ type: \"address\" }, { type: \"uint256\" }],\n },\n { name: \"InvalidShortString\", type: \"error\", inputs: [] },\n { name: \"StringTooLong\", type: \"error\", inputs: [{ type: \"string\" }] },\n] as const;\n","export const openChainErrorsAbi = [\n {\n name: \"AllowanceExpired\",\n type: \"error\",\n inputs: [\n {\n type: \"uint256\",\n },\n ],\n },\n {\n name: \"AssetNotRegistered\",\n type: \"error\",\n inputs: [\n {\n type: \"address\",\n },\n ],\n },\n {\n name: \"ERC20InsufficientAllowance\",\n type: \"error\",\n inputs: [\n {\n type: \"address\",\n },\n {\n type: \"uint256\",\n },\n {\n type: \"uint256\",\n },\n ],\n },\n {\n name: \"ERC4626ExceededMaxWithdraw\",\n type: \"error\",\n inputs: [\n {\n type: \"address\",\n },\n {\n type: \"uint256\",\n },\n {\n type: \"uint256\",\n },\n ],\n },\n {\n name: \"ERC721NonexistentToken\",\n type: \"error\",\n inputs: [\n {\n type: \"uint256\",\n },\n ],\n },\n {\n name: \"ExecutionFailed\",\n type: \"error\",\n inputs: [\n {\n type: \"uint256\",\n },\n {\n type: \"address\",\n },\n {\n type: \"string\",\n },\n ],\n },\n {\n name: \"ExpiredTransaction\",\n type: \"error\",\n inputs: [],\n },\n {\n name: \"FailedToCallFunction\",\n type: \"error\",\n inputs: [\n {\n type: \"bytes\",\n },\n ],\n },\n {\n name: \"InsufficientAmountOut\",\n type: \"error\",\n inputs: [],\n },\n {\n name: \"MinimalOutputBalanceViolation\",\n type: \"error\",\n inputs: [\n {\n type: \"address\",\n },\n {\n type: \"uint256\",\n },\n ],\n },\n {\n name: \"NotPegged\",\n type: \"error\",\n inputs: [\n {\n type: \"address\",\n },\n ],\n },\n {\n name: \"RedeemMoreThanMax\",\n type: \"error\",\n inputs: [],\n },\n {\n name: \"SignatureExpired\",\n type: \"error\",\n inputs: [\n {\n type: \"uint256\",\n },\n ],\n },\n {\n name: \"SlippageExceeded\",\n type: \"error\",\n inputs: [\n {\n type: \"uint256\",\n },\n {\n type: \"uint256\",\n },\n ],\n },\n {\n name: \"SlippageExceeded\",\n type: \"error\",\n inputs: [],\n },\n {\n name: \"StalePrice\",\n type: \"error\",\n inputs: [],\n },\n {\n name: \"TooMuchSlippage\",\n type: \"error\",\n inputs: [\n {\n type: \"address\",\n },\n {\n type: \"uint256\",\n },\n {\n type: \"uint256\",\n },\n ],\n },\n {\n name: \"TransferFromFailed\",\n type: \"error\",\n inputs: [],\n },\n {\n name: \"UnexpectedBasketModeStatus\",\n type: \"error\",\n inputs: [],\n },\n {\n name: \"zeroAmountRequired\",\n type: \"error\",\n inputs: [],\n },\n] as const;\n","import { bundler3errorsAbi } from \"./bundler3errors\";\nimport { erc20errorsAbi } from \"./erc20errors\";\nimport { openChainErrorsAbi } from \"./openChainErrors\";\n\nexport const commonAbiErrors = [\n ...erc20errorsAbi,\n ...bundler3errorsAbi,\n ...openChainErrorsAbi,\n] as const;\n","import type { ErrorLike } from \"@apollo/client\";\n\nimport { mainnet } from \"@berachain/config/mainnet\";\n\nimport { BeraError, type IBeraErrorArgs } from \"./BeraError\";\nimport { errorMsgMap } from \"./errorMap\";\n\n/**\n * This is an error class that should be used to handle errors from fetch requests.\n */\nexport class RequestError extends BeraError {\n /**\n * The error response from the request.\n */\n response: Response | ErrorLike | undefined;\n\n static isCorsError(error: Error) {\n return error.cause instanceof Response && error.cause.type === \"cors\";\n }\n /**\n * The endpoint that was requested.\n */\n endpoint: {\n name?: string;\n url: string;\n type?: \"rest\" | \"graphql\" | \"rpc\";\n };\n\n /**\n * A list of domains that should have their query params removed.\n */\n private queryRichfulDomains = [\n mainnet.bex.aggregatorsProxyUrl,\n \"https://api.fly.trade/aggregator/quote\",\n \"https://open-api.openocean.finance/v4/bera/swap\",\n // vercel internal proxy\n \"/api/aggregators?aggregator\",\n ];\n\n statusCode: number | undefined;\n\n payload?: object;\n\n static readonly REASON_MAP = {\n 429: \"RATE_LIMITED_429\",\n NETWORK_ERROR: \"NETWORK_ERROR\",\n CORS_ERROR: \"CORS\",\n } as const;\n\n constructor(\n args: IBeraErrorArgs & {\n response: Response | ErrorLike | undefined;\n /**\n * The payload sent to the request.\n */\n payload?: object;\n endpoint:\n | string\n | URL\n | {\n name?: string;\n url: string | URL;\n type: \"rest\" | \"graphql\" | \"rpc\";\n };\n statusCode?: number;\n },\n ) {\n super(args);\n this.name = \"RequestError\";\n this.response = args.response;\n this.payload = args.payload;\n this.endpoint = this.setEndpoint(args.endpoint);\n\n if (\n !this.message &&\n typeof this.cause === \"object\" &&\n this.cause !== null\n ) {\n if (\"error\" in this.cause && typeof this.cause.error === \"string\") {\n // haiku returns the error in the response as { error: string }\n this.message = this.cause.error;\n }\n }\n\n if (args.statusCode) {\n this.statusCode = args.statusCode;\n } else if (this.response instanceof Response) {\n this.statusCode = this.response.status;\n }\n\n if (this.statusCode === 429) {\n this.reason = RequestError.REASON_MAP[429];\n this.displayMessage = errorMsgMap.HTTP.RATE_LIMITED_429.errorMSG;\n this.level = args.level ?? \"warning\";\n } else {\n const networkError = this.tryMatchNetworkError();\n if (networkError) {\n this.reason = this.reason ?? networkError.reason;\n this.level = args.level ?? \"warning\";\n this.endpoint.url = this.endpoint.url ?? networkError.url;\n }\n }\n\n this.tags = {\n ...this.tags,\n \"error.statusCode\": this.statusCode,\n \"operation.type\": \"query\",\n ...args.tags,\n };\n\n let message = \"\";\n\n if (this.reason) {\n message += `${this.reason} – `;\n } else if (this.statusCode && this.statusCode >= 400) {\n message += `HTTP ${this.statusCode} – `;\n }\n\n this.message = `${message}${this.endpoint.type}(${this.endpoint.url}): ${this.message}`;\n }\n\n setEndpoint(\n endpoint:\n | string\n | URL\n | {\n name?: string;\n url: string | URL;\n type?: \"rest\" | \"graphql\" | \"rpc\";\n },\n ) {\n if (typeof endpoint === \"string\" || endpoint instanceof URL) {\n this.endpoint = {\n url: typeof endpoint === \"string\" ? endpoint : endpoint.toString(),\n };\n } else {\n this.endpoint = {\n ...this.endpoint,\n ...endpoint,\n url: endpoint.url.toString(),\n };\n }\n\n if (\n this.queryRichfulDomains.some((domain) =>\n this.endpoint.url.includes(domain),\n )\n ) {\n // remove query params if it's an aggregator url\n try {\n const url = new URL(this.endpoint.url);\n url.search = \"\";\n this.endpoint.url = url.toString();\n } catch {}\n }\n this.tags = {\n ...this.tags,\n \"operation.source.url\": this.endpoint.url,\n \"operation.source.name\": this.endpoint.name,\n \"operation.source.type\": this.endpoint.type,\n };\n\n return this.endpoint;\n }\n\n private tryMatchNetworkError():\n | false\n | {\n reason: string;\n message: string;\n url: string;\n } {\n if (\n (this.cause instanceof Error &&\n \"message\" in this.cause &&\n typeof this.cause.message === \"string\") ||\n this.cause instanceof TypeError\n ) {\n const message = this.cause.message as string;\n\n if (message.startsWith(\"Network Error\")) {\n return {\n reason: RequestError.REASON_MAP.NETWORK_ERROR,\n message: message,\n url: this.endpoint.url,\n };\n }\n\n // this matches standard error messages as they're returned by browser fetch when they either:\n // - have a network error\n // - have CORS errors\n // the list is empirically collected from sentry error logs.\n const failedToFetchMatch = message.match(\n /^(?:NetworkError when attempting to fetch resource\\.|Failed to fetch|Load failed) \\(([a-z0-9-.]+)\\)$/,\n );\n if (failedToFetchMatch) {\n return {\n reason: RequestError.REASON_MAP.NETWORK_ERROR,\n message: message,\n url: failedToFetchMatch[1],\n };\n }\n }\n\n return false;\n }\n}\n","import { BeraError, type IBeraErrorArgs } from \"./BeraError\";\n\nexport interface IInvalidArgumentErrorArgs extends IBeraErrorArgs {\n /**\n * The name of the argument that is invalid.\n */\n property: string;\n /**\n * The value of the argument that is invalid.\n */\n value: unknown;\n\n /**\n * The expected type of the value as a string, eg. string, number, boolean, etc.\n */\n expected: string;\n}\n\n/**\n * Error thrown when argument validation fails. (e.g. an argument is missing or invalid)\n *\n * Default level is \"warning\".\n *\n * @example ```ts\n * if (!publicClient) {\n * throw new InvalidArgumentError({\n * property: \"publicClient\",\n * value: publicClient,\n * expected: \"PublicClient\",\n * });\n * }\n * if (!address || !isAddress(address)) {\n * throw new InvalidArgumentError({\n * property: \"address\",\n * value: address,\n * expected: \"Address\",\n * });\n * }\n * ```\n *\n */\nexport class InvalidArgumentError extends BeraError {\n /**\n * The name of the argument that is invalid.\n */\n property: string;\n /**\n * The value of the argument that is invalid.\n */\n value: unknown;\n\n /**\n * The expected value of the argument.\n */\n expected: string;\n\n constructor(args: IInvalidArgumentErrorArgs) {\n super(args);\n this.level = args.level ?? \"warning\";\n this.name = \"InvalidArgumentError\";\n this.property = args.property;\n this.value = args.value;\n this.expected = args.expected;\n this.message = `Invalid argument: ${this.property} ${this.isMissing ? \"is missing\" : `is invalid, expected ${this.expected}`}`;\n\n if (!args.reason) {\n this.reason = `${this.name}.${this.property}.${this.isInvalid ? \"invalid\" : \"missing\"}`;\n }\n }\n\n get isMissing(): boolean {\n return this.value === undefined;\n }\n\n /**\n * Whether the argument is defined but invalid.\n */\n get isInvalid(): boolean {\n return this.value !== undefined;\n }\n}\n"],"mappings":"AAuBO,IAAMA,EAAgB,gDAEhBC,EAAc,CACzB,MAAO,CACL,mBAAoB,CAClB,QAAS,CAAC,kBAAkB,EAC5B,SAAU,wDACZ,EACA,oBAAqB,CACnB,QAAS,CAAC,qBAAqB,EAC/B,SAAU,4BACZ,EACA,uBAAwB,CACtB,QAAS,CACP,aACA,wBACA,4BACF,EACA,SAAU,0DACZ,EACA,kBAAmB,CACjB,QAAS,CAAC,kBAAkB,EAC5B,SAAU,0DACZ,CACF,EACA,KAAM,CACJ,iBAAkB,CAChB,QAAS,CAAC,KAAK,EACf,SAAU,4CACZ,CACF,EACA,KAAM,CACJ,yBAA0B,CACxB,SAAU,CACR,sCACA,qCACF,EAEA,SACE,oEACJ,EACA,qBAAsB,CACpB,SAAU,CACR,sHACF,EAEA,SACE,2HACJ,EACA,eAAgB,CACd,SAAU,CAAC,qBAAqB,EAChC,SAAU,2CACZ,CACF,EACA,IAAK,CACH,mBAAoB,CAClB,QAAS,CAAC,wBAAwB,EAClC,SAAU,CACR,0GACF,EACA,SAAU,mDACZ,EACA,UAAW,CACT,SAAU,CAAC,UAAU,EACrB,SACE,yFACJ,EACA,SAAU,CACR,SAAU,CAAC,UAAU,EAErB,SACE,6EACJ,EACA,eAAgB,CACd,SAAU,CAAC,6CAA6C,EACxD,SAAU,4DACZ,EACA,KAAM,CACJ,SAAU,CAAC,MAAM,EAEjB,SACE,+GACJ,EACA,eAAgB,CACd,QAAS,CAAC,0BAA0B,EACpC,SAAU,CAAC,mCAAmC,EAC9C,SAAU,+BACZ,EACA,wBAAyB,CACvB,QAAS,CAAC,uCAAuC,EACjD,SACE,iGACJ,EACA,eAAgB,CACd,QAAS,CAAC,oBAAoB,EAC9B,SACE,+EACJ,CACF,EACA,QAAS,CACP,oBAAqB,CACnB,QAAS,CAAC,mBAAmB,EAC7B,SAAU,mDACZ,EACA,qBAAsB,CACpB,QAAS,CAAC,oBAAoB,EAC9B,SAAU,wDACZ,CACF,EACA,MAAO,CACL,mBAAoB,CAClB,QAAS,CAAC,oBAAqB,YAAY,EAC3C,SAAU,6DACZ,EACA,gBAAiB,CACf,QAAS,CAAC,YAAY,EACtB,SACE,0EACJ,CACF,EAIA,IAAK,CACH,kBAAmB,CACjB,QAAS,CAAC,mBAAoB,iBAAiB,EAC/C,SACE,kFACJ,EAEA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,0DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,8DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,gEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,uCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,+DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,2CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,2CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,2EACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,wDACZ,EAEA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,8CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,wEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,wEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,qCACZ,EAEA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,uDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,kEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,uMACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,iFACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,mGACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,0EACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,8CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,0EACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,gIACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,sFACJ,EAEA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,qEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,oEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,8DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,oEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,8DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,gEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,gEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,yDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,iDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,sCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,gFACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,wCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,iEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,qEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,8EACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,qFACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,mHACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,uEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,+DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,uDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,kEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,mGACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,+CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,uEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,+HACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,qEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,gDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,yDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,oEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,mEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,oEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,gEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,qEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,qEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,sDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,mEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,+CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,iDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,2DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,wDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,+DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,yDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,wCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,uEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,uDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,kEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,yDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,mDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,kDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,iEACJ,EAEA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,gCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,yCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,gEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,iEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,iDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,mDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,8CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,wCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,0CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,2CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,8CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,kDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,0CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,mCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,sCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,mDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,wDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,yDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,oFACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,sCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,oCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,mCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,yCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,kCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,uCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,2CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,uCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,wCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,8BACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,oCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,2CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,+CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4BACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,8BACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,gCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,mDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,+BACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,0CACZ,EAEA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4BACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,mCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,8BACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,+DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,+CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,2DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,uCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,wDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,yCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,sCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,0CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,0CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,kEACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,sCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,6BACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SACE,2EACJ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,0DACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4BACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,oCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,wCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,mCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,oCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,2CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,+BACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4CACZ,EAEA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,4CACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,kDACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,+CACZ,EAEA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,gDACZ,EAEA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,wCACZ,EACA,OAAQ,CACN,QAAS,CAAC,SAAS,EACnB,SAAU,yCACZ,EAEA,cAAe,CACb,SAAU,CAAC,wBAAwB,EACnC,SAAU,2BACZ,CACF,EACA,WAAY,CACV,qBAAsB,CACpB,SAAU,CAAC,sBAAsB,EACjC,SAAU,2CACZ,CACF,EACA,IAAK,CACH,qBAAsB,CACpB,QAAS,CAAC,oBAAoB,EAC9B,SACE,4EACJ,EACA,yBAA0B,CACxB,QAAS,CAAC,uBAAuB,EACjC,SAAU,yCACZ,EACA,sBAAuB,CACrB,QAAS,CAAC,qBAAqB,EAC/B,SAAU,kDACZ,EACA,4BAA6B,CAC3B,QAAS,CAAC,0BAA0B,EACpC,SAAU,gDACZ,EACA,cAAe,CACb,QAAS,CAAC,cAAc,EACxB,SAAU,0CACZ,EACA,gBAAiB,CACf,QAAS,CAAC,eAAe,EACzB,SAAU,6DACZ,EACA,oBAAqB,CACnB,QAAS,CAAC,2BAA2B,EACrC,SAAU,qCACZ,EACA,6BAA8B,CAC5B,QAAS,CAAC,wBAAwB,EAClC,SAAU,gCACZ,EACA,qBAAsB,CACpB,QAAS,CAAC,oBAAoB,EAC9B,SAAU,qDACZ,EACA,aAAc,CACZ,QAAS,CAAC,aAAa,EACvB,SAAU,6CACZ,EACA,0BAA2B,CACzB,QAAS,CAAC,gCAAgC,EAC1C,SAAU,oCACZ,EACA,4BAA6B,CAC3B,QAAS,CAAC,0BAA0B,EACpC,SAAU,4DACZ,CACF,EACA,KAAM,CACJ,sBAAuB,CACrB,SAAU,CAAC,uBAAuB,EAClC,SAAU,uBACZ,EACA,uBAAwB,CACtB,SAAU,CAAC,kCAAkC,EAC7C,SAAU,mCACZ,EACA,iBAAkB,CAChB,QAAS,CAAC,gBAAgB,EAC1B,SAAU,4BACZ,EACA,iBAAkB,CAChB,QAAS,CAAC,kBAAkB,EAC5B,SAAU,oBACZ,EACA,iBAAkB,CAChB,QAAS,CAAC,kBAAkB,EAC5B,SAAU,oBACZ,EACA,2BAA4B,CAC1B,QAAS,CAAC,4BAA4B,EACtC,SAAU,8BACZ,EACA,eAAgB,CACd,QAAS,CAAC,gBAAgB,EAC1B,SAAU,kBACZ,EACA,eAAgB,CACd,QAAS,CAAC,gBAAgB,EAC1B,SAAU,iBACZ,EACA,WAAY,CACV,QAAS,CAAC,YAAY,EACtB,SAAU,aACZ,EACA,iBAAkB,CAChB,QAAS,CAAC,kBAAkB,EAC5B,SAAU,oBACZ,EACA,gBAAiB,CACf,QAAS,CAAC,iBAAiB,EAC3B,SAAU,kBACZ,EACA,sBAAuB,CACrB,QAAS,CAAC,uBAAuB,EACjC,SAAU,yBACZ,EACA,4BAA6B,CAC3B,QAAS,CAAC,6BAA6B,EACvC,SAAU,gCACZ,EACA,uBAAwB,CACtB,QAAS,CAAC,wBAAwB,EAClC,SAAU,iCACZ,EACA,yBAA0B,CACxB,QAAS,CAAC,0BAA0B,EACpC,SAAU,4BACZ,EACA,qBAAsB,CACpB,QAAS,CAAC,sBAAsB,EAChC,SAAU,wBACZ,EACA,qBAAsB,CACpB,QAAS,CAAC,sBAAsB,EAChC,SAAU,wBACZ,EACA,mBAAoB,CAClB,QAAS,CAAC,oBAAoB,EAC9B,SAAU,sBACZ,EACA,oBAAqB,CACnB,QAAS,CAAC,qBAAqB,EAC/B,SAAU,uBACZ,EACA,wBAAyB,CACvB,QAAS,CAAC,yBAAyB,EACnC,SAAU,2BACZ,EACA,qBAAsB,CACpB,QAAS,CAAC,sBAAsB,EAChC,SAAU,wBACZ,EACA,0BAA2B,CACzB,QAAS,CAAC,2BAA2B,EACrC,SAAU,8BACZ,EACA,uBAAwB,CACtB,QAAS,CAAC,wBAAwB,EAClC,SAAU,2BACZ,EACA,yBAA0B,CACxB,QAAS,CAAC,0BAA0B,EACpC,SAAU,6BACZ,EACA,2BAA4B,CAC1B,QAAS,CAAC,4BAA4B,EACtC,SAAU,+BACZ,EACA,gBAAiB,CACf,QAAS,CAAC,iBAAiB,EAC3B,SAAU,mBACZ,EACA,kBAAmB,CACjB,QAAS,CAAC,mBAAmB,EAC7B,SAAU,oBACZ,EACA,yBAA0B,CACxB,QAAS,CAAC,0BAA0B,EACpC,SAAU,2BACZ,EACA,oBAAqB,CACnB,QAAS,CAAC,qBAAqB,EAC/B,SAAU,uBACZ,EACA,+BAAgC,CAC9B,QAAS,CAAC,gCAAgC,EAC1C,SAAU,uCACZ,EACA,kCAAmC,CACjC,QAAS,CAAC,mCAAmC,EAC7C,SAAU,0CACZ,EACA,uCAAwC,CACtC,QAAS,CAAC,wCAAwC,EAClD,SAAU,+CACZ,EACA,mBAAoB,CAClB,QAAS,CAAC,oBAAoB,EAC9B,SAAU,sBACZ,EACA,iBAAkB,CAChB,QAAS,CAAC,kBAAkB,EAC5B,SAAU,oBACZ,EACA,iBAAkB,CAChB,QAAS,CAAC,kBAAkB,EAC5B,SAAU,oBACZ,EACA,qBAAsB,CACpB,QAAS,CAAC,sBAAsB,EAChC,SAAU,eACZ,EACA,eAAgB,CACd,QAAS,CAAC,gBAAgB,EAC1B,SAAU,kBACZ,EACA,uBAAwB,CACtB,QAAS,CAAC,wBAAwB,EAClC,SAAU,2BACZ,EACA,eAAgB,CACd,QAAS,CAAC,gBAAgB,EAC1B,SAAU,kBACZ,EACA,WAAY,CACV,QAAS,CAAC,YAAY,EACtB,SAAU,cACZ,EACA,iBAAkB,CAChB,QAAS,CAAC,kBAAkB,EAC5B,SAAU,oBACZ,EACA,0BAA2B,CACzB,QAAS,CAAC,2BAA2B,EACrC,SAAU,8BACZ,EACA,eAAgB,CACd,QAAS,CAAC,gBAAgB,EAC1B,SAAU,kBACZ,EACA,mBAAoB,CAClB,QAAS,CAAC,oBAAoB,EAC9B,SAAU,sBACZ,EACA,gBAAiB,CACf,QAAS,CAAC,iBAAiB,EAC3B,SAAU,mBACZ,EACA,oBAAqB,CACnB,QAAS,CAAC,qBAAqB,EAC/B,SAAU,eACZ,EACA,2BAA4B,CAC1B,QAAS,CAAC,4BAA4B,EACtC,SAAU,sBACZ,EACA,WAAY,CACV,QAAS,CAAC,YAAY,EACtB,SAAU,aACZ,EACA,eAAgB,CACd,QAAS,CAAC,gBAAgB,EAC1B,SAAU,iBACZ,EACA,+BAAgC,CAC9B,QAAS,CAAC,gCAAgC,EAC1C,SAAU,mBACZ,EACA,yBAA0B,CACxB,QAAS,CAAC,0BAA0B,EACpC,SAAU,4BACZ,EACA,cAAe,CACb,QAAS,CAAC,eAAe,EACzB,SAAU,iBACZ,EACA,kBAAmB,CACjB,QAAS,CAAC,mBAAmB,EAC7B,SAAU,qBACZ,EACA,mBAAoB,CAClB,QAAS,CAAC,oBAAoB,EAC9B,SAAU,sBACZ,EACA,mBAAoB,CAClB,QAAS,CAAC,oBAAoB,EAC9B,SAAU,qBACZ,EACA,YAAa,CACX,QAAS,CAAC,aAAa,EACvB,SAAU,cACZ,EACA,iBAAkB,CAChB,QAAS,CAAC,kBAAkB,EAC5B,SAAU,oBACZ,CACF,CACF,EC1nCO,SAASC,EAAgB,CAC9B,OAAAC,EACA,QAAAC,CACF,EAGW,CACT,QAAWC,KAAYC,EAAa,CAElC,IAAMC,EAASD,EADKD,CACkB,EAEtC,QAAWG,KAAQD,EAAQ,CACzB,IAAME,EAAYF,EAAOC,CAAI,EAc7B,GAXIL,GAEAM,GAAW,SAAS,KAAMC,GACjBA,IAAMP,CACd,GAQHM,GAAW,UAAU,KAAME,GAClBP,GAAS,SAASO,EAAQ,YAAY,EAAE,KAAK,CAAC,CACtD,EAED,OAAOF,EAAU,QAErB,CACF,CAGA,OAAOG,CACT,CC1DA,OAAmB,aAAAC,MAAiB,OAEpC,OAAS,aAAAC,MAAiB,6BCF1B,OAEE,yCAAAC,EACA,aAAAC,EACA,kCAAAC,EACA,iCAAAC,EAEA,qBAAAC,EACA,oBAAAC,EAEA,mBAAAC,EACA,6BAAAC,EACA,4BAAAC,MACK,OCbA,IAAMC,EAAoB,CAC/B,CAAE,OAAQ,CAAC,EAAG,KAAM,mBAAoB,KAAM,OAAQ,EACtD,CAAE,OAAQ,CAAC,EAAG,KAAM,cAAe,KAAM,OAAQ,EACjD,CAAE,OAAQ,CAAC,EAAG,KAAM,uBAAwB,KAAM,OAAQ,EAC1D,CAAE,OAAQ,CAAC,EAAG,KAAM,yBAA0B,KAAM,OAAQ,CAC9D,ECAO,IAAMC,EAAiB,CAC5B,CAAE,OAAQ,CAAC,EAAG,KAAM,oBAAqB,KAAM,OAAQ,EACvD,CAAE,OAAQ,CAAC,EAAG,KAAM,qBAAsB,KAAM,OAAQ,EACxD,CAAE,OAAQ,CAAC,EAAG,KAAM,oBAAqB,KAAM,OAAQ,EACvD,CAAE,OAAQ,CAAC,EAAG,KAAM,wBAAyB,KAAM,OAAQ,EAC3D,CAAE,OAAQ,CAAC,EAAG,KAAM,sBAAuB,KAAM,OAAQ,EACzD,CAAE,OAAQ,CAAC,EAAG,KAAM,gBAAiB,KAAM,OAAQ,EACnD,CAAE,OAAQ,CAAC,EAAG,KAAM,oCAAqC,KAAM,OAAQ,EACvE,CAAE,OAAQ,CAAC,EAAG,KAAM,gBAAiB,KAAM,OAAQ,EACnD,CAAE,OAAQ,CAAC,EAAG,KAAM,sBAAuB,KAAM,OAAQ,EACzD,CAAE,KAAM,oBAAqB,KAAM,QAAS,OAAQ,CAAC,CAAE,EACvD,CAAE,KAAM,qBAAsB,KAAM,QAAS,OAAQ,CAAC,CAAE,EACxD,CAAE,KAAM,wBAAyB,KAAM,QAAS,OAAQ,CAAC,CAAE,EAC3D,CAAE,KAAM,sBAAuB,KAAM,QAAS,OAAQ,CAAC,CAAE,EACzD,CAAE,KAAM,gBAAiB,KAAM,QAAS,OAAQ,CAAC,CAAE,EACnD,CAAE,KAAM,oCAAqC,KAAM,QAAS,OAAQ,CAAC,CAAE,EACvE,CAAE,KAAM,gBAAiB,KAAM,QAAS,OAAQ,CAAC,CAAE,EACnD,CAAE,KAAM,sBAAuB,KAAM,QAAS,OAAQ,CAAC,CAAE,EACzD,CAAE,KAAM,wBAAyB,KAAM,QAAS,OAAQ,CAAC,CAAE,EAC3D,CACE,KAAM,8BACN,KAAM,QACN,OAAQ,CAAC,CAAE,KAAM,SAAU,CAAC,CAC9B,EACA,CACE,KAAM,yBACN,KAAM,QACN,OAAQ,CAAC,CAAE,KAAM,SAAU,CAAC,CAC9B,EACA,CACE,KAAM,6BACN,KAAM,QACN,OAAQ,CAAC,CAAE,KAAM,SAAU,EAAG,CAAE,KAAM,SAAU,EAAG,CAAE,KAAM,SAAU,CAAC,CACxE,EACA,CACE,KAAM,2BACN,KAAM,QACN,OAAQ,CAAC,CAAE,KAAM,SAAU,EAAG,CAAE,KAAM,SAAU,EAAG,CAAE,KAAM,SAAU,CAAC,CACxE,EACA,CACE,KAAM,uBACN,KAAM,QACN,OAAQ,CAAC,CAAE,KAAM,SAAU,CAAC,CAC9B,EACA,CACE,KAAM,uBACN,KAAM,QACN,OAAQ,CAAC,CAAE,KAAM,SAAU,CAAC,CAC9B,EACA,CAAE,KAAM,qBAAsB,KAAM,QAAS,OAAQ,CAAC,CAAE,KAAM,SAAU,CAAC,CAAE,EAC3E,CAAE,KAAM,sBAAuB,KAAM,QAAS,OAAQ,CAAC,CAAE,KAAM,SAAU,CAAC,CAAE,EAC5E,CACE,KAAM,0BACN,KAAM,QACN,OAAQ,CAAC,CAAE,KAAM,SAAU,CAAC,CAC9B,EACA,CACE,KAAM,uBACN,KAAM,QACN,OAAQ,CAAC,CAAE,KAAM,SAAU,EAAG,CAAE,KAAM,SAAU,CAAC,CACnD,EACA,CACE,KAAM,sBACN,KAAM,QACN,OAAQ,CAAC,CAAE,KAAM,SAAU,EAAG,CAAE,KAAM,SAAU,CAAC,CACnD,EACA,CAAE,KAAM,qBAAsB,KAAM,QAAS,OAAQ,CAAC,CAAE,EACxD,CAAE,KAAM,gBAAiB,KAAM,QAAS,OAAQ,CAAC,CAAE,KAAM,QAAS,CAAC,CAAE,CACvE,ECzEO,IAAMC,EAAqB,CAChC,CACE,KAAM,mBACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,SACR,CACF,CACF,EACA,CACE,KAAM,qBACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,SACR,CACF,CACF,EACA,CACE,KAAM,6BACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,SACR,EACA,CACE,KAAM,SACR,EACA,CACE,KAAM,SACR,CACF,CACF,EACA,CACE,KAAM,6BACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,SACR,EACA,CACE,KAAM,SACR,EACA,CACE,KAAM,SACR,CACF,CACF,EACA,CACE,KAAM,yBACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,SACR,CACF,CACF,EACA,CACE,KAAM,kBACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,SACR,EACA,CACE,KAAM,SACR,EACA,CACE,KAAM,QACR,CACF,CACF,EACA,CACE,KAAM,qBACN,KAAM,QACN,OAAQ,CAAC,CACX,EACA,CACE,KAAM,uBACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,OACR,CACF,CACF,EACA,CACE,KAAM,wBACN,KAAM,QACN,OAAQ,CAAC,CACX,EACA,CACE,KAAM,gCACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,SACR,EACA,CACE,KAAM,SACR,CACF,CACF,EACA,CACE,KAAM,YACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,SACR,CACF,CACF,EACA,CACE,KAAM,oBACN,KAAM,QACN,OAAQ,CAAC,CACX,EACA,CACE,KAAM,mBACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,SACR,CACF,CACF,EACA,CACE,KAAM,mBACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,SACR,EACA,CACE,KAAM,SACR,CACF,CACF,EACA,CACE,KAAM,mBACN,KAAM,QACN,OAAQ,CAAC,CACX,EACA,CACE,KAAM,aACN,KAAM,QACN,OAAQ,CAAC,CACX,EACA,CACE,KAAM,kBACN,KAAM,QACN,OAAQ,CACN,CACE,KAAM,SACR,EACA,CACE,KAAM,SACR,EACA,CACE,KAAM,SACR,CACF,CACF,EACA,CACE,KAAM,qBACN,KAAM,QACN,OAAQ,CAAC,CACX,EACA,CACE,KAAM,6BACN,KAAM,QACN,OAAQ,CAAC,CACX,EACA,CACE,KAAM,qBACN,KAAM,QACN,OAAQ,CAAC,CACX,CACF,EC/KO,IAAMC,EAAkB,CAC7B,GAAGC,EACH,GAAGC,EACH,GAAGC,CACL,EJ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","names":["GENERAL_ERROR","errorMsgMap","getErrorMessage","reason","message","category","errorMsgMap","errors","type","errorType","r","keyword","GENERAL_ERROR","BaseError","appConfig","AtomicReadyWalletRejectedUpgradeError","BaseError","ContractFunctionExecutionError","ContractFunctionRevertedError","decodeErrorResult","HttpRequestError","RpcRequestError","TransactionExecutionError","UserRejectedRequestError","bundler3errorsAbi","erc20errorsAbi","openChainErrorsAbi","commonAbiErrors","erc20errorsAbi","bundler3errorsAbi","openChainErrorsAbi","isBaseError","error","BaseError","isViemError","name","shouldBeInstanceOf","parseDecodedError","parseViemError","abi","revertIfUnknown","cause","ContractFunctionExecutionError","TransactionExecutionError","AtomicReadyWalletRejectedUpgradeError","RpcRequestError","decodedError","decodeErrorResult","commonAbiErrors","ContractFunctionRevertedError","UserRejectedRequestError","HttpRequestError","rpcErrorToReason","errCode","BeraError","_BeraError","tags","m","dm","cause","reason","level","abi","chainId","fingerprint","message","BaseError","parsed","parseViemError","rpcErrorToReason","displayMessage","GENERAL_ERROR","getErrorMessage","appConfig","mainnet","RequestError","_RequestError","BeraError","error","mainnet","args","errorMsgMap","networkError","message","endpoint","domain","url","failedToFetchMatch","InvalidArgumentError","BeraError","args"]}
@@ -1,4 +0,0 @@
1
- import{a as De,c as Qe,d as X,e as B,f as K,g as Ue,h as pe,i as U,j as Z,k as P,m as G,n as We}from"./chunk-Q3SCM6WL.mjs";import{a as Oe,b as Ke,c as j}from"./chunk-7GWTHOLO.mjs";import{a as W,b as te,c as R,d as Ve,f as J}from"./chunk-MTS5SZLA.mjs";import{A as ze,C as re,E as Se,F as Xe,a as ge,b as Me,c as He,d as ye,i as Re,j as Je,k as N,l as $e,q as je,x as se,y as Ye}from"./chunk-TJWKS54T.mjs";import{a as c,b as be,d as _e,e as k}from"./chunk-YQGZMWDT.mjs";import{b as fe,c as Le,d as ie,e as v,f as ee,g as F}from"./chunk-C3G5KXCH.mjs";import{formatEther as Dt}from"viem";async function Oa({sharesAmount:e,vaultAddress:t,publicClient:r}){let a=await r.readContract({address:t,abi:De,functionName:"convertToAssets",args:[e]});return{raw:a,formatted:Dt(a)}}import{ApolloClient as Qt,ServerError as Ut}from"@apollo/client";import{appConfig as Wt}from"@berachain/config/internal";var Ae=class extends Qt{url;constructor(t){super(t),this.url=t.url}async query(t){let r=Lt(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),l=await Oe.startSpan({name:`GraphQL ${r}`,op:"BeraApolloClient.query",attributes:o},i);if(l.error||l.data===void 0)throw new v({level:"fatal",tags:o,message:"Bera Apollo Client: No data returned from query, but error should be thrown since errorPolicy is none"});return{data:l.data}}catch(i){throw!Wt.env.isProduction&&console.error("BeraApolloClient error",i),Ut.is(i)?new ee({response:i.response,cause:i,statusCode:i.statusCode,endpoint:a,tags:o}):i instanceof TypeError?new ee({level:"fatal",reason:"TypeError",response:i,cause:i,endpoint:a,tags:o}):new ee({response:i,tags:o,cause:i,endpoint:a})}}};function Lt(e){return e.definitions.find(r=>r.kind==="OperationDefinition")?.name?.value}import{InMemoryCache as Ot}from"@apollo/client";import{HttpLink as Mt}from"@apollo/client/link/http";import{getUriFromLink as et}from"@berachain/config";import{currentDapp as Ze}from"@berachain/config/internal";import Ht from"@berachain/graphql/dex/api";import{gql as io}from"@apollo/client";function _t(e){if(!Ze)return e;let t=typeof e=="string"?void 0:e.headers;return{uri:et(e),headers:{...t,"x-graphql-client-name":`berachain.${Ze}.${process.env.NEXT_RUNTIME||"browser"}`,"x-graphql-client-version":`${process.env.VERCEL_TARGET_ENV}.${process.env.VERCEL_GIT_COMMIT_SHA}`}}}function Y(e,{ssrMode:t,inMemoryCacheOptions:r}={}){let a=et(e),o=typeof e=="string"?void 0:e.headers;return new Ae({url:a,link:new Mt({uri:a,headers:o}),defaultOptions:{query:{errorPolicy:"none",fetchPolicy:"no-cache"}},cache:new Ot(r),ssrMode:t})}function g(e,{...t}){let{config:r}=c(t);switch(e){case"api":return Y(_t(r.api),{inMemoryCacheOptions:{possibleTypes:Ht.possibleTypes}});case"bend.whisk":if(!r.bend.whiskApi)throw new v({message:"Bend whisk API is not configured on this chain",level:"error"});return Y(r.bend.whiskApi);case"honey.subgraph":return Y(r.honey.subgraph);case"pol.subgraph":return Y(r.pol.subgraph);case"governance.subgraph":return Y(r.governance.subgraph);case"blocks.subgraph":return Y(r.blocksSubgraph);case"bex.subgraph":return Y(r.bex.subgraph)}}import{formatUnits as Jt,isAddress as tt,zeroAddress as $t}from"viem";import le from"@berachain/utils/pkg/bignumber.js";var rt=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(!tt(t)||!tt(r))throw new v({message:`Invalid address: ${t} or ${r}`,level:"error"});return{tokenInAddress:k(t,"BERA")?this.config.tokens.wbera:t,tokenOutAddress:k(r,"BERA")?this.config.tokens.wbera:r,isTokenInNative:k(t,"BERA"),isTokenOutNative:k(r,"BERA")}}getAmountAfterFees(t,r){if(r===void 0)throw new v({message:"aggregatorsFeeBps is required",level:"error"});let a=new le(t).times(r).dividedBy(1e4).toFixed(0,le.ROUND_DOWN);return new le(t).minus(a).toFixed(0,le.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??$t}}getMinAmountOut(t,r){if(r===void 0)throw new v({message:"slippage is required",level:"error"});let a=new le(t).times(1-r/100);return a.isNaN()||a.isZero()?0n:BigInt(a.toFixed(0))}parseAllowanceRequirements({tokenIn:t,rawAmount:r,spender:a}){return k(t,"BERA")?[]:[{token:t,amount:{raw:r,formatted:Jt(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 v({message:`${this.name} does not support tokens chain ID: ${t.chainId} and ${r.chainId}`,level:"error"})}async fetch(t,r){try{return await Me({url:t,name:this.name,type:this.type},{method:"GET",headers:{"Content-Type":"application/json"},...r})}catch(a){let o=W({cause:a});throw this.notFoundMessages.some(i=>o.message.includes(i))&&(o.reason=e.PATH_NOT_FOUND_REASON),o}}};import{API_CHAIN_NAMES as jt,BALANCER_QUERIES as Kt,BALANCER_RELAYER as Yt,BalancerApi as yo,CHAINS as zt,COMPOSABLE_STABLE_POOL_FACTORY as Xt,NATIVE_ASSETS as Zt,Token as er,VAULT as tr,WEIGHTED_POOL_FACTORY_BALANCER_V2 as rr}from"@berachain-foundation/berancer-sdk";import{zeroAddress as ke}from"viem";import{berachain as at,berachainBepolia as ar}from"viem/chains";import{chainConfigs as or}from"@berachain/config/internal";for(let e of Object.keys(or)){let{config:t,chainId:r}=c({chainId:Number(e)});jt[r]=t.bex.chainName,zt[r]=r===at.id?at:ar,Yt[r]=t.bex.relayer,tr[r]=t.bex.vault,Kt[r]=t.bex.queries,rr[r]=ke,Xt[r]=ke;let a=new er(r,ke,be.decimals,be.name,be.symbol,t.tokens.wbera);Zt[r]=a}import{GetPools as nr}from"@berachain/graphql/dex/api";import{GqlPoolOrderBy as ir,GqlPoolOrderDirection as sr}from"@berachain/graphql/pol/api";async function ko({textSearch:e,chain:t,first:r,orderBy:a,orderDirection:o,skip:i,fetchPolicy:l,userAddress:n,blacklistedPoolIds:s,...d}={}){let{config:u}=c(d),f=await g("api",d).query({query:nr,variables:{textSearch:e,chain:t??u.bex.chainName,first:r,orderBy:a??ir.TotalLiquidity,orderDirection:o??sr.Desc,skip:i,userAddress:n,blacklistedPoolIds:s},fetchPolicy:l});return{pools:f.data.poolGetPools??[],count:f.data.count??0}}import{GetPool as lr}from"@berachain/graphql/dex/api";async function Eo({poolId:e,account:t,...r}){let{config:a}=c(r),l=(await g("api",r).query({query:lr,variables:{id:e,userAddress:t,chain:a.bex.chainName},fetchPolicy:"no-cache"})).data.poolGetPool;if(!l)throw new Error(`Pool not found for id: ${e} and user ${t}`);return l}import{GetGlobalLiquidityAndSwapVolume as ur}from"@berachain/graphql/dex/api";async function Qo(e={}){let{config:t}=c(e);return(await g("api",e).query({query:ur,variables:{chain:t.bex.chainName}})).data}import{weightedPoolV4Abi_V2 as cr}from"@berachain-foundation/berancer-sdk";async function ot({publicClient:e,poolAddress:t}){let r=cr,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 dr,vaultV2Abi as mr,weightedPoolFactoryAbi_V3 as nt,weightedPoolV4Abi_V2 as he}from"@berachain-foundation/berancer-sdk";import{erc20Abi as it,formatEther as st,formatUnits as pr,isAddress as fr,isHex as gr}from"viem";import{GqlPoolType as lt}from"@berachain/graphql/pol/api";async function Ko({poolId:e,publicClient:t,...r}){let{config:a}=c(r),o=e.slice(0,42);if(!fr(o)||!gr(e))throw new F({property:"poolId",value:e,expected:"Hex"});try{let[i,l,n,s,d,u,m,f,b]=await Promise.all([t.readContract({address:o,abi:it,functionName:"name"}),t.readContract({address:a.bex.vault,abi:mr,functionName:"getPoolTokens",args:[e]}),t.readContract({address:o,abi:it,functionName:"totalSupply"}),t.readContract({address:o,abi:he,functionName:"getSwapFeePercentage"}),t.readContract({address:o,abi:he,functionName:"version"}),t.readContract({address:o,abi:he,functionName:"decimals"}),t.readContract({address:a.bex.factories.composableStable,abi:nt,functionName:"isPoolFromFactory",args:[o]}),t.readContract({address:a.bex.factories.weighted,abi:nt,functionName:"isPoolFromFactory",args:[o]}),ot({publicClient:t,poolAddress:o})]),p=Number(u),A=JSON.parse(d),C,V,y;if(m?[C,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:dr,functionName:"getAmplificationParameter"})]):A.name==="WeightedPool"&&(V=await t.readContract({address:o,abi:he,functionName:"getNormalizedWeights"})),!m&&!f)throw new Error(`Pool ${o} is not a valid BEX pool`);return{name:i,address:o,id:e,poolTokens:[l[0],l[1].map(String),Number(l[2])],totalSupply:pr(C??n,p),swapFee:st(s),decimals:p,weights:V?.map(I=>st(I)),version:A,factory:m?a.bex.factories.composableStable:a.bex.factories.weighted,type:m?lt.Stable:lt.Weighted,amplificationParameter:y?[Number(y[0]),y[1],Number(y[2])]:void 0,pausedState:b}}catch(i){throw W({cause:i})}}import{GetPoolEvents as br}from"@berachain/graphql/dex/api";async function en({poolId:e,typeInArray:t,...r}){let{config:a}=c(r);return(await g("api",r).query({query:br,variables:{poolId:e,typeIn:t,chain:a.bex.chainName}})).data}import{isHex as yr}from"viem";import{GetPoolHistoricalData as Ar}from"@berachain/graphql/dex/api";async function sn({poolId:e,chain:t,...r}){if(!e||!yr(e))throw new F({property:"poolId",value:e,expected:"hex string"});let a=g("api",r),{data:o}=await a.query({query:Ar,variables:{poolId:e,chain:t}});return o.poolGetSnapshots}import{isHex as hr}from"viem";import{GetSubgraphPool as wr}from"@berachain/graphql/dex/subgraph";async function mn({poolId:e,...t}){if(!hr(e))throw new Error("poolId is not a valid hex string");return(await g("bex.subgraph",t).query({query:wr,variables:{id:e}})).data.pool}import{isAddress as ut,isHex as Cr}from"viem";var ae=({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 l=BigInt(t);if(e.startsWith("uint")&&l<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 t.length===0?"Required":null;case"description":return t.length===0?"Required":null;case"forumLink":if(t.length===0)return"Required";if(!URL.canParse(t))return"Invalid address";let l=new URL(a);return t.startsWith(l.toString())?null:"Must be a berachain forum link";case"address":return ut(t,{strict:!0})?null:"Invalid address";case"hex":return Cr(t,{strict:!0})?null:"Invalid address";case"abi":try{JSON.parse(t)}catch{return"Invalid ABI"}return null;case"action":return ut(t,{strict:!0})?null:"Invalid address";case"tuple":if(typeof t=="object"&&Array.isArray(o)){let n={};for(let s of o)n[s.name]=ae({fieldOrType:s.type,value:t[s.name],components:s.components});return Object.values(n).every(s=>s===null)?null:n}return null;case"tuple[]":if(Array.isArray(t)){let n=t.map(s=>ae({fieldOrType:"tuple",value:s,components:o}));return n.every(s=>s===null)?null:n}return null;case"logoURI":return t===void 0||t===""||URL.canParse(t)&&new URL(t).protocol==="https:"?null:"Must be HTTPS or IPFS";case"url":return t===void 0||t===""||URL.canParse(t)&&new URL(t).protocol==="https:"?null:"Must be HTTPS";default:return console.error(`Invalid field or type: ${e}`),null}};import{ProposalStatus as w}from"@berachain/graphql/governance";var Pr=!1,yn=[w.Active,w.PendingQueue,w.PendingExecution,w.Defeated,w.QuorumNotReached];function we(e,t){let r=Date.now()/1e3;if(t!==void 0){if(e.status===w.CanceledByGuardian)return w.CanceledByGuardian;if(t===2)return Number(e.voteStartAt)<r?w.CanceledByUser:w.CanceledByGuardian;if(t===3)return e.pollResult?!e.quorum||BigInt(e.quorum)>BigInt(e.pollResult.totalTowardsQuorum)?w.QuorumNotReached:w.Defeated:w.QuorumNotReached;if(t===4)return w.PendingQueue;if(t===5)return Number(e.queueEnd)<Date.now()/1e3?w.PendingExecution:w.InQueue;if(t===6)return console.warn("Unexpected expired state on proposal id: ",e.id),w.Defeated}return e.status===w.InQueue&&Number(e.queueEnd)<Date.now()/1e3?w.PendingExecution:Pr&&t===1&&e.quorum&&BigInt(e.quorum)<BigInt(e.pollResult.totalTowardsQuorum)&&Number(e.pollResult.forPercentage)>Number(e.pollResult.againstPercentage)?w.PendingQueue:e.status===w.Pending?Number(e.voteStartAt)<r&&Number(e.voteEndAt)>r?w.Active:Number(e.voteEndAt)<r?e.pollResult?!e.quorum||BigInt(e.quorum)>BigInt(e.pollResult.totalTowardsQuorum)?w.QuorumNotReached:e.pollResult?.against>e.pollResult?.for?w.Defeated:w.PendingQueue:w.QuorumNotReached:w.Pending:e.status===w.Active&&Number(e.voteEndAt)<r?!e.quorum||BigInt(e.quorum)>BigInt(e.pollResult.totalTowardsQuorum)?w.QuorumNotReached:BigInt(e.pollResult?.against??0n)>BigInt(e.pollResult?.for??0n)?w.Defeated:w.PendingQueue:e.status===w.InQueue&&Number(e.queueEnd)<Date.now()/1e3?w.PendingExecution:e.status}import{GetProposals as Br,SearchProposals as vr}from"@berachain/graphql/governance";async function Pn({where:e,orderBy:t,orderDirection:r,offset:a=0,perPage:o=20,text:i,...l}){try{if(o>1e3)throw new Error("perPage must be less than 1000");let n=g("governance.subgraph",l),[s]=await Promise.all([i?n.query({query:vr,variables:{offset:a,limit:o,where:e,text:i}}):n.query({query:Br,variables:{offset:a,limit:o,where:e,orderBy:t,orderDirection:r}})]);return s.data.proposals.map(d=>({...d,status:we(d)}))}catch(n){throw console.error("getAllProposals:",n),n}}var Vn=(e,t)=>{let r={};return r.title=ae({fieldOrType:"title",value:e.title}),r.description=ae({fieldOrType:"description",value:e.description}),r.forumLink=ae({fieldOrType:"forumLink",value:e.forumLink,baseUrl:t.forumLink}),r};import{GetProposal as Vr}from"@berachain/graphql/governance";async function Gn({proposalId:e,...t}){let a=await g("governance.subgraph",t).query({query:Vr,variables:{id:e}});if(a.data.proposal)return{...a.data.proposal,status:we(a.data.proposal)}}import ct from"gray-matter";var Rr=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")},dt=e=>{if(!e)return{isFrontMatter:!1,data:{title:"Loading..."},content:"",matter:"",language:"",orig:"",stringify:()=>""};let t=e?.description??"";if(ct.test(t))return{...ct(t),isFrontMatter:!0};try{let r=Rr(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 Sr}from"viem";import{ProposalStatus as kr}from"@berachain/graphql/governance";async function Un(e){R(e.publicClient);let t;"tx"in e?t=e.tx:t=await e.publicClient.getTransactionReceipt({hash:e.txHash});let r=t?.logs?Sr({abi:Qe,logs:t.logs,eventName:"ProposalCreated"})?.at(0):void 0;if(!t||!r)return null;let a=await e.publicClient.getBlock({blockNumber:t.blockNumber}),o=dt({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:kr.Pending,quorum:null,topics:o.data.topics,votes:[],executableCalls:r?.args.targets.map((i,l)=>({__typename:"ExecutableCall",id:`${t.transactionHash}-${l}`,target:i,value:String(r?.args.values[l]),calldata:r?.args.calldatas[l]})),timelock:void 0}}import{GetProposalVotes as Nr}from"@berachain/graphql/governance";async function Mn({variables:e,...t}){return g("governance.subgraph",t).query({query:Nr,variables:e})}import{Aggregation_Interval as Gr,GetChartData as xr}from"@berachain/graphql/honey";async function $n({days:e,...t}){return(await g("honey.subgraph",t).query({query:xr,variables:{interval:Gr.Day,first:e}})).data}async function zn({client:e,collateralList:t,...r}){let{config:a}=c(r);try{let o=await e.readContract({address:a.honey.factory,abi:B,functionName:"getWeights"});return t.reduce((l,n,s)=>Object.assign(l,{[n.address]:o[s]}),{})}catch(o){throw console.log(o),o}}import{erc20Abi as Ne}from"viem";async function mt({address:e,publicClient:t,chainId:r}){try{if(!t)throw new Error("Public client not found");let[a,o,i]=await Promise.all([t.readContract({address:e,abi:Ne,functionName:"decimals"}),t.readContract({address:e,abi:Ne,functionName:"name"}),t.readContract({address:e,abi:Ne,functionName:"symbol"})]),l={address:e,decimals:a,name:o,symbol:i,chainId:r};if(typeof l.decimals!="number"||typeof l.name!="string"||typeof l.symbol!="string")throw new Error(`Invalid ERC20 token. Address: ${e}`);return l}catch(a){throw console.error(a),W({cause:a})}}async function Ge({client:e,tokenData:t,preferredCollateralOrder:r,...a}){let{config:o}=c(a),[i,l]=await Promise.all([e.readContract({address:o.honey.factory,abi:B,functionName:"numRegisteredAssets"}),e.readContract({address:o.honey.factory,abi:B,functionName:"referenceCollateral"})]),n=[];for(let f=0;f<i;f++)n.push(e.readContract({address:o.honey.factory,abi:B,functionName:"registeredAssets",args:[BigInt(f)]}));let s=await Promise.all(n),u=(await Promise.all(s.map(f=>{let b=t?.find(p=>k(p,f));return b||mt({address:f,chainId:o.chainId,publicClient:e})}))).filter(f=>!!f).sort((f,b)=>s.indexOf(f.address)-s.indexOf(b.address)).map((f,b)=>({...f,order:b}));if(r?.length){let f=[];for(let b of r){let p=u.find(A=>k(A.address,b.address));p&&(f.push(p),u.splice(u.indexOf(p),1))}u.unshift(...f)}let m=u.find(f=>k(f,l));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 Tr}from"viem";async function pt({client:e,collateral:t,latestPrices:r,isPythWrapperEnabled:a,...o}){let{config:i}=c(o);try{let l=e.readContract({address:i.honey.factory,abi:B,functionName:"isBadCollateralAsset",args:[t.address]}),n=e.readContract({address:i.honey.factory,abi:B,functionName:"isPegged",args:[t.address]});if(a&&r){let u=r.prices.map(m=>Tr(m,18));n=e.readContract({address:i.honey.reader,abi:K,functionName:"isPeggedWithPrice",args:[t.address,u[0]]})}let[s,d]=await Promise.all([l,n]);return{isBlacklisted:s,isDepegged:!d}}catch(l){throw console.log(l),l}}import{parseEther as ft}from"viem";import{parseEther as Er}from"viem";async function ue({client:e,asset:t,amount:r,...a}){let{config:o}=c(a);try{let[i,l]=await Promise.all([e.readContract({address:o.honey.factory,abi:B,functionName:"vaults",args:[t]}),e.readContract({address:o.honey.factory,abi:B,functionName:"collectedFees",args:[o.honey.factory,t]})]);return await e.readContract({address:i,abi:X,functionName:"balanceOf",args:[o.honey.factory]})+Er(r??"0")-l}catch(i){throw console.log(i),i}}var Fr=ft("1");async function Vi({client:e,asset:t,amount:r,isMint:a,isPythWrapperEnabled:o,latestPrices:i,...l}){let{config:n}=c(l);try{let s=await e.readContract({address:n.honey.factory,abi:B,functionName:"globalCap"});if(s>=Fr)return!1;let[{collaterals:d},u]=await Promise.all([Ge({client:e}),Ir({client:e,asset:t,amount:r,latestPrices:i,isPythWrapperEnabled:o})]);if(!u)return;for(let m in u)if((a&&k(d[m],t)||!a&&k(d[m],t))&&u[m]>s-ye)return!0;return!1}catch(s){throw console.log(s),s}}async function Ir({client:e,asset:t,amount:r,latestPrices:a,isPythWrapperEnabled:o}){let{collaterals:i}=await Ge({client:e}),l=0n,n=[];for(let s of i){let d=await pt({client:e,collateral:t,latestPrices:a,isPythWrapperEnabled:o});if(d?.isBlacklisted||d?.isDepegged)continue;let u=await ue({client:e,asset:s.address,amount:k(s,t)?r:"0"});u&&(l+=u,n.push(u))}if(l===0n)return n;for(let s in i)n[s]=ft(n[s].toString())/l;return n}import{GetGlobalData as qr}from"@berachain/graphql/honey";async function Ni({...e}={}){return(await g("honey.subgraph",e).query({query:qr})).data}import{parseUnits as gt}from"viem";var Dr=(s=>(s.Mint="previewMintHoney",s.MintWithPrice="previewMintHoneyWithPrices",s.RequiredCollateral="previewMintCollaterals",s.RequiredCollateralWithPrice="previewMintCollateralsWithPrices",s.Redeem="previewRedeemCollaterals",s.RedeemWithPrice="previewRedeemCollateralsWithPrices",s.HoneyToRedeem="previewRedeemHoney",s.HoneyToRedeemWithPrice="previewRedeemHoneyWithPrices",s))(Dr||{});async function Fi({client:e,collateral:t,collateralList:r,amount:a,method:o,latestPrices:i,isPythWrapperEnabled:l,...n}){let{config:s}=c(n);try{let d=o==="previewMintHoney"||o==="previewRedeemHoney"||o==="previewMintHoneyWithPrices"||o==="previewRedeemHoneyWithPrices",u=gt(a,d?t.decimals:18),m,f=[t.address,u];if(l&&i){let p=i.prices.map(A=>gt(A,18));f=[t.address,u,p]}if(d){let p=await e.readContract({address:s.honey.reader,abi:K,functionName:o,args:f});m={collaterals:p[0],honey:p[1]}}else m={collaterals:await e.readContract({address:s.honey.reader,abi:K,functionName:o,args:f}),honey:u};let b=r.reduce((p,A)=>{let C=A.order;return A.address===t.address&&m.collaterals[C]===BigInt(0)?Object.assign(p,{[A.address]:m.collaterals[0]}):Object.assign(p,{[A.address]:m.collaterals[C]})},{});return b[t.address]===BigInt(0)&&(b[t.address]=m.collaterals[0]),{collaterals:b,honey:m.honey}}catch(d){throw console.log("error",d),d}}import{formatUnits as Qr}from"viem";async function Wi({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 s=await e.readContract({address:o.honey.factory,abi:B,functionName:"vaults",args:[n.address]}),[d,u,[m,f]]=await Promise.all([e.readContract({address:s,abi:X,functionName:"balanceOf",args:[i]}),e.readContract({address:i,abi:B,functionName:"collectedAssetFees",args:[n.address]}),e.readContract({address:s,abi:X,functionName:"custodyInfo"})]),b=await e.readContract({address:s,abi:X,functionName:"convertToAssets",args:[d-u]});return{...n,balance:{raw:b.toString(),formatted:Qr(b,n.decimals)},vault:m?f:s}}))}import{HermesClient as Ur}from"@pythnetwork/hermes-client";import{formatUnits as Wr}from"viem";var Lr="https://hermes.pyth.network";async function bt({priceFeedId:e}){let r=await new Ur(Lr,{}).getLatestPriceUpdates(e,{encoding:"hex",parsed:!0});return{calldata:r.binary.data.map(a=>`0x${a}`),prices:r.parsed?.flatMap(a=>Wr(BigInt(a.price.price),a.price.expo*-1))??[]}}import{parseEther as Or}from"viem";async function Yi({client:e,asset:t,amount:r,isMint:a,referenceCollateral:o,...i}){let{config:l}=c(i);if(t===o.address)return!1;try{let[n]=await Promise.all([e.readContract({address:l.honey.factory,abi:B,functionName:"relativeCap",args:[t]})]),[s,d]=await Promise.all([ue({client:e,asset:t,amount:a?r:void 0}),ue({client:e,asset:o.address,amount:a?void 0:r})]);return d===0n?s!==0n:Or((s??0n).toString())/(d??0n)>=n-ye}catch(n){throw console.log(n),n}}async function yt({client:e,priceFeedId:t,...r}){let{config:a}=c(r);try{return await e.readContract({address:a.external.pyth,abi:We,functionName:"getUpdateFee",args:[t]})}catch(o){throw console.error("getPythUpdateFee",o),o}}import{parseUnits as At}from"viem";var us=async({state:e,publicClient:t,priceFeedMap:r,collateralList:a,isPythWrapperEnabled:o,...i})=>{let{config:l}=c(i),n=_e(i),{actionType:s,fromAmount:d,collaterals:u,isBasketModeEnabled:m}=e,f=o?l.honey.pythWrapper:l.honey.factory,b=a.map(p=>p.address);if(d[0]&&b.length){let p=s==="mint";if(o&&t&&r){let C=(await bt({priceFeedId:Object.values(r)})).calldata,V=0n;try{V=await yt({client:t,priceFeedId:C})}catch{V=Je(u.length)}return({account:y})=>{let I=[C,u[0]?.address,At(d[0],(p?u[0]?.decimals:n?.decimals)??18),y,!!m];return{address:f,abi:Ue,functionName:p?"mint":"redeem",params:I,value:V}}}return({account:A})=>{let C=[u[0]?.address,At(d[0],(p?u[0]?.decimals:n?.decimals)??18),A,!!m];return{value:0n,address:f,abi:B,functionName:p?"mint":"redeem",params:C}}}throw new Error("Something went wrong while creating the Honey swap payload")};import{parseUnits as Mr}from"viem";async function gs({client:e,isMint:t,collateralList:r,latestPrices:a,isPythWrapperEnabled:o,...i}){let{config:l}=c(i);if(o&&a){if(r.length===0)return;let s=a.prices.map(u=>Mr(u,18));return await e.readContract({address:l.honey.reader,abi:K,functionName:"isBasketModeEnabledWithPrices",args:[t,s]})}return await e.readContract({address:l.honey.factory,abi:B,functionName:"isBasketModeEnabled",args:[t]})}async function hs({block:e,currentBlock:t,blockTime:r,publicClient:a}){if(te(e,"block"),R(a),t>e){let i=await a.getBlock({blockNumber:BigInt(e),includeTransactions:!1});return{timestamp:Number(i.timestamp)}}return{timestamp:N(Date.now())+r*(Number(e)-Number(t))}}import{formatUnits as xe}from"viem";var Hr=(a=>(a.Duration="duration",a.TargetRate="targetRate",a.TargetApr="targetApr",a))(Hr||{});async function vs(e,t){let[r,a,o,i,l,n]=await Promise.all([t.readContract({address:e,abi:P,functionName:"rewardsDuration"}),t.readContract({address:e,abi:P,functionName:"rewardVaultManager"}),t.readContract({address:e,abi:P,functionName:"rewardRate"}),t.readContract({address:e,abi:P,functionName:"periodFinish"}),t.readContract({address:e,abi:P,functionName:"targetRewardsPerSecond"}),t.readContract({address:e,abi:P,functionName:"minRewardDurationForTargetRate"})]),s=o*(i-BigInt(N(Date.now())))/10n**18n;return{rewardsDuration:Number(r),mode:l===0n?"duration":"targetRate",manager:a,rewardRate:xe(o,36),periodFinish:Number(i),availableRewards:xe(s,18),minRewardDurationForTargetRate:Number(n),targetRewardsPerSecond:xe(l,36)}}function Ce(e,t,r){return e?r*t*se(1)/e:null}function _r(e,t,r){return r?e*r/(t*se(1)):0}function Ss({availableRewards:e,periodFinish:t,tvl:r,bgtPrice:a,MIN_REWARD_DURATION:o,MAX_REWARD_DURATION:i,...l}){let n=N(Date.now());if(n>t)return{apr:0,duration:0,rewardRate:0,targetRate:null,periodFinish:0,mode:null};if(l.mode==="targetRate"||l.mode==="targetApr"){let m,{minRewardDurationForTargetRate:f,currentDuration:b}=l;if(l.mode==="targetRate"?m=l.rewardRate:m=_r(l.apr,a,r),m===0){let C=Math.min(b,i),V=e?e/C:0;return{apr:Ce(r,a,V),duration:C,rewardRate:V,targetRate:null,periodFinish:C+n,mode:"duration"}}let p=f||o,A=e?e/m:0;if(A<p){let C=e?e/p:0;return{apr:Ce(r,a,C),duration:p,rewardRate:C,targetRate:C.toString(),periodFinish:p+n,mode:null}}return{apr:Ce(r,a,m),duration:A,rewardRate:m,targetRate:m.toString(),periodFinish:A+n,mode:null}}let{duration:s}=l,d=e/s;return{apr:Ce(r,a,d),mode:null,targetRate:null,duration:s,rewardRate:d,periodFinish:s+n}}async function xs({address:e,account:t,...r}){let{config:a}=c(r),o=`${a.bonder}/vaults/${e}/earnings/${t}`;return He(o)}import{formatUnits as Jr}from"viem";import{GetVaults as $r}from"@berachain/graphql/pol/api";async function Pe({filter:e,publicClient:t,...r}={}){let o=await g("api",r).query({query:$r,variables:e}),i=await Promise.allSettled(o.data.polGetRewardVaults.vaults.map(async n=>{if(t)return Promise.allSettled(n.activeIncentives.map(s=>t.readContract({abi:P,address:n.address,functionName:"incentives",args:[s.tokenAddress]})))})),l=o.data.polGetRewardVaults.vaults.map((n,s)=>{let d=0,u=n.activeIncentives.map((m,f)=>{let b=Number(m.remainingAmountUsd)&&Number(m.remainingAmount)?Number(m.remainingAmountUsd)/Number(m.remainingAmount):0,p=i[s]?.status==="fulfilled"&&i[s]?.value?.[f]?.status==="fulfilled"?Jr(BigInt(i[s].value[f].value[2]),m.token.decimals):m.remainingAmount;return d+=Number(p)*Number(b),{...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:l}}import{GlobalData as jr}from"@berachain/graphql/pol/api";async function ht(e={}){let{config:t}=c(e),a=await g("api",e).query({query:jr,variables:{chain:t.bex.chainName}});return{...a.data.polGetGlobalInfo,top3EmittingValidators:a.data.top3EmittingValidators.validators,allValidatorsCount:a.data.allValidatorsCount.pagination.totalCount}}import{formatEther as Kr}from"viem";async function wt({publicClient:e,...t}){let{config:r}=c(t);R(e);try{let a=await e.readContract({address:r.tokens.bgt,abi:Z,functionName:"totalBoosts",args:[]});return Kr(a)}catch(a){throw console.log(a),a}}import{erc20Abi as Yr,formatEther as zr}from"viem";async function Ct({publicClient:e,...t}){let{config:r}=c(t);R(e);try{let a=await e.readContract({address:r.tokens.bgt,abi:Yr,functionName:"totalSupply",args:[]});return zr(a??0n)}catch(a){throw console.log(a),a}}import{GqlRewardVaultOrderBy as Xr,GqlRewardVaultOrderDirection as Zr}from"@berachain/graphql/pol/api";async function Pt(e){let{gaugeList:t}=await Pe({filter:{orderBy:Xr.Apr,orderDirection:Zr.Desc,pageSize:e,where:{includeNonWhitelisted:!1}}});return t}async function il(e){let[t,r,a,o]=await Promise.allSettled([ht(),Pt(300),Ct({publicClient:e}),wt({publicClient:e})]);return t.status==="rejected"&&J.captureException(W({cause:t.reason,level:"warning"})),r.status==="rejected"&&J.captureException(W({cause:r.reason,level:"warning"})),a.status==="rejected"&&J.captureException(W({cause:a.reason,level:"warning"})),o.status==="rejected"&&J.captureException(W({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 ea}from"@berachain/graphql/pol/subgraph";async function Bt({...e}){let t=g("pol.subgraph",e),{data:r}=await t.query({query:ea});if(r.incentiveFeeClaims.length>0){let a=r?.incentiveFeeClaims.reduce((l,n)=>l+Number(n.payoutAmount),3e4),i=(r?.incentiveFeeClaims.filter(l=>Number(l.timestamp)/1e3>Date.now()-je(1))).reduce((l,n)=>l+Number(n.payoutAmount),0);return{sumAllClaims:a,sumClaimsInLast24Hours:i}}return{sumAllClaims:0,sumClaimsInLast24Hours:0}}async function pl(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 Al({account:e,validator:t,page:r=1,perPage:a=1e3,...o}){let{config:i}=c(o),l=await fetch(`${i.pol.bribeBoostApi}/api/v1/wallets/${e.toLowerCase()}/proofs/validator/${t.toLowerCase()}?page=${r}&per_page=${a}`,{cache:"no-store"});if(!l.ok){let s=await ge(l);throw new v({message:"Failed to fetch proofs on server",cause:{error:s,result:l,account:e,validator:t},reason:s?.reason})}return await l.json()}import{formatUnits as ta,parseUnits as ra}from"viem";async function Bl({address:e,publicClient:t}){return R(t),t.readContract({address:e,abi:G,functionName:"previewRedeem",args:[ra("1",18)]}).then(r=>Number(ta(r,18))).catch(()=>0)}import{GetRewardVault as aa}from"@berachain/graphql/pol/api";async function Nl({address:e,chainName:t,...r}){let{config:a}=c(r),o=t??a.bex.chainName,i=g("api",r),{data:l}=await i.query({query:aa,variables:{vaultId:e,chain:o}});if(!l?.rewardVault)throw new Ke({resource:"Reward vault",id:e,chainId:a.chainId});return l.rewardVault}import{isSameAddress as vt}from"@berachain-foundation/berancer-sdk";import{erc20Abi as Te,formatUnits as ce}from"viem";async function ql({address:e,stakingToken:t,publicClient:r}){let a=await r.readContract({address:e,abi:P,functionName:"getWhitelistedTokens"}),i=a.findIndex(n=>vt(t,n))!==-1?await r.readContract({address:e,abi:P,functionName:"totalSupply"}):0n,l=await Promise.allSettled(a.map(async n=>{let[s,d,u,m]=await Promise.all([r.readContract({address:e,abi:P,functionName:"incentives",args:[n]}),r.readContract({address:n,abi:Te,functionName:"decimals"}),r.readContract({address:n,abi:Te,functionName:"symbol"}),r.readContract({address:n,abi:Te,functionName:"balanceOf",args:[e]})]),[f,b,p,A]=s;return{token:n,manager:A,minIncentiveRate:ce(f,d),incentiveRate:ce(b,d),remainingAmount:ce(p,d),symbol:u,decimals:d,pendingAmount:vt(t,n)?ce(m-i-p,d):ce(m-p,d)}}));return l.forEach((n,s)=>{n.status==="rejected"&&J.captureException(new v({reason:n.reason,message:"Incorrect incentives token received.",level:"error",extra:{token:a[s],address:e,error:n.reason}}))}),l.map(n=>n.status==="fulfilled"?n.value:null).filter(n=>n!==null)}async function Ul({address:e,publicClient:t}){return await t.readContract({address:e,abi:P,functionName:"stakeToken"})}import{GetSWberaVaultMetadata as oa,GqlSWberaVaultMetadataResolution as Vt}from"@berachain/graphql/pol/api";function na(e){return e==="DAY"?Vt.OneDay:Vt.SevenDays}async function Hl({window:e,...t}){let{config:r}=c(t),a=g("api",t);try{let o=await a.query({query:oa,variables:{chain:r.bex.chainName,resolution:na(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 ia,GqlVaultSnapshotDataRange as sa}from"@berachain/graphql/pol/api";async function Kl({chain:e,range:t=sa.ThirtyDays,...r}={}){let{config:a}=c(r),o=g("api",r);try{return(await o.query({query:ia,variables:{chain:e??a.bex.chainName,range:t}})).data.polGetSWberaVaultSnapshots}catch(i){throw console.error("Failed to get SW Bera Snapshots",i),i}}async function de({publicClient:e,address:t}){let r=await e.readContract({address:t,abi:G,functionName:"WITHDRAWAL_COOLDOWN"});return Number(r)}import{erc20Abi as Be}from"viem";import $ from"@berachain/utils/pkg/bignumber.js";async function iu({address:e,publicClient:t,blockTime:r,...a}){let{config:o}=c(a);R(t);let i=26;try{let[l]=await Promise.all([t.getBlock({blockTag:"latest"})]),n=Math.floor(i*60*60/r),s=l.number-BigInt(n),[d,u,m,f,b,p,A,C,V,y,I]=await Promise.all([t.readContract({address:e,abi:G,functionName:"totalAssets"}),t.readContract({address:e,abi:G,functionName:"totalSupply"}),t.readContract({address:e,abi:G,functionName:"previewRedeem",args:[10n**18n],blockNumber:l.number}),t.readContract({address:o.tokens.wbera,abi:Be,functionName:"balanceOf",args:[e]}),t.readContract({address:e,abi:G,functionName:"totalAssets",blockNumber:s}),t.readContract({address:e,abi:Be,functionName:"totalSupply",blockNumber:s}),t.readContract({address:e,abi:G,functionName:"previewRedeem",args:[10n**18n],blockNumber:s}),t.readContract({address:o.tokens.wbera,abi:Be,functionName:"balanceOf",args:[e],blockNumber:s}),t.readContract({address:o.tokens.wbera,abi:Be,functionName:"totalSupply"}),de({publicClient:t,address:e}),Bt({})]),x=new $(A.toString());return{current:{exchangeRate:new $(m.toString()).toString(),totalSupply:new $(u.toString()).dividedBy(1e18).toString(),totalAssets:new $(d.toString()).dividedBy(1e18).toString(),tvl:new $(f.toString()).dividedBy(1e18).toString()},previous:{exchangeRate:x.toString(),totalSupply:new $(p.toString()).dividedBy(1e18).toString(),totalAssets:new $(b.toString()).dividedBy(1e18).toString(),tvl:new $(C.toString()).dividedBy(1e18).toString()},totalWBeraIssued:new $(V.toString()).dividedBy(1e18).toString(),lockPeriod:y,totalBuyBacks:I.sumAllClaims,totalBuyBacksInLast24Hours:I.sumClaimsInLast24Hours}}catch(l){throw console.error("Failed to get SW Bera Vault Metadata",l),l}}function Rt(e){let t=Date.now(),r=e*1e3-t;if(r<=0)return;let a=N(r);return ze(a,!0,!0)}async function pu({contractAddress:e,accountAddress:t,publicClient:r,version:a}){let o=[];function i(l,n){let[s,d,u]=l,m=s,f=Number(u)+Number(n),b=N(Date.now()),p=f-b;if(m>0){let A=Rt(p<=0?0:f);o.push({receiptTokenAddress:e,withdrawalAmount:m,timeRemaining:A})}}switch(a){case"V1":{let[l,n]=await Promise.all([r.readContract({address:e,abi:G,functionName:"withdrawalRequests",args:[t]}),de({publicClient:r,address:e})]);return i(l,n),o}case"V2":{let[l,n]=await Promise.all([r.readContract({address:e,abi:G,functionName:"getERC721WithdrawalRequestIds",args:[t]}),de({publicClient:r,address:e})]);if(k(e,"SWBERA")){let u=await r.readContract({address:e,abi:G,functionName:"withdrawalRequests",args:[t]});i(u,n)}let d=(await Promise.all(l.map(async u=>{let m=await r.readContract({address:e,abi:G,functionName:"getERC721WithdrawalRequest",args:[u]}),{assets:f,requestTime:b}=m;if(!f||!b)throw new Error("Invalid withdrawal request");let p=f,A=Number(b)+Number(n),C=N(Date.now()),V=A-C;if(p>0){let y=Rt(V<=0?0:A);return{withdrawalAmount:p,timeRemaining:y,withdrawalRequestId:u,receiptTokenAddress:e}}return null}))).filter(u=>u!==null);return o.push(...d),o}}}async function yu({vaultAddresses:e,publicClient:t}){R(t);try{let r=await Promise.all(e.map(async o=>await t.readContract({address:o,abi:G,functionName:"totalAssets"})));return e.reduce((o,i,l)=>(o[i]=r[l],o),{})}catch(r){throw console.error("Failed to get total staked amount",r),r}}async function Pu({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 ge(a);throw new v({message:"Failed to fetch incentives on server",cause:{error:o,result:a,account:e},reason:o?.error})}return await a.json()}async function St({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 await r.readContract({address:t,abi:P,functionName:"earned",args:[e]})}import{formatEther as Ee}from"viem";async function kt({account:e,vaultAddress:t,publicClient:r}){R(r),Ve(e,"account"),Ve(t,"vaultAddress");try{let[a,o]=await Promise.all([r.readContract({address:t,abi:P,functionName:"balanceOf",args:[e]}),r.readContract({address:t,abi:P,functionName:"getTotalDelegateStaked",args:[e]})]);return{balance:a,delegated:o}}catch(a){throw console.log(a),a}}async function Nt({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:P,functionName:"totalSupply",args:[]})}catch(r){throw console.log(r),r}}async function Iu({account:e,vaultAddress:t,publicClient:r}){let[a,o,i]=await Promise.all([kt({account:e,vaultAddress:t,publicClient:r}),St({account:e,vaultAddress:t,publicClient:r}),Nt({vaultAddress:t,publicClient:r})]),l=a.balance-a.delegated,n=i>0n?Number(Number.parseFloat(Ee(a.balance))/Number.parseFloat(Ee(i))).toString():"0";return{balance:a.balance,delegatedBalance:a.delegated,withdrawableBalance:l,rewards:Ee(o),percentage:n}}import{formatUnits as Fe}from"viem";import{GetUserVaults as la}from"@berachain/graphql/pol/api";async function Hu({account:e,publicClient:t,...r}){let{config:a}=c(r),l=(await g("api",r).query({query:la,variables:{userId:e,chain:a.bex.chainName}})).data?.userVaultDeposits?.deposits;if(!l)return{totalBgtRewards:"0",vaults:[],totalStakedValue:0};let[n,s]=await Promise.all([t.multicall({allowFailure:!1,contracts:l.map(b=>({address:b.vaultAddress,abi:P,functionName:"earned",args:[e]}))}),t.multicall({allowFailure:!1,contracts:l.map(b=>({address:b.vaultAddress,abi:P,functionName:"balanceOf",args:[e]}))})]),{userVaults:d,total:u}=l.reduce((b,p,A)=>{let C=n[A],V=s[A];if(b.total+=C,!p.vault)return J.captureException(new v({message:"Deposit data from API is missing vault",level:"error",extra:{deposit:p}})),console.error("Deposit data from API is missing vault",p),b;if(C>0n||V>0n){let y=p.vault.dynamicData?.tvl&&Number(p.vault.stakingTokenAmount)!==0?Number(p.vault.dynamicData?.tvl??0)/Number(p.vault.stakingTokenAmount):null;b.userVaults.push({...p,vault:p.vault,unclaimedBgt:Fe(C,18),formattedBalance:Fe(V,p.vault.stakingToken.decimals),stakingTokenPrice:y})}return b},{userVaults:[],total:0n}),m=[...d].sort((b,p)=>{if(b.vault.isVaultWhitelisted&&!p.vault.isVaultWhitelisted)return-1;if(!b.vault.isVaultWhitelisted&&p.vault.isVaultWhitelisted)return 1;let A=Number.parseFloat(b.unclaimedBgt);return Number.parseFloat(p.unclaimedBgt)-A});return{totalStakedValue:m.reduce((b,p)=>{let A=Number(p.vault.dynamicData?.tvl??0);if(A===0)return b;let C=Number.parseFloat(p.vault.stakingTokenAmount),V=A/C;return b+V*Number(p.formattedBalance)},0),totalBgtRewards:Fe(u,18),vaults:m}}import{GetVaultHistory as ua}from"@berachain/graphql/pol/api";async function Ku({vault:e,chain:t,...r}){let{config:a}=c(r);return(await g("api",r).query({query:ua,variables:{...r,vaultId:e,chain:t??a.bex.chainName}})).data.polGetRewardVaultSnapshots}import{GetVaultValidators as ca}from"@berachain/graphql/pol/api";async function Zu({address:e,onlyActiveValidators:t,...r}){return(await g("api",r).query({query:ca,variables:{vaultId:e,isActive:t}})).data.validators.validators??[]}import{getAddress as da,zeroAddress as ma}from"viem";import{GetTokenCurrentPrices as pa}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,s,d)=>n&&d.indexOf(n)===s),i=g("api",t),{data:l}=await i.query({query:pa,variables:{chains:[r.bex.chainName],addressIn:o}});return l.tokenGetCurrentPrices.reduce((n,s)=>{if(!s.price||!s.address)return n;let d=s.address;return n[da(d)]={price:re(s.price.toString()),updatedAt:s.updatedAt,chainId:a},n[d.toLowerCase()]={price:re(s.price.toString()),updatedAt:s.updatedAt,chainId:a},k(d,"WBERA")&&(n[ma]={price:re(s.price.toString()),updatedAt:s.updatedAt,chainId:a},n[r.tokens.bgt.toLowerCase()]={price:re(s.price.toString()),updatedAt:s.updatedAt,chainId:a},n[r.tokens.bgt]={price:re(s.price.toString()),updatedAt:s.updatedAt,chainId:a}),n},{})}import{getPublicClient as fa}from"@wagmi/core";import{erc20Abi as ga,formatUnits as ba}from"viem";async function mc({items:e,account:t,config:r}){te(e,"items"),te(r,"config"),te(t,"account");let a=Object.groupBy(e,i=>i.token.chainId);return(await Promise.allSettled(Object.entries(a).map(async([i,l])=>{if(!l)return[];let n=fa(r,{chainId:Number(i)});return R(n,`publicClient ${i}`),(await n.multicall({contracts:l.map(u=>({address:u.token.address,abi:ga,functionName:"allowance",args:[t,u.spender]}))})).map((u,m)=>{let f=l[m];return u.error?void 0:{token:f.token,spender:f.spender,amount:f.amount,allowance:{raw:u.result.toString(),formatted:ba(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 ha,getWalletClient as wa,switchChain as Ca}from"@wagmi/core";import{BaseError as Pa,createWalletClient as Ba,decodeErrorResult as va,HttpRequestError as Va,http as Ra}from"viem";import{ChainId as Sa,defaultChainId as Tt}from"@berachain/config/internal";import{AbiFunctionSignatureNotFoundError as ya,decodeFunctionData as Aa}from"viem";async function Gt({publicClient:e,abi:t,...r}){let a=[...fe,...t??[]],o,i,l,n,s,d,u;if("txHash"in r){let m=await e.getTransaction({hash:r.txHash});if(!m.to)throw new F({property:"tx",value:m,expected:"Transaction",message:"Trying to get revert reason for a contract creation"});s=m.input,i=m.to,l=m.from,n=m.value,o=m.blockNumber}else if(o=r.blockNumber,i=r.to,l=r.account,n=r.value,"data"in r)s=r.data;else if("functionName"in r&&"args"in r)d=r.functionName,u=r.args;else if(!n)throw new F({property:"dataOrFunctionNameAndArgs",value:r,expected:"Hex or FunctionName and Args"});try{if(!a)if(s)await e.call({data:s,to:i,account:l,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(s){if(!a){let m=await e.call({data:s,to:i,account:l,blockNumber:o,value:n});throw new Error(`Getting revert reason for successful simulation. Data: ${s}`,{cause:m})}try{let m=Aa({abi:a,data:s});d=m.functionName,u=m.args}catch(m){throw m instanceof ya&&await e.call({data:s,to:i,account:l,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:l,blockNumber:o}),new j({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 ie({error:m,abi:a,revertIfUnknown:!0});throw m}}var ka=$e(1),xt=(e,t)=>e*(100n+BigInt(t))/100n;function Ie({nonceResult:e,onWarning:t}){if(e.status==="fulfilled"){if(e.value&&e.value>Number.MAX_SAFE_INTEGER){t?.(new v({message:"Nonce is too large. No nonce will be provided to avoid IntegerOutOfRangeError.",cause:e.value,level:"debug"}));return}return e.value}}function Na(e=Tt){return e===Sa.BEPOLIA?process.env.NEXT_PUBLIC_80069_ANVIL_IMPERSONATE_ACCOUNT==="true":process.env.NEXT_PUBLIC_80094_ANVIL_IMPERSONATE_ACCOUNT==="true"}async function Fc(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 F({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:l,onWarning:n,onError:s,onSubmission:d,wagmiConfig:u,walletClient:m,account:f,txConfirmationTimeout:b=12e4,chainId:p=Tt,impersonateAccount:A=Na(p),errorsAbi:C=[],pollingInterval:V=ka,...y}=e;i?.(e);let I="data"in y?y.data:void 0,x=[...fe,...C,..."abi"in y&&y.abi&&Array.isArray(y.abi)?y.abi:[]],T=m;if(!u){s?.(new F({property:"wagmiConfig",value:u,expected:"Config"}),e);return}if(!(T?.account?.type==="local"))try{await Ca(u,{chainId:p})}catch(S){let E=S;s?.(new v({cause:E,displayMessage:"There was an error switching to the chain."}),e);return}if(!T)try{T=await wa(u,{chainId:p})}catch(S){s?.(new v({cause:S,displayMessage:"There was an error connecting to the wallet."}),e);return}if(!T){s?.(new F({displayMessage:"There was an error connecting to the wallet.",property:"walletClient",value:T,expected:"WalletClient"}),e);return}let Q=f||T.account;if(!Q){s?.(new F({property:"account",value:Q,expected:"Account"}),e);return}let me=typeof Q=="string"?Q:Q.address,M=ha(u,{chainId:p});try{R(M)}catch(S){s?.(S,e);return}if(A){let S=Se(p);await S.impersonateAccount({address:me}),T=Ba({transport:Ra(S.transport.url),account:Q,chain:T.chain})}let q,ne={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 S=M.getTransactionCount({address:me,blockTag:"latest"}).catch(()=>{}),E={account:me,to:t,address:t,chainId:p,value:a};if(r){let D=r.map(h=>{if("abi"in h&&Array.isArray(x)&&x.push(...h.abi),"data"in h)return{to:h.address,data:h.data,value:h.value??0n};if("abi"in h&&"functionName"in h){let H="params"in h?h.params:void 0;return{to:h.address,abi:h.abi,functionName:h.functionName,args:H,value:h.value??0n}}return{to:h.address,value:h.value??0n}});if(e.enableSimulateCalls){let h=await M.simulateCalls({calls:D,account:Q}),H=h.results.findIndex(_=>_.status==="failure");if(H!==-1){if(h.block.number===null)throw new F({property:"blockNumber",value:h.block.number,expected:"bigint",message:"Block number is null"});let _=h.results[H],{reason:ve}=_.data&&_.data!=="0x"?{reason:Le(va({data:_.data,abi:x}))}:ie({error:_.error,revertIfUnknown:!1,abi:x});s?.(new j({cause:_.error,txHash:q,chainId:p,reason:ve,abi:x,input:ne,blockNumber:h.block.number}),e);return}}if(process.env.NODE_ENV==="test")throw new F({displayMessage:"Batch calls are not supported in test environment",expected:"not test",property:"NODE_ENV",value:process.env.NODE_ENV,level:"fatal"});let L=await T.sendCalls({calls:D,account:Q,forceAtomic:!0});d?.({id:L.id},e);let O=await T.waitForCallsStatus({id:L.id,pollingInterval:V,timeout:b});if(O.status==="success"){let h=O.receipts?.[0];if(!h)throw new v({message:"Call status is success but no receipt was found",cause:O,level:"error",reason:"CALL_STATUS_SUCCESS_BUT_NO_RECEIPT"});return l?.(h,e),h}throw console.error("wallet_sendCalls: Call failed",O),new j({cause:O,level:"error",input:ne,txHash:q,abi:x,chainId:p})}if(I){let[D,L,O]=await Promise.allSettled([M.call({...E,data:I}),o??M.estimateGas({...E,data:I}),S]);if(D.status==="rejected")throw D.reason;let h=L.status==="fulfilled"?xt(L.value,10):Re;q=await T.sendTransaction({data:I,to:t,account:Q,gas:h,chainId:p,nonce:Ie({nonceResult:O,onWarning(H){n?.(H,e)}}),value:a}),d?.({txHash:q},e)}else if("abi"in y&&"functionName"in y){let{abi:D,functionName:L}=y,O="params"in y?y.params:void 0,[h,H,_]=await Promise.allSettled([M.simulateContract({...E,abi:x,functionName:L,args:O,account:Q}),o??M.estimateContractGas({...E,abi:x,functionName:L,args:O}),S]);if(h.status==="rejected")throw h.reason;let ve=o??(H.status==="fulfilled"?xt(H.value,10):Re);q=await T.writeContract({...h.value.request,chainId:p,gas:ve,nonce:Ie({nonceResult:_,onWarning(qt){n?.(qt,e)}})}),d?.({txHash:q},e)}else{let[D]=await Promise.allSettled([S]);q=await T.sendTransaction({chainId:p,to:t,value:a,account:Q,nonce:Ie({nonceResult:D,onWarning(L){n?.(L,e)}})}),d?.({txHash:q},e)}process.env.NODE_ENV==="test"&&await Se(p).mine({blocks:1});let z=await M.waitForTransactionReceipt({hash:q,pollingInterval:V,timeout:b,confirmations:1});if(z.status==="success")l?.(z,e);else{let D=await Gt({publicClient:M,blockNumber:z.blockNumber,to:t,account:me,abi:x,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",D),s?.(new j({reason:D.reason,txHash:q,receipt:z,to:t,functionName:"functionName"in y?y.functionName:void 0,input:ne,chainId:p,abi:x,blockNumber:z.blockNumber}),e)}return z}catch(S){if(S instanceof v)s?.(S,e);else if(S instanceof Error){let E=ie({error:S,revertIfUnknown:!1,abi:x});if(E&&E.rootCause instanceof Pa&&"url"in E.rootCause){s?.(new ee({cause:E.rootCause,response:void 0,endpoint:{url:E.rootCause.url,type:"rpc"},statusCode:E.rootCause instanceof Va?E.rootCause.status:void 0}),e);return}s?.(new j({cause:S,to:t,txHash:q,chainId:p,abi:x,functionName:"functionName"in y?y.functionName:void 0,input:ne}),e)}else s?.(new j({cause:S,txHash:q,to:t,chainId:p,functionName:"functionName"in y?y.functionName:void 0,input:ne,abi:x}),e)}}import{GetValidators as Ga}from"@berachain/graphql/pol/api";async function Et({variables:e={},...t}={}){let{config:r}=c(t);return(await g("api",t).query({query:Ga,variables:{chain:r.bex.chainName,...e}})).data}import{isAddressEqual as xa}from"viem";async function Oc({allocation:e}){let t=await Pe({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=>xa(o.address,a.receiver))}))}import{GetValidator as Ta}from"@berachain/graphql/pol/api";async function $c({id:e,...t}){let{config:r}=c(t);return(await g("api",t).query({query:Ta,variables:{id:e,chain:r.bex.chainName}})).data}import{GetValidatorBlockStats as Ea}from"@berachain/graphql/pol/subgraph";async function zc({pubKey:e,first:t=1,...r}){let a=g("pol.subgraph",r);try{return(await a.query({query:Ea,variables:{pubKey:e,first:t}})).data}catch(o){throw console.error("GetValidatorBlockStats:",o),o}}function oe(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 Fa(e,t){return e.start.blockNumber===t.start.blockNumber&&e.weights.every((r,a)=>r.percentage===t.weights[a].percentage)}async function td({client:e,pubKey:t,...r}){let{config:a}=c(r);try{let[o,i]=await Promise.all([e.readContract({address:a.pol.beraChef,abi:U,functionName:"getActiveRewardAllocation",args:[t]}),e.readContract({address:a.pol.beraChef,abi:U,functionName:"getSetActiveRewardAllocation",args:[t]})]),[l,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}]),s=oe(o,Number(l.timestamp)),d=oe(i,Number(n.timestamp)),u=!1;return d.start.blockNumber===0?u=!0:u=!Fa(d,s),{activeRewardAllocation:s,setRewardAllocation:d,isBaseline:u,isNeverSet:d?.start.blockNumber===0}}catch(o){throw console.log("getValidatorRewardAllocation:",o),o}}function id(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:U,functionName:"getDefaultRewardAllocation",args:[]});return oe({...a,startBlock:0n},0)}import{GetValidatorByAccount as Ia}from"@berachain/graphql/pol/subgraph";async function dd({account:e,...t}){try{return(await g("pol.subgraph",t).query({query:Ia,variables:{account:e}})).data}catch(r){throw console.error("getManagedValidatorByAccount:",r),r}}async function pd({client:e,valPubKey:t}){return 5614}import{formatEther as qe}from"viem";async function Ft({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,l,n]=await Promise.all([r.readContract({address:o.tokens.bgt,abi:Z,functionName:"boosted",args:[e,t]}),r.readContract({address:o.tokens.bgt,abi:Z,functionName:"boostedQueue",args:[e,t]}),r.readContract({address:o.tokens.bgt,abi:Z,functionName:"dropBoostQueue",args:[e,t]})]);return{pubkey:t,activeBoostAmount:qe(i),queuedBoostAmount:qe(l[1]),queuedDropBoostAmount:qe(n[1]),queuedBoostStartBlock:l[0],queuedDropBoostStartBlock:n[0],hasPendingBoosts:Number(l[1])>0||Number(n[1])>0,hasActiveBoosts:Number(i)>0}}import{GetUserValidatorInformation as qa}from"@berachain/graphql/pol/subgraph";async function It({account:e,block:t,...r}){return await g("pol.subgraph",r).query({query:qa,variables:{address:e.toLowerCase(),block:t}})}async function Sd({account:e,publicClient:t,chain:r,...a}){let{config:o}=c(a),i=r??o.bex.chainName,l=await It({account:e}),[n,s]=await Promise.all([Et({variables:{chain:i,where:{idIn:l.data.userValidatorInformations.map(d=>d.validator.id)}}}),t&&Xe({lastBlockTimestamp:l.data._meta?.block.timestamp,blockTime:o.averageBlockTime})?Promise.all(l.data.userValidatorInformations.map(d=>Ft({account:e,pubkey:d.validator.publicKey,publicClient:t}))):void 0]);return n?.validators.validators.map(d=>{let u=s?s.find(m=>m.pubkey.toLowerCase()===d.pubkey.toLowerCase()):l.data.userValidatorInformations.find(m=>m.validator.id.toLowerCase()===d.id.toLowerCase());if(!u)throw new Error("User deposited not found");return{...d,userBoosts:{pubkey:"pubkey"in u?u.pubkey:u.validator.publicKey,activeBoostAmount:u?.activeBoostAmount,queuedBoostAmount:u?.queuedBoostAmount,queuedBoostStartBlock:Number(u?.queuedBoostStartBlock),queuedDropBoostAmount:u?.queuedDropBoostAmount,queuedDropBoostStartBlock:Number(u?.queuedDropBoostStartBlock),hasPendingBoosts:Number(u?.queuedBoostAmount)>0||Number(u?.queuedDropBoostAmount)>0,hasActiveBoosts:Number(u?.activeBoostAmount)>0}}})}var Da=[{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:N(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:N(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:N(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:N(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:N(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:N(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:N(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 Gd(e){return await new Promise(t=>setTimeout(t,2e3)),e==="0x4C368fFE3650379d6318C8d4630bc51f8Ad12bB6"?Da:[]}import{GetValidatorAnalytics as Qa}from"@berachain/graphql/pol/subgraph";async function Id({pubkey:e,dayRange:t,...r}){return(await g("pol.subgraph",r).query({query:Qa,variables:{pubKey:e,timestamp:Ye(t).toString()}})).data}async function Ud({client:e,pubKey:t,...r}){let{config:a}=c(r),o=await e.readContract({address:a.pol.beraChef,abi:U,functionName:"getValCommissionOnIncentiveTokens",args:[t]});return Number(o??0n)/1e4}var Od=(e,t,r)=>{if(!t||!e)return 0;let a=se(1)/r;return(t?a*(Number(e.dynamicData?.stakedBeraAmount)/t):0)*Number.parseFloat(e.dynamicData?.rewardRate??"0")};async function Jd({client:e,pubKey:t,...r}){let{config:a}=c(r);try{return await e.readContract({address:a.depositContract,abi:pe,functionName:"getOperator",args:[t]})}catch(o){throw console.log("getValidatorOperatorAddress:",o),o}}async function Yd({client:e,pubKey:t,...r}){let{config:a}=c(r),o=await e.readContract({address:a.pol.beraChef,abi:U,functionName:"getValQueuedCommissionOnIncentiveTokens",args:[t]});return{blockNumberLast:o.blockNumberLast,commissionRate:Number(o.commissionRate)/1e4}}async function em({client:e,pubKey:t,...r}){let{config:a}=c(r);try{return await e.readContract({address:a.depositContract,abi:pe,functionName:"queuedOperator",args:[t]})}catch(o){throw console.log("getValidatorQueuedOperatorAddress:",o),o}}async function nm({client:e,pubKey:t,...r}){let{config:a}=c(r);try{let o=await e.readContract({address:a.pol.beraChef,abi:U,functionName:"getQueuedRewardAllocation",args:[t]});return oe(o,0)}catch(o){throw console.log("getValidatorQueuedRewardAllocation:",o),o}}export{Oa as a,Ae as b,g as c,io as d,rt as e,yo as f,ko as g,Eo as h,Qo as i,ot as j,Ko as k,en as l,sn as m,mn as n,ae as o,yn as p,we as q,Pn as r,Vn as s,Gn as t,dt as u,Un as v,Mn as w,$n as x,zn as y,mt as z,Ge as A,pt as B,Vi as C,Ni as D,Dr as E,Fi as F,Wi as G,bt as H,Yi as I,yt as J,us as K,gs as L,hs as M,Hr as N,vs as O,Ss as P,xs as Q,Pe as R,il as S,Bt as T,pl as U,Al as V,Bl as W,Nl as X,ql as Y,Ul as Z,Hl as _,Kl as $,de as aa,iu as ba,pu as ca,yu as da,Pu as ea,St as fa,Iu as ga,Hu as ha,Ku as ia,Zu as ja,sc as ka,mc as la,Na as ma,Fc as na,Et as oa,Oc as pa,$c as qa,zc as ra,oe as sa,Fa as ta,td as ua,id as va,sd as wa,dd as xa,pd as ya,Ft as za,Sd as Aa,Gd as Ba,Id as Ca,Ud as Da,Od as Ea,Jd as Fa,Yd as Ga,em as Ha,nm as Ia};
4
- //# sourceMappingURL=chunk-G6NA6NSM.mjs.map