claude-session-dashboard 0.4.0 → 0.4.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (29) hide show
  1. package/dist/client/assets/{_dashboard-CAikP08_.js → _dashboard-t702m22X.js} +1 -1
  2. package/dist/client/assets/{_sessionId-C3iR5Lrv.js → _sessionId-D4Tpmmb5.js} +2 -2
  3. package/dist/client/assets/app-DREGBD44.css +1 -0
  4. package/dist/client/assets/{createServerFn-wbChEQBm.js → createServerFn-BYTDoNe-.js} +1 -1
  5. package/dist/client/assets/{index-Bk56JBgW.js → index-DnK_zh3s.js} +1 -1
  6. package/dist/client/assets/{main-CT7cRkW3.js → main-CV28H4XG.js} +3 -3
  7. package/dist/client/assets/{sessions.queries-jGqvP0O9.js → sessions.queries-tzrs5GhP.js} +1 -1
  8. package/dist/client/assets/{settings-CR-1d6g6.js → settings-D8yv1q93.js} +1 -1
  9. package/dist/client/assets/{settings.types-BEt_cHU1.js → settings.types-CMYAW0cQ.js} +1 -1
  10. package/dist/client/assets/{stats-7Tm8ZX4J.js → stats-C_6E4jyb.js} +1 -1
  11. package/dist/client/assets/{useSessionCost-CGXrAUii.js → useSessionCost-BBu3AmcX.js} +1 -1
  12. package/dist/server/assets/{_sessionId-BvDwvNyA.js → _sessionId-DyFxvcBN.js} +2 -2
  13. package/dist/server/assets/_tanstack-start-manifest_v-RaGuPsWw.js +4 -0
  14. package/dist/server/assets/{claude-path-B2oho3NT.js → claude-path-BdwflgZ1.js} +2 -2
  15. package/dist/server/assets/{index-Biupny11.js → index-Bx7vBs4O.js} +1 -1
  16. package/dist/server/assets/{project-analytics.server-t1bM6wAa.js → project-analytics.server-BsmZ4xil.js} +3 -3
  17. package/dist/server/assets/{router-kB-tCwY9.js → router-Cd4jLk4T.js} +5 -5
  18. package/dist/server/assets/{session-detail.server-IUw67jz-.js → session-detail.server-BDup9xb0.js} +2 -2
  19. package/dist/server/assets/{session-parser-CIucKYBT.js → session-parser-75iTexM0.js} +91 -17
  20. package/dist/server/assets/{session-scanner-1h9TTTAV.js → session-scanner-CPud4KGP.js} +14 -6
  21. package/dist/server/assets/{sessions.server-Cpffr3MU.js → sessions.server-60puUvjv.js} +3 -3
  22. package/dist/server/assets/{settings-jxAA3KAS.js → settings-KKaz1ty7.js} +1 -1
  23. package/dist/server/assets/{stats-CzGBAoxT.js → stats-Bsrkajci.js} +1 -1
  24. package/dist/server/assets/stats.server-qTOvID9-.js +395 -0
  25. package/dist/server/server.js +13 -13
  26. package/package.json +1 -1
  27. package/dist/client/assets/app-DNBe9Acr.css +0 -1
  28. package/dist/server/assets/_tanstack-start-manifest_v-8fGraPRa.js +0 -4
  29. package/dist/server/assets/stats.server-DXJiLqey.js +0 -144
@@ -0,0 +1,395 @@
1
+ import { c as createServerRpc } from "./createServerRpc-Bd3B-Ah9.js";
2
+ import * as fs from "node:fs";
3
+ import { g as getStatsPath } from "./claude-path-BdwflgZ1.js";
4
+ import { s as scanAllSessions, w as scanAllSessionsWithPaths } from "./session-scanner-CPud4KGP.js";
5
+ import { a as parseDetail } from "./session-parser-75iTexM0.js";
6
+ import * as path from "node:path";
7
+ import * as os from "node:os";
8
+ import { z } from "zod";
9
+ import { c as createServerFn } from "../server.js";
10
+ import "@tanstack/history";
11
+ import "@tanstack/router-core/ssr/client";
12
+ import "@tanstack/router-core";
13
+ import "node:async_hooks";
14
+ import "@tanstack/router-core/ssr/server";
15
+ import "h3-v2";
16
+ import "tiny-invariant";
17
+ import "seroval";
18
+ import "react/jsx-runtime";
19
+ import "@tanstack/react-router/ssr/server";
20
+ import "@tanstack/react-router";
21
+ const CACHE_VERSION = 1;
22
+ function getCacheDir() {
23
+ return path.join(os.homedir(), ".claude-dashboard", "cache");
24
+ }
25
+ function getCachePath(cacheKey) {
26
+ return path.join(getCacheDir(), `${cacheKey}.cache.json`);
27
+ }
28
+ function readDiskCache(cacheKey, sourceMtimeMs, schema) {
29
+ try {
30
+ const cachePath = getCachePath(cacheKey);
31
+ if (!fs.existsSync(cachePath)) {
32
+ return null;
33
+ }
34
+ const raw = fs.readFileSync(cachePath, "utf-8");
35
+ const parsed = JSON.parse(raw);
36
+ if (parsed.version !== CACHE_VERSION) {
37
+ return null;
38
+ }
39
+ if (parsed.sourceMtimeMs !== sourceMtimeMs) {
40
+ return null;
41
+ }
42
+ const result = schema.safeParse(parsed.data);
43
+ if (!result.success) {
44
+ console.warn(`[disk-cache] Zod validation failed for "${cacheKey}":`, result.error.message);
45
+ return null;
46
+ }
47
+ return result.data;
48
+ } catch (error) {
49
+ const message = error instanceof Error ? error.message : String(error);
50
+ console.warn(`[disk-cache] Read failed for "${cacheKey}":`, message);
51
+ return null;
52
+ }
53
+ }
54
+ function writeDiskCache(cacheKey, sourceFile, sourceMtimeMs, data) {
55
+ try {
56
+ const cacheDir = getCacheDir();
57
+ fs.mkdirSync(cacheDir, { recursive: true });
58
+ const cachePath = getCachePath(cacheKey);
59
+ const tmpPath = `${cachePath}.tmp`;
60
+ const entry = {
61
+ version: CACHE_VERSION,
62
+ sourceFile,
63
+ sourceMtimeMs,
64
+ cachedAt: (/* @__PURE__ */ new Date()).toISOString(),
65
+ data
66
+ };
67
+ fs.writeFileSync(tmpPath, JSON.stringify(entry), "utf-8");
68
+ fs.renameSync(tmpPath, cachePath);
69
+ } catch (error) {
70
+ const message = error instanceof Error ? error.message : String(error);
71
+ console.warn(`[disk-cache] Write failed for "${cacheKey}":`, message);
72
+ }
73
+ }
74
+ const DailyActivitySchema = z.object({
75
+ date: z.string(),
76
+ messageCount: z.number(),
77
+ sessionCount: z.number(),
78
+ toolCallCount: z.number()
79
+ });
80
+ const DailyModelTokensSchema = z.object({
81
+ date: z.string(),
82
+ tokensByModel: z.record(z.string(), z.number())
83
+ });
84
+ const ModelUsageSchema = z.record(
85
+ z.string(),
86
+ z.object({
87
+ inputTokens: z.number(),
88
+ outputTokens: z.number(),
89
+ cacheReadInputTokens: z.number(),
90
+ cacheCreationInputTokens: z.number(),
91
+ webSearchRequests: z.number().optional(),
92
+ costUSD: z.number().optional()
93
+ })
94
+ );
95
+ const LongestSessionSchema = z.object({
96
+ sessionId: z.string(),
97
+ duration: z.number(),
98
+ messageCount: z.number(),
99
+ timestamp: z.string()
100
+ });
101
+ const StatsCacheSchema = z.object({
102
+ version: z.number(),
103
+ lastComputedDate: z.string(),
104
+ dailyActivity: z.array(DailyActivitySchema),
105
+ dailyModelTokens: z.array(DailyModelTokensSchema),
106
+ modelUsage: ModelUsageSchema,
107
+ totalSessions: z.number(),
108
+ totalMessages: z.number(),
109
+ longestSession: LongestSessionSchema,
110
+ firstSessionDate: z.string(),
111
+ hourCounts: z.record(z.string(), z.number()),
112
+ totalSpeculationTimeSavedMs: z.number().optional()
113
+ });
114
+ let cachedStats = null;
115
+ let mergedCache = null;
116
+ const MERGE_STALENESS_MS = 60000;
117
+ function getTodayDateString() {
118
+ return new Date().toISOString().split("T")[0];
119
+ }
120
+ function extractDateString(isoOrDate) {
121
+ return isoOrDate.split("T")[0];
122
+ }
123
+ function updateHourCounts(hourCounts, session) {
124
+ const startedAt = session.startedAt;
125
+ if (!startedAt) return;
126
+ try {
127
+ const date = new Date(startedAt);
128
+ const hour = date.getHours().toString();
129
+ hourCounts[hour] = (hourCounts[hour] ?? 0) + 1;
130
+ } catch {
131
+ }
132
+ }
133
+ async function parseDetailsInBatches(sessions, batchSize = 10) {
134
+ const results = new Map();
135
+ for (let i = 0; i < sessions.length; i += batchSize) {
136
+ const batch = sessions.slice(i, i + batchSize);
137
+ const details = await Promise.all(
138
+ batch.map(async (s) => {
139
+ try {
140
+ return {
141
+ sessionId: s.sessionId,
142
+ detail: await parseDetail(s.filePath, s.sessionId, s.projectPath, s.projectName),
143
+ };
144
+ } catch {
145
+ return null;
146
+ }
147
+ })
148
+ );
149
+ for (const result of details) {
150
+ if (result) results.set(result.sessionId, result.detail);
151
+ }
152
+ }
153
+ return results;
154
+ }
155
+ async function maybeEnrichWithRecentSessions(stats, mtimeMs) {
156
+ const today = getTodayDateString();
157
+ const lastComputed = extractDateString(stats.lastComputedDate);
158
+ if (lastComputed >= today) {
159
+ return stats;
160
+ }
161
+ if (mergedCache && mergedCache.mtimeMs === mtimeMs && Date.now() - mergedCache.mergedAt < MERGE_STALENESS_MS) {
162
+ return mergedCache.data;
163
+ }
164
+ try {
165
+ const merged = await mergeRecentSessions(stats);
166
+ mergedCache = { mtimeMs, mergedAt: Date.now(), data: merged };
167
+ return merged;
168
+ } catch {
169
+ return stats;
170
+ }
171
+ }
172
+ async function mergeRecentSessions(stats) {
173
+ const summaries = await scanAllSessionsWithPaths();
174
+ const cutoffDate = extractDateString(stats.lastComputedDate);
175
+ const recentSessions = summaries.filter((s) => {
176
+ const sessionDate = extractDateString(s.lastActiveAt ?? s.startedAt);
177
+ return sessionDate > cutoffDate;
178
+ });
179
+ if (recentSessions.length === 0) {
180
+ return stats;
181
+ }
182
+ const detailMap = await parseDetailsInBatches(recentSessions);
183
+ const activityMap = new Map();
184
+ for (const entry of stats.dailyActivity) {
185
+ activityMap.set(entry.date, {
186
+ messageCount: entry.messageCount,
187
+ sessionCount: entry.sessionCount,
188
+ toolCallCount: entry.toolCallCount
189
+ });
190
+ }
191
+ const modelTokensMap = new Map();
192
+ for (const entry of stats.dailyModelTokens) {
193
+ modelTokensMap.set(entry.date, { ...entry.tokensByModel });
194
+ }
195
+ const hourCounts = { ...stats.hourCounts };
196
+ const modelUsage = {};
197
+ for (const [model, usage] of Object.entries(stats.modelUsage)) {
198
+ modelUsage[model] = { ...usage };
199
+ }
200
+ let additionalMessages = 0;
201
+ const additionalSessions = recentSessions.length;
202
+ let longestSession = { ...stats.longestSession };
203
+ const existingSessionCount = stats.totalSessions;
204
+ for (const s of recentSessions) {
205
+ const date = extractDateString(s.lastActiveAt ?? s.startedAt);
206
+ const detail = detailMap.get(s.sessionId);
207
+ const cur = activityMap.get(date) ?? { messageCount: 0, sessionCount: 0, toolCallCount: 0 };
208
+ cur.sessionCount += 1;
209
+ if (detail) {
210
+ cur.messageCount += detail.turns.length;
211
+ cur.toolCallCount += Object.values(detail.toolFrequency)
212
+ .reduce((sum, n) => sum + n, 0);
213
+ const dayTokens = modelTokensMap.get(date) ?? {};
214
+ for (const [model, usage] of Object.entries(detail.tokensByModel)) {
215
+ const total = usage.inputTokens + usage.outputTokens;
216
+ dayTokens[model] = (dayTokens[model] ?? 0) + total;
217
+ }
218
+ modelTokensMap.set(date, dayTokens);
219
+ for (const [model, usage] of Object.entries(detail.tokensByModel)) {
220
+ const existing = modelUsage[model] ?? {
221
+ inputTokens: 0, outputTokens: 0,
222
+ cacheReadInputTokens: 0, cacheCreationInputTokens: 0,
223
+ };
224
+ existing.inputTokens += usage.inputTokens;
225
+ existing.outputTokens += usage.outputTokens;
226
+ existing.cacheReadInputTokens += usage.cacheReadInputTokens;
227
+ existing.cacheCreationInputTokens += usage.cacheCreationInputTokens;
228
+ modelUsage[model] = existing;
229
+ }
230
+ additionalMessages += detail.turns.length;
231
+ } else {
232
+ cur.messageCount += s.messageCount;
233
+ additionalMessages += s.messageCount;
234
+ if (!modelTokensMap.has(date)) {
235
+ modelTokensMap.set(date, {});
236
+ }
237
+ }
238
+ activityMap.set(date, cur);
239
+ updateHourCounts(hourCounts, s);
240
+ if (s.durationMs > longestSession.duration) {
241
+ longestSession = {
242
+ sessionId: s.sessionId,
243
+ duration: s.durationMs,
244
+ messageCount: detail?.turns.length ?? s.messageCount,
245
+ timestamp: s.lastActiveAt ?? s.startedAt
246
+ };
247
+ }
248
+ }
249
+ const dailyActivity = Array.from(activityMap.entries()).map(([date, v]) => ({
250
+ date,
251
+ messageCount: v.messageCount,
252
+ sessionCount: v.sessionCount,
253
+ toolCallCount: v.toolCallCount
254
+ })).sort((a, b) => a.date < b.date ? -1 : 1);
255
+ const dailyModelTokens = Array.from(modelTokensMap.entries()).map(([date, tokensByModel]) => ({ date, tokensByModel })).sort((a, b) => a.date < b.date ? -1 : 1);
256
+ return {
257
+ ...stats,
258
+ dailyActivity,
259
+ dailyModelTokens,
260
+ modelUsage,
261
+ totalSessions: existingSessionCount + additionalSessions,
262
+ totalMessages: stats.totalMessages + additionalMessages,
263
+ longestSession,
264
+ hourCounts
265
+ };
266
+ }
267
+ async function computeStatsFromSessions() {
268
+ try {
269
+ const summaries = await scanAllSessionsWithPaths();
270
+ const detailMap = await parseDetailsInBatches(summaries);
271
+ const activityMap = new Map();
272
+ const modelTokensMap = new Map();
273
+ const modelUsage = {};
274
+ const hourCounts = {};
275
+ let totalMessages = 0;
276
+ let longestSession = { sessionId: "", duration: 0, messageCount: 0, timestamp: "" };
277
+ let firstSessionDate = null;
278
+ for (const s of summaries) {
279
+ const d = (s.lastActiveAt ?? s.startedAt).split("T")[0];
280
+ const detail = detailMap.get(s.sessionId);
281
+ const cur = activityMap.get(d) ?? { messageCount: 0, sessionCount: 0, toolCallCount: 0 };
282
+ cur.sessionCount += 1;
283
+ if (detail) {
284
+ cur.messageCount += detail.turns.length;
285
+ cur.toolCallCount += Object.values(detail.toolFrequency)
286
+ .reduce((sum, n) => sum + n, 0);
287
+ totalMessages += detail.turns.length;
288
+ const dayTokens = modelTokensMap.get(d) ?? {};
289
+ for (const [model, usage] of Object.entries(detail.tokensByModel)) {
290
+ const total = usage.inputTokens + usage.outputTokens;
291
+ dayTokens[model] = (dayTokens[model] ?? 0) + total;
292
+ }
293
+ modelTokensMap.set(d, dayTokens);
294
+ for (const [model, usage] of Object.entries(detail.tokensByModel)) {
295
+ const existing = modelUsage[model] ?? {
296
+ inputTokens: 0, outputTokens: 0,
297
+ cacheReadInputTokens: 0, cacheCreationInputTokens: 0,
298
+ };
299
+ existing.inputTokens += usage.inputTokens;
300
+ existing.outputTokens += usage.outputTokens;
301
+ existing.cacheReadInputTokens += usage.cacheReadInputTokens;
302
+ existing.cacheCreationInputTokens += usage.cacheCreationInputTokens;
303
+ modelUsage[model] = existing;
304
+ }
305
+ } else {
306
+ cur.messageCount += s.messageCount;
307
+ totalMessages += s.messageCount;
308
+ if (!modelTokensMap.has(d)) modelTokensMap.set(d, {});
309
+ }
310
+ activityMap.set(d, cur);
311
+ updateHourCounts(hourCounts, s);
312
+ const msgCount = detail?.turns.length ?? s.messageCount;
313
+ if (s.durationMs > longestSession.duration) {
314
+ longestSession = {
315
+ sessionId: s.sessionId,
316
+ duration: s.durationMs,
317
+ messageCount: msgCount,
318
+ timestamp: s.lastActiveAt ?? s.startedAt
319
+ };
320
+ }
321
+ if (!firstSessionDate || s.startedAt < firstSessionDate) {
322
+ firstSessionDate = s.startedAt;
323
+ }
324
+ }
325
+ const dailyActivity = Array.from(activityMap.entries())
326
+ .map(([date, v]) => ({ date, ...v }))
327
+ .sort((a, b) => a.date < b.date ? -1 : 1);
328
+ const dailyModelTokens = Array.from(modelTokensMap.entries())
329
+ .map(([date, tokensByModel]) => ({ date, tokensByModel }))
330
+ .sort((a, b) => a.date < b.date ? -1 : 1);
331
+ return {
332
+ version: 1,
333
+ lastComputedDate: new Date().toISOString(),
334
+ dailyActivity,
335
+ dailyModelTokens,
336
+ modelUsage,
337
+ totalSessions: summaries.length,
338
+ totalMessages,
339
+ longestSession: {
340
+ sessionId: longestSession.sessionId,
341
+ duration: longestSession.duration,
342
+ messageCount: longestSession.messageCount,
343
+ timestamp: longestSession.timestamp || new Date().toISOString()
344
+ },
345
+ firstSessionDate: firstSessionDate ?? new Date().toISOString(),
346
+ hourCounts
347
+ };
348
+ } catch (error) {
349
+ return null;
350
+ }
351
+ }
352
+ async function parseStats() {
353
+ const statsPath = getStatsPath();
354
+ const stat = await fs.promises.stat(statsPath).catch(() => null);
355
+ if (!stat) {
356
+ try {
357
+ const computed = await computeStatsFromSessions();
358
+ return computed;
359
+ } catch {
360
+ return null;
361
+ }
362
+ }
363
+ if (cachedStats && cachedStats.mtimeMs === stat.mtimeMs) {
364
+ return maybeEnrichWithRecentSessions(cachedStats.data, stat.mtimeMs);
365
+ }
366
+ const diskResult = readDiskCache("stats", stat.mtimeMs, StatsCacheSchema);
367
+ if (diskResult) {
368
+ cachedStats = { mtimeMs: stat.mtimeMs, data: diskResult };
369
+ return maybeEnrichWithRecentSessions(diskResult, stat.mtimeMs);
370
+ }
371
+ try {
372
+ const raw = await fs.promises.readFile(statsPath, "utf-8");
373
+ const parsed = JSON.parse(raw);
374
+ const result = StatsCacheSchema.parse(parsed);
375
+ writeDiskCache("stats", statsPath, stat.mtimeMs, result);
376
+ cachedStats = { mtimeMs: stat.mtimeMs, data: result };
377
+ return maybeEnrichWithRecentSessions(result, stat.mtimeMs);
378
+ } catch {
379
+ const computed = await computeStatsFromSessions();
380
+ return computed;
381
+ }
382
+ }
383
+ const getStats_createServerFn_handler = createServerRpc({
384
+ id: "4b9a58c176f487b49800a372100037cdf33cf048f3592a449f115c7e3f5ea799",
385
+ name: "getStats",
386
+ filename: "src/features/stats/stats.server.ts"
387
+ }, (opts) => getStats.__executeServer(opts));
388
+ const getStats = createServerFn({
389
+ method: "GET"
390
+ }).handler(getStats_createServerFn_handler, async () => {
391
+ return parseStats();
392
+ });
393
+ export {
394
+ getStats_createServerFn_handler
395
+ };
@@ -423,7 +423,7 @@ function getResponse() {
423
423
  return event.res;
424
424
  }
425
425
  async function getStartManifest(matchedRoutes) {
426
- const { tsrStartManifest } = await import("./assets/_tanstack-start-manifest_v-8fGraPRa.js");
426
+ const { tsrStartManifest } = await import("./assets/_tanstack-start-manifest_v-RaGuPsWw.js");
427
427
  const startManifest = tsrStartManifest();
428
428
  const rootRoute = startManifest.routes[rootRouteId] = startManifest.routes[rootRouteId] || {};
429
429
  rootRoute.assets = rootRoute.assets || [];
@@ -577,12 +577,12 @@ function createMultiplexedStream(jsonStream, rawStreams) {
577
577
  }
578
578
  });
579
579
  }
580
- const manifest = { "ff8a3161afdfa175e9c519e4146a56ab5bce6e80745e99cfc2191ebbb7a859bb": {
581
- functionName: "getSessionDetail_createServerFn_handler",
582
- importer: () => import("./assets/session-detail.server-IUw67jz-.js")
583
- }, "4b9a58c176f487b49800a372100037cdf33cf048f3592a449f115c7e3f5ea799": {
580
+ const manifest = { "4b9a58c176f487b49800a372100037cdf33cf048f3592a449f115c7e3f5ea799": {
584
581
  functionName: "getStats_createServerFn_handler",
585
- importer: () => import("./assets/stats.server-DXJiLqey.js")
582
+ importer: () => import("./assets/stats.server-qTOvID9-.js")
583
+ }, "64052f224a1d6696436e5d3deeee2b798f0742e1292ffabd038c3a7bf75e6fcb": {
584
+ functionName: "getProjectAnalytics_createServerFn_handler",
585
+ importer: () => import("./assets/project-analytics.server-BsmZ4xil.js")
586
586
  }, "810657681a273df5b4e58f0d8fcc6a5451598b489431b9bcaa98eea0ad815da8": {
587
587
  functionName: "getSettings_createServerFn_handler",
588
588
  importer: () => import("./assets/settings.server-6B2PvLgf.js")
@@ -591,16 +591,16 @@ const manifest = { "ff8a3161afdfa175e9c519e4146a56ab5bce6e80745e99cfc2191ebbb7a8
591
591
  importer: () => import("./assets/settings.server-6B2PvLgf.js")
592
592
  }, "bf8e4a7901f1843bdc9c46be1ad5ad59c615b8bbe611b73eb3ff28f20e43ee0d": {
593
593
  functionName: "getSessionList_createServerFn_handler",
594
- importer: () => import("./assets/sessions.server-Cpffr3MU.js")
594
+ importer: () => import("./assets/sessions.server-60puUvjv.js")
595
595
  }, "839d29fe93dfa2a6d506af7b48ca25197190a5ff4c796e970ddfdc6e8c98827f": {
596
596
  functionName: "getActiveSessionList_createServerFn_handler",
597
- importer: () => import("./assets/sessions.server-Cpffr3MU.js")
597
+ importer: () => import("./assets/sessions.server-60puUvjv.js")
598
598
  }, "a3f42f9012fd83586787da8f7cb90649da739dd947d867eb67572f68735ff495": {
599
599
  functionName: "getPaginatedSessions_createServerFn_handler",
600
- importer: () => import("./assets/sessions.server-Cpffr3MU.js")
601
- }, "64052f224a1d6696436e5d3deeee2b798f0742e1292ffabd038c3a7bf75e6fcb": {
602
- functionName: "getProjectAnalytics_createServerFn_handler",
603
- importer: () => import("./assets/project-analytics.server-t1bM6wAa.js")
600
+ importer: () => import("./assets/sessions.server-60puUvjv.js")
601
+ }, "ff8a3161afdfa175e9c519e4146a56ab5bce6e80745e99cfc2191ebbb7a859bb": {
602
+ functionName: "getSessionDetail_createServerFn_handler",
603
+ importer: () => import("./assets/session-detail.server-BDup9xb0.js")
604
604
  } };
605
605
  async function getServerFnById(id) {
606
606
  const serverFnInfo = manifest[id];
@@ -1016,7 +1016,7 @@ let entriesPromise;
1016
1016
  let baseManifestPromise;
1017
1017
  let cachedFinalManifestPromise;
1018
1018
  async function loadEntries() {
1019
- const routerEntry = await import("./assets/router-kB-tCwY9.js").then((n) => n.r);
1019
+ const routerEntry = await import("./assets/router-Cd4jLk4T.js").then((n) => n.r);
1020
1020
  const startEntry = await import("./assets/start-HYkvq4Ni.js");
1021
1021
  return { startEntry, routerEntry };
1022
1022
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "claude-session-dashboard",
3
- "version": "0.4.0",
3
+ "version": "0.4.2",
4
4
  "description": "Local observability dashboard for Claude Code sessions",
5
5
  "type": "module",
6
6
  "license": "MIT",
@@ -1 +0,0 @@
1
- @layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-200:oklch(88.5% .062 18.334);--color-red-300:oklch(80.8% .114 19.571);--color-red-400:oklch(70.4% .191 22.216);--color-red-500:oklch(63.7% .237 25.331);--color-red-900:oklch(39.6% .141 25.723);--color-red-950:oklch(25.8% .092 26.042);--color-amber-300:oklch(87.9% .169 91.605);--color-amber-400:oklch(82.8% .189 84.429);--color-amber-500:oklch(76.9% .188 70.08);--color-emerald-300:oklch(84.5% .143 164.978);--color-emerald-400:oklch(76.5% .177 163.223);--color-emerald-500:oklch(69.6% .17 162.48);--color-emerald-800:oklch(43.2% .095 166.913);--color-emerald-900:oklch(37.8% .077 168.94);--color-cyan-400:oklch(78.9% .154 211.53);--color-indigo-300:oklch(78.5% .115 274.713);--color-indigo-400:oklch(67.3% .182 276.935);--color-indigo-500:oklch(58.5% .233 277.117);--color-indigo-900:oklch(35.9% .144 278.697);--color-indigo-950:oklch(25.7% .09 281.288);--color-violet-400:oklch(70.2% .183 293.541);--color-purple-400:oklch(71.4% .203 305.504);--color-purple-500:oklch(62.7% .265 303.9);--color-pink-400:oklch(71.8% .202 349.761);--color-gray-100:#eae6dc;--color-gray-200:#e0dbd0;--color-gray-300:#cdc8b8;--color-gray-400:#a39e90;--color-gray-500:#7a7668;--color-gray-600:#565349;--color-gray-700:#3d3b36;--color-gray-800:#2a2926;--color-gray-900:#1c1c1a;--color-gray-950:#141413;--color-white:#fff;--spacing:.25rem;--container-5xl:64rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--animate-ping:ping 1s cubic-bezier(0,0,.2,1)infinite;--animate-pulse:pulse 2s cubic-bezier(.4,0,.6,1)infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-brand-300:#f0b8a0;--color-brand-400:#e09070;--color-brand-500:#d97757;--color-brand-600:#c4643f}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.-top-8{top:calc(var(--spacing)*-8)}.right-0{right:calc(var(--spacing)*0)}.bottom-0{bottom:calc(var(--spacing)*0)}.left-1\/2{left:50%}.z-10{z-index:10}.z-50{z-index:50}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.mx-auto{margin-inline:auto}.mt-0\.5{margin-top:calc(var(--spacing)*.5)}.mt-1{margin-top:calc(var(--spacing)*1)}.mt-1\.5{margin-top:calc(var(--spacing)*1.5)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-3{margin-top:calc(var(--spacing)*3)}.mt-4{margin-top:calc(var(--spacing)*4)}.mt-6{margin-top:calc(var(--spacing)*6)}.mb-1{margin-bottom:calc(var(--spacing)*1)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-3{margin-bottom:calc(var(--spacing)*3)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.ml-1{margin-left:calc(var(--spacing)*1)}.ml-2{margin-left:calc(var(--spacing)*2)}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-1\.5{height:calc(var(--spacing)*1.5)}.h-2{height:calc(var(--spacing)*2)}.h-3{height:calc(var(--spacing)*3)}.h-3\.5{height:calc(var(--spacing)*3.5)}.h-4{height:calc(var(--spacing)*4)}.h-5{height:calc(var(--spacing)*5)}.h-6{height:calc(var(--spacing)*6)}.h-8{height:calc(var(--spacing)*8)}.h-14{height:calc(var(--spacing)*14)}.h-20{height:calc(var(--spacing)*20)}.h-28{height:calc(var(--spacing)*28)}.h-32{height:calc(var(--spacing)*32)}.h-64{height:calc(var(--spacing)*64)}.h-72{height:calc(var(--spacing)*72)}.h-full{height:100%}.max-h-64{max-height:calc(var(--spacing)*64)}.min-h-screen{min-height:100vh}.w-2{width:calc(var(--spacing)*2)}.w-3{width:calc(var(--spacing)*3)}.w-3\.5{width:calc(var(--spacing)*3.5)}.w-4{width:calc(var(--spacing)*4)}.w-9{width:calc(var(--spacing)*9)}.w-16{width:calc(var(--spacing)*16)}.w-20{width:calc(var(--spacing)*20)}.w-32{width:calc(var(--spacing)*32)}.w-48{width:calc(var(--spacing)*48)}.w-56{width:calc(var(--spacing)*56)}.w-full{width:100%}.max-w-5xl{max-width:var(--container-5xl)}.max-w-48{max-width:calc(var(--spacing)*48)}.min-w-0{min-width:calc(var(--spacing)*0)}.min-w-\[2rem\]{min-width:2rem}.min-w-\[3rem\]{min-width:3rem}.min-w-\[200px\]{min-width:200px}.flex-1{flex:1}.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x: -50% ;translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-\[3px\]{--tw-translate-x:3px;translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-\[18px\]{--tw-translate-x:18px;translate:var(--tw-translate-x)var(--tw-translate-y)}.rotate-45{rotate:45deg}.rotate-180{rotate:180deg}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.animate-ping{animation:var(--animate-ping)}.animate-pulse{animation:var(--animate-pulse)}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-baseline{align-items:baseline}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-0\.5{gap:calc(var(--spacing)*.5)}.gap-1{gap:calc(var(--spacing)*1)}.gap-1\.5{gap:calc(var(--spacing)*1.5)}.gap-2{gap:calc(var(--spacing)*2)}.gap-2\.5{gap:calc(var(--spacing)*2.5)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}:where(.space-y-0\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*.5)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*.5)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*1)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*1)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-1\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*1.5)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*1.5)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*2)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*3)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*3)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*4)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*6)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*6)*calc(1 - var(--tw-space-y-reverse)))}.gap-x-1{column-gap:calc(var(--spacing)*1)}.gap-x-3{column-gap:calc(var(--spacing)*3)}.gap-y-1{row-gap:calc(var(--spacing)*1)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-t{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.rounded-l-lg{border-top-left-radius:var(--radius-lg);border-bottom-left-radius:var(--radius-lg)}.rounded-r-lg{border-top-right-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-brand-500{border-color:var(--color-brand-500)}.border-brand-500\/50{border-color:#d9775780}@supports (color:color-mix(in lab,red,red)){.border-brand-500\/50{border-color:color-mix(in oklab,var(--color-brand-500)50%,transparent)}}.border-emerald-800{border-color:var(--color-emerald-800)}.border-gray-700{border-color:var(--color-gray-700)}.border-gray-800{border-color:var(--color-gray-800)}.border-gray-800\/50{border-color:#2a292680}@supports (color:color-mix(in lab,red,red)){.border-gray-800\/50{border-color:color-mix(in oklab,var(--color-gray-800)50%,transparent)}}.border-indigo-500\/10{border-color:#625fff1a}@supports (color:color-mix(in lab,red,red)){.border-indigo-500\/10{border-color:color-mix(in oklab,var(--color-indigo-500)10%,transparent)}}.border-indigo-500\/20{border-color:#625fff33}@supports (color:color-mix(in lab,red,red)){.border-indigo-500\/20{border-color:color-mix(in oklab,var(--color-indigo-500)20%,transparent)}}.border-red-900\/50{border-color:#82181a80}@supports (color:color-mix(in lab,red,red)){.border-red-900\/50{border-color:color-mix(in oklab,var(--color-red-900)50%,transparent)}}.border-transparent{border-color:#0000}.bg-amber-400{background-color:var(--color-amber-400)}.bg-amber-500{background-color:var(--color-amber-500)}.bg-amber-500\/15{background-color:#f99c0026}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/15{background-color:color-mix(in oklab,var(--color-amber-500)15%,transparent)}}.bg-amber-500\/20{background-color:#f99c0033}@supports (color:color-mix(in lab,red,red)){.bg-amber-500\/20{background-color:color-mix(in oklab,var(--color-amber-500)20%,transparent)}}.bg-brand-400{background-color:var(--color-brand-400)}.bg-brand-500{background-color:var(--color-brand-500)}.bg-brand-500\/10{background-color:#d977571a}@supports (color:color-mix(in lab,red,red)){.bg-brand-500\/10{background-color:color-mix(in oklab,var(--color-brand-500)10%,transparent)}}.bg-brand-500\/15{background-color:#d9775726}@supports (color:color-mix(in lab,red,red)){.bg-brand-500\/15{background-color:color-mix(in oklab,var(--color-brand-500)15%,transparent)}}.bg-brand-500\/20{background-color:#d9775733}@supports (color:color-mix(in lab,red,red)){.bg-brand-500\/20{background-color:color-mix(in oklab,var(--color-brand-500)20%,transparent)}}.bg-brand-600{background-color:var(--color-brand-600)}.bg-emerald-400{background-color:var(--color-emerald-400)}.bg-emerald-500{background-color:var(--color-emerald-500)}.bg-emerald-500\/15{background-color:#00bb7f26}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\/15{background-color:color-mix(in oklab,var(--color-emerald-500)15%,transparent)}}.bg-emerald-500\/20{background-color:#00bb7f33}@supports (color:color-mix(in lab,red,red)){.bg-emerald-500\/20{background-color:color-mix(in oklab,var(--color-emerald-500)20%,transparent)}}.bg-emerald-900\/30{background-color:#004e3b4d}@supports (color:color-mix(in lab,red,red)){.bg-emerald-900\/30{background-color:color-mix(in oklab,var(--color-emerald-900)30%,transparent)}}.bg-gray-500{background-color:var(--color-gray-500)}.bg-gray-500\/15{background-color:#7a766826}@supports (color:color-mix(in lab,red,red)){.bg-gray-500\/15{background-color:color-mix(in oklab,var(--color-gray-500)15%,transparent)}}.bg-gray-500\/20{background-color:#7a766833}@supports (color:color-mix(in lab,red,red)){.bg-gray-500\/20{background-color:color-mix(in oklab,var(--color-gray-500)20%,transparent)}}.bg-gray-600{background-color:var(--color-gray-600)}.bg-gray-700{background-color:var(--color-gray-700)}.bg-gray-800{background-color:var(--color-gray-800)}.bg-gray-800\/40{background-color:#2a292666}@supports (color:color-mix(in lab,red,red)){.bg-gray-800\/40{background-color:color-mix(in oklab,var(--color-gray-800)40%,transparent)}}.bg-gray-800\/50{background-color:#2a292680}@supports (color:color-mix(in lab,red,red)){.bg-gray-800\/50{background-color:color-mix(in oklab,var(--color-gray-800)50%,transparent)}}.bg-gray-900{background-color:var(--color-gray-900)}.bg-gray-900\/50{background-color:#1c1c1a80}@supports (color:color-mix(in lab,red,red)){.bg-gray-900\/50{background-color:color-mix(in oklab,var(--color-gray-900)50%,transparent)}}.bg-gray-950{background-color:var(--color-gray-950)}.bg-gray-950\/40{background-color:#14141366}@supports (color:color-mix(in lab,red,red)){.bg-gray-950\/40{background-color:color-mix(in oklab,var(--color-gray-950)40%,transparent)}}.bg-indigo-500\/15{background-color:#625fff26}@supports (color:color-mix(in lab,red,red)){.bg-indigo-500\/15{background-color:color-mix(in oklab,var(--color-indigo-500)15%,transparent)}}.bg-indigo-500\/20{background-color:#625fff33}@supports (color:color-mix(in lab,red,red)){.bg-indigo-500\/20{background-color:color-mix(in oklab,var(--color-indigo-500)20%,transparent)}}.bg-indigo-900\/30{background-color:#312c854d}@supports (color:color-mix(in lab,red,red)){.bg-indigo-900\/30{background-color:color-mix(in oklab,var(--color-indigo-900)30%,transparent)}}.bg-indigo-950\/15{background-color:#1e1a4d26}@supports (color:color-mix(in lab,red,red)){.bg-indigo-950\/15{background-color:color-mix(in oklab,var(--color-indigo-950)15%,transparent)}}.bg-purple-400{background-color:var(--color-purple-400)}.bg-purple-500{background-color:var(--color-purple-500)}.bg-purple-500\/15{background-color:#ac4bff26}@supports (color:color-mix(in lab,red,red)){.bg-purple-500\/15{background-color:color-mix(in oklab,var(--color-purple-500)15%,transparent)}}.bg-red-500\/15{background-color:#fb2c3626}@supports (color:color-mix(in lab,red,red)){.bg-red-500\/15{background-color:color-mix(in oklab,var(--color-red-500)15%,transparent)}}.bg-red-500\/20{background-color:#fb2c3633}@supports (color:color-mix(in lab,red,red)){.bg-red-500\/20{background-color:color-mix(in oklab,var(--color-red-500)20%,transparent)}}.bg-red-950\/20{background-color:#46080933}@supports (color:color-mix(in lab,red,red)){.bg-red-950\/20{background-color:color-mix(in oklab,var(--color-red-950)20%,transparent)}}.bg-red-950\/30{background-color:#4608094d}@supports (color:color-mix(in lab,red,red)){.bg-red-950\/30{background-color:color-mix(in oklab,var(--color-red-950)30%,transparent)}}.bg-white{background-color:var(--color-white)}.fill-amber-400\/70{fill:#fcbb00b3}@supports (color:color-mix(in lab,red,red)){.fill-amber-400\/70{fill:color-mix(in oklab,var(--color-amber-400)70%,transparent)}}.fill-gray-500{fill:var(--color-gray-500)}.fill-indigo-400\/70{fill:#7d87ffb3}@supports (color:color-mix(in lab,red,red)){.fill-indigo-400\/70{fill:color-mix(in oklab,var(--color-indigo-400)70%,transparent)}}.fill-red-400\/70{fill:#ff6568b3}@supports (color:color-mix(in lab,red,red)){.fill-red-400\/70{fill:color-mix(in oklab,var(--color-red-400)70%,transparent)}}.p-2\.5{padding:calc(var(--spacing)*2.5)}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.px-1{padding-inline:calc(var(--spacing)*1)}.px-1\.5{padding-inline:calc(var(--spacing)*1.5)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-2\.5{padding-inline:calc(var(--spacing)*2.5)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-6{padding-inline:calc(var(--spacing)*6)}.py-0\.5{padding-block:calc(var(--spacing)*.5)}.py-1{padding-block:calc(var(--spacing)*1)}.py-1\.5{padding-block:calc(var(--spacing)*1.5)}.py-2{padding-block:calc(var(--spacing)*2)}.py-3{padding-block:calc(var(--spacing)*3)}.py-6{padding-block:calc(var(--spacing)*6)}.py-8{padding-block:calc(var(--spacing)*8)}.py-12{padding-block:calc(var(--spacing)*12)}.pt-1\.5{padding-top:calc(var(--spacing)*1.5)}.pt-2{padding-top:calc(var(--spacing)*2)}.pt-3{padding-top:calc(var(--spacing)*3)}.pr-4{padding-right:calc(var(--spacing)*4)}.pb-2{padding-bottom:calc(var(--spacing)*2)}.pb-3{padding-bottom:calc(var(--spacing)*3)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[9px\]{font-size:9px}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.leading-none{--tw-leading:1;line-height:1}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.whitespace-nowrap{white-space:nowrap}.text-amber-300{color:var(--color-amber-300)}.text-amber-400{color:var(--color-amber-400)}.text-amber-400\/60{color:#fcbb0099}@supports (color:color-mix(in lab,red,red)){.text-amber-400\/60{color:color-mix(in oklab,var(--color-amber-400)60%,transparent)}}.text-brand-300{color:var(--color-brand-300)}.text-brand-400{color:var(--color-brand-400)}.text-brand-500{color:var(--color-brand-500)}.text-cyan-400{color:var(--color-cyan-400)}.text-emerald-300{color:var(--color-emerald-300)}.text-emerald-400{color:var(--color-emerald-400)}.text-emerald-400\/80{color:#00d294cc}@supports (color:color-mix(in lab,red,red)){.text-emerald-400\/80{color:color-mix(in oklab,var(--color-emerald-400)80%,transparent)}}.text-gray-100{color:var(--color-gray-100)}.text-gray-200{color:var(--color-gray-200)}.text-gray-300{color:var(--color-gray-300)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-indigo-300{color:var(--color-indigo-300)}.text-indigo-300\/70{color:#a4b3ffb3}@supports (color:color-mix(in lab,red,red)){.text-indigo-300\/70{color:color-mix(in oklab,var(--color-indigo-300)70%,transparent)}}.text-indigo-400{color:var(--color-indigo-400)}.text-indigo-400\/50{color:#7d87ff80}@supports (color:color-mix(in lab,red,red)){.text-indigo-400\/50{color:color-mix(in oklab,var(--color-indigo-400)50%,transparent)}}.text-indigo-400\/80{color:#7d87ffcc}@supports (color:color-mix(in lab,red,red)){.text-indigo-400\/80{color:color-mix(in oklab,var(--color-indigo-400)80%,transparent)}}.text-pink-400{color:var(--color-pink-400)}.text-purple-400{color:var(--color-purple-400)}.text-red-200\/80{color:#ffcacacc}@supports (color:color-mix(in lab,red,red)){.text-red-200\/80{color:color-mix(in oklab,var(--color-red-200)80%,transparent)}}.text-red-300{color:var(--color-red-300)}.text-red-400{color:var(--color-red-400)}.text-violet-400{color:var(--color-violet-400)}.text-white{color:var(--color-white)}.capitalize{text-transform:capitalize}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.placeholder-gray-500::placeholder{color:var(--color-gray-500)}.opacity-60{opacity:.6}.opacity-75{opacity:.75}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a),0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media(hover:hover){.group-hover\:block:is(:where(.group):hover *){display:block}.hover\:border-gray-600:hover{border-color:var(--color-gray-600)}.hover\:border-gray-700:hover{border-color:var(--color-gray-700)}.hover\:bg-brand-500:hover{background-color:var(--color-brand-500)}.hover\:bg-gray-700:hover{background-color:var(--color-gray-700)}.hover\:bg-gray-800\/30:hover{background-color:#2a29264d}@supports (color:color-mix(in lab,red,red)){.hover\:bg-gray-800\/30:hover{background-color:color-mix(in oklab,var(--color-gray-800)30%,transparent)}}.hover\:bg-gray-800\/50:hover{background-color:#2a292680}@supports (color:color-mix(in lab,red,red)){.hover\:bg-gray-800\/50:hover{background-color:color-mix(in oklab,var(--color-gray-800)50%,transparent)}}.hover\:bg-gray-900:hover{background-color:var(--color-gray-900)}.hover\:bg-indigo-950\/30:hover{background-color:#1e1a4d4d}@supports (color:color-mix(in lab,red,red)){.hover\:bg-indigo-950\/30:hover{background-color:color-mix(in oklab,var(--color-indigo-950)30%,transparent)}}.hover\:fill-indigo-500\/15:hover{fill:#625fff26}@supports (color:color-mix(in lab,red,red)){.hover\:fill-indigo-500\/15:hover{fill:color-mix(in oklab,var(--color-indigo-500)15%,transparent)}}.hover\:text-gray-200:hover{color:var(--color-gray-200)}.hover\:text-gray-300:hover{color:var(--color-gray-300)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}}.focus\:border-brand-500:focus{border-color:var(--color-brand-500)}.focus\:ring-1:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-brand-500:focus{--tw-ring-color:var(--color-brand-500)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}@media(hover:hover){.disabled\:hover\:bg-gray-800:disabled:hover{background-color:var(--color-gray-800)}.disabled\:hover\:text-gray-400:disabled:hover{color:var(--color-gray-400)}}@media(min-width:40rem){.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:justify-between{justify-content:space-between}}@media(min-width:48rem){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}}@media(min-width:64rem){.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@keyframes ping{75%,to{opacity:0;transform:scale(2)}}@keyframes pulse{50%{opacity:.5}}
@@ -1,4 +0,0 @@
1
- const tsrStartManifest = () => ({ "routes": { "__root__": { "filePath": "/home/runner/work/claude-session-dashboard/claude-session-dashboard/apps/web/src/routes/__root.tsx", "children": ["/", "/_dashboard"], "preloads": ["/assets/main-CT7cRkW3.js"], "assets": [] }, "/": { "filePath": "/home/runner/work/claude-session-dashboard/claude-session-dashboard/apps/web/src/routes/index.tsx" }, "/_dashboard": { "filePath": "/home/runner/work/claude-session-dashboard/claude-session-dashboard/apps/web/src/routes/_dashboard.tsx", "children": ["/_dashboard/settings", "/_dashboard/stats", "/_dashboard/sessions/$sessionId", "/_dashboard/sessions/"], "assets": [], "preloads": ["/assets/_dashboard-CAikP08_.js", "/assets/createServerFn-wbChEQBm.js", "/assets/sessions.queries-jGqvP0O9.js"] }, "/_dashboard/settings": { "filePath": "/home/runner/work/claude-session-dashboard/claude-session-dashboard/apps/web/src/routes/_dashboard/settings.tsx", "assets": [], "preloads": ["/assets/settings-CR-1d6g6.js", "/assets/settings.types-BEt_cHU1.js"] }, "/_dashboard/stats": { "filePath": "/home/runner/work/claude-session-dashboard/claude-session-dashboard/apps/web/src/routes/_dashboard/stats.tsx", "assets": [], "preloads": ["/assets/stats-7Tm8ZX4J.js", "/assets/format-Bsprb3az.js", "/assets/useSessionCost-CGXrAUii.js", "/assets/settings.types-BEt_cHU1.js"] }, "/_dashboard/sessions/$sessionId": { "filePath": "/home/runner/work/claude-session-dashboard/claude-session-dashboard/apps/web/src/routes/_dashboard/sessions/$sessionId.tsx", "assets": [], "preloads": ["/assets/_sessionId-C3iR5Lrv.js", "/assets/format-Bsprb3az.js", "/assets/useSessionCost-CGXrAUii.js", "/assets/settings.types-BEt_cHU1.js"] }, "/_dashboard/sessions/": { "filePath": "/home/runner/work/claude-session-dashboard/claude-session-dashboard/apps/web/src/routes/_dashboard/sessions/index.tsx", "assets": [], "preloads": ["/assets/index-Bk56JBgW.js", "/assets/format-Bsprb3az.js"] } }, "clientEntry": "/assets/main-CT7cRkW3.js" });
2
- export {
3
- tsrStartManifest
4
- };