agentgraphed 0.3.0 → 0.3.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 (140) hide show
  1. package/.next/standalone/.next/BUILD_ID +1 -1
  2. package/.next/standalone/.next/app-build-manifest.json +39 -39
  3. package/.next/standalone/.next/app-path-routes-manifest.json +6 -6
  4. package/.next/standalone/.next/build-manifest.json +3 -3
  5. package/.next/standalone/.next/prerender-manifest.json +3 -3
  6. package/.next/standalone/.next/required-server-files.json +6 -6
  7. package/.next/standalone/.next/server/app/_not-found/page.js +2 -2
  8. package/.next/standalone/.next/server/app/_not-found/page.js.nft.json +1 -1
  9. package/.next/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  10. package/.next/standalone/.next/server/app/_not-found.html +1 -1
  11. package/.next/standalone/.next/server/app/_not-found.rsc +2 -2
  12. package/.next/standalone/.next/server/app/analytics/page.js +2 -2
  13. package/.next/standalone/.next/server/app/analytics/page.js.nft.json +1 -1
  14. package/.next/standalone/.next/server/app/analytics/page_client-reference-manifest.js +1 -1
  15. package/.next/standalone/.next/server/app/api/ingest-local/route.js +1 -1
  16. package/.next/standalone/.next/server/app/api/ingest-local/route_client-reference-manifest.js +1 -1
  17. package/.next/standalone/.next/server/app/api/quota-probe/route.js +2 -2
  18. package/.next/standalone/.next/server/app/api/quota-probe/route_client-reference-manifest.js +1 -1
  19. package/.next/standalone/.next/server/app/api/share/dashboard/route.js +1 -1
  20. package/.next/standalone/.next/server/app/api/share/dashboard/route_client-reference-manifest.js +1 -1
  21. package/.next/standalone/.next/server/app/api/share/project/[id]/route.js +1 -1
  22. package/.next/standalone/.next/server/app/api/share/project/[id]/route_client-reference-manifest.js +1 -1
  23. package/.next/standalone/.next/server/app/api/share/session/[id]/route.js +1 -1
  24. package/.next/standalone/.next/server/app/api/share/session/[id]/route_client-reference-manifest.js +1 -1
  25. package/.next/standalone/.next/server/app/page.js +3 -3
  26. package/.next/standalone/.next/server/app/page.js.nft.json +1 -1
  27. package/.next/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  28. package/.next/standalone/.next/server/app/projects/[id]/page.js +2 -2
  29. package/.next/standalone/.next/server/app/projects/[id]/page.js.nft.json +1 -1
  30. package/.next/standalone/.next/server/app/projects/[id]/page_client-reference-manifest.js +1 -1
  31. package/.next/standalone/.next/server/app/projects/page.js +2 -44
  32. package/.next/standalone/.next/server/app/projects/page.js.nft.json +1 -1
  33. package/.next/standalone/.next/server/app/projects/page_client-reference-manifest.js +1 -1
  34. package/.next/standalone/.next/server/app/sessions/[id]/page.js +3 -3
  35. package/.next/standalone/.next/server/app/sessions/[id]/page.js.nft.json +1 -1
  36. package/.next/standalone/.next/server/app/sessions/[id]/page_client-reference-manifest.js +1 -1
  37. package/.next/standalone/.next/server/app/sessions/page.js +2 -44
  38. package/.next/standalone/.next/server/app/sessions/page.js.nft.json +1 -1
  39. package/.next/standalone/.next/server/app/sessions/page_client-reference-manifest.js +1 -1
  40. package/.next/standalone/.next/server/app/settings/page.js +4 -4
  41. package/.next/standalone/.next/server/app/settings/page.js.nft.json +1 -1
  42. package/.next/standalone/.next/server/app/settings/page_client-reference-manifest.js +1 -1
  43. package/.next/standalone/.next/server/app/timeline/page.js +2 -44
  44. package/.next/standalone/.next/server/app/timeline/page.js.nft.json +1 -1
  45. package/.next/standalone/.next/server/app/timeline/page_client-reference-manifest.js +1 -1
  46. package/.next/standalone/.next/server/app-paths-manifest.json +6 -6
  47. package/.next/standalone/.next/server/chunks/27.js +15 -3
  48. package/.next/standalone/.next/server/chunks/450.js +137 -0
  49. package/.next/standalone/.next/server/chunks/564.js +4 -4
  50. package/.next/standalone/.next/server/chunks/694.js +43 -0
  51. package/.next/standalone/.next/server/chunks/903.js +1 -0
  52. package/.next/standalone/.next/server/chunks/944.js +61 -25
  53. package/.next/standalone/.next/server/chunks/954.js +1 -0
  54. package/.next/standalone/.next/server/functions-config-manifest.json +1 -1
  55. package/.next/standalone/.next/server/middleware-build-manifest.js +1 -1
  56. package/.next/standalone/.next/server/pages/404.html +1 -1
  57. package/.next/standalone/.next/server/pages/500.html +1 -1
  58. package/.next/standalone/.next/server/server-reference-manifest.js +1 -1
  59. package/.next/standalone/.next/server/server-reference-manifest.json +1 -1
  60. package/.next/standalone/.next/static/chunks/app/_not-found/{page-dc1cbec20c205394.js → page-01ad39d2ead973c7.js} +1 -1
  61. package/.next/{static/chunks/app/analytics/page-42186370029f753c.js → standalone/.next/static/chunks/app/analytics/page-79a1781c3529dcb6.js} +1 -1
  62. package/.next/standalone/.next/static/chunks/app/{layout-4527370a1e451501.js → layout-bbab14e77aaeeb67.js} +1 -1
  63. package/.next/standalone/.next/static/chunks/app/page-d5393f25e2553a0c.js +1 -0
  64. package/.next/standalone/.next/static/chunks/app/projects/[id]/page-32fe8cf66558be7c.js +1 -0
  65. package/.next/standalone/.next/static/chunks/app/projects/page-dce207c2f75422be.js +1 -0
  66. package/.next/standalone/.next/static/chunks/app/sessions/[id]/{page-a887f742425eb49c.js → page-49542233907f7f6b.js} +1 -1
  67. package/.next/standalone/.next/static/chunks/app/sessions/page-aec145af506da55b.js +1 -0
  68. package/.next/standalone/.next/static/chunks/app/settings/page-b961ca195748ef3b.js +1 -0
  69. package/.next/standalone/.next/static/chunks/app/timeline/page-dce207c2f75422be.js +1 -0
  70. package/.next/standalone/.next/static/chunks/{main-app-c9ae70e5bb48ac77.js → main-app-27b331c894fe5037.js} +1 -1
  71. package/.next/standalone/node_modules/@img/{sharp-libvips-darwin-arm64/lib/libvips-cpp.8.17.3.dylib → sharp-libvips-linux-x64/lib/libvips-cpp.so.8.17.3} +0 -0
  72. package/.next/standalone/node_modules/@img/{sharp-libvips-darwin-arm64 → sharp-libvips-linux-x64}/package.json +11 -5
  73. package/.next/standalone/node_modules/@img/sharp-libvips-linuxmusl-x64/lib/index.js +1 -0
  74. package/.next/standalone/node_modules/@img/sharp-libvips-linuxmusl-x64/lib/libvips-cpp.so.8.17.3 +0 -0
  75. package/.next/standalone/node_modules/@img/sharp-libvips-linuxmusl-x64/package.json +42 -0
  76. package/.next/standalone/node_modules/@img/sharp-libvips-linuxmusl-x64/versions.json +30 -0
  77. package/.next/standalone/node_modules/@img/sharp-linux-x64/lib/sharp-linux-x64.node +0 -0
  78. package/.next/standalone/node_modules/@img/{sharp-darwin-arm64 → sharp-linux-x64}/package.json +13 -7
  79. package/.next/standalone/node_modules/@img/sharp-linuxmusl-x64/LICENSE +191 -0
  80. package/.next/standalone/node_modules/@img/sharp-linuxmusl-x64/lib/sharp-linuxmusl-x64.node +0 -0
  81. package/.next/standalone/node_modules/@img/sharp-linuxmusl-x64/package.json +46 -0
  82. package/.next/standalone/package.json +1 -1
  83. package/.next/standalone/server.js +1 -1
  84. package/.next/standalone/src/lib/pricing-data/litellm.json +615 -92
  85. package/.next/standalone/src/lib/pricing-data/litellm.meta.json +2 -2
  86. package/.next/static/chunks/app/_not-found/{page-dc1cbec20c205394.js → page-01ad39d2ead973c7.js} +1 -1
  87. package/.next/{standalone/.next/static/chunks/app/analytics/page-42186370029f753c.js → static/chunks/app/analytics/page-79a1781c3529dcb6.js} +1 -1
  88. package/.next/static/chunks/app/{layout-4527370a1e451501.js → layout-bbab14e77aaeeb67.js} +1 -1
  89. package/.next/static/chunks/app/page-d5393f25e2553a0c.js +1 -0
  90. package/.next/static/chunks/app/projects/[id]/page-32fe8cf66558be7c.js +1 -0
  91. package/.next/static/chunks/app/projects/page-dce207c2f75422be.js +1 -0
  92. package/.next/static/chunks/app/sessions/[id]/{page-a887f742425eb49c.js → page-49542233907f7f6b.js} +1 -1
  93. package/.next/static/chunks/app/sessions/page-aec145af506da55b.js +1 -0
  94. package/.next/static/chunks/app/settings/page-b961ca195748ef3b.js +1 -0
  95. package/.next/static/chunks/app/timeline/page-dce207c2f75422be.js +1 -0
  96. package/.next/static/chunks/{main-app-c9ae70e5bb48ac77.js → main-app-27b331c894fe5037.js} +1 -1
  97. package/CHANGELOG.md +22 -0
  98. package/README.md +52 -46
  99. package/package.json +1 -1
  100. package/src/lib/pricing-data/litellm.json +615 -92
  101. package/src/lib/pricing-data/litellm.meta.json +2 -2
  102. package/.next/standalone/.next/server/chunks/165.js +0 -109
  103. package/.next/standalone/.next/server/chunks/191.js +0 -1
  104. package/.next/standalone/.next/server/chunks/367.js +0 -43
  105. package/.next/standalone/.next/server/chunks/660.js +0 -1
  106. package/.next/standalone/.next/static/chunks/app/page-aa358006ddd29e91.js +0 -1
  107. package/.next/standalone/.next/static/chunks/app/projects/[id]/page-15f21aaacdacb59c.js +0 -1
  108. package/.next/standalone/.next/static/chunks/app/projects/page-d794cc35674274a4.js +0 -1
  109. package/.next/standalone/.next/static/chunks/app/sessions/page-35c503eef7e53742.js +0 -1
  110. package/.next/standalone/.next/static/chunks/app/settings/page-dc0bec0bd2577322.js +0 -1
  111. package/.next/standalone/.next/static/chunks/app/timeline/page-d794cc35674274a4.js +0 -1
  112. package/.next/standalone/node_modules/@img/sharp-darwin-arm64/lib/sharp-darwin-arm64.node +0 -0
  113. package/.next/standalone/node_modules/better-sqlite3/build/Release/better_sqlite3.node +0 -0
  114. package/.next/standalone/node_modules/better-sqlite3/lib/database.js +0 -90
  115. package/.next/standalone/node_modules/better-sqlite3/lib/index.js +0 -3
  116. package/.next/standalone/node_modules/better-sqlite3/lib/methods/aggregate.js +0 -43
  117. package/.next/standalone/node_modules/better-sqlite3/lib/methods/backup.js +0 -67
  118. package/.next/standalone/node_modules/better-sqlite3/lib/methods/function.js +0 -31
  119. package/.next/standalone/node_modules/better-sqlite3/lib/methods/inspect.js +0 -7
  120. package/.next/standalone/node_modules/better-sqlite3/lib/methods/pragma.js +0 -12
  121. package/.next/standalone/node_modules/better-sqlite3/lib/methods/serialize.js +0 -16
  122. package/.next/standalone/node_modules/better-sqlite3/lib/methods/table.js +0 -189
  123. package/.next/standalone/node_modules/better-sqlite3/lib/methods/transaction.js +0 -78
  124. package/.next/standalone/node_modules/better-sqlite3/lib/methods/wrappers.js +0 -54
  125. package/.next/standalone/node_modules/better-sqlite3/lib/sqlite-error.js +0 -20
  126. package/.next/standalone/node_modules/better-sqlite3/lib/util.js +0 -12
  127. package/.next/standalone/node_modules/better-sqlite3/package.json +0 -54
  128. package/.next/static/chunks/app/page-aa358006ddd29e91.js +0 -1
  129. package/.next/static/chunks/app/projects/[id]/page-15f21aaacdacb59c.js +0 -1
  130. package/.next/static/chunks/app/projects/page-d794cc35674274a4.js +0 -1
  131. package/.next/static/chunks/app/sessions/page-35c503eef7e53742.js +0 -1
  132. package/.next/static/chunks/app/settings/page-dc0bec0bd2577322.js +0 -1
  133. package/.next/static/chunks/app/timeline/page-d794cc35674274a4.js +0 -1
  134. /package/.next/standalone/.next/static/{A6dvfHR2KYz42pasM2hyV → hnOq_d-GplXbWU5EnSBzF}/_buildManifest.js +0 -0
  135. /package/.next/standalone/.next/static/{A6dvfHR2KYz42pasM2hyV → hnOq_d-GplXbWU5EnSBzF}/_ssgManifest.js +0 -0
  136. /package/.next/standalone/node_modules/@img/{sharp-libvips-darwin-arm64 → sharp-libvips-linux-x64}/lib/index.js +0 -0
  137. /package/.next/standalone/node_modules/@img/{sharp-libvips-darwin-arm64 → sharp-libvips-linux-x64}/versions.json +0 -0
  138. /package/.next/standalone/node_modules/@img/{sharp-darwin-arm64 → sharp-linux-x64}/LICENSE +0 -0
  139. /package/.next/static/{A6dvfHR2KYz42pasM2hyV → hnOq_d-GplXbWU5EnSBzF}/_buildManifest.js +0 -0
  140. /package/.next/static/{A6dvfHR2KYz42pasM2hyV → hnOq_d-GplXbWU5EnSBzF}/_ssgManifest.js +0 -0
@@ -1,4 +1,4 @@
1
1
  {
2
- "fetchedAt": "2026-06-05T19:43:10.991Z",
3
- "modelCount": 2748
2
+ "fetchedAt": "2026-06-09T20:57:50.730Z",
3
+ "modelCount": 2776
4
4
  }
@@ -1,109 +0,0 @@
1
- "use strict";exports.id=165,exports.ids=[165],exports.modules={40753:(a,b,c)=>{c.d(b,{z:()=>e});var d=c(75338);function e({title:a,subtitle:b,right:c,titleAdornment:e}){return(0,d.jsxs)("header",{className:"px-7 h-[72px] border-b border-surface-2 flex items-center justify-between sticky top-0 z-20 bg-canvas/95 backdrop-blur supports-[backdrop-filter]:bg-canvas/80",children:[(0,d.jsxs)("div",{children:[(0,d.jsxs)("div",{className:"flex items-center gap-3",children:[(0,d.jsx)("h1",{className:"text-headline-md text-ink font-semibold",children:a}),e]}),b&&(0,d.jsx)("div",{className:"text-body-sm text-ink-mute mt-0.5",children:b})]}),c&&(0,d.jsx)("div",{className:"flex items-center gap-2",children:c})]})}},53223:(a,b,c)=>{c.d(b,{x:()=>y});var d={};c.r(d),c.d(d,{daySummaries:()=>u,ingestState:()=>s,messages:()=>r,projectSummaries:()=>v,projects:()=>p,sessions:()=>q,settings:()=>t});var e=c(87550),f=c.n(e),g=c(35674),h=c(48161),i=c(76760),j=c(73024),k=c(37444),l=c(72873),m=c(51166),n=c(92780),o=c(41444);let p=(0,k.D)("projects",{id:(0,l.Qq)("id").primaryKey(),name:(0,l.Qq)("name").notNull(),rootPath:(0,l.Qq)("root_path").notNull(),gitRemote:(0,l.Qq)("git_remote"),firstSeen:(0,m.nd)("first_seen").notNull(),lastActive:(0,m.nd)("last_active").notNull()},a=>({rootIdx:(0,n.GL)("projects_root_idx").on(a.rootPath)})),q=(0,k.D)("sessions",{id:(0,l.Qq)("id").primaryKey(),provider:(0,l.Qq)("provider").notNull(),projectId:(0,l.Qq)("project_id").notNull(),cwd:(0,l.Qq)("cwd").notNull(),startedAt:(0,m.nd)("started_at").notNull(),endedAt:(0,m.nd)("ended_at").notNull(),durationMs:(0,m.nd)("duration_ms").notNull(),model:(0,l.Qq)("model"),messageCount:(0,m.nd)("message_count").notNull().default(0),userMessageCount:(0,m.nd)("user_message_count").notNull().default(0),inputTokens:(0,m.nd)("input_tokens").notNull().default(0),outputTokens:(0,m.nd)("output_tokens").notNull().default(0),cacheReadTokens:(0,m.nd)("cache_read_tokens").notNull().default(0),cacheWriteTokens:(0,m.nd)("cache_write_tokens").notNull().default(0),estCostUsd:(0,o.x)("est_cost_usd").notNull().default(0),firstPrompt:(0,l.Qq)("first_prompt"),summary:(0,l.Qq)("summary"),summaryGenerated:(0,m.nd)("summary_generated").notNull().default(0),heuristicTitle:(0,l.Qq)("heuristic_title"),category:(0,l.Qq)("category"),keywords:(0,l.Qq)("keywords"),gitBranch:(0,l.Qq)("git_branch"),sourcePath:(0,l.Qq)("source_path").notNull()},a=>({projectIdx:(0,n.Pe)("sessions_project_idx").on(a.projectId),startedIdx:(0,n.Pe)("sessions_started_idx").on(a.startedAt),providerIdx:(0,n.Pe)("sessions_provider_idx").on(a.provider),modelIdx:(0,n.Pe)("sessions_model_idx").on(a.model)})),r=(0,k.D)("messages",{id:(0,l.Qq)("id").primaryKey(),sessionId:(0,l.Qq)("session_id").notNull(),role:(0,l.Qq)("role").notNull(),content:(0,l.Qq)("content").notNull(),timestamp:(0,m.nd)("timestamp").notNull(),model:(0,l.Qq)("model")},a=>({sessionIdx:(0,n.Pe)("messages_session_idx").on(a.sessionId),timestampIdx:(0,n.Pe)("messages_timestamp_idx").on(a.timestamp)})),s=(0,k.D)("ingest_state",{sourcePath:(0,l.Qq)("source_path").primaryKey(),mtime:(0,m.nd)("mtime").notNull(),size:(0,m.nd)("size").notNull(),sessionId:(0,l.Qq)("session_id").notNull(),ingestedAt:(0,m.nd)("ingested_at").notNull()}),t=(0,k.D)("settings",{key:(0,l.Qq)("key").primaryKey(),value:(0,l.Qq)("value").notNull()}),u=(0,k.D)("day_summaries",{day:(0,l.Qq)("day").primaryKey(),summary:(0,l.Qq)("summary").notNull(),generatedAt:(0,m.nd)("generated_at").notNull()}),v=(0,k.D)("project_summaries",{projectId:(0,l.Qq)("project_id").primaryKey(),summary:(0,l.Qq)("summary").notNull(),generatedAt:(0,m.nd)("generated_at").notNull()}),w=null,x=null;function y(){return!x&&(w||((x=new(f())((0,i.join)(function(){let a=process.env.AGENTGRAPHED_DATA_DIR||(0,i.join)((0,h.homedir)(),".agentgraphed");return(0,j.existsSync)(a)||(0,j.mkdirSync)(a,{recursive:!0}),a}(),"agentgraphed.sqlite"))).pragma("journal_mode = WAL"),x.pragma("synchronous = NORMAL"),function(a){a.exec(`
2
- CREATE TABLE IF NOT EXISTS projects (
3
- id TEXT PRIMARY KEY,
4
- name TEXT NOT NULL,
5
- root_path TEXT NOT NULL,
6
- git_remote TEXT,
7
- first_seen INTEGER NOT NULL,
8
- last_active INTEGER NOT NULL
9
- );
10
- CREATE UNIQUE INDEX IF NOT EXISTS projects_root_idx ON projects(root_path);
11
-
12
- CREATE TABLE IF NOT EXISTS sessions (
13
- id TEXT PRIMARY KEY,
14
- provider TEXT NOT NULL,
15
- project_id TEXT NOT NULL,
16
- cwd TEXT NOT NULL,
17
- started_at INTEGER NOT NULL,
18
- ended_at INTEGER NOT NULL,
19
- duration_ms INTEGER NOT NULL,
20
- model TEXT,
21
- message_count INTEGER NOT NULL DEFAULT 0,
22
- user_message_count INTEGER NOT NULL DEFAULT 0,
23
- input_tokens INTEGER NOT NULL DEFAULT 0,
24
- output_tokens INTEGER NOT NULL DEFAULT 0,
25
- cache_read_tokens INTEGER NOT NULL DEFAULT 0,
26
- cache_write_tokens INTEGER NOT NULL DEFAULT 0,
27
- est_cost_usd REAL NOT NULL DEFAULT 0,
28
- first_prompt TEXT,
29
- summary TEXT,
30
- summary_generated INTEGER NOT NULL DEFAULT 0,
31
- heuristic_title TEXT,
32
- category TEXT,
33
- keywords TEXT,
34
- git_branch TEXT,
35
- source_path TEXT NOT NULL
36
- );
37
- CREATE INDEX IF NOT EXISTS sessions_project_idx ON sessions(project_id);
38
- CREATE INDEX IF NOT EXISTS sessions_started_idx ON sessions(started_at);
39
- CREATE INDEX IF NOT EXISTS sessions_provider_idx ON sessions(provider);
40
- CREATE INDEX IF NOT EXISTS sessions_model_idx ON sessions(model);
41
-
42
- CREATE TABLE IF NOT EXISTS messages (
43
- id TEXT PRIMARY KEY,
44
- session_id TEXT NOT NULL,
45
- role TEXT NOT NULL,
46
- content TEXT NOT NULL,
47
- timestamp INTEGER NOT NULL,
48
- model TEXT
49
- );
50
- CREATE INDEX IF NOT EXISTS messages_session_idx ON messages(session_id);
51
- CREATE INDEX IF NOT EXISTS messages_timestamp_idx ON messages(timestamp);
52
-
53
- CREATE TABLE IF NOT EXISTS ingest_state (
54
- source_path TEXT PRIMARY KEY,
55
- mtime INTEGER NOT NULL,
56
- size INTEGER NOT NULL,
57
- session_id TEXT NOT NULL,
58
- ingested_at INTEGER NOT NULL
59
- );
60
-
61
- CREATE TABLE IF NOT EXISTS settings (
62
- key TEXT PRIMARY KEY,
63
- value TEXT NOT NULL
64
- );
65
-
66
- CREATE TABLE IF NOT EXISTS day_summaries (
67
- day TEXT PRIMARY KEY,
68
- summary TEXT NOT NULL,
69
- generated_at INTEGER NOT NULL
70
- );
71
-
72
- CREATE TABLE IF NOT EXISTS project_summaries (
73
- project_id TEXT PRIMARY KEY,
74
- summary TEXT NOT NULL,
75
- generated_at INTEGER NOT NULL
76
- );
77
-
78
- CREATE TABLE IF NOT EXISTS session_contexts (
79
- session_id TEXT PRIMARY KEY,
80
- context TEXT NOT NULL,
81
- generated_at INTEGER NOT NULL,
82
- model TEXT
83
- );
84
-
85
- CREATE TABLE IF NOT EXISTS quota_snapshots (
86
- provider TEXT PRIMARY KEY,
87
- observed_at INTEGER NOT NULL,
88
- plan_type TEXT,
89
- primary_pct REAL,
90
- primary_window_minutes INTEGER,
91
- primary_resets_at INTEGER,
92
- secondary_pct REAL,
93
- secondary_window_minutes INTEGER,
94
- secondary_resets_at INTEGER
95
- );
96
-
97
- CREATE TABLE IF NOT EXISTS claude_limit_events (
98
- id INTEGER PRIMARY KEY AUTOINCREMENT,
99
- session_id TEXT NOT NULL,
100
- observed_at INTEGER NOT NULL,
101
- reset_at INTEGER,
102
- kind TEXT NOT NULL,
103
- raw TEXT
104
- );
105
- CREATE INDEX IF NOT EXISTS claude_limit_events_observed_idx ON claude_limit_events(observed_at);
106
- CREATE INDEX IF NOT EXISTS claude_limit_events_session_idx ON claude_limit_events(session_id);
107
- `);let b=new Set(a.prepare("PRAGMA table_info(sessions)").all().map(a=>a.name));b.has("heuristic_title")||a.exec("ALTER TABLE sessions ADD COLUMN heuristic_title TEXT"),b.has("category")||a.exec("ALTER TABLE sessions ADD COLUMN category TEXT"),b.has("keywords")||a.exec("ALTER TABLE sessions ADD COLUMN keywords TEXT"),a.exec("CREATE INDEX IF NOT EXISTS sessions_category_idx ON sessions(category)"),b.has("categories")||(a.exec("ALTER TABLE sessions ADD COLUMN categories TEXT"),a.exec(`UPDATE sessions
108
- SET categories = json_array(category)
109
- WHERE category IS NOT NULL AND categories IS NULL`))}(x),w=(0,g.f)(x,{schema:d}))),x}},74498:(a,b,c)=>{let d;c.d(b,{PL:()=>i,ZC:()=>h});var e=c(53223),f=c(73024),g=c(76760);function h(a,b){(0,e.x)().prepare("INSERT OR REPLACE INTO settings (key, value) VALUES (?, ?)").run(a,b)}function i(a){let b=(0,e.x)().prepare("SELECT value FROM settings WHERE key = ?").get(a);return b?.value??null}c(73136),!function(){let a=function(){if(void 0!==d)return d;try{let a=__dirname,b=(0,g.join)(a,"pricing-data","litellm.meta.json");d=(0,f.existsSync)(b)?JSON.parse((0,f.readFileSync)(b,"utf8")):null}catch{d=null}return d}();a?.fetchedAt&&a.fetchedAt.slice(0,10)}()},88009:(a,b,c)=>{c.d(b,{$I:()=>f,P6:()=>e,nG:()=>g});let d=[{id:"claude-haiku-4-5",label:"Claude Haiku 4.5 (cheapest)",provider:"anthropic",input:1,output:5},{id:"claude-sonnet-4-6",label:"Claude Sonnet 4.6 (smarter)",provider:"anthropic",input:3,output:15},{id:"gpt-5-mini",label:"GPT-5 Mini (cheapest)",provider:"openai",input:.5,output:2},{id:"gpt-4o-mini",label:"GPT-4o Mini (very cheap)",provider:"openai",input:.15,output:.6},{id:"gpt-5",label:"GPT-5 (smarter)",provider:"openai",input:2.5,output:10}];function e(a){return d.find(b=>b.id===a)}function f(a){return"openai"===a?"gpt-5-mini":"claude-haiku-4-5"}function g(a,b,c){return(b*a.input+c*a.output)/1e6}},92568:(a,b,c)=>{c.d(b,{$I:()=>f,P6:()=>e,nG:()=>g});let d=[{id:"claude-haiku-4-5",label:"Claude Haiku 4.5 (cheapest)",provider:"anthropic",input:1,output:5},{id:"claude-sonnet-4-6",label:"Claude Sonnet 4.6 (smarter)",provider:"anthropic",input:3,output:15},{id:"gpt-5-mini",label:"GPT-5 Mini (cheapest)",provider:"openai",input:.5,output:2},{id:"gpt-4o-mini",label:"GPT-4o Mini (very cheap)",provider:"openai",input:.15,output:.6},{id:"gpt-5",label:"GPT-5 (smarter)",provider:"openai",input:2.5,output:10}];function e(a){return d.find(b=>b.id===a)}function f(a){return"openai"===a?"gpt-5-mini":"claude-haiku-4-5"}function g(a,b,c){return(b*a.input+c*a.output)/1e6}},94450:(a,b,c)=>{c.d(b,{M:()=>i,Q:()=>h});var d=c(79742),e=c(63894),f=c(74498),g=c(88009);function h(){let a=(0,f.PL)("llm_provider")||"anthropic",b="openai"===a?"openai_api_key":"anthropic_api_key",c=(0,f.PL)(b)||process.env["openai"===a?"OPENAI_API_KEY":"ANTHROPIC_API_KEY"]||"";if(!c)return null;let d=(0,f.PL)("classifier_model")||(0,g.$I)(a),e=(0,f.PL)("summarizer_model")||(0,g.$I)(a);return{provider:a,apiKey:c,classifierModel:d,summarizerModel:e}}async function i(a){let b=h();if(!b)throw Error("No LLM provider configured");let c=(0,g.P6)(a.model)??(0,g.P6)(b.classifierModel);if(!c)throw Error(`Unknown model: ${a.model}`);if("anthropic"===c.provider){let e=new d.Ay({apiKey:b.apiKey}),f=await e.messages.create({model:c.id,max_tokens:a.maxTokens??1024,system:a.systemPrompt,messages:[{role:"user",content:a.userPrompt}]});return{text:f.content.map(a=>"text"in a?a.text:"").join("").trim(),inputTokens:f.usage.input_tokens,outputTokens:f.usage.output_tokens}}{let d=new e.Ay({apiKey:b.apiKey}),f=/^gpt-5/i.test(c.id)||/^o\d/i.test(c.id),g=await d.chat.completions.create({model:c.id,messages:[...a.systemPrompt?[{role:"system",content:a.systemPrompt}]:[],{role:"user",content:a.userPrompt}],max_completion_tokens:a.maxTokens??1024,...f?{reasoning_effort:"minimal"}:{},..."json"===a.responseFormat?{response_format:{type:"json_object"}}:{}}),h=g.choices[0]?.message?.content?.trim()||"",i=g.usage?.completion_tokens_details?.reasoning_tokens??0,j=g.choices[0]?.finish_reason;if(!h)throw Error("length"===j&&i>0?`model used all ${i} output tokens on reasoning before producing any visible content; raise the token budget or use a non-reasoning model`:`model returned empty content (finish_reason=${j})`);return{text:h,inputTokens:g.usage?.prompt_tokens??0,outputTokens:g.usage?.completion_tokens??0}}}}};
@@ -1 +0,0 @@
1
- exports.id=191,exports.ids=[191],exports.modules={22412:(a,b,c)=>{"use strict";c.d(b,{ShareButton:()=>f});var d=c(21124),e=c(38301);function f({imageUrl:a,className:b}){let[c,f]=(0,e.useState)("idle"),[j,k]=(0,e.useState)(null),l=async()=>{f("busy"),k(null);try{let b=await fetch(a);if(!b.ok)throw Error(`HTTP ${b.status}`);let c=await b.blob();if("undefined"==typeof ClipboardItem||!navigator.clipboard?.write)throw Error("clipboard image unsupported");let d=new ClipboardItem({"image/png":c});await navigator.clipboard.write([d]),f("done"),setTimeout(()=>f("idle"),2400)}catch(b){try{let b=await fetch(a),c=await b.blob(),d=URL.createObjectURL(c),e=document.createElement("a");e.href=d,e.download="agentgraphed-stats.png",document.body.appendChild(e),e.click(),document.body.removeChild(e),setTimeout(()=>URL.revokeObjectURL(d),5e3),k("Saved to Downloads (clipboard image unsupported)"),f("err"),setTimeout(()=>f("idle"),4e3)}catch(a){k(a.message||b.message),f("err"),setTimeout(()=>f("idle"),3e3)}}};return(0,d.jsx)("button",{onClick:l,disabled:"busy"===c,"aria-label":"Share",title:"busy"===c?"Generating image…":"done"===c?"Image copied to clipboard":"err"===c?j??"Try again":"Copy share image to clipboard",className:`btn-icon ${"done"===c?"text-secondary":""} ${b??""}`,children:"busy"===c?(0,d.jsx)(i,{}):"done"===c?(0,d.jsx)(h,{}):(0,d.jsx)(g,{})})}function g(){return(0,d.jsxs)("svg",{width:"17",height:"17",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.4",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,d.jsx)("path",{d:"M4 12v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-8"}),(0,d.jsx)("polyline",{points:"16 6 12 2 8 6"}),(0,d.jsx)("line",{x1:"12",y1:"2",x2:"12",y2:"15"})]})}function h(){return(0,d.jsx)("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",children:(0,d.jsx)("polyline",{points:"20 6 9 17 4 12"})})}function i(){return(0,d.jsx)("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"animate-spin",children:(0,d.jsx)("path",{d:"M21 12a9 9 0 1 1-6.219-8.56"})})}},25799:(a,b,c)=>{"use strict";Object.defineProperty(b,"__esModule",{value:!0}),Object.defineProperty(b,"unstable_rethrow",{enumerable:!0,get:function(){return function a(b){if((0,g.isNextRouterError)(b)||(0,f.isBailoutToCSRError)(b)||(0,i.isDynamicServerError)(b)||(0,h.isDynamicPostpone)(b)||(0,e.isPostpone)(b)||(0,d.isHangingPromiseRejectionError)(b))throw b;b instanceof Error&&"cause"in b&&a(b.cause)}}});let d=c(82831),e=c(43740),f=c(29305),g=c(61981),h=c(26906),i=c(69168);("function"==typeof b.default||"object"==typeof b.default&&null!==b.default)&&void 0===b.default.__esModule&&(Object.defineProperty(b.default,"__esModule",{value:!0}),Object.assign(b.default,b),a.exports=b.default)},29088:(a,b,c)=>{"use strict";function d(){throw Object.defineProperty(Error("`unauthorized()` is experimental and only allowed to be used when `experimental.authInterrupts` is enabled."),"__NEXT_ERROR_CODE",{value:"E411",enumerable:!1,configurable:!0})}Object.defineProperty(b,"__esModule",{value:!0}),Object.defineProperty(b,"unauthorized",{enumerable:!0,get:function(){return d}}),c(98541).HTTP_ERROR_FALLBACK_ERROR_CODE,("function"==typeof b.default||"object"==typeof b.default&&null!==b.default)&&void 0===b.default.__esModule&&(Object.defineProperty(b.default,"__esModule",{value:!0}),Object.assign(b.default,b),a.exports=b.default)},35530:(a,b,c)=>{"use strict";c.d(b,{ShareButton:()=>d});let d=(0,c(97954).registerClientReference)(function(){throw Error("Attempted to call ShareButton() from the server but ShareButton is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/Users/mikekuehn/devProjects/agentgraphed/oss/src/components/ShareButton.tsx","ShareButton")},47614:(a,b,c)=>{"use strict";Object.defineProperty(b,"__esModule",{value:!0}),!function(a,b){for(var c in b)Object.defineProperty(a,c,{enumerable:!0,get:b[c]})}(b,{getRedirectError:function(){return g},getRedirectStatusCodeFromError:function(){return l},getRedirectTypeFromError:function(){return k},getURLFromRedirectError:function(){return j},permanentRedirect:function(){return i},redirect:function(){return h}});let d=c(91203),e=c(92781),f=c(19121).actionAsyncStorage;function g(a,b,c){void 0===c&&(c=d.RedirectStatusCode.TemporaryRedirect);let f=Object.defineProperty(Error(e.REDIRECT_ERROR_CODE),"__NEXT_ERROR_CODE",{value:"E394",enumerable:!1,configurable:!0});return f.digest=e.REDIRECT_ERROR_CODE+";"+b+";"+a+";"+c+";",f}function h(a,b){var c;throw null!=b||(b=(null==f||null==(c=f.getStore())?void 0:c.isAction)?e.RedirectType.push:e.RedirectType.replace),g(a,b,d.RedirectStatusCode.TemporaryRedirect)}function i(a,b){throw void 0===b&&(b=e.RedirectType.replace),g(a,b,d.RedirectStatusCode.PermanentRedirect)}function j(a){return(0,e.isRedirectError)(a)?a.digest.split(";").slice(2,-2).join(";"):null}function k(a){if(!(0,e.isRedirectError)(a))throw Object.defineProperty(Error("Not a redirect error"),"__NEXT_ERROR_CODE",{value:"E260",enumerable:!1,configurable:!0});return a.digest.split(";",2)[1]}function l(a){if(!(0,e.isRedirectError)(a))throw Object.defineProperty(Error("Not a redirect error"),"__NEXT_ERROR_CODE",{value:"E260",enumerable:!1,configurable:!0});return Number(a.digest.split(";").at(-2))}("function"==typeof b.default||"object"==typeof b.default&&null!==b.default)&&void 0===b.default.__esModule&&(Object.defineProperty(b.default,"__esModule",{value:!0}),Object.assign(b.default,b),a.exports=b.default)},64404:(a,b,c)=>{"use strict";Object.defineProperty(b,"__esModule",{value:!0}),Object.defineProperty(b,"notFound",{enumerable:!0,get:function(){return e}});let d=""+c(98541).HTTP_ERROR_FALLBACK_ERROR_CODE+";404";function e(){let a=Object.defineProperty(Error(d),"__NEXT_ERROR_CODE",{value:"E394",enumerable:!1,configurable:!0});throw a.digest=d,a}("function"==typeof b.default||"object"==typeof b.default&&null!==b.default)&&void 0===b.default.__esModule&&(Object.defineProperty(b.default,"__esModule",{value:!0}),Object.assign(b.default,b),a.exports=b.default)},64712:(a,b,c)=>{"use strict";Object.defineProperty(b,"__esModule",{value:!0}),Object.defineProperty(b,"unstable_rethrow",{enumerable:!0,get:function(){return d}});let d=c(25799).unstable_rethrow;("function"==typeof b.default||"object"==typeof b.default&&null!==b.default)&&void 0===b.default.__esModule&&(Object.defineProperty(b.default,"__esModule",{value:!0}),Object.assign(b.default,b),a.exports=b.default)},65169:(a,b,c)=>{let{createProxy:d}=c(39893);a.exports=d("/Users/mikekuehn/devProjects/agentgraphed/oss/node_modules/next/dist/client/app-dir/link.js")},67837:(a,b,c)=>{"use strict";function d(){throw Object.defineProperty(Error("`forbidden()` is experimental and only allowed to be enabled when `experimental.authInterrupts` is enabled."),"__NEXT_ERROR_CODE",{value:"E488",enumerable:!1,configurable:!0})}Object.defineProperty(b,"__esModule",{value:!0}),Object.defineProperty(b,"forbidden",{enumerable:!0,get:function(){return d}}),c(98541).HTTP_ERROR_FALLBACK_ERROR_CODE,("function"==typeof b.default||"object"==typeof b.default&&null!==b.default)&&void 0===b.default.__esModule&&(Object.defineProperty(b.default,"__esModule",{value:!0}),Object.assign(b.default,b),a.exports=b.default)},73169:(a,b,c)=>{"use strict";c.d(b,{f:()=>e});var d=c(75338);function e({label:a,value:b,hint:c,accent:e}){return(0,d.jsxs)("div",{className:"card p-4",children:[(0,d.jsx)("div",{className:"metric-label",children:a}),(0,d.jsx)("div",{className:`metric-value tabular mt-1 ${"primary"===e?"text-primary":"secondary"===e?"text-secondary":"text-ink"}`,children:b}),c&&(0,d.jsx)("div",{className:"text-[11px] text-ink-mute mt-1",children:c})]})}},82161:(a,b,c)=>{"use strict";var d=c(93045);c.o(d,"notFound")&&c.d(b,{notFound:function(){return d.notFound}})},92490:(a,b,c)=>{"use strict";c.d(b,{i:()=>f});var d=c(75338);let e={Planning:"bg-tertiary-soft text-ink-dim border-ink-mute/30",Debugging:"bg-error/15 text-error border-error/30",Refactor:"bg-primary/10 text-primary border-primary/30",Feature:"bg-secondary/10 text-secondary border-secondary/30",Styling:"bg-fuchsia-400/10 text-fuchsia-300 border-fuchsia-400/30","SEO/Content":"bg-amber-400/10 text-amber-300 border-amber-400/30",DevOps:"bg-orange-400/10 text-orange-300 border-orange-400/30",Data:"bg-sky-400/10 text-sky-300 border-sky-400/30",Payments:"bg-emerald-400/10 text-emerald-300 border-emerald-400/30",Docs:"bg-violet-400/10 text-violet-300 border-violet-400/30",Unknown:"bg-surface-3 text-ink-mute border-surface-4"};function f({category:a,size:b="sm"}){let c=e[a]||e.Unknown;return(0,d.jsx)("span",{className:`inline-block ${"xs"===b?"text-[9px] px-1 py-0":"text-[10px] px-1.5 py-0.5"} rounded font-mono uppercase tracking-wider border ${c} shrink-0`,children:a})}},93045:(a,b,c)=>{"use strict";Object.defineProperty(b,"__esModule",{value:!0}),!function(a,b){for(var c in b)Object.defineProperty(a,c,{enumerable:!0,get:b[c]})}(b,{ReadonlyURLSearchParams:function(){return k},RedirectType:function(){return e.RedirectType},forbidden:function(){return g.forbidden},notFound:function(){return f.notFound},permanentRedirect:function(){return d.permanentRedirect},redirect:function(){return d.redirect},unauthorized:function(){return h.unauthorized},unstable_isUnrecognizedActionError:function(){return l},unstable_rethrow:function(){return i.unstable_rethrow}});let d=c(47614),e=c(92781),f=c(64404),g=c(67837),h=c(29088),i=c(64712);class j extends Error{constructor(){super("Method unavailable on `ReadonlyURLSearchParams`. Read more: https://nextjs.org/docs/app/api-reference/functions/use-search-params#updating-searchparams")}}class k extends URLSearchParams{append(){throw new j}delete(){throw new j}set(){throw new j}sort(){throw new j}}function l(){throw Object.defineProperty(Error("`unstable_isUnrecognizedActionError` can only be used on the client."),"__NEXT_ERROR_CODE",{value:"E776",enumerable:!1,configurable:!0})}("function"==typeof b.default||"object"==typeof b.default&&null!==b.default)&&void 0===b.default.__esModule&&(Object.defineProperty(b.default,"__esModule",{value:!0}),Object.assign(b.default,b),a.exports=b.default)},99044:(a,b,c)=>{"use strict";c.d(b,{G:()=>e});var d=c(48161);function e(a){if(!a)return a;let b=process.env.AGENTGRAPHED_DEMO_HOME;if(!b)return a;let c=(0,d.homedir)();return a.startsWith(c)?b+a.slice(c.length):a.replace(/^(\/Users|\/home)\/[^/]+/,b)}}};
@@ -1,43 +0,0 @@
1
- "use strict";exports.id=367,exports.ids=[367],exports.modules={15988:(a,b,c)=>{c.d(b,{Ev:()=>i,Kv:()=>k,N6:()=>j});var d=c(22446),e=c(71277),f=c(92568);let g=["Planning","Debugging","Refactor","Feature","Styling","SEO/Content","DevOps","Data","Payments","Docs","Unknown"],h=`You categorize AI coding sessions and write short, concrete titles for them.
2
-
3
- For each session you receive a list of the user's prompts in order ("prompts": [...]).
4
- The first prompt is the opening goal; later prompts show how the session evolved
5
- (e.g. "let's plan this" → "now add the route" → "fix this bug"). Sessions
6
- often span multiple kinds of work.
7
-
8
- Return JSON only:
9
- {
10
- "results": [
11
- { "id": "...", "categories": ["Primary", "Secondary?"], "title": "..." }
12
- ]
13
- }
14
-
15
- Categories (pick 1–3, ordered by how much of the session they represent,
16
- most-significant first; only include a label if it materially appears):
17
- - Planning — brainstorming, PRDs, deciding whether to build something, product strategy
18
- - Debugging — fixing bugs, errors, broken things, failing tests
19
- - Refactor — restructuring or renaming existing code without behavior change
20
- - Feature — building or adding new functionality
21
- - Styling — UI, CSS, layout, design, theme
22
- - SEO/Content — SEO, blog content, headlines, meta tags
23
- - DevOps — deploy, CI/CD, env vars, infrastructure, DNS
24
- - Data — databases, schemas, migrations, scraping, ETL
25
- - Payments — Stripe, checkout, billing, invoices, subscriptions
26
- - Docs — README, documentation, changelog
27
- - Unknown — when you genuinely can't tell (prefer this over guessing)
28
-
29
- When in doubt, prefer fewer labels. A session that's 90% Feature with a tiny
30
- bug fix at the end is just Feature.
31
-
32
- Title rules:
33
- - 4-9 words, past tense ("Added", "Fixed", "Drafted")
34
- - Capture the dominant outcome of the session, not just the opening prompt
35
- - Concrete object ("Stripe checkout reminder" not "payments stuff")
36
- - No quotes, no period
37
- - Keep acronyms (PRD, API, CLI) and proper nouns (Stripe, Drizzle, Next.js) capitalized
38
- - Never repeat a category in the title
39
-
40
- Return the JSON only, no prose.`;async function i(a){let b=(0,e.Q)();if(!b)throw Error("No LLM provider configured");let c=(0,f.P6)(b.classifierModel),d=(0,f.nG)(c,600*a,50*a);return{totalUsd:d,perSessionUsd:0===a?0:d/a,modelId:c.id,modelLabel:c.label}}async function j(a){let b,c=(0,e.Q)();if(!c)throw Error("No LLM provider configured");let i=(0,f.P6)(c.classifierModel),j=a.batchSize??20,k=(0,d.x)(),l=k.prepare("UPDATE sessions SET heuristic_title = ?, category = ?, categories = ? WHERE id = ?"),m=0,n=0,o=0;for(let p=0;p<a.rows.length;p+=j){let q=a.rows.slice(p,p+j),r=q.map(a=>({id:a.id,prompts:function(a,b){let c=(0,d.x)().prepare("SELECT content FROM messages WHERE session_id = ? AND role = 'user' ORDER BY timestamp ASC").all(a);if(0===c.length)return[b];if(c.length<=8)return c.map(a=>a.content);let e=[c[0].content],f=(c.length-2)/7;for(let a=1;a<=6;a++)e.push(c[Math.round(a*f)].content);return e.push(c[c.length-1].content),e}(a.id,a.first_prompt)})),s=function(a){let b={sessions:a.map(a=>({id:a.id,prompts:a.prompts.map(a=>a.slice(0,400))}))};return`Sessions to classify:
41
- ${JSON.stringify(b,null,2)}`}(r);r.reduce((a,b)=>a+b.prompts.reduce((a,b)=>a+Math.ceil(b.length/4),0),0);let t=Math.min(3e3,Math.max(800,100*q.length));try{let{text:a,inputTokens:d,outputTokens:j}=await (0,e.M)({model:c.classifierModel,systemPrompt:h,userPrompt:s,maxTokens:t,responseFormat:"json"});m+=(0,f.nG)(i,d,j);let p=function(a){let b=a.trim(),c=b.match(/```(?:json)?\s*([\s\S]*?)```/);c&&(b=c[1].trim());let d=b.indexOf("{"),e=b.lastIndexOf("}");if(-1===d||-1===e)return[];try{let a=JSON.parse(b.slice(d,e+1));if(Array.isArray(a?.results))return a.results}catch{}return[]}(a);if(0===p.length&&a.length>0){o+=1,b||(b=`Could not parse model response. First 200 chars: ${a.slice(0,200)}`);continue}k.transaction(a=>{for(let b of a){if(!b.id)continue;let a=[...new Set((b.categories??(b.category?[b.category]:[])).filter(a=>"string"==typeof a).map(a=>a.trim()).filter(a=>g.includes(a)))].slice(0,3);if(0===a.length)continue;let c=(b.title||"").trim().replace(/[.\s]+$/,"").slice(0,120);c&&(l.run(c,a[0],JSON.stringify(a),b.id),n+=1)}})(p)}catch(c){o+=1;let a=c.message;console.error("classify batch failed",a),b||(b=a)}a.onProgress?.(Math.min(p+j,a.rows.length),a.rows.length)}return{classified:n,costUsd:m,firstError:b,batchesFailed:o}}function k(a){let b=(0,d.x)(),c=`SELECT id, first_prompt FROM sessions
42
- WHERE category IS NULL AND first_prompt IS NOT NULL AND length(first_prompt) > 0
43
- ORDER BY started_at DESC${a?` LIMIT ${a}`:""}`;return b.prepare(c).all()}},29509:(a,b,c)=>{c.d(b,{Ig:()=>h,QT:()=>g,RC:()=>e,du:()=>f});let d=[{key:"7d",label:"Last 7 days",days:7},{key:"30d",label:"Last 30 days",days:30},{key:"90d",label:"Last 90 days",days:90},{key:"all",label:"All time",days:null}];function e(a){let b=(a||"").toLowerCase(),c=d.find(a=>a.key===b);return c?c.key:"30d"}function f(a){return d.find(b=>b.key===a)?.days??30}function g(a){return d.find(b=>b.key===a)?.label??"Last 30 days"}function h(a){return"all"===a?"all time":a}},51094:(a,b,c)=>{c.d(b,{RangePicker:()=>d});let d=(0,c(97954).registerClientReference)(function(){throw Error("Attempted to call RangePicker() from the server but RangePicker is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/Users/mikekuehn/devProjects/agentgraphed/oss/src/components/RangePicker.tsx","RangePicker")},71277:(a,b,c)=>{c.d(b,{M:()=>i,Q:()=>h});var d=c(19283),e=c(9244),f=c(10944),g=c(92568);function h(){let a=(0,f.PL)("llm_provider")||"anthropic",b="openai"===a?"openai_api_key":"anthropic_api_key",c=(0,f.PL)(b)||process.env["openai"===a?"OPENAI_API_KEY":"ANTHROPIC_API_KEY"]||"";if(!c)return null;let d=(0,f.PL)("classifier_model")||(0,g.$I)(a),e=(0,f.PL)("summarizer_model")||(0,g.$I)(a);return{provider:a,apiKey:c,classifierModel:d,summarizerModel:e}}async function i(a){let b=h();if(!b)throw Error("No LLM provider configured");let c=(0,g.P6)(a.model)??(0,g.P6)(b.classifierModel);if(!c)throw Error(`Unknown model: ${a.model}`);if("anthropic"===c.provider){let e=new d.Ay({apiKey:b.apiKey}),f=await e.messages.create({model:c.id,max_tokens:a.maxTokens??1024,system:a.systemPrompt,messages:[{role:"user",content:a.userPrompt}]});return{text:f.content.map(a=>"text"in a?a.text:"").join("").trim(),inputTokens:f.usage.input_tokens,outputTokens:f.usage.output_tokens}}{let d=new e.Ay({apiKey:b.apiKey}),f=/^gpt-5/i.test(c.id)||/^o\d/i.test(c.id),g=await d.chat.completions.create({model:c.id,messages:[...a.systemPrompt?[{role:"system",content:a.systemPrompt}]:[],{role:"user",content:a.userPrompt}],max_completion_tokens:a.maxTokens??1024,...f?{reasoning_effort:"minimal"}:{},..."json"===a.responseFormat?{response_format:{type:"json_object"}}:{}}),h=g.choices[0]?.message?.content?.trim()||"",i=g.usage?.completion_tokens_details?.reasoning_tokens??0,j=g.choices[0]?.finish_reason;if(!h)throw Error("length"===j&&i>0?`model used all ${i} output tokens on reasoning before producing any visible content; raise the token budget or use a non-reasoning model`:`model returned empty content (finish_reason=${j})`);return{text:h,inputTokens:g.usage?.prompt_tokens??0,outputTokens:g.usage?.completion_tokens??0}}}},73169:(a,b,c)=>{c.d(b,{f:()=>e});var d=c(75338);function e({label:a,value:b,hint:c,accent:e}){return(0,d.jsxs)("div",{className:"card p-4",children:[(0,d.jsx)("div",{className:"metric-label",children:a}),(0,d.jsx)("div",{className:`metric-value tabular mt-1 ${"primary"===e?"text-primary":"secondary"===e?"text-secondary":"text-ink"}`,children:b}),c&&(0,d.jsx)("div",{className:"text-[11px] text-ink-mute mt-1",children:c})]})}},86718:(a,b,c)=>{c.d(b,{L:()=>l,N:()=>j});var d=c(90027),e=c(10944),f=c(25742),g=c(15988),h=c(71277);let i=null;function j(){if(i)return;let a=(0,e.PL)("dashboard_last_auto_ingest_ms"),b=a?parseInt(a,10):0;Date.now()-b<1e4||((0,e.ZC)("dashboard_last_auto_ingest_ms",String(Date.now())),i=(async()=>{try{let a=await (0,d.U)();(a.claude.filesIngested>0||a.codex.filesIngested>0)&&(0,f.e)(),await k()}catch{}finally{i=null}})())}async function k(){try{if("off"===(0,e.PL)("auto_classify")||!(0,h.Q)())return;let a=(0,g.Kv)();if(a.length<5)return;(await (0,g.N6)({rows:a})).classified>0&&(0,f.e)()}catch{}}function l(){let a=(0,e.PL)("dashboard_last_auto_ingest_ms");return a?parseInt(a,10):0}},92155:(a,b,c)=>{function d(a){return a>=1e6?`${(a/1e6).toFixed(1)}M`:a>=1e3?`${(a/1e3).toFixed(1)}k`:a.toString()}function e(a){return a>=1e3?`$${a.toFixed(0)}`:`$${a.toFixed(2)}`}function f(a){let b=Math.floor(a/1e3);if(b<60)return`${b}s`;let c=Math.floor(b/60);if(c<60)return`${c}m`;let d=Math.floor(c/60);return`${d}h ${c%60}m`}c.d(b,{F0:()=>e,c5:()=>f,yj:()=>d})},94709:(a,b,c)=>{c.d(b,{RangePicker:()=>h});var d=c(21124),e=c(42378),f=c(38301);let g=[{key:"7d",label:"Last 7 days",days:7},{key:"30d",label:"Last 30 days",days:30},{key:"90d",label:"Last 90 days",days:90},{key:"all",label:"All time",days:null}];function h({current:a}){let b=(0,e.useRouter)(),c=(0,e.usePathname)(),h=(0,e.useSearchParams)(),[i,j]=(0,f.useTransition)();return(0,d.jsx)("div",{className:`flex items-center gap-0.5 normal-case tracking-normal transition-opacity ${i?"opacity-50":""}`,children:g.map(e=>(0,d.jsx)("button",{onClick:()=>(a=>{let d=new URLSearchParams(h.toString());"30d"===a?d.delete("range"):d.set("range",a);let e=d.toString();j(()=>{b.push(e?`${c}?${e}`:c)})})(e.key),className:`px-2 py-0.5 text-[11px] rounded transition-colors font-mono ${a===e.key?"bg-primary/15 text-primary":"text-ink-mute hover:text-ink-dim"}`,children:"all"===e.key?"All":e.key},e.key))})}}};
@@ -1 +0,0 @@
1
- exports.id=660,exports.ids=[660],exports.modules={74:(a,b,c)=>{Promise.resolve().then(c.t.bind(c,54160,23)),Promise.resolve().then(c.t.bind(c,31603,23)),Promise.resolve().then(c.t.bind(c,68495,23)),Promise.resolve().then(c.t.bind(c,75170,23)),Promise.resolve().then(c.t.bind(c,77526,23)),Promise.resolve().then(c.t.bind(c,78922,23)),Promise.resolve().then(c.t.bind(c,29234,23)),Promise.resolve().then(c.t.bind(c,12263,23)),Promise.resolve().then(c.bind(c,82146))},46194:(a,b,c)=>{Promise.resolve().then(c.bind(c,65610))},51472:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>g,metadata:()=>f});var d=c(75338);c(61135);var e=c(87907);let f={title:"AgentGraphed",description:"Local-first analytics for AI-assisted development"};function g({children:a}){return(0,d.jsx)("html",{lang:"en",children:(0,d.jsx)("body",{children:(0,d.jsxs)("div",{className:"flex min-h-screen",children:[(0,d.jsx)(e.Sidebar,{}),(0,d.jsx)("main",{className:"flex-1 min-w-0",children:a})]})})})}},61135:()=>{},65610:(a,b,c)=>{"use strict";c.d(b,{Sidebar:()=>s});var d=c(21124),e=c(3991),f=c.n(e),g=c(42378),h=c(43249),i=c(38301),j=c(23312);function k(a){if(!a||!a.ok)return null;let b=a.primary?.pct??null,c=a.secondary?.pct??null;return null===b&&null===c?null:Math.max(b??0,c??0)}function l(a){let b=a-Date.now();if(b<=0&&b>-12e4)return"<1m";if(b<=0)return"resetting";let c=Math.round(b/6e4);if(c<1)return"<1m";if(c<60)return`${c}m`;let d=Math.floor(c/60),e=c%60;return 0===e?`${d}h`:`${d}h${e}m`}function m(){let[a,b]=(0,i.useState)({claude:null,codex:null,fetchedAt:0,loading:!1}),[c,e]=(0,i.useState)(!1),[f,g]=(0,i.useState)(null),h=(0,i.useRef)(null),m=(0,i.useRef)(null),o=(0,i.useCallback)(async()=>{b(a=>({...a,loading:!0}));let[a,c]=await Promise.all([fetch("/api/quota-probe?provider=claude",{method:"POST"}).then(a=>a.json()).catch(a=>({ok:!1,error:a.message})),fetch("/api/quota-probe?provider=codex",{method:"POST"}).then(a=>a.json()).catch(a=>({ok:!1,error:a.message}))]);b({claude:q("claude",a),codex:q("codex",c),fetchedAt:Date.now(),loading:!1})},[]);function p(){m.current&&clearTimeout(m.current),e(!0),Date.now()-a.fetchedAt>6e4&&!a.loading&&o()}function r(){m.current&&clearTimeout(m.current),m.current=setTimeout(()=>e(!1),120)}return(0,d.jsxs)("div",{ref:h,className:"relative px-3 py-2 border-b border-surface-2",onMouseEnter:p,onMouseLeave:r,onFocus:p,onBlur:r,children:[(0,d.jsxs)("button",{type:"button",onClick:o,className:"w-full flex items-center gap-2 text-[12px] text-ink-dim hover:text-ink","aria-haspopup":"dialog","aria-expanded":c,children:[(0,d.jsx)("span",{className:`w-1.5 h-1.5 rounded-full ${function(a){if(0===a.fetchedAt)return"bg-ink-mute";let b=Math.max(k(a.claude)??0,k(a.codex)??0);return b>=95?"bg-error":b>=80?"bg-secondary":"bg-primary"}(a)} ${a.loading?"animate-pulse":""}`}),(0,d.jsx)("span",{className:"font-mono tabular truncate",children:a.loading&&0===a.fetchedAt?"Probing…":function(a){if(0===a.fetchedAt)return"Live quota";let b=k(a.claude);return null!==b&&a.claude?.primary?`Claude ${Math.round(b)}% \xb7 ${l(a.claude.primary.resetsAt)}`:"Live quota"}(a)})]}),c&&f&&"undefined"!=typeof document&&(0,j.createPortal)((0,d.jsx)(n,{state:a,loading:a.loading,anchorRect:f,onEnter:p,onLeave:r}),document.body)]})}function n({state:a,loading:b,anchorRect:c,onEnter:e,onLeave:f}){let g={position:"fixed",left:c.right+8,top:c.top,backgroundColor:"#1c2026",isolation:"isolate"};return(0,d.jsx)("div",{role:"dialog",onMouseEnter:e,onMouseLeave:f,className:"w-72 z-[9999] rounded-lg border border-surface-3 p-4 space-y-4 shadow-[0_20px_60px_-10px_rgba(0,0,0,0.8)]",style:g,children:b&&0===a.fetchedAt?(0,d.jsx)("div",{className:"text-body-sm text-ink-mute",children:"Probing Anthropic & OpenAI…"}):(0,d.jsxs)(d.Fragment,{children:[(0,d.jsx)(o,{kpi:a.claude}),(0,d.jsx)("div",{className:"border-t border-surface-2"}),(0,d.jsx)(o,{kpi:a.codex}),(0,d.jsx)("div",{className:"text-[10px] text-ink-mute font-mono tabular pt-1 border-t border-surface-2",children:0===a.fetchedAt?"never probed":`updated ${function(a){let b=Date.now()-a;return b<1e3?"just now":b<6e4?`${Math.round(b/1e3)}s ago`:`${Math.round(b/6e4)}m ago`}(a.fetchedAt)} \xb7 hover again after 60s to refresh`})]})})}function o({kpi:a}){if(!a)return(0,d.jsx)("div",{className:"text-body-sm text-ink-mute",children:"No data."});let b="claude"===a.provider?"Claude":"Codex";return(0,d.jsxs)("div",{className:"space-y-2",children:[(0,d.jsxs)("div",{className:"flex items-baseline justify-between",children:[(0,d.jsx)("span",{className:"text-label-caps text-ink-dim",children:b}),a.ok&&a.planType&&(0,d.jsx)("span",{className:"text-[10px] text-ink-mute font-mono uppercase tracking-wide",children:a.planType})]}),a.ok?(0,d.jsxs)(d.Fragment,{children:[a.primary&&(0,d.jsx)(p,{label:a.primary.label,pct:a.primary.pct,resetsAt:a.primary.resetsAt,accent:"primary"}),a.secondary&&(0,d.jsx)(p,{label:a.secondary.label,pct:a.secondary.pct,resetsAt:a.secondary.resetsAt,accent:"secondary"}),!a.primary&&!a.secondary&&(0,d.jsx)("div",{className:"text-body-sm text-ink-mute",children:"No rate-limit headers returned."})]}):(0,d.jsx)("div",{className:"text-[11px] text-ink-mute leading-relaxed",children:a.error})]})}function p({label:a,pct:b,resetsAt:c,accent:e}){return(0,d.jsxs)("div",{children:[(0,d.jsxs)("div",{className:"flex items-baseline justify-between text-body-sm",children:[(0,d.jsx)("span",{className:"text-ink font-mono uppercase tracking-wider text-[10px]",children:a}),(0,d.jsxs)("span",{className:"font-mono tabular text-ink",children:[Math.round(b),"%"]})]}),(0,d.jsx)("div",{className:"h-1 bg-surface-2 rounded-full overflow-hidden mt-1",children:(0,d.jsx)("div",{className:`h-full ${"primary"===e?"bg-primary":"bg-secondary"}`,style:{width:`${Math.min(100,Math.max(0,b))}%`}})}),(0,d.jsxs)("div",{className:"text-[10px] text-ink-mute font-mono tabular mt-0.5",children:["resets in ",l(c)]})]})}function q(a,b){if(!b||!("ok"in b))return{provider:a,ok:!1,observedAt:Date.now(),planType:null,primary:null,secondary:null,error:"unexpected response"};if(!b.ok)return{provider:a,ok:!1,observedAt:Date.now(),planType:null,primary:null,secondary:null,error:b.error};let c=b.snapshot;return{provider:a,ok:!0,observedAt:c.observedAt,planType:c.planType,primary:c.primary?{pct:c.primary.pct,resetsAt:c.primary.resetsAt,label:"claude"===a?"5h":"1m"}:null,secondary:c.secondary?{pct:c.secondary.pct,resetsAt:c.secondary.resetsAt,label:"7d"}:null}}let r=[{href:"/",label:"Dashboard",icon:"◧"},{href:"/timeline",label:"Timeline",icon:"☰"},{href:"/projects",label:"Projects",icon:"▦"},{href:"/sessions",label:"Sessions",icon:"⌘"},{href:"/analytics",label:"Analytics",icon:"⌁"}];function s(){let a=(0,g.usePathname)();return(0,d.jsxs)("aside",{className:"w-56 shrink-0 border-r border-surface-2 bg-surface-0 flex flex-col sticky top-0 h-screen self-start",children:[(0,d.jsxs)("div",{className:"px-5 border-b border-surface-2 h-[72px] flex flex-col justify-center",children:[(0,d.jsxs)("div",{className:"flex items-baseline gap-1.5 leading-none",children:[(0,d.jsx)("span",{className:"text-primary text-base",children:"◧"}),(0,d.jsxs)("span",{className:"text-lg font-bold tracking-tight",children:[(0,d.jsx)("span",{className:"text-ink-dim",children:"Agent"}),(0,d.jsx)("span",{className:"text-primary",children:"Graphed"})]})]}),(0,d.jsx)("div",{className:"text-[10px] uppercase tracking-wider text-ink-mute mt-1.5",children:"See your AI work"})]}),(0,d.jsx)(m,{}),(0,d.jsx)("nav",{className:"px-2 py-3 flex-1 flex flex-col gap-0.5",children:r.map(b=>{let c="/"===b.href?"/"===a:a.startsWith(b.href);return(0,d.jsxs)(f(),{href:b.href,className:(0,h.A)("flex items-center gap-3 px-3 py-2 rounded text-[13px] transition-colors",c?"bg-surface-2 text-primary border-l-2 border-primary -ml-px":"text-ink-dim hover:text-ink hover:bg-surface-1"),children:[(0,d.jsx)("span",{className:"text-base w-4 text-center opacity-80",children:b.icon}),(0,d.jsx)("span",{children:b.label})]},b.href)})}),(0,d.jsx)("div",{className:"px-2 py-3 border-t border-surface-2",children:(0,d.jsxs)(f(),{href:"/settings",className:(0,h.A)("flex items-center gap-3 px-3 py-2 rounded text-[13px] transition-colors",a.startsWith("/settings")?"bg-surface-2 text-primary border-l-2 border-primary -ml-px":"text-ink-dim hover:text-ink hover:bg-surface-1"),children:[(0,d.jsx)("span",{className:"text-base w-4 text-center opacity-80",children:"⚙"}),(0,d.jsx)("span",{children:"Settings"})]})})]})}},81922:(a,b,c)=>{Promise.resolve().then(c.t.bind(c,81170,23)),Promise.resolve().then(c.t.bind(c,23597,23)),Promise.resolve().then(c.t.bind(c,36893,23)),Promise.resolve().then(c.t.bind(c,89748,23)),Promise.resolve().then(c.t.bind(c,6060,23)),Promise.resolve().then(c.t.bind(c,7184,23)),Promise.resolve().then(c.t.bind(c,69576,23)),Promise.resolve().then(c.t.bind(c,73041,23)),Promise.resolve().then(c.t.bind(c,51384,23))},83146:(a,b,c)=>{Promise.resolve().then(c.bind(c,87907))},87907:(a,b,c)=>{"use strict";c.d(b,{Sidebar:()=>d});let d=(0,c(97954).registerClientReference)(function(){throw Error("Attempted to call Sidebar() from the server but Sidebar is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/Users/mikekuehn/devProjects/agentgraphed/oss/src/components/Sidebar.tsx","Sidebar")}};
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[974],{2278:(e,t,r)=>{Promise.resolve().then(r.t.bind(r,52619,23)),Promise.resolve().then(r.bind(r,15433)),Promise.resolve().then(r.bind(r,34077)),Promise.resolve().then(r.bind(r,74050)),Promise.resolve().then(r.bind(r,61438)),Promise.resolve().then(r.bind(r,95925)),Promise.resolve().then(r.bind(r,17834)),Promise.resolve().then(r.bind(r,29366))},15433:(e,t,r)=>{"use strict";r.d(t,{ClassifyChip:()=>a});var n=r(95155),o=r(12115),s=r(20063),i=r(25511);function a(e){let{count:t,estimatedUsd:r}=e,a=(0,s.useRouter)(),[l,c]=(0,o.useState)("idle"),[d,u]=(0,o.useState)(null),[m,p]=(0,o.useState)(null),[h,x]=(0,o.useTransition)(),f=()=>{if("idle"===l)return void c("confirm");"confirm"===l&&x(async()=>{let e=await (0,i.v)("uncategorized");if(!e.ok){u(e.error),c("err"),setTimeout(()=>c("idle"),4e3);return}p({classified:e.classified,costUsd:e.costUsd}),c("done"),a.refresh(),setTimeout(()=>c("idle"),3e3)})};return"done"===l&&m?(0,n.jsxs)("div",{className:"text-[11px] font-mono px-2 py-0.5 rounded bg-secondary/10 text-secondary border border-secondary/30",children:["✓ classified ",m.classified," \xb7 $",m.costUsd.toFixed(4)]}):"err"===l?(0,n.jsx)("div",{className:"text-[11px] font-mono px-2 py-0.5 rounded bg-error/10 text-error border border-error/30",title:null!=d?d:"",children:"✗ failed"}):"confirm"===l?(0,n.jsx)("button",{onClick:f,disabled:h,className:"text-[11px] font-mono px-2 py-0.5 rounded bg-primary/15 text-primary border border-primary/40 hover:bg-primary/25 transition-colors disabled:opacity-60",title:"Click again to confirm — sends prompts to your configured provider",children:h?"… classifying":"confirm \xb7 run for ~$".concat(r.toFixed(4))}):(0,n.jsxs)("button",{onClick:f,className:"text-[11px] font-mono px-2 py-0.5 rounded text-ink-mute hover:text-primary hover:bg-surface-2 transition-colors",title:"Send their first prompts to your configured LLM to assign a title + category. ~$0.0001 per session.",children:[t," unclassified \xb7 classify"]})}},17834:(e,t,r)=>{"use strict";r.d(t,{ShareButton:()=>s});var n=r(95155),o=r(12115);function s(e){let{imageUrl:t,className:r}=e,[s,c]=(0,o.useState)("idle"),[d,u]=(0,o.useState)(null),m=async()=>{c("busy"),u(null);try{var e;let r=await fetch(t);if(!r.ok)throw Error("HTTP ".concat(r.status));let n=await r.blob();if("undefined"==typeof ClipboardItem||!(null==(e=navigator.clipboard)?void 0:e.write))throw Error("clipboard image unsupported");let o=new ClipboardItem({"image/png":n});await navigator.clipboard.write([o]),c("done"),setTimeout(()=>c("idle"),2400)}catch(e){try{let e=await fetch(t),r=await e.blob(),n=URL.createObjectURL(r),o=document.createElement("a");o.href=n,o.download="agentgraphed-stats.png",document.body.appendChild(o),o.click(),document.body.removeChild(o),setTimeout(()=>URL.revokeObjectURL(n),5e3),u("Saved to Downloads (clipboard image unsupported)"),c("err"),setTimeout(()=>c("idle"),4e3)}catch(t){u(t.message||e.message),c("err"),setTimeout(()=>c("idle"),3e3)}}};return(0,n.jsx)("button",{onClick:m,disabled:"busy"===s,"aria-label":"Share",title:"busy"===s?"Generating image…":"done"===s?"Image copied to clipboard":"err"===s?null!=d?d:"Try again":"Copy share image to clipboard",className:"btn-icon ".concat("done"===s?"text-secondary":""," ").concat(null!=r?r:""),children:"busy"===s?(0,n.jsx)(l,{}):"done"===s?(0,n.jsx)(a,{}):(0,n.jsx)(i,{})})}function i(){return(0,n.jsxs)("svg",{width:"17",height:"17",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.4",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("path",{d:"M4 12v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-8"}),(0,n.jsx)("polyline",{points:"16 6 12 2 8 6"}),(0,n.jsx)("line",{x1:"12",y1:"2",x2:"12",y2:"15"})]})}function a(){return(0,n.jsx)("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",children:(0,n.jsx)("polyline",{points:"20 6 9 17 4 12"})})}function l(){return(0,n.jsx)("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"animate-spin",children:(0,n.jsx)("path",{d:"M21 12a9 9 0 1 1-6.219-8.56"})})}},20467:(e,t,r)=>{"use strict";function n(e){return e>=1e6?"".concat((e/1e6).toFixed(1),"M"):e>=1e3?"".concat((e/1e3).toFixed(1),"k"):e.toString()}function o(e){return e>=1e3?"$".concat(e.toFixed(0)):"$".concat(e.toFixed(2))}function s(e){let t=Math.floor(e/1e3);if(t<60)return"".concat(t,"s");let r=Math.floor(t/60);if(r<60)return"".concat(r,"m");let n=Math.floor(r/60);return"".concat(n,"h ").concat(r%60,"m")}r.d(t,{F0:()=>o,c5:()=>s,yj:()=>n})},25511:(e,t,r)=>{"use strict";r.d(t,{v:()=>o});var n=r(30926);let o=(0,n.createServerReference)("40ebbe581be2d6a1560853a1f470f6bef259ff3ce0",n.callServer,void 0,n.findSourceMapURL,"classifyAction")},29366:(e,t,r)=>{"use strict";r.d(t,{UsageChartCard:()=>x});var n=r(95155),o=r(12115),s=r(20063),i=r(26991),a=r(73850),l=r(68425),c=r(47734),d=r(73697),u=r(23508),m=r(77568),p=r(20467);function h(e){let{data:t,metric:r="tokens",scale:o="lin"}=e,s=t.map(e=>{let t=e[r];return{...e,label:e.day.slice(5),value:"log"===o&&t<=0?1:t,raw:t}}),h="cost"===r?"#00ffab":"#00f5ff";return(0,n.jsx)("div",{className:"h-64 -mx-1",children:(0,n.jsx)(i.u,{width:"100%",height:"100%",children:(0,n.jsxs)(a.Q,{data:s,margin:{top:8,right:8,bottom:0,left:-8},children:[(0,n.jsx)("defs",{children:(0,n.jsxs)("linearGradient",{id:"grad-".concat(r),x1:"0",y1:"0",x2:"0",y2:"1",children:[(0,n.jsx)("stop",{offset:"0%",stopColor:h,stopOpacity:.35}),(0,n.jsx)("stop",{offset:"100%",stopColor:h,stopOpacity:0})]})}),(0,n.jsx)(l.d,{stroke:"#262a31",strokeDasharray:"2 4",vertical:!1}),(0,n.jsx)(c.W,{dataKey:"label",tick:{fill:"#849495",fontSize:11,fontFamily:"JetBrains Mono"},axisLine:{stroke:"#262a31"},tickLine:!1,minTickGap:48}),(0,n.jsx)(d.h,{scale:"log"===o?"log":"auto",domain:"log"===o?[1,"auto"]:["auto","auto"],allowDataOverflow:!0,tick:{fill:"#849495",fontSize:11,fontFamily:"JetBrains Mono"},axisLine:!1,tickLine:!1,tickFormatter:e=>"cost"===r?"$".concat(Math.round(e)):(0,p.yj)(e)}),(0,n.jsx)(u.m,{cursor:{stroke:h,strokeOpacity:.3},contentStyle:{background:"#181c22",border:"1px solid ".concat(h),borderRadius:6,fontSize:12,color:"#dfe2eb"},formatter:(e,t,n)=>{var o,s;let i=null!=(s=null==n||null==(o=n.payload)?void 0:o.raw)?s:0;return"tokens"===r?[(0,p.yj)(i),"tokens"]:"sessions"===r?[i.toString(),"sessions"]:["$".concat(i.toFixed(2)),"cost"]},labelFormatter:e=>"Day ".concat(e)}),(0,n.jsx)(m.G,{type:"monotone",dataKey:"value",stroke:h,strokeWidth:2,fill:"url(#grad-".concat(r,")"),isAnimationActive:!1})]})})})}function x(e){let{data:t,label:r="last 30 days",metric:i,scale:a}=e,l=(0,s.useRouter)(),c=(0,s.usePathname)(),d=(0,s.useSearchParams)(),u=(0,o.useMemo)(()=>!function(e,t){let r=e.map(e=>e[t]).filter(e=>e>0);if(r.length<5)return!1;let n=[...r].sort((e,t)=>e-t);return n[n.length-1]/Math.max(n[Math.floor(n.length/2)],1)>10}(t,i)?"lin":"log",[t,i]),m=null!=a?a:u,p=(e,t,r)=>{let n=new URLSearchParams(d.toString());null===t||t===r?n.delete(e):n.set(e,t);let o=n.toString();l.push(o?"".concat(c,"?").concat(o):c,{scroll:!1})};return(0,n.jsxs)("div",{className:"card",children:[(0,n.jsxs)("div",{className:"card-header flex items-center justify-between",children:[(0,n.jsxs)("span",{children:["Usage — ",r]}),(0,n.jsxs)("div",{className:"flex items-center gap-3 normal-case tracking-normal",children:[(0,n.jsx)("div",{className:"flex items-center gap-0.5",children:[{id:"tokens",label:"Tokens"},{id:"sessions",label:"Sessions"},{id:"cost",label:"Est. Cost"}].map(e=>(0,n.jsx)("button",{onClick:()=>p("metric",e.id,"tokens"),className:"px-2 py-0.5 text-[11px] rounded transition-colors font-mono ".concat(i===e.id?"bg-primary/15 text-primary":"text-ink-mute hover:text-ink-dim"),children:e.label},e.id))}),(0,n.jsx)("div",{className:"w-px h-4 bg-surface-3"}),(0,n.jsx)("div",{className:"flex items-center gap-0.5",children:["lin","log"].map(e=>(0,n.jsxs)("button",{onClick:()=>p("scale",e,u),className:"px-1.5 py-0.5 text-[10px] rounded transition-colors font-mono uppercase relative ".concat(m===e?"bg-secondary/15 text-secondary":"text-ink-mute hover:text-ink-dim"),title:"log"===e?"Logarithmic scale — better when one day dwarfs the rest":"Linear scale",children:[e,null===a&&u===e&&(0,n.jsx)("span",{className:"absolute -top-0.5 -right-0.5 w-1.5 h-1.5 rounded-full bg-secondary",title:"auto-selected based on data range"})]},e))})]})]}),(0,n.jsx)("div",{className:"p-4",children:(0,n.jsx)(h,{data:t,metric:i,scale:m})})]})}},30926:(e,t,r)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),!function(e,t){for(var r in t)Object.defineProperty(e,r,{enumerable:!0,get:t[r]})}(t,{callServer:function(){return n.callServer},createServerReference:function(){return s.createServerReference},findSourceMapURL:function(){return o.findSourceMapURL}});let n=r(41209),o=r(85153),s=r(77197)},34077:(e,t,r)=>{"use strict";r.d(t,{FreshnessIndicator:()=>i});var n=r(95155),o=r(12115),s=r(20063);function i(e){let{lastIngestedAt:t}=e,[,r]=(0,o.useState)(0),[i,c]=(0,o.useState)(!1),[d,u]=(0,o.useTransition)(),m=(0,s.useRouter)();(0,o.useEffect)(()=>{let e=setInterval(()=>r(e=>e+1),5e3);return()=>clearInterval(e)},[]);let p=0===t?"never scanned":"updated ".concat(function(e){let t=Date.now()-e;return t<1e3?"just now":t<6e4?"".concat(l(Math.round(t/1e3)),"s"):t<36e5?"".concat(l(Math.round(t/6e4)),"m"):"".concat(l(Math.round(t/36e5)),"h")}(t)," ago"),h=0===t,x=i||d;return(0,n.jsxs)("button",{type:"button",onClick:function(){u(()=>m.refresh())},onMouseEnter:()=>c(!0),onMouseLeave:()=>c(!1),onFocus:()=>c(!0),onBlur:()=>c(!1),disabled:h||d,title:"Re-scan local sessions and refresh",style:{width:"128px"},className:"text-[11px] font-mono tabular px-2 py-0.5 rounded transition-colors text-ink-mute hover:text-primary hover:bg-surface-2 focus-visible:text-primary focus-visible:bg-surface-2 outline-none disabled:opacity-50 disabled:hover:bg-transparent disabled:hover:text-ink-mute disabled:cursor-not-allowed grid items-center",children:[(0,n.jsx)("span",{className:"col-start-1 row-start-1 transition-opacity flex items-center justify-center gap-1.5 whitespace-nowrap",style:{opacity:+!x},children:p}),(0,n.jsxs)("span",{"aria-hidden":!0,className:"col-start-1 row-start-1 transition-opacity flex items-center justify-center gap-1.5 whitespace-nowrap",style:{opacity:+!!x},children:[(0,n.jsx)(a,{spinning:d}),(0,n.jsx)("span",{children:"refresh"})]})]})}function a(e){let{spinning:t}=e;return(0,n.jsxs)("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",className:t?"animate-spin":"",children:[(0,n.jsx)("path",{d:"M3 12a9 9 0 0 1 15.5-6.4L21 8"}),(0,n.jsx)("path",{d:"M21 3v5h-5"}),(0,n.jsx)("path",{d:"M21 12a9 9 0 0 1-15.5 6.4L3 16"}),(0,n.jsx)("path",{d:"M3 21v-5h5"})]})}function l(e){return e<10?"0".concat(e):String(e)}},61438:(e,t,r)=>{"use strict";r.d(t,{ProjectFilter:()=>a});var n=r(95155),o=r(20063),s=r(12115),i=r(47650);function a(e){var t,r;let{projects:a,current:l}=e,c=(0,o.useRouter)(),d=(0,o.usePathname)(),u=(0,o.useSearchParams)(),[m,p]=(0,s.useState)(!1),[h,x]=(0,s.useTransition)(),[f,y]=(0,s.useState)(!1),[b,v]=(0,s.useState)(null),g=(0,s.useRef)(null);(0,s.useEffect)(()=>y(!0),[]);let k=e=>{let t=new URLSearchParams(u.toString());e?t.set("project",e):t.delete("project");let r=t.toString();p(!1),x(()=>c.push(r?"".concat(d,"?").concat(r):d,{scroll:!1}))},j=l?null!=(r=null==(t=a.find(e=>e.id===l))?void 0:t.name)?r:"project":null;return(0,s.useEffect)(()=>{if(!m)return;let e=e=>{var t;let r=e.target;if(null==(t=g.current)?void 0:t.contains(r))return;let n=document.getElementById("project-filter-pop");null!=n&&n.contains(r)||p(!1)},t=e=>{"Escape"===e.key&&p(!1)};return window.addEventListener("mousedown",e),window.addEventListener("keydown",t),()=>{window.removeEventListener("mousedown",e),window.removeEventListener("keydown",t)}},[m]),(0,n.jsxs)(n.Fragment,{children:[(0,n.jsxs)("button",{ref:g,onClick:()=>{if(!m&&g.current){let e=g.current.getBoundingClientRect();v({top:e.bottom+6,left:e.left,width:Math.max(e.width,220)})}p(e=>!e)},className:"text-[11px] font-mono px-2 py-0.5 rounded transition-colors flex items-center gap-1.5 ".concat(l?"bg-primary/15 text-primary":"text-ink-mute hover:text-ink-dim hover:bg-surface-2"," ").concat(h?"opacity-60":""),title:"Filter by project",children:[(0,n.jsx)("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",children:(0,n.jsx)("path",{d:"M22 19a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h5l2 3h9a2 2 0 0 1 2 2z"})}),(0,n.jsx)("span",{className:"truncate max-w-[140px]",children:null!=j?j:"All projects"}),(0,n.jsx)("svg",{width:"8",height:"8",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"3",strokeLinecap:"round",strokeLinejoin:"round",className:"transition-transform ".concat(m?"rotate-180":""),children:(0,n.jsx)("polyline",{points:"6 9 12 15 18 9"})})]}),f&&m&&b&&(0,i.createPortal)((0,n.jsxs)("div",{id:"project-filter-pop",style:{position:"fixed",top:b.top,left:b.left,minWidth:b.width,backgroundColor:"#1c2026",zIndex:100,isolation:"isolate"},className:"border border-surface-3 rounded-md shadow-xl overflow-hidden text-[12px] font-mono max-h-[60vh] overflow-y-auto",children:[(0,n.jsx)("button",{onClick:()=>k(null),className:"w-full text-left px-3 py-2 transition-colors hover:bg-surface-2 ".concat(l?"text-ink-dim":"text-primary bg-primary/10"),children:"All projects"}),(0,n.jsx)("div",{className:"h-px bg-surface-3"}),a.map(e=>(0,n.jsx)("button",{onClick:()=>k(e.id),className:"w-full text-left px-3 py-2 transition-colors hover:bg-surface-2 truncate ".concat(l===e.id?"text-primary bg-primary/10":"text-ink-dim"),title:e.name,children:e.name},e.id)),0===a.length&&(0,n.jsx)("div",{className:"px-3 py-2 text-ink-mute",children:"No projects yet."})]}),document.body)]})}},74050:(e,t,r)=>{"use strict";r.d(t,{ModelFilter:()=>a});var n=r(95155),o=r(20063),s=r(12115),i=r(47650);function a(e){let{families:t,current:r}=e,a=(0,o.useRouter)(),l=(0,o.usePathname)(),c=(0,o.useSearchParams)(),[d,u]=(0,s.useState)(!1),[m,p]=(0,s.useTransition)(),[h,x]=(0,s.useState)(!1),[f,y]=(0,s.useState)(null),b=(0,s.useRef)(null);(0,s.useEffect)(()=>x(!0),[]);let v=e=>{let t=new URLSearchParams(c.toString());e?t.set("model",e):t.delete("model");let r=t.toString();u(!1),p(()=>a.push(r?"".concat(l,"?").concat(r):l,{scroll:!1}))};return(0,s.useEffect)(()=>{if(!d)return;let e=e=>{var t;let r=e.target;if(null==(t=b.current)?void 0:t.contains(r))return;let n=document.getElementById("model-filter-pop");null!=n&&n.contains(r)||u(!1)},t=e=>{"Escape"===e.key&&u(!1)};return window.addEventListener("mousedown",e),window.addEventListener("keydown",t),()=>{window.removeEventListener("mousedown",e),window.removeEventListener("keydown",t)}},[d]),(0,n.jsxs)(n.Fragment,{children:[(0,n.jsxs)("button",{ref:b,onClick:()=>{if(!d&&b.current){let e=b.current.getBoundingClientRect();y({top:e.bottom+6,left:e.left,width:Math.max(e.width,200)})}u(e=>!e)},className:"text-[11px] font-mono px-2 py-0.5 rounded transition-colors flex items-center gap-1.5 ".concat(r?"bg-primary/15 text-primary":"text-ink-mute hover:text-ink-dim hover:bg-surface-2"," ").concat(m?"opacity-60":""),title:"Filter by model",children:[(0,n.jsxs)("svg",{width:"11",height:"11",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("circle",{cx:"12",cy:"12",r:"4"}),(0,n.jsx)("path",{d:"M12 2v2M12 20v2M2 12h2M20 12h2M4.9 4.9l1.4 1.4M17.7 17.7l1.4 1.4M4.9 19.1l1.4-1.4M17.7 6.3l1.4-1.4"})]}),(0,n.jsx)("span",{className:"truncate max-w-[140px]",children:null!=r?r:"All models"}),(0,n.jsx)("svg",{width:"8",height:"8",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"3",strokeLinecap:"round",strokeLinejoin:"round",className:"transition-transform ".concat(d?"rotate-180":""),children:(0,n.jsx)("polyline",{points:"6 9 12 15 18 9"})})]}),h&&d&&f&&(0,i.createPortal)((0,n.jsxs)("div",{id:"model-filter-pop",style:{position:"fixed",top:f.top,left:f.left,minWidth:f.width,backgroundColor:"#1c2026",zIndex:100,isolation:"isolate"},className:"border border-surface-3 rounded-md shadow-xl overflow-hidden text-[12px] font-mono max-h-[60vh] overflow-y-auto",children:[(0,n.jsx)("button",{onClick:()=>v(null),className:"w-full text-left px-3 py-2 transition-colors hover:bg-surface-2 ".concat(r?"text-ink-dim":"text-primary bg-primary/10"),children:"All models"}),(0,n.jsx)("div",{className:"h-px bg-surface-3"}),t.map(e=>(0,n.jsxs)("button",{onClick:()=>v(e.family),className:"w-full text-left px-3 py-2 transition-colors hover:bg-surface-2 flex items-center justify-between gap-3 ".concat(r===e.family?"text-primary bg-primary/10":"text-ink-dim"),title:e.family,children:[(0,n.jsx)("span",{className:"truncate",children:e.family}),(0,n.jsx)("span",{className:"text-ink-mute text-[10px] tabular",children:e.sessions})]},e.family)),0===t.length&&(0,n.jsx)("div",{className:"px-3 py-2 text-ink-mute",children:"No models seen yet."})]}),document.body)]})}},95925:(e,t,r)=>{"use strict";r.d(t,{RangePicker:()=>a});var n=r(95155),o=r(20063),s=r(12115);let i=[{key:"7d",label:"Last 7 days",days:7},{key:"30d",label:"Last 30 days",days:30},{key:"90d",label:"Last 90 days",days:90},{key:"all",label:"All time",days:null}];function a(e){let{current:t}=e,r=(0,o.useRouter)(),a=(0,o.usePathname)(),l=(0,o.useSearchParams)(),[c,d]=(0,s.useTransition)();return(0,n.jsx)("div",{className:"flex items-center gap-0.5 normal-case tracking-normal transition-opacity ".concat(c?"opacity-50":""),children:i.map(e=>(0,n.jsx)("button",{onClick:()=>(e=>{let t=new URLSearchParams(l.toString());"30d"===e?t.delete("range"):t.set("range",e);let n=t.toString();d(()=>{r.push(n?"".concat(a,"?").concat(n):a)})})(e.key),className:"px-2 py-0.5 text-[11px] rounded transition-colors font-mono ".concat(t===e.key?"bg-primary/15 text-primary":"text-ink-mute hover:text-ink-dim"),children:"all"===e.key?"All":e.key},e.key))})}}},e=>{e.O(0,[619,997,441,255,358],()=>e(e.s=2278)),_N_E=e.O()}]);
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[801],{16500:(e,t,o)=>{Promise.resolve().then(o.t.bind(o,52619,23)),Promise.resolve().then(o.bind(o,17834))},17834:(e,t,o)=>{"use strict";o.d(t,{ShareButton:()=>r});var n=o(95155),i=o(12115);function r(e){let{imageUrl:t,className:o}=e,[r,d]=(0,i.useState)("idle"),[c,u]=(0,i.useState)(null),h=async()=>{d("busy"),u(null);try{var e;let o=await fetch(t);if(!o.ok)throw Error("HTTP ".concat(o.status));let n=await o.blob();if("undefined"==typeof ClipboardItem||!(null==(e=navigator.clipboard)?void 0:e.write))throw Error("clipboard image unsupported");let i=new ClipboardItem({"image/png":n});await navigator.clipboard.write([i]),d("done"),setTimeout(()=>d("idle"),2400)}catch(e){try{let e=await fetch(t),o=await e.blob(),n=URL.createObjectURL(o),i=document.createElement("a");i.href=n,i.download="agentgraphed-stats.png",document.body.appendChild(i),i.click(),document.body.removeChild(i),setTimeout(()=>URL.revokeObjectURL(n),5e3),u("Saved to Downloads (clipboard image unsupported)"),d("err"),setTimeout(()=>d("idle"),4e3)}catch(t){u(t.message||e.message),d("err"),setTimeout(()=>d("idle"),3e3)}}};return(0,n.jsx)("button",{onClick:h,disabled:"busy"===r,"aria-label":"Share",title:"busy"===r?"Generating image…":"done"===r?"Image copied to clipboard":"err"===r?null!=c?c:"Try again":"Copy share image to clipboard",className:"btn-icon ".concat("done"===r?"text-secondary":""," ").concat(null!=o?o:""),children:"busy"===r?(0,n.jsx)(l,{}):"done"===r?(0,n.jsx)(s,{}):(0,n.jsx)(a,{})})}function a(){return(0,n.jsxs)("svg",{width:"17",height:"17",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.4",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("path",{d:"M4 12v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-8"}),(0,n.jsx)("polyline",{points:"16 6 12 2 8 6"}),(0,n.jsx)("line",{x1:"12",y1:"2",x2:"12",y2:"15"})]})}function s(){return(0,n.jsx)("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",children:(0,n.jsx)("polyline",{points:"20 6 9 17 4 12"})})}function l(){return(0,n.jsx)("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"animate-spin",children:(0,n.jsx)("path",{d:"M21 12a9 9 0 1 1-6.219-8.56"})})}}},e=>{e.O(0,[619,441,255,358],()=>e(e.s=16500)),_N_E=e.O()}]);
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[404,893],{8724:(e,s,_)=>{Promise.resolve().then(_.t.bind(_,52619,23))}},e=>{e.O(0,[619,441,255,358],()=>e(e.s=8724)),_N_E=e.O()}]);
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[898],{20063:(e,t,r)=>{"use strict";var n=r(47260);r.o(n,"usePathname")&&r.d(t,{usePathname:function(){return n.usePathname}}),r.o(n,"useRouter")&&r.d(t,{useRouter:function(){return n.useRouter}}),r.o(n,"useSearchParams")&&r.d(t,{useSearchParams:function(){return n.useSearchParams}})},20467:(e,t,r)=>{"use strict";function n(e){return e>=1e6?"".concat((e/1e6).toFixed(1),"M"):e>=1e3?"".concat((e/1e3).toFixed(1),"k"):e.toString()}function a(e){return e>=1e3?"$".concat(e.toFixed(0)):"$".concat(e.toFixed(2))}function s(e){let t=Math.floor(e/1e3);if(t<60)return"".concat(t,"s");let r=Math.floor(t/60);if(r<60)return"".concat(r,"m");let n=Math.floor(r/60);return"".concat(n,"h ").concat(r%60,"m")}r.d(t,{F0:()=>a,c5:()=>s,yj:()=>n})},38250:(e,t,r)=>{"use strict";r.d(t,{SessionRow:()=>i});var n=r(95155),a=r(20063),s=r(20467);let o={Planning:"bg-tertiary-soft text-ink-dim border-ink-mute/30",Debugging:"bg-error/15 text-error border-error/30",Refactor:"bg-primary/10 text-primary border-primary/30",Feature:"bg-secondary/10 text-secondary border-secondary/30",Styling:"bg-fuchsia-400/10 text-fuchsia-300 border-fuchsia-400/30","SEO/Content":"bg-amber-400/10 text-amber-300 border-amber-400/30",DevOps:"bg-orange-400/10 text-orange-300 border-orange-400/30",Data:"bg-sky-400/10 text-sky-300 border-sky-400/30",Payments:"bg-emerald-400/10 text-emerald-300 border-emerald-400/30",Docs:"bg-violet-400/10 text-violet-300 border-violet-400/30",Unknown:"bg-surface-3 text-ink-mute border-surface-4"};function c(e){let{category:t,size:r="sm"}=e,a=o[t]||o.Unknown;return(0,n.jsx)("span",{className:"inline-block ".concat("xs"===r?"text-[9px] px-1 py-0":"text-[10px] px-1.5 py-0.5"," rounded font-mono uppercase tracking-wider border ").concat(a," shrink-0"),children:t})}function i(e){let{session:t,zebra:r}=e,o=(0,a.useRouter)(),i="/sessions/".concat(t.id),u=t.input_tokens+t.output_tokens+t.cache_read_tokens+t.cache_write_tokens,l=t.summary?t.summary.split("\n")[0].trim():t.heuristic_title?t.heuristic_title:t.first_prompt?function(e){let t=e.trim(),r=(t=(t=(t=(t=(t=(t=(t=t.replace(/<[^>]+>/g," ")).replace(/^\/[a-z][a-z0-9-]*(\s|$)/i,"")).replace(/```[a-z]*\n?/gi," ").replace(/```/g," ").replace(/`/g,"")).replace(/\[([^\]]+)\]\([^)]*\)/g,"$1")).replace(/https?:\/\/\S+/g,"")).replace(/(^|\s)(\/|~\/)[\w./~-]+/g," ")).replace(/\s+/g," ").trim()).search(/[.!?](\s|$)/);if(r>8&&r<90&&(t=t.slice(0,r).trim()),0===t.length)return"(untitled session)";if((t=t.charAt(0).toUpperCase()+t.slice(1)).length<=90)return t;let n=t.lastIndexOf(" ",90);return(n>50?t.slice(0,n):t.slice(0,90))+"…"}(t.first_prompt):"(untitled session)",d=function(e){if(e.categories)try{let t=JSON.parse(e.categories);if(Array.isArray(t))return t.filter(e=>"string"==typeof e)}catch(e){}return e.category?[e.category]:[]}(t);return(0,n.jsxs)("tr",{onClick:()=>o.push(i),onAuxClick:e=>{1===e.button&&window.open(i,"_blank")},onKeyDown:e=>{"Enter"===e.key&&o.push(i)},tabIndex:0,role:"link",className:"border-t border-surface-2 cursor-pointer transition-colors hover:bg-surface-2/60 focus:outline-none focus:bg-surface-2/70 ".concat(r?"bg-surface-1/30":""),children:[(0,n.jsx)("td",{className:"px-3 py-2 font-mono text-code-sm text-ink-mute",children:new Date(t.started_at).toLocaleString([],{month:"short",day:"numeric",hour:"2-digit",minute:"2-digit"})}),(0,n.jsx)("td",{className:"px-3 py-2",children:(0,n.jsx)("span",{className:"inline-block px-1.5 py-0.5 rounded text-[10px] font-mono uppercase tracking-wider ".concat("claude"===t.provider?"bg-primary/15 text-primary":"bg-secondary/15 text-secondary"),children:t.provider})}),(0,n.jsx)("td",{className:"px-3 py-2 text-ink-dim",children:t.project_name}),(0,n.jsx)("td",{className:"px-3 py-2 font-mono text-code-sm text-ink-mute truncate max-w-[180px]",children:t.model||"—"}),(0,n.jsx)("td",{className:"px-3 py-2 max-w-[420px]",children:(0,n.jsxs)("div",{className:"flex items-center gap-2 flex-wrap",children:[(0,n.jsx)("span",{className:"text-ink truncate",children:l}),d.map(e=>(0,n.jsx)(c,{category:e},e))]})}),(0,n.jsx)("td",{className:"px-3 py-2 text-right font-mono tabular",children:(0,s.yj)(u)}),(0,n.jsx)("td",{className:"px-3 py-2 text-right font-mono tabular text-secondary",children:(0,s.F0)(t.est_cost_usd)}),(0,n.jsx)("td",{className:"px-3 py-2 text-right font-mono tabular text-ink-mute",children:(0,s.c5)(t.duration_ms)})]})}},99884:(e,t,r)=>{Promise.resolve().then(r.bind(r,38250))}},e=>{e.O(0,[441,255,358],()=>e(e.s=99884)),_N_E=e.O()}]);
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[662],{25511:(e,s,a)=>{"use strict";a.d(s,{v:()=>r});var t=a(30926);let r=(0,t.createServerReference)("40ebbe581be2d6a1560853a1f470f6bef259ff3ce0",t.callServer,void 0,t.findSourceMapURL,"classifyAction")},30926:(e,s,a)=>{"use strict";Object.defineProperty(s,"__esModule",{value:!0}),!function(e,s){for(var a in s)Object.defineProperty(e,a,{enumerable:!0,get:s[a]})}(s,{callServer:function(){return t.callServer},createServerReference:function(){return n.createServerReference},findSourceMapURL:function(){return r.findSourceMapURL}});let t=a(41209),r=a(85153),n=a(77197)},66700:(e,s,a)=>{Promise.resolve().then(a.bind(a,68566))},68566:(e,s,a)=>{"use strict";a.d(s,{LlmSection:()=>x});var t=a(95155),r=a(12115),n=a(30926);let i=(0,n.createServerReference)("40acb06b98d922bbaa705775c5e053590069080d2e",n.callServer,void 0,n.findSourceMapURL,"saveLlmAction"),o=(0,n.createServerReference)("403820812a9461424d17b14bf3b24acd13354c2523",n.callServer,void 0,n.findSourceMapURL,"setAutoClassifyAction"),l=(0,n.createServerReference)("40d6068a0e90cc763358acc206b8d68d79340910e7",n.callServer,void 0,n.findSourceMapURL,"clearKeyAction"),c=(0,n.createServerReference)("404e24f64e5bf12ba9bd1bba81003a96aa21b8f8f0",n.callServer,void 0,n.findSourceMapURL,"estimateAction");var d=a(25511);let m=[{id:"claude-haiku-4-5",label:"Claude Haiku 4.5 (cheapest)",provider:"anthropic",input:1,output:5},{id:"claude-sonnet-4-6",label:"Claude Sonnet 4.6 (smarter)",provider:"anthropic",input:3,output:15},{id:"gpt-5-mini",label:"GPT-5 Mini (cheapest)",provider:"openai",input:.5,output:2},{id:"gpt-4o-mini",label:"GPT-4o Mini (very cheap)",provider:"openai",input:.15,output:.6},{id:"gpt-5",label:"GPT-5 (smarter)",provider:"openai",input:2.5,output:10}];function p(e){return m.filter(s=>s.provider===e)}function u(e){return"openai"===e?"gpt-5-mini":"claude-haiku-4-5"}let b=e=>e?e.slice(0,8)+"…"+e.slice(-4):"";function x(e){let{provider:s,anthKey:a,oaiKey:n,classifierModel:m,summarizerModel:x,classified:f,total:h,autoClassify:v}=e,[y,k]=(0,r.useState)(s),[j,N]=(0,r.useState)(m),[g,w]=(0,r.useState)(null),[S,C]=(0,r.useState)(v),[L,R]=(0,r.useState)({kind:"idle"}),[U,A]=(0,r.useTransition)(),M=("openai"===y?n:a).length>0,_=p(y),O=_.some(e=>e.id===j)?j:u(y),P=e=>{R({kind:"idle"}),A(async()=>{let s=await c(e);s.ok?R({kind:"estimate",totalUsd:s.totalUsd,rowCount:s.rowCount,modelLabel:s.modelLabel,scope:e}):R({kind:"error",message:s.error})})};return(0,t.jsxs)("div",{className:"card",children:[(0,t.jsxs)("div",{className:"card-header flex items-center justify-between",children:[(0,t.jsx)("span",{children:"LLM provider"}),(0,t.jsxs)("span",{className:"normal-case tracking-normal text-ink-mute text-[11px] font-mono",children:[f,"/",h," sessions classified"]})]}),(0,t.jsxs)("form",{action:e=>{A(async()=>{await i(e),w(Date.now()),setTimeout(()=>w(null),2e3)})},className:"p-5 space-y-4 text-body-md",children:[(0,t.jsxs)("p",{className:"text-ink-dim text-body-sm",children:["Optional. Used to auto-title and categorize sessions, and to generate context primers when you click ",(0,t.jsx)("em",{children:"Copy context"})," on a session. Skip this and titles stay as the raw first prompt."]}),(0,t.jsxs)("div",{className:"grid grid-cols-2 gap-3",children:[(0,t.jsxs)("div",{className:"space-y-1",children:[(0,t.jsx)("label",{className:"text-label-caps text-ink-mute block",children:"Provider"}),(0,t.jsxs)("select",{name:"provider",value:y,onChange:e=>{var s;k(s=e.target.value),p(s).some(e=>e.id===j)||N(u(s))},className:"bg-surface-1 border border-surface-3 rounded px-2 h-9 text-body-md w-full",children:[(0,t.jsx)("option",{value:"anthropic",children:"Anthropic"}),(0,t.jsx)("option",{value:"openai",children:"OpenAI"})]})]}),(0,t.jsxs)("div",{className:"space-y-1",children:[(0,t.jsx)("label",{className:"text-label-caps text-ink-mute block",children:"Model"}),(0,t.jsx)("select",{name:"classifier_model",value:O,onChange:e=>N(e.target.value),className:"bg-surface-1 border border-surface-3 rounded px-2 h-9 text-body-md font-mono w-full",children:_.map(e=>(0,t.jsx)("option",{value:e.id,children:e.label},e.id))})]})]}),(0,t.jsxs)("div",{className:"grid grid-cols-2 gap-3",children:[(0,t.jsxs)("div",{className:"space-y-1",children:[(0,t.jsxs)("label",{className:"text-label-caps text-ink-mute block flex items-center justify-between",children:["Anthropic key",a&&(0,t.jsx)("button",{type:"button",onClick:()=>A(()=>l("anthropic")),className:"normal-case tracking-normal text-[10px] text-ink-mute hover:text-error",children:"clear"})]}),(0,t.jsx)("input",{type:"password",name:"anthropic_key",placeholder:b(a)||"sk-ant-…",className:"bg-surface-1 border border-surface-3 rounded px-3 h-9 text-body-md font-mono w-full focus:outline-none focus:border-primary"})]}),(0,t.jsxs)("div",{className:"space-y-1",children:[(0,t.jsxs)("label",{className:"text-label-caps text-ink-mute block flex items-center justify-between",children:["OpenAI key",n&&(0,t.jsx)("button",{type:"button",onClick:()=>A(()=>l("openai")),className:"normal-case tracking-normal text-[10px] text-ink-mute hover:text-error",children:"clear"})]}),(0,t.jsx)("input",{type:"password",name:"openai_key",placeholder:b(n)||"sk-…",className:"bg-surface-1 border border-surface-3 rounded px-3 h-9 text-body-md font-mono w-full focus:outline-none focus:border-primary"})]})]}),(0,t.jsxs)("p",{className:"text-[11px] text-ink-mute leading-relaxed",children:["Keys are stored in plaintext in your local SQLite file — same threat model as"," ",(0,t.jsx)("span",{className:"font-mono",children:"~/.aws/credentials"})," or a ",(0,t.jsx)("span",{className:"font-mono",children:".env"}),". Never sent over the network. Any process that can read your home folder can read them."]}),(0,t.jsx)("input",{type:"hidden",name:"summarizer_model",value:x}),(0,t.jsxs)("div",{className:"flex items-center gap-2",children:[(0,t.jsx)("button",{className:"btn btn-primary",type:"submit",disabled:U,children:U?"Saving…":"Save"}),g&&(0,t.jsx)("span",{className:"text-body-sm text-secondary",children:"✓ saved"})]})]}),(0,t.jsxs)("div",{className:"px-5 pb-5 border-t border-surface-2 pt-4 space-y-3",children:[(0,t.jsxs)("label",{className:"flex items-start gap-3 text-body-sm ".concat(M?"cursor-pointer":"opacity-60 cursor-not-allowed"),children:[(0,t.jsx)("input",{type:"checkbox",checked:S,onChange:e=>{var s;C(s=e.target.checked),A(async()=>{await o(s)})},disabled:!M||U,className:"mt-1 accent-primary"}),(0,t.jsxs)("span",{className:"text-ink-dim",children:[(0,t.jsx)("span",{className:"text-ink font-medium",children:"Automatically classify new sessions"}),(0,t.jsx)("span",{className:"block text-ink-mute text-[11px] mt-0.5",children:"When a background scan finds unclassified sessions, batch them through the classifier. Costs ~$0.0001 per session."})]})]}),(0,t.jsxs)("div",{className:"flex items-center gap-2 flex-wrap",children:[(0,t.jsx)("button",{type:"button",disabled:!M||U,onClick:()=>P("uncategorized"),className:"btn disabled:opacity-50 disabled:cursor-not-allowed",children:"Classify uncategorized"}),(0,t.jsx)("button",{type:"button",disabled:!M||U,onClick:()=>P("all"),className:"btn disabled:opacity-50 disabled:cursor-not-allowed",children:"Re-classify all"}),!M&&(0,t.jsx)("span",{className:"text-body-sm text-ink-mute",children:"Save a key above to enable."})]}),"estimate"===L.kind&&(0,t.jsxs)("div",{className:"border border-primary/40 bg-primary/5 rounded p-3 text-body-sm",children:[(0,t.jsx)("div",{className:"text-ink mb-2",children:0===L.rowCount?"Nothing to classify.":(0,t.jsxs)(t.Fragment,{children:["About to classify ",(0,t.jsx)("span",{className:"font-mono text-primary",children:L.rowCount})," ","sessions with ",L.modelLabel," for an estimated"," ",(0,t.jsxs)("span",{className:"font-mono text-primary",children:["$",L.totalUsd.toFixed(4)]}),"."]})}),L.rowCount>0&&(0,t.jsxs)("div",{className:"flex items-center gap-2",children:[(0,t.jsx)("button",{type:"button",onClick:()=>{var e;return e=L.scope,void A(async()=>{let s=await (0,d.v)(e);s.ok?R({kind:"done",classified:s.classified,costUsd:s.costUsd,warning:s.warning}):R({kind:"error",message:s.error})})},className:"btn btn-primary",disabled:U,children:U?"Classifying…":"Confirm"}),(0,t.jsx)("button",{type:"button",onClick:()=>R({kind:"idle"}),className:"btn",disabled:U,children:"Cancel"})]})]}),"done"===L.kind&&(0,t.jsxs)("div",{className:"border border-secondary/40 bg-secondary/5 rounded p-3 text-body-sm text-ink space-y-1",children:[(0,t.jsxs)("div",{children:["✓ Classified ",(0,t.jsx)("span",{className:"font-mono text-secondary",children:L.classified})," ","sessions for ",(0,t.jsxs)("span",{className:"font-mono",children:["$",L.costUsd.toFixed(4)]}),"."]}),L.warning&&(0,t.jsxs)("div",{className:"text-error text-[11px] border-l-2 border-error pl-2 font-mono break-words",children:["Warning: ",L.warning]})]}),"error"===L.kind&&(0,t.jsx)("div",{className:"text-body-sm text-error border-l-2 border-error pl-3",children:L.message})]})]})}}},e=>{e.O(0,[441,255,358],()=>e(e.s=66700)),_N_E=e.O()}]);
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[404,893],{8724:(e,s,_)=>{Promise.resolve().then(_.t.bind(_,52619,23))}},e=>{e.O(0,[619,441,255,358],()=>e(e.s=8724)),_N_E=e.O()}]);
@@ -1,90 +0,0 @@
1
- 'use strict';
2
- const fs = require('fs');
3
- const path = require('path');
4
- const util = require('./util');
5
- const SqliteError = require('./sqlite-error');
6
-
7
- let DEFAULT_ADDON;
8
-
9
- function Database(filenameGiven, options) {
10
- if (new.target == null) {
11
- return new Database(filenameGiven, options);
12
- }
13
-
14
- // Apply defaults
15
- let buffer;
16
- if (Buffer.isBuffer(filenameGiven)) {
17
- buffer = filenameGiven;
18
- filenameGiven = ':memory:';
19
- }
20
- if (filenameGiven == null) filenameGiven = '';
21
- if (options == null) options = {};
22
-
23
- // Validate arguments
24
- if (typeof filenameGiven !== 'string') throw new TypeError('Expected first argument to be a string');
25
- if (typeof options !== 'object') throw new TypeError('Expected second argument to be an options object');
26
- if ('readOnly' in options) throw new TypeError('Misspelled option "readOnly" should be "readonly"');
27
- if ('memory' in options) throw new TypeError('Option "memory" was removed in v7.0.0 (use ":memory:" filename instead)');
28
-
29
- // Interpret options
30
- const filename = filenameGiven.trim();
31
- const anonymous = filename === '' || filename === ':memory:';
32
- const readonly = util.getBooleanOption(options, 'readonly');
33
- const fileMustExist = util.getBooleanOption(options, 'fileMustExist');
34
- const timeout = 'timeout' in options ? options.timeout : 5000;
35
- const verbose = 'verbose' in options ? options.verbose : null;
36
- const nativeBinding = 'nativeBinding' in options ? options.nativeBinding : null;
37
-
38
- // Validate interpreted options
39
- if (readonly && anonymous && !buffer) throw new TypeError('In-memory/temporary databases cannot be readonly');
40
- if (!Number.isInteger(timeout) || timeout < 0) throw new TypeError('Expected the "timeout" option to be a positive integer');
41
- if (timeout > 0x7fffffff) throw new RangeError('Option "timeout" cannot be greater than 2147483647');
42
- if (verbose != null && typeof verbose !== 'function') throw new TypeError('Expected the "verbose" option to be a function');
43
- if (nativeBinding != null && typeof nativeBinding !== 'string' && typeof nativeBinding !== 'object') throw new TypeError('Expected the "nativeBinding" option to be a string or addon object');
44
-
45
- // Load the native addon
46
- let addon;
47
- if (nativeBinding == null) {
48
- addon = DEFAULT_ADDON || (DEFAULT_ADDON = require('bindings')('better_sqlite3.node'));
49
- } else if (typeof nativeBinding === 'string') {
50
- // See <https://webpack.js.org/api/module-variables/#__non_webpack_require__-webpack-specific>
51
- const requireFunc = typeof __non_webpack_require__ === 'function' ? __non_webpack_require__ : require;
52
- addon = requireFunc(path.resolve(nativeBinding).replace(/(\.node)?$/, '.node'));
53
- } else {
54
- // See <https://github.com/WiseLibs/better-sqlite3/issues/972>
55
- addon = nativeBinding;
56
- }
57
-
58
- if (!addon.isInitialized) {
59
- addon.setErrorConstructor(SqliteError);
60
- addon.isInitialized = true;
61
- }
62
-
63
- // Make sure the specified directory exists
64
- if (!anonymous && !fs.existsSync(path.dirname(filename))) {
65
- throw new TypeError('Cannot open database because the directory does not exist');
66
- }
67
-
68
- Object.defineProperties(this, {
69
- [util.cppdb]: { value: new addon.Database(filename, filenameGiven, anonymous, readonly, fileMustExist, timeout, verbose || null, buffer || null) },
70
- ...wrappers.getters,
71
- });
72
- }
73
-
74
- const wrappers = require('./methods/wrappers');
75
- Database.prototype.prepare = wrappers.prepare;
76
- Database.prototype.transaction = require('./methods/transaction');
77
- Database.prototype.pragma = require('./methods/pragma');
78
- Database.prototype.backup = require('./methods/backup');
79
- Database.prototype.serialize = require('./methods/serialize');
80
- Database.prototype.function = require('./methods/function');
81
- Database.prototype.aggregate = require('./methods/aggregate');
82
- Database.prototype.table = require('./methods/table');
83
- Database.prototype.loadExtension = wrappers.loadExtension;
84
- Database.prototype.exec = wrappers.exec;
85
- Database.prototype.close = wrappers.close;
86
- Database.prototype.defaultSafeIntegers = wrappers.defaultSafeIntegers;
87
- Database.prototype.unsafeMode = wrappers.unsafeMode;
88
- Database.prototype[util.inspect] = require('./methods/inspect');
89
-
90
- module.exports = Database;
@@ -1,3 +0,0 @@
1
- 'use strict';
2
- module.exports = require('./database');
3
- module.exports.SqliteError = require('./sqlite-error');
@@ -1,43 +0,0 @@
1
- 'use strict';
2
- const { getBooleanOption, cppdb } = require('../util');
3
-
4
- module.exports = function defineAggregate(name, options) {
5
- // Validate arguments
6
- if (typeof name !== 'string') throw new TypeError('Expected first argument to be a string');
7
- if (typeof options !== 'object' || options === null) throw new TypeError('Expected second argument to be an options object');
8
- if (!name) throw new TypeError('User-defined function name cannot be an empty string');
9
-
10
- // Interpret options
11
- const start = 'start' in options ? options.start : null;
12
- const step = getFunctionOption(options, 'step', true);
13
- const inverse = getFunctionOption(options, 'inverse', false);
14
- const result = getFunctionOption(options, 'result', false);
15
- const safeIntegers = 'safeIntegers' in options ? +getBooleanOption(options, 'safeIntegers') : 2;
16
- const deterministic = getBooleanOption(options, 'deterministic');
17
- const directOnly = getBooleanOption(options, 'directOnly');
18
- const varargs = getBooleanOption(options, 'varargs');
19
- let argCount = -1;
20
-
21
- // Determine argument count
22
- if (!varargs) {
23
- argCount = Math.max(getLength(step), inverse ? getLength(inverse) : 0);
24
- if (argCount > 0) argCount -= 1;
25
- if (argCount > 100) throw new RangeError('User-defined functions cannot have more than 100 arguments');
26
- }
27
-
28
- this[cppdb].aggregate(start, step, inverse, result, name, argCount, safeIntegers, deterministic, directOnly);
29
- return this;
30
- };
31
-
32
- const getFunctionOption = (options, key, required) => {
33
- const value = key in options ? options[key] : null;
34
- if (typeof value === 'function') return value;
35
- if (value != null) throw new TypeError(`Expected the "${key}" option to be a function`);
36
- if (required) throw new TypeError(`Missing required option "${key}"`);
37
- return null;
38
- };
39
-
40
- const getLength = ({ length }) => {
41
- if (Number.isInteger(length) && length >= 0) return length;
42
- throw new TypeError('Expected function.length to be a positive integer');
43
- };
@@ -1,67 +0,0 @@
1
- 'use strict';
2
- const fs = require('fs');
3
- const path = require('path');
4
- const { promisify } = require('util');
5
- const { cppdb } = require('../util');
6
- const fsAccess = promisify(fs.access);
7
-
8
- module.exports = async function backup(filename, options) {
9
- if (options == null) options = {};
10
-
11
- // Validate arguments
12
- if (typeof filename !== 'string') throw new TypeError('Expected first argument to be a string');
13
- if (typeof options !== 'object') throw new TypeError('Expected second argument to be an options object');
14
-
15
- // Interpret options
16
- filename = filename.trim();
17
- const attachedName = 'attached' in options ? options.attached : 'main';
18
- const handler = 'progress' in options ? options.progress : null;
19
-
20
- // Validate interpreted options
21
- if (!filename) throw new TypeError('Backup filename cannot be an empty string');
22
- if (filename === ':memory:') throw new TypeError('Invalid backup filename ":memory:"');
23
- if (typeof attachedName !== 'string') throw new TypeError('Expected the "attached" option to be a string');
24
- if (!attachedName) throw new TypeError('The "attached" option cannot be an empty string');
25
- if (handler != null && typeof handler !== 'function') throw new TypeError('Expected the "progress" option to be a function');
26
-
27
- // Make sure the specified directory exists
28
- await fsAccess(path.dirname(filename)).catch(() => {
29
- throw new TypeError('Cannot save backup because the directory does not exist');
30
- });
31
-
32
- const isNewFile = await fsAccess(filename).then(() => false, () => true);
33
- return runBackup(this[cppdb].backup(this, attachedName, filename, isNewFile), handler || null);
34
- };
35
-
36
- const runBackup = (backup, handler) => {
37
- let rate = 0;
38
- let useDefault = true;
39
-
40
- return new Promise((resolve, reject) => {
41
- setImmediate(function step() {
42
- try {
43
- const progress = backup.transfer(rate);
44
- if (!progress.remainingPages) {
45
- backup.close();
46
- resolve(progress);
47
- return;
48
- }
49
- if (useDefault) {
50
- useDefault = false;
51
- rate = 100;
52
- }
53
- if (handler) {
54
- const ret = handler(progress);
55
- if (ret !== undefined) {
56
- if (typeof ret === 'number' && ret === ret) rate = Math.max(0, Math.min(0x7fffffff, Math.round(ret)));
57
- else throw new TypeError('Expected progress callback to return a number or undefined');
58
- }
59
- }
60
- setImmediate(step);
61
- } catch (err) {
62
- backup.close();
63
- reject(err);
64
- }
65
- });
66
- });
67
- };
@@ -1,31 +0,0 @@
1
- 'use strict';
2
- const { getBooleanOption, cppdb } = require('../util');
3
-
4
- module.exports = function defineFunction(name, options, fn) {
5
- // Apply defaults
6
- if (options == null) options = {};
7
- if (typeof options === 'function') { fn = options; options = {}; }
8
-
9
- // Validate arguments
10
- if (typeof name !== 'string') throw new TypeError('Expected first argument to be a string');
11
- if (typeof fn !== 'function') throw new TypeError('Expected last argument to be a function');
12
- if (typeof options !== 'object') throw new TypeError('Expected second argument to be an options object');
13
- if (!name) throw new TypeError('User-defined function name cannot be an empty string');
14
-
15
- // Interpret options
16
- const safeIntegers = 'safeIntegers' in options ? +getBooleanOption(options, 'safeIntegers') : 2;
17
- const deterministic = getBooleanOption(options, 'deterministic');
18
- const directOnly = getBooleanOption(options, 'directOnly');
19
- const varargs = getBooleanOption(options, 'varargs');
20
- let argCount = -1;
21
-
22
- // Determine argument count
23
- if (!varargs) {
24
- argCount = fn.length;
25
- if (!Number.isInteger(argCount) || argCount < 0) throw new TypeError('Expected function.length to be a positive integer');
26
- if (argCount > 100) throw new RangeError('User-defined functions cannot have more than 100 arguments');
27
- }
28
-
29
- this[cppdb].function(fn, name, argCount, safeIntegers, deterministic, directOnly);
30
- return this;
31
- };
@@ -1,7 +0,0 @@
1
- 'use strict';
2
- const DatabaseInspection = function Database() {};
3
-
4
- module.exports = function inspect(depth, opts) {
5
- return Object.assign(new DatabaseInspection(), this);
6
- };
7
-