@levrbet/shared 0.0.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 (488) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +92 -0
  3. package/bin/setup-prisma.js +44 -0
  4. package/dist/core/config/dotenv.d.ts +16 -0
  5. package/dist/core/config/dotenv.js +77 -0
  6. package/dist/core/config/dotenv.js.map +1 -0
  7. package/dist/core/config/index.d.ts +2 -0
  8. package/dist/core/config/index.js +19 -0
  9. package/dist/core/config/index.js.map +1 -0
  10. package/dist/core/config/urls.d.ts +55 -0
  11. package/dist/core/config/urls.js +61 -0
  12. package/dist/core/config/urls.js.map +1 -0
  13. package/dist/core/contracts/abis/LevrBaseMarket.d.ts +1009 -0
  14. package/dist/core/contracts/abis/LevrBaseMarket.js +976 -0
  15. package/dist/core/contracts/abis/LevrBaseMarket.js.map +1 -0
  16. package/dist/core/contracts/abis/LevrConfigProvider.d.ts +2671 -0
  17. package/dist/core/contracts/abis/LevrConfigProvider.js +2551 -0
  18. package/dist/core/contracts/abis/LevrConfigProvider.js.map +1 -0
  19. package/dist/core/contracts/abis/LevrFeeCollector.d.ts +259 -0
  20. package/dist/core/contracts/abis/LevrFeeCollector.js +143 -0
  21. package/dist/core/contracts/abis/LevrFeeCollector.js.map +1 -0
  22. package/dist/core/contracts/abis/LevrFulltimeMarket.d.ts +1050 -0
  23. package/dist/core/contracts/abis/LevrFulltimeMarket.js +462 -0
  24. package/dist/core/contracts/abis/LevrFulltimeMarket.js.map +1 -0
  25. package/dist/core/contracts/abis/LevrFundManager.d.ts +51 -0
  26. package/dist/core/contracts/abis/LevrFundManager.js +4 -0
  27. package/dist/core/contracts/abis/LevrFundManager.js.map +1 -0
  28. package/dist/core/contracts/abis/LevrLiquidationEngine.d.ts +244 -0
  29. package/dist/core/contracts/abis/LevrLiquidationEngine.js +231 -0
  30. package/dist/core/contracts/abis/LevrLiquidationEngine.js.map +1 -0
  31. package/dist/core/contracts/abis/LevrManager.d.ts +1281 -0
  32. package/dist/core/contracts/abis/LevrManager.js +1090 -0
  33. package/dist/core/contracts/abis/LevrManager.js.map +1 -0
  34. package/dist/core/contracts/abis/LevrMarketFeed.d.ts +902 -0
  35. package/dist/core/contracts/abis/LevrMarketFeed.js +775 -0
  36. package/dist/core/contracts/abis/LevrMarketFeed.js.map +1 -0
  37. package/dist/core/contracts/abis/LevrMarketMaker.d.ts +175 -0
  38. package/dist/core/contracts/abis/LevrMarketMaker.js +108 -0
  39. package/dist/core/contracts/abis/LevrMarketMaker.js.map +1 -0
  40. package/dist/core/contracts/abis/LevrMarketRiskSentinel.d.ts +682 -0
  41. package/dist/core/contracts/abis/LevrMarketRiskSentinel.js +323 -0
  42. package/dist/core/contracts/abis/LevrMarketRiskSentinel.js.map +1 -0
  43. package/dist/core/contracts/abis/LevrMarketRouter.d.ts +281 -0
  44. package/dist/core/contracts/abis/LevrMarketRouter.js +262 -0
  45. package/dist/core/contracts/abis/LevrMarketRouter.js.map +1 -0
  46. package/dist/core/contracts/abis/LevrMvpDepository.d.ts +766 -0
  47. package/dist/core/contracts/abis/LevrMvpDepository.js +396 -0
  48. package/dist/core/contracts/abis/LevrMvpDepository.js.map +1 -0
  49. package/dist/core/contracts/abis/LevrMvpRouter.d.ts +305 -0
  50. package/dist/core/contracts/abis/LevrMvpRouter.js +291 -0
  51. package/dist/core/contracts/abis/LevrMvpRouter.js.map +1 -0
  52. package/dist/core/contracts/abis/LevrMvpStaker.d.ts +746 -0
  53. package/dist/core/contracts/abis/LevrMvpStaker.js +386 -0
  54. package/dist/core/contracts/abis/LevrMvpStaker.js.map +1 -0
  55. package/dist/core/contracts/abis/LevrMvpToken.d.ts +341 -0
  56. package/dist/core/contracts/abis/LevrMvpToken.js +183 -0
  57. package/dist/core/contracts/abis/LevrMvpToken.js.map +1 -0
  58. package/dist/core/contracts/abis/LevrOrderbook.d.ts +471 -0
  59. package/dist/core/contracts/abis/LevrOrderbook.js +486 -0
  60. package/dist/core/contracts/abis/LevrOrderbook.js.map +1 -0
  61. package/dist/core/contracts/abis/LevrOrderbookLens.d.ts +167 -0
  62. package/dist/core/contracts/abis/LevrOrderbookLens.js +103 -0
  63. package/dist/core/contracts/abis/LevrOrderbookLens.js.map +1 -0
  64. package/dist/core/contracts/abis/LevrOverUnderMarket.d.ts +1054 -0
  65. package/dist/core/contracts/abis/LevrOverUnderMarket.js +463 -0
  66. package/dist/core/contracts/abis/LevrOverUnderMarket.js.map +1 -0
  67. package/dist/core/contracts/abis/LevrPythFeed.d.ts +225 -0
  68. package/dist/core/contracts/abis/LevrPythFeed.js +131 -0
  69. package/dist/core/contracts/abis/LevrPythFeed.js.map +1 -0
  70. package/dist/core/contracts/abis/LevrUtil.d.ts +485 -0
  71. package/dist/core/contracts/abis/LevrUtil.js +226 -0
  72. package/dist/core/contracts/abis/LevrUtil.js.map +1 -0
  73. package/dist/core/contracts/abis/Storage.d.ts +34 -0
  74. package/dist/core/contracts/abis/Storage.js +47 -0
  75. package/dist/core/contracts/abis/Storage.js.map +1 -0
  76. package/dist/core/contracts/abis/index.d.ts +12174 -0
  77. package/dist/core/contracts/abis/index.js +51 -0
  78. package/dist/core/contracts/abis/index.js.map +1 -0
  79. package/dist/core/contracts/addresses.d.ts +154 -0
  80. package/dist/core/contracts/addresses.js +160 -0
  81. package/dist/core/contracts/addresses.js.map +1 -0
  82. package/dist/core/contracts/chains.d.ts +4 -0
  83. package/dist/core/contracts/chains.js +14 -0
  84. package/dist/core/contracts/chains.js.map +1 -0
  85. package/dist/core/contracts/clients/index.d.ts +1 -0
  86. package/dist/core/contracts/clients/index.js +18 -0
  87. package/dist/core/contracts/clients/index.js.map +1 -0
  88. package/dist/core/contracts/clients/publicClients.d.ts +24 -0
  89. package/dist/core/contracts/clients/publicClients.js +123 -0
  90. package/dist/core/contracts/clients/publicClients.js.map +1 -0
  91. package/dist/core/contracts/constants.d.ts +15 -0
  92. package/dist/core/contracts/constants.js +30 -0
  93. package/dist/core/contracts/constants.js.map +1 -0
  94. package/dist/core/contracts/index.d.ts +6 -0
  95. package/dist/core/contracts/index.js +23 -0
  96. package/dist/core/contracts/index.js.map +1 -0
  97. package/dist/core/contracts/instances.d.ts +48 -0
  98. package/dist/core/contracts/instances.js +101 -0
  99. package/dist/core/contracts/instances.js.map +1 -0
  100. package/dist/core/index.d.ts +9 -0
  101. package/dist/core/index.js +26 -0
  102. package/dist/core/index.js.map +1 -0
  103. package/dist/core/indexers/envio.test.query.d.ts +5 -0
  104. package/dist/core/indexers/envio.test.query.js +32 -0
  105. package/dist/core/indexers/envio.test.query.js.map +1 -0
  106. package/dist/core/indexers/index.d.ts +1 -0
  107. package/dist/core/indexers/index.js +18 -0
  108. package/dist/core/indexers/index.js.map +1 -0
  109. package/dist/core/indexers/indexers.service.d.ts +19 -0
  110. package/dist/core/indexers/indexers.service.js +104 -0
  111. package/dist/core/indexers/indexers.service.js.map +1 -0
  112. package/dist/core/indexers/subsquid.test.query.d.ts +4 -0
  113. package/dist/core/indexers/subsquid.test.query.js +42 -0
  114. package/dist/core/indexers/subsquid.test.query.js.map +1 -0
  115. package/dist/core/prisma/index.d.ts +1 -0
  116. package/dist/core/prisma/index.js +21 -0
  117. package/dist/core/prisma/index.js.map +1 -0
  118. package/dist/core/prisma/schema.prisma +360 -0
  119. package/dist/core/privy/constants.d.ts +19 -0
  120. package/dist/core/privy/constants.js +28 -0
  121. package/dist/core/privy/constants.js.map +1 -0
  122. package/dist/core/privy/index.d.ts +1 -0
  123. package/dist/core/privy/index.js +18 -0
  124. package/dist/core/privy/index.js.map +1 -0
  125. package/dist/core/socket.io/events.d.ts +20 -0
  126. package/dist/core/socket.io/events.js +20 -0
  127. package/dist/core/socket.io/events.js.map +1 -0
  128. package/dist/core/socket.io/index.d.ts +2 -0
  129. package/dist/core/socket.io/index.js +19 -0
  130. package/dist/core/socket.io/index.js.map +1 -0
  131. package/dist/core/socket.io/rooms.d.ts +6 -0
  132. package/dist/core/socket.io/rooms.js +10 -0
  133. package/dist/core/socket.io/rooms.js.map +1 -0
  134. package/dist/core/types/auth/auth.types.d.ts +31 -0
  135. package/dist/core/types/auth/auth.types.js +15 -0
  136. package/dist/core/types/auth/auth.types.js.map +1 -0
  137. package/dist/core/types/auth/index.d.ts +2 -0
  138. package/dist/core/types/auth/index.js +19 -0
  139. package/dist/core/types/auth/index.js.map +1 -0
  140. package/dist/core/types/auth/request.types.d.ts +19 -0
  141. package/dist/core/types/auth/request.types.js +15 -0
  142. package/dist/core/types/auth/request.types.js.map +1 -0
  143. package/dist/core/types/blockchain/chains.types.d.ts +3 -0
  144. package/dist/core/types/blockchain/chains.types.js +8 -0
  145. package/dist/core/types/blockchain/chains.types.js.map +1 -0
  146. package/dist/core/types/blockchain/contract.types.d.ts +8 -0
  147. package/dist/core/types/blockchain/contract.types.js +13 -0
  148. package/dist/core/types/blockchain/contract.types.js.map +1 -0
  149. package/dist/core/types/blockchain/index.d.ts +3 -0
  150. package/dist/core/types/blockchain/index.js +20 -0
  151. package/dist/core/types/blockchain/index.js.map +1 -0
  152. package/dist/core/types/blockchain/oz.relayer.types.d.ts +7 -0
  153. package/dist/core/types/blockchain/oz.relayer.types.js +13 -0
  154. package/dist/core/types/blockchain/oz.relayer.types.js.map +1 -0
  155. package/dist/core/types/index.d.ts +6 -0
  156. package/dist/core/types/index.js +23 -0
  157. package/dist/core/types/index.js.map +1 -0
  158. package/dist/core/types/indexers.types.d.ts +4 -0
  159. package/dist/core/types/indexers.types.js +9 -0
  160. package/dist/core/types/indexers.types.js.map +1 -0
  161. package/dist/core/types/misc.types.d.ts +6 -0
  162. package/dist/core/types/misc.types.js +11 -0
  163. package/dist/core/types/misc.types.js.map +1 -0
  164. package/dist/core/types/oracle/fixture.types.d.ts +75 -0
  165. package/dist/core/types/oracle/fixture.types.js +4 -0
  166. package/dist/core/types/oracle/fixture.types.js.map +1 -0
  167. package/dist/core/types/oracle/game/game.types.d.ts +108 -0
  168. package/dist/core/types/oracle/game/game.types.js +64 -0
  169. package/dist/core/types/oracle/game/game.types.js.map +1 -0
  170. package/dist/core/types/oracle/game/index.d.ts +2 -0
  171. package/dist/core/types/oracle/game/index.js +19 -0
  172. package/dist/core/types/oracle/game/index.js.map +1 -0
  173. package/dist/core/types/oracle/game/zod.game.types.d.ts +31 -0
  174. package/dist/core/types/oracle/game/zod.game.types.js +22 -0
  175. package/dist/core/types/oracle/game/zod.game.types.js.map +1 -0
  176. package/dist/core/types/oracle/index.d.ts +4 -0
  177. package/dist/core/types/oracle/index.js +21 -0
  178. package/dist/core/types/oracle/index.js.map +1 -0
  179. package/dist/core/types/oracle/market/index.d.ts +3 -0
  180. package/dist/core/types/oracle/market/index.js +20 -0
  181. package/dist/core/types/oracle/market/index.js.map +1 -0
  182. package/dist/core/types/oracle/market/markets.types.d.ts +95 -0
  183. package/dist/core/types/oracle/market/markets.types.js +35 -0
  184. package/dist/core/types/oracle/market/markets.types.js.map +1 -0
  185. package/dist/core/types/oracle/market/odds.types.d.ts +14 -0
  186. package/dist/core/types/oracle/market/odds.types.js +3 -0
  187. package/dist/core/types/oracle/market/odds.types.js.map +1 -0
  188. package/dist/core/types/oracle/market/positions.types.d.ts +57 -0
  189. package/dist/core/types/oracle/market/positions.types.js +3 -0
  190. package/dist/core/types/oracle/market/positions.types.js.map +1 -0
  191. package/dist/core/types/oracle/requests/game.request.types.d.ts +170 -0
  192. package/dist/core/types/oracle/requests/game.request.types.js +126 -0
  193. package/dist/core/types/oracle/requests/game.request.types.js.map +1 -0
  194. package/dist/core/types/oracle/requests/game.response.types.d.ts +8 -0
  195. package/dist/core/types/oracle/requests/game.response.types.js +3 -0
  196. package/dist/core/types/oracle/requests/game.response.types.js.map +1 -0
  197. package/dist/core/types/oracle/requests/index.d.ts +5 -0
  198. package/dist/core/types/oracle/requests/index.js +22 -0
  199. package/dist/core/types/oracle/requests/index.js.map +1 -0
  200. package/dist/core/types/oracle/requests/market.request.types.d.ts +63 -0
  201. package/dist/core/types/oracle/requests/market.request.types.js +41 -0
  202. package/dist/core/types/oracle/requests/market.request.types.js.map +1 -0
  203. package/dist/core/types/oracle/requests/odds.response.types.d.ts +2 -0
  204. package/dist/core/types/oracle/requests/odds.response.types.js +3 -0
  205. package/dist/core/types/oracle/requests/odds.response.types.js.map +1 -0
  206. package/dist/core/types/oracle/requests/user.request.type.d.ts +4 -0
  207. package/dist/core/types/oracle/requests/user.request.type.js +3 -0
  208. package/dist/core/types/oracle/requests/user.request.type.js.map +1 -0
  209. package/dist/core/types/privy.types.d.ts +4 -0
  210. package/dist/core/types/privy.types.js +9 -0
  211. package/dist/core/types/privy.types.js.map +1 -0
  212. package/dist/core/utils/converters.utils.d.ts +29 -0
  213. package/dist/core/utils/converters.utils.js +97 -0
  214. package/dist/core/utils/converters.utils.js.map +1 -0
  215. package/dist/core/utils/game.utils.d.ts +4 -0
  216. package/dist/core/utils/game.utils.js +79 -0
  217. package/dist/core/utils/game.utils.js.map +1 -0
  218. package/dist/core/utils/index.d.ts +4 -0
  219. package/dist/core/utils/index.js +21 -0
  220. package/dist/core/utils/index.js.map +1 -0
  221. package/dist/core/utils/misc.utils.d.ts +14 -0
  222. package/dist/core/utils/misc.utils.js +33 -0
  223. package/dist/core/utils/misc.utils.js.map +1 -0
  224. package/dist/core/utils/position.utils.d.ts +18 -0
  225. package/dist/core/utils/position.utils.js +68 -0
  226. package/dist/core/utils/position.utils.js.map +1 -0
  227. package/dist/core/validators/bytes.validators.d.ts +32 -0
  228. package/dist/core/validators/bytes.validators.js +47 -0
  229. package/dist/core/validators/bytes.validators.js.map +1 -0
  230. package/dist/core/validators/index.d.ts +2 -0
  231. package/dist/core/validators/index.js +19 -0
  232. package/dist/core/validators/index.js.map +1 -0
  233. package/dist/core/validators/mongo.validators.d.ts +2 -0
  234. package/dist/core/validators/mongo.validators.js +10 -0
  235. package/dist/core/validators/mongo.validators.js.map +1 -0
  236. package/dist/index.d.ts +1 -0
  237. package/dist/index.js +23 -0
  238. package/dist/index.js.map +1 -0
  239. package/dist/react/hooks/auth/index.d.ts +1 -0
  240. package/dist/react/hooks/auth/index.js +18 -0
  241. package/dist/react/hooks/auth/index.js.map +1 -0
  242. package/dist/react/hooks/auth/useAuthHeaders.d.ts +45 -0
  243. package/dist/react/hooks/auth/useAuthHeaders.js +58 -0
  244. package/dist/react/hooks/auth/useAuthHeaders.js.map +1 -0
  245. package/dist/react/hooks/contracts/erc20/index.d.ts +6 -0
  246. package/dist/react/hooks/contracts/erc20/index.js +23 -0
  247. package/dist/react/hooks/contracts/erc20/index.js.map +1 -0
  248. package/dist/react/hooks/contracts/erc20/useApproveErc20.d.ts +13 -0
  249. package/dist/react/hooks/contracts/erc20/useApproveErc20.js +28 -0
  250. package/dist/react/hooks/contracts/erc20/useApproveErc20.js.map +1 -0
  251. package/dist/react/hooks/contracts/erc20/useErc20Allowance.d.ts +10 -0
  252. package/dist/react/hooks/contracts/erc20/useErc20Allowance.js +34 -0
  253. package/dist/react/hooks/contracts/erc20/useErc20Allowance.js.map +1 -0
  254. package/dist/react/hooks/contracts/erc20/useErc20Balance.d.ts +22 -0
  255. package/dist/react/hooks/contracts/erc20/useErc20Balance.js +95 -0
  256. package/dist/react/hooks/contracts/erc20/useErc20Balance.js.map +1 -0
  257. package/dist/react/hooks/contracts/erc20/useErc20Decimals.d.ts +8 -0
  258. package/dist/react/hooks/contracts/erc20/useErc20Decimals.js +28 -0
  259. package/dist/react/hooks/contracts/erc20/useErc20Decimals.js.map +1 -0
  260. package/dist/react/hooks/contracts/erc20/useErc20Symbol.d.ts +8 -0
  261. package/dist/react/hooks/contracts/erc20/useErc20Symbol.js +28 -0
  262. package/dist/react/hooks/contracts/erc20/useErc20Symbol.js.map +1 -0
  263. package/dist/react/hooks/contracts/erc20/useTransferErc20.d.ts +13 -0
  264. package/dist/react/hooks/contracts/erc20/useTransferErc20.js +31 -0
  265. package/dist/react/hooks/contracts/erc20/useTransferErc20.js.map +1 -0
  266. package/dist/react/hooks/contracts/index.d.ts +3 -0
  267. package/dist/react/hooks/contracts/index.js +20 -0
  268. package/dist/react/hooks/contracts/index.js.map +1 -0
  269. package/dist/react/hooks/contracts/useContracts.d.ts +120 -0
  270. package/dist/react/hooks/contracts/useContracts.js +81 -0
  271. package/dist/react/hooks/contracts/useContracts.js.map +1 -0
  272. package/dist/react/hooks/contracts/useLevrMarketContractAddresses.d.ts +3 -0
  273. package/dist/react/hooks/contracts/useLevrMarketContractAddresses.js +27 -0
  274. package/dist/react/hooks/contracts/useLevrMarketContractAddresses.js.map +1 -0
  275. package/dist/react/hooks/index.d.ts +2 -0
  276. package/dist/react/hooks/index.js +19 -0
  277. package/dist/react/hooks/index.js.map +1 -0
  278. package/dist/react/index.d.ts +6 -0
  279. package/dist/react/index.js +23 -0
  280. package/dist/react/index.js.map +1 -0
  281. package/dist/react/injectedDependencies.d.ts +78 -0
  282. package/dist/react/injectedDependencies.js +94 -0
  283. package/dist/react/injectedDependencies.js.map +1 -0
  284. package/dist/react/queryClient.d.ts +9 -0
  285. package/dist/react/queryClient.js +13 -0
  286. package/dist/react/queryClient.js.map +1 -0
  287. package/dist/react/queryKeys.d.ts +17 -0
  288. package/dist/react/queryKeys.js +23 -0
  289. package/dist/react/queryKeys.js.map +1 -0
  290. package/dist/react/types/contracts.types.d.ts +4 -0
  291. package/dist/react/types/contracts.types.js +3 -0
  292. package/dist/react/types/contracts.types.js.map +1 -0
  293. package/dist/react/types/index.d.ts +1 -0
  294. package/dist/react/types/index.js +18 -0
  295. package/dist/react/types/index.js.map +1 -0
  296. package/dist/server/config/cloudflare.d.ts +30 -0
  297. package/dist/server/config/cloudflare.js +45 -0
  298. package/dist/server/config/cloudflare.js.map +1 -0
  299. package/dist/server/config/constants.d.ts +1 -0
  300. package/dist/server/config/constants.js +7 -0
  301. package/dist/server/config/constants.js.map +1 -0
  302. package/dist/server/config/dotenv.d.ts +35 -0
  303. package/dist/server/config/dotenv.js +42 -0
  304. package/dist/server/config/dotenv.js.map +1 -0
  305. package/dist/server/config/index.d.ts +9 -0
  306. package/dist/server/config/index.js +31 -0
  307. package/dist/server/config/index.js.map +1 -0
  308. package/dist/server/config/kms.d.ts +22 -0
  309. package/dist/server/config/kms.js +54 -0
  310. package/dist/server/config/kms.js.map +1 -0
  311. package/dist/server/config/prisma.d.ts +20 -0
  312. package/dist/server/config/prisma.js +40 -0
  313. package/dist/server/config/prisma.js.map +1 -0
  314. package/dist/server/config/redis.d.ts +57 -0
  315. package/dist/server/config/redis.js +121 -0
  316. package/dist/server/config/redis.js.map +1 -0
  317. package/dist/server/config/urls.d.ts +49 -0
  318. package/dist/server/config/urls.js +7 -0
  319. package/dist/server/config/urls.js.map +1 -0
  320. package/dist/server/config/winston.d.ts +3 -0
  321. package/dist/server/config/winston.js +14 -0
  322. package/dist/server/config/winston.js.map +1 -0
  323. package/dist/server/contracts/clients/index.d.ts +1 -0
  324. package/dist/server/contracts/clients/index.js +18 -0
  325. package/dist/server/contracts/clients/index.js.map +1 -0
  326. package/dist/server/contracts/clients/ozRelayerService.d.ts +18 -0
  327. package/dist/server/contracts/clients/ozRelayerService.js +167 -0
  328. package/dist/server/contracts/clients/ozRelayerService.js.map +1 -0
  329. package/dist/server/contracts/index.d.ts +2 -0
  330. package/dist/server/contracts/index.js +19 -0
  331. package/dist/server/contracts/index.js.map +1 -0
  332. package/dist/server/contracts/instances.d.ts +20 -0
  333. package/dist/server/contracts/instances.js +28 -0
  334. package/dist/server/contracts/instances.js.map +1 -0
  335. package/dist/server/index.d.ts +11 -0
  336. package/dist/server/index.js +36 -0
  337. package/dist/server/index.js.map +1 -0
  338. package/dist/server/instrumentation.d.ts +9 -0
  339. package/dist/server/instrumentation.js +37 -0
  340. package/dist/server/instrumentation.js.map +1 -0
  341. package/dist/server/liquidation-engine/index.d.ts +3 -0
  342. package/dist/server/liquidation-engine/index.js +20 -0
  343. package/dist/server/liquidation-engine/index.js.map +1 -0
  344. package/dist/server/liquidation-engine/redis.cache.manager/cache.keys.util.d.ts +10 -0
  345. package/dist/server/liquidation-engine/redis.cache.manager/cache.keys.util.js +15 -0
  346. package/dist/server/liquidation-engine/redis.cache.manager/cache.keys.util.js.map +1 -0
  347. package/dist/server/liquidation-engine/redis.cache.manager/prices.set.manager.d.ts +124 -0
  348. package/dist/server/liquidation-engine/redis.cache.manager/prices.set.manager.js +242 -0
  349. package/dist/server/liquidation-engine/redis.cache.manager/prices.set.manager.js.map +1 -0
  350. package/dist/server/liquidation-engine/redis.cache.manager/prices.set.manager.test.d.ts +1 -0
  351. package/dist/server/liquidation-engine/redis.cache.manager/prices.set.manager.test.js +115 -0
  352. package/dist/server/liquidation-engine/redis.cache.manager/prices.set.manager.test.js.map +1 -0
  353. package/dist/server/liquidation-engine/types/index.d.ts +1 -0
  354. package/dist/server/liquidation-engine/types/index.js +3 -0
  355. package/dist/server/liquidation-engine/types/index.js.map +1 -0
  356. package/dist/server/middleware/auth/cloudflare.handler.d.ts +6 -0
  357. package/dist/server/middleware/auth/cloudflare.handler.js +37 -0
  358. package/dist/server/middleware/auth/cloudflare.handler.js.map +1 -0
  359. package/dist/server/middleware/auth/hmac.handler.d.ts +11 -0
  360. package/dist/server/middleware/auth/hmac.handler.js +157 -0
  361. package/dist/server/middleware/auth/hmac.handler.js.map +1 -0
  362. package/dist/server/middleware/auth/index.d.ts +3 -0
  363. package/dist/server/middleware/auth/index.js +20 -0
  364. package/dist/server/middleware/auth/index.js.map +1 -0
  365. package/dist/server/middleware/auth/privy.handler.d.ts +7 -0
  366. package/dist/server/middleware/auth/privy.handler.js +31 -0
  367. package/dist/server/middleware/auth/privy.handler.js.map +1 -0
  368. package/dist/server/middleware/index.d.ts +2 -0
  369. package/dist/server/middleware/index.js +19 -0
  370. package/dist/server/middleware/index.js.map +1 -0
  371. package/dist/server/middleware/multiAuth.examples.d.ts +46 -0
  372. package/dist/server/middleware/multiAuth.examples.js +123 -0
  373. package/dist/server/middleware/multiAuth.examples.js.map +1 -0
  374. package/dist/server/middleware/multiAuth.middleware.d.ts +30 -0
  375. package/dist/server/middleware/multiAuth.middleware.js +90 -0
  376. package/dist/server/middleware/multiAuth.middleware.js.map +1 -0
  377. package/dist/server/middleware/rateLimit.middleware.d.ts +1 -0
  378. package/dist/server/middleware/rateLimit.middleware.js +19 -0
  379. package/dist/server/middleware/rateLimit.middleware.js.map +1 -0
  380. package/dist/server/oracle/index.d.ts +3 -0
  381. package/dist/server/oracle/index.js +20 -0
  382. package/dist/server/oracle/index.js.map +1 -0
  383. package/dist/server/oracle/redis-cache-manager/cache.keys.utils.d.ts +90 -0
  384. package/dist/server/oracle/redis-cache-manager/cache.keys.utils.js +147 -0
  385. package/dist/server/oracle/redis-cache-manager/cache.keys.utils.js.map +1 -0
  386. package/dist/server/oracle/redis-cache-manager/channels.d.ts +2 -0
  387. package/dist/server/oracle/redis-cache-manager/channels.js +11 -0
  388. package/dist/server/oracle/redis-cache-manager/channels.js.map +1 -0
  389. package/dist/server/oracle/redis-cache-manager/game.cache.service.d.ts +184 -0
  390. package/dist/server/oracle/redis-cache-manager/game.cache.service.js +698 -0
  391. package/dist/server/oracle/redis-cache-manager/game.cache.service.js.map +1 -0
  392. package/dist/server/oracle/redis-cache-manager/index.d.ts +4 -0
  393. package/dist/server/oracle/redis-cache-manager/index.js +21 -0
  394. package/dist/server/oracle/redis-cache-manager/index.js.map +1 -0
  395. package/dist/server/oracle/redis-cache-manager/market.cache.service.d.ts +115 -0
  396. package/dist/server/oracle/redis-cache-manager/market.cache.service.js +279 -0
  397. package/dist/server/oracle/redis-cache-manager/market.cache.service.js.map +1 -0
  398. package/dist/server/oracle/rmq-manager/base.queue.manager.d.ts +21 -0
  399. package/dist/server/oracle/rmq-manager/base.queue.manager.js +128 -0
  400. package/dist/server/oracle/rmq-manager/base.queue.manager.js.map +1 -0
  401. package/dist/server/oracle/rmq-manager/index.d.ts +2 -0
  402. package/dist/server/oracle/rmq-manager/index.js +19 -0
  403. package/dist/server/oracle/rmq-manager/index.js.map +1 -0
  404. package/dist/server/oracle/rmq-manager/queue.configs.d.ts +5 -0
  405. package/dist/server/oracle/rmq-manager/queue.configs.js +38 -0
  406. package/dist/server/oracle/rmq-manager/queue.configs.js.map +1 -0
  407. package/dist/server/oracle/types/index.d.ts +2 -0
  408. package/dist/server/oracle/types/index.js +19 -0
  409. package/dist/server/oracle/types/index.js.map +1 -0
  410. package/dist/server/oracle/types/providers/index.d.ts +4 -0
  411. package/dist/server/oracle/types/providers/index.js +21 -0
  412. package/dist/server/oracle/types/providers/index.js.map +1 -0
  413. package/dist/server/oracle/types/providers/lsports.types.d.ts +148 -0
  414. package/dist/server/oracle/types/providers/lsports.types.js +13 -0
  415. package/dist/server/oracle/types/providers/lsports.types.js.map +1 -0
  416. package/dist/server/oracle/types/providers/optic.odds.types.d.ts +293 -0
  417. package/dist/server/oracle/types/providers/optic.odds.types.js +140 -0
  418. package/dist/server/oracle/types/providers/optic.odds.types.js.map +1 -0
  419. package/dist/server/oracle/types/providers/providers.types.d.ts +5 -0
  420. package/dist/server/oracle/types/providers/providers.types.js +10 -0
  421. package/dist/server/oracle/types/providers/providers.types.js.map +1 -0
  422. package/dist/server/oracle/types/providers/rundown.types.d.ts +194 -0
  423. package/dist/server/oracle/types/providers/rundown.types.js +22 -0
  424. package/dist/server/oracle/types/providers/rundown.types.js.map +1 -0
  425. package/dist/server/oracle/types/queue/index.d.ts +2 -0
  426. package/dist/server/oracle/types/queue/index.js +19 -0
  427. package/dist/server/oracle/types/queue/index.js.map +1 -0
  428. package/dist/server/oracle/types/queue/queue.constant.d.ts +10 -0
  429. package/dist/server/oracle/types/queue/queue.constant.js +14 -0
  430. package/dist/server/oracle/types/queue/queue.constant.js.map +1 -0
  431. package/dist/server/oracle/types/queue/queue.types.d.ts +5 -0
  432. package/dist/server/oracle/types/queue/queue.types.js +3 -0
  433. package/dist/server/oracle/types/queue/queue.types.js.map +1 -0
  434. package/dist/server/prisma/index.d.ts +2 -0
  435. package/dist/server/prisma/index.js +24 -0
  436. package/dist/server/prisma/index.js.map +1 -0
  437. package/dist/server/repositories/apiKey.repository.d.ts +7 -0
  438. package/dist/server/repositories/apiKey.repository.js +19 -0
  439. package/dist/server/repositories/apiKey.repository.js.map +1 -0
  440. package/dist/server/repositories/index.d.ts +1 -0
  441. package/dist/server/repositories/index.js +18 -0
  442. package/dist/server/repositories/index.js.map +1 -0
  443. package/dist/server/services/cloudflare.service.d.ts +12 -0
  444. package/dist/server/services/cloudflare.service.js +24 -0
  445. package/dist/server/services/cloudflare.service.js.map +1 -0
  446. package/dist/server/services/crypto.service.d.ts +17 -0
  447. package/dist/server/services/crypto.service.js +50 -0
  448. package/dist/server/services/crypto.service.js.map +1 -0
  449. package/dist/server/services/hmac.service.d.ts +52 -0
  450. package/dist/server/services/hmac.service.js +115 -0
  451. package/dist/server/services/hmac.service.js.map +1 -0
  452. package/dist/server/services/index.d.ts +5 -0
  453. package/dist/server/services/index.js +22 -0
  454. package/dist/server/services/index.js.map +1 -0
  455. package/dist/server/services/presigned.urls.d.ts +11 -0
  456. package/dist/server/services/presigned.urls.js +41 -0
  457. package/dist/server/services/presigned.urls.js.map +1 -0
  458. package/dist/server/services/privy.service.d.ts +30 -0
  459. package/dist/server/services/privy.service.js +122 -0
  460. package/dist/server/services/privy.service.js.map +1 -0
  461. package/dist/server/test-relayers.d.ts +1 -0
  462. package/dist/server/test-relayers.js +17 -0
  463. package/dist/server/test-relayers.js.map +1 -0
  464. package/dist/server/types/auth.types.d.ts +8 -0
  465. package/dist/server/types/auth.types.js +3 -0
  466. package/dist/server/types/auth.types.js.map +1 -0
  467. package/dist/server/types/global.types.d.ts +35 -0
  468. package/dist/server/types/global.types.js +4 -0
  469. package/dist/server/types/global.types.js.map +1 -0
  470. package/dist/server/types/index.d.ts +2 -0
  471. package/dist/server/types/index.js +19 -0
  472. package/dist/server/types/index.js.map +1 -0
  473. package/dist/server/utils/express.utils.d.ts +24 -0
  474. package/dist/server/utils/express.utils.js +36 -0
  475. package/dist/server/utils/express.utils.js.map +1 -0
  476. package/dist/server/utils/index.d.ts +2 -0
  477. package/dist/server/utils/index.js +19 -0
  478. package/dist/server/utils/index.js.map +1 -0
  479. package/dist/server/utils/tracing/index.d.ts +2 -0
  480. package/dist/server/utils/tracing/index.js +19 -0
  481. package/dist/server/utils/tracing/index.js.map +1 -0
  482. package/dist/server/utils/tracing/trace.d.ts +12 -0
  483. package/dist/server/utils/tracing/trace.js +50 -0
  484. package/dist/server/utils/tracing/trace.js.map +1 -0
  485. package/dist/server/utils/tracing/wrap.module.with.tracing.d.ts +126 -0
  486. package/dist/server/utils/tracing/wrap.module.with.tracing.js +202 -0
  487. package/dist/server/utils/tracing/wrap.module.with.tracing.js.map +1 -0
  488. package/package.json +126 -0
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.objectIdSchema = void 0;
7
+ const bson_1 = require("bson");
8
+ const zod_1 = __importDefault(require("zod"));
9
+ exports.objectIdSchema = zod_1.default.string().refine((val) => bson_1.ObjectId.isValid(val), { message: "Invalid MongoDB ObjectId" });
10
+ //# sourceMappingURL=mongo.validators.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mongo.validators.js","sourceRoot":"","sources":["../../../src/core/validators/mongo.validators.ts"],"names":[],"mappings":";;;;;;AAAA,+BAA+B;AAC/B,8CAAmB;AAEN,QAAA,cAAc,GAAG,aAAC,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,eAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,EAAE,OAAO,EAAE,0BAA0B,EAAE,CAAC,CAAA"}
@@ -0,0 +1 @@
1
+ export * from "./core";
package/dist/index.js ADDED
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ // Main entry point - exports everything from core by default
18
+ __exportStar(require("./core"), exports);
19
+ //
20
+ // Note: Server and React modules should be imported via specific paths:.
21
+ // import { ... } from "@levrbet/shared/server"
22
+ // import { ... } from "@levrbet/shared/react"
23
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6DAA6D;AAC7D,yCAAsB;AACtB,EAAE;AACF,yEAAyE;AAEzE,+CAA+C;AAC/C,8CAA8C"}
@@ -0,0 +1 @@
1
+ export * from "./useAuthHeaders";
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./useAuthHeaders"), exports);
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/react/hooks/auth/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAgC"}
@@ -0,0 +1,45 @@
1
+ /**
2
+ * Auth Headers Hook
3
+ *
4
+ * IMPORTANT: Before using this hook, you must inject the dependencies from your application:
5
+ *
6
+ * ```typescript
7
+ * import { injectDependencies } from '@levr/shared/react';
8
+ * import { usePrivy, useIdentityToken, useUser } from '@privy-io/react-auth';
9
+ * import { useQuery } from '@tanstack/react-query';
10
+ * import { LevrEnv } from '@levr/shared/core';
11
+ *
12
+ * // Call this once in your app initialization (e.g., in your root component or main.tsx)
13
+ * injectDependencies({ usePrivy, useIdentityToken, useUser, useQuery, levrEnv: LevrEnv.TESTNET });
14
+ * ```
15
+ *
16
+ * This ensures that the shared library uses your application's React context and configuration
17
+ * instead of creating its own, which would cause context duplication issues.
18
+ */
19
+ import { Address } from "viem";
20
+ import { LevrAuth } from "../../../core";
21
+ export interface UseAuthHeadersProps {
22
+ address?: Address;
23
+ }
24
+ export declare const useAuthHeaders: (props?: UseAuthHeadersProps) => import("@tanstack/react-query").UseQueryResult<{
25
+ "x-levr-auth-type"?: undefined;
26
+ "x-eth-address"?: undefined;
27
+ "privy-access-token"?: undefined;
28
+ "privy-id-token"?: undefined;
29
+ } | {
30
+ "x-levr-auth-type": LevrAuth;
31
+ "x-eth-address": `0x${string}` | undefined;
32
+ "privy-access-token": string | null;
33
+ "privy-id-token": string | null;
34
+ }, Error>;
35
+ export declare const useAdminAuthHeaders: (props?: UseAuthHeadersProps) => import("@tanstack/react-query").UseQueryResult<{
36
+ "x-levr-auth-type"?: undefined;
37
+ "x-eth-address"?: undefined;
38
+ "privy-access-token"?: undefined;
39
+ "privy-id-token"?: undefined;
40
+ } | {
41
+ "x-levr-auth-type": LevrAuth;
42
+ "x-eth-address": `0x${string}` | undefined;
43
+ "privy-access-token": string | null;
44
+ "privy-id-token": string | null;
45
+ }, Error>;
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ /**
3
+ * Auth Headers Hook
4
+ *
5
+ * IMPORTANT: Before using this hook, you must inject the dependencies from your application:
6
+ *
7
+ * ```typescript
8
+ * import { injectDependencies } from '@levr/shared/react';
9
+ * import { usePrivy, useIdentityToken, useUser } from '@privy-io/react-auth';
10
+ * import { useQuery } from '@tanstack/react-query';
11
+ * import { LevrEnv } from '@levr/shared/core';
12
+ *
13
+ * // Call this once in your app initialization (e.g., in your root component or main.tsx)
14
+ * injectDependencies({ usePrivy, useIdentityToken, useUser, useQuery, levrEnv: LevrEnv.TESTNET });
15
+ * ```
16
+ *
17
+ * This ensures that the shared library uses your application's React context and configuration
18
+ * instead of creating its own, which would cause context duplication issues.
19
+ */
20
+ var __importDefault = (this && this.__importDefault) || function (mod) {
21
+ return (mod && mod.__esModule) ? mod : { "default": mod };
22
+ };
23
+ Object.defineProperty(exports, "__esModule", { value: true });
24
+ exports.useAdminAuthHeaders = exports.useAuthHeaders = void 0;
25
+ const lodash_1 = __importDefault(require("lodash"));
26
+ const ms_1 = __importDefault(require("ms"));
27
+ const core_1 = require("../../../core");
28
+ const constants_1 = require("../../../core/privy/constants");
29
+ const injectedDependencies_1 = require("../../injectedDependencies");
30
+ const queryKeys_1 = require("../../queryKeys");
31
+ function useBaseAuthHeaders(levrAuth, props = {}) {
32
+ const { address } = props;
33
+ const { usePrivy, useIdentityToken, useUser, useQuery } = (0, injectedDependencies_1.getDependencies)();
34
+ const { getAccessToken, user } = usePrivy();
35
+ const { identityToken } = useIdentityToken();
36
+ const { refreshUser } = useUser();
37
+ return useQuery({
38
+ queryKey: queryKeys_1.queryKeys.auth.headers(levrAuth, user?.id, address),
39
+ queryFn: async () => {
40
+ if (!user)
41
+ return {};
42
+ await refreshUser();
43
+ return {
44
+ [core_1.LEVR_AUTH_HEADER]: levrAuth,
45
+ [constants_1.ETH_ADDRESS_HEADER]: address,
46
+ [constants_1.PRIVY_ACCESS_TOKEN_HEADER]: await getAccessToken(),
47
+ [constants_1.PRIVY_ID_TOKEN_HEADER]: identityToken,
48
+ };
49
+ },
50
+ enabled: !lodash_1.default.isNil(user),
51
+ refetchInterval: (0, ms_1.default)("5m"),
52
+ });
53
+ }
54
+ const useAuthHeaders = (props) => useBaseAuthHeaders(core_1.LevrAuth.PRIVY_USER, props);
55
+ exports.useAuthHeaders = useAuthHeaders;
56
+ const useAdminAuthHeaders = (props) => useBaseAuthHeaders(core_1.LevrAuth.PRIVY_ADMIN, props);
57
+ exports.useAdminAuthHeaders = useAdminAuthHeaders;
58
+ //# sourceMappingURL=useAuthHeaders.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useAuthHeaders.js","sourceRoot":"","sources":["../../../../src/react/hooks/auth/useAuthHeaders.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;GAiBG;;;;;;AAEH,oDAAsB;AACtB,4CAAmB;AAGnB,wCAA0D;AAC1D,6DAAoH;AACpH,qEAA4D;AAC5D,+CAA2C;AAM3C,SAAS,kBAAkB,CAAC,QAAkB,EAAE,QAA6B,EAAE;IAC3E,MAAM,EAAE,OAAO,EAAE,GAAG,KAAK,CAAA;IACzB,MAAM,EAAE,QAAQ,EAAE,gBAAgB,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,IAAA,sCAAe,GAAE,CAAA;IAC3E,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,GAAG,QAAQ,EAAE,CAAA;IAC3C,MAAM,EAAE,aAAa,EAAE,GAAG,gBAAgB,EAAE,CAAA;IAC5C,MAAM,EAAE,WAAW,EAAE,GAAG,OAAO,EAAE,CAAA;IAEjC,OAAO,QAAQ,CAAC;QACZ,QAAQ,EAAE,qBAAS,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,IAAI,EAAE,EAAE,EAAE,OAAO,CAAC;QAC7D,OAAO,EAAE,KAAK,IAAI,EAAE;YAChB,IAAI,CAAC,IAAI;gBAAE,OAAO,EAAE,CAAA;YACpB,MAAM,WAAW,EAAE,CAAA;YAEnB,OAAO;gBACH,CAAC,uBAAgB,CAAC,EAAE,QAAQ;gBAC5B,CAAC,8BAAkB,CAAC,EAAE,OAAO;gBAC7B,CAAC,qCAAyB,CAAC,EAAE,MAAM,cAAc,EAAE;gBACnD,CAAC,iCAAqB,CAAC,EAAE,aAAa;aACzC,CAAA;QACL,CAAC;QACD,OAAO,EAAE,CAAC,gBAAC,CAAC,KAAK,CAAC,IAAI,CAAC;QACvB,eAAe,EAAE,IAAA,YAAE,EAAC,IAAI,CAAC;KAC5B,CAAC,CAAA;AACN,CAAC;AAEM,MAAM,cAAc,GAAG,CAAC,KAA2B,EAAE,EAAE,CAAC,kBAAkB,CAAC,eAAQ,CAAC,UAAU,EAAE,KAAK,CAAC,CAAA;AAAhG,QAAA,cAAc,kBAAkF;AAEtG,MAAM,mBAAmB,GAAG,CAAC,KAA2B,EAAE,EAAE,CAAC,kBAAkB,CAAC,eAAQ,CAAC,WAAW,EAAE,KAAK,CAAC,CAAA;AAAtG,QAAA,mBAAmB,uBAAmF"}
@@ -0,0 +1,6 @@
1
+ export * from "./useApproveErc20";
2
+ export * from "./useErc20Allowance";
3
+ export * from "./useErc20Balance";
4
+ export * from "./useErc20Decimals";
5
+ export * from "./useErc20Symbol";
6
+ export * from "./useTransferErc20";
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./useApproveErc20"), exports);
18
+ __exportStar(require("./useErc20Allowance"), exports);
19
+ __exportStar(require("./useErc20Balance"), exports);
20
+ __exportStar(require("./useErc20Decimals"), exports);
21
+ __exportStar(require("./useErc20Symbol"), exports);
22
+ __exportStar(require("./useTransferErc20"), exports);
23
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/react/hooks/contracts/erc20/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAiC;AACjC,sDAAmC;AACnC,oDAAiC;AACjC,qDAAkC;AAClC,mDAAgC;AAChC,qDAAkC"}
@@ -0,0 +1,13 @@
1
+ import { Address } from "viem";
2
+ import { LevrChain } from "../../../../core";
3
+ interface UseApproveErc20Params {
4
+ erc20Address?: Address;
5
+ chainId?: LevrChain;
6
+ spenderAddress?: Address;
7
+ }
8
+ export declare const useApproveErc20: ({ erc20Address, chainId: _chainId, spenderAddress }?: UseApproveErc20Params) => import("@tanstack/react-query").UseMutationResult<{
9
+ hash: `0x${string}`;
10
+ }, Error, {
11
+ amount: bigint;
12
+ }, unknown>;
13
+ export {};
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useApproveErc20 = void 0;
4
+ const core_1 = require("../../../../core");
5
+ const injectedDependencies_1 = require("../../../injectedDependencies");
6
+ const queryKeys_1 = require("../../../queryKeys");
7
+ const useApproveErc20 = ({ erc20Address, chainId: _chainId, spenderAddress } = {}) => {
8
+ const { useMutation, useChainId, useConnectorClient, useAccount } = (0, injectedDependencies_1.getDependencies)();
9
+ const chainId = useChainId?.() ?? _chainId;
10
+ const { data: walletClient } = useConnectorClient?.() ?? {};
11
+ const { address: userAddress } = useAccount?.() ?? {};
12
+ return useMutation({
13
+ mutationFn: async ({ amount }) => {
14
+ if (!erc20Address || !chainId || !spenderAddress)
15
+ throw new Error("Missing erc20Address, chainId, or spenderAddress");
16
+ if (!walletClient)
17
+ throw new Error("Wallet client not available");
18
+ const contract = (0, core_1.getErc20Contract)(erc20Address, chainId, { walletClient });
19
+ const hash = await contract.write.approve([spenderAddress, amount]);
20
+ return { hash };
21
+ },
22
+ meta: {
23
+ invalidatesQueries: [queryKeys_1.queryKeys.erc20.allowance(erc20Address, userAddress, spenderAddress, chainId)],
24
+ },
25
+ });
26
+ };
27
+ exports.useApproveErc20 = useApproveErc20;
28
+ //# sourceMappingURL=useApproveErc20.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useApproveErc20.js","sourceRoot":"","sources":["../../../../../src/react/hooks/contracts/erc20/useApproveErc20.ts"],"names":[],"mappings":";;;AACA,2CAA8D;AAC9D,wEAA+D;AAC/D,kDAA8C;AAQvC,MAAM,eAAe,GAAG,CAAC,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,cAAc,KAA4B,EAAE,EAAE,EAAE;IAC/G,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,kBAAkB,EAAE,UAAU,EAAE,GAAG,IAAA,sCAAe,GAAE,CAAA;IACrF,MAAM,OAAO,GAAG,UAAU,EAAE,EAAE,IAAI,QAAQ,CAAA;IAC1C,MAAM,EAAE,IAAI,EAAE,YAAY,EAAE,GAAG,kBAAkB,EAAE,EAAE,IAAI,EAAE,CAAA;IAC3D,MAAM,EAAE,OAAO,EAAE,WAAW,EAAE,GAAG,UAAU,EAAE,EAAE,IAAI,EAAE,CAAA;IAErD,OAAO,WAAY,CAAC;QAChB,UAAU,EAAE,KAAK,EAAE,EAAE,MAAM,EAAsB,EAAE,EAAE;YACjD,IAAI,CAAC,YAAY,IAAI,CAAC,OAAO,IAAI,CAAC,cAAc;gBAAE,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAA;YACrH,IAAI,CAAC,YAAY;gBAAE,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAA;YAEjE,MAAM,QAAQ,GAAG,IAAA,uBAAgB,EAAC,YAAY,EAAE,OAAO,EAAE,EAAE,YAAY,EAAE,CAAC,CAAA;YAC1E,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC,CAAA;YAEnE,OAAO,EAAE,IAAI,EAAE,CAAA;QACnB,CAAC;QACD,IAAI,EAAE;YACF,kBAAkB,EAAE,CAAC,qBAAS,CAAC,KAAK,CAAC,SAAS,CAAC,YAAY,EAAE,WAAW,EAAE,cAAc,EAAE,OAAO,CAAC,CAAC;SACtG;KACJ,CAAC,CAAA;AACN,CAAC,CAAA;AApBY,QAAA,eAAe,mBAoB3B"}
@@ -0,0 +1,10 @@
1
+ import { Address } from "viem";
2
+ import { LevrChain } from "../../../../core";
3
+ interface UseErc20AllowanceParams {
4
+ erc20Address?: Address;
5
+ ownerAddress?: Address;
6
+ spenderAddress?: Address;
7
+ chainId?: LevrChain;
8
+ }
9
+ export declare const useErc20Allowance: ({ erc20Address, ownerAddress: _ownerAddress, spenderAddress, chainId: _chainId, }: UseErc20AllowanceParams) => import("@tanstack/react-query").UseQueryResult<bigint, Error>;
10
+ export {};
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.useErc20Allowance = void 0;
7
+ const react_query_1 = require("@tanstack/react-query");
8
+ const lodash_1 = __importDefault(require("lodash"));
9
+ const core_1 = require("../../../../core");
10
+ const injectedDependencies_1 = require("../../../injectedDependencies");
11
+ const queryKeys_1 = require("../../../queryKeys");
12
+ const erc20AllowanceQueryOptions = ({ erc20Address, ownerAddress, spenderAddress, chainId }) => (0, react_query_1.queryOptions)({
13
+ queryKey: queryKeys_1.queryKeys.erc20.allowance(erc20Address, ownerAddress, spenderAddress, chainId),
14
+ queryFn: async () => {
15
+ if (!erc20Address || !ownerAddress || !spenderAddress || !chainId) {
16
+ throw new Error("Missing erc20Address, ownerAddress, spenderAddress, or chainId");
17
+ }
18
+ const contract = (0, core_1.getErc20Contract)(erc20Address, chainId);
19
+ return await contract.read.allowance([ownerAddress, spenderAddress]);
20
+ },
21
+ enabled: !lodash_1.default.isNil(erc20Address) && !lodash_1.default.isNil(ownerAddress) && !lodash_1.default.isNil(spenderAddress) && !lodash_1.default.isNil(chainId),
22
+ });
23
+ const useErc20Allowance = ({ erc20Address, ownerAddress: _ownerAddress, spenderAddress, chainId: _chainId, }) => {
24
+ const { useQuery, useAccount, useChainId } = (0, injectedDependencies_1.getDependencies)();
25
+ const { address } = useAccount?.() ?? {};
26
+ const ownerAddress = _ownerAddress ?? address;
27
+ const chainId = useChainId?.() ?? _chainId;
28
+ return useQuery({
29
+ ...erc20AllowanceQueryOptions({ erc20Address, ownerAddress, spenderAddress, chainId }),
30
+ enabled: !lodash_1.default.isNil(erc20Address) && !lodash_1.default.isNil(ownerAddress) && !lodash_1.default.isNil(spenderAddress) && !lodash_1.default.isNil(chainId),
31
+ });
32
+ };
33
+ exports.useErc20Allowance = useErc20Allowance;
34
+ //# sourceMappingURL=useErc20Allowance.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useErc20Allowance.js","sourceRoot":"","sources":["../../../../../src/react/hooks/contracts/erc20/useErc20Allowance.ts"],"names":[],"mappings":";;;;;;AAAA,uDAAoD;AACpD,oDAAsB;AAEtB,2CAA8D;AAC9D,wEAA+D;AAC/D,kDAA8C;AAS9C,MAAM,0BAA0B,GAAG,CAAC,EAAE,YAAY,EAAE,YAAY,EAAE,cAAc,EAAE,OAAO,EAA2B,EAAE,EAAE,CACpH,IAAA,0BAAY,EAAC;IACT,QAAQ,EAAE,qBAAS,CAAC,KAAK,CAAC,SAAS,CAAC,YAAY,EAAE,YAAY,EAAE,cAAc,EAAE,OAAO,CAAC;IACxF,OAAO,EAAE,KAAK,IAAI,EAAE;QAChB,IAAI,CAAC,YAAY,IAAI,CAAC,YAAY,IAAI,CAAC,cAAc,IAAI,CAAC,OAAO,EAAE,CAAC;YAChE,MAAM,IAAI,KAAK,CAAC,gEAAgE,CAAC,CAAA;QACrF,CAAC;QACD,MAAM,QAAQ,GAAG,IAAA,uBAAgB,EAAC,YAAY,EAAE,OAAO,CAAC,CAAA;QACxD,OAAO,MAAM,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,YAAY,EAAE,cAAc,CAAC,CAAC,CAAA;IACxE,CAAC;IACD,OAAO,EAAE,CAAC,gBAAC,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,OAAO,CAAC;CAC7G,CAAC,CAAA;AAEC,MAAM,iBAAiB,GAAG,CAAC,EAC9B,YAAY,EACZ,YAAY,EAAE,aAAa,EAC3B,cAAc,EACd,OAAO,EAAE,QAAQ,GACK,EAAE,EAAE;IAC1B,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,IAAA,sCAAe,GAAE,CAAA;IAC9D,MAAM,EAAE,OAAO,EAAE,GAAG,UAAU,EAAE,EAAE,IAAI,EAAE,CAAA;IACxC,MAAM,YAAY,GAAG,aAAa,IAAI,OAAO,CAAA;IAC7C,MAAM,OAAO,GAAG,UAAU,EAAE,EAAE,IAAI,QAAQ,CAAA;IAE1C,OAAO,QAAQ,CAAC;QACZ,GAAG,0BAA0B,CAAC,EAAE,YAAY,EAAE,YAAY,EAAE,cAAc,EAAE,OAAO,EAAE,CAAC;QACtF,OAAO,EAAE,CAAC,gBAAC,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,OAAO,CAAC;KAC7G,CAAC,CAAA;AACN,CAAC,CAAA;AAfY,QAAA,iBAAiB,qBAe7B"}
@@ -0,0 +1,22 @@
1
+ import { Address } from "viem";
2
+ import { LevrChain } from "../../../../core";
3
+ interface UseErc20BalanceParams {
4
+ erc20Address?: Address;
5
+ userAddress?: Address;
6
+ chainId?: LevrChain;
7
+ }
8
+ interface UseErc20FormattedBalanceParams extends UseErc20BalanceParams {
9
+ decimalPlaces?: number;
10
+ }
11
+ export declare const useErc20Balance: ({ erc20Address, userAddress: _userAddress, chainId: _chainId }: UseErc20BalanceParams) => import("@tanstack/react-query").UseQueryResult<bigint, Error>;
12
+ /**
13
+ * Hook to get formatted ERC20 balance
14
+ * @param decimalPlaces - Number of decimal places to show (default: 2). Truncates by removing excess decimals.
15
+ */
16
+ export declare const useErc20FormattedBalance: ({ erc20Address, userAddress: _userAddress, chainId: _chainId, decimalPlaces, }: UseErc20FormattedBalanceParams) => import("@tanstack/react-query").UseQueryResult<string, Error>;
17
+ /**
18
+ * Hook to get ERC20 balance formatted with commas
19
+ * @param decimalPlaces - Number of decimal places to show (default: 2). Truncates by removing excess decimals.
20
+ */
21
+ export declare const useErc20NumberFormattedBalance: ({ erc20Address, userAddress: _userAddress, chainId: _chainId, decimalPlaces, }: UseErc20FormattedBalanceParams) => import("@tanstack/react-query").UseQueryResult<string, Error>;
22
+ export {};
@@ -0,0 +1,95 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.useErc20NumberFormattedBalance = exports.useErc20FormattedBalance = exports.useErc20Balance = void 0;
7
+ const react_query_1 = require("@tanstack/react-query");
8
+ const lodash_1 = __importDefault(require("lodash"));
9
+ const viem_1 = require("viem");
10
+ const core_1 = require("../../../../core");
11
+ const injectedDependencies_1 = require("../../../injectedDependencies");
12
+ const queryKeys_1 = require("../../../queryKeys");
13
+ const useErc20Decimals_1 = require("./useErc20Decimals");
14
+ const erc20BalanceQueryOptions = ({ erc20Address, userAddress, chainId }) => (0, react_query_1.queryOptions)({
15
+ queryKey: queryKeys_1.queryKeys.erc20.balance(erc20Address, userAddress, chainId),
16
+ queryFn: async () => {
17
+ if (!erc20Address || !userAddress || !chainId)
18
+ throw new Error("Missing erc20Address, userAddress, or chainId");
19
+ const contract = (0, core_1.getErc20Contract)(erc20Address, chainId);
20
+ return await contract.read.balanceOf([userAddress]);
21
+ },
22
+ enabled: !lodash_1.default.isNil(erc20Address) && !lodash_1.default.isNil(userAddress) && !lodash_1.default.isNil(chainId),
23
+ });
24
+ const useErc20Balance = ({ erc20Address, userAddress: _userAddress, chainId: _chainId }) => {
25
+ const { useQuery, useAccount, useChainId } = (0, injectedDependencies_1.getDependencies)();
26
+ const { address } = useAccount?.() ?? {};
27
+ const userAddress = _userAddress ?? address;
28
+ const chainId = useChainId?.() ?? _chainId;
29
+ return useQuery({
30
+ ...erc20BalanceQueryOptions({ erc20Address, userAddress, chainId }),
31
+ enabled: !lodash_1.default.isNil(erc20Address) && !lodash_1.default.isNil(userAddress) && !lodash_1.default.isNil(chainId),
32
+ });
33
+ };
34
+ exports.useErc20Balance = useErc20Balance;
35
+ /**
36
+ * Hook to get formatted ERC20 balance
37
+ * @param decimalPlaces - Number of decimal places to show (default: 2). Truncates by removing excess decimals.
38
+ */
39
+ const useErc20FormattedBalance = ({ erc20Address, userAddress: _userAddress, chainId: _chainId, decimalPlaces = 2, }) => {
40
+ const { useQuery, useAccount, useChainId } = (0, injectedDependencies_1.getDependencies)();
41
+ const { address } = useAccount?.() ?? {};
42
+ const userAddress = _userAddress ?? address;
43
+ const chainId = useChainId?.() ?? _chainId;
44
+ const { data: decimals } = (0, useErc20Decimals_1.useErc20Decimals)({ erc20Address, chainId });
45
+ return useQuery({
46
+ ...erc20BalanceQueryOptions({ erc20Address, userAddress, chainId }),
47
+ select: (balance) => {
48
+ if (lodash_1.default.isNil(decimals))
49
+ return "0";
50
+ const formatted = (0, viem_1.formatUnits)(balance, decimals);
51
+ // Truncate to specified decimal places by removing excess decimals
52
+ const parts = formatted.split(".");
53
+ if (parts.length === 1 || decimalPlaces === 0) {
54
+ return parts[0] || "0";
55
+ }
56
+ const truncatedDecimals = parts[1]?.slice(0, decimalPlaces) || "";
57
+ return truncatedDecimals ? `${parts[0]}.${truncatedDecimals}` : parts[0] || "0";
58
+ },
59
+ enabled: !lodash_1.default.isNil(erc20Address) && !lodash_1.default.isNil(userAddress) && !lodash_1.default.isNil(chainId) && !lodash_1.default.isNil(decimals),
60
+ });
61
+ };
62
+ exports.useErc20FormattedBalance = useErc20FormattedBalance;
63
+ /**
64
+ * Hook to get ERC20 balance formatted with commas
65
+ * @param decimalPlaces - Number of decimal places to show (default: 2). Truncates by removing excess decimals.
66
+ */
67
+ const useErc20NumberFormattedBalance = ({ erc20Address, userAddress: _userAddress, chainId: _chainId, decimalPlaces = 2, }) => {
68
+ const { useQuery, useAccount, useChainId } = (0, injectedDependencies_1.getDependencies)();
69
+ const { address } = useAccount?.() ?? {};
70
+ const userAddress = _userAddress ?? address;
71
+ const chainId = useChainId?.() ?? _chainId;
72
+ const { data: decimals } = (0, useErc20Decimals_1.useErc20Decimals)({ erc20Address, chainId });
73
+ return useQuery({
74
+ ...erc20BalanceQueryOptions({ erc20Address, userAddress, chainId }),
75
+ select: (balance) => {
76
+ if (lodash_1.default.isNil(decimals))
77
+ return "0";
78
+ const formatted = (0, viem_1.formatUnits)(balance, decimals);
79
+ // Truncate to specified decimal places by removing excess decimals
80
+ const parts = formatted.split(".");
81
+ let truncated;
82
+ if (parts.length === 1 || decimalPlaces === 0) {
83
+ truncated = parts[0] || "0";
84
+ }
85
+ else {
86
+ const truncatedDecimals = parts[1]?.slice(0, decimalPlaces) || "";
87
+ truncated = truncatedDecimals ? `${parts[0]}.${truncatedDecimals}` : parts[0] || "0";
88
+ }
89
+ return (0, core_1.formatNumberWithCommas)(truncated);
90
+ },
91
+ enabled: !lodash_1.default.isNil(erc20Address) && !lodash_1.default.isNil(userAddress) && !lodash_1.default.isNil(chainId) && !lodash_1.default.isNil(decimals),
92
+ });
93
+ };
94
+ exports.useErc20NumberFormattedBalance = useErc20NumberFormattedBalance;
95
+ //# sourceMappingURL=useErc20Balance.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useErc20Balance.js","sourceRoot":"","sources":["../../../../../src/react/hooks/contracts/erc20/useErc20Balance.ts"],"names":[],"mappings":";;;;;;AAAA,uDAAoD;AACpD,oDAAsB;AACtB,+BAA2C;AAC3C,2CAAsF;AACtF,wEAA+D;AAC/D,kDAA8C;AAC9C,yDAAqD;AAYrD,MAAM,wBAAwB,GAAG,CAAC,EAAE,YAAY,EAAE,WAAW,EAAE,OAAO,EAAyB,EAAE,EAAE,CAC/F,IAAA,0BAAY,EAAC;IACT,QAAQ,EAAE,qBAAS,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,EAAE,WAAW,EAAE,OAAO,CAAC;IACrE,OAAO,EAAE,KAAK,IAAI,EAAE;QAChB,IAAI,CAAC,YAAY,IAAI,CAAC,WAAW,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAA;QAC/G,MAAM,QAAQ,GAAG,IAAA,uBAAgB,EAAC,YAAY,EAAE,OAAO,CAAC,CAAA;QACxD,OAAO,MAAM,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,WAAW,CAAC,CAAC,CAAA;IACvD,CAAC;IACD,OAAO,EAAE,CAAC,gBAAC,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,OAAO,CAAC;CAChF,CAAC,CAAA;AAEC,MAAM,eAAe,GAAG,CAAC,EAAE,YAAY,EAAE,WAAW,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAyB,EAAE,EAAE;IACrH,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,IAAA,sCAAe,GAAE,CAAA;IAC9D,MAAM,EAAE,OAAO,EAAE,GAAG,UAAU,EAAE,EAAE,IAAI,EAAE,CAAA;IACxC,MAAM,WAAW,GAAG,YAAY,IAAI,OAAO,CAAA;IAC3C,MAAM,OAAO,GAAG,UAAU,EAAE,EAAE,IAAI,QAAQ,CAAA;IAE1C,OAAO,QAAQ,CAAC;QACZ,GAAG,wBAAwB,CAAC,EAAE,YAAY,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC;QACnE,OAAO,EAAE,CAAC,gBAAC,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,OAAO,CAAC;KAChF,CAAC,CAAA;AACN,CAAC,CAAA;AAVY,QAAA,eAAe,mBAU3B;AAED;;;GAGG;AACI,MAAM,wBAAwB,GAAG,CAAC,EACrC,YAAY,EACZ,WAAW,EAAE,YAAY,EACzB,OAAO,EAAE,QAAQ,EACjB,aAAa,GAAG,CAAC,GACY,EAAE,EAAE;IACjC,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,IAAA,sCAAe,GAAE,CAAA;IAC9D,MAAM,EAAE,OAAO,EAAE,GAAG,UAAU,EAAE,EAAE,IAAI,EAAE,CAAA;IACxC,MAAM,WAAW,GAAG,YAAY,IAAI,OAAO,CAAA;IAC3C,MAAM,OAAO,GAAG,UAAU,EAAE,EAAE,IAAI,QAAQ,CAAA;IAC1C,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,IAAA,mCAAgB,EAAC,EAAE,YAAY,EAAE,OAAO,EAAE,CAAC,CAAA;IAEtE,OAAO,QAAQ,CAAC;QACZ,GAAG,wBAAwB,CAAC,EAAE,YAAY,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC;QACnE,MAAM,EAAE,CAAC,OAAO,EAAE,EAAE;YAChB,IAAI,gBAAC,CAAC,KAAK,CAAC,QAAQ,CAAC;gBAAE,OAAO,GAAG,CAAA;YAEjC,MAAM,SAAS,GAAG,IAAA,kBAAW,EAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;YAEhD,mEAAmE;YACnE,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YAClC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,aAAa,KAAK,CAAC,EAAE,CAAC;gBAC5C,OAAO,KAAK,CAAC,CAAC,CAAC,IAAI,GAAG,CAAA;YAC1B,CAAC;YAED,MAAM,iBAAiB,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,aAAa,CAAC,IAAI,EAAE,CAAA;YACjE,OAAO,iBAAiB,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,iBAAiB,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,GAAG,CAAA;QACnF,CAAC;QACD,OAAO,EAAE,CAAC,gBAAC,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,QAAQ,CAAC;KACtG,CAAC,CAAA;AACN,CAAC,CAAA;AA9BY,QAAA,wBAAwB,4BA8BpC;AAED;;;GAGG;AACI,MAAM,8BAA8B,GAAG,CAAC,EAC3C,YAAY,EACZ,WAAW,EAAE,YAAY,EACzB,OAAO,EAAE,QAAQ,EACjB,aAAa,GAAG,CAAC,GACY,EAAE,EAAE;IACjC,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,IAAA,sCAAe,GAAE,CAAA;IAC9D,MAAM,EAAE,OAAO,EAAE,GAAG,UAAU,EAAE,EAAE,IAAI,EAAE,CAAA;IACxC,MAAM,WAAW,GAAG,YAAY,IAAI,OAAO,CAAA;IAC3C,MAAM,OAAO,GAAG,UAAU,EAAE,EAAE,IAAI,QAAQ,CAAA;IAC1C,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,IAAA,mCAAgB,EAAC,EAAE,YAAY,EAAE,OAAO,EAAE,CAAC,CAAA;IAEtE,OAAO,QAAQ,CAAC;QACZ,GAAG,wBAAwB,CAAC,EAAE,YAAY,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC;QACnE,MAAM,EAAE,CAAC,OAAO,EAAE,EAAE;YAChB,IAAI,gBAAC,CAAC,KAAK,CAAC,QAAQ,CAAC;gBAAE,OAAO,GAAG,CAAA;YAEjC,MAAM,SAAS,GAAG,IAAA,kBAAW,EAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;YAEhD,mEAAmE;YACnE,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YAClC,IAAI,SAAiB,CAAA;YACrB,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,aAAa,KAAK,CAAC,EAAE,CAAC;gBAC5C,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,GAAG,CAAA;YAC/B,CAAC;iBAAM,CAAC;gBACJ,MAAM,iBAAiB,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,aAAa,CAAC,IAAI,EAAE,CAAA;gBACjE,SAAS,GAAG,iBAAiB,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,iBAAiB,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,GAAG,CAAA;YACxF,CAAC;YAED,OAAO,IAAA,6BAAsB,EAAC,SAAS,CAAC,CAAA;QAC5C,CAAC;QACD,OAAO,EAAE,CAAC,gBAAC,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,QAAQ,CAAC;KACtG,CAAC,CAAA;AACN,CAAC,CAAA;AAjCY,QAAA,8BAA8B,kCAiC1C"}
@@ -0,0 +1,8 @@
1
+ import { Address } from "viem";
2
+ import { LevrChain } from "../../../../core";
3
+ interface UseErc20DecimalParams {
4
+ erc20Address?: Address;
5
+ chainId?: LevrChain;
6
+ }
7
+ export declare const useErc20Decimals: ({ erc20Address, chainId: _chainId }: UseErc20DecimalParams) => import("@tanstack/react-query").UseQueryResult<number, Error>;
8
+ export {};
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.useErc20Decimals = void 0;
7
+ const lodash_1 = __importDefault(require("lodash"));
8
+ const core_1 = require("../../../../core");
9
+ const injectedDependencies_1 = require("../../../injectedDependencies");
10
+ const queryKeys_1 = require("../../../queryKeys");
11
+ const useErc20Decimals = ({ erc20Address, chainId: _chainId }) => {
12
+ const { useQuery, useChainId } = (0, injectedDependencies_1.getDependencies)();
13
+ const chainId = useChainId?.() ?? _chainId;
14
+ return useQuery({
15
+ queryKey: queryKeys_1.queryKeys.erc20.decimals(erc20Address, chainId),
16
+ queryFn: async () => {
17
+ if (!erc20Address || !chainId)
18
+ throw new Error("Missing erc20Address or chainId");
19
+ const contract = (0, core_1.getErc20Contract)(erc20Address, chainId);
20
+ return await contract.read.decimals();
21
+ },
22
+ enabled: !lodash_1.default.isNil(erc20Address) && !lodash_1.default.isNil(chainId),
23
+ staleTime: Infinity,
24
+ gcTime: Infinity,
25
+ });
26
+ };
27
+ exports.useErc20Decimals = useErc20Decimals;
28
+ //# sourceMappingURL=useErc20Decimals.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useErc20Decimals.js","sourceRoot":"","sources":["../../../../../src/react/hooks/contracts/erc20/useErc20Decimals.ts"],"names":[],"mappings":";;;;;;AAAA,oDAAsB;AAEtB,2CAA8D;AAC9D,wEAA+D;AAC/D,kDAA8C;AAOvC,MAAM,gBAAgB,GAAG,CAAC,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAyB,EAAE,EAAE;IAC3F,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,GAAG,IAAA,sCAAe,GAAE,CAAA;IAClD,MAAM,OAAO,GAAG,UAAU,EAAE,EAAE,IAAI,QAAQ,CAAA;IAE1C,OAAO,QAAQ,CAAC;QACZ,QAAQ,EAAE,qBAAS,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,EAAE,OAAO,CAAC;QACzD,OAAO,EAAE,KAAK,IAAI,EAAE;YAChB,IAAI,CAAC,YAAY,IAAI,CAAC,OAAO;gBAAE,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAA;YAEjF,MAAM,QAAQ,GAAG,IAAA,uBAAgB,EAAC,YAAY,EAAE,OAAO,CAAC,CAAA;YAExD,OAAO,MAAM,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAA;QACzC,CAAC;QACD,OAAO,EAAE,CAAC,gBAAC,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,OAAO,CAAC;QACpD,SAAS,EAAE,QAAQ;QACnB,MAAM,EAAE,QAAQ;KACnB,CAAC,CAAA;AACN,CAAC,CAAA;AAjBY,QAAA,gBAAgB,oBAiB5B"}
@@ -0,0 +1,8 @@
1
+ import { Address } from "viem";
2
+ import { LevrChain } from "../../../../core";
3
+ interface UseErc20SymbolParams {
4
+ erc20Address?: Address;
5
+ chainId?: LevrChain;
6
+ }
7
+ export declare const useErc20Symbol: ({ erc20Address, chainId: _chainId }: UseErc20SymbolParams) => import("@tanstack/react-query").UseQueryResult<string, Error>;
8
+ export {};
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.useErc20Symbol = void 0;
7
+ const lodash_1 = __importDefault(require("lodash"));
8
+ const core_1 = require("../../../../core");
9
+ const injectedDependencies_1 = require("../../../injectedDependencies");
10
+ const queryKeys_1 = require("../../../queryKeys");
11
+ const useErc20Symbol = ({ erc20Address, chainId: _chainId }) => {
12
+ const { useQuery, useChainId } = (0, injectedDependencies_1.getDependencies)();
13
+ const chainId = useChainId?.() ?? _chainId;
14
+ return useQuery({
15
+ queryKey: queryKeys_1.queryKeys.erc20.symbol(erc20Address, chainId),
16
+ queryFn: async () => {
17
+ if (!erc20Address || !chainId)
18
+ throw new Error("Missing erc20Address or chainId");
19
+ const contract = (0, core_1.getErc20Contract)(erc20Address, chainId);
20
+ return await contract.read.symbol();
21
+ },
22
+ enabled: !lodash_1.default.isNil(erc20Address) && !lodash_1.default.isNil(chainId),
23
+ staleTime: Infinity,
24
+ gcTime: Infinity,
25
+ });
26
+ };
27
+ exports.useErc20Symbol = useErc20Symbol;
28
+ //# sourceMappingURL=useErc20Symbol.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useErc20Symbol.js","sourceRoot":"","sources":["../../../../../src/react/hooks/contracts/erc20/useErc20Symbol.ts"],"names":[],"mappings":";;;;;;AAAA,oDAAsB;AAEtB,2CAA8D;AAC9D,wEAA+D;AAC/D,kDAA8C;AAOvC,MAAM,cAAc,GAAG,CAAC,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAwB,EAAE,EAAE;IACxF,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,GAAG,IAAA,sCAAe,GAAE,CAAA;IAClD,MAAM,OAAO,GAAG,UAAU,EAAE,EAAE,IAAI,QAAQ,CAAA;IAE1C,OAAO,QAAQ,CAAC;QACZ,QAAQ,EAAE,qBAAS,CAAC,KAAK,CAAC,MAAM,CAAC,YAAY,EAAE,OAAO,CAAC;QACvD,OAAO,EAAE,KAAK,IAAI,EAAE;YAChB,IAAI,CAAC,YAAY,IAAI,CAAC,OAAO;gBAAE,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAA;YAEjF,MAAM,QAAQ,GAAG,IAAA,uBAAgB,EAAC,YAAY,EAAE,OAAO,CAAC,CAAA;YAExD,OAAO,MAAM,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAA;QACvC,CAAC;QACD,OAAO,EAAE,CAAC,gBAAC,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,gBAAC,CAAC,KAAK,CAAC,OAAO,CAAC;QACpD,SAAS,EAAE,QAAQ;QACnB,MAAM,EAAE,QAAQ;KACnB,CAAC,CAAA;AACN,CAAC,CAAA;AAjBY,QAAA,cAAc,kBAiB1B"}
@@ -0,0 +1,13 @@
1
+ import { Address } from "viem";
2
+ import { LevrChain } from "../../../../core";
3
+ interface UseTransferErc20Params {
4
+ erc20Address?: Address;
5
+ chainId?: LevrChain;
6
+ toAddress?: Address;
7
+ }
8
+ export declare const useTransferErc20: ({ erc20Address, chainId: _chainId, toAddress }?: UseTransferErc20Params) => import("@tanstack/react-query").UseMutationResult<{
9
+ hash: `0x${string}`;
10
+ }, Error, {
11
+ amount: bigint;
12
+ }, unknown>;
13
+ export {};
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useTransferErc20 = void 0;
4
+ const core_1 = require("../../../../core");
5
+ const injectedDependencies_1 = require("../../../injectedDependencies");
6
+ const queryKeys_1 = require("../../../queryKeys");
7
+ const useTransferErc20 = ({ erc20Address, chainId: _chainId, toAddress } = {}) => {
8
+ const { useMutation, useChainId, useConnectorClient, useAccount } = (0, injectedDependencies_1.getDependencies)();
9
+ const chainId = useChainId?.() ?? _chainId;
10
+ const { data: walletClient } = useConnectorClient?.() ?? {};
11
+ const { address: userAddress } = useAccount?.() ?? {};
12
+ return useMutation({
13
+ mutationFn: async ({ amount }) => {
14
+ if (!erc20Address || !chainId || !toAddress)
15
+ throw new Error("Missing erc20Address, chainId, or toAddress");
16
+ if (!walletClient)
17
+ throw new Error("Wallet client not available");
18
+ const contract = (0, core_1.getErc20Contract)(erc20Address, chainId, { walletClient });
19
+ const hash = await contract.write.transfer([toAddress, amount]);
20
+ return { hash };
21
+ },
22
+ meta: {
23
+ invalidatesQueries: [
24
+ queryKeys_1.queryKeys.erc20.balance(erc20Address, userAddress, chainId),
25
+ queryKeys_1.queryKeys.erc20.balance(erc20Address, toAddress, chainId),
26
+ ],
27
+ },
28
+ });
29
+ };
30
+ exports.useTransferErc20 = useTransferErc20;
31
+ //# sourceMappingURL=useTransferErc20.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useTransferErc20.js","sourceRoot":"","sources":["../../../../../src/react/hooks/contracts/erc20/useTransferErc20.ts"],"names":[],"mappings":";;;AACA,2CAA8D;AAC9D,wEAA+D;AAC/D,kDAA8C;AAQvC,MAAM,gBAAgB,GAAG,CAAC,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,KAA6B,EAAE,EAAE,EAAE;IAC5G,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,kBAAkB,EAAE,UAAU,EAAE,GAAG,IAAA,sCAAe,GAAE,CAAA;IACrF,MAAM,OAAO,GAAG,UAAU,EAAE,EAAE,IAAI,QAAQ,CAAA;IAC1C,MAAM,EAAE,IAAI,EAAE,YAAY,EAAE,GAAG,kBAAkB,EAAE,EAAE,IAAI,EAAE,CAAA;IAC3D,MAAM,EAAE,OAAO,EAAE,WAAW,EAAE,GAAG,UAAU,EAAE,EAAE,IAAI,EAAE,CAAA;IAErD,OAAO,WAAY,CAAC;QAChB,UAAU,EAAE,KAAK,EAAE,EAAE,MAAM,EAAsB,EAAE,EAAE;YACjD,IAAI,CAAC,YAAY,IAAI,CAAC,OAAO,IAAI,CAAC,SAAS;gBAAE,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAA;YAC3G,IAAI,CAAC,YAAY;gBAAE,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAA;YAEjE,MAAM,QAAQ,GAAG,IAAA,uBAAgB,EAAC,YAAY,EAAE,OAAO,EAAE,EAAE,YAAY,EAAE,CAAC,CAAA;YAC1E,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,CAAA;YAE/D,OAAO,EAAE,IAAI,EAAE,CAAA;QACnB,CAAC;QACD,IAAI,EAAE;YACF,kBAAkB,EAAE;gBAChB,qBAAS,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,EAAE,WAAW,EAAE,OAAO,CAAC;gBAC3D,qBAAS,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,EAAE,SAAS,EAAE,OAAO,CAAC;aAC5D;SACJ;KACJ,CAAC,CAAA;AACN,CAAC,CAAA;AAvBY,QAAA,gBAAgB,oBAuB5B"}
@@ -0,0 +1,3 @@
1
+ export * from "./erc20";
2
+ export * from "./useContracts";
3
+ export * from "./useLevrMarketContractAddresses";
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./erc20"), exports);
18
+ __exportStar(require("./useContracts"), exports);
19
+ __exportStar(require("./useLevrMarketContractAddresses"), exports);
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/react/hooks/contracts/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0CAAuB;AACvB,iDAA8B;AAC9B,mEAAgD"}