@berachain/berajs 0.1.2 → 0.2.0

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 (453) hide show
  1. package/dist/{BeraError-D1HS_rbb.d.cts → BeraError-_mQdkanr.d.cts} +35 -10
  2. package/dist/{BeraError-D1HS_rbb.d.ts → BeraError-_mQdkanr.d.ts} +35 -10
  3. package/dist/HoneyConfigProvider-CK6mOKFH.d.ts +390 -0
  4. package/dist/HoneyConfigProvider-Ca3ouozs.d.cts +390 -0
  5. package/dist/{RequestError-D8AE6xnI.d.cts → RequestError-A8XJ6QR9.d.cts} +1 -1
  6. package/dist/{RequestError-m4jxyM7D.d.ts → RequestError-Dk97z8rm.d.ts} +1 -1
  7. package/dist/abi/exports.cjs +2 -0
  8. package/dist/abi/exports.cjs.map +1 -0
  9. package/dist/abi/{index.d.cts → exports.d.cts} +12369 -9122
  10. package/dist/abi/{index.d.ts → exports.d.ts} +12369 -9122
  11. package/dist/abi/exports.mjs +2 -0
  12. package/dist/abi/exports.mjs.map +1 -0
  13. package/dist/actions/exports.cjs +2 -0
  14. package/dist/actions/exports.cjs.map +1 -0
  15. package/dist/actions/{index.d.cts → exports.d.cts} +80 -107
  16. package/dist/actions/{index.d.ts → exports.d.ts} +80 -107
  17. package/dist/actions/exports.mjs +2 -0
  18. package/dist/actions/exports.mjs.map +1 -0
  19. package/dist/chunk-575OK77P.mjs +2 -0
  20. package/dist/chunk-575OK77P.mjs.map +1 -0
  21. package/dist/chunk-7GWTHOLO.mjs +2 -0
  22. package/dist/chunk-7GWTHOLO.mjs.map +1 -0
  23. package/dist/chunk-7SC4VD3U.cjs +2 -0
  24. package/dist/chunk-7SC4VD3U.cjs.map +1 -0
  25. package/dist/chunk-BHNQX4XC.mjs +2 -0
  26. package/dist/chunk-BHNQX4XC.mjs.map +1 -0
  27. package/dist/chunk-BOYZVULX.cjs +2 -0
  28. package/dist/chunk-BOYZVULX.cjs.map +1 -0
  29. package/dist/chunk-C3FHGFLK.mjs +2 -0
  30. package/dist/chunk-C3FHGFLK.mjs.map +1 -0
  31. package/dist/chunk-C3G5KXCH.mjs +2 -0
  32. package/dist/chunk-C3G5KXCH.mjs.map +1 -0
  33. package/dist/chunk-CYKCYPFR.cjs +2 -0
  34. package/dist/chunk-CYKCYPFR.cjs.map +1 -0
  35. package/dist/chunk-F4BKSBEM.mjs +2 -0
  36. package/dist/chunk-F4BKSBEM.mjs.map +1 -0
  37. package/dist/chunk-FL2N3XHK.cjs +2 -0
  38. package/dist/chunk-FL2N3XHK.cjs.map +1 -0
  39. package/dist/chunk-G6NA6NSM.mjs +4 -0
  40. package/dist/chunk-G6NA6NSM.mjs.map +1 -0
  41. package/dist/chunk-H2QSRMVS.mjs +2 -0
  42. package/dist/chunk-H2QSRMVS.mjs.map +1 -0
  43. package/dist/chunk-IJM76AWK.cjs +4 -0
  44. package/dist/chunk-IJM76AWK.cjs.map +1 -0
  45. package/dist/chunk-MTS5SZLA.mjs +2 -0
  46. package/dist/chunk-MTS5SZLA.mjs.map +1 -0
  47. package/dist/chunk-MUNAP5TM.cjs +2 -0
  48. package/dist/chunk-MUNAP5TM.cjs.map +1 -0
  49. package/dist/chunk-NAXAZJJY.mjs +2 -0
  50. package/dist/chunk-NAXAZJJY.mjs.map +1 -0
  51. package/dist/chunk-OGJMSGB2.mjs +2 -0
  52. package/dist/chunk-OGJMSGB2.mjs.map +1 -0
  53. package/dist/chunk-OIYXOKTT.cjs +2 -0
  54. package/dist/chunk-OIYXOKTT.cjs.map +1 -0
  55. package/dist/chunk-OS5AJMYJ.cjs +2 -0
  56. package/dist/chunk-OS5AJMYJ.cjs.map +1 -0
  57. package/dist/chunk-Q3SCM6WL.mjs +2 -0
  58. package/dist/chunk-Q3SCM6WL.mjs.map +1 -0
  59. package/dist/chunk-SWMJQOH6.cjs +2 -0
  60. package/dist/chunk-SWMJQOH6.cjs.map +1 -0
  61. package/dist/chunk-TEBJWAVU.mjs +2 -0
  62. package/dist/chunk-TEBJWAVU.mjs.map +1 -0
  63. package/dist/chunk-TJWKS54T.mjs +2 -0
  64. package/dist/chunk-TJWKS54T.mjs.map +1 -0
  65. package/dist/chunk-UQUWMHVF.cjs +2 -0
  66. package/dist/chunk-UQUWMHVF.cjs.map +1 -0
  67. package/dist/chunk-UXUWSRVV.cjs +2 -0
  68. package/dist/chunk-UXUWSRVV.cjs.map +1 -0
  69. package/dist/chunk-VP7XUOSI.cjs +2 -0
  70. package/dist/chunk-VP7XUOSI.cjs.map +1 -0
  71. package/dist/chunk-VXL2ZZ4X.cjs +2 -0
  72. package/dist/chunk-VXL2ZZ4X.cjs.map +1 -0
  73. package/dist/chunk-WRFDB3QJ.cjs +2 -0
  74. package/dist/chunk-WRFDB3QJ.cjs.map +1 -0
  75. package/dist/chunk-WTCBORPB.cjs +2 -0
  76. package/dist/chunk-WTCBORPB.cjs.map +1 -0
  77. package/dist/chunk-XNJLSA6P.cjs +2 -0
  78. package/dist/chunk-XNJLSA6P.cjs.map +1 -0
  79. package/dist/chunk-YQGZMWDT.mjs +2 -0
  80. package/dist/chunk-YQGZMWDT.mjs.map +1 -0
  81. package/dist/chunk-YXLFOEZN.mjs +2 -0
  82. package/dist/chunk-YXLFOEZN.mjs.map +1 -0
  83. package/dist/chunk-ZAKA4TGK.cjs +2 -0
  84. package/dist/chunk-ZAKA4TGK.cjs.map +1 -0
  85. package/dist/chunk-ZQRACIGR.mjs +2 -0
  86. package/dist/chunk-ZQRACIGR.mjs.map +1 -0
  87. package/dist/contexts/exports.cjs +2 -0
  88. package/dist/contexts/exports.cjs.map +1 -0
  89. package/dist/contexts/{index.d.ts → exports.d.cts} +19 -28
  90. package/dist/contexts/{index.d.cts → exports.d.ts} +19 -28
  91. package/dist/contexts/exports.mjs +2 -0
  92. package/dist/contexts/exports.mjs.map +1 -0
  93. package/dist/contracts-CQIPk0Jc.d.cts +74 -0
  94. package/dist/contracts-CQIPk0Jc.d.ts +74 -0
  95. package/dist/{defaultFlags-V-tJs2K8.d.cts → defaultFlags-d0kPbT0i.d.cts} +1 -1
  96. package/dist/{defaultFlags-V-tJs2K8.d.ts → defaultFlags-d0kPbT0i.d.ts} +1 -1
  97. package/dist/dex-C_BB0b0O.d.cts +37 -0
  98. package/dist/dex-C_BB0b0O.d.ts +37 -0
  99. package/dist/enum/exports.cjs +2 -0
  100. package/dist/enum/exports.cjs.map +1 -0
  101. package/dist/enum/exports.d.cts +24 -0
  102. package/dist/enum/exports.d.ts +24 -0
  103. package/dist/enum/exports.mjs +2 -0
  104. package/dist/enum/exports.mjs.map +1 -0
  105. package/dist/errors/exports.cjs +2 -0
  106. package/dist/errors/exports.cjs.map +1 -0
  107. package/dist/errors/exports.d.cts +385 -0
  108. package/dist/errors/exports.d.ts +385 -0
  109. package/dist/errors/exports.mjs +2 -0
  110. package/dist/{getValidatorQueuedOperatorAddress-9xY2RUGe.d.cts → getValidatorQueuedOperatorAddress-BX35p2Lv.d.ts} +125 -15
  111. package/dist/{getValidatorQueuedOperatorAddress-Ne2zoiiV.d.ts → getValidatorQueuedOperatorAddress-It0GsdvQ.d.cts} +125 -15
  112. package/dist/global.d-Ba-NIojH.d.cts +474 -0
  113. package/dist/global.d-By70bEv2.d.ts +474 -0
  114. package/dist/honey-CYm0RWf4.d.cts +14 -0
  115. package/dist/honey-CYm0RWf4.d.ts +14 -0
  116. package/dist/hooks/exports.cjs +4 -0
  117. package/dist/hooks/exports.cjs.map +1 -0
  118. package/dist/hooks/{index.d.cts → exports.d.cts} +223 -173
  119. package/dist/hooks/{index.d.ts → exports.d.ts} +223 -173
  120. package/dist/hooks/exports.mjs +4 -0
  121. package/dist/hooks/exports.mjs.map +1 -0
  122. package/dist/{BexStatusProvider-nS3NcdxI.d.cts → transactionStore-BvStaXf3.d.ts} +41 -1
  123. package/dist/{BexStatusProvider-nS3NcdxI.d.ts → transactionStore-CQrGYSY2.d.cts} +41 -1
  124. package/dist/{txnEnum-BQKDfaeH.d.cts → txnEnum-BYNbCxla.d.cts} +1 -0
  125. package/dist/{txnEnum-BQKDfaeH.d.ts → txnEnum-BYNbCxla.d.ts} +1 -0
  126. package/dist/types/exports.cjs +1 -0
  127. package/dist/types/exports.cjs.map +1 -0
  128. package/dist/types/exports.d.cts +58 -0
  129. package/dist/types/exports.d.ts +58 -0
  130. package/dist/types/exports.mjs +1 -0
  131. package/dist/{useHoneySwapState-C-9BV4VB.d.cts → useHoneySwapState-B-vmIP1b.d.cts} +1 -1
  132. package/dist/{useHoneySwapState-CUY5Sm1b.d.ts → useHoneySwapState-D1DKG_Of.d.ts} +1 -1
  133. package/dist/utils/exports.cjs +2 -0
  134. package/dist/utils/exports.cjs.map +1 -0
  135. package/dist/utils/{index.d.cts → exports.d.cts} +83 -20
  136. package/dist/utils/{index.d.ts → exports.d.ts} +83 -20
  137. package/dist/utils/exports.mjs +2 -0
  138. package/dist/utils/exports.mjs.map +1 -0
  139. package/package.json +16 -17
  140. package/src/abi/{index.ts → exports.ts} +3 -0
  141. package/src/abi/pol/LSTStakerVault.ts +2032 -0
  142. package/src/abi/utils/openChainErrors.ts +71 -30
  143. package/src/abi/utils/thirdwebMinimalAccount.ts +616 -0
  144. package/src/actions/clients/BeraApolloClient.ts +8 -6
  145. package/src/actions/dex/__tests__/aggregators.unit.test.ts +2 -5
  146. package/src/actions/dex/aggregators/base.ts +74 -16
  147. package/src/actions/dex/aggregators/bex.ts +54 -74
  148. package/src/actions/dex/aggregators/bgt.ts +31 -8
  149. package/src/actions/dex/aggregators/{enso.ts → enso/enso.ts} +18 -14
  150. package/src/actions/dex/aggregators/enso/ensoErc4626.debug.test.ts +37 -0
  151. package/src/actions/dex/aggregators/enso/ensoErc4626.ts +176 -0
  152. package/src/actions/dex/aggregators/erc4626.ts +122 -0
  153. package/src/actions/dex/aggregators/fly.ts +59 -53
  154. package/src/actions/dex/aggregators/haiku.ts +52 -54
  155. package/src/actions/dex/aggregators/honey.ts +54 -45
  156. package/src/actions/dex/aggregators/kyberswap.ts +41 -39
  157. package/src/actions/dex/aggregators/oogabooga.ts +47 -46
  158. package/src/actions/dex/aggregators/openOcean.ts +51 -46
  159. package/src/actions/dex/aggregators/wbera.ts +54 -42
  160. package/src/actions/dex/b-sdk.ts +5 -2
  161. package/src/actions/dex/getIsTokenExploited.ts +2 -2
  162. package/src/actions/enso/{zap.ts → getEnsoSwapBundle.ts} +4 -5
  163. package/src/actions/enso/getEnsoUserTokensWithBalances.debug.test.ts +73 -0
  164. package/src/actions/enso/{getEnsoUserToken.ts → getEnsoUserTokensWithBalances.ts} +42 -30
  165. package/src/actions/enso/util.ts +1 -1
  166. package/src/actions/{index.ts → exports.ts} +5 -0
  167. package/src/actions/governance/__tests__/checkProposalField.unit.test.ts +1 -1
  168. package/src/actions/governance/__tests__/getQuorum.integration.test.ts +1 -1
  169. package/src/actions/governance/checkProposalField.ts +1 -1
  170. package/src/actions/governance/computeActualStatus.ts +1 -1
  171. package/src/actions/governance/getBodyErrors.ts +1 -1
  172. package/src/actions/governance/getDecodedFunctionData.ts +1 -4
  173. package/src/actions/governance/getProposalDetails.ts +2 -2
  174. package/src/actions/governance/getProposalFromTx.ts +1 -2
  175. package/src/actions/governance/getProposalParams.ts +7 -8
  176. package/src/actions/governance/getQuorum.ts +1 -2
  177. package/src/actions/honey/getCollateralWeights.ts +1 -1
  178. package/src/actions/honey/getHoneyCollaterals.ts +1 -0
  179. package/src/actions/honey/getHoneyVaultsBalance.ts +51 -55
  180. package/src/actions/honey/getSwapPayload.ts +37 -35
  181. package/src/actions/honey/tests/pyth.integration.test.ts +0 -1
  182. package/src/actions/pol/__tests__/getAllValidators.integration.test.ts +1 -1
  183. package/src/actions/pol/getEarnedStakedBeraVault.ts +31 -0
  184. package/src/actions/pol/getGlobalData.ts +14 -13
  185. package/src/actions/pol/getLSTStakeConfig.ts +67 -0
  186. package/src/actions/pol/getMarkets.ts +1 -1
  187. package/src/actions/pol/getRewardProofsByValidator.ts +1 -1
  188. package/src/actions/pol/getRewardVaultIncentives.ts +3 -5
  189. package/src/actions/pol/getRewardVaults.ts +2 -3
  190. package/src/actions/pol/getSWBeraVaultMetadata.ts +7 -5
  191. package/src/actions/pol/getSWBeraWithdrawal.ts +41 -27
  192. package/src/actions/pol/getStakeWithdrawalCooldown.ts +5 -7
  193. package/src/actions/pol/getStakingDailyAssets.ts +21 -0
  194. package/src/actions/pol/getStakingTokenInformation.ts +3 -4
  195. package/src/actions/pol/getTotalStakedAmount.ts +47 -0
  196. package/src/actions/pol/getUserClaimableIncentives.ts +1 -1
  197. package/src/actions/pol/getUserVaults.ts +8 -6
  198. package/src/actions/pol/getUserVaultsBalance.ts +4 -16
  199. package/src/actions/prices/getTokenCurrentPrices.ts +8 -3
  200. package/src/actions/tokens/getAllowances.ts +68 -41
  201. package/src/actions/tokens/getTokenInformation.ts +4 -1
  202. package/src/actions/tokens/getTokens.ts +1 -1
  203. package/src/actions/tokens/getUnderlyingToken.ts +53 -0
  204. package/src/actions/tokens/getWalletBalances.integration.test.ts +53 -14
  205. package/src/actions/tokens/getWalletBalances.ts +69 -43
  206. package/src/actions/transactions/beraWriteContract.integration.test.ts +18 -6
  207. package/src/actions/transactions/beraWriteContract.ts +3 -3
  208. package/src/actions/validators/getUserActiveValidators.ts +2 -3
  209. package/src/actions/validators/getUserBoostsOnValidator.ts +2 -3
  210. package/src/contexts/BeraFlags/defaultFlags.ts +4 -0
  211. package/src/contexts/SwrFallback.tsx +13 -3
  212. package/src/contexts/TokensProvider.tsx +35 -8
  213. package/src/{hooks/transactions → contexts}/TransactionStoreContext.tsx +32 -4
  214. package/src/contexts/block-time-provider.tsx +1 -1
  215. package/src/contexts/{index.ts → exports.ts} +1 -1
  216. package/src/data/contracts.ts +16 -1
  217. package/src/enum/contracts.ts +13 -0
  218. package/src/enum/dex.ts +29 -0
  219. package/src/enum/{index.ts → exports.ts} +3 -0
  220. package/src/enum/governance.ts +61 -0
  221. package/src/enum/honey.ts +12 -0
  222. package/src/enum/txnEnum.ts +1 -0
  223. package/src/errors/BeraError.ts +50 -11
  224. package/src/errors/BeraMonitoring.ts +66 -0
  225. package/src/errors/BeraTracing.ts +79 -0
  226. package/src/errors/BeraTracing.unit.test.ts +198 -0
  227. package/src/errors/RequestError.ts +2 -2
  228. package/src/errors/assert.ts +4 -2
  229. package/src/errors/assert.unit.test.ts +6 -2
  230. package/src/errors/errorMap.ts +16 -6
  231. package/src/errors/{index.ts → exports.ts} +7 -0
  232. package/src/errors/getErrorMessage.ts +22 -3
  233. package/src/errors/getRevertReason.integration.test.ts +17 -5
  234. package/src/errors/getRevertReason.ts +41 -2
  235. package/src/errors/initBeraError.ts +52 -7
  236. package/src/errors/parseViemError.ts +114 -27
  237. package/src/errors/severity.ts +12 -0
  238. package/src/hooks/bend/useGetConvertToAssets.ts +3 -2
  239. package/src/hooks/dex/useAggregatorsQuotes.ts +126 -365
  240. package/src/hooks/dex/useAllUserPools.ts +1 -1
  241. package/src/hooks/dex/useApiPool.ts +1 -1
  242. package/src/hooks/dex/useCreatePool.ts +6 -5
  243. package/src/hooks/dex/useExploitedTokens.ts +1 -1
  244. package/src/hooks/dex/useLiquidityMismatch.ts +2 -5
  245. package/src/hooks/dex/useLpPosition.ts +21 -20
  246. package/src/hooks/dex/useMultipleTokenApprovalsWithSlippage.ts +40 -29
  247. package/src/hooks/dex/usePollPoolCreationRelayerApproval.ts +1 -1
  248. package/src/hooks/dex/usePoolEvents.ts +1 -1
  249. package/src/hooks/dex/usePools.ts +1 -1
  250. package/src/hooks/dex/usePriceImpact.ts +40 -0
  251. package/src/hooks/dex/useSingleAggregatorQuote.ts +350 -0
  252. package/src/hooks/enso/useBendZapSupply.ts +216 -0
  253. package/src/hooks/enso/useEnsoSwapBundle.ts +107 -0
  254. package/src/hooks/enso/useEnsoUserTokensWithBalances.ts +43 -0
  255. package/src/hooks/enso/useZapStakeBera.ts +113 -0
  256. package/src/hooks/{index.ts → exports.ts} +18 -7
  257. package/src/hooks/governance/useCreateProposal.ts +8 -8
  258. package/src/hooks/governance/usePollAllProposals.ts +1 -1
  259. package/src/hooks/governance/usePollProposal.ts +1 -1
  260. package/src/hooks/governance/usePollProposalThreshold.ts +1 -1
  261. package/src/hooks/governance/usePollUserDelegates.ts +1 -1
  262. package/src/hooks/governance/useProposalState.ts +2 -2
  263. package/src/hooks/honey/useCappedGlobally.ts +2 -1
  264. package/src/hooks/honey/useCappedRelatively.ts +1 -1
  265. package/src/hooks/honey/useCollateralWeights.ts +2 -1
  266. package/src/hooks/honey/useHoneyAlerts.ts +11 -11
  267. package/src/hooks/honey/useHoneyBalances.ts +7 -3
  268. package/src/hooks/honey/useHoneyGlobalData.ts +2 -1
  269. package/src/hooks/honey/useHoneySwapState.ts +2 -1
  270. package/src/hooks/honey/useHoneyVaultsBalance.ts +1 -1
  271. package/src/hooks/honey/useIsBadCollateralAsset.ts +2 -1
  272. package/src/hooks/honey/useIsBasketModeEnabled.ts +1 -1
  273. package/src/hooks/honey/usePythLatestPrices.ts +1 -1
  274. package/src/hooks/pol/useOnChainRewardVault.ts +3 -2
  275. package/src/hooks/pol/usePollGlobalData.ts +1 -1
  276. package/src/hooks/pol/usePollMarkets.ts +1 -1
  277. package/src/hooks/pol/useQueuedBeraUnlock.ts +17 -15
  278. package/src/hooks/pol/useRewardTokenToBeraRate.ts +6 -3
  279. package/src/hooks/pol/useRewardVault.ts +1 -1
  280. package/src/hooks/pol/useRewardVaults.ts +1 -1
  281. package/src/hooks/pol/useSWBeraVaultMetadata.ts +35 -0
  282. package/src/hooks/pol/useStakedAPR.ts +38 -0
  283. package/src/hooks/pol/useStakedData.ts +117 -0
  284. package/src/hooks/pol/useStakedSnapshots.ts +52 -0
  285. package/src/hooks/pol/useTotalStakedAmount.ts +30 -0
  286. package/src/hooks/pol/useUserVaultInfo.ts +1 -1
  287. package/src/hooks/pol/useVaultValidators.ts +1 -1
  288. package/src/hooks/tokens/useMultipleTokenInformation.ts +15 -6
  289. package/src/hooks/tokens/usePollAllowances.ts +15 -19
  290. package/src/hooks/tokens/usePollBalance.ts +8 -4
  291. package/src/hooks/tokens/usePollWalletBalances.ts +14 -11
  292. package/src/hooks/tokens/useStakingTokenInformation.ts +2 -1
  293. package/src/hooks/tokens/useTokenCurrentPrice.ts +4 -2
  294. package/src/hooks/tokens/useTokenCurrentPrices.ts +92 -13
  295. package/src/hooks/tokens/useTokenInformation.ts +11 -6
  296. package/src/hooks/tokens/useTokenPrice.ts +21 -0
  297. package/src/hooks/tokens/useTokenPrices.ts +133 -0
  298. package/src/hooks/tokens/useTokens.ts +1 -0
  299. package/src/hooks/tokens/useUnderlyingAsset.ts +23 -0
  300. package/src/hooks/transactions/transactionStore.ts +86 -65
  301. package/src/hooks/transactions/transactionStore.unit.test.ts +54 -1
  302. package/src/hooks/transactions/useAddRecentTransaction.ts +1 -1
  303. package/src/hooks/transactions/useRecentTransactions.ts +1 -1
  304. package/src/hooks/transactions/useSetTransactionStatus.ts +31 -0
  305. package/src/hooks/useContractWrite/useBeraContractWrite.ts +2 -1
  306. package/src/hooks/validators/useAllValidators.ts +1 -1
  307. package/src/hooks/validators/useApiValidator.ts +1 -1
  308. package/src/hooks/validators/useDailyValidatorBlockStats.ts +1 -1
  309. package/src/hooks/validators/useManagedValidatorByAccount.ts +1 -1
  310. package/src/hooks/validators/useManagedValidatorRole.ts +1 -1
  311. package/src/hooks/validators/useOnChainValidator.ts +1 -1
  312. package/src/hooks/validators/useStakingPoolBatch.ts +1 -1
  313. package/src/hooks/validators/useUserActiveValidators.ts +1 -1
  314. package/src/hooks/validators/useUserBoostsOnValidator.ts +1 -1
  315. package/src/hooks/validators/useUserClaimableIncentives.ts +8 -8
  316. package/src/hooks/validators/useValidator.ts +1 -1
  317. package/src/hooks/validators/useValidatorAnalytics.ts +1 -1
  318. package/src/hooks/validators/useValidatorCommission.ts +1 -1
  319. package/src/hooks/validators/useValidatorQueuedCommission.ts +1 -1
  320. package/src/hooks/validators/useValidatorQueuedOperatorAddress.ts +1 -1
  321. package/src/hooks/validators/useValidatorQueuedRewardAllocation.ts +1 -1
  322. package/src/hooks/validators/useValidatorRewardAllocation.ts +1 -1
  323. package/src/types/{dex.ts → dex.d.ts} +96 -67
  324. package/src/types/{enso.ts → enso.d.ts} +1 -1
  325. package/src/types/exports.ts +8 -0
  326. package/src/types/{global.ts → global.d.ts} +1 -30
  327. package/src/types/{governance.ts → governance.d.ts} +2 -64
  328. package/src/types/{honeySwap.ts → honeySwap.d.ts} +1 -13
  329. package/src/types/{pol.ts → pol.d.ts} +12 -1
  330. package/src/types/staking.d.ts +22 -0
  331. package/src/utils/createEmitter.ts +122 -0
  332. package/src/utils/createEmitter.unit.test.ts +149 -0
  333. package/src/utils/{index.ts → exports.ts} +3 -2
  334. package/src/utils/filter.ts +34 -0
  335. package/src/utils/formatNumber.ts +1 -1
  336. package/src/utils/formatNumber.unit.test.ts +2 -1
  337. package/src/utils/formatTokenList.ts +4 -10
  338. package/src/utils/getHoneySwapMessage.test.ts +1 -2
  339. package/src/utils/getServerSideClient.ts +4 -5
  340. package/src/utils/isDifferenceExceedingThreshold.ts +1 -1
  341. package/src/utils/layerZeroScan.ts +122 -0
  342. package/src/utils/math.ts +1 -1
  343. package/src/utils/parseWhiskToken.ts +15 -0
  344. package/src/utils/poolNamings.ts +1 -1
  345. package/src/utils/tokens.ts +23 -7
  346. package/dist/HoneyConfigProvider-6PXZJMSU.d.cts +0 -562
  347. package/dist/HoneyConfigProvider-CwDFrt02.d.ts +0 -562
  348. package/dist/abi/index.cjs +0 -2
  349. package/dist/abi/index.cjs.map +0 -1
  350. package/dist/abi/index.mjs +0 -2
  351. package/dist/actions/index.cjs +0 -2
  352. package/dist/actions/index.cjs.map +0 -1
  353. package/dist/actions/index.mjs +0 -2
  354. package/dist/aggregatorsRouter-Cny4B_MB.d.cts +0 -593
  355. package/dist/aggregatorsRouter-Cny4B_MB.d.ts +0 -593
  356. package/dist/chunk-22MQVFHP.cjs +0 -2
  357. package/dist/chunk-22MQVFHP.cjs.map +0 -1
  358. package/dist/chunk-3TKSVFZ3.mjs +0 -2
  359. package/dist/chunk-3TKSVFZ3.mjs.map +0 -1
  360. package/dist/chunk-6VF3RF53.cjs +0 -3
  361. package/dist/chunk-6VF3RF53.cjs.map +0 -1
  362. package/dist/chunk-6W22TFYA.mjs +0 -2
  363. package/dist/chunk-6W22TFYA.mjs.map +0 -1
  364. package/dist/chunk-AMRJ4B36.mjs +0 -2
  365. package/dist/chunk-AMRJ4B36.mjs.map +0 -1
  366. package/dist/chunk-DS2ZDVKU.mjs +0 -2
  367. package/dist/chunk-DS2ZDVKU.mjs.map +0 -1
  368. package/dist/chunk-ED43NYSE.cjs +0 -2
  369. package/dist/chunk-ED43NYSE.cjs.map +0 -1
  370. package/dist/chunk-EU4WFADK.cjs +0 -2
  371. package/dist/chunk-EU4WFADK.cjs.map +0 -1
  372. package/dist/chunk-HCTFDGXL.mjs +0 -2
  373. package/dist/chunk-HCTFDGXL.mjs.map +0 -1
  374. package/dist/chunk-IOSYBHKU.mjs +0 -2
  375. package/dist/chunk-IOSYBHKU.mjs.map +0 -1
  376. package/dist/chunk-JMKLDDKY.cjs +0 -2
  377. package/dist/chunk-JMKLDDKY.cjs.map +0 -1
  378. package/dist/chunk-KMKUXP2S.mjs +0 -3
  379. package/dist/chunk-KMKUXP2S.mjs.map +0 -1
  380. package/dist/chunk-OJXJ6CZ4.mjs +0 -4
  381. package/dist/chunk-OJXJ6CZ4.mjs.map +0 -1
  382. package/dist/chunk-PHIOKO3A.mjs +0 -2
  383. package/dist/chunk-PHIOKO3A.mjs.map +0 -1
  384. package/dist/chunk-QCK474XD.cjs +0 -2
  385. package/dist/chunk-QCK474XD.cjs.map +0 -1
  386. package/dist/chunk-REDXXUK7.cjs +0 -2
  387. package/dist/chunk-REDXXUK7.cjs.map +0 -1
  388. package/dist/chunk-S74ZMG2G.cjs +0 -2
  389. package/dist/chunk-S74ZMG2G.cjs.map +0 -1
  390. package/dist/chunk-TOAXF4YW.cjs +0 -2
  391. package/dist/chunk-TOAXF4YW.cjs.map +0 -1
  392. package/dist/chunk-UZ5CB33M.cjs +0 -2
  393. package/dist/chunk-UZ5CB33M.cjs.map +0 -1
  394. package/dist/chunk-VYWYJR63.mjs +0 -2
  395. package/dist/chunk-VYWYJR63.mjs.map +0 -1
  396. package/dist/chunk-XFPTQMAK.cjs +0 -4
  397. package/dist/chunk-XFPTQMAK.cjs.map +0 -1
  398. package/dist/chunk-YK4NINF5.mjs +0 -2
  399. package/dist/chunk-YK4NINF5.mjs.map +0 -1
  400. package/dist/contexts/index.cjs +0 -2
  401. package/dist/contexts/index.cjs.map +0 -1
  402. package/dist/contexts/index.mjs +0 -2
  403. package/dist/contexts/index.mjs.map +0 -1
  404. package/dist/enum/index.cjs +0 -2
  405. package/dist/enum/index.cjs.map +0 -1
  406. package/dist/enum/index.d.cts +0 -31
  407. package/dist/enum/index.d.ts +0 -31
  408. package/dist/enum/index.mjs +0 -2
  409. package/dist/enum/index.mjs.map +0 -1
  410. package/dist/errors/index.cjs +0 -2
  411. package/dist/errors/index.cjs.map +0 -1
  412. package/dist/errors/index.d.cts +0 -204
  413. package/dist/errors/index.d.ts +0 -204
  414. package/dist/errors/index.mjs +0 -2
  415. package/dist/errors/index.mjs.map +0 -1
  416. package/dist/hooks/index.cjs +0 -4
  417. package/dist/hooks/index.cjs.map +0 -1
  418. package/dist/hooks/index.mjs +0 -4
  419. package/dist/hooks/index.mjs.map +0 -1
  420. package/dist/staking-F9Nx9TKD.d.ts +0 -246
  421. package/dist/staking-f4BpYH7l.d.cts +0 -246
  422. package/dist/types/index.cjs +0 -2
  423. package/dist/types/index.cjs.map +0 -1
  424. package/dist/types/index.d.cts +0 -56
  425. package/dist/types/index.d.ts +0 -56
  426. package/dist/types/index.mjs +0 -2
  427. package/dist/types/index.mjs.map +0 -1
  428. package/dist/utils/index.cjs +0 -2
  429. package/dist/utils/index.cjs.map +0 -1
  430. package/dist/utils/index.mjs +0 -2
  431. package/dist/utils/index.mjs.map +0 -1
  432. package/src/actions/dex/getTransactionCount.ts +0 -29
  433. package/src/actions/enso/bend.ts +0 -143
  434. package/src/actions/enso/getEnsoUserToken.debug.test.ts +0 -57
  435. package/src/contexts/berajsProvider/context.tsx +0 -49
  436. package/src/contexts/berajsProvider/index.ts +0 -2
  437. package/src/contexts/berajsProvider/useBeraJs.ts +0 -18
  438. package/src/hooks/dex/usePollVaultIsPaused.ts +0 -30
  439. package/src/hooks/enso/useBendTransactionRequests.ts +0 -247
  440. package/src/hooks/enso/useEnsoZap.ts +0 -166
  441. package/src/hooks/enso/useZapTransactionRequests.ts +0 -81
  442. package/src/hooks/pol/useEarnedStakedBeraVault.ts +0 -59
  443. package/src/hooks/pol/useStakedBeraSnapshots.ts +0 -27
  444. package/src/hooks/validators/validatorRoleManager.ts +0 -0
  445. package/src/types/index.ts +0 -8
  446. package/src/types/staking.ts +0 -7
  447. package/src/utils/formatAggregatorsQuotes.ts +0 -57
  448. package/src/utils/formatAggregatorsQuotes.unit.test.ts +0 -191
  449. package/src/utils/sentryBeforeSend.ts +0 -52
  450. /package/dist/{abi/index.mjs.map → errors/exports.mjs.map} +0 -0
  451. /package/dist/{actions/index.mjs.map → types/exports.mjs.map} +0 -0
  452. /package/src/actions/dex/{__tests__ → aggregators}/haiku.integration.test.ts +0 -0
  453. /package/src/types/{bribe-boost.ts → bribe-boost.d.ts} +0 -0
@@ -1,81 +0,0 @@
1
- "use client";
2
-
3
- import useSWR from "swr";
4
-
5
- import { POLLING } from "~/enum/polling";
6
- import { assertAddress, assertAmount, assertDefined } from "~/errors/assert";
7
- import type {
8
- BalanceToken,
9
- BalanceTokenWithMetadata,
10
- GetZapTransactionResponse,
11
- } from "~/types";
12
- import { useEnsoZap } from "./useEnsoZap";
13
-
14
- /**
15
- * Get the zap transaction requests for swapping tokens using Enso.
16
- * @param {Pick<BalanceToken, "address" | "decimals">} tokenIn - The input token to swap from
17
- * @param {Pick<BalanceToken, "address" | "decimals">} tokenOut - The output token to swap to
18
- * @param {string} amount - The amount of input token to swap
19
- * @param {number} slippage - The slippage tolerance to use for the route in percentage
20
- * @returns {DefaultHookReturnType<GetZapTransactionResponse> & {tokens: BalanceTokenWithMetadata[], refresh: () => void}}
21
- *
22
- * The zap transaction response data with polling enabled, see {@link GetZapTransactionResponse} and {@link BalanceTokenWithMetadata}
23
- * @remarks The hook is only enabled when all parameters are provided and amount is greater than 0
24
- * @see {@link useEnsoZap}
25
- */
26
- export const useZapTransactionRequests = ({
27
- tokenIn,
28
- tokenOut,
29
- amount,
30
- slippage,
31
- chainId,
32
- }: {
33
- tokenIn?: Pick<BalanceToken, "address" | "decimals">;
34
- tokenOut?: Pick<BalanceToken, "address" | "decimals">;
35
- amount?: string;
36
- slippage?: number;
37
- chainId?: number;
38
- }) => {
39
- const { getZapTransactionRequests, refreshTokens, tokens } = useEnsoZap({
40
- chainId,
41
- });
42
- const isEnabled =
43
- !!tokenIn && !!tokenOut && !!amount && Number(amount) > 0 && !!slippage;
44
- const QUERY_KEY = isEnabled
45
- ? ([
46
- "useZapTransactionRequests",
47
- tokenIn,
48
- tokenOut,
49
- amount,
50
- slippage,
51
- ] as const)
52
- : null;
53
-
54
- const swrResponse = useSWR(
55
- QUERY_KEY,
56
- async ([, tokenIn, tokenOut, amount, slippage]) => {
57
- assertDefined(tokenIn, "tokenIn");
58
- assertAddress(tokenOut?.address, "tokenOutAddress");
59
- assertAmount(amount, "amount");
60
- assertAmount(slippage, "slippage");
61
- return getZapTransactionRequests({
62
- amount,
63
- tokenIn: tokenIn,
64
- tokenOut: tokenOut.address,
65
- slippage,
66
- });
67
- },
68
- {
69
- refreshInterval: POLLING.NORMAL,
70
- isEnabled: isEnabled,
71
- },
72
- );
73
- return {
74
- ...swrResponse,
75
- tokens,
76
- refresh: () => {
77
- swrResponse.mutate();
78
- refreshTokens();
79
- },
80
- };
81
- };
@@ -1,59 +0,0 @@
1
- import useSWR from "swr";
2
-
3
- import {
4
- GetStakeBeraVaultEarningsByOwner,
5
- type GetStakeBeraVaultEarningsByOwnerQuery,
6
- type GetStakeBeraVaultEarningsByOwnerQueryVariables,
7
- } from "@berachain/graphql/pol/api";
8
- import { useBeraWallet } from "@berachain/wagmi/hooks";
9
-
10
- import { getApolloClient } from "~/actions/clients/getApolloClient";
11
- import { POLLING } from "~/enum/polling";
12
- import type {
13
- DefaultHookOptions,
14
- DefaultHookReturnType,
15
- TokenWithMetadata,
16
- } from "~/types";
17
-
18
- type UseEarnedStakedBeraVaultArgs = {
19
- /**
20
- * The token that the user has staked
21
- */
22
- receiptToken: TokenWithMetadata;
23
- };
24
- export function useEarnedStakedBeraVault(
25
- { receiptToken }: UseEarnedStakedBeraVaultArgs,
26
- opt?: DefaultHookOptions,
27
- ): DefaultHookReturnType<string> {
28
- const { address: account } = useBeraWallet();
29
-
30
- const QUERY_KEY =
31
- receiptToken.address && account
32
- ? (["useEarnedStakedBeraVault", receiptToken.address, account] as const)
33
- : null;
34
-
35
- const swrResponse = useSWR(
36
- QUERY_KEY,
37
- async ([_, , account]) => {
38
- const bexApiGraphqlClient = getApolloClient("api", {});
39
- const response = await bexApiGraphqlClient.query<
40
- GetStakeBeraVaultEarningsByOwnerQuery,
41
- GetStakeBeraVaultEarningsByOwnerQueryVariables
42
- >({
43
- query: GetStakeBeraVaultEarningsByOwner,
44
- variables: {
45
- owner: account,
46
- },
47
- });
48
- return response.data?.polGetStakeBeraVaultEarningsByOwner?.earnings;
49
- },
50
- {
51
- refreshInterval: POLLING.SLOW,
52
- ...opt?.opts,
53
- },
54
- );
55
- return {
56
- ...swrResponse,
57
- refresh: swrResponse.mutate,
58
- };
59
- }
@@ -1,27 +0,0 @@
1
- import useSWR from "swr";
2
-
3
- import type { GetSWberaVaultSnapshotsQuery } from "@berachain/graphql/pol/api";
4
-
5
- import {
6
- type GetStakedBeraSnapshotsArgs,
7
- getStakedBeraSnapshots,
8
- } from "~/actions/pol/getStakedBeraSnapshots";
9
- import type { DefaultHookReturnType } from "~/types/global";
10
-
11
- export const useStakedBeraSnapshots = ({
12
- range,
13
- }: GetStakedBeraSnapshotsArgs): DefaultHookReturnType<
14
- GetSWberaVaultSnapshotsQuery["polGetSWberaVaultSnapshots"]
15
- > => {
16
- const QUERY_KEY = range ? (["useStakedBeraSnapshots", range] as const) : null;
17
- const swrResponse = useSWR(QUERY_KEY, ([, range]) =>
18
- getStakedBeraSnapshots({
19
- range,
20
- }),
21
- );
22
-
23
- return {
24
- ...swrResponse,
25
- refresh: () => swrResponse.mutate(),
26
- };
27
- };
File without changes
@@ -1,8 +0,0 @@
1
- export * from "./bribe-boost";
2
- export * from "./dex";
3
- export * from "./enso";
4
- export * from "./global";
5
- export * from "./governance";
6
- export * from "./honeySwap";
7
- export * from "./pol";
8
- export * from "./staking";
@@ -1,7 +0,0 @@
1
- export interface ProtocolMetadata {
2
- name: string;
3
- logoURI: string;
4
- url: string;
5
- description: string;
6
- tags?: string[];
7
- }
@@ -1,57 +0,0 @@
1
- import BigNumber from "bignumber.js";
2
- import { formatUnits } from "viem";
3
-
4
- import type { IAggregatorQuote, IRawAggregatorQuote, Token } from "~/types";
5
- import { computePriceImpact } from "./math";
6
-
7
- export const formatAggregatorsQuotes = (
8
- rawQuotes: (IRawAggregatorQuote | IRawAggregatorQuote<false>)[],
9
- selectedFrom: Token | undefined,
10
- selectedTo: Token | undefined,
11
- tokenInPrice: number,
12
- tokenOutPrice: number,
13
- ): IAggregatorQuote[] =>
14
- rawQuotes
15
- .map((quote) => {
16
- const amountOut = formatUnits(
17
- BigInt(quote.amountOut),
18
- selectedTo?.decimals || 18,
19
- );
20
- const amountIn = formatUnits(
21
- BigInt(quote.amountIn),
22
- selectedFrom?.decimals || 18,
23
- );
24
- const amountOutUsd = new BigNumber(amountOut)
25
- .times(tokenOutPrice)
26
- .toFixed();
27
- const amountInUsd = new BigNumber(amountIn).times(tokenInPrice).toFixed();
28
- const priceImpactPercentage = computePriceImpact(
29
- (tokenInPrice || 0).toString(),
30
- (tokenOutPrice || 0).toString(),
31
- amountIn,
32
- amountOut,
33
- );
34
- return {
35
- ...quote,
36
- exchangeRate: new BigNumber(amountOut).div(amountIn).toNumber(),
37
- amountIn,
38
- amountOut,
39
- amountOutUsd,
40
- amountInUsd,
41
- priceImpactPercentage,
42
- };
43
- })
44
- .sort((a, b) => new BigNumber(b.amountOut).minus(a.amountOut).toNumber())
45
- .map((quote, _, allQuotes) => ({
46
- ...quote,
47
- relativeLossPercentage: computePriceImpact(
48
- // hardcoded to 1 since we're calculating relative loss percentage
49
- // between this quote's output amount and the best quote's output amount.
50
- // The input amounts are the same for all quotes, so we use 1 as a base
51
- // to get the pure percentage difference between outputs.
52
- "1",
53
- "1",
54
- allQuotes[0].amountOut,
55
- quote.amountOut,
56
- ),
57
- }));
@@ -1,191 +0,0 @@
1
- import { zeroAddress } from "viem";
2
- import { describe, expect, expectTypeOf, test } from "vitest";
3
-
4
- import {
5
- Aggregators,
6
- type IAggregatorQuote,
7
- type IRawAggregatorQuote,
8
- type Token,
9
- } from "~/types/dex";
10
- import { formatAggregatorsQuotes } from "./formatAggregatorsQuotes";
11
-
12
- const mockToken = (symbol: string, decimals: number): Token => ({
13
- symbol,
14
- decimals,
15
- address: zeroAddress,
16
- name: symbol,
17
- chainId: 1,
18
- });
19
-
20
- const mockCalldata = {
21
- params: [],
22
- functionName: "",
23
- abi: [],
24
- address: zeroAddress,
25
- value: BigInt(0),
26
- };
27
-
28
- const mockQuotes: IRawAggregatorQuote<false>[] = [
29
- {
30
- amountOut: "1000000000000000000", // 1 token
31
- amountIn: "2000000000000000000", // 2 tokens
32
- name: Aggregators.Fly,
33
- spender: zeroAddress,
34
- calldata: mockCalldata,
35
- swapFeeBps: 10,
36
- },
37
- {
38
- amountOut: "1200000000000000000", // 1.2 tokens
39
- amountIn: "2000000000000000000", // 2 tokens
40
- name: Aggregators.HubPools,
41
- spender: zeroAddress,
42
- calldata: mockCalldata,
43
- swapFeeBps: 10,
44
- },
45
- {
46
- amountOut: "800000000000000000", // 0.8 tokens
47
- amountIn: "2000000000000000000", // 2 tokens
48
- name: Aggregators.Oogabooga,
49
- spender: zeroAddress,
50
- calldata: mockCalldata,
51
- swapFeeBps: 10,
52
- },
53
- ];
54
-
55
- describe("formatAggregatorsQuotes", () => {
56
- test("should return an empty array if no quotes are provided", () => {
57
- expect(formatAggregatorsQuotes([], undefined, undefined, 0, 0)).toEqual([]);
58
- });
59
-
60
- test("should return the correct type", () => {
61
- const results = formatAggregatorsQuotes(
62
- mockQuotes,
63
- undefined,
64
- undefined,
65
- 0,
66
- 0,
67
- );
68
- expectTypeOf(results).toEqualTypeOf<IAggregatorQuote[]>();
69
- });
70
-
71
- test("should sort quotes by amountOut in descending order", () => {
72
- const tokenIn = mockToken("TOKEN_IN", 18);
73
- const tokenOut = mockToken("TOKEN_OUT", 18);
74
-
75
- const results = formatAggregatorsQuotes(
76
- mockQuotes,
77
- tokenIn,
78
- tokenOut,
79
- 1,
80
- 1,
81
- );
82
-
83
- expect(results[0].amountOut).toBe("1.2");
84
- expect(results[1].amountOut).toBe("1");
85
- expect(results[2].amountOut).toBe("0.8");
86
- });
87
-
88
- test("should calculate relative loss percentage correctly", () => {
89
- const tokenIn = mockToken("ABC", 18);
90
- const tokenOut = mockToken("XYZ", 18);
91
-
92
- const results = formatAggregatorsQuotes(
93
- mockQuotes,
94
- tokenIn,
95
- tokenOut,
96
- 1,
97
- 1,
98
- );
99
-
100
- // best quote has 0% loss
101
- expect(results[0].relativeLossPercentage).toBe(0);
102
-
103
- // other quotes show percentage loss relative to best quote
104
- expect(results[1].relativeLossPercentage).toBeCloseTo(0.166);
105
- expect(results[2].relativeLossPercentage).toBeCloseTo(0.333);
106
- });
107
-
108
- test("should handle tokens with different decimals", () => {
109
- const tokenIn = mockToken("USDC", 6);
110
- const tokenOut = mockToken("ETH", 18);
111
-
112
- const quotesWithDifferentDecimals: IRawAggregatorQuote<false>[] = [
113
- {
114
- amountOut: "1000000000000000000", // 1 ETH
115
- amountIn: "2000000", // 2 USDC
116
- name: Aggregators.Fly,
117
- spender: zeroAddress,
118
- calldata: mockCalldata,
119
- swapFeeBps: 10,
120
- },
121
- ];
122
-
123
- const results = formatAggregatorsQuotes(
124
- quotesWithDifferentDecimals,
125
- tokenIn,
126
- tokenOut,
127
- 1,
128
- 1,
129
- );
130
-
131
- expect(results[0].amountIn).toBe("2");
132
- expect(results[0].amountOut).toBe("1");
133
- });
134
-
135
- test("should calculate amountOutUsd correctly", () => {
136
- const tokenIn = mockToken("ABC", 18);
137
- const tokenOut = mockToken("XYZ", 18);
138
- const tokenOutPrice = 100; // $100 per token
139
-
140
- const results = formatAggregatorsQuotes(
141
- mockQuotes,
142
- tokenIn,
143
- tokenOut,
144
- 1,
145
- tokenOutPrice,
146
- );
147
-
148
- // amountOutUsd = amountOut * tokenOutPrice
149
- expect(results[0].amountOutUsd).toBe("120"); // 1.2 * $100
150
- expect(results[1].amountOutUsd).toBe("100"); // 1.0 * $100
151
- expect(results[2].amountOutUsd).toBe("80"); // 0.8 * $100
152
- });
153
-
154
- test("should calculate amountOutUsd correctly with different decimals", () => {
155
- const tokenIn = mockToken("USDC", 6);
156
- const tokenOut = mockToken("ETH", 18);
157
- const tokenOutPrice = 100.5; // $100.50 per token
158
-
159
- const results = formatAggregatorsQuotes(
160
- mockQuotes,
161
- tokenIn,
162
- tokenOut,
163
- 1,
164
- tokenOutPrice,
165
- );
166
-
167
- // amountOutUsd = amountOut * tokenOutPrice
168
- expect(results[0].amountOutUsd).toBe("120.6"); // 1.2 * $100.50
169
- expect(results[1].amountOutUsd).toBe("100.5"); // 1.0 * $100.50
170
- expect(results[2].amountOutUsd).toBe("80.4"); // 0.8 * $100.50
171
- });
172
-
173
- test("should calculate price impact when token prices provided", () => {
174
- const tokenIn = mockToken("ABC", 18);
175
- const tokenOut = mockToken("XYZ", 18);
176
-
177
- const results = formatAggregatorsQuotes(
178
- mockQuotes,
179
- tokenIn,
180
- tokenOut,
181
- 100, // $100 per token in
182
- 50, // $50 per token out
183
- );
184
-
185
- // For best quote (1.2 out for 2 in):
186
- // USD in = 2 * $100 = $200
187
- // USD out = 1.2 * $50 = $60
188
- // Price impact = 1 - (60/200) = 0.7 = 70%
189
- expect(results[0].priceImpactPercentage).toBe(0.7);
190
- });
191
- });
@@ -1,52 +0,0 @@
1
- import type * as SentryType from "@sentry/nextjs";
2
-
3
- import { RequestError } from "~/errors/RequestError";
4
- import { BeraError } from "../errors/BeraError";
5
-
6
- /**
7
- * Util to make Sentry errors consistent with BeraErrors
8
- * @returns
9
- */
10
- export function sentryBeforeSend<
11
- TEvent extends SentryType.ErrorEvent,
12
- THint extends SentryType.EventHint,
13
- >(
14
- event: TEvent,
15
- hint: THint,
16
- ): PromiseLike<SentryType.ErrorEvent | null> | SentryType.ErrorEvent | null {
17
- const originalException = hint.originalException;
18
-
19
- if (!originalException) {
20
- return event;
21
- }
22
-
23
- if (originalException instanceof BeraError) {
24
- // if it's a bera error, we want to add the tags and level to the event
25
- // we're using them as defaults and override them if the captureContext has different values
26
-
27
- event.extra = {
28
- ...originalException,
29
- ...event.extra,
30
- };
31
- event.tags = {
32
- ...originalException.tags,
33
- ...event.tags,
34
- };
35
- event.level =
36
- hint.captureContext && "level" in hint.captureContext
37
- ? hint.captureContext.level
38
- : originalException.level;
39
- }
40
-
41
- if (originalException instanceof TypeError) {
42
- // this is either CORS or network error
43
- event.extra = { ...originalException };
44
- event.tags = {
45
- "error.reason": RequestError.isCorsError(originalException)
46
- ? RequestError.REASON_MAP.CORS_ERROR
47
- : originalException.name,
48
- level: "warning",
49
- };
50
- }
51
- return event;
52
- }
File without changes