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
@@ -1,144 +0,0 @@
1
- import { c as createServerRpc } from "./createServerRpc-Bd3B-Ah9.js";
2
- import * as fs from "node:fs";
3
- import { a as getStatsPath } from "./claude-path-B2oho3NT.js";
4
- import * as path from "node:path";
5
- import * as os from "node:os";
6
- import { z } from "zod";
7
- import { c as createServerFn } from "../server.js";
8
- import "@tanstack/history";
9
- import "@tanstack/router-core/ssr/client";
10
- import "@tanstack/router-core";
11
- import "node:async_hooks";
12
- import "@tanstack/router-core/ssr/server";
13
- import "h3-v2";
14
- import "tiny-invariant";
15
- import "seroval";
16
- import "react/jsx-runtime";
17
- import "@tanstack/react-router/ssr/server";
18
- import "@tanstack/react-router";
19
- const CACHE_VERSION = 1;
20
- function getCacheDir() {
21
- return path.join(os.homedir(), ".claude-dashboard", "cache");
22
- }
23
- function getCachePath(cacheKey) {
24
- return path.join(getCacheDir(), `${cacheKey}.cache.json`);
25
- }
26
- function readDiskCache(cacheKey, sourceMtimeMs, schema) {
27
- try {
28
- const cachePath = getCachePath(cacheKey);
29
- if (!fs.existsSync(cachePath)) {
30
- return null;
31
- }
32
- const raw = fs.readFileSync(cachePath, "utf-8");
33
- const parsed = JSON.parse(raw);
34
- if (parsed.version !== CACHE_VERSION) {
35
- return null;
36
- }
37
- if (parsed.sourceMtimeMs !== sourceMtimeMs) {
38
- return null;
39
- }
40
- const result = schema.safeParse(parsed.data);
41
- if (!result.success) {
42
- console.warn(`[disk-cache] Zod validation failed for "${cacheKey}":`, result.error.message);
43
- return null;
44
- }
45
- return result.data;
46
- } catch (error) {
47
- const message = error instanceof Error ? error.message : String(error);
48
- console.warn(`[disk-cache] Read failed for "${cacheKey}":`, message);
49
- return null;
50
- }
51
- }
52
- function writeDiskCache(cacheKey, sourceFile, sourceMtimeMs, data) {
53
- try {
54
- const cacheDir = getCacheDir();
55
- fs.mkdirSync(cacheDir, { recursive: true });
56
- const cachePath = getCachePath(cacheKey);
57
- const tmpPath = `${cachePath}.tmp`;
58
- const entry = {
59
- version: CACHE_VERSION,
60
- sourceFile,
61
- sourceMtimeMs,
62
- cachedAt: (/* @__PURE__ */ new Date()).toISOString(),
63
- data
64
- };
65
- fs.writeFileSync(tmpPath, JSON.stringify(entry), "utf-8");
66
- fs.renameSync(tmpPath, cachePath);
67
- } catch (error) {
68
- const message = error instanceof Error ? error.message : String(error);
69
- console.warn(`[disk-cache] Write failed for "${cacheKey}":`, message);
70
- }
71
- }
72
- const DailyActivitySchema = z.object({
73
- date: z.string(),
74
- messageCount: z.number(),
75
- sessionCount: z.number(),
76
- toolCallCount: z.number()
77
- });
78
- const DailyModelTokensSchema = z.object({
79
- date: z.string(),
80
- tokensByModel: z.record(z.string(), z.number())
81
- });
82
- const ModelUsageSchema = z.record(
83
- z.string(),
84
- z.object({
85
- inputTokens: z.number(),
86
- outputTokens: z.number(),
87
- cacheReadInputTokens: z.number(),
88
- cacheCreationInputTokens: z.number(),
89
- webSearchRequests: z.number().optional(),
90
- costUSD: z.number().optional()
91
- })
92
- );
93
- const LongestSessionSchema = z.object({
94
- sessionId: z.string(),
95
- duration: z.number(),
96
- messageCount: z.number(),
97
- timestamp: z.string()
98
- });
99
- const StatsCacheSchema = z.object({
100
- version: z.number(),
101
- lastComputedDate: z.string(),
102
- dailyActivity: z.array(DailyActivitySchema),
103
- dailyModelTokens: z.array(DailyModelTokensSchema),
104
- modelUsage: ModelUsageSchema,
105
- totalSessions: z.number(),
106
- totalMessages: z.number(),
107
- longestSession: LongestSessionSchema,
108
- firstSessionDate: z.string(),
109
- hourCounts: z.record(z.string(), z.number()),
110
- totalSpeculationTimeSavedMs: z.number().optional()
111
- });
112
- let cachedStats = null;
113
- async function parseStats() {
114
- const statsPath = getStatsPath();
115
- const stat = await fs.promises.stat(statsPath).catch(() => null);
116
- if (!stat) return null;
117
- if (cachedStats && cachedStats.mtimeMs === stat.mtimeMs) {
118
- return cachedStats.data;
119
- }
120
- const diskResult = readDiskCache("stats", stat.mtimeMs, StatsCacheSchema);
121
- if (diskResult) {
122
- cachedStats = { mtimeMs: stat.mtimeMs, data: diskResult };
123
- return diskResult;
124
- }
125
- const raw = await fs.promises.readFile(statsPath, "utf-8");
126
- const parsed = JSON.parse(raw);
127
- const result = StatsCacheSchema.parse(parsed);
128
- writeDiskCache("stats", statsPath, stat.mtimeMs, result);
129
- cachedStats = { mtimeMs: stat.mtimeMs, data: result };
130
- return result;
131
- }
132
- const getStats_createServerFn_handler = createServerRpc({
133
- id: "4b9a58c176f487b49800a372100037cdf33cf048f3592a449f115c7e3f5ea799",
134
- name: "getStats",
135
- filename: "src/features/stats/stats.server.ts"
136
- }, (opts) => getStats.__executeServer(opts));
137
- const getStats = createServerFn({
138
- method: "GET"
139
- }).handler(getStats_createServerFn_handler, async () => {
140
- return parseStats();
141
- });
142
- export {
143
- getStats_createServerFn_handler
144
- };