effect-start 0.22.0 → 0.23.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (313) hide show
  1. package/dist/BlobStore.d.ts +80 -0
  2. package/dist/BlobStore.js +19 -0
  3. package/dist/ChildProcess.d.ts +60 -0
  4. package/dist/ChildProcess.js +30 -0
  5. package/dist/Commander.d.ts +3 -6
  6. package/dist/Commander.js +6 -13
  7. package/dist/ContentNegotiation.d.ts +8 -9
  8. package/dist/ContentNegotiation.js +32 -37
  9. package/dist/Cookies.d.ts +47 -0
  10. package/dist/Cookies.js +273 -363
  11. package/dist/Development.d.ts +2 -2
  12. package/dist/Development.js +3 -4
  13. package/dist/Effectify.d.ts +1 -4
  14. package/dist/FilePathPattern.d.ts +3 -3
  15. package/dist/FileRouter.d.ts +5 -8
  16. package/dist/FileRouter.js +9 -10
  17. package/dist/FileRouterCodegen.d.ts +1 -1
  18. package/dist/FileRouterCodegen.js +33 -13
  19. package/dist/FileSystem.d.ts +158 -0
  20. package/dist/FileSystem.js +64 -125
  21. package/dist/Http.js +2 -6
  22. package/dist/PathPattern.d.ts +7 -7
  23. package/dist/PathPattern.js +1 -3
  24. package/dist/PlatformError.d.ts +24 -32
  25. package/dist/PlatformError.js +3 -21
  26. package/dist/PlatformRuntime.js +5 -10
  27. package/dist/Route.d.ts +14 -19
  28. package/dist/Route.js +8 -11
  29. package/dist/RouteBody.d.ts +6 -12
  30. package/dist/RouteBody.js +2 -2
  31. package/dist/RouteError.d.ts +98 -0
  32. package/dist/RouteError.js +55 -0
  33. package/dist/RouteHook.js +6 -11
  34. package/dist/RouteHttp.d.ts +3 -3
  35. package/dist/RouteHttp.js +27 -22
  36. package/dist/RouteMount.d.ts +16 -50
  37. package/dist/RouteMount.js +6 -20
  38. package/dist/RouteSchema.d.ts +22 -1
  39. package/dist/RouteSchema.js +33 -0
  40. package/dist/RouteSse.js +4 -10
  41. package/dist/RouteTree.d.ts +2 -1
  42. package/dist/RouteTree.js +17 -15
  43. package/dist/RouteTrie.d.ts +2 -2
  44. package/dist/RouteTrie.js +4 -9
  45. package/dist/SchemaExtra.d.ts +1 -1
  46. package/dist/Socket.d.ts +27 -0
  47. package/dist/Socket.js +20 -28
  48. package/dist/Sql.d.ts +34 -0
  49. package/dist/Sql.js +5 -0
  50. package/dist/SqlIntrospect.d.ts +91 -0
  51. package/dist/SqlIntrospect.js +466 -0
  52. package/dist/Start.d.ts +4 -6
  53. package/dist/Start.js +10 -2
  54. package/dist/StreamExtra.d.ts +1 -1
  55. package/dist/StreamExtra.js +9 -9
  56. package/dist/System.d.ts +7 -0
  57. package/dist/System.js +22 -0
  58. package/dist/TuplePathPattern.js +55 -50
  59. package/dist/Unique.js +7 -7
  60. package/dist/Values.d.ts +2 -1
  61. package/dist/Values.js +19 -13
  62. package/dist/bun/BunBlobStoreDisk.d.ts +6 -0
  63. package/dist/bun/BunBlobStoreDisk.js +116 -0
  64. package/dist/bun/BunBlobStoreS3.d.ts +11 -0
  65. package/dist/bun/BunBlobStoreS3.js +89 -0
  66. package/dist/bun/BunBlobWatcherDisk.d.ts +6 -0
  67. package/dist/bun/BunBlobWatcherDisk.js +60 -0
  68. package/dist/bun/BunBlobWatcherQueue.d.ts +6 -0
  69. package/dist/bun/BunBlobWatcherQueue.js +17 -0
  70. package/dist/bun/BunBundle.d.ts +5 -6
  71. package/dist/bun/BunBundle.js +7 -15
  72. package/dist/bun/BunChildProcessSpawner.d.ts +3 -0
  73. package/dist/bun/BunChildProcessSpawner.js +103 -0
  74. package/dist/bun/BunImportTrackerPlugin.d.ts +1 -1
  75. package/dist/bun/BunImportTrackerPlugin.js +3 -5
  76. package/dist/bun/BunRoute.d.ts +3 -2
  77. package/dist/bun/BunRoute.js +5 -7
  78. package/dist/bun/BunRuntime.js +1 -1
  79. package/dist/bun/BunServer.d.ts +11 -4
  80. package/dist/bun/BunServer.js +35 -11
  81. package/dist/bun/BunSql.d.ts +4 -0
  82. package/dist/bun/BunSql.js +81 -0
  83. package/dist/bun/_BunEnhancedResolve.d.ts +3 -3
  84. package/dist/bun/_BunEnhancedResolve.js +2 -4
  85. package/dist/bun/index.d.ts +1 -0
  86. package/dist/bun/index.js +1 -0
  87. package/dist/bundler/Bundle.d.ts +2 -1
  88. package/dist/bundler/Bundle.js +1 -1
  89. package/dist/bundler/BundleFiles.d.ts +5 -5
  90. package/dist/bundler/BundleFiles.js +10 -8
  91. package/dist/bundler/BundleRoute.d.ts +27 -0
  92. package/dist/bundler/BundleRoute.js +51 -0
  93. package/dist/client/ScrollState.js +2 -6
  94. package/dist/client/index.js +6 -8
  95. package/dist/console/Console.d.ts +6 -0
  96. package/dist/console/Console.js +26 -0
  97. package/dist/console/ConsoleErrors.d.ts +3 -0
  98. package/dist/console/ConsoleErrors.js +200 -0
  99. package/dist/console/ConsoleLogger.d.ts +3 -0
  100. package/dist/console/ConsoleLogger.js +47 -0
  101. package/dist/console/ConsoleMetrics.d.ts +3 -0
  102. package/dist/console/ConsoleMetrics.js +61 -0
  103. package/dist/console/ConsoleProcess.d.ts +3 -0
  104. package/dist/console/ConsoleProcess.js +49 -0
  105. package/dist/console/ConsoleStore.d.ts +144 -0
  106. package/dist/console/ConsoleStore.js +61 -0
  107. package/dist/console/ConsoleTracer.d.ts +3 -0
  108. package/dist/console/ConsoleTracer.js +94 -0
  109. package/dist/console/Simulation.d.ts +2 -0
  110. package/dist/console/Simulation.js +633 -0
  111. package/dist/console/index.d.ts +3 -0
  112. package/dist/console/index.js +3 -0
  113. package/dist/console/routes/errors/route.d.ts +10 -0
  114. package/dist/console/routes/errors/route.js +47 -0
  115. package/dist/console/routes/fiberDetail.d.ts +16 -0
  116. package/dist/console/routes/fiberDetail.js +38 -0
  117. package/dist/console/routes/fibers/route.d.ts +10 -0
  118. package/dist/console/routes/fibers/route.js +19 -0
  119. package/dist/console/routes/git/route.d.ts +11 -0
  120. package/dist/console/routes/git/route.js +33 -0
  121. package/dist/console/routes/layout.d.ts +9 -0
  122. package/dist/console/routes/layout.js +3 -0
  123. package/dist/console/routes/logs/route.d.ts +10 -0
  124. package/dist/console/routes/logs/route.js +32 -0
  125. package/dist/console/routes/metrics/route.d.ts +10 -0
  126. package/dist/console/routes/metrics/route.js +17 -0
  127. package/dist/console/routes/route.d.ts +6 -0
  128. package/dist/console/routes/route.js +5 -0
  129. package/dist/console/routes/routes/route.d.ts +6 -0
  130. package/dist/console/routes/routes/route.js +20 -0
  131. package/dist/console/routes/services/route.d.ts +6 -0
  132. package/dist/console/routes/services/route.js +12 -0
  133. package/dist/console/routes/system/route.d.ts +10 -0
  134. package/dist/console/routes/system/route.js +18 -0
  135. package/dist/console/routes/traceDetail.d.ts +16 -0
  136. package/dist/console/routes/traceDetail.js +14 -0
  137. package/dist/console/routes/traces/route.d.ts +10 -0
  138. package/dist/console/routes/traces/route.js +39 -0
  139. package/dist/console/routes/tree.d.ts +153 -0
  140. package/dist/console/routes/tree.js +29 -0
  141. package/dist/console/ui/Errors.d.ts +4 -0
  142. package/dist/console/ui/Errors.js +15 -0
  143. package/dist/console/ui/Fibers.d.ts +24 -0
  144. package/dist/console/ui/Fibers.js +121 -0
  145. package/dist/console/ui/Git.d.ts +20 -0
  146. package/dist/console/ui/Git.js +95 -0
  147. package/dist/console/ui/Logs.d.ts +4 -0
  148. package/dist/console/ui/Logs.js +25 -0
  149. package/dist/console/ui/Metrics.d.ts +4 -0
  150. package/dist/console/ui/Metrics.js +26 -0
  151. package/dist/console/ui/Routes.d.ts +8 -0
  152. package/dist/console/ui/Routes.js +70 -0
  153. package/dist/console/ui/Services.d.ts +10 -0
  154. package/dist/console/ui/Services.js +246 -0
  155. package/dist/console/ui/Shell.d.ts +10 -0
  156. package/dist/console/ui/Shell.js +7 -0
  157. package/dist/console/ui/System.d.ts +4 -0
  158. package/dist/console/ui/System.js +35 -0
  159. package/dist/console/ui/Traces.d.ts +12 -0
  160. package/dist/console/ui/Traces.js +179 -0
  161. package/dist/datastar/actions/fetch.d.ts +1 -1
  162. package/dist/datastar/actions/fetch.js +10 -18
  163. package/dist/datastar/actions/peek.js +1 -2
  164. package/dist/datastar/actions/setAll.js +1 -2
  165. package/dist/datastar/actions/toggleAll.js +1 -2
  166. package/dist/datastar/attributes/attr.js +1 -2
  167. package/dist/datastar/attributes/bind.js +10 -18
  168. package/dist/datastar/attributes/class.js +2 -5
  169. package/dist/datastar/attributes/computed.js +2 -3
  170. package/dist/datastar/attributes/effect.js +1 -2
  171. package/dist/datastar/attributes/indicator.js +2 -4
  172. package/dist/datastar/attributes/init.js +2 -3
  173. package/dist/datastar/attributes/jsonSignals.js +1 -2
  174. package/dist/datastar/attributes/on.js +41 -22
  175. package/dist/datastar/attributes/onIntersect.js +2 -3
  176. package/dist/datastar/attributes/onInterval.js +2 -3
  177. package/dist/datastar/attributes/onSignalPatch.js +2 -4
  178. package/dist/datastar/attributes/ref.js +1 -2
  179. package/dist/datastar/attributes/show.js +1 -2
  180. package/dist/datastar/attributes/signals.js +1 -2
  181. package/dist/datastar/attributes/style.js +6 -12
  182. package/dist/datastar/attributes/text.js +1 -2
  183. package/dist/datastar/engine.d.ts +13 -7
  184. package/dist/datastar/engine.js +76 -48
  185. package/dist/datastar/happydom.d.ts +1 -0
  186. package/dist/datastar/happydom.js +8 -0
  187. package/dist/datastar/index.d.ts +1 -1
  188. package/dist/datastar/index.js +1 -1
  189. package/dist/datastar/utils.js +4 -7
  190. package/dist/datastar/watchers/patchElements.js +24 -45
  191. package/dist/datastar/watchers/patchSignals.js +1 -2
  192. package/dist/experimental/EncryptedCookies.d.ts +2 -5
  193. package/dist/experimental/EncryptedCookies.js +17 -48
  194. package/dist/experimental/index.d.ts +0 -1
  195. package/dist/experimental/index.js +0 -1
  196. package/dist/hyper/Hyper.d.ts +2 -9
  197. package/dist/hyper/Hyper.js +1 -12
  198. package/dist/hyper/HyperHtml.d.ts +1 -1
  199. package/dist/hyper/HyperHtml.js +18 -12
  200. package/dist/hyper/HyperHtml.test.d.ts +1 -0
  201. package/dist/hyper/HyperHtml.test.js +197 -0
  202. package/dist/hyper/HyperRoute.test.js +14 -3
  203. package/dist/hyper/html.d.ts +11 -0
  204. package/dist/hyper/html.js +30 -0
  205. package/dist/hyper/index.d.ts +2 -0
  206. package/dist/hyper/index.js +1 -0
  207. package/dist/hyper/jsx-runtime.d.ts +1 -1
  208. package/dist/hyper/jsx-runtime.js +1 -1
  209. package/dist/index.d.ts +1 -0
  210. package/dist/index.js +1 -0
  211. package/dist/lint/plugin.d.ts +86 -0
  212. package/dist/lint/plugin.js +341 -0
  213. package/dist/node/NodeFileSystem.d.ts +2 -2
  214. package/dist/node/NodeFileSystem.js +4 -14
  215. package/dist/sql/bun/index.d.ts +3 -0
  216. package/dist/sql/bun/index.js +75 -0
  217. package/dist/sql/mssql/docker.d.ts +2 -0
  218. package/dist/sql/mssql/docker.js +67 -0
  219. package/dist/sql/mssql/index.d.ts +21 -0
  220. package/dist/sql/mssql/index.js +113 -0
  221. package/dist/testing/TestLogger.js +4 -1
  222. package/dist/testing/index.d.ts +0 -1
  223. package/dist/testing/index.js +0 -1
  224. package/dist/testing/utils.d.ts +3 -3
  225. package/dist/testing/utils.js +4 -4
  226. package/dist/x/cloudflare/CloudflareTunnel.d.ts +2 -5
  227. package/dist/x/cloudflare/CloudflareTunnel.js +14 -27
  228. package/dist/x/datastar/Datastar.d.ts +1 -1
  229. package/dist/x/datastar/Datastar.js +13 -12
  230. package/dist/x/datastar/index.d.ts +1 -2
  231. package/dist/x/datastar/index.js +1 -2
  232. package/dist/x/tailscale/TailscaleTunnel.d.ts +15 -0
  233. package/dist/x/tailscale/TailscaleTunnel.js +68 -0
  234. package/dist/x/tailscale/index.d.ts +1 -0
  235. package/dist/x/tailscale/index.js +1 -0
  236. package/dist/x/tailwind/TailwindPlugin.js +19 -19
  237. package/dist/x/tailwind/compile.d.ts +2 -2
  238. package/dist/x/tailwind/compile.js +2 -4
  239. package/package.json +22 -10
  240. package/src/ChildProcess.ts +145 -0
  241. package/src/PlatformError.ts +27 -50
  242. package/src/Route.ts +2 -2
  243. package/src/RouteError.ts +76 -0
  244. package/src/RouteHttp.ts +13 -5
  245. package/src/RouteSchema.ts +96 -1
  246. package/src/RouteTree.ts +12 -0
  247. package/src/Sql.ts +51 -0
  248. package/src/SqlIntrospect.ts +620 -0
  249. package/src/Start.ts +15 -3
  250. package/src/System.ts +43 -0
  251. package/src/Values.ts +7 -0
  252. package/src/bun/BunChildProcessSpawner.ts +143 -0
  253. package/src/bun/BunRoute.ts +5 -2
  254. package/src/bun/BunServer.ts +22 -1
  255. package/src/bun/index.ts +1 -0
  256. package/src/bundler/BundleRoute.ts +66 -0
  257. package/src/console/Console.ts +42 -0
  258. package/src/console/ConsoleErrors.ts +213 -0
  259. package/src/console/ConsoleLogger.ts +56 -0
  260. package/src/console/ConsoleMetrics.ts +72 -0
  261. package/src/console/ConsoleProcess.ts +59 -0
  262. package/src/console/ConsoleStore.ts +187 -0
  263. package/src/console/ConsoleTracer.ts +107 -0
  264. package/src/console/Simulation.ts +814 -0
  265. package/src/console/console.html +340 -0
  266. package/src/console/index.ts +3 -0
  267. package/src/console/routes/errors/route.tsx +97 -0
  268. package/src/console/routes/fiberDetail.tsx +54 -0
  269. package/src/console/routes/fibers/route.tsx +45 -0
  270. package/src/console/routes/git/route.tsx +64 -0
  271. package/src/console/routes/layout.tsx +4 -0
  272. package/src/console/routes/logs/route.tsx +77 -0
  273. package/src/console/routes/metrics/route.tsx +36 -0
  274. package/src/console/routes/route.tsx +8 -0
  275. package/src/console/routes/routes/route.tsx +30 -0
  276. package/src/console/routes/services/route.tsx +21 -0
  277. package/src/console/routes/system/route.tsx +43 -0
  278. package/src/console/routes/traceDetail.tsx +22 -0
  279. package/src/console/routes/traces/route.tsx +81 -0
  280. package/src/console/routes/tree.ts +30 -0
  281. package/src/console/ui/Errors.tsx +76 -0
  282. package/src/console/ui/Fibers.tsx +321 -0
  283. package/src/console/ui/Git.tsx +182 -0
  284. package/src/console/ui/Logs.tsx +46 -0
  285. package/src/console/ui/Metrics.tsx +78 -0
  286. package/src/console/ui/Routes.tsx +125 -0
  287. package/src/console/ui/Services.tsx +273 -0
  288. package/src/console/ui/Shell.tsx +62 -0
  289. package/src/console/ui/System.tsx +131 -0
  290. package/src/console/ui/Traces.tsx +426 -0
  291. package/src/datastar/README.md +6 -1
  292. package/src/datastar/actions/fetch.ts +0 -1
  293. package/src/datastar/attributes/on.ts +40 -20
  294. package/src/datastar/engine.ts +51 -0
  295. package/src/datastar/jsx.d.ts +79 -0
  296. package/src/hyper/Hyper.ts +1 -16
  297. package/src/hyper/HyperHtml.ts +6 -4
  298. package/src/hyper/HyperRoute.ts +2 -1
  299. package/src/hyper/html.ts +47 -0
  300. package/src/hyper/index.ts +2 -0
  301. package/src/hyper/jsx.d.ts +5 -3
  302. package/src/index.ts +1 -0
  303. package/src/lint/plugin.js +129 -0
  304. package/src/sql/bun/index.ts +147 -0
  305. package/src/sql/mssql/docker.ts +117 -0
  306. package/src/sql/mssql/index.ts +223 -0
  307. package/src/sql/mssql/mssql.d.ts +41 -0
  308. package/src/x/cloudflare/CloudflareTunnel.ts +8 -36
  309. package/src/x/tailscale/TailscaleTunnel.ts +113 -0
  310. package/src/x/tailscale/index.ts +1 -0
  311. package/src/x/datastar/Datastar.ts +0 -61
  312. package/src/x/datastar/index.ts +0 -2
  313. package/src/x/datastar/jsx-datastar.d.ts +0 -60
@@ -0,0 +1,246 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "effect-start/jsx-runtime";
2
+ import * as Option from "effect/Option";
3
+ const EffectTypeIds = {
4
+ [Symbol.for("effect/Ref")]: "Ref",
5
+ [Symbol.for("effect/SynchronizedRef")]: "SynchronizedRef",
6
+ [Symbol.for("effect/QueueDequeue")]: "Dequeue",
7
+ [Symbol.for("effect/QueueEnqueue")]: "Enqueue",
8
+ [Symbol.for("effect/Pool")]: "Pool",
9
+ [Symbol.for("effect/Deferred")]: "Deferred",
10
+ [Symbol.for("effect/FiberRef")]: "FiberRef",
11
+ [Symbol.for("effect/Scope")]: "Scope",
12
+ [Symbol.for("effect/Tracer")]: "Tracer",
13
+ [Symbol.for("effect/Request/Cache")]: "RequestCache",
14
+ [Symbol.for("effect/Logger")]: "Logger",
15
+ [Symbol.for("effect/Supervisor")]: "Supervisor",
16
+ [Symbol.for("effect/Clock")]: "Clock",
17
+ [Symbol.for("effect/Random")]: "Random",
18
+ [Symbol.for("effect/KeyValueStore")]: "KeyValueStore",
19
+ [Symbol.for("effect/RateLimiter")]: "RateLimiter",
20
+ };
21
+ function detectEffectType(value) {
22
+ if (value === null || value === undefined || typeof value !== "object")
23
+ return undefined;
24
+ if ("publish" in value && "subscribe" in value && "offer" in value)
25
+ return "PubSub";
26
+ for (const sym of Object.getOwnPropertySymbols(value)) {
27
+ const name = EffectTypeIds[sym];
28
+ if (name)
29
+ return name;
30
+ }
31
+ return undefined;
32
+ }
33
+ function inspectEffectValue(type, value) {
34
+ const info = { _type: type };
35
+ try {
36
+ switch (type) {
37
+ case "PubSub": {
38
+ if (typeof value.capacity === "function")
39
+ info.capacity = value.capacity();
40
+ if (typeof value.isActive === "function")
41
+ info.active = value.isActive();
42
+ if (typeof value.unsafeSize === "function") {
43
+ const size = value.unsafeSize();
44
+ info.size = Option.isSome(size) ? size.value : "shutdown";
45
+ }
46
+ if (value.pubsub && typeof value.pubsub.subscriberCount === "number") {
47
+ info.subscribers = value.pubsub.subscriberCount;
48
+ }
49
+ break;
50
+ }
51
+ case "Enqueue":
52
+ case "Dequeue": {
53
+ if (typeof value.capacity === "function")
54
+ info.capacity = value.capacity();
55
+ if (typeof value.isActive === "function")
56
+ info.active = value.isActive();
57
+ if (typeof value.unsafeSize === "function") {
58
+ const size = value.unsafeSize();
59
+ info.size = Option.isSome(size) ? size.value : "shutdown";
60
+ }
61
+ break;
62
+ }
63
+ case "Ref":
64
+ case "SynchronizedRef": {
65
+ if (value.ref && "current" in value.ref) {
66
+ const current = value.ref.current;
67
+ info.value = safeSerialize(current);
68
+ }
69
+ break;
70
+ }
71
+ case "Pool": {
72
+ if (typeof value.minSize === "number")
73
+ info.minSize = value.minSize;
74
+ if (typeof value.maxSize === "number")
75
+ info.maxSize = value.maxSize;
76
+ if (typeof value.concurrency === "number")
77
+ info.concurrency = value.concurrency;
78
+ if (value.items instanceof Set)
79
+ info.items = value.items.size;
80
+ if (value.available instanceof Set)
81
+ info.available = value.available.size;
82
+ if (value.invalidated instanceof Set)
83
+ info.invalidated = value.invalidated.size;
84
+ if (typeof value.waiters === "number")
85
+ info.waiters = value.waiters;
86
+ break;
87
+ }
88
+ case "FiberRef": {
89
+ if ("initial" in value)
90
+ info.initial = safeSerialize(value.initial);
91
+ break;
92
+ }
93
+ case "Deferred": {
94
+ if ("state" in value && value.state) {
95
+ const state = value.state;
96
+ if (typeof state === "object" && "_tag" in state) {
97
+ info.status = state._tag;
98
+ }
99
+ }
100
+ break;
101
+ }
102
+ }
103
+ }
104
+ catch {
105
+ // ignore introspection errors
106
+ }
107
+ return info;
108
+ }
109
+ function safeSerialize(value) {
110
+ if (value === null || value === undefined)
111
+ return value;
112
+ if (typeof value === "bigint")
113
+ return `${value}n`;
114
+ if (typeof value === "function")
115
+ return "<function>";
116
+ if (typeof value === "symbol")
117
+ return value.toString();
118
+ if (typeof value !== "object")
119
+ return value;
120
+ if (detectEffectType(value))
121
+ return `<${detectEffectType(value)}>`;
122
+ if (Array.isArray(value))
123
+ return value.map(safeSerialize);
124
+ const proto = Object.getPrototypeOf(value);
125
+ if (proto !== null && proto !== Object.prototype)
126
+ return `<${proto.constructor?.name ?? "object"}>`;
127
+ const out = {};
128
+ for (const [k, v] of Object.entries(value)) {
129
+ if (typeof v === "function")
130
+ continue;
131
+ out[k] = safeSerialize(v);
132
+ }
133
+ return out;
134
+ }
135
+ function isJsonPrimitive(value) {
136
+ if (value === null)
137
+ return true;
138
+ const t = typeof value;
139
+ return t === "string" || t === "number" || t === "boolean" || t === "bigint";
140
+ }
141
+ function isPlainJson(value) {
142
+ if (isJsonPrimitive(value))
143
+ return true;
144
+ if (Array.isArray(value))
145
+ return value.every(isPlainJson);
146
+ if (typeof value === "object" && value !== null) {
147
+ const proto = Object.getPrototypeOf(value);
148
+ if (proto !== null && proto !== Object.prototype)
149
+ return false;
150
+ return Object.values(value).every(isPlainJson);
151
+ }
152
+ return false;
153
+ }
154
+ function jsonReplacer(_key, v) {
155
+ if (typeof v === "bigint")
156
+ return `${v}n`;
157
+ return v;
158
+ }
159
+ function collectDisplayValues(obj, prefix, out) {
160
+ if (typeof obj === "function")
161
+ return;
162
+ if (isJsonPrimitive(obj) || Array.isArray(obj)) {
163
+ out[prefix] = safeSerialize(obj);
164
+ return;
165
+ }
166
+ if (typeof obj === "object" && obj !== null) {
167
+ const et = detectEffectType(obj);
168
+ if (et) {
169
+ out[prefix || et] = inspectEffectValue(et, obj);
170
+ return;
171
+ }
172
+ for (const [k, v] of Object.entries(obj)) {
173
+ if (typeof v === "function")
174
+ continue;
175
+ const path = prefix ? `${prefix}.${k}` : k;
176
+ if (isPlainJson(v)) {
177
+ out[path] = safeSerialize(v);
178
+ }
179
+ else if (typeof v === "object" && v !== null) {
180
+ collectDisplayValues(v, path, out);
181
+ }
182
+ }
183
+ }
184
+ }
185
+ function kindColor(kind) {
186
+ if (kind === "config")
187
+ return { bg: "#2d1f0e", fg: "#fbbf24" };
188
+ if (kind === "effect")
189
+ return { bg: "#2d1a3e", fg: "#c084fc" };
190
+ if (kind === "empty")
191
+ return { bg: "#1f2937", fg: "#64748b" };
192
+ if (kind === "function")
193
+ return { bg: "#1a2e1a", fg: "#4ade80" };
194
+ return { bg: "#1e3a5f", fg: "#60a5fa" };
195
+ }
196
+ function ServiceRow({ entry }) {
197
+ const colors = kindColor(entry.type);
198
+ return (_jsxs("details", { class: "tl-row", children: [_jsxs("summary", { class: "tl-summary tl-cols", children: [_jsx("span", { class: "tl-cell tl-cell-status", children: _jsx("span", { style: `width:8px;height:8px;border-radius:50%;background:${colors.fg};display:block` }) }), _jsx("span", { class: "tl-cell tl-cell-name", children: entry.key }), _jsx("span", { class: "tl-cell tl-cell-dur", children: _jsx("span", { style: `font-size:10px;padding:1px 6px;border-radius:4px;background:${colors.bg};color:${colors.fg}`, children: entry.kind }) })] }), _jsx("div", { class: "tl-body", children: entry.display ? (_jsx("pre", { style: "color:#e2e8f0;font-family:monospace;font-size:12px;margin:0;padding:8px;white-space:pre-wrap;word-break:break-all", children: entry.display })) : (_jsx("div", { style: "padding:4px 8px;color:#64748b;font-size:12px", children: "No inspectable values" })) })] }));
199
+ }
200
+ export function ServiceList({ services }) {
201
+ if (services.length === 0) {
202
+ return _jsx("div", { class: "empty", children: "No services registered" });
203
+ }
204
+ return (_jsxs("div", { class: "tl-grid", children: [_jsxs("div", { class: "tl-header tl-cols", children: [_jsx("span", { class: "tl-cell tl-cell-status" }), _jsx("span", { class: "tl-cell tl-cell-name", children: "Service" }), _jsx("span", { class: "tl-cell tl-cell-dur", children: "Kind" })] }), services.map((s) => (_jsx(ServiceRow, { entry: s })))] }));
205
+ }
206
+ export function collectServices(unsafeMap) {
207
+ const entries = [];
208
+ for (const [key, value] of unsafeMap) {
209
+ const isConfig = key.toLowerCase().includes("config") || key.toLowerCase().includes("configuration");
210
+ const effectType = typeof value === "object" && value !== null ? detectEffectType(value) : undefined;
211
+ if (effectType) {
212
+ const info = inspectEffectValue(effectType, value);
213
+ entries.push({
214
+ key,
215
+ kind: effectType,
216
+ display: JSON.stringify(info, jsonReplacer, 2),
217
+ type: "effect",
218
+ });
219
+ continue;
220
+ }
221
+ if (typeof value === "function") {
222
+ entries.push({ key, kind: "function", display: "", type: "value" });
223
+ continue;
224
+ }
225
+ if (value === null || value === undefined) {
226
+ entries.push({ key, kind: "empty", display: "", type: "value" });
227
+ continue;
228
+ }
229
+ const type = isConfig ? "config" : "value";
230
+ const plain = {};
231
+ collectDisplayValues(value, "", plain);
232
+ const display = Object.keys(plain).length > 0 ? JSON.stringify(plain, jsonReplacer, 2) : "";
233
+ let kind = "object";
234
+ if (typeof value !== "object") {
235
+ kind = typeof value;
236
+ }
237
+ else {
238
+ const proto = Object.getPrototypeOf(value);
239
+ if (proto && proto.constructor && proto.constructor.name !== "Object") {
240
+ kind = proto.constructor.name;
241
+ }
242
+ }
243
+ entries.push({ key, kind: isConfig ? "config" : kind, display, type });
244
+ }
245
+ return entries.sort((a, b) => a.key.localeCompare(b.key));
246
+ }
@@ -0,0 +1,10 @@
1
+ export type NavTab = "traces" | "metrics" | "logs" | "errors" | "fibers" | "routes" | "system" | "services" | "git";
2
+ export declare function Sidebar({ prefix, active }: {
3
+ prefix: string;
4
+ active: NavTab;
5
+ }): import("../../hyper/HyperNode").HyperNode;
6
+ export declare function Shell({ prefix, active, children, }: {
7
+ prefix: string;
8
+ active: NavTab;
9
+ children: any;
10
+ }): import("../../hyper/HyperNode").HyperNode;
@@ -0,0 +1,7 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "effect-start/jsx-runtime";
2
+ export function Sidebar({ prefix, active }) {
3
+ return (_jsxs("div", { class: "sidebar", children: [_jsx("div", { class: "sidebar-title", children: "Effect Console" }), _jsx("a", { href: `${prefix}/traces`, class: active === "traces" ? "nav-link active" : "nav-link", children: "Traces" }), _jsx("a", { href: `${prefix}/metrics`, class: active === "metrics" ? "nav-link active" : "nav-link", children: "Metrics" }), _jsx("a", { href: `${prefix}/logs`, class: active === "logs" ? "nav-link active" : "nav-link", children: "Logs" }), _jsx("a", { href: `${prefix}/errors`, class: active === "errors" ? "nav-link active" : "nav-link", children: "Errors" }), _jsx("a", { href: `${prefix}/fibers`, class: active === "fibers" ? "nav-link active" : "nav-link", children: "Fibers" }), _jsx("a", { href: `${prefix}/routes`, class: active === "routes" ? "nav-link active" : "nav-link", children: "Routes" }), _jsx("a", { href: `${prefix}/system`, class: active === "system" ? "nav-link active" : "nav-link", children: "System" }), _jsx("a", { href: `${prefix}/services`, class: active === "services" ? "nav-link active" : "nav-link", children: "Services" }), _jsx("a", { href: `${prefix}/git`, class: active === "git" ? "nav-link active" : "nav-link", children: "Git" })] }));
4
+ }
5
+ export function Shell({ prefix, active, children, }) {
6
+ return (_jsxs("div", { class: "shell", children: [_jsx(Sidebar, { prefix: prefix, active: active }), _jsx("div", { class: "content", children: children })] }));
7
+ }
@@ -0,0 +1,4 @@
1
+ import type * as ConsoleStore from "../ConsoleStore.ts";
2
+ export declare function SystemStatsView({ stats }: {
3
+ stats: ConsoleStore.ProcessStats;
4
+ }): import("../../hyper/HyperNode.ts").HyperNode;
@@ -0,0 +1,35 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "effect-start/jsx-runtime";
2
+ function formatBytes(bytes) {
3
+ if (bytes < 1024)
4
+ return `${bytes}B`;
5
+ if (bytes < 1024 * 1024)
6
+ return `${(bytes / 1024).toFixed(1)}KB`;
7
+ if (bytes < 1024 * 1024 * 1024)
8
+ return `${(bytes / 1024 / 1024).toFixed(1)}MB`;
9
+ return `${(bytes / 1024 / 1024 / 1024).toFixed(2)}GB`;
10
+ }
11
+ function formatUptime(seconds) {
12
+ const d = Math.floor(seconds / 86400);
13
+ const h = Math.floor((seconds % 86400) / 3600);
14
+ const m = Math.floor((seconds % 3600) / 60);
15
+ const s = Math.floor(seconds % 60);
16
+ if (d > 0)
17
+ return `${d}d ${h}h ${m}m`;
18
+ if (h > 0)
19
+ return `${h}h ${m}m ${s}s`;
20
+ if (m > 0)
21
+ return `${m}m ${s}s`;
22
+ return `${s}s`;
23
+ }
24
+ function StatCard({ label, value, sub }) {
25
+ return (_jsxs("div", { style: "background:#111827;border:1px solid #374151;border-radius:6px;padding:12px;min-width:180px", children: [_jsx("div", { style: "color:#9ca3af;font-size:11px;margin-bottom:4px", children: label }), _jsx("div", { style: "color:#f3f4f6;font-size:22px;font-weight:700;font-family:monospace", children: value }), sub && _jsx("div", { style: "color:#6b7280;font-size:10px;margin-top:2px", children: sub })] }));
26
+ }
27
+ function BarMeter({ label, used, total }) {
28
+ const pct = total > 0 ? (used / total) * 100 : 0;
29
+ const color = pct > 90 ? "#ef4444" : pct > 70 ? "#f59e0b" : "#22c55e";
30
+ return (_jsxs("div", { style: "background:#111827;border:1px solid #374151;border-radius:6px;padding:12px", children: [_jsxs("div", { style: "display:flex;justify-content:space-between;margin-bottom:6px", children: [_jsx("span", { style: "color:#9ca3af;font-size:11px", children: label }), _jsxs("span", { style: "color:#e5e7eb;font-size:11px;font-family:monospace", children: [formatBytes(used), " / ", formatBytes(total)] })] }), _jsx("div", { style: "height:8px;background:#1f2937;border-radius:4px;overflow:hidden", children: _jsx("div", { style: `width:${pct.toFixed(1)}%;height:100%;background:${color};border-radius:4px;transition:width .3s` }) }), _jsxs("div", { style: "color:#6b7280;font-size:10px;margin-top:2px;text-align:right", children: [pct.toFixed(1), "%"] })] }));
31
+ }
32
+ export function SystemStatsView({ stats }) {
33
+ const cpuTotal = stats.cpu.user + stats.cpu.system;
34
+ return (_jsxs(_Fragment, { children: [_jsxs("div", { style: "display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;padding:12px", children: [_jsx(StatCard, { label: "PID", value: String(stats.pid), sub: `${stats.system.platform} ${stats.system.arch}` }), _jsx(StatCard, { label: "Uptime", value: formatUptime(stats.uptime) }), _jsx(StatCard, { label: "CPU Time", value: `${(cpuTotal / 1_000_000).toFixed(2)}s`, sub: `user ${(stats.cpu.user / 1_000_000).toFixed(2)}s / sys ${(stats.cpu.system / 1_000_000).toFixed(2)}s` }), _jsx(StatCard, { label: "Load Average", value: stats.system.loadavg[0].toFixed(2), sub: `${stats.system.loadavg[0].toFixed(2)} / ${stats.system.loadavg[1].toFixed(2)} / ${stats.system.loadavg[2].toFixed(2)} (${stats.system.cpuCount} cores)` })] }), _jsxs("div", { style: "display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;padding:0 12px 12px", children: [_jsx(BarMeter, { label: "Heap Memory", used: stats.memory.heapUsed, total: stats.memory.heapTotal }), _jsx(BarMeter, { label: "System Memory", used: stats.system.totalmem - stats.system.freemem, total: stats.system.totalmem })] }), _jsxs("div", { style: "display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;padding:0 12px 12px", children: [_jsx(StatCard, { label: "RSS", value: formatBytes(stats.memory.rss) }), _jsx(StatCard, { label: "Peak RSS", value: formatBytes(stats.resourceUsage.maxRSS) }), _jsx(StatCard, { label: "External", value: formatBytes(stats.memory.external) }), _jsx(StatCard, { label: "Array Buffers", value: formatBytes(stats.memory.arrayBuffers) })] }), _jsx("div", { style: "padding:0 12px 12px", children: _jsxs("div", { style: "background:#111827;border:1px solid #374151;border-radius:6px;padding:12px", children: [_jsx("div", { style: "color:#9ca3af;font-size:11px;margin-bottom:8px", children: "Resource Usage" }), _jsxs("div", { style: "display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:4px", children: [_jsxs("div", { style: "display:flex;justify-content:space-between;font-size:12px", children: [_jsx("span", { style: "color:#6b7280", children: "Page Faults (minor)" }), _jsx("span", { style: "color:#e5e7eb;font-family:monospace", children: stats.resourceUsage.minorPageFault })] }), _jsxs("div", { style: "display:flex;justify-content:space-between;font-size:12px", children: [_jsx("span", { style: "color:#6b7280", children: "Page Faults (major)" }), _jsx("span", { style: "color:#e5e7eb;font-family:monospace", children: stats.resourceUsage.majorPageFault })] }), _jsxs("div", { style: "display:flex;justify-content:space-between;font-size:12px", children: [_jsx("span", { style: "color:#6b7280", children: "FS Reads" }), _jsx("span", { style: "color:#e5e7eb;font-family:monospace", children: stats.resourceUsage.fsRead })] }), _jsxs("div", { style: "display:flex;justify-content:space-between;font-size:12px", children: [_jsx("span", { style: "color:#6b7280", children: "FS Writes" }), _jsx("span", { style: "color:#e5e7eb;font-family:monospace", children: stats.resourceUsage.fsWrite })] }), _jsxs("div", { style: "display:flex;justify-content:space-between;font-size:12px", children: [_jsx("span", { style: "color:#6b7280", children: "Context Switches (vol)" }), _jsx("span", { style: "color:#e5e7eb;font-family:monospace", children: stats.resourceUsage.voluntaryContextSwitches })] }), _jsxs("div", { style: "display:flex;justify-content:space-between;font-size:12px", children: [_jsx("span", { style: "color:#6b7280", children: "Context Switches (invol)" }), _jsx("span", { style: "color:#e5e7eb;font-family:monospace", children: stats.resourceUsage.involuntaryContextSwitches })] })] })] }) })] }));
35
+ }
@@ -0,0 +1,12 @@
1
+ import * as ConsoleStore from "../ConsoleStore.ts";
2
+ export declare function groupByTraceId(spans: Array<ConsoleStore.ConsoleSpan>): Map<string, Array<ConsoleStore.ConsoleSpan>>;
3
+ export declare function TraceGroup({ spans }: {
4
+ spans: Array<ConsoleStore.ConsoleSpan>;
5
+ }): import("../../hyper/HyperNode.ts").HyperNode | null;
6
+ export declare function TraceGroups({ spans }: {
7
+ spans: Array<ConsoleStore.ConsoleSpan>;
8
+ }): import("../../hyper/HyperNode.ts").HyperNode;
9
+ export declare function TraceDetail({ prefix, spans, }: {
10
+ prefix: string;
11
+ spans: Array<ConsoleStore.ConsoleSpan>;
12
+ }): import("../../hyper/HyperNode.ts").HyperNode;
@@ -0,0 +1,179 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "effect-start/jsx-runtime";
2
+ import * as ConsoleStore from "../ConsoleStore.js";
3
+ function formatDuration(ms) {
4
+ if (ms == null)
5
+ return "...";
6
+ if (ms < 1)
7
+ return `${(ms * 1000).toFixed(0)}µs`;
8
+ if (ms < 1000)
9
+ return `${ms.toFixed(1)}ms`;
10
+ return `${(ms / 1000).toFixed(2)}s`;
11
+ }
12
+ function statusColor(status) {
13
+ if (status === "ok")
14
+ return "#22c55e";
15
+ if (status === "error")
16
+ return "#ef4444";
17
+ return "#eab308";
18
+ }
19
+ function KeyValue({ label, value }) {
20
+ if (value == null)
21
+ return null;
22
+ return (_jsxs("div", { style: "display:flex;gap:8px;padding:4px 0;border-bottom:1px solid #1e293b;font-size:12px", children: [_jsx("span", { style: "color:#64748b;min-width:120px", children: label }), _jsx("span", { style: "color:#e2e8f0;font-family:monospace;word-break:break-all", children: value })] }));
23
+ }
24
+ function StatusBadge({ status }) {
25
+ const bg = status === "ok" ? "#166534" : status === "error" ? "#7f1d1d" : "#713f12";
26
+ const fg = status === "ok" ? "#4ade80" : status === "error" ? "#fca5a5" : "#fde047";
27
+ return (_jsx("span", { style: `font-size:11px;padding:2px 8px;border-radius:4px;background:${bg};color:${fg}`, children: status }));
28
+ }
29
+ function buildSpanTree(spans) {
30
+ const byId = new Map();
31
+ const childrenOf = new Map();
32
+ for (const s of spans) {
33
+ byId.set(s.spanId, s);
34
+ }
35
+ const roots = [];
36
+ for (const s of spans) {
37
+ if (s.parentSpanId && byId.has(s.parentSpanId)) {
38
+ let children = childrenOf.get(s.parentSpanId);
39
+ if (!children) {
40
+ children = [];
41
+ childrenOf.set(s.parentSpanId, children);
42
+ }
43
+ children.push(s);
44
+ }
45
+ else {
46
+ roots.push(s);
47
+ }
48
+ }
49
+ const sortByStart = (a, b) => Number(a.startTime - b.startTime);
50
+ roots.sort(sortByStart);
51
+ for (const children of childrenOf.values()) {
52
+ children.sort(sortByStart);
53
+ }
54
+ const result = [];
55
+ function walk(span, depth, isLast, ancestors) {
56
+ const children = childrenOf.get(span.spanId) ?? [];
57
+ result.push({
58
+ span,
59
+ depth,
60
+ childCount: children.length,
61
+ isLastChild: isLast,
62
+ ancestorHasNextSibling: [...ancestors],
63
+ });
64
+ for (let i = 0; i < children.length; i++) {
65
+ walk(children[i], depth + 1, i === children.length - 1, [...ancestors, !isLast]);
66
+ }
67
+ }
68
+ for (let i = 0; i < roots.length; i++) {
69
+ walk(roots[i], 0, i === roots.length - 1, []);
70
+ }
71
+ return result;
72
+ }
73
+ // --- Components ---
74
+ function TreeConnectors({ tree }) {
75
+ if (tree.depth === 0)
76
+ return null;
77
+ const indent = tree.depth * 20;
78
+ const elements = [];
79
+ for (let i = 0; i < tree.ancestorHasNextSibling.length; i++) {
80
+ if (tree.ancestorHasNextSibling[i]) {
81
+ elements.push(_jsx("div", { class: "wf-vline", style: `left:${i * 20 + 6}px` }));
82
+ }
83
+ }
84
+ if (tree.isLastChild) {
85
+ elements.push(_jsx("div", { class: "wf-elbow", style: `left:${(tree.depth - 1) * 20 + 6}px` }));
86
+ }
87
+ else {
88
+ elements.push(_jsx("div", { class: "wf-vline", style: `left:${(tree.depth - 1) * 20 + 6}px` }));
89
+ }
90
+ elements.push(_jsx("div", { class: "wf-hline", style: `left:${(tree.depth - 1) * 20 + 6}px;top:50%` }));
91
+ return (_jsx("div", { class: "wf-tree", style: `width:${indent}px;position:relative`, children: elements }));
92
+ }
93
+ function TimeAxis({ totalMs }) {
94
+ const ticks = 5;
95
+ const labels = [];
96
+ for (let i = 0; i <= ticks; i++) {
97
+ labels.push(formatDuration((totalMs / ticks) * i));
98
+ }
99
+ return (_jsxs("div", { class: "wf-axis", children: [_jsx("div", { style: "padding:4px 8px;color:#64748b;font-size:11px", children: "Span" }), _jsx("div", { class: "wf-axis-ticks", children: labels.map((l) => (_jsx("span", { children: l }))) })] }));
100
+ }
101
+ function WaterfallRow({ tree, totalMs, rootStart, }) {
102
+ const s = tree.span;
103
+ const offsetMs = Number(s.startTime - rootStart) / 1_000_000;
104
+ const durMs = s.durationMs ?? 0;
105
+ const leftPct = totalMs > 0 ? Math.min(100, (offsetMs / totalMs) * 100) : 0;
106
+ const widthPct = totalMs > 0 ? Math.max(0.5, Math.min(100 - leftPct, (durMs / totalMs) * 100)) : 100;
107
+ const color = statusColor(s.status);
108
+ const durLabelLeft = leftPct + widthPct + 0.5;
109
+ return (_jsxs("div", { class: "wf-row", children: [_jsxs("div", { class: "wf-name", children: [_jsx(TreeConnectors, { tree: tree }), _jsx("span", { style: "overflow:hidden;text-overflow:ellipsis", children: s.name }), tree.childCount > 0 && _jsx("span", { class: "wf-badge", children: tree.childCount })] }), _jsxs("div", { class: "wf-bar-cell", children: [_jsx("div", { class: "wf-bar", style: `left:${leftPct}%;width:${widthPct}%;background:${color}` }), _jsx("div", { class: "wf-dur", style: `left:${durLabelLeft}%`, children: formatDuration(s.durationMs) })] })] }));
110
+ }
111
+ function MiniWaterfall({ spans, totalMs, rootStart, }) {
112
+ if (totalMs <= 0)
113
+ return _jsx("div", { class: "mini-wf" });
114
+ return (_jsx("div", { class: "mini-wf", children: spans.map((s) => {
115
+ const offsetMs = Number(s.startTime - rootStart) / 1_000_000;
116
+ const durMs = s.durationMs ?? 0;
117
+ const leftPct = Math.min(100, (offsetMs / totalMs) * 100);
118
+ const widthPct = Math.max(0.3, Math.min(100 - leftPct, (durMs / totalMs) * 100));
119
+ return (_jsx("div", { class: "mini-wf-bar", style: `left:${leftPct}%;width:${widthPct}%;background:${statusColor(s.status)}` }));
120
+ }) }));
121
+ }
122
+ // --- Exports ---
123
+ export function groupByTraceId(spans) {
124
+ const groups = new Map();
125
+ for (const span of spans) {
126
+ let group = groups.get(span.traceId);
127
+ if (!group) {
128
+ group = [];
129
+ groups.set(span.traceId, group);
130
+ }
131
+ group.push(span);
132
+ }
133
+ return groups;
134
+ }
135
+ export function TraceGroup({ spans }) {
136
+ if (spans.length === 0)
137
+ return null;
138
+ const root = spans.find((s) => !s.parentSpanId) ?? spans[0];
139
+ const traceId = root.traceId;
140
+ const totalMs = root.durationMs ?? 0;
141
+ const rootStart = root.startTime;
142
+ const hasError = spans.some((s) => s.status === "error");
143
+ const status = hasError ? "error" : root.status;
144
+ return (_jsxs("details", { class: "tl-row", children: [_jsxs("summary", { class: "tl-summary tl-cols", children: [_jsx("span", { class: "tl-cell tl-cell-status", children: _jsx("span", { style: `width:8px;height:8px;border-radius:50%;background:${statusColor(status)};display:block` }) }), _jsx("span", { class: "tl-cell tl-cell-name", children: root.name }), _jsx("span", { class: "tl-cell tl-cell-spans", children: spans.length }), _jsx("span", { class: "tl-cell tl-cell-dur", children: formatDuration(totalMs) }), _jsx("span", { class: "tl-cell tl-cell-id", children: traceId.slice(0, 12) })] }), _jsxs("div", { class: "tl-body", children: [_jsxs("div", { style: "display:flex;gap:12px;align-items:center;margin-bottom:8px", children: [_jsx("a", { href: `${ConsoleStore.store.prefix}/traces/${traceId}`, style: "color:#38bdf8;font-size:12px;text-decoration:none", children: "Full trace view" }), _jsx(StatusBadge, { status: status }), _jsxs("span", { style: "color:#64748b;font-size:11px", children: [spans.length, " span", spans.length !== 1 ? "s" : ""] }), _jsx("span", { style: "color:#64748b;font-size:11px;font-family:monospace", children: formatDuration(totalMs) }), _jsx("span", { style: "color:#475569;font-size:10px;font-family:monospace", children: traceId })] }), spans.map((s) => {
145
+ const offsetMs = Number(s.startTime - rootStart) / 1_000_000;
146
+ const leftPct = totalMs > 0 ? Math.min(100, (offsetMs / totalMs) * 100) : 0;
147
+ const widthPct = totalMs > 0
148
+ ? Math.max(0.5, Math.min(100 - leftPct, ((s.durationMs ?? 0) / totalMs) * 100))
149
+ : 100;
150
+ return (_jsxs("div", { style: "display:flex;align-items:center;gap:8px;padding:2px 0;font-size:11px;font-family:monospace", children: [_jsx("span", { style: `color:${statusColor(s.status)};min-width:10px`, children: s.parentSpanId ? " " : "" }), _jsx("span", { style: "color:#d1d5db;min-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap", children: s.name }), _jsx("div", { style: "flex:1;height:10px;background:#1f2937;border-radius:2px;position:relative;overflow:hidden", children: _jsx("div", { style: `position:absolute;height:100%;border-radius:2px;background:${statusColor(s.status)};left:${leftPct}%;width:${widthPct}%` }) }), _jsx("span", { style: "color:#9ca3af;min-width:60px;text-align:right", children: formatDuration(s.durationMs) })] }));
151
+ })] })] }));
152
+ }
153
+ export function TraceGroups({ spans }) {
154
+ const groups = groupByTraceId(spans);
155
+ const sorted = Array.from(groups.values())
156
+ .sort((a, b) => Number(b[0].startTime) - Number(a[0].startTime))
157
+ .slice(0, 50);
158
+ if (sorted.length === 0) {
159
+ return _jsx("div", { class: "empty", children: "Waiting for traces..." });
160
+ }
161
+ return (_jsxs("div", { class: "tl-grid", children: [_jsxs("div", { class: "tl-header tl-cols", children: [_jsx("span", { class: "tl-cell tl-cell-status" }), _jsx("span", { class: "tl-cell tl-cell-name", children: "Name" }), _jsx("span", { class: "tl-cell tl-cell-spans", children: "Spans" }), _jsx("span", { class: "tl-cell tl-cell-dur", children: "Duration" }), _jsx("span", { class: "tl-cell tl-cell-id", children: "Trace" })] }), sorted.map((group) => (_jsx(TraceGroup, { spans: group })))] }));
162
+ }
163
+ export function TraceDetail({ prefix, spans, }) {
164
+ if (spans.length === 0) {
165
+ return _jsx("div", { class: "empty", children: "Trace not found" });
166
+ }
167
+ const root = spans.find((s) => !s.parentSpanId) ?? spans[0];
168
+ const traceId = root.traceId;
169
+ const totalMs = root.durationMs ?? 0;
170
+ const rootStart = root.startTime;
171
+ const startDate = new Date(Number(rootStart) / 1_000_000);
172
+ const tree = buildSpanTree(spans);
173
+ return (_jsxs(_Fragment, { children: [_jsxs("div", { style: "padding:12px 16px;border-bottom:1px solid #1e293b", children: [_jsxs("div", { style: "display:flex;align-items:center;gap:8px;margin-bottom:8px", children: [_jsx("a", { href: `${prefix}/traces`, style: "color:#64748b;text-decoration:none;font-size:12px", children: "Traces" }), _jsx("span", { style: "color:#475569", children: "/" }), _jsx("span", { style: "color:#e2e8f0;font-size:13px;font-family:monospace", children: root.name })] }), _jsxs("div", { style: "display:flex;gap:16px;font-size:12px;color:#94a3b8;align-items:center", children: [_jsx(StatusBadge, { status: root.status }), _jsxs("span", { children: [spans.length, " span", spans.length !== 1 ? "s" : ""] }), _jsx("span", { children: formatDuration(totalMs) }), _jsx("span", { children: startDate.toLocaleTimeString("en", { hour12: false }) }), _jsx("span", { style: "color:#475569;font-family:monospace;font-size:10px", children: traceId })] })] }), _jsx("div", { style: "padding:8px 16px", children: _jsx(MiniWaterfall, { spans: spans, totalMs: totalMs, rootStart: rootStart }) }), _jsxs("div", { style: "padding:0 8px", children: [_jsx(TimeAxis, { totalMs: totalMs }), _jsx("div", { class: "wf-grid", children: tree.map((t) => (_jsx(WaterfallRow, { tree: t, totalMs: totalMs, rootStart: rootStart }))) })] }), _jsx("div", { style: "padding:8px", children: tree.map((t) => {
174
+ const s = t.span;
175
+ const stacktrace = s.attributes["code.stacktrace"];
176
+ const customAttrs = Object.entries(s.attributes).filter(([k]) => k !== "code.stacktrace");
177
+ return (_jsxs("details", { class: "span-panel", style: "margin-bottom:4px", children: [_jsxs("summary", { class: "span-panel-header", children: [_jsx("span", { style: `width:8px;height:8px;border-radius:50%;background:${statusColor(s.status)};flex-shrink:0` }), _jsx("span", { style: "color:#e2e8f0;font-family:monospace;font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1", children: s.name }), _jsx(StatusBadge, { status: s.status }), _jsx("span", { style: "color:#64748b;font-size:11px;font-family:monospace;margin-left:auto", children: formatDuration(s.durationMs) })] }), _jsxs("div", { class: "span-panel-body", children: [_jsx(KeyValue, { label: "Span ID", value: s.spanId }), _jsx(KeyValue, { label: "Kind", value: s.kind }), s.parentSpanId && _jsx(KeyValue, { label: "Parent", value: s.parentSpanId }), stacktrace && _jsx(KeyValue, { label: "Source", value: stacktrace }), customAttrs.map(([k, v]) => (_jsx(KeyValue, { label: k, value: String(v) }))), s.events.length > 0 && (_jsxs("div", { style: "margin-top:4px", children: [_jsx("span", { style: "color:#64748b;font-size:11px", children: "Events:" }), s.events.map((ev) => (_jsxs("div", { style: "padding:2px 0;font-size:11px;color:#94a3b8;font-family:monospace", children: [ev.name, ev.attributes && (_jsxs("span", { style: "color:#64748b", children: [" ", JSON.stringify(ev.attributes)] }))] })))] }))] })] }));
178
+ }) })] }));
179
+ }
@@ -1,4 +1,4 @@
1
- import type { SignalFilterOptions } from "../engine.ts";
1
+ import { type SignalFilterOptions } from "../engine.ts";
2
2
  export declare const STARTED = "started";
3
3
  export declare const FINISHED = "finished";
4
4
  export declare const ERROR = "error";
@@ -1,13 +1,9 @@
1
- import { DATASTAR_FETCH_EVENT } from "../engine.js";
2
- import { action } from "../engine.js";
3
- import { filtered, startPeeking, stopPeeking, } from "../engine.js";
1
+ import { action, DATASTAR_FETCH_EVENT, filtered, startPeeking, stopPeeking, } from "../engine.js";
4
2
  import { kebab } from "../utils.js";
5
3
  const createHttpMethod = (name, method, openWhenHiddenDefault = true) => action({
6
4
  name,
7
5
  apply: async ({ el, evt, error, cleanups }, url, { selector, headers: userHeaders, contentType = "json", filterSignals: { include = /.*/, exclude = /(^|\.)_/ } = {}, openWhenHidden = openWhenHiddenDefault, payload, requestCancellation = "auto", retry = "auto", retryInterval = 1_000, retryScaler = 2, retryMaxWaitMs = 30_000, retryMaxCount = 10, } = {}) => {
8
- const controller = requestCancellation instanceof AbortController
9
- ? requestCancellation
10
- : new AbortController();
6
+ const controller = requestCancellation instanceof AbortController ? requestCancellation : new AbortController();
11
7
  if (requestCancellation === "auto") {
12
8
  cleanups.get(`@${name}`)?.();
13
9
  cleanups.set(`@${name}`, async () => {
@@ -71,9 +67,7 @@ const createHttpMethod = (name, method, openWhenHiddenDefault = true) => action(
71
67
  const queryParams = new URLSearchParams(urlInstance.search);
72
68
  if (contentType === "json") {
73
69
  startPeeking();
74
- payload = payload !== undefined
75
- ? payload
76
- : filtered({ include, exclude });
70
+ payload = payload !== undefined ? payload : filtered({ include, exclude });
77
71
  stopPeeking();
78
72
  const body = JSON.stringify(payload);
79
73
  if (method === "GET") {
@@ -109,8 +103,7 @@ const createHttpMethod = (name, method, openWhenHiddenDefault = true) => action(
109
103
  if (name)
110
104
  formData.append(name, submitter.value);
111
105
  }
112
- const multipart = formEl
113
- .getAttribute("enctype") === "multipart/form-data";
106
+ const multipart = formEl.getAttribute("enctype") === "multipart/form-data";
114
107
  if (!multipart) {
115
108
  headers["Content-Type"] = "application/x-www-form-urlencoded";
116
109
  }
@@ -201,7 +194,6 @@ const getLines = (onLine) => {
201
194
  }
202
195
  break;
203
196
  // @ts-expect-error:7029
204
- // biome-ignore lint/suspicious/noFallthroughSwitchClause: intentional fallthrough for CR to LF
205
197
  case 13:
206
198
  discardTrailingNewline = true;
207
199
  case 10:
@@ -243,12 +235,12 @@ const getMessages = (onId, onRetry, onMessage) => {
243
235
  message.event = value;
244
236
  break;
245
237
  case "id":
246
- onId(message.id = value);
238
+ onId((message.id = value));
247
239
  break;
248
240
  case "retry": {
249
241
  const retry = +value;
250
242
  if (!Number.isNaN(retry)) {
251
- onRetry(message.retry = retry);
243
+ onRetry((message.retry = retry));
252
244
  }
253
245
  break;
254
246
  }
@@ -330,10 +322,10 @@ const fetchEventSource = (input, el, { signal: inputSignal, headers: inputHeader
330
322
  const isErrorStatus = status >= 400 && status < 600;
331
323
  if (status !== 200) {
332
324
  onclose?.();
333
- if (retry !== "never"
334
- && !isNoContentStatus
335
- && !isRedirectStatus
336
- && (retry === "always" || (retry === "error" && isErrorStatus))) {
325
+ if (retry !== "never" &&
326
+ !isNoContentStatus &&
327
+ !isRedirectStatus &&
328
+ (retry === "always" || (retry === "error" && isErrorStatus))) {
337
329
  clearTimeout(retryTimer);
338
330
  retryTimer = setTimeout(create, retryInterval);
339
331
  return;
@@ -1,5 +1,4 @@
1
- import { action } from "../engine.js";
2
- import { startPeeking, stopPeeking, } from "../engine.js";
1
+ import { action, startPeeking, stopPeeking } from "../engine.js";
3
2
  action({
4
3
  name: "peek",
5
4
  apply(_, fn) {
@@ -1,5 +1,4 @@
1
- import { action } from "../engine.js";
2
- import { filtered, mergePatch, startPeeking, stopPeeking, } from "../engine.js";
1
+ import { action, filtered, mergePatch, startPeeking, stopPeeking, } from "../engine.js";
3
2
  import { updateLeaves } from "../utils.js";
4
3
  action({
5
4
  name: "setAll",
@@ -1,5 +1,4 @@
1
- import { action } from "../engine.js";
2
- import { filtered, mergePatch, startPeeking, stopPeeking, } from "../engine.js";
1
+ import { action, filtered, mergePatch, startPeeking, stopPeeking, } from "../engine.js";
3
2
  import { updateLeaves } from "../utils.js";
4
3
  action({
5
4
  name: "toggleAll",
@@ -1,5 +1,4 @@
1
- import { attribute } from "../engine.js";
2
- import { effect } from "../engine.js";
1
+ import { attribute, effect } from "../engine.js";
3
2
  attribute({
4
3
  name: "attr",
5
4
  requirement: { value: "must" },