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,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,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,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
|
-
|
|
335
|
-
|
|
336
|
-
|
|
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 { 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",
|