@coinbase/cdp-hooks 0.0.62 → 0.0.64

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