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.
- package/dist/BlobStore.d.ts +80 -0
- package/dist/BlobStore.js +19 -0
- package/dist/ChildProcess.d.ts +60 -0
- package/dist/ChildProcess.js +30 -0
- package/dist/Commander.d.ts +3 -6
- package/dist/Commander.js +6 -13
- package/dist/ContentNegotiation.d.ts +8 -9
- package/dist/ContentNegotiation.js +32 -37
- package/dist/Cookies.d.ts +47 -0
- package/dist/Cookies.js +273 -363
- package/dist/Development.d.ts +2 -2
- package/dist/Development.js +3 -4
- package/dist/Effectify.d.ts +1 -4
- package/dist/FilePathPattern.d.ts +3 -3
- package/dist/FileRouter.d.ts +5 -8
- package/dist/FileRouter.js +9 -10
- package/dist/FileRouterCodegen.d.ts +1 -1
- package/dist/FileRouterCodegen.js +33 -13
- package/dist/FileSystem.d.ts +158 -0
- package/dist/FileSystem.js +64 -125
- package/dist/Http.js +2 -6
- package/dist/PathPattern.d.ts +7 -7
- package/dist/PathPattern.js +1 -3
- package/dist/PlatformError.d.ts +24 -32
- package/dist/PlatformError.js +3 -21
- package/dist/PlatformRuntime.js +5 -10
- package/dist/Route.d.ts +14 -19
- package/dist/Route.js +8 -11
- package/dist/RouteBody.d.ts +6 -12
- package/dist/RouteBody.js +2 -2
- package/dist/RouteError.d.ts +98 -0
- package/dist/RouteError.js +55 -0
- package/dist/RouteHook.js +6 -11
- package/dist/RouteHttp.d.ts +3 -3
- package/dist/RouteHttp.js +27 -22
- package/dist/RouteMount.d.ts +16 -50
- package/dist/RouteMount.js +6 -20
- package/dist/RouteSchema.d.ts +22 -1
- package/dist/RouteSchema.js +33 -0
- package/dist/RouteSse.js +4 -10
- package/dist/RouteTree.d.ts +2 -1
- package/dist/RouteTree.js +17 -15
- package/dist/RouteTrie.d.ts +2 -2
- package/dist/RouteTrie.js +4 -9
- package/dist/SchemaExtra.d.ts +1 -1
- package/dist/Socket.d.ts +27 -0
- package/dist/Socket.js +20 -28
- package/dist/Sql.d.ts +34 -0
- package/dist/Sql.js +5 -0
- package/dist/SqlIntrospect.d.ts +91 -0
- package/dist/SqlIntrospect.js +466 -0
- package/dist/Start.d.ts +4 -6
- package/dist/Start.js +10 -2
- package/dist/StreamExtra.d.ts +1 -1
- package/dist/StreamExtra.js +9 -9
- package/dist/System.d.ts +7 -0
- package/dist/System.js +22 -0
- package/dist/TuplePathPattern.js +55 -50
- package/dist/Unique.js +7 -7
- package/dist/Values.d.ts +2 -1
- package/dist/Values.js +19 -13
- package/dist/bun/BunBlobStoreDisk.d.ts +6 -0
- package/dist/bun/BunBlobStoreDisk.js +116 -0
- package/dist/bun/BunBlobStoreS3.d.ts +11 -0
- package/dist/bun/BunBlobStoreS3.js +89 -0
- package/dist/bun/BunBlobWatcherDisk.d.ts +6 -0
- package/dist/bun/BunBlobWatcherDisk.js +60 -0
- package/dist/bun/BunBlobWatcherQueue.d.ts +6 -0
- package/dist/bun/BunBlobWatcherQueue.js +17 -0
- package/dist/bun/BunBundle.d.ts +5 -6
- package/dist/bun/BunBundle.js +7 -15
- package/dist/bun/BunChildProcessSpawner.d.ts +3 -0
- package/dist/bun/BunChildProcessSpawner.js +103 -0
- package/dist/bun/BunImportTrackerPlugin.d.ts +1 -1
- package/dist/bun/BunImportTrackerPlugin.js +3 -5
- package/dist/bun/BunRoute.d.ts +3 -2
- package/dist/bun/BunRoute.js +5 -7
- package/dist/bun/BunRuntime.js +1 -1
- package/dist/bun/BunServer.d.ts +11 -4
- package/dist/bun/BunServer.js +35 -11
- package/dist/bun/BunSql.d.ts +4 -0
- package/dist/bun/BunSql.js +81 -0
- package/dist/bun/_BunEnhancedResolve.d.ts +3 -3
- package/dist/bun/_BunEnhancedResolve.js +2 -4
- package/dist/bun/index.d.ts +1 -0
- package/dist/bun/index.js +1 -0
- package/dist/bundler/Bundle.d.ts +2 -1
- package/dist/bundler/Bundle.js +1 -1
- package/dist/bundler/BundleFiles.d.ts +5 -5
- package/dist/bundler/BundleFiles.js +10 -8
- package/dist/bundler/BundleRoute.d.ts +27 -0
- package/dist/bundler/BundleRoute.js +51 -0
- package/dist/client/ScrollState.js +2 -6
- package/dist/client/index.js +6 -8
- package/dist/console/Console.d.ts +6 -0
- package/dist/console/Console.js +26 -0
- package/dist/console/ConsoleErrors.d.ts +3 -0
- package/dist/console/ConsoleErrors.js +200 -0
- package/dist/console/ConsoleLogger.d.ts +3 -0
- package/dist/console/ConsoleLogger.js +47 -0
- package/dist/console/ConsoleMetrics.d.ts +3 -0
- package/dist/console/ConsoleMetrics.js +61 -0
- package/dist/console/ConsoleProcess.d.ts +3 -0
- package/dist/console/ConsoleProcess.js +49 -0
- package/dist/console/ConsoleStore.d.ts +144 -0
- package/dist/console/ConsoleStore.js +61 -0
- package/dist/console/ConsoleTracer.d.ts +3 -0
- package/dist/console/ConsoleTracer.js +94 -0
- package/dist/console/Simulation.d.ts +2 -0
- package/dist/console/Simulation.js +633 -0
- package/dist/console/index.d.ts +3 -0
- package/dist/console/index.js +3 -0
- package/dist/console/routes/errors/route.d.ts +10 -0
- package/dist/console/routes/errors/route.js +47 -0
- package/dist/console/routes/fiberDetail.d.ts +16 -0
- package/dist/console/routes/fiberDetail.js +38 -0
- package/dist/console/routes/fibers/route.d.ts +10 -0
- package/dist/console/routes/fibers/route.js +19 -0
- package/dist/console/routes/git/route.d.ts +11 -0
- package/dist/console/routes/git/route.js +33 -0
- package/dist/console/routes/layout.d.ts +9 -0
- package/dist/console/routes/layout.js +3 -0
- package/dist/console/routes/logs/route.d.ts +10 -0
- package/dist/console/routes/logs/route.js +32 -0
- package/dist/console/routes/metrics/route.d.ts +10 -0
- package/dist/console/routes/metrics/route.js +17 -0
- package/dist/console/routes/route.d.ts +6 -0
- package/dist/console/routes/route.js +5 -0
- package/dist/console/routes/routes/route.d.ts +6 -0
- package/dist/console/routes/routes/route.js +20 -0
- package/dist/console/routes/services/route.d.ts +6 -0
- package/dist/console/routes/services/route.js +12 -0
- package/dist/console/routes/system/route.d.ts +10 -0
- package/dist/console/routes/system/route.js +18 -0
- package/dist/console/routes/traceDetail.d.ts +16 -0
- package/dist/console/routes/traceDetail.js +14 -0
- package/dist/console/routes/traces/route.d.ts +10 -0
- package/dist/console/routes/traces/route.js +39 -0
- package/dist/console/routes/tree.d.ts +153 -0
- package/dist/console/routes/tree.js +29 -0
- package/dist/console/ui/Errors.d.ts +4 -0
- package/dist/console/ui/Errors.js +15 -0
- package/dist/console/ui/Fibers.d.ts +24 -0
- package/dist/console/ui/Fibers.js +121 -0
- package/dist/console/ui/Git.d.ts +20 -0
- package/dist/console/ui/Git.js +95 -0
- package/dist/console/ui/Logs.d.ts +4 -0
- package/dist/console/ui/Logs.js +25 -0
- package/dist/console/ui/Metrics.d.ts +4 -0
- package/dist/console/ui/Metrics.js +26 -0
- package/dist/console/ui/Routes.d.ts +8 -0
- package/dist/console/ui/Routes.js +70 -0
- package/dist/console/ui/Services.d.ts +10 -0
- package/dist/console/ui/Services.js +246 -0
- package/dist/console/ui/Shell.d.ts +10 -0
- package/dist/console/ui/Shell.js +7 -0
- package/dist/console/ui/System.d.ts +4 -0
- package/dist/console/ui/System.js +35 -0
- package/dist/console/ui/Traces.d.ts +12 -0
- package/dist/console/ui/Traces.js +179 -0
- package/dist/datastar/actions/fetch.d.ts +1 -1
- package/dist/datastar/actions/fetch.js +10 -18
- package/dist/datastar/actions/peek.js +1 -2
- package/dist/datastar/actions/setAll.js +1 -2
- package/dist/datastar/actions/toggleAll.js +1 -2
- package/dist/datastar/attributes/attr.js +1 -2
- package/dist/datastar/attributes/bind.js +10 -18
- package/dist/datastar/attributes/class.js +2 -5
- package/dist/datastar/attributes/computed.js +2 -3
- package/dist/datastar/attributes/effect.js +1 -2
- package/dist/datastar/attributes/indicator.js +2 -4
- package/dist/datastar/attributes/init.js +2 -3
- package/dist/datastar/attributes/jsonSignals.js +1 -2
- package/dist/datastar/attributes/on.js +41 -22
- package/dist/datastar/attributes/onIntersect.js +2 -3
- package/dist/datastar/attributes/onInterval.js +2 -3
- package/dist/datastar/attributes/onSignalPatch.js +2 -4
- package/dist/datastar/attributes/ref.js +1 -2
- package/dist/datastar/attributes/show.js +1 -2
- package/dist/datastar/attributes/signals.js +1 -2
- package/dist/datastar/attributes/style.js +6 -12
- package/dist/datastar/attributes/text.js +1 -2
- package/dist/datastar/engine.d.ts +13 -7
- package/dist/datastar/engine.js +76 -48
- package/dist/datastar/happydom.d.ts +1 -0
- package/dist/datastar/happydom.js +8 -0
- package/dist/datastar/index.d.ts +1 -1
- package/dist/datastar/index.js +1 -1
- package/dist/datastar/utils.js +4 -7
- package/dist/datastar/watchers/patchElements.js +24 -45
- package/dist/datastar/watchers/patchSignals.js +1 -2
- package/dist/experimental/EncryptedCookies.d.ts +2 -5
- package/dist/experimental/EncryptedCookies.js +17 -48
- package/dist/experimental/index.d.ts +0 -1
- package/dist/experimental/index.js +0 -1
- package/dist/hyper/Hyper.d.ts +2 -9
- package/dist/hyper/Hyper.js +1 -12
- package/dist/hyper/HyperHtml.d.ts +1 -1
- package/dist/hyper/HyperHtml.js +18 -12
- package/dist/hyper/HyperHtml.test.d.ts +1 -0
- package/dist/hyper/HyperHtml.test.js +197 -0
- package/dist/hyper/HyperRoute.test.js +14 -3
- package/dist/hyper/html.d.ts +11 -0
- package/dist/hyper/html.js +30 -0
- package/dist/hyper/index.d.ts +2 -0
- package/dist/hyper/index.js +1 -0
- package/dist/hyper/jsx-runtime.d.ts +1 -1
- package/dist/hyper/jsx-runtime.js +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/lint/plugin.d.ts +86 -0
- package/dist/lint/plugin.js +341 -0
- package/dist/node/NodeFileSystem.d.ts +2 -2
- package/dist/node/NodeFileSystem.js +4 -14
- package/dist/sql/bun/index.d.ts +3 -0
- package/dist/sql/bun/index.js +75 -0
- package/dist/sql/mssql/docker.d.ts +2 -0
- package/dist/sql/mssql/docker.js +67 -0
- package/dist/sql/mssql/index.d.ts +21 -0
- package/dist/sql/mssql/index.js +113 -0
- package/dist/testing/TestLogger.js +4 -1
- package/dist/testing/index.d.ts +0 -1
- package/dist/testing/index.js +0 -1
- package/dist/testing/utils.d.ts +3 -3
- package/dist/testing/utils.js +4 -4
- package/dist/x/cloudflare/CloudflareTunnel.d.ts +2 -5
- package/dist/x/cloudflare/CloudflareTunnel.js +14 -27
- package/dist/x/datastar/Datastar.d.ts +1 -1
- package/dist/x/datastar/Datastar.js +13 -12
- package/dist/x/datastar/index.d.ts +1 -2
- package/dist/x/datastar/index.js +1 -2
- package/dist/x/tailscale/TailscaleTunnel.d.ts +15 -0
- package/dist/x/tailscale/TailscaleTunnel.js +68 -0
- package/dist/x/tailscale/index.d.ts +1 -0
- package/dist/x/tailscale/index.js +1 -0
- package/dist/x/tailwind/TailwindPlugin.js +19 -19
- package/dist/x/tailwind/compile.d.ts +2 -2
- package/dist/x/tailwind/compile.js +2 -4
- package/package.json +22 -10
- package/src/ChildProcess.ts +145 -0
- package/src/PlatformError.ts +27 -50
- package/src/Route.ts +2 -2
- package/src/RouteError.ts +76 -0
- package/src/RouteHttp.ts +13 -5
- package/src/RouteSchema.ts +96 -1
- package/src/RouteTree.ts +12 -0
- package/src/Sql.ts +51 -0
- package/src/SqlIntrospect.ts +620 -0
- package/src/Start.ts +15 -3
- package/src/System.ts +43 -0
- package/src/Values.ts +7 -0
- package/src/bun/BunChildProcessSpawner.ts +143 -0
- package/src/bun/BunRoute.ts +5 -2
- package/src/bun/BunServer.ts +22 -1
- package/src/bun/index.ts +1 -0
- package/src/bundler/BundleRoute.ts +66 -0
- package/src/console/Console.ts +42 -0
- package/src/console/ConsoleErrors.ts +213 -0
- package/src/console/ConsoleLogger.ts +56 -0
- package/src/console/ConsoleMetrics.ts +72 -0
- package/src/console/ConsoleProcess.ts +59 -0
- package/src/console/ConsoleStore.ts +187 -0
- package/src/console/ConsoleTracer.ts +107 -0
- package/src/console/Simulation.ts +814 -0
- package/src/console/console.html +340 -0
- package/src/console/index.ts +3 -0
- package/src/console/routes/errors/route.tsx +97 -0
- package/src/console/routes/fiberDetail.tsx +54 -0
- package/src/console/routes/fibers/route.tsx +45 -0
- package/src/console/routes/git/route.tsx +64 -0
- package/src/console/routes/layout.tsx +4 -0
- package/src/console/routes/logs/route.tsx +77 -0
- package/src/console/routes/metrics/route.tsx +36 -0
- package/src/console/routes/route.tsx +8 -0
- package/src/console/routes/routes/route.tsx +30 -0
- package/src/console/routes/services/route.tsx +21 -0
- package/src/console/routes/system/route.tsx +43 -0
- package/src/console/routes/traceDetail.tsx +22 -0
- package/src/console/routes/traces/route.tsx +81 -0
- package/src/console/routes/tree.ts +30 -0
- package/src/console/ui/Errors.tsx +76 -0
- package/src/console/ui/Fibers.tsx +321 -0
- package/src/console/ui/Git.tsx +182 -0
- package/src/console/ui/Logs.tsx +46 -0
- package/src/console/ui/Metrics.tsx +78 -0
- package/src/console/ui/Routes.tsx +125 -0
- package/src/console/ui/Services.tsx +273 -0
- package/src/console/ui/Shell.tsx +62 -0
- package/src/console/ui/System.tsx +131 -0
- package/src/console/ui/Traces.tsx +426 -0
- package/src/datastar/README.md +6 -1
- package/src/datastar/actions/fetch.ts +0 -1
- package/src/datastar/attributes/on.ts +40 -20
- package/src/datastar/engine.ts +51 -0
- package/src/datastar/jsx.d.ts +79 -0
- package/src/hyper/Hyper.ts +1 -16
- package/src/hyper/HyperHtml.ts +6 -4
- package/src/hyper/HyperRoute.ts +2 -1
- package/src/hyper/html.ts +47 -0
- package/src/hyper/index.ts +2 -0
- package/src/hyper/jsx.d.ts +5 -3
- package/src/index.ts +1 -0
- package/src/lint/plugin.js +129 -0
- package/src/sql/bun/index.ts +147 -0
- package/src/sql/mssql/docker.ts +117 -0
- package/src/sql/mssql/index.ts +223 -0
- package/src/sql/mssql/mssql.d.ts +41 -0
- package/src/x/cloudflare/CloudflareTunnel.ts +8 -36
- package/src/x/tailscale/TailscaleTunnel.ts +113 -0
- package/src/x/tailscale/index.ts +1 -0
- package/src/x/datastar/Datastar.ts +0 -61
- package/src/x/datastar/index.ts +0 -2
- 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,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,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,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,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>;
|