@clober/v2-sdk 0.0.127 → 1.0.0-beta.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 (775) hide show
  1. package/dist/cjs/calls/approval/open-order.js +49 -0
  2. package/dist/cjs/calls/approval/open-order.js.map +1 -0
  3. package/dist/cjs/calls/approval/token.js +60 -0
  4. package/dist/cjs/calls/approval/token.js.map +1 -0
  5. package/dist/cjs/calls/index.js +39 -0
  6. package/dist/cjs/calls/index.js.map +1 -0
  7. package/dist/cjs/calls/market/cancel.js +80 -0
  8. package/dist/cjs/calls/market/cancel.js.map +1 -0
  9. package/dist/cjs/calls/market/claim.js +79 -0
  10. package/dist/cjs/calls/market/claim.js.map +1 -0
  11. package/dist/cjs/calls/market/limit.js +182 -0
  12. package/dist/cjs/calls/market/limit.js.map +1 -0
  13. package/dist/cjs/calls/market/make.js +160 -0
  14. package/dist/cjs/calls/market/make.js.map +1 -0
  15. package/dist/cjs/calls/market/market.js +170 -0
  16. package/dist/cjs/calls/market/market.js.map +1 -0
  17. package/dist/cjs/calls/market/open.js +50 -0
  18. package/dist/cjs/calls/market/open.js.map +1 -0
  19. package/dist/cjs/calls/pool/burn.js +88 -0
  20. package/dist/cjs/calls/pool/burn.js.map +1 -0
  21. package/dist/cjs/calls/pool/market-making/adjust.js +69 -0
  22. package/dist/cjs/calls/pool/market-making/adjust.js.map +1 -0
  23. package/dist/cjs/calls/pool/market-making/pause.js +44 -0
  24. package/dist/cjs/calls/pool/market-making/pause.js.map +1 -0
  25. package/dist/cjs/calls/pool/market-making/refill.js +41 -0
  26. package/dist/cjs/calls/pool/market-making/refill.js.map +1 -0
  27. package/dist/cjs/calls/pool/market-making/resume.js +44 -0
  28. package/dist/cjs/calls/pool/market-making/resume.js.map +1 -0
  29. package/dist/cjs/calls/pool/mint.js +253 -0
  30. package/dist/cjs/calls/pool/mint.js.map +1 -0
  31. package/dist/cjs/calls/pool/open.js +50 -0
  32. package/dist/cjs/calls/pool/open.js.map +1 -0
  33. package/dist/cjs/calls/pool/wrap.js +97 -0
  34. package/dist/cjs/calls/pool/wrap.js.map +1 -0
  35. package/dist/cjs/{abis → constants/abis}/core/book-manager-abi.js +28 -0
  36. package/dist/cjs/constants/abis/core/book-manager-abi.js.map +1 -0
  37. package/dist/cjs/constants/abis/core/book-viewer-abi.js.map +1 -0
  38. package/dist/cjs/{abis → constants/abis}/core/controller-abi.js +24 -1
  39. package/dist/cjs/constants/abis/core/controller-abi.js.map +1 -0
  40. package/dist/cjs/constants/abis/core/params-abi.js +77 -0
  41. package/dist/cjs/constants/abis/core/params-abi.js.map +1 -0
  42. package/dist/cjs/constants/abis/rebalancer/minter-abi.js.map +1 -0
  43. package/dist/cjs/constants/abis/rebalancer/mock-swap-abi.js.map +1 -0
  44. package/dist/cjs/constants/abis/rebalancer/operator-abi.js.map +1 -0
  45. package/dist/cjs/constants/abis/rebalancer/rebalancer-abi.js.map +1 -0
  46. package/dist/cjs/constants/abis/rebalancer/strategy-abi.js.map +1 -0
  47. package/dist/cjs/constants/abis/rebalancer/wrapped-6909-factory-abi.js +107 -0
  48. package/dist/cjs/constants/abis/rebalancer/wrapped-6909-factory-abi.js.map +1 -0
  49. package/dist/cjs/constants/chain-configs/addresses.js +78 -0
  50. package/dist/cjs/constants/chain-configs/addresses.js.map +1 -0
  51. package/dist/cjs/constants/{chain.js → chain-configs/chain.js} +8 -15
  52. package/dist/cjs/constants/chain-configs/chain.js.map +1 -0
  53. package/dist/cjs/constants/chain-configs/currency.js +221 -0
  54. package/dist/cjs/constants/chain-configs/currency.js.map +1 -0
  55. package/dist/cjs/constants/chain-configs/fee.js +24 -0
  56. package/dist/cjs/constants/chain-configs/fee.js.map +1 -0
  57. package/dist/cjs/constants/{subgraph.js → chain-configs/subgraph.js} +8 -9
  58. package/dist/cjs/constants/chain-configs/subgraph.js.map +1 -0
  59. package/dist/cjs/constants/networks/giwa-sepolia.js +41 -0
  60. package/dist/cjs/constants/networks/giwa-sepolia.js.map +1 -0
  61. package/dist/cjs/constants/networks/rise-sepolia.js.map +1 -0
  62. package/dist/cjs/constants/networks/test-chain.js +27 -0
  63. package/dist/cjs/constants/networks/test-chain.js.map +1 -0
  64. package/dist/cjs/constants/permit.js +2 -2
  65. package/dist/cjs/constants/permit.js.map +1 -1
  66. package/dist/cjs/constants/price.js.map +1 -1
  67. package/dist/cjs/entities/analytics/apis/index.js +179 -0
  68. package/dist/cjs/entities/analytics/apis/index.js.map +1 -0
  69. package/dist/cjs/{model/depth.js → entities/analytics/types.js} +1 -1
  70. package/dist/cjs/entities/analytics/types.js.map +1 -0
  71. package/dist/cjs/entities/book/apis/index.js +87 -0
  72. package/dist/cjs/entities/book/apis/index.js.map +1 -0
  73. package/dist/cjs/{model/book.js → entities/book/model.js} +11 -11
  74. package/dist/cjs/entities/book/model.js.map +1 -0
  75. package/dist/cjs/{model/currency.js → entities/book/types.js} +1 -1
  76. package/dist/cjs/entities/book/types.js.map +1 -0
  77. package/dist/cjs/{utils → entities/book/utils}/book-id.js +1 -1
  78. package/dist/cjs/entities/book/utils/book-id.js.map +1 -0
  79. package/dist/cjs/entities/currency/apis/allowance.js +38 -0
  80. package/dist/cjs/entities/currency/apis/allowance.js.map +1 -0
  81. package/dist/cjs/entities/currency/apis/approval.js +39 -0
  82. package/dist/cjs/entities/currency/apis/approval.js.map +1 -0
  83. package/dist/cjs/entities/currency/apis/index.js +128 -0
  84. package/dist/cjs/entities/currency/apis/index.js.map +1 -0
  85. package/dist/cjs/entities/currency/apis/price.js +36 -0
  86. package/dist/cjs/entities/currency/apis/price.js.map +1 -0
  87. package/dist/cjs/entities/currency/apis/total-supply.js +67 -0
  88. package/dist/cjs/entities/currency/apis/total-supply.js.map +1 -0
  89. package/dist/cjs/{model/chart-log.js → entities/currency/types.js} +1 -1
  90. package/dist/cjs/entities/currency/types.js.map +1 -0
  91. package/dist/cjs/{model/fee-policy.js → entities/fee-policy/model.js} +2 -2
  92. package/dist/cjs/entities/fee-policy/model.js.map +1 -0
  93. package/dist/cjs/{apis/chart-logs.js → entities/market/apis/chart-log.js} +15 -15
  94. package/dist/cjs/entities/market/apis/chart-log.js.map +1 -0
  95. package/dist/cjs/entities/market/apis/index.js +33 -0
  96. package/dist/cjs/entities/market/apis/index.js.map +1 -0
  97. package/dist/cjs/entities/market/apis/snapshot.js +374 -0
  98. package/dist/cjs/entities/market/apis/snapshot.js.map +1 -0
  99. package/dist/cjs/{model/market.js → entities/market/model.js} +14 -16
  100. package/dist/cjs/entities/market/model.js.map +1 -0
  101. package/dist/cjs/{model/open-order.js → entities/market/types.js} +1 -1
  102. package/dist/cjs/entities/market/types.js.map +1 -0
  103. package/dist/cjs/{utils/market.js → entities/market/utils/market-id.js} +18 -8
  104. package/dist/cjs/entities/market/utils/market-id.js.map +1 -0
  105. package/dist/cjs/entities/open-order/apis/index.js +198 -0
  106. package/dist/cjs/entities/open-order/apis/index.js.map +1 -0
  107. package/dist/cjs/entities/open-order/types.js +3 -0
  108. package/dist/cjs/entities/open-order/types.js.map +1 -0
  109. package/dist/cjs/entities/open-order/utils/order-id.js +18 -0
  110. package/dist/cjs/entities/open-order/utils/order-id.js.map +1 -0
  111. package/dist/cjs/entities/pool/apis/index.js +88 -0
  112. package/dist/cjs/entities/pool/apis/index.js.map +1 -0
  113. package/dist/cjs/entities/pool/apis/snapshot.js +93 -0
  114. package/dist/cjs/entities/pool/apis/snapshot.js.map +1 -0
  115. package/dist/cjs/{apis → entities/pool/apis}/strategy.js +4 -22
  116. package/dist/cjs/entities/pool/apis/strategy.js.map +1 -0
  117. package/dist/cjs/{model/pool.js → entities/pool/model.js} +33 -12
  118. package/dist/cjs/entities/pool/model.js.map +1 -0
  119. package/dist/cjs/entities/pool/types.js +3 -0
  120. package/dist/cjs/entities/pool/types.js.map +1 -0
  121. package/dist/cjs/{utils/pool.js → entities/pool/utils/mint.js} +14 -2
  122. package/dist/cjs/entities/pool/utils/mint.js.map +1 -0
  123. package/dist/cjs/{utils → entities/pool/utils}/pool-key.js +3 -6
  124. package/dist/cjs/entities/pool/utils/pool-key.js.map +1 -0
  125. package/dist/cjs/entities/swap/apis/index.js +48 -0
  126. package/dist/cjs/entities/swap/apis/index.js.map +1 -0
  127. package/dist/cjs/entities/swap/types.js +3 -0
  128. package/dist/cjs/entities/swap/types.js.map +1 -0
  129. package/dist/cjs/index.js +11 -4
  130. package/dist/cjs/index.js.map +1 -1
  131. package/dist/cjs/types/default-options.js +3 -0
  132. package/dist/cjs/types/default-options.js.map +1 -0
  133. package/dist/cjs/{type.js → types/index.js} +2 -2
  134. package/dist/cjs/types/index.js.map +1 -0
  135. package/dist/cjs/types/permit.js +3 -0
  136. package/dist/cjs/types/permit.js.map +1 -0
  137. package/dist/cjs/types/transaction.js +3 -0
  138. package/dist/cjs/types/transaction.js.map +1 -0
  139. package/dist/cjs/utils/bigint.js +4 -1
  140. package/dist/cjs/utils/bigint.js.map +1 -1
  141. package/dist/cjs/utils/{decimals.js → conversion.js} +1 -1
  142. package/dist/cjs/utils/conversion.js.map +1 -0
  143. package/dist/cjs/{utils.js → utils/index.js} +8 -8
  144. package/dist/cjs/utils/index.js.map +1 -0
  145. package/dist/cjs/utils/prices.js +1 -2
  146. package/dist/cjs/utils/prices.js.map +1 -1
  147. package/dist/cjs/utils/time.js +7 -2
  148. package/dist/cjs/utils/time.js.map +1 -1
  149. package/dist/cjs/utils/unit-size.js +2 -2
  150. package/dist/cjs/utils/unit-size.js.map +1 -1
  151. package/dist/cjs/views/address.js +9 -0
  152. package/dist/cjs/views/address.js.map +1 -0
  153. package/dist/cjs/views/analytics.js +21 -0
  154. package/dist/cjs/views/analytics.js.map +1 -0
  155. package/dist/cjs/views/currency.js +35 -0
  156. package/dist/cjs/views/currency.js.map +1 -0
  157. package/dist/cjs/views/index.js +46 -0
  158. package/dist/cjs/views/index.js.map +1 -0
  159. package/dist/cjs/views/market/chart-log.js +13 -0
  160. package/dist/cjs/views/market/chart-log.js.map +1 -0
  161. package/dist/cjs/views/market/index.js +32 -0
  162. package/dist/cjs/views/market/index.js.map +1 -0
  163. package/dist/cjs/views/market/parse.js +22 -0
  164. package/dist/cjs/views/market/parse.js.map +1 -0
  165. package/dist/cjs/views/market/quote.js +97 -0
  166. package/dist/cjs/views/market/quote.js.map +1 -0
  167. package/dist/cjs/views/market/snapshot.js +28 -0
  168. package/dist/cjs/views/market/snapshot.js.map +1 -0
  169. package/dist/cjs/views/market/token.js +10 -0
  170. package/dist/cjs/views/market/token.js.map +1 -0
  171. package/dist/cjs/views/open-order.js +13 -0
  172. package/dist/cjs/views/open-order.js.map +1 -0
  173. package/dist/cjs/views/pool/index.js +43 -0
  174. package/dist/cjs/views/pool/index.js.map +1 -0
  175. package/dist/cjs/views/pool/market-making.js +23 -0
  176. package/dist/cjs/views/pool/market-making.js.map +1 -0
  177. package/dist/cjs/views/pool/snapshot.js +17 -0
  178. package/dist/cjs/views/pool/snapshot.js.map +1 -0
  179. package/dist/cjs/views/subgraph.js +24 -0
  180. package/dist/cjs/views/subgraph.js.map +1 -0
  181. package/dist/cjs/views/tick.js +80 -0
  182. package/dist/cjs/views/tick.js.map +1 -0
  183. package/dist/cjs/views/trade.js +15 -0
  184. package/dist/cjs/views/trade.js.map +1 -0
  185. package/dist/esm/calls/approval/open-order.js +69 -0
  186. package/dist/esm/calls/approval/open-order.js.map +1 -0
  187. package/dist/esm/{approval.js → calls/approval/token.js} +5 -70
  188. package/dist/esm/calls/approval/token.js.map +1 -0
  189. package/dist/esm/calls/index.js +17 -0
  190. package/dist/esm/calls/index.js.map +1 -0
  191. package/dist/esm/calls/market/cancel.js +123 -0
  192. package/dist/esm/calls/market/cancel.js.map +1 -0
  193. package/dist/esm/calls/market/claim.js +122 -0
  194. package/dist/esm/calls/market/claim.js.map +1 -0
  195. package/dist/esm/calls/market/limit.js +224 -0
  196. package/dist/esm/calls/market/limit.js.map +1 -0
  197. package/dist/esm/calls/market/make.js +156 -0
  198. package/dist/esm/calls/market/make.js.map +1 -0
  199. package/dist/esm/calls/market/market.js +201 -0
  200. package/dist/esm/calls/market/market.js.map +1 -0
  201. package/dist/esm/calls/market/open.js +65 -0
  202. package/dist/esm/calls/market/open.js.map +1 -0
  203. package/dist/esm/calls/pool/burn.js +85 -0
  204. package/dist/esm/calls/pool/burn.js.map +1 -0
  205. package/dist/esm/calls/pool/market-making/adjust.js +65 -0
  206. package/dist/esm/calls/pool/market-making/adjust.js.map +1 -0
  207. package/dist/esm/calls/pool/market-making/pause.js +40 -0
  208. package/dist/esm/calls/pool/market-making/pause.js.map +1 -0
  209. package/dist/esm/calls/pool/market-making/refill.js +37 -0
  210. package/dist/esm/calls/pool/market-making/refill.js.map +1 -0
  211. package/dist/esm/calls/pool/market-making/resume.js +40 -0
  212. package/dist/esm/calls/pool/market-making/resume.js.map +1 -0
  213. package/dist/esm/calls/pool/mint.js +250 -0
  214. package/dist/esm/calls/pool/mint.js.map +1 -0
  215. package/dist/esm/calls/pool/open.js +67 -0
  216. package/dist/esm/calls/pool/open.js.map +1 -0
  217. package/dist/esm/calls/pool/wrap.js +138 -0
  218. package/dist/esm/calls/pool/wrap.js.map +1 -0
  219. package/dist/esm/{abis → constants/abis}/core/book-manager-abi.js +28 -0
  220. package/dist/esm/constants/abis/core/book-manager-abi.js.map +1 -0
  221. package/dist/esm/constants/abis/core/book-viewer-abi.js.map +1 -0
  222. package/dist/esm/{abis → constants/abis}/core/controller-abi.js +24 -1
  223. package/dist/esm/constants/abis/core/controller-abi.js.map +1 -0
  224. package/dist/esm/constants/abis/core/params-abi.js +74 -0
  225. package/dist/esm/constants/abis/core/params-abi.js.map +1 -0
  226. package/dist/esm/constants/abis/rebalancer/minter-abi.js.map +1 -0
  227. package/dist/esm/constants/abis/rebalancer/mock-swap-abi.js.map +1 -0
  228. package/dist/esm/constants/abis/rebalancer/operator-abi.js.map +1 -0
  229. package/dist/esm/constants/abis/rebalancer/rebalancer-abi.js.map +1 -0
  230. package/dist/esm/constants/abis/rebalancer/strategy-abi.js.map +1 -0
  231. package/dist/esm/constants/abis/rebalancer/wrapped-6909-factory-abi.js +104 -0
  232. package/dist/esm/constants/abis/rebalancer/wrapped-6909-factory-abi.js.map +1 -0
  233. package/dist/esm/constants/chain-configs/addresses.js +93 -0
  234. package/dist/esm/constants/chain-configs/addresses.js.map +1 -0
  235. package/dist/esm/constants/{chain.js → chain-configs/chain.js} +12 -14
  236. package/dist/esm/constants/chain-configs/chain.js.map +1 -0
  237. package/dist/esm/constants/chain-configs/currency.js +236 -0
  238. package/dist/esm/constants/chain-configs/currency.js.map +1 -0
  239. package/dist/esm/constants/{fee.js → chain-configs/fee.js} +9 -7
  240. package/dist/esm/constants/chain-configs/fee.js.map +1 -0
  241. package/dist/esm/constants/{subgraph.js → chain-configs/subgraph.js} +12 -9
  242. package/dist/esm/constants/chain-configs/subgraph.js.map +1 -0
  243. package/dist/esm/constants/networks/giwa-sepolia.js +38 -0
  244. package/dist/esm/constants/networks/giwa-sepolia.js.map +1 -0
  245. package/dist/esm/constants/networks/rise-sepolia.js.map +1 -0
  246. package/dist/esm/constants/networks/test-chain.js +24 -0
  247. package/dist/esm/constants/networks/test-chain.js.map +1 -0
  248. package/dist/esm/constants/permit.js +1 -1
  249. package/dist/esm/constants/permit.js.map +1 -1
  250. package/dist/esm/constants/price.js.map +1 -1
  251. package/dist/esm/entities/analytics/apis/index.js +172 -0
  252. package/dist/esm/entities/analytics/apis/index.js.map +1 -0
  253. package/dist/esm/entities/analytics/types.js +2 -0
  254. package/dist/esm/entities/analytics/types.js.map +1 -0
  255. package/dist/esm/entities/book/apis/index.js +83 -0
  256. package/dist/esm/entities/book/apis/index.js.map +1 -0
  257. package/dist/esm/{model/book.js → entities/book/model.js} +6 -6
  258. package/dist/esm/entities/book/model.js.map +1 -0
  259. package/dist/esm/entities/book/types.js +2 -0
  260. package/dist/esm/entities/book/types.js.map +1 -0
  261. package/dist/esm/{utils → entities/book/utils}/book-id.js +1 -1
  262. package/dist/esm/entities/book/utils/book-id.js.map +1 -0
  263. package/dist/esm/entities/currency/apis/allowance.js +34 -0
  264. package/dist/esm/entities/currency/apis/allowance.js.map +1 -0
  265. package/dist/esm/entities/currency/apis/approval.js +35 -0
  266. package/dist/esm/entities/currency/apis/approval.js.map +1 -0
  267. package/dist/esm/entities/currency/apis/index.js +123 -0
  268. package/dist/esm/entities/currency/apis/index.js.map +1 -0
  269. package/dist/esm/entities/currency/apis/price.js +30 -0
  270. package/dist/esm/entities/currency/apis/price.js.map +1 -0
  271. package/dist/esm/entities/currency/apis/total-supply.js +62 -0
  272. package/dist/esm/entities/currency/apis/total-supply.js.map +1 -0
  273. package/dist/esm/entities/currency/types.js +2 -0
  274. package/dist/esm/entities/currency/types.js.map +1 -0
  275. package/dist/esm/{model/fee-policy.js → entities/fee-policy/model.js} +2 -2
  276. package/dist/esm/entities/fee-policy/model.js.map +1 -0
  277. package/dist/esm/{apis/chart-logs.js → entities/market/apis/chart-log.js} +3 -3
  278. package/dist/esm/entities/market/apis/chart-log.js.map +1 -0
  279. package/dist/esm/entities/market/apis/index.js +29 -0
  280. package/dist/esm/entities/market/apis/index.js.map +1 -0
  281. package/dist/esm/entities/market/apis/snapshot.js +371 -0
  282. package/dist/esm/entities/market/apis/snapshot.js.map +1 -0
  283. package/dist/esm/{model/market.js → entities/market/model.js} +5 -7
  284. package/dist/esm/entities/market/model.js.map +1 -0
  285. package/dist/esm/entities/market/types.js +2 -0
  286. package/dist/esm/entities/market/types.js.map +1 -0
  287. package/dist/esm/{utils/market.js → entities/market/utils/market-id.js} +18 -8
  288. package/dist/esm/entities/market/utils/market-id.js.map +1 -0
  289. package/dist/esm/entities/open-order/apis/index.js +195 -0
  290. package/dist/esm/entities/open-order/apis/index.js.map +1 -0
  291. package/dist/esm/entities/open-order/types.js +2 -0
  292. package/dist/esm/entities/open-order/types.js.map +1 -0
  293. package/dist/esm/entities/open-order/utils/order-id.js +13 -0
  294. package/dist/esm/entities/open-order/utils/order-id.js.map +1 -0
  295. package/dist/esm/entities/pool/apis/index.js +84 -0
  296. package/dist/esm/entities/pool/apis/index.js.map +1 -0
  297. package/dist/esm/entities/pool/apis/snapshot.js +88 -0
  298. package/dist/esm/entities/pool/apis/snapshot.js.map +1 -0
  299. package/dist/esm/entities/pool/apis/strategy.js +30 -0
  300. package/dist/esm/entities/pool/apis/strategy.js.map +1 -0
  301. package/dist/esm/{model/pool.js → entities/pool/model.js} +31 -10
  302. package/dist/esm/entities/pool/model.js.map +1 -0
  303. package/dist/esm/entities/pool/types.js +2 -0
  304. package/dist/esm/entities/pool/types.js.map +1 -0
  305. package/dist/esm/{utils/pool.js → entities/pool/utils/mint.js} +11 -1
  306. package/dist/esm/entities/pool/utils/mint.js.map +1 -0
  307. package/dist/esm/{utils → entities/pool/utils}/pool-key.js +1 -3
  308. package/dist/esm/entities/pool/utils/pool-key.js.map +1 -0
  309. package/dist/esm/entities/swap/apis/index.js +44 -0
  310. package/dist/esm/entities/swap/apis/index.js.map +1 -0
  311. package/dist/esm/entities/swap/types.js +2 -0
  312. package/dist/esm/entities/swap/types.js.map +1 -0
  313. package/dist/esm/index.js +9 -4
  314. package/dist/esm/index.js.map +1 -1
  315. package/dist/esm/types/default-options.js +2 -0
  316. package/dist/esm/types/default-options.js.map +1 -0
  317. package/dist/esm/{type.js → types/index.js} +2 -2
  318. package/dist/esm/types/index.js.map +1 -0
  319. package/dist/esm/types/permit.js +2 -0
  320. package/dist/esm/types/permit.js.map +1 -0
  321. package/dist/esm/types/transaction.js +2 -0
  322. package/dist/esm/types/transaction.js.map +1 -0
  323. package/dist/esm/utils/bigint.js +2 -0
  324. package/dist/esm/utils/bigint.js.map +1 -1
  325. package/dist/esm/utils/{decimals.js → conversion.js} +1 -1
  326. package/dist/esm/utils/conversion.js.map +1 -0
  327. package/dist/esm/utils/index.js +5 -0
  328. package/dist/esm/utils/index.js.map +1 -0
  329. package/dist/esm/utils/prices.js +1 -2
  330. package/dist/esm/utils/prices.js.map +1 -1
  331. package/dist/esm/utils/time.js +4 -1
  332. package/dist/esm/utils/time.js.map +1 -1
  333. package/dist/esm/utils/unit-size.js +2 -2
  334. package/dist/esm/utils/unit-size.js.map +1 -1
  335. package/dist/esm/views/address.js +17 -0
  336. package/dist/esm/views/address.js.map +1 -0
  337. package/dist/esm/views/analytics.js +14 -0
  338. package/dist/esm/views/analytics.js.map +1 -0
  339. package/dist/esm/views/currency.js +50 -0
  340. package/dist/esm/views/currency.js.map +1 -0
  341. package/dist/esm/views/index.js +10 -0
  342. package/dist/esm/views/index.js.map +1 -0
  343. package/dist/esm/views/market/chart-log.js +48 -0
  344. package/dist/esm/views/market/chart-log.js.map +1 -0
  345. package/dist/esm/views/market/index.js +37 -0
  346. package/dist/esm/views/market/index.js.map +1 -0
  347. package/dist/esm/views/market/parse.js +18 -0
  348. package/dist/esm/views/market/parse.js.map +1 -0
  349. package/dist/esm/views/market/quote.js +137 -0
  350. package/dist/esm/views/market/quote.js.map +1 -0
  351. package/dist/esm/views/market/snapshot.js +23 -0
  352. package/dist/esm/views/market/snapshot.js.map +1 -0
  353. package/dist/esm/views/market/token.js +23 -0
  354. package/dist/esm/views/market/token.js.map +1 -0
  355. package/dist/esm/views/open-order.js +38 -0
  356. package/dist/esm/views/open-order.js.map +1 -0
  357. package/dist/esm/views/pool/index.js +54 -0
  358. package/dist/esm/views/pool/index.js.map +1 -0
  359. package/dist/esm/views/pool/market-making.js +18 -0
  360. package/dist/esm/views/pool/market-making.js.map +1 -0
  361. package/dist/esm/views/pool/snapshot.js +12 -0
  362. package/dist/esm/views/pool/snapshot.js.map +1 -0
  363. package/dist/esm/views/subgraph.js +54 -0
  364. package/dist/esm/views/subgraph.js.map +1 -0
  365. package/dist/esm/views/tick.js +89 -0
  366. package/dist/esm/views/tick.js.map +1 -0
  367. package/dist/esm/views/trade.js +11 -0
  368. package/dist/esm/views/trade.js.map +1 -0
  369. package/dist/tsconfig.build.tsbuildinfo +1 -1
  370. package/dist/types/calls/approval/open-order.d.ts +33 -0
  371. package/dist/types/calls/approval/open-order.d.ts.map +1 -0
  372. package/dist/types/{approval.d.ts → calls/approval/token.d.ts} +3 -32
  373. package/dist/types/calls/approval/token.d.ts.map +1 -0
  374. package/dist/types/calls/index.d.ts +17 -0
  375. package/dist/types/calls/index.d.ts.map +1 -0
  376. package/dist/types/calls/market/cancel.d.ts +73 -0
  377. package/dist/types/calls/market/cancel.d.ts.map +1 -0
  378. package/dist/types/calls/market/claim.d.ts +73 -0
  379. package/dist/types/calls/market/claim.d.ts.map +1 -0
  380. package/dist/types/calls/market/limit.d.ts +87 -0
  381. package/dist/types/calls/market/limit.d.ts.map +1 -0
  382. package/dist/types/calls/market/make.d.ts +36 -0
  383. package/dist/types/calls/market/make.d.ts.map +1 -0
  384. package/dist/types/calls/market/market.d.ts +67 -0
  385. package/dist/types/calls/market/market.d.ts.map +1 -0
  386. package/dist/types/calls/market/open.d.ts +31 -0
  387. package/dist/types/calls/market/open.d.ts.map +1 -0
  388. package/dist/types/calls/pool/burn.d.ts +22 -0
  389. package/dist/types/calls/pool/burn.d.ts.map +1 -0
  390. package/dist/types/calls/pool/market-making/adjust.d.ts +22 -0
  391. package/dist/types/calls/pool/market-making/adjust.d.ts.map +1 -0
  392. package/dist/types/calls/pool/market-making/pause.d.ts +14 -0
  393. package/dist/types/calls/pool/market-making/pause.d.ts.map +1 -0
  394. package/dist/types/calls/pool/market-making/refill.d.ts +14 -0
  395. package/dist/types/calls/pool/market-making/refill.d.ts.map +1 -0
  396. package/dist/types/calls/pool/market-making/resume.d.ts +14 -0
  397. package/dist/types/calls/pool/market-making/resume.d.ts.map +1 -0
  398. package/dist/types/calls/pool/mint.d.ts +45 -0
  399. package/dist/types/calls/pool/mint.d.ts.map +1 -0
  400. package/dist/types/calls/pool/open.d.ts +34 -0
  401. package/dist/types/calls/pool/open.d.ts.map +1 -0
  402. package/dist/types/calls/pool/wrap.d.ts +79 -0
  403. package/dist/types/calls/pool/wrap.d.ts.map +1 -0
  404. package/dist/types/{abis → constants/abis}/core/book-manager-abi.d.ts +35 -0
  405. package/dist/types/constants/abis/core/book-manager-abi.d.ts.map +1 -0
  406. package/dist/types/{abis → constants/abis}/core/book-viewer-abi.d.ts.map +1 -1
  407. package/dist/types/{abis → constants/abis}/core/controller-abi.d.ts +19 -1
  408. package/dist/types/{abis → constants/abis}/core/controller-abi.d.ts.map +1 -1
  409. package/dist/types/constants/abis/core/params-abi.d.ts +31 -0
  410. package/dist/types/constants/abis/core/params-abi.d.ts.map +1 -0
  411. package/dist/types/{abis → constants/abis}/rebalancer/minter-abi.d.ts.map +1 -1
  412. package/dist/types/constants/abis/rebalancer/mock-swap-abi.d.ts.map +1 -0
  413. package/dist/types/{abis → constants/abis}/rebalancer/operator-abi.d.ts.map +1 -1
  414. package/dist/types/{abis → constants/abis}/rebalancer/rebalancer-abi.d.ts.map +1 -1
  415. package/dist/types/{abis → constants/abis}/rebalancer/strategy-abi.d.ts.map +1 -1
  416. package/dist/types/constants/abis/rebalancer/wrapped-6909-factory-abi.d.ts +80 -0
  417. package/dist/types/constants/abis/rebalancer/wrapped-6909-factory-abi.d.ts.map +1 -0
  418. package/dist/types/constants/{addresses.d.ts → chain-configs/addresses.d.ts} +1 -0
  419. package/dist/types/constants/chain-configs/addresses.d.ts.map +1 -0
  420. package/dist/types/constants/{chain.d.ts → chain-configs/chain.d.ts} +3 -5
  421. package/dist/types/constants/chain-configs/chain.d.ts.map +1 -0
  422. package/dist/types/constants/chain-configs/currency.d.ts +18 -0
  423. package/dist/types/constants/chain-configs/currency.d.ts.map +1 -0
  424. package/dist/types/constants/{fee.d.ts → chain-configs/fee.d.ts} +1 -1
  425. package/dist/types/constants/chain-configs/fee.d.ts.map +1 -0
  426. package/dist/types/constants/chain-configs/subgraph.d.ts.map +1 -0
  427. package/dist/types/constants/networks/giwa-sepolia.d.ts +60 -0
  428. package/dist/types/constants/networks/giwa-sepolia.d.ts.map +1 -0
  429. package/dist/types/constants/{rise-sepolia.d.ts → networks/rise-sepolia.d.ts} +3 -0
  430. package/dist/types/constants/networks/rise-sepolia.d.ts.map +1 -0
  431. package/dist/types/constants/networks/test-chain.d.ts +3 -0
  432. package/dist/types/constants/networks/test-chain.d.ts.map +1 -0
  433. package/dist/types/constants/permit.d.ts +1 -1
  434. package/dist/types/constants/permit.d.ts.map +1 -1
  435. package/dist/types/constants/price.d.ts.map +1 -1
  436. package/dist/types/entities/analytics/apis/index.d.ts +7 -0
  437. package/dist/types/entities/analytics/apis/index.d.ts.map +1 -0
  438. package/dist/types/entities/analytics/types.d.ts +52 -0
  439. package/dist/types/entities/analytics/types.d.ts.map +1 -0
  440. package/dist/types/entities/book/apis/index.d.ts +6 -0
  441. package/dist/types/entities/book/apis/index.d.ts.map +1 -0
  442. package/dist/types/{model/book.d.ts → entities/book/model.d.ts} +11 -7
  443. package/dist/types/entities/book/model.d.ts.map +1 -0
  444. package/dist/types/entities/book/types.d.ts +14 -0
  445. package/dist/types/entities/book/types.d.ts.map +1 -0
  446. package/dist/types/{utils → entities/book/utils}/book-id.d.ts +1 -1
  447. package/dist/types/entities/book/utils/book-id.d.ts.map +1 -0
  448. package/dist/types/entities/currency/apis/allowance.d.ts.map +1 -0
  449. package/dist/types/{utils → entities/currency/apis}/approval.d.ts +1 -1
  450. package/dist/types/entities/currency/apis/approval.d.ts.map +1 -0
  451. package/dist/types/entities/currency/apis/index.d.ts +6 -0
  452. package/dist/types/entities/currency/apis/index.d.ts.map +1 -0
  453. package/dist/types/entities/currency/apis/price.d.ts +10 -0
  454. package/dist/types/entities/currency/apis/price.d.ts.map +1 -0
  455. package/dist/types/entities/currency/apis/total-supply.d.ts +6 -0
  456. package/dist/types/entities/currency/apis/total-supply.d.ts.map +1 -0
  457. package/dist/types/entities/currency/types.d.ts +32 -0
  458. package/dist/types/entities/currency/types.d.ts.map +1 -0
  459. package/dist/types/{model/fee-policy.d.ts → entities/fee-policy/model.d.ts} +1 -1
  460. package/dist/types/entities/fee-policy/model.d.ts.map +1 -0
  461. package/dist/types/{apis/chart-logs.d.ts → entities/market/apis/chart-log.d.ts} +4 -3
  462. package/dist/types/entities/market/apis/chart-log.d.ts.map +1 -0
  463. package/dist/types/entities/market/apis/index.d.ts +5 -0
  464. package/dist/types/entities/market/apis/index.d.ts.map +1 -0
  465. package/dist/types/entities/market/apis/snapshot.d.ts +6 -0
  466. package/dist/types/entities/market/apis/snapshot.d.ts.map +1 -0
  467. package/dist/types/{model/market.d.ts → entities/market/model.d.ts} +16 -11
  468. package/dist/types/entities/market/model.d.ts.map +1 -0
  469. package/dist/types/entities/market/types.d.ts +38 -0
  470. package/dist/types/entities/market/types.d.ts.map +1 -0
  471. package/dist/types/{utils/market.d.ts → entities/market/utils/market-id.d.ts} +2 -2
  472. package/dist/types/entities/market/utils/market-id.d.ts.map +1 -0
  473. package/dist/types/{apis/open-order.d.ts → entities/open-order/apis/index.d.ts} +6 -3
  474. package/dist/types/entities/open-order/apis/index.d.ts.map +1 -0
  475. package/dist/types/entities/open-order/types.d.ts +21 -0
  476. package/dist/types/entities/open-order/types.d.ts.map +1 -0
  477. package/dist/types/entities/open-order/utils/order-id.d.ts +7 -0
  478. package/dist/types/entities/open-order/utils/order-id.d.ts.map +1 -0
  479. package/dist/types/entities/pool/apis/index.d.ts +6 -0
  480. package/dist/types/entities/pool/apis/index.d.ts.map +1 -0
  481. package/dist/types/entities/pool/apis/snapshot.d.ts +5 -0
  482. package/dist/types/entities/pool/apis/snapshot.d.ts.map +1 -0
  483. package/dist/types/entities/pool/apis/strategy.d.ts +6 -0
  484. package/dist/types/entities/pool/apis/strategy.d.ts.map +1 -0
  485. package/dist/types/{model/pool.d.ts → entities/pool/model.d.ts} +10 -34
  486. package/dist/types/entities/pool/model.d.ts.map +1 -0
  487. package/dist/types/entities/pool/types.d.ts +75 -0
  488. package/dist/types/entities/pool/types.d.ts.map +1 -0
  489. package/dist/types/{utils/pool.d.ts → entities/pool/utils/mint.d.ts} +4 -2
  490. package/dist/types/entities/pool/utils/mint.d.ts.map +1 -0
  491. package/dist/types/entities/pool/utils/pool-key.d.ts +2 -0
  492. package/dist/types/entities/pool/utils/pool-key.d.ts.map +1 -0
  493. package/dist/types/entities/swap/apis/index.d.ts +5 -0
  494. package/dist/types/entities/swap/apis/index.d.ts.map +1 -0
  495. package/dist/types/entities/swap/types.d.ts +12 -0
  496. package/dist/types/entities/swap/types.d.ts.map +1 -0
  497. package/dist/types/index.d.ts +4 -4
  498. package/dist/types/index.d.ts.map +1 -1
  499. package/dist/types/types/default-options.d.ts +10 -0
  500. package/dist/types/types/default-options.d.ts.map +1 -0
  501. package/dist/types/types/index.d.ts +26 -0
  502. package/dist/types/types/index.d.ts.map +1 -0
  503. package/dist/types/types/permit.d.ts +12 -0
  504. package/dist/types/types/permit.d.ts.map +1 -0
  505. package/dist/types/types/transaction.d.ts +10 -0
  506. package/dist/types/types/transaction.d.ts.map +1 -0
  507. package/dist/types/utils/bigint.d.ts +1 -0
  508. package/dist/types/utils/bigint.d.ts.map +1 -1
  509. package/dist/types/utils/build-transaction.d.ts +1 -1
  510. package/dist/types/utils/build-transaction.d.ts.map +1 -1
  511. package/dist/types/utils/{decimals.d.ts → conversion.d.ts} +1 -1
  512. package/dist/types/utils/conversion.d.ts.map +1 -0
  513. package/dist/types/utils/index.d.ts +5 -0
  514. package/dist/types/utils/index.d.ts.map +1 -0
  515. package/dist/types/utils/prices.d.ts +1 -1
  516. package/dist/types/utils/prices.d.ts.map +1 -1
  517. package/dist/types/utils/time.d.ts +2 -0
  518. package/dist/types/utils/time.d.ts.map +1 -1
  519. package/dist/types/utils/unit-size.d.ts +2 -2
  520. package/dist/types/utils/unit-size.d.ts.map +1 -1
  521. package/dist/types/views/address.d.ts +26 -0
  522. package/dist/types/views/address.d.ts.map +1 -0
  523. package/dist/types/views/analytics.d.ts +17 -0
  524. package/dist/types/views/analytics.d.ts.map +1 -0
  525. package/dist/types/views/currency.d.ts +50 -0
  526. package/dist/types/views/currency.d.ts.map +1 -0
  527. package/dist/types/views/index.d.ts +10 -0
  528. package/dist/types/views/index.d.ts.map +1 -0
  529. package/dist/types/views/market/chart-log.d.ts +56 -0
  530. package/dist/types/views/market/chart-log.d.ts.map +1 -0
  531. package/dist/types/views/market/index.d.ts +33 -0
  532. package/dist/types/views/market/index.d.ts.map +1 -0
  533. package/dist/types/views/market/parse.d.ts +10 -0
  534. package/dist/types/views/market/parse.d.ts.map +1 -0
  535. package/dist/types/views/market/quote.d.ts +90 -0
  536. package/dist/types/views/market/quote.d.ts.map +1 -0
  537. package/dist/types/views/market/snapshot.d.ts +17 -0
  538. package/dist/types/views/market/snapshot.d.ts.map +1 -0
  539. package/dist/types/views/market/token.d.ts +24 -0
  540. package/dist/types/views/market/token.d.ts.map +1 -0
  541. package/dist/types/views/open-order.d.ts +41 -0
  542. package/dist/types/views/open-order.d.ts.map +1 -0
  543. package/dist/types/views/pool/index.d.ts +43 -0
  544. package/dist/types/views/pool/index.d.ts.map +1 -0
  545. package/dist/types/views/pool/market-making.d.ts +13 -0
  546. package/dist/types/views/pool/market-making.d.ts.map +1 -0
  547. package/dist/types/views/pool/snapshot.d.ts +10 -0
  548. package/dist/types/views/pool/snapshot.d.ts.map +1 -0
  549. package/dist/types/views/subgraph.d.ts +52 -0
  550. package/dist/types/views/subgraph.d.ts.map +1 -0
  551. package/dist/types/views/tick.d.ts +77 -0
  552. package/dist/types/views/tick.d.ts.map +1 -0
  553. package/dist/types/views/trade.d.ts +10 -0
  554. package/dist/types/views/trade.d.ts.map +1 -0
  555. package/package.json +2 -2
  556. package/dist/cjs/abis/core/book-manager-abi.js.map +0 -1
  557. package/dist/cjs/abis/core/book-viewer-abi.js.map +0 -1
  558. package/dist/cjs/abis/core/controller-abi.js.map +0 -1
  559. package/dist/cjs/abis/rebalancer/minter-abi.js.map +0 -1
  560. package/dist/cjs/abis/rebalancer/mock-swap-abi.js.map +0 -1
  561. package/dist/cjs/abis/rebalancer/operator-abi.js.map +0 -1
  562. package/dist/cjs/abis/rebalancer/rebalancer-abi.js.map +0 -1
  563. package/dist/cjs/abis/rebalancer/strategy-abi.js.map +0 -1
  564. package/dist/cjs/apis/chart-logs.js.map +0 -1
  565. package/dist/cjs/apis/market.js +0 -89
  566. package/dist/cjs/apis/market.js.map +0 -1
  567. package/dist/cjs/apis/odos.js +0 -100
  568. package/dist/cjs/apis/odos.js.map +0 -1
  569. package/dist/cjs/apis/open-order.js +0 -131
  570. package/dist/cjs/apis/open-order.js.map +0 -1
  571. package/dist/cjs/apis/pool.js +0 -95
  572. package/dist/cjs/apis/pool.js.map +0 -1
  573. package/dist/cjs/apis/strategy.js.map +0 -1
  574. package/dist/cjs/approval.js +0 -102
  575. package/dist/cjs/approval.js.map +0 -1
  576. package/dist/cjs/call.js +0 -1057
  577. package/dist/cjs/call.js.map +0 -1
  578. package/dist/cjs/constants/action.js +0 -14
  579. package/dist/cjs/constants/action.js.map +0 -1
  580. package/dist/cjs/constants/addresses.js +0 -80
  581. package/dist/cjs/constants/addresses.js.map +0 -1
  582. package/dist/cjs/constants/chain.js.map +0 -1
  583. package/dist/cjs/constants/currency.js +0 -95
  584. package/dist/cjs/constants/currency.js.map +0 -1
  585. package/dist/cjs/constants/fee.js +0 -26
  586. package/dist/cjs/constants/fee.js.map +0 -1
  587. package/dist/cjs/constants/rise-sepolia.js.map +0 -1
  588. package/dist/cjs/constants/subgraph.js.map +0 -1
  589. package/dist/cjs/constants/test-chain.js +0 -50
  590. package/dist/cjs/constants/test-chain.js.map +0 -1
  591. package/dist/cjs/model/book.js.map +0 -1
  592. package/dist/cjs/model/chart-log.js.map +0 -1
  593. package/dist/cjs/model/currency.js.map +0 -1
  594. package/dist/cjs/model/depth.js.map +0 -1
  595. package/dist/cjs/model/fee-policy.js.map +0 -1
  596. package/dist/cjs/model/market.js.map +0 -1
  597. package/dist/cjs/model/open-order.js.map +0 -1
  598. package/dist/cjs/model/pool.js.map +0 -1
  599. package/dist/cjs/type.js.map +0 -1
  600. package/dist/cjs/utils/allowance.js +0 -39
  601. package/dist/cjs/utils/allowance.js.map +0 -1
  602. package/dist/cjs/utils/approval.js +0 -40
  603. package/dist/cjs/utils/approval.js.map +0 -1
  604. package/dist/cjs/utils/book-id.js.map +0 -1
  605. package/dist/cjs/utils/currency.js +0 -165
  606. package/dist/cjs/utils/currency.js.map +0 -1
  607. package/dist/cjs/utils/decimals.js.map +0 -1
  608. package/dist/cjs/utils/market.js.map +0 -1
  609. package/dist/cjs/utils/open.js +0 -46
  610. package/dist/cjs/utils/open.js.map +0 -1
  611. package/dist/cjs/utils/order.js +0 -97
  612. package/dist/cjs/utils/order.js.map +0 -1
  613. package/dist/cjs/utils/pool-key.js.map +0 -1
  614. package/dist/cjs/utils/pool.js.map +0 -1
  615. package/dist/cjs/utils/quotes.js +0 -16
  616. package/dist/cjs/utils/quotes.js.map +0 -1
  617. package/dist/cjs/utils/time-series.js +0 -31
  618. package/dist/cjs/utils/time-series.js.map +0 -1
  619. package/dist/cjs/utils.js.map +0 -1
  620. package/dist/cjs/view.js +0 -349
  621. package/dist/cjs/view.js.map +0 -1
  622. package/dist/esm/abis/core/book-manager-abi.js.map +0 -1
  623. package/dist/esm/abis/core/book-viewer-abi.js.map +0 -1
  624. package/dist/esm/abis/core/controller-abi.js.map +0 -1
  625. package/dist/esm/abis/rebalancer/minter-abi.js.map +0 -1
  626. package/dist/esm/abis/rebalancer/mock-swap-abi.js.map +0 -1
  627. package/dist/esm/abis/rebalancer/operator-abi.js.map +0 -1
  628. package/dist/esm/abis/rebalancer/rebalancer-abi.js.map +0 -1
  629. package/dist/esm/abis/rebalancer/strategy-abi.js.map +0 -1
  630. package/dist/esm/apis/chart-logs.js.map +0 -1
  631. package/dist/esm/apis/market.js +0 -85
  632. package/dist/esm/apis/market.js.map +0 -1
  633. package/dist/esm/apis/odos.js +0 -94
  634. package/dist/esm/apis/odos.js.map +0 -1
  635. package/dist/esm/apis/open-order.js +0 -129
  636. package/dist/esm/apis/open-order.js.map +0 -1
  637. package/dist/esm/apis/pool.js +0 -90
  638. package/dist/esm/apis/pool.js.map +0 -1
  639. package/dist/esm/apis/strategy.js +0 -48
  640. package/dist/esm/apis/strategy.js.map +0 -1
  641. package/dist/esm/approval.js.map +0 -1
  642. package/dist/esm/call.js +0 -1257
  643. package/dist/esm/call.js.map +0 -1
  644. package/dist/esm/constants/action.js +0 -11
  645. package/dist/esm/constants/action.js.map +0 -1
  646. package/dist/esm/constants/addresses.js +0 -77
  647. package/dist/esm/constants/addresses.js.map +0 -1
  648. package/dist/esm/constants/chain.js.map +0 -1
  649. package/dist/esm/constants/currency.js +0 -94
  650. package/dist/esm/constants/currency.js.map +0 -1
  651. package/dist/esm/constants/fee.js.map +0 -1
  652. package/dist/esm/constants/rise-sepolia.js.map +0 -1
  653. package/dist/esm/constants/subgraph.js.map +0 -1
  654. package/dist/esm/constants/test-chain.js +0 -47
  655. package/dist/esm/constants/test-chain.js.map +0 -1
  656. package/dist/esm/model/book.js.map +0 -1
  657. package/dist/esm/model/chart-log.js +0 -2
  658. package/dist/esm/model/chart-log.js.map +0 -1
  659. package/dist/esm/model/currency.js +0 -2
  660. package/dist/esm/model/currency.js.map +0 -1
  661. package/dist/esm/model/depth.js +0 -2
  662. package/dist/esm/model/depth.js.map +0 -1
  663. package/dist/esm/model/fee-policy.js.map +0 -1
  664. package/dist/esm/model/market.js.map +0 -1
  665. package/dist/esm/model/open-order.js +0 -2
  666. package/dist/esm/model/open-order.js.map +0 -1
  667. package/dist/esm/model/pool.js.map +0 -1
  668. package/dist/esm/type.js.map +0 -1
  669. package/dist/esm/utils/allowance.js +0 -35
  670. package/dist/esm/utils/allowance.js.map +0 -1
  671. package/dist/esm/utils/approval.js +0 -36
  672. package/dist/esm/utils/approval.js.map +0 -1
  673. package/dist/esm/utils/book-id.js.map +0 -1
  674. package/dist/esm/utils/currency.js +0 -160
  675. package/dist/esm/utils/currency.js.map +0 -1
  676. package/dist/esm/utils/decimals.js.map +0 -1
  677. package/dist/esm/utils/market.js.map +0 -1
  678. package/dist/esm/utils/open.js +0 -42
  679. package/dist/esm/utils/open.js.map +0 -1
  680. package/dist/esm/utils/order.js +0 -92
  681. package/dist/esm/utils/order.js.map +0 -1
  682. package/dist/esm/utils/pool-key.js.map +0 -1
  683. package/dist/esm/utils/pool.js.map +0 -1
  684. package/dist/esm/utils/quotes.js +0 -12
  685. package/dist/esm/utils/quotes.js.map +0 -1
  686. package/dist/esm/utils/time-series.js +0 -27
  687. package/dist/esm/utils/time-series.js.map +0 -1
  688. package/dist/esm/utils.js +0 -5
  689. package/dist/esm/utils.js.map +0 -1
  690. package/dist/esm/view.js +0 -549
  691. package/dist/esm/view.js.map +0 -1
  692. package/dist/types/abis/core/book-manager-abi.d.ts.map +0 -1
  693. package/dist/types/abis/rebalancer/mock-swap-abi.d.ts.map +0 -1
  694. package/dist/types/apis/chart-logs.d.ts.map +0 -1
  695. package/dist/types/apis/market.d.ts +0 -5
  696. package/dist/types/apis/market.d.ts.map +0 -1
  697. package/dist/types/apis/odos.d.ts +0 -28
  698. package/dist/types/apis/odos.d.ts.map +0 -1
  699. package/dist/types/apis/open-order.d.ts.map +0 -1
  700. package/dist/types/apis/pool.d.ts +0 -11
  701. package/dist/types/apis/pool.d.ts.map +0 -1
  702. package/dist/types/apis/strategy.d.ts +0 -6
  703. package/dist/types/apis/strategy.d.ts.map +0 -1
  704. package/dist/types/approval.d.ts.map +0 -1
  705. package/dist/types/call.d.ts +0 -465
  706. package/dist/types/call.d.ts.map +0 -1
  707. package/dist/types/constants/action.d.ts +0 -10
  708. package/dist/types/constants/action.d.ts.map +0 -1
  709. package/dist/types/constants/addresses.d.ts.map +0 -1
  710. package/dist/types/constants/chain.d.ts.map +0 -1
  711. package/dist/types/constants/currency.d.ts +0 -16
  712. package/dist/types/constants/currency.d.ts.map +0 -1
  713. package/dist/types/constants/fee.d.ts.map +0 -1
  714. package/dist/types/constants/rise-sepolia.d.ts.map +0 -1
  715. package/dist/types/constants/subgraph.d.ts.map +0 -1
  716. package/dist/types/constants/test-chain.d.ts +0 -4
  717. package/dist/types/constants/test-chain.d.ts.map +0 -1
  718. package/dist/types/model/book.d.ts.map +0 -1
  719. package/dist/types/model/chart-log.d.ts +0 -9
  720. package/dist/types/model/chart-log.d.ts.map +0 -1
  721. package/dist/types/model/currency.d.ts +0 -14
  722. package/dist/types/model/currency.d.ts.map +0 -1
  723. package/dist/types/model/depth.d.ts +0 -10
  724. package/dist/types/model/depth.d.ts.map +0 -1
  725. package/dist/types/model/fee-policy.d.ts.map +0 -1
  726. package/dist/types/model/market.d.ts.map +0 -1
  727. package/dist/types/model/open-order.d.ts +0 -50
  728. package/dist/types/model/open-order.d.ts.map +0 -1
  729. package/dist/types/model/pool.d.ts.map +0 -1
  730. package/dist/types/type.d.ts +0 -159
  731. package/dist/types/type.d.ts.map +0 -1
  732. package/dist/types/utils/allowance.d.ts.map +0 -1
  733. package/dist/types/utils/approval.d.ts.map +0 -1
  734. package/dist/types/utils/book-id.d.ts.map +0 -1
  735. package/dist/types/utils/currency.d.ts +0 -8
  736. package/dist/types/utils/currency.d.ts.map +0 -1
  737. package/dist/types/utils/decimals.d.ts.map +0 -1
  738. package/dist/types/utils/market.d.ts.map +0 -1
  739. package/dist/types/utils/open.d.ts +0 -4
  740. package/dist/types/utils/open.d.ts.map +0 -1
  741. package/dist/types/utils/order.d.ts +0 -10
  742. package/dist/types/utils/order.d.ts.map +0 -1
  743. package/dist/types/utils/pool-key.d.ts +0 -3
  744. package/dist/types/utils/pool-key.d.ts.map +0 -1
  745. package/dist/types/utils/pool.d.ts.map +0 -1
  746. package/dist/types/utils/quotes.d.ts +0 -2
  747. package/dist/types/utils/quotes.d.ts.map +0 -1
  748. package/dist/types/utils/time-series.d.ts +0 -4
  749. package/dist/types/utils/time-series.d.ts.map +0 -1
  750. package/dist/types/utils.d.ts +0 -5
  751. package/dist/types/utils.d.ts.map +0 -1
  752. package/dist/types/view.d.ts +0 -423
  753. package/dist/types/view.d.ts.map +0 -1
  754. /package/dist/cjs/{abis → constants/abis}/core/book-viewer-abi.js +0 -0
  755. /package/dist/cjs/{abis → constants/abis}/rebalancer/minter-abi.js +0 -0
  756. /package/dist/cjs/{abis → constants/abis}/rebalancer/mock-swap-abi.js +0 -0
  757. /package/dist/cjs/{abis → constants/abis}/rebalancer/operator-abi.js +0 -0
  758. /package/dist/cjs/{abis → constants/abis}/rebalancer/rebalancer-abi.js +0 -0
  759. /package/dist/cjs/{abis → constants/abis}/rebalancer/strategy-abi.js +0 -0
  760. /package/dist/cjs/constants/{rise-sepolia.js → networks/rise-sepolia.js} +0 -0
  761. /package/dist/esm/{abis → constants/abis}/core/book-viewer-abi.js +0 -0
  762. /package/dist/esm/{abis → constants/abis}/rebalancer/minter-abi.js +0 -0
  763. /package/dist/esm/{abis → constants/abis}/rebalancer/mock-swap-abi.js +0 -0
  764. /package/dist/esm/{abis → constants/abis}/rebalancer/operator-abi.js +0 -0
  765. /package/dist/esm/{abis → constants/abis}/rebalancer/rebalancer-abi.js +0 -0
  766. /package/dist/esm/{abis → constants/abis}/rebalancer/strategy-abi.js +0 -0
  767. /package/dist/esm/constants/{rise-sepolia.js → networks/rise-sepolia.js} +0 -0
  768. /package/dist/types/{abis → constants/abis}/core/book-viewer-abi.d.ts +0 -0
  769. /package/dist/types/{abis → constants/abis}/rebalancer/minter-abi.d.ts +0 -0
  770. /package/dist/types/{abis → constants/abis}/rebalancer/mock-swap-abi.d.ts +0 -0
  771. /package/dist/types/{abis → constants/abis}/rebalancer/operator-abi.d.ts +0 -0
  772. /package/dist/types/{abis → constants/abis}/rebalancer/rebalancer-abi.d.ts +0 -0
  773. /package/dist/types/{abis → constants/abis}/rebalancer/strategy-abi.d.ts +0 -0
  774. /package/dist/types/constants/{subgraph.d.ts → chain-configs/subgraph.d.ts} +0 -0
  775. /package/dist/types/{utils → entities/currency/apis}/allowance.d.ts +0 -0
@@ -0,0 +1,123 @@
1
+ import { createPublicClient, http, isAddressEqual, zeroAddress, zeroHash, } from 'viem';
2
+ import { CHAIN_MAP } from '../../constants/chain-configs/chain';
3
+ import { fetchIsApprovedForAll } from '../../entities/currency/apis/approval';
4
+ import { fetchOnChainOrders, fetchOpenOrdersByOrderIdsFromSubgraph, } from '../../entities/open-order/apis';
5
+ import { buildTransaction } from '../../utils/build-transaction';
6
+ import { CONTRACT_ADDRESSES } from '../../constants/chain-configs/addresses';
7
+ import { CONTROLLER_ABI } from '../../constants/abis/core/controller-abi';
8
+ import { getDeadlineTimestampInSeconds } from '../../utils/time';
9
+ /**
10
+ * Cancels specified open order if the order is not fully filled.
11
+ * [IMPORTANT] Set ApprovalForAll before calling this function.
12
+ *
13
+ * @param {CHAIN_IDS} chainId The chain ID.
14
+ * @param {`0x${string}`} userAddress The Ethereum address of the user.
15
+ * @param {string} id An ID representing the open order to be canceled
16
+ * @param options {@link DefaultWriteContractOptions} options.
17
+ * @returns {Promise<{ transaction: Transaction, result: CurrencyFlow }>}
18
+ * Promise resolving to the transaction object representing the cancel action with the result of the order.
19
+ * @throws {Error} Throws an error if no open orders are found for the specified user.
20
+ * @example
21
+ * import { getOpenOrders, cancelOrders } from '@clober/v2-sdk'
22
+ *
23
+ * const openOrders = await getOpenOrders({
24
+ * chainId: 421614,
25
+ * userAddress:'0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0'
26
+ * })
27
+ * const transaction = await cancelOrders({
28
+ * chainId: 421614,
29
+ * userAddress: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0',
30
+ * id: openOrders.map((order) => order.id)
31
+ * })
32
+ */
33
+ export const cancelOrder = async ({ chainId, userAddress, id, options, }) => {
34
+ const { transaction, result } = await cancelOrders({
35
+ chainId,
36
+ userAddress,
37
+ ids: [id],
38
+ options: { ...options },
39
+ });
40
+ return {
41
+ transaction,
42
+ result: result[0],
43
+ };
44
+ };
45
+ /**
46
+ * Cancels specified open orders if orders are not fully filled.
47
+ * [IMPORTANT] Set ApprovalForAll before calling this function.
48
+ *
49
+ * @param {CHAIN_IDS} chainId The chain ID.
50
+ * @param {`0x${string}`} userAddress The Ethereum address of the user.
51
+ * @param {string[]} ids An array of IDs representing the open orders to be canceled.
52
+ * @param options {@link DefaultWriteContractOptions} options.
53
+ * @returns {Promise<{ transaction: Transaction, result: CurrencyFlow[] }>
54
+ * Promise resolving to the transaction object representing the cancel action with the result of the orders.
55
+ * @throws {Error} Throws an error if no open orders are found for the specified user.
56
+ * @example
57
+ * import { getOpenOrders, cancelOrders } from '@clober/v2-sdk'
58
+ *
59
+ * const openOrders = await getOpenOrders({
60
+ * chainId: 421614,
61
+ * userAddress: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0'
62
+ * })
63
+ * const transaction = await cancelOrders({
64
+ * chainId: 421614,
65
+ * userAddress: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0',
66
+ * ids: openOrders.map((order) => order.id)
67
+ * })
68
+ */
69
+ export const cancelOrders = async ({ chainId, userAddress, ids, options, }) => {
70
+ const publicClient = createPublicClient({
71
+ chain: CHAIN_MAP[chainId],
72
+ transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
73
+ });
74
+ const isApprovedForAll = await fetchIsApprovedForAll(publicClient, chainId, userAddress);
75
+ if (!isApprovedForAll) {
76
+ throw new Error(`
77
+ Set ApprovalForAll before calling this function.
78
+ import { setApprovalOfOpenOrdersForAll } from '@clober/v2-sdk'
79
+
80
+ const hash = await setApprovalOfOpenOrdersForAll({
81
+ chainId: ${chainId},
82
+ walletClient, // use viem
83
+ })
84
+ `);
85
+ }
86
+ const useSubgraph = !!(options && options.useSubgraph);
87
+ const orders = (useSubgraph
88
+ ? await fetchOpenOrdersByOrderIdsFromSubgraph(chainId, ids)
89
+ : await fetchOnChainOrders(publicClient, chainId, ids.map((id) => BigInt(id)))).filter((order) => isAddressEqual(order.user, userAddress) && order.cancelable.value !== '0');
90
+ const tokensToSettle = orders
91
+ .map((order) => [order.inputCurrency.address, order.outputCurrency.address])
92
+ .flat()
93
+ .filter((address, index, self) => self.findIndex((c) => isAddressEqual(c, address)) === index)
94
+ .filter((address) => !isAddressEqual(address, zeroAddress));
95
+ return {
96
+ transaction: await buildTransaction(publicClient, {
97
+ chain: CHAIN_MAP[chainId],
98
+ account: userAddress,
99
+ address: CONTRACT_ADDRESSES[chainId].Controller,
100
+ abi: CONTROLLER_ABI,
101
+ functionName: 'cancel',
102
+ args: [
103
+ orders.map(({ id }) => ({
104
+ id,
105
+ leftQuoteAmount: 0n,
106
+ hookData: zeroHash,
107
+ })),
108
+ tokensToSettle,
109
+ [],
110
+ getDeadlineTimestampInSeconds(),
111
+ ],
112
+ }, options?.gasLimit),
113
+ result: orders.reduce((acc, { cancelable: { currency, value } }) => {
114
+ const index = acc.findIndex((c) => isAddressEqual(c.currency.address, currency.address));
115
+ if (index === -1) {
116
+ return [...acc, { currency, amount: value, direction: 'out' }];
117
+ }
118
+ acc[index].amount = (Number(acc[index].amount) + Number(value)).toString();
119
+ return acc;
120
+ }, []),
121
+ };
122
+ };
123
+ //# sourceMappingURL=cancel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cancel.js","sourceRoot":"","sources":["../../../../src/calls/market/cancel.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,IAAI,EACJ,cAAc,EACd,WAAW,EACX,QAAQ,GACT,MAAM,MAAM,CAAA;AAEb,OAAO,EAAa,SAAS,EAAE,MAAM,qCAAqC,CAAA;AAO1E,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAA;AAE7E,OAAO,EACL,kBAAkB,EAClB,qCAAqC,GACtC,MAAM,gCAAgC,CAAA;AACvC,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAA;AAChE,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAA;AAC5E,OAAO,EAAE,cAAc,EAAE,MAAM,0CAA0C,CAAA;AACzE,OAAO,EAAE,6BAA6B,EAAE,MAAM,kBAAkB,CAAA;AAEhE;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG,KAAK,EAAE,EAChC,OAAO,EACP,WAAW,EACX,EAAE,EACF,OAAO,GAQR,EAA+D,EAAE;IAChE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,GAAG,MAAM,YAAY,CAAC;QACjD,OAAO;QACP,WAAW;QACX,GAAG,EAAE,CAAC,EAAE,CAAC;QACT,OAAO,EAAE,EAAE,GAAG,OAAO,EAAE;KACxB,CAAC,CAAA;IACF,OAAO;QACL,WAAW;QACX,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;KAClB,CAAA;AACH,CAAC,CAAA;AAED;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG,KAAK,EAAE,EACjC,OAAO,EACP,WAAW,EACX,GAAG,EACH,OAAO,GAQR,EAAiE,EAAE;IAClE,MAAM,YAAY,GAAG,kBAAkB,CAAC;QACtC,KAAK,EAAE,SAAS,CAAC,OAAO,CAAC;QACzB,SAAS,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE;KAC3D,CAAC,CAAA;IACF,MAAM,gBAAgB,GAAG,MAAM,qBAAqB,CAClD,YAAY,EACZ,OAAO,EACP,WAAW,CACZ,CAAA;IACD,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACtB,MAAM,IAAI,KAAK,CAAC;;;;;uBAKG,OAAO;;;KAGzB,CAAC,CAAA;IACJ,CAAC;IAED,MAAM,WAAW,GAAG,CAAC,CAAC,CAAC,OAAO,IAAI,OAAO,CAAC,WAAW,CAAC,CAAA;IACtD,MAAM,MAAM,GAAqC,CAC/C,WAAW;QACT,CAAC,CAAC,MAAM,qCAAqC,CAAC,OAAO,EAAE,GAAG,CAAC;QAC3D,CAAC,CAAC,MAAM,kBAAkB,CACtB,YAAY,EACZ,OAAO,EACP,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAC5B,CACN,CAAC,MAAM,CACN,CAAC,KAAK,EAAE,EAAE,CACR,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,KAAK,CAAC,UAAU,CAAC,KAAK,KAAK,GAAG,CAC5E,CAAA;IACD,MAAM,cAAc,GAAG,MAAM;SAC1B,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;SAC3E,IAAI,EAAE;SACN,MAAM,CACL,CAAC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,CACvB,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,cAAc,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,KAAK,KAAK,CAC9D;SACA,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,cAAc,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC,CAAA;IAE7D,OAAO;QACL,WAAW,EAAE,MAAM,gBAAgB,CACjC,YAAY,EACZ;YACE,KAAK,EAAE,SAAS,CAAC,OAAO,CAAC;YACzB,OAAO,EAAE,WAAW;YACpB,OAAO,EAAE,kBAAkB,CAAC,OAAO,CAAE,CAAC,UAAU;YAChD,GAAG,EAAE,cAAc;YACnB,YAAY,EAAE,QAAQ;YACtB,IAAI,EAAE;gBACJ,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;oBACtB,EAAE;oBACF,eAAe,EAAE,EAAE;oBACnB,QAAQ,EAAE,QAAQ;iBACnB,CAAC,CAAC;gBACH,cAAc;gBACd,EAAE;gBACF,6BAA6B,EAAE;aAChC;SACF,EACD,OAAO,EAAE,QAAQ,CAClB;QACD,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,UAAU,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE;YACjE,MAAM,KAAK,GAAG,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAChC,cAAc,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,EAAE,QAAQ,CAAC,OAAO,CAAC,CACrD,CAAA;YACD,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE,CAAC;gBACjB,OAAO,CAAC,GAAG,GAAG,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAA;YAChE,CAAC;YACD,GAAG,CAAC,KAAK,CAAC,CAAC,MAAM,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAA;YAC1E,OAAO,GAAG,CAAA;QACZ,CAAC,EAAE,EAAoB,CAAC;KACzB,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,122 @@
1
+ import { createPublicClient, http, isAddressEqual, zeroAddress, zeroHash, } from 'viem';
2
+ import { CHAIN_MAP } from '../../constants/chain-configs/chain';
3
+ import { fetchIsApprovedForAll } from '../../entities/currency/apis/approval';
4
+ import { fetchOnChainOrders, fetchOpenOrdersByOrderIdsFromSubgraph, } from '../../entities/open-order/apis';
5
+ import { buildTransaction } from '../../utils/build-transaction';
6
+ import { CONTRACT_ADDRESSES } from '../../constants/chain-configs/addresses';
7
+ import { CONTROLLER_ABI } from '../../constants/abis/core/controller-abi';
8
+ import { getDeadlineTimestampInSeconds } from '../../utils/time';
9
+ /**
10
+ * Claims specified open order for settlement.
11
+ * [IMPORTANT] Set ApprovalForAll before calling this function.
12
+ *
13
+ * @param {CHAIN_IDS} chainId The chain ID.
14
+ * @param {`0x${string}`} userAddress The Ethereum address of the user.
15
+ * @param {string} id An ID representing the open order to be claimed.
16
+ * @param options {@link DefaultWriteContractOptions} options.
17
+ * @returns {Promise<{ transaction: Transaction, result: CurrencyFlow }>}
18
+ * Promise resolving to the transaction object representing the claim action with the result of the order.
19
+ * @throws {Error} Throws an error if no open orders are found for the specified user.
20
+ * @example
21
+ * import { getOpenOrders, claimOrders } from '@clober/v2-sdk'
22
+ *
23
+ * const openOrders = await getOpenOrders({
24
+ * chainId: 421614,
25
+ * userAddress: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0'
26
+ * })
27
+ * const transaction = await claimOrders({
28
+ * chainId: 421614,
29
+ * userAddress: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0',
30
+ * id: openOrders.map((order) => order.id)
31
+ * })
32
+ */
33
+ export const claimOrder = async ({ chainId, userAddress, id, options, }) => {
34
+ const { transaction, result } = await claimOrders({
35
+ chainId,
36
+ userAddress,
37
+ ids: [id],
38
+ options: { ...options },
39
+ });
40
+ return {
41
+ transaction,
42
+ result: result[0],
43
+ };
44
+ };
45
+ /**
46
+ * Claims specified open orders for settlement.
47
+ * [IMPORTANT] Set ApprovalForAll before calling this function.
48
+ *
49
+ * @param {CHAIN_IDS} chainId The chain ID.
50
+ * @param {`0x${string}`} userAddress The Ethereum address of the user.
51
+ * @param {string[]} ids An array of IDs representing the open orders to be claimed.
52
+ * @param options {@link DefaultWriteContractOptions} options.
53
+ * @returns {Promise<{ transaction: Transaction, result: CurrencyFlow[] }>}
54
+ * Promise resolving to the transaction object representing the claim action with the result of the orders.
55
+ * @throws {Error} Throws an error if no open orders are found for the specified user.
56
+ * @example
57
+ * import { getOpenOrders, claimOrders } from '@clober/v2-sdk'
58
+ *
59
+ * const openOrders = await getOpenOrders({
60
+ * chainId: 421614,
61
+ * userAddress: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0'
62
+ * })
63
+ * const transaction = await claimOrders(
64
+ * chainId: 421614,
65
+ * userAddress: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0',
66
+ * ids: openOrders.map((order) => order.id)
67
+ * )
68
+ */
69
+ export const claimOrders = async ({ chainId, userAddress, ids, options, }) => {
70
+ const publicClient = createPublicClient({
71
+ chain: CHAIN_MAP[chainId],
72
+ transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
73
+ });
74
+ const isApprovedForAll = await fetchIsApprovedForAll(publicClient, chainId, userAddress);
75
+ if (!isApprovedForAll) {
76
+ throw new Error(`
77
+ Set ApprovalForAll before calling this function.
78
+ import { setApprovalOfOpenOrdersForAll } from '@clober/v2-sdk'
79
+
80
+ const hash = await setApprovalOfOpenOrdersForAll({
81
+ chainId: ${chainId},
82
+ walletClient, // use viem
83
+ })
84
+ `);
85
+ }
86
+ const useSubgraph = !!(options && options.useSubgraph);
87
+ const orders = (useSubgraph
88
+ ? await fetchOpenOrdersByOrderIdsFromSubgraph(chainId, ids)
89
+ : await fetchOnChainOrders(publicClient, chainId, ids.map((id) => BigInt(id)))).filter((order) => isAddressEqual(order.user, userAddress) && order.claimable.value !== '0');
90
+ const tokensToSettle = orders
91
+ .map((order) => [order.inputCurrency.address, order.outputCurrency.address])
92
+ .flat()
93
+ .filter((address, index, self) => self.findIndex((c) => isAddressEqual(c, address)) === index)
94
+ .filter((address) => !isAddressEqual(address, zeroAddress));
95
+ return {
96
+ transaction: await buildTransaction(publicClient, {
97
+ chain: CHAIN_MAP[chainId],
98
+ account: userAddress,
99
+ address: CONTRACT_ADDRESSES[chainId].Controller,
100
+ abi: CONTROLLER_ABI,
101
+ functionName: 'claim',
102
+ args: [
103
+ orders.map(({ id }) => ({
104
+ id,
105
+ hookData: zeroHash,
106
+ })),
107
+ tokensToSettle,
108
+ [],
109
+ getDeadlineTimestampInSeconds(),
110
+ ],
111
+ }, options?.gasLimit),
112
+ result: orders.reduce((acc, { claimable: { currency, value } }) => {
113
+ const index = acc.findIndex((c) => isAddressEqual(c.currency.address, currency.address));
114
+ if (index === -1) {
115
+ return [...acc, { currency, amount: value, direction: 'out' }];
116
+ }
117
+ acc[index].amount = (Number(acc[index].amount) + Number(value)).toString();
118
+ return acc;
119
+ }, []),
120
+ };
121
+ };
122
+ //# sourceMappingURL=claim.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"claim.js","sourceRoot":"","sources":["../../../../src/calls/market/claim.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,224 @@
1
+ import { createPublicClient, formatUnits, getAddress, http, isAddress, isAddressEqual, parseUnits, zeroAddress, zeroHash, } from 'viem';
2
+ import { CHAIN_MAP } from '../../constants/chain-configs/chain';
3
+ import { fetchMarket } from '../../entities/market/apis';
4
+ import { formatPrice, parsePrice, invertTick, toPrice } from '../../utils';
5
+ import { calculateUnitSize } from '../../utils/unit-size';
6
+ import { getExpectedOutput } from '../../views';
7
+ import { toBookId } from '../../entities/book/utils/book-id';
8
+ import { buildTransaction } from '../../utils/build-transaction';
9
+ import { CONTRACT_ADDRESSES } from '../../constants/chain-configs/addresses';
10
+ import { CONTROLLER_ABI } from '../../constants/abis/core/controller-abi';
11
+ import { getDeadlineTimestampInSeconds } from '../../utils/time';
12
+ /**
13
+ * Places a limit order on the specified chain for trading tokens.
14
+ *
15
+ * @param {CHAIN_IDS} chainId The chain ID.
16
+ * @param {`0x${string}`} userAddress The Ethereum address of the user placing the order.
17
+ * @param {`0x${string}`} inputToken The address of the token to be used as input.
18
+ * @param {`0x${string}`} outputToken The address of the token to be received as output.
19
+ * @param {string} amount The amount of input tokens for the order.
20
+ * @param {string} price The price at which the order should be executed.
21
+ * @param options {@link DefaultWriteContractOptions} options.
22
+ * @param {erc20PermitParam} [options.erc20PermitParam] The permit signature for token approval.
23
+ * @param {boolean} [options.postOnly] A boolean indicating whether the order is only to be made not taken.
24
+ * @param {bigint} [options.makeTick] The tick for the make order.
25
+ * @param {bigint} [options.takeLimitTick] The tick for the take order.
26
+ * @param {boolean} [options.roundingUpMakeBid] A boolean indicating whether to round up the make bid.
27
+ * @param {boolean} [options.roundingDownMakeAsk] A boolean indicating whether to round down the make ask.
28
+ * @param {boolean} [options.roundingDownTakenBid] A boolean indicating whether to round down the taken bid.
29
+ * @param {boolean} [options.roundingUpTakenAsk] A boolean indicating whether to round up the taken ask.
30
+ * @returns {Promise<{ transaction: Transaction, result: { make: CurrencyFlow, take: CurrencyFlow, spent: CurrencyFlow }>}
31
+ * Promise resolving to the transaction object representing the limit order with the result of the order.
32
+ * @example
33
+ * import { limitOrder } from '@clober/v2-sdk'
34
+ * import { privateKeyToAccount } from 'viem/accounts'
35
+ *
36
+ * const { transaction } = await limitOrder({
37
+ * chainId: 421614,
38
+ * userAddress: '0xF8c1869Ecd4df136693C45EcE1b67f85B6bDaE69
39
+ * inputToken: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0',
40
+ * outputToken: '0x0000000000000000000000000000000000000000',
41
+ * amount: '100.123', // 100.123 USDC
42
+ * price: '4000.01', // price at 4000.01 (ETH/USDC)
43
+ * })
44
+ *
45
+ * @example
46
+ * import { limitOrder } from '@clober/v2-sdk'
47
+ *
48
+ * const { transaction } = await limitOrder({
49
+ * chainId: 421614,
50
+ * userAddress: '0xF8c1869Ecd4df136693C45EcE1b67f85B6bDaE69
51
+ * inputToken: '0x0000000000000000000000000000000000000000',
52
+ * outputToken: '0x00bfd44e79fb7f6dd5887a9426c8ef85a0cd23e0',
53
+ * amount: '0.13', // 0.13 ETH
54
+ * price: '4000.01', // price at 4000.01 (ETH/USDC)
55
+ * })
56
+ */
57
+ export const limitOrder = async ({ chainId, userAddress, inputToken, outputToken, amount, price, options, }) => {
58
+ const [roundingUpMakeBid, roundingDownMakeAsk, roundingDownTakenBid, roundingUpTakenAsk,] = [
59
+ options?.roundingUpMakeBid ? options.roundingUpMakeBid : false,
60
+ options?.roundingDownMakeAsk ? options.roundingDownMakeAsk : false,
61
+ options?.roundingDownTakenBid ? options.roundingDownTakenBid : false,
62
+ options?.roundingUpTakenAsk ? options.roundingUpTakenAsk : false,
63
+ ];
64
+ const publicClient = createPublicClient({
65
+ chain: CHAIN_MAP[chainId],
66
+ transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
67
+ });
68
+ const market = await fetchMarket(publicClient, chainId, [inputToken, outputToken], !!(options && options.useSubgraph));
69
+ const isBid = isAddressEqual(market.quote.address, inputToken);
70
+ const [inputCurrency, outputCurrency] = isBid
71
+ ? [market.quote, market.base]
72
+ : [market.base, market.quote];
73
+ if ((isBid && !market.bidBook.isOpened) ||
74
+ (!isBid && !market.askBook.isOpened)) {
75
+ throw new Error(`
76
+ Open the market before placing a limit order.
77
+ import { openMarket } from '@clober/v2-sdk'
78
+
79
+ const transaction = await openMarket({
80
+ chainId: ${chainId},
81
+ inputToken: '${inputToken}',
82
+ outputToken: '${outputToken}',
83
+ })
84
+ `);
85
+ }
86
+ const provider = options && options.provider && isAddress(options.provider)
87
+ ? getAddress(options.provider)
88
+ : zeroAddress;
89
+ const { roundingDownTick, roundingUpTick } = parsePrice(Number(price), market.quote.decimals, market.base.decimals);
90
+ const tokensToSettle = [inputToken, outputToken].filter((address) => !isAddressEqual(address, zeroAddress));
91
+ const quoteAmount = parseUnits(amount, inputCurrency.decimals);
92
+ const unitSize = calculateUnitSize(chainId, inputCurrency);
93
+ const { takenAmount, spentAmount, bookId, events } = await getExpectedOutput({
94
+ chainId,
95
+ inputToken,
96
+ outputToken,
97
+ amountIn: amount,
98
+ options: {
99
+ ...options,
100
+ limitPrice: price,
101
+ },
102
+ });
103
+ const isETH = isAddressEqual(inputToken, zeroAddress);
104
+ const makeParam = {
105
+ id: toBookId(chainId, inputToken, outputToken, unitSize),
106
+ tick: options?.makeTick
107
+ ? Number(options.makeTick)
108
+ : Number(isBid
109
+ ? roundingUpMakeBid
110
+ ? roundingUpTick
111
+ : roundingDownTick
112
+ : invertTick(roundingDownMakeAsk ? roundingDownTick : roundingUpTick)),
113
+ quoteAmount,
114
+ provider,
115
+ hookData: zeroHash,
116
+ };
117
+ if (options?.postOnly === true || spentAmount === '0') {
118
+ return {
119
+ transaction: await buildTransaction(publicClient, {
120
+ chain: CHAIN_MAP[chainId],
121
+ account: userAddress,
122
+ address: CONTRACT_ADDRESSES[chainId].Controller,
123
+ abi: CONTROLLER_ABI,
124
+ functionName: 'make',
125
+ args: [
126
+ [makeParam],
127
+ tokensToSettle,
128
+ options?.erc20PermitParam ? [options.erc20PermitParam] : [],
129
+ getDeadlineTimestampInSeconds(),
130
+ ],
131
+ value: isETH ? quoteAmount : 0n,
132
+ }, options?.gasLimit),
133
+ result: {
134
+ make: {
135
+ amount: formatUnits(quoteAmount, inputCurrency.decimals),
136
+ currency: inputCurrency,
137
+ direction: 'in',
138
+ price: formatPrice(isBid
139
+ ? toPrice(BigInt(makeParam.tick))
140
+ : toPrice(invertTick(BigInt(makeParam.tick))), market.quote.decimals, market.base.decimals),
141
+ },
142
+ spent: {
143
+ amount: '0',
144
+ currency: inputCurrency,
145
+ direction: 'in',
146
+ events: [],
147
+ },
148
+ taken: {
149
+ amount: '0',
150
+ currency: outputCurrency,
151
+ direction: 'out',
152
+ events: [],
153
+ },
154
+ },
155
+ };
156
+ }
157
+ else {
158
+ // take and make
159
+ return {
160
+ transaction: await buildTransaction(publicClient, {
161
+ chain: CHAIN_MAP[chainId],
162
+ account: userAddress,
163
+ address: CONTRACT_ADDRESSES[chainId].Controller,
164
+ abi: CONTROLLER_ABI,
165
+ functionName: 'limit',
166
+ args: [
167
+ [
168
+ {
169
+ takeBookId: bookId,
170
+ makeBookId: makeParam.id,
171
+ limitPrice: options?.takeLimitTick
172
+ ? toPrice(options.takeLimitTick)
173
+ : toPrice(isBid
174
+ ? invertTick(roundingUpTakenAsk
175
+ ? roundingUpTick
176
+ : roundingDownTick)
177
+ : roundingDownTakenBid
178
+ ? roundingDownTick
179
+ : roundingUpTick),
180
+ tick: makeParam.tick,
181
+ quoteAmount,
182
+ provider,
183
+ takeHookData: zeroHash,
184
+ makeHookData: makeParam.hookData,
185
+ },
186
+ ],
187
+ tokensToSettle,
188
+ options?.erc20PermitParam ? [options.erc20PermitParam] : [],
189
+ getDeadlineTimestampInSeconds(),
190
+ ],
191
+ value: isETH ? quoteAmount : 0n,
192
+ }, options?.gasLimit),
193
+ result: {
194
+ make: {
195
+ amount: formatUnits(quoteAmount - parseUnits(spentAmount, inputCurrency.decimals), inputCurrency.decimals),
196
+ currency: inputCurrency,
197
+ direction: 'in',
198
+ price: formatPrice(isBid
199
+ ? toPrice(BigInt(makeParam.tick))
200
+ : toPrice(invertTick(BigInt(makeParam.tick))), market.quote.decimals, market.base.decimals),
201
+ },
202
+ spent: {
203
+ amount: spentAmount,
204
+ currency: inputCurrency,
205
+ direction: 'in',
206
+ events: events.map(({ price, spentAmount }) => ({
207
+ price,
208
+ amount: spentAmount,
209
+ })),
210
+ },
211
+ taken: {
212
+ amount: takenAmount,
213
+ currency: outputCurrency,
214
+ direction: 'out',
215
+ events: events.map(({ price, takenAmount }) => ({
216
+ price,
217
+ amount: takenAmount,
218
+ })),
219
+ },
220
+ },
221
+ };
222
+ }
223
+ };
224
+ //# sourceMappingURL=limit.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"limit.js","sourceRoot":"","sources":["../../../../src/calls/market/limit.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,WAAW,EACX,UAAU,EACV,IAAI,EACJ,SAAS,EACT,cAAc,EACd,UAAU,EACV,WAAW,EACX,QAAQ,GACT,MAAM,MAAM,CAAA;AAEb,OAAO,EAAa,SAAS,EAAE,MAAM,qCAAqC,CAAA;AAO1E,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAA;AACxD,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAA;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAA;AAC/C,OAAO,EAAE,QAAQ,EAAE,MAAM,mCAAmC,CAAA;AAC5D,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAA;AAChE,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAA;AAC5E,OAAO,EAAE,cAAc,EAAE,MAAM,0CAA0C,CAAA;AACzE,OAAO,EAAE,6BAA6B,EAAE,MAAM,kBAAkB,CAAA;AAEhE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4CG;AACH,MAAM,CAAC,MAAM,UAAU,GAAG,KAAK,EAAE,EAC/B,OAAO,EACP,WAAW,EACX,UAAU,EACV,WAAW,EACX,MAAM,EACN,KAAK,EACL,OAAO,GAoBR,EAOE,EAAE;IACH,MAAM,CACJ,iBAAiB,EACjB,mBAAmB,EACnB,oBAAoB,EACpB,kBAAkB,EACnB,GAAG;QACF,OAAO,EAAE,iBAAiB,CAAC,CAAC,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC,CAAC,KAAK;QAC9D,OAAO,EAAE,mBAAmB,CAAC,CAAC,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC,CAAC,KAAK;QAClE,OAAO,EAAE,oBAAoB,CAAC,CAAC,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC,CAAC,KAAK;QACpE,OAAO,EAAE,kBAAkB,CAAC,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,CAAC,KAAK;KACjE,CAAA;IACD,MAAM,YAAY,GAAG,kBAAkB,CAAC;QACtC,KAAK,EAAE,SAAS,CAAC,OAAO,CAAC;QACzB,SAAS,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE;KAC3D,CAAC,CAAA;IACF,MAAM,MAAM,GAAG,MAAM,WAAW,CAC9B,YAAY,EACZ,OAAO,EACP,CAAC,UAAU,EAAE,WAAW,CAAC,EACzB,CAAC,CAAC,CAAC,OAAO,IAAI,OAAO,CAAC,WAAW,CAAC,CACnC,CAAA;IACD,MAAM,KAAK,GAAG,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,UAAU,CAAC,CAAA;IAC9D,MAAM,CAAC,aAAa,EAAE,cAAc,CAAC,GAAG,KAAK;QAC3C,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC;QAC7B,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;IAC/B,IACE,CAAC,KAAK,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC;QACnC,CAAC,CAAC,KAAK,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,EACpC,CAAC;QACD,MAAM,IAAI,KAAK,CAAC;;;;;uBAKG,OAAO;2BACH,UAAU;4BACT,WAAW;;KAElC,CAAC,CAAA;IACJ,CAAC;IAED,MAAM,QAAQ,GACZ,OAAO,IAAI,OAAO,CAAC,QAAQ,IAAI,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC;QACxD,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,QAAQ,CAAC;QAC9B,CAAC,CAAC,WAAW,CAAA;IACjB,MAAM,EAAE,gBAAgB,EAAE,cAAc,EAAE,GAAG,UAAU,CACrD,MAAM,CAAC,KAAK,CAAC,EACb,MAAM,CAAC,KAAK,CAAC,QAAQ,EACrB,MAAM,CAAC,IAAI,CAAC,QAAQ,CACrB,CAAA;IACD,MAAM,cAAc,GAAG,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC,MAAM,CACrD,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,cAAc,CAAC,OAAO,EAAE,WAAW,CAAC,CACnD,CAAA;IACD,MAAM,WAAW,GAAG,UAAU,CAAC,MAAM,EAAE,aAAa,CAAC,QAAQ,CAAC,CAAA;IAC9D,MAAM,QAAQ,GAAG,iBAAiB,CAAC,OAAO,EAAE,aAAa,CAAC,CAAA;IAC1D,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,iBAAiB,CAAC;QAC3E,OAAO;QACP,UAAU;QACV,WAAW;QACX,QAAQ,EAAE,MAAM;QAChB,OAAO,EAAE;YACP,GAAG,OAAO;YACV,UAAU,EAAE,KAAK;SAClB;KACF,CAAC,CAAA;IACF,MAAM,KAAK,GAAG,cAAc,CAAC,UAAU,EAAE,WAAW,CAAC,CAAA;IACrD,MAAM,SAAS,GAAG;QAChB,EAAE,EAAE,QAAQ,CAAC,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,QAAQ,CAAC;QACxD,IAAI,EAAE,OAAO,EAAE,QAAQ;YACrB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC;YAC1B,CAAC,CAAC,MAAM,CACJ,KAAK;gBACH,CAAC,CAAC,iBAAiB;oBACjB,CAAC,CAAC,cAAc;oBAChB,CAAC,CAAC,gBAAgB;gBACpB,CAAC,CAAC,UAAU,CACR,mBAAmB,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,cAAc,CACxD,CACN;QACL,WAAW;QACX,QAAQ;QACR,QAAQ,EAAE,QAAQ;KACnB,CAAA;IACD,IAAI,OAAO,EAAE,QAAQ,KAAK,IAAI,IAAI,WAAW,KAAK,GAAG,EAAE,CAAC;QACtD,OAAO;YACL,WAAW,EAAE,MAAM,gBAAgB,CACjC,YAAY,EACZ;gBACE,KAAK,EAAE,SAAS,CAAC,OAAO,CAAC;gBACzB,OAAO,EAAE,WAAW;gBACpB,OAAO,EAAE,kBAAkB,CAAC,OAAO,CAAE,CAAC,UAAU;gBAChD,GAAG,EAAE,cAAc;gBACnB,YAAY,EAAE,MAAM;gBACpB,IAAI,EAAE;oBACJ,CAAC,SAAS,CAAC;oBACX,cAAc;oBACd,OAAO,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,EAAE;oBAC3D,6BAA6B,EAAE;iBAChC;gBACD,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE;aAChC,EACD,OAAO,EAAE,QAAQ,CAClB;YACD,MAAM,EAAE;gBACN,IAAI,EAAE;oBACJ,MAAM,EAAE,WAAW,CAAC,WAAW,EAAE,aAAa,CAAC,QAAQ,CAAC;oBACxD,QAAQ,EAAE,aAAa;oBACvB,SAAS,EAAE,IAAI;oBACf,KAAK,EAAE,WAAW,CAChB,KAAK;wBACH,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;wBACjC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAC/C,MAAM,CAAC,KAAK,CAAC,QAAQ,EACrB,MAAM,CAAC,IAAI,CAAC,QAAQ,CACrB;iBACF;gBACD,KAAK,EAAE;oBACL,MAAM,EAAE,GAAG;oBACX,QAAQ,EAAE,aAAa;oBACvB,SAAS,EAAE,IAAI;oBACf,MAAM,EAAE,EAAE;iBACX;gBACD,KAAK,EAAE;oBACL,MAAM,EAAE,GAAG;oBACX,QAAQ,EAAE,cAAc;oBACxB,SAAS,EAAE,KAAK;oBAChB,MAAM,EAAE,EAAE;iBACX;aACF;SACF,CAAA;IACH,CAAC;SAAM,CAAC;QACN,gBAAgB;QAChB,OAAO;YACL,WAAW,EAAE,MAAM,gBAAgB,CACjC,YAAY,EACZ;gBACE,KAAK,EAAE,SAAS,CAAC,OAAO,CAAC;gBACzB,OAAO,EAAE,WAAW;gBACpB,OAAO,EAAE,kBAAkB,CAAC,OAAO,CAAE,CAAC,UAAU;gBAChD,GAAG,EAAE,cAAc;gBACnB,YAAY,EAAE,OAAO;gBACrB,IAAI,EAAE;oBACJ;wBACE;4BACE,UAAU,EAAE,MAAM;4BAClB,UAAU,EAAE,SAAS,CAAC,EAAE;4BACxB,UAAU,EAAE,OAAO,EAAE,aAAa;gCAChC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,aAAa,CAAC;gCAChC,CAAC,CAAC,OAAO,CACL,KAAK;oCACH,CAAC,CAAC,UAAU,CACR,kBAAkB;wCAChB,CAAC,CAAC,cAAc;wCAChB,CAAC,CAAC,gBAAgB,CACrB;oCACH,CAAC,CAAC,oBAAoB;wCACpB,CAAC,CAAC,gBAAgB;wCAClB,CAAC,CAAC,cAAc,CACrB;4BACL,IAAI,EAAE,SAAS,CAAC,IAAI;4BACpB,WAAW;4BACX,QAAQ;4BACR,YAAY,EAAE,QAAQ;4BACtB,YAAY,EAAE,SAAS,CAAC,QAAQ;yBACjC;qBACF;oBACD,cAAc;oBACd,OAAO,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,EAAE;oBAC3D,6BAA6B,EAAE;iBAChC;gBACD,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE;aAChC,EACD,OAAO,EAAE,QAAQ,CAClB;YACD,MAAM,EAAE;gBACN,IAAI,EAAE;oBACJ,MAAM,EAAE,WAAW,CACjB,WAAW,GAAG,UAAU,CAAC,WAAW,EAAE,aAAa,CAAC,QAAQ,CAAC,EAC7D,aAAa,CAAC,QAAQ,CACvB;oBACD,QAAQ,EAAE,aAAa;oBACvB,SAAS,EAAE,IAAI;oBACf,KAAK,EAAE,WAAW,CAChB,KAAK;wBACH,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;wBACjC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAC/C,MAAM,CAAC,KAAK,CAAC,QAAQ,EACrB,MAAM,CAAC,IAAI,CAAC,QAAQ,CACrB;iBACF;gBACD,KAAK,EAAE;oBACL,MAAM,EAAE,WAAW;oBACnB,QAAQ,EAAE,aAAa;oBACvB,SAAS,EAAE,IAAI;oBACf,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC,CAAC;wBAC9C,KAAK;wBACL,MAAM,EAAE,WAAW;qBACpB,CAAC,CAAC;iBACJ;gBACD,KAAK,EAAE;oBACL,MAAM,EAAE,WAAW;oBACnB,QAAQ,EAAE,cAAc;oBACxB,SAAS,EAAE,KAAK;oBAChB,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC,CAAC;wBAC9C,KAAK;wBACL,MAAM,EAAE,WAAW;qBACpB,CAAC,CAAC;iBACJ;aACF;SACF,CAAA;IACH,CAAC;AACH,CAAC,CAAA"}
@@ -0,0 +1,156 @@
1
+ import { createPublicClient, encodeAbiParameters, getAddress, http, isAddress, isAddressEqual, parseUnits, zeroAddress, zeroHash, } from 'viem';
2
+ import { CHAIN_MAP } from '../../constants/chain-configs/chain';
3
+ import { fetchMarket } from '../../entities/market/apis';
4
+ import { getContractAddresses, getOpenOrders, getPriceNeighborhood, getQuoteToken, } from '../../views';
5
+ import { CONTROLLER_ABI } from '../../constants/abis/core/controller-abi';
6
+ import { CANCEL_ORDER_PARAMS_ABI, CLAIM_ORDER_PARAMS_ABI, MAKE_ORDER_PARAMS_ABI, } from '../../constants/abis/core/params-abi';
7
+ import { buildTransaction } from '../../utils/build-transaction';
8
+ import { getDeadlineTimestampInSeconds } from '../../utils/time';
9
+ export var Action;
10
+ (function (Action) {
11
+ Action[Action["OPEN"] = 0] = "OPEN";
12
+ Action[Action["MAKE"] = 1] = "MAKE";
13
+ Action[Action["LIMIT"] = 2] = "LIMIT";
14
+ Action[Action["TAKE"] = 3] = "TAKE";
15
+ Action[Action["SPEND"] = 4] = "SPEND";
16
+ Action[Action["CLAIM"] = 5] = "CLAIM";
17
+ Action[Action["CANCEL"] = 6] = "CANCEL";
18
+ })(Action || (Action = {}));
19
+ export const placeMarketMakingQuotes = async ({ chainId, userAddress, bidQuotes, askQuotes, baseToken, quoteToken, clearOpenOrders, options, }) => {
20
+ let orderIdsToClaim = options?.orderIdsToClaim || [];
21
+ let orderIdsToCancel = options?.orderIdsToCancel || [];
22
+ if (clearOpenOrders) {
23
+ const openOrders = await getOpenOrders({
24
+ chainId,
25
+ userAddress,
26
+ });
27
+ orderIdsToClaim = openOrders
28
+ .filter(({ claimable }) => Number(claimable.value) > 0)
29
+ .map((order) => order.id);
30
+ orderIdsToCancel = openOrders
31
+ .filter(({ cancelable }) => Number(cancelable.value) > 0)
32
+ .map((order) => order.id);
33
+ }
34
+ const [roundingUpMakeBid, roundingDownMakeAsk] = [
35
+ options?.roundingUpMakeBid ? options.roundingUpMakeBid : false,
36
+ options?.roundingDownMakeAsk ? options.roundingDownMakeAsk : false,
37
+ ];
38
+ const publicClient = createPublicClient({
39
+ chain: CHAIN_MAP[chainId],
40
+ transport: options?.rpcUrl ? http(options.rpcUrl) : http(),
41
+ });
42
+ const market = options?.market
43
+ ? options.market
44
+ : (await fetchMarket(publicClient, chainId, [baseToken, quoteToken], !!(options && options.useSubgraph))).toJson();
45
+ if (!isAddressEqual(quoteToken, getQuoteToken({ chainId, token0: baseToken, token1: quoteToken }))) {
46
+ throw new Error(`Invalid market: The quote token ${quoteToken} does not match the base token ${baseToken}. Please check the market configuration.`);
47
+ }
48
+ if (!market.bidBook.isOpened && bidQuotes.length > 0) {
49
+ throw new Error(`
50
+ Open the market before placing a limit order.
51
+ import { openMarket } from '@clober/v2-sdk'
52
+
53
+ const transaction = await openMarket({
54
+ chainId: ${chainId},
55
+ inputToken: '${market.quote.address}',
56
+ outputToken: '${market.base.address}',
57
+ })
58
+ `);
59
+ }
60
+ if (!market.askBook.isOpened && askQuotes.length > 0) {
61
+ throw new Error(`
62
+ Open the market before placing a limit order.
63
+ import { openMarket } from '@clober/v2-sdk'
64
+
65
+ const transaction = await openMarket({
66
+ chainId: ${chainId},
67
+ inputToken: '${market.base.address}',
68
+ outputToken: '${market.quote.address}',
69
+ })
70
+ `);
71
+ }
72
+ const provider = options && options.provider && isAddress(options.provider)
73
+ ? getAddress(options.provider)
74
+ : zeroAddress;
75
+ const bidMakeParams = bidQuotes.map((quote) => {
76
+ const { normal: { now: { tick: bidTick }, }, } = getPriceNeighborhood({
77
+ chainId,
78
+ price: quote.price,
79
+ currency0: market.quote,
80
+ currency1: market.base,
81
+ });
82
+ return {
83
+ id: BigInt(market.bidBook.id),
84
+ tick: roundingUpMakeBid ? Number(bidTick + 1n) : Number(bidTick),
85
+ quoteAmount: parseUnits(quote.amount, market.quote.decimals),
86
+ provider,
87
+ hookData: zeroHash,
88
+ isNative: isAddressEqual(market.quote.address, zeroAddress),
89
+ };
90
+ });
91
+ const askMakeParams = askQuotes.map((quote) => {
92
+ const { inverted: { now: { tick: askTick }, }, } = getPriceNeighborhood({
93
+ chainId,
94
+ price: quote.price,
95
+ currency0: market.quote,
96
+ currency1: market.base,
97
+ });
98
+ return {
99
+ id: BigInt(market.askBook.id),
100
+ tick: roundingDownMakeAsk ? Number(askTick - 1n) : Number(askTick),
101
+ quoteAmount: parseUnits(quote.amount, market.base.decimals),
102
+ provider,
103
+ hookData: zeroHash,
104
+ isNative: isAddressEqual(market.base.address, zeroAddress),
105
+ };
106
+ });
107
+ const args = {
108
+ address: getContractAddresses({ chainId }).Controller,
109
+ abi: CONTROLLER_ABI,
110
+ account: userAddress,
111
+ functionName: 'execute',
112
+ args: [
113
+ [
114
+ ...orderIdsToClaim.map(() => Action.CLAIM),
115
+ ...orderIdsToCancel.map(() => Action.CANCEL),
116
+ ...[...bidMakeParams].map(() => Action.MAKE),
117
+ ...[...askMakeParams].map(() => Action.MAKE),
118
+ ],
119
+ [
120
+ ...orderIdsToClaim.map((id) => encodeAbiParameters(CLAIM_ORDER_PARAMS_ABI, [
121
+ { id, hookData: zeroHash },
122
+ ])),
123
+ ...orderIdsToCancel.map((id) => encodeAbiParameters(CANCEL_ORDER_PARAMS_ABI, [
124
+ { id, leftQuoteAmount: 0n, hookData: zeroHash },
125
+ ])),
126
+ ...[...bidMakeParams].map((param) => encodeAbiParameters(MAKE_ORDER_PARAMS_ABI, [
127
+ {
128
+ id: param.id,
129
+ tick: param.tick,
130
+ quoteAmount: param.quoteAmount,
131
+ provider: param.provider,
132
+ hookData: param.hookData,
133
+ },
134
+ ])),
135
+ ...[...askMakeParams].map((param) => encodeAbiParameters(MAKE_ORDER_PARAMS_ABI, [
136
+ {
137
+ id: param.id,
138
+ tick: param.tick,
139
+ quoteAmount: param.quoteAmount,
140
+ provider: param.provider,
141
+ hookData: param.hookData,
142
+ },
143
+ ])),
144
+ ],
145
+ [market.base.address, market.quote.address].filter((address) => !isAddressEqual(address, zeroAddress)),
146
+ [],
147
+ [],
148
+ getDeadlineTimestampInSeconds(),
149
+ ],
150
+ value: [...bidMakeParams, ...askMakeParams]
151
+ .filter((p) => p.isNative)
152
+ .reduce((acc, p) => acc + BigInt(p.quoteAmount), 0n),
153
+ };
154
+ return buildTransaction(publicClient, args, options?.gasLimit);
155
+ };
156
+ //# sourceMappingURL=make.js.map