@coinbase/cdp-hooks 0.0.72 → 0.0.74

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 (303) hide show
  1. package/README.md +231 -2
  2. package/dist/esm/index.js +55 -48
  3. package/dist/esm/index10.js +1 -1
  4. package/dist/esm/index100.js +9 -3
  5. package/dist/esm/index101.js +2 -327
  6. package/dist/esm/index102.js +2 -14
  7. package/dist/esm/index103.js +3 -5
  8. package/dist/esm/index104.js +299 -28
  9. package/dist/esm/index105.js +14 -2
  10. package/dist/esm/index106.js +4 -7
  11. package/dist/esm/index107.js +29 -188
  12. package/dist/esm/index108.js +2 -32
  13. package/dist/esm/index109.js +7 -21
  14. package/dist/esm/index11.js +1 -1
  15. package/dist/esm/index110.js +214 -5
  16. package/dist/esm/index111.js +30 -72
  17. package/dist/esm/index112.js +21 -5
  18. package/dist/esm/index113.js +5 -5
  19. package/dist/esm/index114.js +69 -31
  20. package/dist/esm/index115.js +5 -75
  21. package/dist/esm/index116.js +6 -3
  22. package/dist/esm/index117.js +28 -16
  23. package/dist/esm/index118.js +57 -433
  24. package/dist/esm/index119.js +3 -31
  25. package/dist/esm/index12.js +1 -1
  26. package/dist/esm/index120.js +17 -20
  27. package/dist/esm/index121.js +439 -21
  28. package/dist/esm/index122.js +28 -32
  29. package/dist/esm/index123.js +18 -185
  30. package/dist/esm/index124.js +31 -6
  31. package/dist/esm/index125.js +35 -2
  32. package/dist/esm/index126.js +189 -8
  33. package/dist/esm/index127.js +7 -17
  34. package/dist/esm/index128.js +2 -28
  35. package/dist/esm/index129.js +12 -8
  36. package/dist/esm/index13.js +1 -1
  37. package/dist/esm/index130.js +15 -52
  38. package/dist/esm/index131.js +23 -41
  39. package/dist/esm/index132.js +8 -8
  40. package/dist/esm/index133.js +55 -7
  41. package/dist/esm/index134.js +44 -15
  42. package/dist/esm/index135.js +8 -18
  43. package/dist/esm/index136.js +7 -24
  44. package/dist/esm/index137.js +16 -16
  45. package/dist/esm/index138.js +17 -53
  46. package/dist/esm/index139.js +22 -9
  47. package/dist/esm/index14.js +1 -1
  48. package/dist/esm/index140.js +15 -159
  49. package/dist/esm/index141.js +53 -20
  50. package/dist/esm/index142.js +11 -127
  51. package/dist/esm/index143.js +153 -31
  52. package/dist/esm/index144.js +21 -6
  53. package/dist/esm/index145.js +127 -27
  54. package/dist/esm/index146.js +31 -184
  55. package/dist/esm/index147.js +7 -4
  56. package/dist/esm/index148.js +26 -63
  57. package/dist/esm/index149.js +192 -3
  58. package/dist/esm/index15.js +1 -1
  59. package/dist/esm/index150.js +4 -21
  60. package/dist/esm/index151.js +61 -13
  61. package/dist/esm/index152.js +3 -24
  62. package/dist/esm/index153.js +20 -11
  63. package/dist/esm/index154.js +15 -33
  64. package/dist/esm/index155.js +24 -3
  65. package/dist/esm/index156.js +11 -18
  66. package/dist/esm/index157.js +33 -26
  67. package/dist/esm/index158.js +3 -36
  68. package/dist/esm/index159.js +18 -7
  69. package/dist/esm/index16.js +1 -1
  70. package/dist/esm/index160.js +26 -24
  71. package/dist/esm/index161.js +34 -27
  72. package/dist/esm/index162.js +7 -64
  73. package/dist/esm/index163.js +25 -9
  74. package/dist/esm/index164.js +28 -33
  75. package/dist/esm/index165.js +64 -27
  76. package/dist/esm/index166.js +9 -24
  77. package/dist/esm/index167.js +33 -3
  78. package/dist/esm/index168.js +27 -14
  79. package/dist/esm/index169.js +24 -103
  80. package/dist/esm/index170.js +3 -64
  81. package/dist/esm/index171.js +14 -5
  82. package/dist/esm/index172.js +103 -6
  83. package/dist/esm/index173.js +62 -25
  84. package/dist/esm/index174.js +5 -38
  85. package/dist/esm/index175.js +6 -13
  86. package/dist/esm/index176.js +24 -39
  87. package/dist/esm/index177.js +38 -5
  88. package/dist/esm/index178.js +13 -11
  89. package/dist/esm/index179.js +42 -19
  90. package/dist/esm/index18.js +5 -5
  91. package/dist/esm/index180.js +5 -78
  92. package/dist/esm/index181.js +12 -2
  93. package/dist/esm/index182.js +19 -37
  94. package/dist/esm/index183.js +73 -105
  95. package/dist/esm/index184.js +2 -49
  96. package/dist/esm/index185.js +36 -31
  97. package/dist/esm/index186.js +110 -8
  98. package/dist/esm/index187.js +48 -6
  99. package/dist/esm/index188.js +32 -6
  100. package/dist/esm/index189.js +8 -11
  101. package/dist/esm/index19.js +5 -5
  102. package/dist/esm/index190.js +6 -10
  103. package/dist/esm/index191.js +6 -13
  104. package/dist/esm/index192.js +11 -32
  105. package/dist/esm/index193.js +11 -5
  106. package/dist/esm/index194.js +13 -8
  107. package/dist/esm/index195.js +30 -17
  108. package/dist/esm/index196.js +5 -32
  109. package/dist/esm/index197.js +8 -20
  110. package/dist/esm/index198.js +19 -3
  111. package/dist/esm/index199.js +31 -17
  112. package/dist/esm/index2.js +2 -2
  113. package/dist/esm/index20.js +5 -5
  114. package/dist/esm/index200.js +20 -10
  115. package/dist/esm/index201.js +3 -21
  116. package/dist/esm/index202.js +16 -21
  117. package/dist/esm/index203.js +10 -5
  118. package/dist/esm/index204.js +21 -5
  119. package/dist/esm/index205.js +22 -8
  120. package/dist/esm/index206.js +5 -104
  121. package/dist/esm/index207.js +6 -3
  122. package/dist/esm/index208.js +8 -18
  123. package/dist/esm/index209.js +99 -166
  124. package/dist/esm/index21.js +5 -5
  125. package/dist/esm/index210.js +3 -18
  126. package/dist/esm/index211.js +19 -10
  127. package/dist/esm/index212.js +170 -39
  128. package/dist/esm/index213.js +18 -2
  129. package/dist/esm/index214.js +10 -5
  130. package/dist/esm/index215.js +38 -10
  131. package/dist/esm/index216.js +2 -20
  132. package/dist/esm/index217.js +69 -7
  133. package/dist/esm/index218.js +34 -11
  134. package/dist/esm/index219.js +14 -66
  135. package/dist/esm/index22.js +7 -8
  136. package/dist/esm/index220.js +39 -64
  137. package/dist/esm/index221.js +2 -186
  138. package/dist/esm/index222.js +4 -22
  139. package/dist/esm/index223.js +9 -41
  140. package/dist/esm/index224.js +17 -74
  141. package/dist/esm/index225.js +7 -40
  142. package/dist/esm/index226.js +10 -15
  143. package/dist/esm/index227.js +66 -13
  144. package/dist/esm/index228.js +65 -7
  145. package/dist/esm/index229.js +185 -6
  146. package/dist/esm/index23.js +8 -34
  147. package/dist/esm/index230.js +21 -35
  148. package/dist/esm/index231.js +42 -15
  149. package/dist/esm/index232.js +76 -8
  150. package/dist/esm/index233.js +40 -12
  151. package/dist/esm/index234.js +16 -9
  152. package/dist/esm/index235.js +12 -15
  153. package/dist/esm/index236.js +7 -22
  154. package/dist/esm/index237.js +6 -30
  155. package/dist/esm/index238.js +37 -2
  156. package/dist/esm/index239.js +15 -13
  157. package/dist/esm/index24.js +57 -18
  158. package/dist/esm/index240.js +8 -12
  159. package/dist/esm/index241.js +12 -47
  160. package/dist/esm/index242.js +9 -9
  161. package/dist/esm/index243.js +16 -13
  162. package/dist/esm/index244.js +21 -13
  163. package/dist/esm/index245.js +28 -6
  164. package/dist/esm/index246.js +2 -16
  165. package/dist/esm/index247.js +12 -23
  166. package/dist/esm/index248.js +12 -11
  167. package/dist/esm/index249.js +45 -22
  168. package/dist/esm/index25.js +8 -11
  169. package/dist/esm/index250.js +9 -51
  170. package/dist/esm/index251.js +13 -17
  171. package/dist/esm/index252.js +13 -13
  172. package/dist/esm/index253.js +8 -11
  173. package/dist/esm/index254.js +15 -103
  174. package/dist/esm/index255.js +24 -5
  175. package/dist/esm/index256.js +10 -222
  176. package/dist/esm/index257.js +24 -6
  177. package/dist/esm/index258.js +52 -7
  178. package/dist/esm/index259.js +17 -26
  179. package/dist/esm/index26.js +34 -12
  180. package/dist/esm/index260.js +13 -18
  181. package/dist/esm/index261.js +11 -145
  182. package/dist/esm/index262.js +103 -38
  183. package/dist/esm/index263.js +6 -2
  184. package/dist/esm/index264.js +223 -69
  185. package/dist/esm/index265.js +6 -34
  186. package/dist/esm/index266.js +7 -15
  187. package/dist/esm/index267.js +26 -12
  188. package/dist/esm/index268.js +20 -36
  189. package/dist/esm/index269.js +145 -41
  190. package/dist/esm/index27.js +18 -54
  191. package/dist/esm/index270.js +13 -2
  192. package/dist/esm/index271.js +35 -68
  193. package/dist/esm/index272.js +41 -3
  194. package/dist/esm/index273.js +2 -137
  195. package/dist/esm/index274.js +69 -156
  196. package/dist/esm/index275.js +134 -7
  197. package/dist/esm/index276.js +3 -16
  198. package/dist/esm/index277.js +140 -98
  199. package/dist/esm/index278.js +9 -134
  200. package/dist/esm/index279.js +16 -78
  201. package/dist/esm/index28.js +11 -57
  202. package/dist/esm/index280.js +114 -2
  203. package/dist/esm/index281.js +124 -687
  204. package/dist/esm/index282.js +73 -133
  205. package/dist/esm/index283.js +2 -43
  206. package/dist/esm/index284.js +675 -178
  207. package/dist/esm/index285.js +136 -63
  208. package/dist/esm/index286.js +42 -4
  209. package/dist/esm/index287.js +200 -40
  210. package/dist/esm/index288.js +3 -7
  211. package/dist/esm/index289.js +61 -58
  212. package/dist/esm/index29.js +12 -56
  213. package/dist/esm/index290.js +4 -77
  214. package/dist/esm/index291.js +41 -4
  215. package/dist/esm/index292.js +7 -194
  216. package/dist/esm/index293.js +62 -3
  217. package/dist/esm/index294.js +61 -47
  218. package/dist/esm/index295.js +4 -45
  219. package/dist/esm/index296.js +194 -4
  220. package/dist/esm/index297.js +64 -5
  221. package/dist/esm/index298.js +45 -2
  222. package/dist/esm/index299.js +4 -21
  223. package/dist/esm/index3.js +1 -1
  224. package/dist/esm/index30.js +54 -5
  225. package/dist/esm/index300.js +7 -0
  226. package/dist/esm/index301.js +4 -0
  227. package/dist/esm/index302.js +24 -0
  228. package/dist/esm/index31.js +57 -47
  229. package/dist/esm/index32.js +56 -33
  230. package/dist/esm/index33.js +5 -4
  231. package/dist/esm/index34.js +46 -8
  232. package/dist/esm/index35.js +31 -67
  233. package/dist/esm/index36.js +3 -9
  234. package/dist/esm/index37.js +9 -28
  235. package/dist/esm/index38.js +68 -70
  236. package/dist/esm/index39.js +9 -19
  237. package/dist/esm/index40.js +26 -108
  238. package/dist/esm/index41.js +70 -60
  239. package/dist/esm/index42.js +19 -24
  240. package/dist/esm/index43.js +110 -40
  241. package/dist/esm/index44.js +57 -34
  242. package/dist/esm/index45.js +20 -54
  243. package/dist/esm/index46.js +37 -160
  244. package/dist/esm/index47.js +36 -38
  245. package/dist/esm/index48.js +58 -9
  246. package/dist/esm/index49.js +161 -29
  247. package/dist/esm/index5.js +3 -3
  248. package/dist/esm/index50.js +39 -36
  249. package/dist/esm/index51.js +7 -7
  250. package/dist/esm/index52.js +30 -28
  251. package/dist/esm/index53.js +34 -44
  252. package/dist/esm/index54.js +9 -88
  253. package/dist/esm/index55.js +26 -37
  254. package/dist/esm/index56.js +46 -8
  255. package/dist/esm/index57.js +88 -6
  256. package/dist/esm/index58.js +40 -16
  257. package/dist/esm/index59.js +8 -8
  258. package/dist/esm/index6.js +2 -2
  259. package/dist/esm/index60.js +6 -13
  260. package/dist/esm/index61.js +16 -7
  261. package/dist/esm/index62.js +8 -9
  262. package/dist/esm/index63.js +13 -16
  263. package/dist/esm/index64.js +7 -46
  264. package/dist/esm/index65.js +9 -13
  265. package/dist/esm/index66.js +15 -15
  266. package/dist/esm/index67.js +46 -13
  267. package/dist/esm/index68.js +13 -6
  268. package/dist/esm/index69.js +15 -34
  269. package/dist/esm/index7.js +1 -1
  270. package/dist/esm/index70.js +13 -9
  271. package/dist/esm/index71.js +5 -7
  272. package/dist/esm/index72.js +35 -25
  273. package/dist/esm/index73.js +9 -10
  274. package/dist/esm/index74.js +7 -13
  275. package/dist/esm/index75.js +25 -11
  276. package/dist/esm/index76.js +10 -116
  277. package/dist/esm/index77.js +13 -32
  278. package/dist/esm/index78.js +11 -79
  279. package/dist/esm/index79.js +108 -169
  280. package/dist/esm/index8.js +2 -2
  281. package/dist/esm/index80.js +26 -37
  282. package/dist/esm/index81.js +79 -6
  283. package/dist/esm/index82.js +177 -13
  284. package/dist/esm/index83.js +44 -13
  285. package/dist/esm/index84.js +6 -99
  286. package/dist/esm/index85.js +13 -72
  287. package/dist/esm/index86.js +13 -87
  288. package/dist/esm/index87.js +93 -142
  289. package/dist/esm/index88.js +65 -129
  290. package/dist/esm/index89.js +73 -54
  291. package/dist/esm/index9.js +1 -1
  292. package/dist/esm/index90.js +148 -23
  293. package/dist/esm/index91.js +133 -102
  294. package/dist/esm/index92.js +68 -6
  295. package/dist/esm/index93.js +23 -131
  296. package/dist/esm/index94.js +101 -271
  297. package/dist/esm/index95.js +7 -3
  298. package/dist/esm/index96.js +132 -4
  299. package/dist/esm/index97.js +276 -9
  300. package/dist/esm/index98.js +3 -2
  301. package/dist/esm/index99.js +4 -2
  302. package/dist/types/index.d.ts +33 -0
  303. package/package.json +3 -3
@@ -1,151 +1,102 @@
1
- import { DecodeLogDataMismatch as M, DecodeLogTopicsMismatch as P } from "./index101.js";
2
- import { InvalidInputRpcError as T } from "./index118.js";
3
- import { decodeEventLog as z } from "./index148.js";
4
- import { encodeEventTopics as A } from "./index158.js";
5
- import { formatLog as B } from "./index139.js";
6
- import { getAction as g } from "./index228.js";
7
- import { observe as F } from "./index230.js";
8
- import { poll as O } from "./index231.js";
9
- import { stringify as D } from "./index125.js";
10
- import { createContractEventFilter as R } from "./index49.js";
11
- import { getBlockNumber as U } from "./index59.js";
12
- import { getContractEvents as j } from "./index63.js";
13
- import { getFilterChanges as q } from "./index66.js";
14
- import { uninstallFilter as x } from "./index81.js";
15
- function st(t, S) {
16
- const { abi: b, address: p, args: l, batch: E = !0, eventName: c, fromBlock: m, onError: h, onLogs: N, poll: L, pollingInterval: w = t.pollingInterval, strict: v } = S;
17
- return (typeof L < "u" ? L : typeof m == "bigint" ? !0 : !(t.transport.type === "webSocket" || t.transport.type === "ipc" || t.transport.type === "fallback" && (t.transport.transports[0].config.type === "webSocket" || t.transport.transports[0].config.type === "ipc"))) ? (() => {
18
- const u = v ?? !1, C = D([
19
- "watchContractEvent",
20
- p,
21
- l,
22
- E,
23
- t.uid,
24
- c,
25
- w,
26
- u,
27
- m
28
- ]);
29
- return F(C, { onLogs: N, onError: h }, (a) => {
30
- let n;
31
- m !== void 0 && (n = m - 1n);
32
- let e, s = !1;
33
- const k = O(async () => {
34
- if (!s) {
1
+ import { BlockNotFoundError as D } from "./index109.js";
2
+ import { WaitForTransactionReceiptTimeoutError as M, TransactionNotFoundError as O, TransactionReceiptNotFoundError as W } from "./index118.js";
3
+ import { getAction as l } from "./index236.js";
4
+ import { observe as q } from "./index238.js";
5
+ import { withResolvers as z } from "./index240.js";
6
+ import { withRetry as B } from "./index200.js";
7
+ import { stringify as G } from "./index128.js";
8
+ import { getBlock as H } from "./index61.js";
9
+ import { getTransaction as J } from "./index75.js";
10
+ import { getTransactionReceipt as g } from "./index78.js";
11
+ import { watchBlockNumber as K } from "./index88.js";
12
+ async function re(r, b) {
13
+ const {
14
+ checkReplacement: F = !0,
15
+ confirmations: n = 1,
16
+ hash: s,
17
+ onReplaced: _,
18
+ retryCount: v = 6,
19
+ retryDelay: y = ({ count: t }) => ~~(1 << t) * 200,
20
+ // exponential backoff
21
+ timeout: N = 18e4
22
+ } = b, I = G(["waitForTransactionReceipt", r.uid, s]), E = b.pollingInterval ? b.pollingInterval : r.chain?.experimental_preconfirmationTime ? r.chain.experimental_preconfirmationTime : r.pollingInterval;
23
+ let i, a, e, c = !1, p, d;
24
+ const { promise: j, resolve: x, reject: R } = z(), w = N ? setTimeout(() => {
25
+ d(), p(), R(new M({ hash: s }));
26
+ }, N) : void 0;
27
+ return p = q(I, { onReplaced: _, resolve: x, reject: R }, async (t) => {
28
+ if (e = await l(r, g, "getTransactionReceipt")({ hash: s }).catch(() => {
29
+ }), e && n <= 1) {
30
+ clearTimeout(w), t.resolve(e), p();
31
+ return;
32
+ }
33
+ d = l(r, K, "watchBlockNumber")({
34
+ emitMissed: !0,
35
+ emitOnBegin: !0,
36
+ poll: !0,
37
+ pollingInterval: E,
38
+ async onBlockNumber(A) {
39
+ const u = (f) => {
40
+ clearTimeout(w), d(), f(), p();
41
+ };
42
+ let m = A;
43
+ if (!c)
35
44
  try {
36
- e = await g(t, R, "createContractEventFilter")({
37
- abi: b,
38
- address: p,
39
- args: l,
40
- eventName: c,
41
- strict: u,
42
- fromBlock: m
43
- });
44
- } catch {
45
- }
46
- s = !0;
47
- return;
48
- }
49
- try {
50
- let o;
51
- if (e)
52
- o = await g(t, q, "getFilterChanges")({ filter: e });
53
- else {
54
- const r = await g(t, U, "getBlockNumber")({});
55
- n && n < r ? o = await g(t, j, "getContractEvents")({
56
- abi: b,
57
- address: p,
58
- args: l,
59
- eventName: c,
60
- fromBlock: n + 1n,
61
- toBlock: r,
62
- strict: u
63
- }) : o = [], n = r;
64
- }
65
- if (o.length === 0)
66
- return;
67
- if (E)
68
- a.onLogs(o);
69
- else
70
- for (const r of o)
71
- a.onLogs([r]);
72
- } catch (o) {
73
- e && o instanceof T && (s = !1), a.onError?.(o);
74
- }
75
- }, {
76
- emitOnBegin: !0,
77
- interval: w
78
- });
79
- return async () => {
80
- e && await g(t, x, "uninstallFilter")({ filter: e }), k();
81
- };
82
- });
83
- })() : (() => {
84
- const u = v ?? !1, C = D([
85
- "watchContractEvent",
86
- p,
87
- l,
88
- E,
89
- t.uid,
90
- c,
91
- w,
92
- u
93
- ]);
94
- let a = !0, n = () => a = !1;
95
- return F(C, { onLogs: N, onError: h }, (e) => ((async () => {
96
- try {
97
- const s = (() => {
98
- if (t.transport.type === "fallback") {
99
- const r = t.transport.transports.find((i) => i.config.type === "webSocket" || i.config.type === "ipc");
100
- return r ? r.value : t.transport;
101
- }
102
- return t.transport;
103
- })(), k = c ? A({
104
- abi: b,
105
- eventName: c,
106
- args: l
107
- }) : [], { unsubscribe: o } = await s.subscribe({
108
- params: ["logs", { address: p, topics: k }],
109
- onData(r) {
110
- if (!a)
45
+ if (e) {
46
+ if (n > 1 && (!e.blockNumber || m - e.blockNumber + 1n < n))
47
+ return;
48
+ u(() => t.resolve(e));
111
49
  return;
112
- const i = r.result;
113
- try {
114
- const { eventName: f, args: d } = z({
115
- abi: b,
116
- data: i.data,
117
- topics: i.topics,
118
- strict: v
119
- }), y = B(i, {
120
- args: d,
121
- eventName: f
122
- });
123
- e.onLogs([y]);
124
- } catch (f) {
125
- let d, y;
126
- if (f instanceof M || f instanceof P) {
127
- if (v)
50
+ }
51
+ if (F && !i && (c = !0, await B(async () => {
52
+ i = await l(r, J, "getTransaction")({ hash: s }), i.blockNumber && (m = i.blockNumber);
53
+ }, {
54
+ delay: y,
55
+ retryCount: v
56
+ }), c = !1), e = await l(r, g, "getTransactionReceipt")({ hash: s }), n > 1 && (!e.blockNumber || m - e.blockNumber + 1n < n))
57
+ return;
58
+ u(() => t.resolve(e));
59
+ } catch (f) {
60
+ if (f instanceof O || f instanceof W) {
61
+ if (!i) {
62
+ c = !1;
63
+ return;
64
+ }
65
+ try {
66
+ a = i, c = !0;
67
+ const T = await B(() => l(r, H, "getBlock")({
68
+ blockNumber: m,
69
+ includeTransactions: !0
70
+ }), {
71
+ delay: y,
72
+ retryCount: v,
73
+ shouldRetry: ({ error: k }) => k instanceof D
74
+ });
75
+ c = !1;
76
+ const o = T.transactions.find(({ from: k, nonce: C }) => k === a.from && C === a.nonce);
77
+ if (!o || (e = await l(r, g, "getTransactionReceipt")({
78
+ hash: o.hash
79
+ }), n > 1 && (!e.blockNumber || m - e.blockNumber + 1n < n)))
128
80
  return;
129
- d = f.abiItem.name, y = f.abiItem.inputs?.some((I) => !("name" in I && I.name));
81
+ let h = "replaced";
82
+ o.to === a.to && o.value === a.value && o.input === a.input ? h = "repriced" : o.from === o.to && o.value === 0n && (h = "cancelled"), u(() => {
83
+ t.onReplaced?.({
84
+ reason: h,
85
+ replacedTransaction: a,
86
+ transaction: o,
87
+ transactionReceipt: e
88
+ }), t.resolve(e);
89
+ });
90
+ } catch (T) {
91
+ u(() => t.reject(T));
130
92
  }
131
- const _ = B(i, {
132
- args: y ? [] : {},
133
- eventName: d
134
- });
135
- e.onLogs([_]);
136
- }
137
- },
138
- onError(r) {
139
- e.onError?.(r);
93
+ } else
94
+ u(() => t.reject(f));
140
95
  }
141
- });
142
- n = o, a || n();
143
- } catch (s) {
144
- h?.(s);
145
96
  }
146
- })(), () => n()));
147
- })();
97
+ });
98
+ }), j;
148
99
  }
149
100
  export {
150
- st as watchContractEvent
101
+ re as waitForTransactionReceipt
151
102
  };
@@ -1,139 +1,75 @@
1
- import { encodeEventTopics as S } from "./index158.js";
2
- import { observe as B } from "./index230.js";
3
- import { poll as C } from "./index231.js";
4
- import { stringify as T } from "./index125.js";
5
- import { DecodeLogDataMismatch as z, DecodeLogTopicsMismatch as A } from "./index101.js";
6
- import { InvalidInputRpcError as O } from "./index118.js";
7
- import { decodeEventLog as P } from "./index148.js";
8
- import { formatLog as I } from "./index139.js";
9
- import { getAction as u } from "./index228.js";
10
- import { createEventFilter as R } from "./index50.js";
11
- import { getBlockNumber as U } from "./index59.js";
12
- import { getFilterChanges as j } from "./index66.js";
13
- import { getLogs as q } from "./index69.js";
14
- import { uninstallFilter as x } from "./index81.js";
15
- function nt(r, { address: m, args: l, batch: h = !0, event: s, events: d, fromBlock: c, onError: y, onLogs: v, poll: E, pollingInterval: k = r.pollingInterval, strict: N }) {
16
- const D = typeof E < "u" ? E : typeof c == "bigint" ? !0 : !(r.transport.type === "webSocket" || r.transport.type === "ipc" || r.transport.type === "fallback" && (r.transport.transports[0].config.type === "webSocket" || r.transport.transports[0].config.type === "ipc")), F = N ?? !1;
17
- return D ? (() => {
18
- const p = T([
19
- "watchEvent",
20
- m,
21
- l,
22
- h,
1
+ import { hexToBigInt as w } from "./index167.js";
2
+ import { getAction as g } from "./index236.js";
3
+ import { observe as k } from "./index238.js";
4
+ import { poll as h } from "./index239.js";
5
+ import { stringify as y } from "./index128.js";
6
+ import { getBlockNumber as v } from "./index62.js";
7
+ function H(r, { emitOnBegin: c = !1, emitMissed: a = !1, onBlockNumber: l, onError: b, poll: i, pollingInterval: m = r.pollingInterval }) {
8
+ const N = typeof i < "u" ? i : !(r.transport.type === "webSocket" || r.transport.type === "ipc" || r.transport.type === "fallback" && (r.transport.transports[0].config.type === "webSocket" || r.transport.transports[0].config.type === "ipc"));
9
+ let t;
10
+ return N ? (() => {
11
+ const p = y([
12
+ "watchBlockNumber",
23
13
  r.uid,
24
- s,
25
- k,
26
- c
14
+ c,
15
+ a,
16
+ m
27
17
  ]);
28
- return B(p, { onLogs: v, onError: y }, (a) => {
29
- let n;
30
- c !== void 0 && (n = c - 1n);
31
- let o, i = !1;
32
- const w = C(async () => {
33
- if (!i) {
34
- try {
35
- o = await u(r, R, "createEventFilter")({
36
- address: m,
37
- args: l,
38
- event: s,
39
- events: d,
40
- strict: F,
41
- fromBlock: c
42
- });
43
- } catch {
44
- }
45
- i = !0;
46
- return;
47
- }
48
- try {
49
- let t;
50
- if (o)
51
- t = await u(r, j, "getFilterChanges")({ filter: o });
52
- else {
53
- const e = await u(r, U, "getBlockNumber")({});
54
- n && n !== e ? t = await u(r, q, "getLogs")({
55
- address: m,
56
- args: l,
57
- event: s,
58
- events: d,
59
- fromBlock: n + 1n,
60
- toBlock: e
61
- }) : t = [], n = e;
62
- }
63
- if (t.length === 0)
18
+ return k(p, { onBlockNumber: l, onError: b }, (s) => h(async () => {
19
+ try {
20
+ const o = await g(r, v, "getBlockNumber")({ cacheTime: 0 });
21
+ if (t) {
22
+ if (o === t)
64
23
  return;
65
- if (h)
66
- a.onLogs(t);
67
- else
68
- for (const e of t)
69
- a.onLogs([e]);
70
- } catch (t) {
71
- o && t instanceof O && (i = !1), a.onError?.(t);
24
+ if (o - t > 1 && a)
25
+ for (let e = t + 1n; e < o; e++)
26
+ s.onBlockNumber(e, t), t = e;
72
27
  }
73
- }, {
74
- emitOnBegin: !0,
75
- interval: k
76
- });
77
- return async () => {
78
- o && await u(r, x, "uninstallFilter")({ filter: o }), w();
79
- };
80
- });
28
+ (!t || o > t) && (s.onBlockNumber(o, t), t = o);
29
+ } catch (o) {
30
+ s.onError?.(o);
31
+ }
32
+ }, {
33
+ emitOnBegin: c,
34
+ interval: m
35
+ }));
81
36
  })() : (() => {
82
- let p = !0, a = () => p = !1;
83
- return (async () => {
84
- try {
85
- const n = (() => {
86
- if (r.transport.type === "fallback") {
87
- const t = r.transport.transports.find((e) => e.config.type === "webSocket" || e.config.type === "ipc");
88
- return t ? t.value : r.transport;
89
- }
90
- return r.transport;
91
- })(), o = d ?? (s ? [s] : void 0);
92
- let i = [];
93
- o && (i = [o.flatMap((e) => S({
94
- abi: [e],
95
- eventName: e.name,
96
- args: l
97
- }))], s && (i = i[0]));
98
- const { unsubscribe: w } = await n.subscribe({
99
- params: ["logs", { address: m, topics: i }],
100
- onData(t) {
101
- if (!p)
102
- return;
103
- const e = t.result;
104
- try {
105
- const { eventName: f, args: b } = P({
106
- abi: o ?? [],
107
- data: e.data,
108
- topics: e.topics,
109
- strict: F
110
- }), g = I(e, { args: b, eventName: f });
111
- v([g]);
112
- } catch (f) {
113
- let b, g;
114
- if (f instanceof z || f instanceof A) {
115
- if (N)
116
- return;
117
- b = f.abiItem.name, g = f.abiItem.inputs?.some((L) => !("name" in L && L.name));
118
- }
119
- const M = I(e, {
120
- args: g ? [] : {},
121
- eventName: b
122
- });
123
- v([M]);
37
+ const p = y([
38
+ "watchBlockNumber",
39
+ r.uid,
40
+ c,
41
+ a
42
+ ]);
43
+ return k(p, { onBlockNumber: l, onError: b }, (s) => {
44
+ let o = !0, e = () => o = !1;
45
+ return (async () => {
46
+ try {
47
+ const f = (() => {
48
+ if (r.transport.type === "fallback") {
49
+ const n = r.transport.transports.find((u) => u.config.type === "webSocket" || u.config.type === "ipc");
50
+ return n ? n.value : r.transport;
124
51
  }
125
- },
126
- onError(t) {
127
- y?.(t);
128
- }
129
- });
130
- a = w, p || a();
131
- } catch (n) {
132
- y?.(n);
133
- }
134
- })(), () => a();
52
+ return r.transport;
53
+ })(), { unsubscribe: B } = await f.subscribe({
54
+ params: ["newHeads"],
55
+ onData(n) {
56
+ if (!o)
57
+ return;
58
+ const u = w(n.result?.number);
59
+ s.onBlockNumber(u, t), t = u;
60
+ },
61
+ onError(n) {
62
+ s.onError?.(n);
63
+ }
64
+ });
65
+ e = B, o || e();
66
+ } catch (f) {
67
+ b?.(f);
68
+ }
69
+ })(), () => e();
70
+ });
135
71
  })();
136
72
  }
137
73
  export {
138
- nt as watchEvent
74
+ H as watchBlockNumber
139
75
  };
@@ -1,71 +1,90 @@
1
- import { getAction as c } from "./index228.js";
2
- import { observe as p } from "./index230.js";
3
- import { poll as b } from "./index231.js";
4
- import { stringify as m } from "./index125.js";
5
- import { createPendingTransactionFilter as d } from "./index51.js";
6
- import { getFilterChanges as h } from "./index66.js";
7
- import { uninstallFilter as P } from "./index81.js";
8
- function D(r, { batch: u = !0, onError: i, onTransactions: l, poll: f, pollingInterval: g = r.pollingInterval }) {
9
- return (typeof f < "u" ? f : r.transport.type !== "webSocket" && r.transport.type !== "ipc") ? (() => {
10
- const a = m([
11
- "watchPendingTransactions",
1
+ import { getAction as p } from "./index236.js";
2
+ import { observe as h } from "./index238.js";
3
+ import { poll as v } from "./index239.js";
4
+ import { stringify as S } from "./index128.js";
5
+ import { getBlock as i } from "./index61.js";
6
+ function P(r, { blockTag: l = r.experimental_blockTag ?? "latest", emitMissed: y = !1, emitOnBegin: m = !1, onBlock: k, onError: f, includeTransactions: B, poll: d, pollingInterval: w = r.pollingInterval }) {
7
+ const g = typeof d < "u" ? d : !(r.transport.type === "webSocket" || r.transport.type === "ipc" || r.transport.type === "fallback" && (r.transport.transports[0].config.type === "webSocket" || r.transport.transports[0].config.type === "ipc")), a = B ?? !1;
8
+ let e;
9
+ return g ? (() => {
10
+ const o = S([
11
+ "watchBlocks",
12
12
  r.uid,
13
- u,
14
- g
13
+ l,
14
+ y,
15
+ m,
16
+ a,
17
+ w
15
18
  ]);
16
- return p(a, { onTransactions: l, onError: i }, (t) => {
17
- let n;
18
- const s = b(async () => {
19
- try {
20
- if (!n)
21
- try {
22
- n = await c(r, d, "createPendingTransactionFilter")({});
23
- return;
24
- } catch (o) {
25
- throw s(), o;
26
- }
27
- const e = await c(r, h, "getFilterChanges")({ filter: n });
28
- if (e.length === 0)
19
+ return h(o, { onBlock: k, onError: f }, (s) => v(async () => {
20
+ try {
21
+ const t = await p(r, i, "getBlock")({
22
+ blockTag: l,
23
+ includeTransactions: a
24
+ });
25
+ if (t.number !== null && e?.number != null) {
26
+ if (t.number === e.number)
29
27
  return;
30
- if (u)
31
- t.onTransactions(e);
32
- else
33
- for (const o of e)
34
- t.onTransactions([o]);
35
- } catch (e) {
36
- t.onError?.(e);
28
+ if (t.number - e.number > 1 && y)
29
+ for (let u = e?.number + 1n; u < t.number; u++) {
30
+ const b = await p(r, i, "getBlock")({
31
+ blockNumber: u,
32
+ includeTransactions: a
33
+ });
34
+ s.onBlock(b, e), e = b;
35
+ }
37
36
  }
38
- }, {
39
- emitOnBegin: !0,
40
- interval: g
41
- });
42
- return async () => {
43
- n && await c(r, P, "uninstallFilter")({ filter: n }), s();
44
- };
45
- });
37
+ // If no previous block exists, emit.
38
+ (e?.number == null || // If the block tag is "pending" with no block number, emit.
39
+ l === "pending" && t?.number == null || // If the next block number is greater than the previous block number, emit.
40
+ // We don't want to emit blocks in the past.
41
+ t.number !== null && t.number > e.number) && (s.onBlock(t, e), e = t);
42
+ } catch (t) {
43
+ s.onError?.(t);
44
+ }
45
+ }, {
46
+ emitOnBegin: m,
47
+ interval: w
48
+ }));
46
49
  })() : (() => {
47
- let a = !0, t = () => a = !1;
50
+ let o = !0, s = !0, t = () => o = !1;
48
51
  return (async () => {
49
52
  try {
50
- const { unsubscribe: n } = await r.transport.subscribe({
51
- params: ["newPendingTransactions"],
52
- onData(s) {
53
- if (!a)
53
+ m && p(r, i, "getBlock")({
54
+ blockTag: l,
55
+ includeTransactions: a
56
+ }).then((n) => {
57
+ o && s && (k(n, void 0), s = !1);
58
+ }).catch(f);
59
+ const u = (() => {
60
+ if (r.transport.type === "fallback") {
61
+ const n = r.transport.transports.find((c) => c.config.type === "webSocket" || c.config.type === "ipc");
62
+ return n ? n.value : r.transport;
63
+ }
64
+ return r.transport;
65
+ })(), { unsubscribe: b } = await u.subscribe({
66
+ params: ["newHeads"],
67
+ async onData(n) {
68
+ if (!o)
54
69
  return;
55
- const e = s.result;
56
- l([e]);
70
+ const c = await p(r, i, "getBlock")({
71
+ blockNumber: n.result?.number,
72
+ includeTransactions: a
73
+ }).catch(() => {
74
+ });
75
+ o && (k(c, e), s = !1, e = c);
57
76
  },
58
- onError(s) {
59
- i?.(s);
77
+ onError(n) {
78
+ f?.(n);
60
79
  }
61
80
  });
62
- t = n, a || t();
63
- } catch (n) {
64
- i?.(n);
81
+ t = b, o || t();
82
+ } catch (u) {
83
+ f?.(u);
65
84
  }
66
85
  })(), () => t();
67
86
  })();
68
87
  }
69
88
  export {
70
- D as watchPendingTransactions
89
+ P as watchBlocks
71
90
  };
@@ -1,5 +1,5 @@
1
1
  import "./index2.js";
2
- import { useSendHookCallOnce as t } from "./index22.js";
2
+ import { useSendHookCallOnce as t } from "./index25.js";
3
3
  import "react";
4
4
  import { useLinkOAuth as n } from "./index13.js";
5
5
  function g() {