@workflow/web-shared 4.1.0-beta.47 → 4.1.0-beta.49

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 (301) hide show
  1. package/README.md +26 -52
  2. package/dist/components/error-boundary.d.ts.map +1 -0
  3. package/dist/{error-boundary.js → components/error-boundary.js} +1 -1
  4. package/dist/components/error-boundary.js.map +1 -0
  5. package/dist/{event-list-view.d.ts → components/event-list-view.d.ts} +2 -3
  6. package/dist/components/event-list-view.d.ts.map +1 -0
  7. package/dist/{event-list-view.js → components/event-list-view.js} +9 -17
  8. package/dist/components/event-list-view.js.map +1 -0
  9. package/dist/{hook-actions.d.ts → components/hook-actions.d.ts} +2 -3
  10. package/dist/components/hook-actions.d.ts.map +1 -0
  11. package/dist/{hook-actions.js → components/hook-actions.js} +3 -4
  12. package/dist/components/hook-actions.js.map +1 -0
  13. package/dist/components/index.d.ts +10 -0
  14. package/dist/components/index.d.ts.map +1 -0
  15. package/dist/components/index.js +8 -0
  16. package/dist/components/index.js.map +1 -0
  17. package/dist/components/run-trace-view.d.ts +22 -0
  18. package/dist/components/run-trace-view.d.ts.map +1 -0
  19. package/dist/components/run-trace-view.js +11 -0
  20. package/dist/components/run-trace-view.js.map +1 -0
  21. package/dist/components/sidebar/attribute-panel.d.ts.map +1 -0
  22. package/dist/{sidebar → components/sidebar}/attribute-panel.js +3 -3
  23. package/dist/components/sidebar/attribute-panel.js.map +1 -0
  24. package/dist/components/sidebar/conversation-view.d.ts.map +1 -0
  25. package/dist/components/sidebar/conversation-view.js.map +1 -0
  26. package/dist/components/sidebar/detail-card.d.ts.map +1 -0
  27. package/dist/components/sidebar/detail-card.js.map +1 -0
  28. package/dist/components/sidebar/entity-detail-panel.d.ts +32 -0
  29. package/dist/components/sidebar/entity-detail-panel.d.ts.map +1 -0
  30. package/dist/{sidebar → components/sidebar}/entity-detail-panel.js +61 -49
  31. package/dist/components/sidebar/entity-detail-panel.js.map +1 -0
  32. package/dist/components/sidebar/events-list.d.ts +8 -0
  33. package/dist/components/sidebar/events-list.d.ts.map +1 -0
  34. package/dist/components/sidebar/events-list.js +16 -0
  35. package/dist/components/sidebar/events-list.js.map +1 -0
  36. package/dist/components/sidebar/resolve-hook-modal.d.ts.map +1 -0
  37. package/dist/components/sidebar/resolve-hook-modal.js.map +1 -0
  38. package/dist/components/stream-viewer.d.ts +18 -0
  39. package/dist/components/stream-viewer.d.ts.map +1 -0
  40. package/dist/{stream-viewer.js → components/stream-viewer.js} +1 -59
  41. package/dist/components/stream-viewer.js.map +1 -0
  42. package/dist/components/trace-viewer/components/map.d.ts.map +1 -0
  43. package/dist/components/trace-viewer/components/map.js.map +1 -0
  44. package/dist/components/trace-viewer/components/markers.d.ts.map +1 -0
  45. package/dist/components/trace-viewer/components/markers.js.map +1 -0
  46. package/dist/components/trace-viewer/components/node.d.ts.map +1 -0
  47. package/dist/components/trace-viewer/components/node.js.map +1 -0
  48. package/dist/components/trace-viewer/components/search-input.d.ts.map +1 -0
  49. package/dist/components/trace-viewer/components/search-input.js.map +1 -0
  50. package/dist/components/trace-viewer/components/search.d.ts.map +1 -0
  51. package/dist/components/trace-viewer/components/search.js.map +1 -0
  52. package/dist/components/trace-viewer/components/span-detail-panel.d.ts.map +1 -0
  53. package/dist/components/trace-viewer/components/span-detail-panel.js.map +1 -0
  54. package/dist/components/trace-viewer/components/ui.d.ts.map +1 -0
  55. package/dist/components/trace-viewer/components/ui.js.map +1 -0
  56. package/dist/components/trace-viewer/components/zoom-button.d.ts.map +1 -0
  57. package/dist/components/trace-viewer/components/zoom-button.js.map +1 -0
  58. package/dist/components/trace-viewer/components/zoom-icons.d.ts.map +1 -0
  59. package/dist/components/trace-viewer/components/zoom-icons.js.map +1 -0
  60. package/dist/components/trace-viewer/context.d.ts.map +1 -0
  61. package/dist/components/trace-viewer/context.js.map +1 -0
  62. package/dist/components/trace-viewer/index.d.ts.map +1 -0
  63. package/dist/components/trace-viewer/index.js.map +1 -0
  64. package/dist/components/trace-viewer/trace-viewer.d.ts.map +1 -0
  65. package/dist/components/trace-viewer/trace-viewer.js.map +1 -0
  66. package/dist/components/trace-viewer/types.d.ts.map +1 -0
  67. package/dist/components/trace-viewer/types.js.map +1 -0
  68. package/dist/components/trace-viewer/util/constants.d.ts.map +1 -0
  69. package/dist/components/trace-viewer/util/constants.js.map +1 -0
  70. package/dist/components/trace-viewer/util/scrollbar-width.d.ts.map +1 -0
  71. package/dist/components/trace-viewer/util/scrollbar-width.js.map +1 -0
  72. package/dist/{trace-viewer → components/trace-viewer}/util/timing.d.ts +1 -1
  73. package/dist/components/trace-viewer/util/timing.d.ts.map +1 -0
  74. package/dist/{trace-viewer → components/trace-viewer}/util/timing.js +1 -1
  75. package/dist/components/trace-viewer/util/timing.js.map +1 -0
  76. package/dist/components/trace-viewer/util/tree.d.ts.map +1 -0
  77. package/dist/components/trace-viewer/util/tree.js.map +1 -0
  78. package/dist/components/trace-viewer/util/use-immediate-style.d.ts.map +1 -0
  79. package/dist/components/trace-viewer/util/use-immediate-style.js.map +1 -0
  80. package/dist/components/trace-viewer/util/use-streaming-spans.d.ts.map +1 -0
  81. package/dist/components/trace-viewer/util/use-streaming-spans.js.map +1 -0
  82. package/dist/components/trace-viewer/util/use-trackpad-zoom.d.ts.map +1 -0
  83. package/dist/components/trace-viewer/util/use-trackpad-zoom.js.map +1 -0
  84. package/dist/components/trace-viewer/worker.d.ts.map +1 -0
  85. package/dist/components/trace-viewer/worker.js.map +1 -0
  86. package/dist/components/workflow-trace-view.d.ts +24 -0
  87. package/dist/components/workflow-trace-view.d.ts.map +1 -0
  88. package/dist/components/workflow-trace-view.js +152 -0
  89. package/dist/components/workflow-trace-view.js.map +1 -0
  90. package/dist/components/workflow-traces/event-colors.d.ts.map +1 -0
  91. package/dist/components/workflow-traces/event-colors.js.map +1 -0
  92. package/dist/components/workflow-traces/trace-colors.d.ts.map +1 -0
  93. package/dist/components/workflow-traces/trace-colors.js.map +1 -0
  94. package/dist/components/workflow-traces/trace-span-construction.d.ts.map +1 -0
  95. package/dist/components/workflow-traces/trace-span-construction.js.map +1 -0
  96. package/dist/components/workflow-traces/trace-time-utils.d.ts.map +1 -0
  97. package/dist/components/workflow-traces/trace-time-utils.js.map +1 -0
  98. package/dist/index.d.ts +3 -13
  99. package/dist/index.d.ts.map +1 -1
  100. package/dist/index.js +2 -9
  101. package/dist/index.js.map +1 -1
  102. package/package.json +15 -11
  103. package/src/components/error-boundary.tsx +79 -0
  104. package/src/components/event-list-view.tsx +429 -0
  105. package/src/components/hook-actions.tsx +167 -0
  106. package/src/components/index.d.ts +1 -0
  107. package/src/components/index.ts +23 -0
  108. package/src/components/run-trace-view.tsx +75 -0
  109. package/src/components/sidebar/attribute-panel.tsx +938 -0
  110. package/src/components/sidebar/conversation-view.tsx +235 -0
  111. package/src/components/sidebar/detail-card.tsx +43 -0
  112. package/src/components/sidebar/entity-detail-panel.tsx +338 -0
  113. package/src/components/sidebar/events-list.tsx +119 -0
  114. package/src/components/sidebar/resolve-hook-modal.tsx +219 -0
  115. package/src/components/stream-viewer.tsx +143 -0
  116. package/src/components/trace-viewer/components/map.tsx +226 -0
  117. package/src/components/trace-viewer/components/markers.tsx +564 -0
  118. package/src/components/trace-viewer/components/node.tsx +259 -0
  119. package/src/components/trace-viewer/components/search-input.tsx +52 -0
  120. package/src/components/trace-viewer/components/search.tsx +47 -0
  121. package/src/components/trace-viewer/components/span-detail-panel.tsx +650 -0
  122. package/src/components/trace-viewer/components/ui.tsx +156 -0
  123. package/src/components/trace-viewer/components/zoom-button.tsx +61 -0
  124. package/src/components/trace-viewer/components/zoom-icons.tsx +65 -0
  125. package/src/components/trace-viewer/context.tsx +633 -0
  126. package/src/components/trace-viewer/index.tsx +4 -0
  127. package/src/components/trace-viewer/modules.d.ts +16 -0
  128. package/src/components/trace-viewer/trace-viewer.module.css +1292 -0
  129. package/src/components/trace-viewer/trace-viewer.tsx +448 -0
  130. package/src/components/trace-viewer/types.ts +234 -0
  131. package/src/components/trace-viewer/util/constants.ts +8 -0
  132. package/src/components/trace-viewer/util/scrollbar-width.ts +13 -0
  133. package/src/components/trace-viewer/util/timing.ts +33 -0
  134. package/src/components/trace-viewer/util/tree.ts +277 -0
  135. package/src/components/trace-viewer/util/use-immediate-style.ts +38 -0
  136. package/src/components/trace-viewer/util/use-streaming-spans.ts +415 -0
  137. package/src/components/trace-viewer/util/use-trackpad-zoom.tsx +51 -0
  138. package/src/components/trace-viewer/worker.ts +128 -0
  139. package/src/components/ui/alert.tsx +59 -0
  140. package/src/components/ui/card.tsx +88 -0
  141. package/src/components/ui/error-card.tsx +65 -0
  142. package/src/components/ui/skeleton.tsx +15 -0
  143. package/src/components/workflow-trace-view.tsx +306 -0
  144. package/src/components/workflow-traces/event-colors.ts +94 -0
  145. package/src/components/workflow-traces/trace-colors.ts +112 -0
  146. package/src/components/workflow-traces/trace-span-construction.ts +299 -0
  147. package/src/components/workflow-traces/trace-time-utils.ts +50 -0
  148. package/src/hooks/use-dark-mode.ts +34 -0
  149. package/src/index.d.ts +1 -0
  150. package/src/index.ts +29 -0
  151. package/src/lib/event-analysis.ts +231 -0
  152. package/src/lib/utils.ts +166 -0
  153. package/dist/api/workflow-api-client.d.ts +0 -543
  154. package/dist/api/workflow-api-client.d.ts.map +0 -1
  155. package/dist/api/workflow-api-client.js +0 -953
  156. package/dist/api/workflow-api-client.js.map +0 -1
  157. package/dist/api/workflow-server-actions.d.ts +0 -230
  158. package/dist/api/workflow-server-actions.d.ts.map +0 -1
  159. package/dist/api/workflow-server-actions.js +0 -861
  160. package/dist/api/workflow-server-actions.js.map +0 -1
  161. package/dist/error-boundary.d.ts.map +0 -1
  162. package/dist/error-boundary.js.map +0 -1
  163. package/dist/event-list-view.d.ts.map +0 -1
  164. package/dist/event-list-view.js.map +0 -1
  165. package/dist/hook-actions.d.ts.map +0 -1
  166. package/dist/hook-actions.js.map +0 -1
  167. package/dist/run-trace-view.d.ts +0 -8
  168. package/dist/run-trace-view.d.ts.map +0 -1
  169. package/dist/run-trace-view.js +0 -15
  170. package/dist/run-trace-view.js.map +0 -1
  171. package/dist/sidebar/attribute-panel.d.ts.map +0 -1
  172. package/dist/sidebar/attribute-panel.js.map +0 -1
  173. package/dist/sidebar/conversation-view.d.ts.map +0 -1
  174. package/dist/sidebar/conversation-view.js.map +0 -1
  175. package/dist/sidebar/detail-card.d.ts.map +0 -1
  176. package/dist/sidebar/detail-card.js.map +0 -1
  177. package/dist/sidebar/entity-detail-panel.d.ts +0 -12
  178. package/dist/sidebar/entity-detail-panel.d.ts.map +0 -1
  179. package/dist/sidebar/entity-detail-panel.js.map +0 -1
  180. package/dist/sidebar/events-list.d.ts +0 -9
  181. package/dist/sidebar/events-list.d.ts.map +0 -1
  182. package/dist/sidebar/events-list.js +0 -36
  183. package/dist/sidebar/events-list.js.map +0 -1
  184. package/dist/sidebar/resolve-hook-modal.d.ts.map +0 -1
  185. package/dist/sidebar/resolve-hook-modal.js.map +0 -1
  186. package/dist/stream-viewer.d.ts +0 -13
  187. package/dist/stream-viewer.d.ts.map +0 -1
  188. package/dist/stream-viewer.js.map +0 -1
  189. package/dist/trace-viewer/components/map.d.ts.map +0 -1
  190. package/dist/trace-viewer/components/map.js.map +0 -1
  191. package/dist/trace-viewer/components/markers.d.ts.map +0 -1
  192. package/dist/trace-viewer/components/markers.js.map +0 -1
  193. package/dist/trace-viewer/components/node.d.ts.map +0 -1
  194. package/dist/trace-viewer/components/node.js.map +0 -1
  195. package/dist/trace-viewer/components/search-input.d.ts.map +0 -1
  196. package/dist/trace-viewer/components/search-input.js.map +0 -1
  197. package/dist/trace-viewer/components/search.d.ts.map +0 -1
  198. package/dist/trace-viewer/components/search.js.map +0 -1
  199. package/dist/trace-viewer/components/span-detail-panel.d.ts.map +0 -1
  200. package/dist/trace-viewer/components/span-detail-panel.js.map +0 -1
  201. package/dist/trace-viewer/components/ui.d.ts.map +0 -1
  202. package/dist/trace-viewer/components/ui.js.map +0 -1
  203. package/dist/trace-viewer/components/zoom-button.d.ts.map +0 -1
  204. package/dist/trace-viewer/components/zoom-button.js.map +0 -1
  205. package/dist/trace-viewer/components/zoom-icons.d.ts.map +0 -1
  206. package/dist/trace-viewer/components/zoom-icons.js.map +0 -1
  207. package/dist/trace-viewer/context.d.ts.map +0 -1
  208. package/dist/trace-viewer/context.js.map +0 -1
  209. package/dist/trace-viewer/index.d.ts.map +0 -1
  210. package/dist/trace-viewer/index.js.map +0 -1
  211. package/dist/trace-viewer/trace-viewer.d.ts.map +0 -1
  212. package/dist/trace-viewer/trace-viewer.js.map +0 -1
  213. package/dist/trace-viewer/types.d.ts.map +0 -1
  214. package/dist/trace-viewer/types.js.map +0 -1
  215. package/dist/trace-viewer/util/constants.d.ts.map +0 -1
  216. package/dist/trace-viewer/util/constants.js.map +0 -1
  217. package/dist/trace-viewer/util/scrollbar-width.d.ts.map +0 -1
  218. package/dist/trace-viewer/util/scrollbar-width.js.map +0 -1
  219. package/dist/trace-viewer/util/timing.d.ts.map +0 -1
  220. package/dist/trace-viewer/util/timing.js.map +0 -1
  221. package/dist/trace-viewer/util/tree.d.ts.map +0 -1
  222. package/dist/trace-viewer/util/tree.js.map +0 -1
  223. package/dist/trace-viewer/util/use-immediate-style.d.ts.map +0 -1
  224. package/dist/trace-viewer/util/use-immediate-style.js.map +0 -1
  225. package/dist/trace-viewer/util/use-streaming-spans.d.ts.map +0 -1
  226. package/dist/trace-viewer/util/use-streaming-spans.js.map +0 -1
  227. package/dist/trace-viewer/util/use-trackpad-zoom.d.ts.map +0 -1
  228. package/dist/trace-viewer/util/use-trackpad-zoom.js.map +0 -1
  229. package/dist/trace-viewer/worker.d.ts.map +0 -1
  230. package/dist/trace-viewer/worker.js.map +0 -1
  231. package/dist/workflow-trace-view.d.ts +0 -14
  232. package/dist/workflow-trace-view.d.ts.map +0 -1
  233. package/dist/workflow-trace-view.js +0 -135
  234. package/dist/workflow-trace-view.js.map +0 -1
  235. package/dist/workflow-traces/event-colors.d.ts.map +0 -1
  236. package/dist/workflow-traces/event-colors.js.map +0 -1
  237. package/dist/workflow-traces/trace-colors.d.ts.map +0 -1
  238. package/dist/workflow-traces/trace-colors.js.map +0 -1
  239. package/dist/workflow-traces/trace-span-construction.d.ts.map +0 -1
  240. package/dist/workflow-traces/trace-span-construction.js.map +0 -1
  241. package/dist/workflow-traces/trace-time-utils.d.ts.map +0 -1
  242. package/dist/workflow-traces/trace-time-utils.js.map +0 -1
  243. package/server/README.md +0 -1
  244. package/server/package.json +0 -4
  245. /package/dist/{error-boundary.d.ts → components/error-boundary.d.ts} +0 -0
  246. /package/dist/{sidebar → components/sidebar}/attribute-panel.d.ts +0 -0
  247. /package/dist/{sidebar → components/sidebar}/conversation-view.d.ts +0 -0
  248. /package/dist/{sidebar → components/sidebar}/conversation-view.js +0 -0
  249. /package/dist/{sidebar → components/sidebar}/detail-card.d.ts +0 -0
  250. /package/dist/{sidebar → components/sidebar}/detail-card.js +0 -0
  251. /package/dist/{sidebar → components/sidebar}/resolve-hook-modal.d.ts +0 -0
  252. /package/dist/{sidebar → components/sidebar}/resolve-hook-modal.js +0 -0
  253. /package/dist/{trace-viewer → components/trace-viewer}/components/map.d.ts +0 -0
  254. /package/dist/{trace-viewer → components/trace-viewer}/components/map.js +0 -0
  255. /package/dist/{trace-viewer → components/trace-viewer}/components/markers.d.ts +0 -0
  256. /package/dist/{trace-viewer → components/trace-viewer}/components/markers.js +0 -0
  257. /package/dist/{trace-viewer → components/trace-viewer}/components/node.d.ts +0 -0
  258. /package/dist/{trace-viewer → components/trace-viewer}/components/node.js +0 -0
  259. /package/dist/{trace-viewer → components/trace-viewer}/components/search-input.d.ts +0 -0
  260. /package/dist/{trace-viewer → components/trace-viewer}/components/search-input.js +0 -0
  261. /package/dist/{trace-viewer → components/trace-viewer}/components/search.d.ts +0 -0
  262. /package/dist/{trace-viewer → components/trace-viewer}/components/search.js +0 -0
  263. /package/dist/{trace-viewer → components/trace-viewer}/components/span-detail-panel.d.ts +0 -0
  264. /package/dist/{trace-viewer → components/trace-viewer}/components/span-detail-panel.js +0 -0
  265. /package/dist/{trace-viewer → components/trace-viewer}/components/ui.d.ts +0 -0
  266. /package/dist/{trace-viewer → components/trace-viewer}/components/ui.js +0 -0
  267. /package/dist/{trace-viewer → components/trace-viewer}/components/zoom-button.d.ts +0 -0
  268. /package/dist/{trace-viewer → components/trace-viewer}/components/zoom-button.js +0 -0
  269. /package/dist/{trace-viewer → components/trace-viewer}/components/zoom-icons.d.ts +0 -0
  270. /package/dist/{trace-viewer → components/trace-viewer}/components/zoom-icons.js +0 -0
  271. /package/dist/{trace-viewer → components/trace-viewer}/context.d.ts +0 -0
  272. /package/dist/{trace-viewer → components/trace-viewer}/context.js +0 -0
  273. /package/dist/{trace-viewer → components/trace-viewer}/index.d.ts +0 -0
  274. /package/dist/{trace-viewer → components/trace-viewer}/index.js +0 -0
  275. /package/dist/{trace-viewer → components/trace-viewer}/trace-viewer.d.ts +0 -0
  276. /package/dist/{trace-viewer → components/trace-viewer}/trace-viewer.js +0 -0
  277. /package/dist/{trace-viewer → components/trace-viewer}/trace-viewer.module.css +0 -0
  278. /package/dist/{trace-viewer → components/trace-viewer}/types.d.ts +0 -0
  279. /package/dist/{trace-viewer → components/trace-viewer}/types.js +0 -0
  280. /package/dist/{trace-viewer → components/trace-viewer}/util/constants.d.ts +0 -0
  281. /package/dist/{trace-viewer → components/trace-viewer}/util/constants.js +0 -0
  282. /package/dist/{trace-viewer → components/trace-viewer}/util/scrollbar-width.d.ts +0 -0
  283. /package/dist/{trace-viewer → components/trace-viewer}/util/scrollbar-width.js +0 -0
  284. /package/dist/{trace-viewer → components/trace-viewer}/util/tree.d.ts +0 -0
  285. /package/dist/{trace-viewer → components/trace-viewer}/util/tree.js +0 -0
  286. /package/dist/{trace-viewer → components/trace-viewer}/util/use-immediate-style.d.ts +0 -0
  287. /package/dist/{trace-viewer → components/trace-viewer}/util/use-immediate-style.js +0 -0
  288. /package/dist/{trace-viewer → components/trace-viewer}/util/use-streaming-spans.d.ts +0 -0
  289. /package/dist/{trace-viewer → components/trace-viewer}/util/use-streaming-spans.js +0 -0
  290. /package/dist/{trace-viewer → components/trace-viewer}/util/use-trackpad-zoom.d.ts +0 -0
  291. /package/dist/{trace-viewer → components/trace-viewer}/util/use-trackpad-zoom.js +0 -0
  292. /package/dist/{trace-viewer → components/trace-viewer}/worker.d.ts +0 -0
  293. /package/dist/{trace-viewer → components/trace-viewer}/worker.js +0 -0
  294. /package/dist/{workflow-traces → components/workflow-traces}/event-colors.d.ts +0 -0
  295. /package/dist/{workflow-traces → components/workflow-traces}/event-colors.js +0 -0
  296. /package/dist/{workflow-traces → components/workflow-traces}/trace-colors.d.ts +0 -0
  297. /package/dist/{workflow-traces → components/workflow-traces}/trace-colors.js +0 -0
  298. /package/dist/{workflow-traces → components/workflow-traces}/trace-span-construction.d.ts +0 -0
  299. /package/dist/{workflow-traces → components/workflow-traces}/trace-span-construction.js +0 -0
  300. /package/dist/{workflow-traces → components/workflow-traces}/trace-time-utils.d.ts +0 -0
  301. /package/dist/{workflow-traces → components/workflow-traces}/trace-time-utils.js +0 -0
@@ -0,0 +1,259 @@
1
+ 'use client';
2
+
3
+ import { clsx } from 'clsx';
4
+ import type { CSSProperties, MutableRefObject, ReactNode } from 'react';
5
+ import { memo, useRef } from 'react';
6
+ import styles from '../trace-viewer.module.css';
7
+ import type {
8
+ MemoCache,
9
+ MemoCacheKey,
10
+ RootNode,
11
+ ScrollSnapshot,
12
+ SpanNode,
13
+ VisibleSpan,
14
+ VisibleSpanEvent,
15
+ } from '../types';
16
+ import { MARKER_HEIGHT, ROW_HEIGHT, ROW_PADDING } from '../util/constants';
17
+ import { formatDuration } from '../util/timing';
18
+
19
+ const isSpanSmall = (node: VisibleSpan, scale: number): boolean =>
20
+ node.duration * scale < 64;
21
+
22
+ const isSpanHuge = (node: VisibleSpan, scale: number): boolean =>
23
+ node.duration * scale >= 500;
24
+
25
+ export const getSpanColorClassName = (node: SpanNode): string => {
26
+ if (node.isVercel) return String(styles.colorVercel);
27
+ return String(styles[`color${node.resourceIndex % 5}` as 'color0']);
28
+ };
29
+
30
+ export const getSpanClassName = (node: VisibleSpan, scale: number): string => {
31
+ const isHuge = isSpanHuge(node, scale);
32
+ const isHovered = node.isHovered && !isHuge && node.isHighlighted !== false;
33
+
34
+ return clsx(
35
+ styles.spanNode,
36
+ isHuge && styles.huge,
37
+ isSpanSmall(node, scale) && styles.small,
38
+ node.isSelected && styles.selected,
39
+ isHovered && styles.xHover,
40
+ node.isHighlighted ? styles.colorHighlight : getSpanColorClassName(node),
41
+ node.isHighlighted === false && styles.unlit
42
+ );
43
+ };
44
+
45
+ const getDuration = (node: SpanNode): string => {
46
+ if (node.isInstrumentationHint) {
47
+ return 'Get Started';
48
+ }
49
+
50
+ return formatDuration(node.duration);
51
+ };
52
+
53
+ export const SpanNodes = memo(function SpanNodes({
54
+ root,
55
+ scale,
56
+ spans,
57
+ scrollSnapshotRef,
58
+ cache,
59
+ customSpanClassNameFunc,
60
+ customSpanEventClassNameFunc,
61
+ }: {
62
+ root: RootNode;
63
+ scale: number;
64
+ spans: VisibleSpan[];
65
+ scrollSnapshotRef: MutableRefObject<ScrollSnapshot | undefined>;
66
+ cacheKey?: MemoCacheKey;
67
+ cache: MemoCache;
68
+ customSpanClassNameFunc?: (span: SpanNode) => string;
69
+ customSpanEventClassNameFunc?: (event: VisibleSpanEvent) => string;
70
+ }) {
71
+ return spans.map((x) => (
72
+ <SpanComponent
73
+ cacheKey={cache.get(x.span.spanId)}
74
+ customSpanEventClassNameFunc={customSpanEventClassNameFunc}
75
+ customSpanClassNameFunc={customSpanClassNameFunc}
76
+ key={x.span.spanId}
77
+ node={x}
78
+ root={root}
79
+ scale={scale}
80
+ scrollSnapshotRef={scrollSnapshotRef}
81
+ />
82
+ ));
83
+ });
84
+
85
+ export const SpanComponent = memo(function SpanComponent({
86
+ node,
87
+ root,
88
+ scale,
89
+ scrollSnapshotRef,
90
+ customSpanClassNameFunc,
91
+ customSpanEventClassNameFunc,
92
+ }: {
93
+ node: VisibleSpan;
94
+ root: RootNode;
95
+ scale: number;
96
+ scrollSnapshotRef: MutableRefObject<ScrollSnapshot | undefined>;
97
+ cacheKey?: MemoCacheKey;
98
+ customSpanClassNameFunc?: (span: SpanNode) => string;
99
+ customSpanEventClassNameFunc?: (event: VisibleSpanEvent) => string;
100
+ }): ReactNode {
101
+ const ref = useRef<HTMLButtonElement>(null);
102
+ node.ref = ref;
103
+
104
+ const { span } = node;
105
+ const duration = getDuration(node);
106
+
107
+ const left = (node.startTime - root.startTime) * scale;
108
+ let top = MARKER_HEIGHT + (ROW_HEIGHT + ROW_PADDING) * node.row;
109
+ const actualWidth = node.duration * scale;
110
+ // Enforce minimum width so very short spans are always visible
111
+ const MIN_SPAN_WIDTH = 4;
112
+ const width = Math.max(actualWidth, MIN_SPAN_WIDTH);
113
+ let height = ROW_HEIGHT;
114
+ const isHuge = isSpanHuge(node, scale);
115
+ // Check if span is small based on actual width, not minimum width
116
+ const isSmall = actualWidth < 64;
117
+ const isHovered = node.isHovered && !isHuge && node.isHighlighted !== false;
118
+ if (isSmall && !isHovered) {
119
+ height *= 0.4;
120
+ top += (ROW_HEIGHT - height) * 0.5;
121
+ }
122
+
123
+ let isNearRightSide = false;
124
+ if (isHovered) {
125
+ let { duration: visibleDuration, endTime: visibleEndTime } = root;
126
+ const snapshot = scrollSnapshotRef.current;
127
+ if (snapshot) {
128
+ visibleDuration = snapshot.endTime - snapshot.startTime;
129
+ visibleEndTime = snapshot.endTime;
130
+ }
131
+ isNearRightSide = visibleEndTime - node.startTime < 0.25 * visibleDuration;
132
+ }
133
+
134
+ // Get custom class name from callback if provided
135
+ const customClassName = customSpanClassNameFunc
136
+ ? customSpanClassNameFunc(node)
137
+ : '';
138
+
139
+ return (
140
+ <>
141
+ <button
142
+ aria-label={`${span.name} - ${duration}`}
143
+ className={clsx(getSpanClassName(node, scale), customClassName)}
144
+ data-span-id={span.spanId}
145
+ data-start-time={node.startTime - root.startTime}
146
+ data-right-side={isNearRightSide}
147
+ ref={ref}
148
+ style={
149
+ {
150
+ // Use actualWidth for CSS variable so hover expansion is accurate
151
+ '--span-width': `${Math.max(actualWidth, 1)}px`,
152
+ minWidth: isHovered ? width : undefined,
153
+ width: isHovered ? undefined : width,
154
+ height,
155
+ maxWidth:
156
+ isHovered && !isNearRightSide
157
+ ? (root.endTime - node.startTime) * scale
158
+ : undefined,
159
+ containIntrinsicWidth: isHovered ? undefined : width,
160
+ containIntrinsicHeight: height,
161
+ left: isNearRightSide ? undefined : left,
162
+ right: isNearRightSide
163
+ ? (root.endTime - node.endTime) * scale
164
+ : undefined,
165
+ top,
166
+ } as CSSProperties
167
+ }
168
+ type="button"
169
+ >
170
+ {isSmall && !isHovered ? null : (
171
+ <>
172
+ <span className={styles.spanName}>{node.label || span.name}</span>
173
+ {isHuge ? <span className={styles.spanSpacer} /> : null}
174
+ {isHovered || width > 128 ? (
175
+ <span className={styles.spanDuration}>{duration}</span>
176
+ ) : null}
177
+ </>
178
+ )}
179
+ </button>
180
+ {node.events && !isSmall
181
+ ? node.events.map((x) => (
182
+ <SpanEventComponent
183
+ customSpanEventClassNameFunc={customSpanEventClassNameFunc}
184
+ event={x}
185
+ key={x.key}
186
+ node={node}
187
+ root={root}
188
+ scale={scale}
189
+ />
190
+ ))
191
+ : null}
192
+ </>
193
+ );
194
+ });
195
+
196
+ export const SpanEventComponent = memo(function SpanEventComponent({
197
+ event,
198
+ node,
199
+ root,
200
+ scale,
201
+ customSpanEventClassNameFunc,
202
+ }: {
203
+ event: VisibleSpanEvent;
204
+ node: VisibleSpan;
205
+ root: RootNode;
206
+ scale: number;
207
+ customSpanEventClassNameFunc?: (event: VisibleSpanEvent) => string;
208
+ }): ReactNode {
209
+ const ref = useRef<HTMLDivElement>(null);
210
+ event.ref = ref;
211
+
212
+ const {
213
+ event: { name },
214
+ } = event;
215
+ const timestamp = formatDuration(event.timestamp - root.startTime);
216
+
217
+ const left = (event.timestamp - root.startTime) * scale;
218
+ const top = MARKER_HEIGHT + (ROW_HEIGHT + ROW_PADDING) * node.row;
219
+
220
+ // Get custom class name from callback if provided
221
+ const customClassName = customSpanEventClassNameFunc
222
+ ? customSpanEventClassNameFunc(event)
223
+ : '';
224
+
225
+ return (
226
+ <div
227
+ title={`${name} at ${timestamp}`}
228
+ className={clsx(
229
+ styles.spanNodeEvent,
230
+ customClassName,
231
+ node.isHighlighted
232
+ ? styles.colorHighlight
233
+ : getSpanColorClassName(node),
234
+ node.isHighlighted === false && styles.unlit
235
+ )}
236
+ data-hovered={event.isHovered}
237
+ ref={ref}
238
+ style={
239
+ {
240
+ left,
241
+ top,
242
+ } as CSSProperties
243
+ }
244
+ >
245
+ <div
246
+ className={clsx(
247
+ styles.hoverInfo,
248
+ (event.timestamp - node.startTime) / node.duration < 0.5
249
+ ? styles.alignStart
250
+ : styles.alignEnd
251
+ )}
252
+ >
253
+ <span className={styles.eventName}>{name}</span>
254
+ <span className={styles.eventTimestamp}>{timestamp}</span>
255
+ </div>
256
+ <div className={styles.eventDiamond} />
257
+ </div>
258
+ );
259
+ });
@@ -0,0 +1,52 @@
1
+ import type { ChangeEventHandler, ReactNode } from 'react';
2
+ import styles from '../trace-viewer.module.css';
3
+
4
+ export function SearchInput({
5
+ height,
6
+ width,
7
+ value,
8
+ placeholder,
9
+ onChange,
10
+ }: {
11
+ height: number | string;
12
+ width?: number | string;
13
+ value: string;
14
+ placeholder?: string;
15
+ onChange: ChangeEventHandler<HTMLInputElement>;
16
+ }): ReactNode {
17
+ return (
18
+ <label className={styles.searchInputLabel}>
19
+ <div className={styles.searchInputPrefix}>
20
+ <MagnifyingGlassIcon />
21
+ </div>
22
+ <input
23
+ type="search"
24
+ value={value}
25
+ placeholder={placeholder}
26
+ onChange={onChange}
27
+ style={{ height, width }}
28
+ />
29
+ </label>
30
+ );
31
+ }
32
+
33
+ function MagnifyingGlassIcon(): ReactNode {
34
+ return (
35
+ <svg
36
+ width={16}
37
+ height={16}
38
+ viewBox="0 0 16 16"
39
+ fill="none"
40
+ aria-hidden="true"
41
+ focusable="false"
42
+ >
43
+ <circle cx="7" cy="7" r="4.5" stroke="currentColor" strokeWidth="1.5" />
44
+ <path
45
+ d="M11.5 11.5L14 14"
46
+ stroke="currentColor"
47
+ strokeWidth="1.5"
48
+ strokeLinecap="round"
49
+ />
50
+ </svg>
51
+ );
52
+ }
@@ -0,0 +1,47 @@
1
+ 'use client';
2
+
3
+ import { type ReactNode, useEffect, useState } from 'react';
4
+ import { useTraceViewer } from '../context';
5
+ import styles from '../trace-viewer.module.css';
6
+ import { SEARCH_HEIGHT } from '../util/constants';
7
+ import { SearchInput } from './search-input';
8
+
9
+ export function SearchBar(): ReactNode {
10
+ return (
11
+ <nav className={styles.searchBar}>
12
+ <SearchInputWrapper />
13
+ </nav>
14
+ );
15
+ }
16
+
17
+ function SearchInputWrapper(): ReactNode {
18
+ const { dispatch } = useTraceViewer();
19
+ const [value, setValue] = useState('');
20
+
21
+ useEffect(() => {
22
+ const timeout = setTimeout(
23
+ () =>
24
+ dispatch({
25
+ type: 'setFilter',
26
+ filter: value,
27
+ }),
28
+ 100
29
+ );
30
+
31
+ return () => {
32
+ clearTimeout(timeout);
33
+ };
34
+ }, [dispatch, value]);
35
+
36
+ return (
37
+ <div className={styles.searchInput}>
38
+ <SearchInput
39
+ height={SEARCH_HEIGHT}
40
+ onChange={(e) => setValue(e.target.value)}
41
+ placeholder="Search spans…"
42
+ value={value}
43
+ width="100%"
44
+ />
45
+ </div>
46
+ );
47
+ }