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,29 @@
1
+ import * as Route from "../../Route.js";
2
+ import errorsRoute from "./errors/route.js";
3
+ import fiberDetailRoute from "./fiberDetail.js";
4
+ import fibersRoute from "./fibers/route.js";
5
+ import gitRoute from "./git/route.js";
6
+ import layout from "./layout.js";
7
+ import logsRoute from "./logs/route.js";
8
+ import metricsRoute from "./metrics/route.js";
9
+ import systemRoute from "./system/route.js";
10
+ import rootRoute from "./route.js";
11
+ import routesRoute from "./routes/route.js";
12
+ import servicesRoute from "./services/route.js";
13
+ import traceDetailRoute from "./traceDetail.js";
14
+ import tracesRoute from "./traces/route.js";
15
+ export default Route.tree({
16
+ "*": layout,
17
+ "/": rootRoute,
18
+ "/traces": tracesRoute,
19
+ "/traces/:id": traceDetailRoute,
20
+ "/metrics": metricsRoute,
21
+ "/logs": logsRoute,
22
+ "/errors": errorsRoute,
23
+ "/fibers": fibersRoute,
24
+ "/fibers/:id": fiberDetailRoute,
25
+ "/routes": routesRoute,
26
+ "/system": systemRoute,
27
+ "/services": servicesRoute,
28
+ "/git": gitRoute,
29
+ });
@@ -0,0 +1,4 @@
1
+ import * as ConsoleStore from "../ConsoleStore.ts";
2
+ export declare function ErrorLine({ error }: {
3
+ error: ConsoleStore.ConsoleError;
4
+ }): import("../../hyper/HyperNode.ts").HyperNode;
@@ -0,0 +1,15 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "effect-start/jsx-runtime";
2
+ import * as ConsoleStore from "../ConsoleStore.js";
3
+ export function ErrorLine({ error }) {
4
+ const time = error.date.toLocaleTimeString("en", {
5
+ hour12: false,
6
+ hour: "2-digit",
7
+ minute: "2-digit",
8
+ second: "2-digit",
9
+ });
10
+ const firstLine = error.prettyPrint.split("\n")[0] ?? "";
11
+ const tags = error.details.map((d) => d.tag).filter(Boolean);
12
+ const allSpans = error.details.map((d) => d.span).filter(Boolean);
13
+ const allProps = error.details.flatMap((d) => Object.entries(d.properties));
14
+ return (_jsxs("details", { style: "border-bottom:1px solid #1e293b", children: [_jsxs("summary", { style: "display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:pointer;font-size:12px;font-family:monospace", children: [_jsx("span", { style: "color:#6b7280;flex-shrink:0", children: time }), _jsx("span", { style: "color:#fca5a5", children: firstLine })] }), _jsxs("div", { style: "padding:4px 12px 10px;font-size:12px;font-family:monospace", children: [tags.length > 0 && (_jsx("div", { style: "display:flex;flex-wrap:wrap;gap:4px 12px;margin-bottom:6px", children: tags.map((t) => (_jsxs("div", { children: [_jsx("span", { style: "color:#64748b", children: "tag " }), _jsx("span", { style: "color:#fca5a5;text-decoration:underline;cursor:copy", "data-on:click": `(e) => { e.signals.errorTag.value = '${t}'; e.actions.get(location.href, { contentType: 'form' }) }`, children: t })] }))) })), allSpans.length > 0 && (_jsx("div", { style: "display:flex;flex-wrap:wrap;gap:4px 12px;margin-bottom:6px", children: allSpans.map((s) => (_jsxs("div", { children: [_jsx("span", { style: "color:#64748b", children: "span " }), _jsx("span", { style: "color:#818cf8", children: s })] }))) })), allProps.length > 0 && (_jsx("div", { style: "display:flex;flex-wrap:wrap;gap:4px 12px;margin-bottom:6px", children: allProps.map(([k, v]) => (_jsxs("div", { children: [_jsx("span", { style: "color:#64748b", children: k }), _jsx("span", { style: "color:#4b5563", children: "=" }), _jsx("span", { style: "color:#e2e8f0", children: typeof v === "object" ? JSON.stringify(v) : String(v) })] }))) })), _jsxs("div", { style: "margin-bottom:6px", children: [_jsx("span", { style: "color:#64748b", children: "fiber " }), _jsx("a", { href: `${ConsoleStore.store.prefix}/fibers/${error.fiberId.replace("#", "")}`, style: "color:#9ca3af;text-decoration:none", children: error.fiberId })] }), _jsx("pre", { style: "color:#9ca3af;font-size:11px;padding:0;margin:0;white-space:pre-wrap;word-break:break-all", children: error.prettyPrint })] })] }));
15
+ }
@@ -0,0 +1,24 @@
1
+ import * as ConsoleStore from "../ConsoleStore.ts";
2
+ export interface FiberSummary {
3
+ readonly id: string;
4
+ logCount: number;
5
+ spanCount: number;
6
+ lastSeen: Date | undefined;
7
+ alive: "alive" | "dead" | "unknown";
8
+ readonly levels: Set<string>;
9
+ }
10
+ export declare function getParentChain(fiberId: string, fiberParents: Map<string, string>): Array<string>;
11
+ export declare function collectFibers(logs: Array<ConsoleStore.ConsoleLog>, spans: Array<ConsoleStore.ConsoleSpan>): Array<FiberSummary>;
12
+ export declare function FiberList({ fibers, prefix }: {
13
+ fibers: Array<FiberSummary>;
14
+ prefix: string;
15
+ }): import("../../hyper/HyperNode.ts").HyperNode;
16
+ export declare function FiberDetail({ prefix, fiberId, logs, spans, alive, parents, context, }: {
17
+ prefix: string;
18
+ fiberId: string;
19
+ logs: Array<ConsoleStore.ConsoleLog>;
20
+ spans: Array<ConsoleStore.ConsoleSpan>;
21
+ alive: "alive" | "dead" | "unknown";
22
+ parents: Array<string>;
23
+ context: ConsoleStore.FiberContext | undefined;
24
+ }): import("../../hyper/HyperNode.ts").HyperNode;
@@ -0,0 +1,121 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "effect-start/jsx-runtime";
2
+ import * as ConsoleStore from "../ConsoleStore.js";
3
+ import * as Logs from "./Logs.js";
4
+ function formatDuration(ms) {
5
+ if (ms == null)
6
+ return "...";
7
+ if (ms < 1)
8
+ return `${(ms * 1000).toFixed(0)}µs`;
9
+ if (ms < 1000)
10
+ return `${ms.toFixed(1)}ms`;
11
+ return `${(ms / 1000).toFixed(2)}s`;
12
+ }
13
+ function KeyValue({ label, value }) {
14
+ if (value == null)
15
+ return null;
16
+ 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 })] }));
17
+ }
18
+ function StatusBadge({ status }) {
19
+ const bg = status === "ok" ? "#166534" : status === "error" ? "#7f1d1d" : "#713f12";
20
+ const fg = status === "ok" ? "#4ade80" : status === "error" ? "#fca5a5" : "#fde047";
21
+ return (_jsx("span", { style: `font-size:11px;padding:2px 8px;border-radius:4px;background:${bg};color:${fg}`, children: status }));
22
+ }
23
+ export function getParentChain(fiberId, fiberParents) {
24
+ const chain = [];
25
+ const visited = new Set();
26
+ let current = fiberParents.get(fiberId);
27
+ while (current && !visited.has(current)) {
28
+ chain.push(current);
29
+ visited.add(current);
30
+ current = fiberParents.get(current);
31
+ }
32
+ return chain.reverse();
33
+ }
34
+ export function collectFibers(logs, spans) {
35
+ const map = new Map();
36
+ const counter = ConsoleStore.fiberIdCounter();
37
+ const now = Date.now();
38
+ for (const log of logs) {
39
+ let fiber = map.get(log.fiberId);
40
+ if (!fiber) {
41
+ fiber = {
42
+ id: log.fiberId,
43
+ logCount: 0,
44
+ spanCount: 0,
45
+ lastSeen: undefined,
46
+ alive: "unknown",
47
+ levels: new Set(),
48
+ };
49
+ map.set(log.fiberId, fiber);
50
+ }
51
+ fiber.logCount++;
52
+ fiber.levels.add(log.level);
53
+ if (!fiber.lastSeen || log.date > fiber.lastSeen) {
54
+ fiber.lastSeen = log.date;
55
+ }
56
+ }
57
+ for (const span of spans) {
58
+ const fiberId = span.attributes["fiber.id"];
59
+ if (!fiberId)
60
+ continue;
61
+ let fiber = map.get(fiberId);
62
+ if (!fiber) {
63
+ fiber = {
64
+ id: fiberId,
65
+ logCount: 0,
66
+ spanCount: 0,
67
+ lastSeen: undefined,
68
+ alive: "unknown",
69
+ levels: new Set(),
70
+ };
71
+ map.set(fiberId, fiber);
72
+ }
73
+ fiber.spanCount++;
74
+ }
75
+ for (const fiber of map.values()) {
76
+ const num = parseInt(fiber.id.replace("#", ""), 10);
77
+ if (!isNaN(num)) {
78
+ if (fiber.lastSeen && now - fiber.lastSeen.getTime() < 5000) {
79
+ fiber.alive = "alive";
80
+ }
81
+ else if (num < counter) {
82
+ fiber.alive = "dead";
83
+ }
84
+ }
85
+ }
86
+ return Array.from(map.values()).sort((a, b) => {
87
+ const na = parseInt(a.id.replace("#", ""), 10);
88
+ const nb = parseInt(b.id.replace("#", ""), 10);
89
+ return nb - na;
90
+ });
91
+ }
92
+ function FiberRow({ fiber, prefix }) {
93
+ const aliveColor = fiber.alive === "alive" ? "#4ade80" : fiber.alive === "dead" ? "#ef4444" : "#94a3b8";
94
+ const aliveBg = fiber.alive === "alive" ? "#166534" : fiber.alive === "dead" ? "#7f1d1d" : "#334155";
95
+ const lastSeen = fiber.lastSeen
96
+ ? fiber.lastSeen.toLocaleTimeString("en", {
97
+ hour12: false,
98
+ hour: "2-digit",
99
+ minute: "2-digit",
100
+ second: "2-digit",
101
+ })
102
+ : "—";
103
+ return (_jsxs("a", { href: `${prefix}/fibers/${fiber.id.replace("#", "")}`, style: "display:flex;align-items:center;gap:12px;padding:8px 12px;border-bottom:1px solid #1e293b;text-decoration:none;transition:background .1s", onmouseover: "this.style.background='#1e293b'", onmouseout: "this.style.background='transparent'", children: [_jsx("span", { style: "color:#e2e8f0;font-family:monospace;font-size:13px;font-weight:600;min-width:60px", children: fiber.id }), _jsx("span", { style: `font-size:10px;padding:2px 8px;border-radius:4px;background:${aliveBg};color:${aliveColor}`, children: fiber.alive }), _jsxs("span", { style: "color:#94a3b8;font-size:12px", children: [fiber.spanCount, " span", fiber.spanCount !== 1 ? "s" : ""] }), _jsxs("span", { style: "color:#94a3b8;font-size:12px", children: [fiber.logCount, " log", fiber.logCount !== 1 ? "s" : ""] }), fiber.levels.has("ERROR") && (_jsx("span", { style: "font-size:10px;padding:1px 6px;border-radius:4px;background:#7f1d1d;color:#fca5a5", children: "ERROR" })), fiber.levels.has("WARNING") && (_jsx("span", { style: "font-size:10px;padding:1px 6px;border-radius:4px;background:#713f12;color:#fde047", children: "WARN" })), _jsx("span", { style: "color:#6b7280;font-size:11px;margin-left:auto;font-family:monospace", children: lastSeen })] }));
104
+ }
105
+ export function FiberList({ fibers, prefix }) {
106
+ if (fibers.length === 0) {
107
+ return _jsx("div", { class: "empty", children: "Waiting for fibers..." });
108
+ }
109
+ return (_jsx(_Fragment, { children: fibers.map((f) => (_jsx(FiberRow, { fiber: f, prefix: prefix }))) }));
110
+ }
111
+ export function FiberDetail({ prefix, fiberId, logs, spans, alive, parents, context, }) {
112
+ const aliveColor = alive === "alive" ? "#4ade80" : alive === "dead" ? "#ef4444" : "#94a3b8";
113
+ const aliveBg = alive === "alive" ? "#166534" : alive === "dead" ? "#7f1d1d" : "#334155";
114
+ return (_jsxs(_Fragment, { children: [_jsxs("div", { class: "tab-header", children: [_jsxs("div", { style: "display:flex;align-items:center;gap:8px;margin-bottom:4px", children: [_jsx("a", { href: `${prefix}/fibers`, style: "color:#64748b;text-decoration:none;font-size:12px", children: "Fibers" }), _jsx("span", { style: "color:#475569", children: "/" }), _jsx("span", { style: "color:#e2e8f0;font-size:13px;font-family:monospace", children: fiberId }), _jsx("span", { style: `font-size:11px;padding:2px 8px;border-radius:4px;background:${aliveBg};color:${aliveColor}`, children: alive })] }), _jsxs("div", { style: "display:flex;gap:16px;font-size:12px;color:#94a3b8", children: [_jsxs("span", { children: [logs.length, " log", logs.length !== 1 ? "s" : ""] }), _jsxs("span", { children: [spans.length, " span", spans.length !== 1 ? "s" : ""] })] })] }), _jsxs("div", { class: "tab-body", children: [parents.length > 0 && (_jsxs("div", { style: "padding:8px 16px", children: [_jsx("div", { style: "color:#94a3b8;font-size:12px;font-weight:600;margin-bottom:8px", children: "Parents" }), _jsx("div", { style: "display:flex;gap:6px;flex-wrap:wrap", children: parents.map((id) => (_jsx("a", { href: `${prefix}/fibers/${id.replace("#", "")}`, style: "color:#38bdf8;font-family:monospace;font-size:13px;text-decoration:none;padding:4px 10px;background:#111827;border:1px solid #1e293b;border-radius:6px", children: id }))) })] })), context &&
115
+ (context.spanName || context.traceId || Object.keys(context.annotations).length > 0) && (_jsxs("div", { style: "padding:8px 16px", children: [_jsx("div", { style: "color:#94a3b8;font-size:12px;font-weight:600;margin-bottom:8px", children: "Context" }), _jsxs("div", { style: "background:#111827;border:1px solid #1e293b;border-radius:6px;padding:8px 12px", children: [context.spanName && _jsx(KeyValue, { label: "Span", value: context.spanName }), context.traceId && (_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: "Trace" }), _jsx("a", { href: `${prefix}/traces/${context.traceId}`, style: "color:#38bdf8;font-family:monospace;word-break:break-all;text-decoration:none", children: context.traceId })] })), Object.entries(context.annotations).map(([k, v]) => (_jsx(KeyValue, { label: k, value: typeof v === "object" ? JSON.stringify(v) : String(v) })))] })] })), spans.length > 0 && (_jsxs("div", { style: "padding:8px 16px", children: [_jsx("div", { style: "color:#94a3b8;font-size:12px;font-weight:600;margin-bottom:8px", children: "Spans" }), spans.map((s) => {
116
+ const stacktrace = s.attributes["code.stacktrace"];
117
+ return (_jsxs("div", { style: "margin-bottom:6px;background:#111827;border:1px solid #1e293b;border-radius:6px;padding:8px 12px", children: [_jsxs("div", { style: "display:flex;align-items:center;gap:8px;margin-bottom:4px", children: [_jsx("a", { href: `${prefix}/traces/${s.traceId}`, style: "color:#38bdf8;font-family:monospace;font-size:13px;text-decoration:none", children: s.name }), _jsx(StatusBadge, { status: s.status }), _jsx("span", { style: "color:#64748b;font-size:11px;margin-left:auto;font-family:monospace", children: formatDuration(s.durationMs) })] }), _jsx(KeyValue, { label: "Trace", value: s.traceId }), _jsx(KeyValue, { label: "Kind", value: s.kind }), stacktrace && _jsx(KeyValue, { label: "Source", value: stacktrace }), Object.entries(s.attributes)
118
+ .filter(([k]) => k !== "code.stacktrace")
119
+ .map(([k, v]) => (_jsx(KeyValue, { label: k, value: String(v) })))] }));
120
+ })] })), logs.length > 0 && (_jsxs("div", { style: "padding:8px 16px", children: [_jsx("div", { style: "color:#94a3b8;font-size:12px;font-weight:600;margin-bottom:8px", children: "Logs" }), logs.map((l) => (_jsx(Logs.LogLine, { log: l })))] })), logs.length === 0 && spans.length === 0 && (_jsxs("div", { class: "empty", children: ["No data found for fiber ", fiberId] }))] })] }));
121
+ }
@@ -0,0 +1,20 @@
1
+ export interface GitFileEntry {
2
+ readonly status: string;
3
+ readonly path: string;
4
+ }
5
+ export interface GitStatus {
6
+ readonly oid: string;
7
+ readonly head: string;
8
+ readonly upstream: string | undefined;
9
+ readonly ahead: number;
10
+ readonly behind: number;
11
+ readonly tag: string | undefined;
12
+ readonly tagDistance: number;
13
+ readonly staged: Array<GitFileEntry>;
14
+ readonly unstaged: Array<GitFileEntry>;
15
+ readonly untracked: Array<string>;
16
+ }
17
+ export declare function parseGitStatus(porcelain: string, tagLine: string): GitStatus;
18
+ export declare function GitStatusView({ status }: {
19
+ status: GitStatus;
20
+ }): import("../../hyper/HyperNode").HyperNode;
@@ -0,0 +1,95 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "effect-start/jsx-runtime";
2
+ const xyToLabel = {
3
+ M: "modified",
4
+ A: "new file",
5
+ D: "deleted",
6
+ R: "renamed",
7
+ C: "copied",
8
+ T: "typechange",
9
+ U: "unmerged",
10
+ };
11
+ function statusLabel(code) {
12
+ return xyToLabel[code] ?? code;
13
+ }
14
+ function gitStatusColor(code) {
15
+ if (code === "D")
16
+ return "#ef4444";
17
+ if (code === "A")
18
+ return "#4ade80";
19
+ if (code === "R" || code === "C")
20
+ return "#60a5fa";
21
+ if (code === "M")
22
+ return "#fbbf24";
23
+ return "#94a3b8";
24
+ }
25
+ export function parseGitStatus(porcelain, tagLine) {
26
+ const lines = porcelain.split("\n");
27
+ let oid = "";
28
+ let head = "";
29
+ let upstream;
30
+ let ahead = 0;
31
+ let behind = 0;
32
+ const staged = [];
33
+ const unstaged = [];
34
+ const untracked = [];
35
+ for (const line of lines) {
36
+ if (line.startsWith("# branch.oid ")) {
37
+ oid = line.slice("# branch.oid ".length, "# branch.oid ".length + 7);
38
+ }
39
+ else if (line.startsWith("# branch.head ")) {
40
+ head = line.slice("# branch.head ".length);
41
+ }
42
+ else if (line.startsWith("# branch.upstream ")) {
43
+ upstream = line.slice("# branch.upstream ".length);
44
+ }
45
+ else if (line.startsWith("# branch.ab ")) {
46
+ const parts = line.slice("# branch.ab ".length).split(" ");
47
+ ahead = parseInt(parts[0]?.slice(1) ?? "0", 10);
48
+ behind = parseInt(parts[1]?.slice(1) ?? "0", 10);
49
+ }
50
+ else if (line.startsWith("1 ") || line.startsWith("2 ")) {
51
+ const xy = line.slice(2, 4);
52
+ const x = xy[0];
53
+ const y = xy[1];
54
+ const parts = line.split("\t");
55
+ const firstParts = parts[0].split(" ");
56
+ const path = parts.length > 1 ? parts[1] : firstParts[firstParts.length - 1];
57
+ if (x !== "." && x !== "?")
58
+ staged.push({ status: x, path });
59
+ if (y !== "." && y !== "?")
60
+ unstaged.push({ status: y, path });
61
+ }
62
+ else if (line.startsWith("u ")) {
63
+ const parts = line.split("\t");
64
+ const path = parts.length > 1 ? parts[1] : line.split(" ").pop();
65
+ staged.push({ status: "U", path });
66
+ }
67
+ else if (line.startsWith("? ")) {
68
+ untracked.push(line.slice(2));
69
+ }
70
+ }
71
+ let tag;
72
+ let tagDistance = 0;
73
+ const tagParts = tagLine.trim().split("\n");
74
+ if (tagParts[0] && !tagParts[0].startsWith("fatal")) {
75
+ tag = tagParts[0];
76
+ tagDistance = parseInt(tagParts[1] ?? "0", 10);
77
+ }
78
+ return { oid, head, upstream, ahead, behind, tag, tagDistance, staged, unstaged, untracked };
79
+ }
80
+ function GitKV({ label, children }) {
81
+ return (_jsxs("div", { style: "display:flex;gap:8px;padding:3px 0;font-size:13px;font-family:monospace", children: [_jsx("span", { style: "color:#6b7280;min-width:80px", children: label }), _jsx("span", { style: "color:#e5e7eb", children: children })] }));
82
+ }
83
+ function GitFileRow({ entry }) {
84
+ const label = statusLabel(entry.status);
85
+ const color = gitStatusColor(entry.status);
86
+ return (_jsxs("div", { style: "display:flex;gap:12px;padding:2px 0;font-size:13px;font-family:monospace", children: [_jsx("span", { style: `color:${color};font-style:italic;min-width:80px`, children: label }), _jsx("span", { style: "color:#d1d5db", children: entry.path })] }));
87
+ }
88
+ function SectionHeader({ title, count }) {
89
+ return (_jsxs("div", { style: "color:#fbbf24;font-size:14px;font-weight:600;padding:16px 0 6px;font-family:monospace", children: [title, " (", count, ")"] }));
90
+ }
91
+ export function GitStatusView({ status }) {
92
+ return (_jsxs("div", { style: "padding:12px 16px", children: [_jsxs(GitKV, { label: "Head:", children: [_jsx("span", { style: "color:#94a3b8;font-style:italic", children: status.oid }), " ", _jsx("span", { style: "color:#4ade80;font-weight:600", children: status.head })] }), status.upstream && (_jsxs(GitKV, { label: "Upstream:", children: [_jsx("span", { style: "color:#94a3b8;font-style:italic", children: status.oid }), " ", _jsx("span", { style: "color:#60a5fa;font-weight:600", children: status.upstream }), (status.ahead > 0 || status.behind > 0) && (_jsxs("span", { style: "color:#94a3b8", children: [status.ahead > 0 ? ` +${status.ahead}` : "", status.behind > 0 ? ` -${status.behind}` : ""] }))] })), status.tag && (_jsxs(GitKV, { label: "Tag:", children: [_jsx("span", { style: "color:#e5e7eb", children: status.tag }), status.tagDistance > 0 && _jsxs("span", { style: "color:#60a5fa", children: [" (", status.tagDistance, ")"] })] })), status.untracked.length > 0 && (_jsxs(_Fragment, { children: [_jsx(SectionHeader, { title: "Untracked files", count: status.untracked.length }), status.untracked.map((f) => (_jsx("div", { style: "padding:2px 0;font-size:13px;font-family:monospace;color:#d1d5db", children: f })))] })), status.unstaged.length > 0 && (_jsxs(_Fragment, { children: [_jsx(SectionHeader, { title: "Unstaged changes", count: status.unstaged.length }), status.unstaged.map((e) => (_jsx(GitFileRow, { entry: e })))] })), status.staged.length > 0 && (_jsxs(_Fragment, { children: [_jsx(SectionHeader, { title: "Staged changes", count: status.staged.length }), status.staged.map((e) => (_jsx(GitFileRow, { entry: e })))] })), status.untracked.length === 0 &&
93
+ status.unstaged.length === 0 &&
94
+ status.staged.length === 0 && (_jsx("div", { style: "color:#4ade80;font-size:13px;font-family:monospace;padding:16px 0", children: "Clean working tree" }))] }));
95
+ }
@@ -0,0 +1,4 @@
1
+ import * as ConsoleStore from "../ConsoleStore.ts";
2
+ export declare function LogLine({ log }: {
3
+ log: ConsoleStore.ConsoleLog;
4
+ }): import("../../hyper/HyperNode.ts").HyperNode;
@@ -0,0 +1,25 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "effect-start/jsx-runtime";
2
+ import * as ConsoleStore from "../ConsoleStore.js";
3
+ function levelColor(level) {
4
+ if (level === "DEBUG")
5
+ return "#94a3b8";
6
+ if (level === "INFO")
7
+ return "#60a5fa";
8
+ if (level === "WARNING")
9
+ return "#fbbf24";
10
+ if (level === "ERROR")
11
+ return "#ef4444";
12
+ if (level === "FATAL")
13
+ return "#dc2626";
14
+ return "#e5e7eb";
15
+ }
16
+ export function LogLine({ log }) {
17
+ const color = levelColor(log.level);
18
+ const time = log.date.toLocaleTimeString("en", {
19
+ hour12: false,
20
+ hour: "2-digit",
21
+ minute: "2-digit",
22
+ second: "2-digit",
23
+ });
24
+ return (_jsxs("div", { id: `log-${log.id}`, style: "padding:3px 8px;border-bottom:1px solid #1f2937;font-family:monospace;font-size:12px;display:flex;align-items:baseline", children: [_jsx("span", { style: "color:#6b7280;white-space:nowrap", children: time }), _jsx("span", { style: `color:${color};font-weight:600;width:56px;text-align:center;flex-shrink:0`, children: log.level }), _jsx("span", { style: "color:#e5e7eb;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis", children: log.message }), _jsx("a", { href: `${ConsoleStore.store.prefix}/fibers/${log.fiberId.replace("#", "")}`, style: "color:#6b7280;white-space:nowrap;margin-left:8px;text-decoration:none", children: log.fiberId }), log.cause && (_jsx("div", { style: "color:#ef4444;font-size:11px;padding:2px 0 0 0;white-space:pre-wrap;width:100%", children: log.cause }))] }));
25
+ }
@@ -0,0 +1,4 @@
1
+ import type * as ConsoleStore from "../ConsoleStore.ts";
2
+ export declare function MetricsGrid({ metrics }: {
3
+ metrics: Array<ConsoleStore.ConsoleMetricSnapshot>;
4
+ }): import("../../hyper/HyperNode.ts").HyperNode;
@@ -0,0 +1,26 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "effect-start/jsx-runtime";
2
+ function MetricValue({ metric }) {
3
+ if (metric.type === "counter" || metric.type === "gauge") {
4
+ return (_jsx("div", { style: "font-size:32px;font-weight:700;color:#e5e7eb;font-family:monospace;line-height:1.1", children: String(metric.value) }));
5
+ }
6
+ if (metric.type === "histogram") {
7
+ const h = metric.value;
8
+ return (_jsxs("div", { style: "display:grid;grid-template-columns:auto auto;gap:2px 12px;font-size:12px;font-family:monospace", children: [_jsx("span", { style: "color:#6b7280", children: "count" }), _jsx("span", { style: "color:#e5e7eb", children: h.count }), _jsx("span", { style: "color:#6b7280", children: "sum" }), _jsx("span", { style: "color:#e5e7eb", children: h.sum.toFixed(2) }), _jsx("span", { style: "color:#6b7280", children: "min" }), _jsx("span", { style: "color:#e5e7eb", children: h.min.toFixed(2) }), _jsx("span", { style: "color:#6b7280", children: "max" }), _jsx("span", { style: "color:#e5e7eb", children: h.max.toFixed(2) })] }));
9
+ }
10
+ if (metric.type === "frequency") {
11
+ const occ = metric.value;
12
+ return (_jsx("div", { style: "display:grid;grid-template-columns:auto auto;gap:2px 12px;font-size:12px;font-family:monospace", children: Object.entries(occ)
13
+ .slice(0, 10)
14
+ .map(([k, v]) => (_jsxs(_Fragment, { children: [_jsx("span", { style: "color:#6b7280", children: k }), _jsx("span", { style: "color:#e5e7eb", children: v })] }))) }));
15
+ }
16
+ return (_jsx("pre", { style: "font-size:11px;color:#9ca3af;margin:0;white-space:pre-wrap", children: JSON.stringify(metric.value, null, 2) }));
17
+ }
18
+ function MetricCard({ metric }) {
19
+ return (_jsxs("div", { style: "background:#111827;border:1px solid #374151;border-radius:6px;padding:12px;min-width:200px", children: [_jsxs("div", { style: "display:flex;align-items:center;gap:8px;margin-bottom:8px", children: [_jsx("span", { style: "color:#d1d5db;font-size:13px;font-weight:600", children: metric.name }), _jsx("span", { style: "font-size:10px;padding:1px 6px;border-radius:4px;background:#1e3a5f;color:#60a5fa", children: metric.type })] }), _jsx(MetricValue, { metric: metric }), metric.tags.length > 0 && (_jsx("div", { style: "font-size:10px;color:#6b7280;margin-top:4px", children: metric.tags.map((t) => `${t.key}=${t.value}`).join(" ") }))] }));
20
+ }
21
+ export function MetricsGrid({ metrics }) {
22
+ if (metrics.length === 0) {
23
+ return _jsx("div", { class: "empty", children: "Waiting for metrics..." });
24
+ }
25
+ return (_jsx(_Fragment, { children: metrics.map((m) => (_jsx(MetricCard, { metric: m }))) }));
26
+ }
@@ -0,0 +1,8 @@
1
+ export interface RouteInfo {
2
+ readonly method: string;
3
+ readonly path: string;
4
+ readonly format: string | undefined;
5
+ }
6
+ export declare function RouteList({ routes }: {
7
+ routes: Array<RouteInfo>;
8
+ }): import("../../hyper/HyperNode").HyperNode;
@@ -0,0 +1,70 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "effect-start/jsx-runtime";
2
+ function groupByPath(routes) {
3
+ const byPath = new Map();
4
+ for (const r of routes) {
5
+ let group = byPath.get(r.path);
6
+ if (!group) {
7
+ group = [];
8
+ byPath.set(r.path, group);
9
+ }
10
+ group.push(r);
11
+ }
12
+ return Array.from(byPath, ([path, routes]) => ({
13
+ path,
14
+ routes: routes.sort((a, b) => methodOrder.indexOf(a.method) - methodOrder.indexOf(b.method)),
15
+ })).sort((a, b) => a.path.localeCompare(b.path));
16
+ }
17
+ function methodColor(method) {
18
+ if (method === "GET")
19
+ return "#22c55e";
20
+ if (method === "POST")
21
+ return "#3b82f6";
22
+ if (method === "PUT")
23
+ return "#f59e0b";
24
+ if (method === "DELETE")
25
+ return "#ef4444";
26
+ if (method === "PATCH")
27
+ return "#a855f7";
28
+ if (method === "*")
29
+ return "#6b7280";
30
+ return "#94a3b8";
31
+ }
32
+ function methodBg(method) {
33
+ if (method === "GET")
34
+ return "#052e16";
35
+ if (method === "POST")
36
+ return "#172554";
37
+ if (method === "PUT")
38
+ return "#422006";
39
+ if (method === "DELETE")
40
+ return "#450a0a";
41
+ if (method === "PATCH")
42
+ return "#3b0764";
43
+ return "#1e293b";
44
+ }
45
+ const methodOrder = ["GET", "POST", "PUT", "PATCH", "DELETE", "HEAD", "OPTIONS", "*"];
46
+ function MethodBadge({ method }) {
47
+ return (_jsx("span", { style: `font-size:10px;font-weight:700;font-family:monospace;padding:2px 6px;border-radius:3px;background:${methodBg(method)};color:${methodColor(method)};min-width:48px;text-align:center;display:inline-block`, children: method }));
48
+ }
49
+ function FormatBadge({ format }) {
50
+ return (_jsx("span", { style: "font-size:10px;padding:1px 6px;border-radius:3px;background:#1e3a5f;color:#60a5fa", children: format }));
51
+ }
52
+ function ColoredPath({ path }) {
53
+ const segments = path.split("/").filter(Boolean);
54
+ return (_jsx("span", { style: "font-family:monospace;font-size:13px", children: segments.length === 0 ? (_jsx("span", { style: "color:#e2e8f0", children: "/" })) : (segments.map((seg) => {
55
+ const isParam = seg.startsWith(":");
56
+ return (_jsxs(_Fragment, { children: [_jsx("span", { style: "color:#475569", children: "/" }), _jsx("span", { style: isParam ? "color:#c084fc" : "color:#e2e8f0", children: seg })] }));
57
+ })) }));
58
+ }
59
+ function PathGroup({ path, routes }) {
60
+ return (_jsxs("div", { style: "padding:8px 12px;border-bottom:1px solid #1e293b", children: [_jsx("div", { style: "margin-bottom:4px", children: _jsx(ColoredPath, { path: path }) }), _jsx("div", { style: "display:flex;flex-wrap:wrap;gap:4px", children: routes.map((r) => (_jsxs("div", { style: "display:flex;align-items:center;gap:6px", children: [_jsx(MethodBadge, { method: r.method }), r.format && _jsx(FormatBadge, { format: r.format })] }))) })] }));
61
+ }
62
+ export function RouteList({ routes }) {
63
+ if (routes.length === 0) {
64
+ return _jsx("div", { class: "empty", children: "No routes registered" });
65
+ }
66
+ const groups = groupByPath(routes);
67
+ const routeCount = routes.length;
68
+ const pathCount = groups.length;
69
+ return (_jsxs(_Fragment, { children: [_jsxs("div", { style: "padding:8px 12px;border-bottom:1px solid #1e293b;display:flex;gap:16px;font-size:12px;color:#64748b", children: [_jsxs("span", { children: [pathCount, " path", pathCount !== 1 ? "s" : ""] }), _jsxs("span", { children: [routeCount, " route", routeCount !== 1 ? "s" : ""] })] }), groups.map((g) => (_jsx(PathGroup, { path: g.path, routes: g.routes })))] }));
70
+ }
@@ -0,0 +1,10 @@
1
+ export interface ServiceEntry {
2
+ readonly key: string;
3
+ readonly kind: string;
4
+ readonly display: string;
5
+ readonly type: "config" | "value" | "effect";
6
+ }
7
+ export declare function ServiceList({ services }: {
8
+ services: Array<ServiceEntry>;
9
+ }): import("../../hyper/HyperNode").HyperNode;
10
+ export declare function collectServices(unsafeMap: Map<string, any>): Array<ServiceEntry>;