@hienlh/ppm 0.8.39 → 0.8.41

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 (50) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/chat-ui-test-1.png +0 -0
  3. package/chat-ui-test-mid.png +0 -0
  4. package/chat-ui-test-mid2.png +0 -0
  5. package/chat-ui-test-top.png +0 -0
  6. package/chat-ui-v2-mid.png +0 -0
  7. package/dist/web/assets/{api-settings-0Hx_9lIU.js → api-settings-CaKDC7_s.js} +1 -1
  8. package/dist/web/assets/chat-tab-CN-ULuHd.js +7 -0
  9. package/dist/web/assets/{code-editor-DZlXHMtA.js → code-editor-CFZAz_WA.js} +1 -1
  10. package/dist/web/assets/{database-viewer-BaxjPtYR.js → database-viewer-DT9IEf-4.js} +1 -1
  11. package/dist/web/assets/{diff-viewer-CDdO3tqP.js → diff-viewer-SZcQ0Arc.js} +1 -1
  12. package/dist/web/assets/git-graph-DsKiCtcj.js +1 -0
  13. package/dist/web/assets/{index-CvbNQ1mi.js → index-BiOW8qrf.js} +8 -8
  14. package/dist/web/assets/index-CGOBw13I.css +2 -0
  15. package/dist/web/assets/{input-4ElbicvY.js → input-CE3bFwLk.js} +1 -1
  16. package/dist/web/assets/keybindings-store-BShKvCCo.js +1 -0
  17. package/dist/web/assets/markdown-renderer-Cr3-VbIg.js +59 -0
  18. package/dist/web/assets/{postgres-viewer-hmqfZRr-.js → postgres-viewer-BhTz35TV.js} +1 -1
  19. package/dist/web/assets/{settings-store-Clv3ZNje.js → settings-store-xG6mKqkD.js} +2 -2
  20. package/dist/web/assets/settings-tab-TlZunMhi.js +1 -0
  21. package/dist/web/assets/{sqlite-viewer-9X_1ZHJE.js → sqlite-viewer-CnZbwR2F.js} +1 -1
  22. package/dist/web/assets/{tab-store-D7tRt0VT.js → tab-store-NOBndc0_.js} +1 -1
  23. package/dist/web/assets/tag-DJUYe5BQ.js +1 -0
  24. package/dist/web/assets/{terminal-tab-V7x81Qpr.js → terminal-tab-BBy02Lde.js} +1 -1
  25. package/dist/web/assets/{use-monaco-theme-czriskTO.js → use-monaco-theme-DlFSiqvG.js} +1 -1
  26. package/dist/web/index.html +9 -9
  27. package/dist/web/sw.js +1 -1
  28. package/docs/lessons-learned.md +5 -12
  29. package/package.json +2 -3
  30. package/sdh-uit-edu-vn-screenshot.png +0 -0
  31. package/src/index.ts +0 -10
  32. package/src/providers/claude-agent-sdk.ts +57 -292
  33. package/src/server/routes/fs-browse.ts +21 -0
  34. package/src/types/config.ts +0 -8
  35. package/src/web/components/chat/message-list.tsx +163 -55
  36. package/src/web/components/settings/ai-settings-section.tsx +0 -24
  37. package/src/web/components/shared/markdown-renderer.tsx +48 -2
  38. package/src/web/lib/api-settings.ts +0 -1
  39. package/dist/web/assets/chat-tab-CGic5t8w.js +0 -7
  40. package/dist/web/assets/git-graph-C-TRbbx7.js +0 -1
  41. package/dist/web/assets/index-DXTts38q.css +0 -2
  42. package/dist/web/assets/keybindings-store-Dqs-i9cV.js +0 -1
  43. package/dist/web/assets/markdown-renderer-DE503g9L.js +0 -59
  44. package/dist/web/assets/settings-tab-BdgsQeES.js +0 -1
  45. package/scripts/patch-sdk.mjs +0 -214
  46. package/scripts/test-drain-bug.mjs +0 -131
  47. package/test-sdk.mjs +0 -106
  48. /package/dist/web/assets/{api-client-B0aMOJxF.js → api-client-TUmacMRS.js} +0 -0
  49. /package/dist/web/assets/{react-Dk7fkoaB.js → react-rgzL83kk.js} +0 -0
  50. /package/dist/web/assets/{utils-DBpa1UZX.js → utils-DC-bdPS3.js} +0 -0
@@ -5,7 +5,7 @@ import type { ChatMessage, ChatEvent } from "../../../types/chat";
5
5
  import type { StreamingStatus } from "@/hooks/use-chat";
6
6
  import { ToolCard } from "./tool-cards";
7
7
  import { MarkdownRenderer } from "@/components/shared/markdown-renderer";
8
- import { basename } from "@/lib/utils";
8
+ import { cn, basename } from "@/lib/utils";
9
9
 
10
10
  import {
11
11
  AlertCircle,
@@ -20,6 +20,8 @@ import {
20
20
  Loader2,
21
21
  RotateCcw,
22
22
  TerminalSquare,
23
+ ChevronUp,
24
+ Tag,
23
25
  } from "lucide-react";
24
26
  import { QuestionCard } from "./question-card";
25
27
  import type { Question } from "./question-card";
@@ -79,15 +81,26 @@ export function MessageList({
79
81
  const hasEvents = msg.events && msg.events.length > 0;
80
82
  return hasContent || hasEvents;
81
83
  })
82
- .map((msg) => (
83
- <MessageBubble
84
- key={msg.id}
85
- message={msg}
86
- isStreaming={isStreaming && msg.id.startsWith("streaming-")}
87
- projectName={projectName}
88
- onFork={msg.role === "user" && onFork ? () => onFork(msg.content) : undefined}
89
- />
90
- ))}
84
+ .map((msg) => {
85
+ const bubble = (
86
+ <MessageBubble
87
+ key={msg.id}
88
+ message={msg}
89
+ isStreaming={isStreaming && msg.id.startsWith("streaming-")}
90
+ projectName={projectName}
91
+ onFork={msg.role === "user" && onFork ? () => onFork(msg.content) : undefined}
92
+ />
93
+ );
94
+ // User messages stick to top when scrolling
95
+ if (msg.role === "user") {
96
+ return (
97
+ <div key={msg.id} className="sticky top-0 z-10 bg-background py-0.5">
98
+ {bubble}
99
+ </div>
100
+ );
101
+ }
102
+ return bubble;
103
+ })}
91
104
 
92
105
  {pendingApproval && (
93
106
  pendingApproval.tool === "AskUserQuestion"
@@ -153,9 +166,36 @@ function MessageBubble({ message, isStreaming, projectName, onFork }: { message:
153
166
  /** Image extensions that can be previewed inline */
154
167
  const IMAGE_EXTS = new Set([".png", ".jpg", ".jpeg", ".gif", ".webp"]);
155
168
 
156
- /** Strip system-injected XML tags (e.g. <system-reminder>, <available-deferred-tools>) from message content */
157
- function stripSystemTags(text: string): string {
158
- return text.replace(/<(system-reminder|available-deferred-tools|antml:[\w-]+|fast_mode_info|claudeMd|gitStatus|currentDate)[\s\S]*?<\/\1>/g, "").trim();
169
+ interface SystemTag {
170
+ name: string;
171
+ label: string;
172
+ content: string;
173
+ }
174
+
175
+ const TAG_LABELS: Record<string, string> = {
176
+ "system-reminder": "Context",
177
+ "claudeMd": "CLAUDE.md",
178
+ "gitStatus": "Git Status",
179
+ "currentDate": "Date",
180
+ "fast_mode_info": "Fast Mode",
181
+ "available-deferred-tools": "Tools",
182
+ };
183
+
184
+ /** Extract system-injected XML tags into structured objects + clean text */
185
+ function extractSystemTags(text: string): { cleanText: string; tags: SystemTag[] } {
186
+ const tags: SystemTag[] = [];
187
+ const tagPattern = /<(system-reminder|available-deferred-tools|antml:[\w-]+|fast_mode_info|claudeMd|gitStatus|currentDate)[^>]*>([\s\S]*?)<\/\1>/g;
188
+ let match;
189
+ while ((match = tagPattern.exec(text)) !== null) {
190
+ const name = match[1]!;
191
+ tags.push({
192
+ name,
193
+ label: TAG_LABELS[name] ?? name.replace(/^antml:/, "").replace(/-/g, " "),
194
+ content: match[2]!.trim(),
195
+ });
196
+ }
197
+ const cleanText = text.replace(tagPattern, "").trim();
198
+ return { cleanText, tags };
159
199
  }
160
200
 
161
201
  /** Parse user message content, extracting attached file paths and the actual text */
@@ -193,59 +233,127 @@ function isPdfPath(path: string): boolean {
193
233
  return path.toLowerCase().endsWith(".pdf");
194
234
  }
195
235
 
196
- /** User message bubble with attachment rendering */
236
+ /** User message bubble — full width, collapsible, with system tag badges */
197
237
  function UserBubble({ content, projectName, onFork }: { content: string; projectName?: string; onFork?: () => void }) {
198
- const { files, text } = useMemo(() => {
238
+ const { files, text, tags } = useMemo(() => {
199
239
  const parsed = parseUserAttachments(content);
200
- return { files: parsed.files, text: stripSystemTags(parsed.text) };
240
+ const { cleanText, tags } = extractSystemTags(parsed.text);
241
+ return { files: parsed.files, text: cleanText, tags };
201
242
  }, [content]);
202
243
 
244
+ const [expanded, setExpanded] = useState(false);
245
+ const [isOverflowing, setIsOverflowing] = useState(false);
246
+ const contentRef = useRef<HTMLDivElement>(null);
247
+
248
+ useEffect(() => {
249
+ const el = contentRef.current;
250
+ if (!el) return;
251
+ // Compare natural height vs clamped height (5 lines ≈ 5 * 1.25rem)
252
+ const check = () => setIsOverflowing(el.scrollHeight > el.clientHeight + 2);
253
+ check();
254
+ // Re-check on resize
255
+ const ro = new ResizeObserver(check);
256
+ ro.observe(el);
257
+ return () => ro.disconnect();
258
+ }, [text]);
259
+
203
260
  return (
204
- <div className="flex justify-end group/user">
205
- <div className="rounded-lg bg-primary/10 px-3 py-2 text-sm text-text-primary max-w-[85%] space-y-2 relative">
206
- {/* Attached files */}
261
+ <div className="group/user relative">
262
+ <div className="rounded-lg bg-primary/10 px-3 py-2 text-sm text-text-primary space-y-2">
263
+ {/* System tags as badges */}
264
+ {tags.length > 0 && <SystemTagBadges tags={tags} />}
265
+
266
+ {/* Attached files — compact chips (same style as input area) */}
207
267
  {files.length > 0 && (
208
- <div className="flex flex-wrap gap-2">
209
- {files.map((filePath, i) =>
210
- isImagePath(filePath) ? (
211
- <AuthImage
212
- key={i}
213
- src={uploadPreviewUrl(filePath, projectName)}
214
- alt={basename(filePath) || "image"}
215
- />
216
- ) : isPdfPath(filePath) ? (
217
- <AuthFileLink
218
- key={i}
219
- src={uploadPreviewUrl(filePath, projectName)}
220
- filename={basename(filePath) || "document.pdf"}
221
- mimeType="application/pdf"
222
- />
223
- ) : (
224
- <div
225
- key={i}
226
- className="flex items-center gap-1.5 rounded-md border border-border bg-background/50 px-2 py-1 text-xs text-text-secondary"
227
- >
228
- <FileText className="size-3.5 shrink-0" />
229
- <span className="truncate max-w-40">{basename(filePath)}</span>
230
- </div>
231
- ),
232
- )}
268
+ <div className="flex flex-wrap gap-1.5">
269
+ {files.map((filePath, i) => (
270
+ <div
271
+ key={i}
272
+ className="flex items-center gap-1 rounded-md border border-border/60 bg-background/40 px-1.5 py-0.5 text-[11px] text-text-secondary"
273
+ >
274
+ {isImagePath(filePath) ? <ImageIcon className="size-3 shrink-0" /> : <FileText className="size-3 shrink-0" />}
275
+ <span className="truncate max-w-32">{basename(filePath)}</span>
276
+ </div>
277
+ ))}
233
278
  </div>
234
279
  )}
235
280
 
236
- {/* Text content */}
237
- {text && <p className="whitespace-pre-wrap break-words">{text}</p>}
238
- {/* Fork/Rewind button — visible on hover */}
239
- {onFork && (
240
- <button
241
- onClick={onFork}
242
- title="Retry from this message (fork session)"
243
- className="absolute -left-8 top-1/2 -translate-y-1/2 opacity-0 group-hover/user:opacity-100 transition-opacity size-6 flex items-center justify-center rounded bg-surface border border-border text-text-subtle hover:text-text-primary hover:bg-surface-elevated"
244
- >
245
- <RotateCcw className="size-3" />
246
- </button>
281
+ {/* Text content — 2-line clamp by default, expandable */}
282
+ {text && (
283
+ <div>
284
+ <div
285
+ ref={contentRef}
286
+ className={cn(
287
+ "whitespace-pre-wrap break-words transition-all duration-200",
288
+ !expanded && "line-clamp-2",
289
+ expanded && "max-h-[50vh] overflow-y-auto",
290
+ )}
291
+ >
292
+ {text}
293
+ </div>
294
+ {(isOverflowing || expanded) && (
295
+ <button
296
+ onClick={() => setExpanded(!expanded)}
297
+ className="flex items-center gap-1 text-xs text-primary/70 hover:text-primary mt-1 transition-colors"
298
+ >
299
+ {expanded ? (
300
+ <>
301
+ <ChevronUp className="size-3" />
302
+ Show less
303
+ </>
304
+ ) : (
305
+ <>
306
+ <ChevronDown className="size-3" />
307
+ Show more
308
+ </>
309
+ )}
310
+ </button>
311
+ )}
312
+ </div>
247
313
  )}
248
314
  </div>
315
+ {/* Fork/Rewind button — visible on hover */}
316
+ {onFork && (
317
+ <button
318
+ onClick={onFork}
319
+ title="Retry from this message (fork session)"
320
+ className="absolute -right-8 top-1/2 -translate-y-1/2 opacity-0 group-hover/user:opacity-100 transition-opacity size-6 flex items-center justify-center rounded bg-surface border border-border text-text-subtle hover:text-text-primary hover:bg-surface-elevated"
321
+ >
322
+ <RotateCcw className="size-3" />
323
+ </button>
324
+ )}
325
+ </div>
326
+ );
327
+ }
328
+
329
+ /** Render system tags as collapsible badges */
330
+ function SystemTagBadges({ tags }: { tags: SystemTag[] }) {
331
+ return (
332
+ <div className="flex flex-wrap gap-1.5">
333
+ {tags.map((tag, i) => (
334
+ <SystemTagBadge key={i} tag={tag} />
335
+ ))}
336
+ </div>
337
+ );
338
+ }
339
+
340
+ function SystemTagBadge({ tag }: { tag: SystemTag }) {
341
+ const [open, setOpen] = useState(false);
342
+ return (
343
+ <div className="text-xs">
344
+ <button
345
+ onClick={() => setOpen(!open)}
346
+ className="flex items-center gap-1 rounded-full border border-border/60 bg-surface/50 px-2 py-0.5 text-text-subtle hover:text-text-secondary hover:bg-surface transition-colors"
347
+ >
348
+ <Tag className="size-2.5" />
349
+ <span>{tag.label}</span>
350
+ <ChevronRight className={cn("size-2.5 transition-transform", open && "rotate-90")} />
351
+ </button>
352
+ {open && (
353
+ <div className="mt-1 rounded border border-border/40 bg-surface/30 px-2 py-1.5 text-[11px] text-text-subtle/80 whitespace-pre-wrap max-h-40 overflow-y-auto leading-relaxed">
354
+ {tag.content}
355
+ </div>
356
+ )}
249
357
  </div>
250
358
  );
251
359
  }
@@ -10,11 +10,6 @@ import {
10
10
  } from "@/components/ui/select";
11
11
  import { getAISettings, updateAISettings, type AISettings } from "@/lib/api-settings";
12
12
 
13
- const EXECUTION_MODE_OPTIONS = [
14
- { value: "sdk", label: "SDK (native)" },
15
- { value: "cli", label: "CLI (claude command)" },
16
- ];
17
-
18
13
  const MODEL_OPTIONS = [
19
14
  { value: "claude-sonnet-4-6", label: "Claude Sonnet 4.6" },
20
15
  { value: "claude-opus-4-6", label: "Claude Opus 4.6" },
@@ -87,25 +82,6 @@ export function AISettingsSection({ compact }: { compact?: boolean } = {}) {
87
82
  <h3 className={`${headingSize} font-medium text-text-secondary`}>AI Provider</h3>
88
83
 
89
84
  <div className={innerGap}>
90
- <div className={fieldGap}>
91
- <Label htmlFor="ai-execution-mode" className={compact ? labelSize : undefined}>Execution Mode</Label>
92
- <Select
93
- value={config?.execution_mode ?? "sdk"}
94
- onValueChange={(v) => handleSave("execution_mode", v)}
95
- >
96
- <SelectTrigger id="ai-execution-mode" className={`w-full ${compact ? "h-7 text-[11px]" : ""}`}>
97
- <SelectValue />
98
- </SelectTrigger>
99
- <SelectContent>
100
- {EXECUTION_MODE_OPTIONS.map((opt) => (
101
- <SelectItem key={opt.value} value={opt.value}>
102
- {opt.label}
103
- </SelectItem>
104
- ))}
105
- </SelectContent>
106
- </Select>
107
- </div>
108
-
109
85
  <div className={fieldGap}>
110
86
  <Label htmlFor="ai-model" className={compact ? labelSize : undefined}>Model</Label>
111
87
  <Select
@@ -3,9 +3,12 @@ import { marked } from "marked";
3
3
  import { useTabStore } from "@/stores/tab-store";
4
4
  import { useFileStore, type FileNode } from "@/stores/file-store";
5
5
  import { openCommandPalette } from "@/hooks/use-global-keybindings";
6
- import { api, projectUrl } from "@/lib/api-client";
6
+ import { api, projectUrl, getAuthToken } from "@/lib/api-client";
7
7
  import { basename } from "@/lib/utils";
8
8
 
9
+ /** Detect local absolute file paths (Unix or Windows) */
10
+ const LOCAL_PATH_RE = /^(\/|[A-Za-z]:[/\\])/;
11
+
9
12
  // Configure marked globally
10
13
  marked.use({ gfm: true, breaks: true });
11
14
 
@@ -171,6 +174,46 @@ export function MarkdownRenderer({ content, projectName, className = "", codeAct
171
174
 
172
175
  container.addEventListener("click", handleClick);
173
176
 
177
+ // --- Auth-load images with local file paths ---
178
+ const blobUrls: string[] = [];
179
+ container.querySelectorAll("img").forEach((img) => {
180
+ const src = img.getAttribute("src") ?? "";
181
+ // Only intercept local file paths, not http/data/blob URLs
182
+ if (!LOCAL_PATH_RE.test(src)) return;
183
+ // Mark as loading
184
+ img.style.opacity = "0.3";
185
+ img.style.minHeight = "48px";
186
+ img.style.minWidth = "48px";
187
+ const token = getAuthToken();
188
+ fetch(`/api/fs/raw?path=${encodeURIComponent(src)}`, {
189
+ headers: token ? { Authorization: `Bearer ${token}` } : {},
190
+ })
191
+ .then((r) => {
192
+ if (!r.ok) throw new Error("Failed to load");
193
+ return r.blob();
194
+ })
195
+ .then((blob) => {
196
+ const url = URL.createObjectURL(blob);
197
+ blobUrls.push(url);
198
+ img.src = url;
199
+ img.style.opacity = "";
200
+ img.style.minHeight = "";
201
+ img.style.minWidth = "";
202
+ // Style: constrain size, add border like AuthImage
203
+ img.style.maxHeight = "400px";
204
+ img.style.maxWidth = "100%";
205
+ img.style.objectFit = "contain";
206
+ img.style.borderRadius = "0.375rem";
207
+ img.style.border = "1px solid var(--color-border)";
208
+ img.style.cursor = "pointer";
209
+ img.onclick = () => window.open(url, "_blank");
210
+ })
211
+ .catch(() => {
212
+ img.style.opacity = "0.5";
213
+ img.alt = `[Image not found: ${basename(src)}]`;
214
+ });
215
+ });
216
+
174
217
  // --- Code block copy/run buttons ---
175
218
  if (codeActions) {
176
219
  container.querySelectorAll("pre").forEach((pre) => {
@@ -216,7 +259,10 @@ export function MarkdownRenderer({ content, projectName, className = "", codeAct
216
259
  });
217
260
  }
218
261
 
219
- return () => container.removeEventListener("click", handleClick);
262
+ return () => {
263
+ container.removeEventListener("click", handleClick);
264
+ blobUrls.forEach((u) => URL.revokeObjectURL(u));
265
+ };
220
266
  }, [html, projectName, openTab, codeActions]);
221
267
 
222
268
  return (
@@ -121,7 +121,6 @@ export function importAccounts(params: { data: string; password: string }): Prom
121
121
 
122
122
  export interface AIProviderSettings {
123
123
  type?: string;
124
- execution_mode?: string;
125
124
  api_key_env?: string;
126
125
  base_url?: string;
127
126
  model?: string;
@@ -1,7 +0,0 @@
1
- const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/api-client-B0aMOJxF.js","assets/react-CYzKIDNi.js"])))=>i.map(i=>d[i]);
2
- import{i as e,t}from"./react-CYzKIDNi.js";import{A as n,M as r,N as i,j as a}from"./input-4ElbicvY.js";import{n as o,t as s}from"./jsx-runtime-wQxeESYQ.js";import{t as c}from"./columns-2-BZ5wv2wA.js";import{a as l,n as u,t as d}from"./tab-store-D7tRt0VT.js";import{n as f,r as p}from"./settings-store-Clv3ZNje.js";import{r as m,t as h}from"./utils-DBpa1UZX.js";import{i as g,r as _,t as v}from"./api-client-B0aMOJxF.js";import{a as y,c as b,f as x,h as S,l as C,s as w}from"./api-settings-0Hx_9lIU.js";import{C as T,D as E,F as D,G as O,I as k,J as A,M as j,O as M,P as N,R as P,T as F,U as I,W as L,_ as R,i as z,j as ee,k as te,q as B,r as ne,t as V}from"./index-CvbNQ1mi.js";import{t as H}from"./markdown-renderer-DE503g9L.js";var re=o(`activity`,[[`path`,{d:`M22 12h-2.48a2 2 0 0 0-1.93 1.46l-2.35 8.36a.25.25 0 0 1-.48 0L9.24 2.18a.25.25 0 0 0-.48 0l-2.35 8.36A2 2 0 0 1 4.49 12H2`,key:`169zse`}]]),ie=o(`arrow-up`,[[`path`,{d:`m5 12 7-7 7 7`,key:`hav0vg`}],[`path`,{d:`M12 19V5`,key:`x0mq9r`}]]),U=o(`circle-x`,[[`circle`,{cx:`12`,cy:`12`,r:`10`,key:`1mglay`}],[`path`,{d:`m15 9-6 6`,key:`1uzhvr`}],[`path`,{d:`m9 9 6 6`,key:`z0biqf`}]]),W=o(`clipboard-list`,[[`rect`,{width:`8`,height:`4`,x:`8`,y:`2`,rx:`1`,ry:`1`,key:`tgr4d6`}],[`path`,{d:`M16 4h2a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h2`,key:`116196`}],[`path`,{d:`M12 11h4`,key:`1jrz19`}],[`path`,{d:`M12 16h4`,key:`n85exb`}],[`path`,{d:`M8 11h.01`,key:`1dfujw`}],[`path`,{d:`M8 16h.01`,key:`18s6g9`}]]),ae=o(`code`,[[`path`,{d:`m16 18 6-6-6-6`,key:`eg8j8`}],[`path`,{d:`m8 6-6 6 6 6`,key:`ppft3o`}]]),oe=o(`globe`,[[`circle`,{cx:`12`,cy:`12`,r:`10`,key:`1mglay`}],[`path`,{d:`M12 2a14.5 14.5 0 0 0 0 20 14.5 14.5 0 0 0 0-20`,key:`13o1zl`}],[`path`,{d:`M2 12h20`,key:`9i4pu4`}]]),se=o(`hand`,[[`path`,{d:`M18 11V6a2 2 0 0 0-2-2a2 2 0 0 0-2 2`,key:`1fvzgz`}],[`path`,{d:`M14 10V4a2 2 0 0 0-2-2a2 2 0 0 0-2 2v2`,key:`1kc0my`}],[`path`,{d:`M10 10.5V6a2 2 0 0 0-2-2a2 2 0 0 0-2 2v8`,key:`10h0bg`}],[`path`,{d:`M18 8a2 2 0 1 1 4 0v6a8 8 0 0 1-8 8h-2c-2.8 0-4.5-.86-5.99-2.34l-3.6-3.6a2 2 0 0 1 2.83-2.82L7 15`,key:`1s1gnw`}]]),ce=o(`history`,[[`path`,{d:`M3 12a9 9 0 1 0 9-9 9.75 9.75 0 0 0-6.74 2.74L3 8`,key:`1357e3`}],[`path`,{d:`M3 3v5h5`,key:`1xhq8a`}],[`path`,{d:`M12 7v5l4 2`,key:`1fdv2h`}]]),G=o(`image`,[[`rect`,{width:`18`,height:`18`,x:`3`,y:`3`,rx:`2`,ry:`2`,key:`1m3agn`}],[`circle`,{cx:`9`,cy:`9`,r:`2`,key:`af1f0g`}],[`path`,{d:`m21 15-3.086-3.086a2 2 0 0 0-2.828 0L6 21`,key:`1xmnt7`}]]),K=o(`list-todo`,[[`path`,{d:`M13 5h8`,key:`a7qcls`}],[`path`,{d:`M13 12h8`,key:`h98zly`}],[`path`,{d:`M13 19h8`,key:`c3s6r1`}],[`path`,{d:`m3 17 2 2 4-4`,key:`1jhpwq`}],[`rect`,{x:`3`,y:`4`,width:`6`,height:`6`,rx:`1`,key:`cif1o7`}]]),le=o(`paperclip`,[[`path`,{d:`m16 6-8.414 8.586a2 2 0 0 0 2.829 2.829l8.414-8.586a4 4 0 1 0-5.657-5.657l-8.379 8.551a6 6 0 1 0 8.485 8.485l8.379-8.551`,key:`1miecu`}]]),ue=o(`settings-2`,[[`path`,{d:`M14 17H5`,key:`gfn3mx`}],[`path`,{d:`M19 7h-9`,key:`6i9tg`}],[`circle`,{cx:`17`,cy:`17`,r:`3`,key:`18b49y`}],[`circle`,{cx:`7`,cy:`7`,r:`3`,key:`dfmy0x`}]]),de=o(`shield-alert`,[[`path`,{d:`M20 13c0 5-3.5 7.5-7.66 8.95a1 1 0 0 1-.67-.01C7.5 20.5 4 18 4 13V6a1 1 0 0 1 1-1c2 0 4.5-1.2 6.24-2.72a1.17 1.17 0 0 1 1.52 0C14.51 3.81 17 5 19 5a1 1 0 0 1 1 1z`,key:`oel41y`}],[`path`,{d:`M12 8v4`,key:`1got3b`}],[`path`,{d:`M12 16h.01`,key:`1drbdi`}]]),fe=o(`shield-check`,[[`path`,{d:`M20 13c0 5-3.5 7.5-7.66 8.95a1 1 0 0 1-.67-.01C7.5 20.5 4 18 4 13V6a1 1 0 0 1 1-1c2 0 4.5-1.2 6.24-2.72a1.17 1.17 0 0 1 1.52 0C14.51 3.81 17 5 19 5a1 1 0 0 1 1 1z`,key:`oel41y`}],[`path`,{d:`m9 12 2 2 4-4`,key:`dzmm74`}]]),q=o(`shield-off`,[[`path`,{d:`m2 2 20 20`,key:`1ooewy`}],[`path`,{d:`M5 5a1 1 0 0 0-1 1v7c0 5 3.5 7.5 7.67 8.94a1 1 0 0 0 .67.01c2.35-.82 4.48-1.97 5.9-3.71`,key:`1jlk70`}],[`path`,{d:`M9.309 3.652A12.252 12.252 0 0 0 11.24 2.28a1.17 1.17 0 0 1 1.52 0C14.51 3.81 17 5 19 5a1 1 0 0 1 1 1v7a9.784 9.784 0 0 1-.08 1.264`,key:`18rp1v`}]]),pe=o(`sparkles`,[[`path`,{d:`M11.017 2.814a1 1 0 0 1 1.966 0l1.051 5.558a2 2 0 0 0 1.594 1.594l5.558 1.051a1 1 0 0 1 0 1.966l-5.558 1.051a2 2 0 0 0-1.594 1.594l-1.051 5.558a1 1 0 0 1-1.966 0l-1.051-5.558a2 2 0 0 0-1.594-1.594l-5.558-1.051a1 1 0 0 1 0-1.966l5.558-1.051a2 2 0 0 0 1.594-1.594z`,key:`1s2grr`}],[`path`,{d:`M20 2v4`,key:`1rf3ol`}],[`path`,{d:`M22 4h-4`,key:`gwowj6`}],[`circle`,{cx:`4`,cy:`20`,r:`2`,key:`6kqj1y`}]]),me=o(`square`,[[`rect`,{width:`18`,height:`18`,x:`3`,y:`3`,rx:`2`,key:`afitv7`}]]),J=e(t(),1),he=3e4,ge=1e3,_e=class{ws=null;url;handlers=[];reconnectAttempts=0;reconnectTimer=null;intentionalClose=!1;pendingMessages=[];constructor(e){this.url=e}connect(){this.intentionalClose=!1,this.cleanup();let e=window.location.protocol===`https:`?`wss:`:`ws:`,t=this.url.startsWith(`ws`)?this.url:`${e}//${window.location.host}${this.url}`;this.ws=new WebSocket(t),this.ws.onopen=()=>{this.reconnectAttempts=0;try{this.ws?.send(JSON.stringify({type:`ready`}))}catch{}if(this.pendingMessages.length>0){console.log(`[ws] flushing ${this.pendingMessages.length} queued message(s)`);for(let e of this.pendingMessages)try{this.ws?.send(e)}catch{}this.pendingMessages=[]}},this.ws.onmessage=e=>{for(let t of this.handlers)t(e)},this.ws.onclose=()=>{this.intentionalClose||this.scheduleReconnect()},this.ws.onerror=()=>{this.ws?.close()}}disconnect(){this.intentionalClose=!0,this.pendingMessages=[],this.cleanup(),this.reconnectTimer&&=(clearTimeout(this.reconnectTimer),null)}send(e){this.ws?.readyState===WebSocket.OPEN?this.ws.send(e):this.ws?.readyState===WebSocket.CONNECTING?(console.warn(`[ws] WS still CONNECTING — queuing message`),this.pendingMessages.push(e)):console.warn(`[ws] message dropped — readyState=${this.ws?.readyState??`no-ws`}`)}onMessage(e){return this.handlers.push(e),()=>{this.handlers=this.handlers.filter(t=>t!==e)}}get isConnected(){return this.ws?.readyState===WebSocket.OPEN}cleanup(){this.ws&&=(this.ws.onopen=null,this.ws.onclose=null,this.ws.onmessage=null,this.ws.onerror=null,(this.ws.readyState===WebSocket.OPEN||this.ws.readyState===WebSocket.CONNECTING)&&this.ws.close(),null)}scheduleReconnect(){let e=Math.min(ge*2**this.reconnectAttempts,he);this.reconnectAttempts++,this.reconnectTimer=setTimeout(()=>this.connect(),e)}};function ve({url:e,onMessage:t,autoConnect:n=!0}){let r=(0,J.useRef)(null);return(0,J.useEffect)(()=>{let i=new _e(e);return r.current=i,t&&i.onMessage(t),n&&i.connect(),()=>{i.disconnect(),r.current=null}},[e,n]),{send:(0,J.useCallback)(e=>{r.current?.send(e)},[]),connect:(0,J.useCallback)(()=>{r.current?.connect()},[]),disconnect:(0,J.useCallback)(()=>{r.current?.disconnect()},[])}}var ye=null;function be(){return ye||=new AudioContext,ye}function Y(e,t,n,r,i=`sine`){let a=be(),o=a.createOscillator(),s=a.createGain();o.type=i,o.frequency.value=e,s.gain.setValueAtTime(r,n),s.gain.exponentialRampToValueAtTime(.001,n+t),o.connect(s),s.connect(a.destination),o.start(n),o.stop(n+t)}function xe(){let e=be().currentTime;Y(523,.15,e,.15),Y(659,.2,e+.12,.15)}function Se(){let e=be().currentTime;Y(880,.12,e,.18,`square`),Y(698,.12,e+.15,.18,`square`),Y(880,.15,e+.3,.15,`square`)}function Ce(){let e=be().currentTime;Y(440,.12,e,.12),Y(523,.12,e+.1,.12),Y(659,.18,e+.2,.12)}var we={done:xe,approval_request:Se,question:Ce};function Te(e){try{we[e]?.()}catch{}}function Ee(e){if(document.hidden)return!1;let{panels:t,focusedPanelId:n}=u.getState(),r=t[n];if(!r)return!1;let i=r.tabs.find(e=>e.id===r.activeTabId);return i?.type===`chat`&&i.metadata?.sessionId===e}function De(e,t=`claude`,n=``){let[r,i]=(0,J.useState)([]),[a,o]=(0,J.useState)(!1),[s,c]=(0,J.useState)(!1),[l,u]=(0,J.useState)(`idle`),[d,f]=(0,J.useState)(0),[p,m]=(0,J.useState)(15),[h,v]=(0,J.useState)(null),[y,b]=(0,J.useState)(null),[x,S]=(0,J.useState)(null),[C,w]=(0,J.useState)(!1),T=(0,J.useRef)(``),E=(0,J.useRef)([]),D=(0,J.useRef)(null),O=(0,J.useRef)(!1),k=(0,J.useRef)(null),A=(0,J.useRef)(()=>{}),j=(0,J.useRef)(null),M=(0,J.useRef)(e);M.current=e;let N=(0,J.useRef)(n);N.current=n;let P=(0,J.useCallback)(e=>{let t;try{t=JSON.parse(e.data)}catch{return}if(t.type===`ping`)return;if(t.type===`title_updated`){S(t.title??null);return}if(t.type===`streaming_status`){let e=t.status??`idle`;if(u(e),f(e===`connecting`?t.elapsed??0:0),e===`connecting`){let e=t.effort,n=t.thinkingBudget,r=15;n&&n>0?r=Math.max(15,Math.round(n/500)):e===`high`?r=30:e===`low`&&(r=10),m(r)}return}if(t.type===`connected`){w(!0),t.sessionTitle&&S(t.sessionTitle);return}if(t.type===`status`){w(!0);let e=t;e.sessionTitle&&S(e.sessionTitle),e.isStreaming&&(O.current=!0,c(!0)),e.pendingApproval&&v({requestId:e.pendingApproval.requestId,tool:e.pendingApproval.tool,input:e.pendingApproval.input}),j.current?.();return}let n=(e,t)=>{let n=E.current.findIndex(e=>e.type===`tool_use`&&(e.tool===`Agent`||e.tool===`Task`)&&e.toolUseId===t);if(n===-1)return!1;let r=E.current[n];if(r.type!==`tool_use`)return!1;let i=[...r.children??[],e];return E.current[n]={...r,children:i},!0},r=()=>{let e=T.current,t=[...E.current],n=D.current;i(r=>{let i=r[r.length-1];return i?.role===`assistant`&&!i.id.startsWith(`final-`)?[...r.slice(0,-1),{...i,content:e,events:t,...n}]:[...r,{id:`streaming-${Date.now()}`,role:`assistant`,content:e,events:t,timestamp:new Date().toISOString(),...n}]})};switch(t.type){case`account_info`:D.current={accountId:t.accountId,accountLabel:t.accountLabel};break;case`text`:{let e=t.parentToolUseId;if(e&&n(t,e)){r();break}T.current+=t.content,E.current.push(t),r();break}case`thinking`:{let e=t.parentToolUseId;if(e&&n(t,e)){r();break}E.current.push(t),r();break}case`tool_use`:{let e=t.parentToolUseId;if(e&&n(t,e)){r();break}E.current.push(t),r();break}case`tool_result`:{let e=t.parentToolUseId;if(e&&n(t,e)){r();break}E.current.push(t),r();break}case`approval_request`:if(E.current.push(t),v({requestId:t.requestId,tool:t.tool,input:t.input}),M.current&&!Ee(M.current)){let e=t.tool===`AskUserQuestion`?`question`:`approval_request`;R.getState().addNotification(M.current,e,N.current),Te(e)}break;case`error`:{E.current.push(t);let e=[...E.current];i(n=>{let r=n[n.length-1];return r?.role===`assistant`?[...n.slice(0,-1),{...r,events:e}]:[...n,{id:`error-${Date.now()}`,role:`system`,content:t.message,events:[t],timestamp:new Date().toISOString()}]}),O.current=!1,c(!1),u(`idle`);break}case`done`:{if(!O.current)break;t.contextWindowPct!=null&&b(t.contextWindowPct),M.current&&!Ee(M.current)&&(R.getState().addNotification(M.current,`done`,N.current),Te(`done`));let e=T.current,n=[...E.current];i(t=>{let r=t[t.length-1];return r?.role===`assistant`?[...t.slice(0,-1),{...r,id:`final-${Date.now()}`,content:e||r.content,events:n.length>0?n:r.events}]:t}),T.current=``,E.current=[],D.current=null,O.current=!1,c(!1),u(`idle`);break}}},[]),{send:F,connect:I}=ve({url:e&&n?`/ws/project/${encodeURIComponent(n)}/chat/${e}`:``,onMessage:P,autoConnect:!!e&&!!n});A.current=F,(0,J.useEffect)(()=>{let r=!1;return c(!1),v(null),T.current=``,E.current=[],w(!1),e&&n?(o(!0),fetch(`${g(n)}/chat/sessions/${e}/messages?providerId=${t}`,{headers:{Authorization:`Bearer ${_()}`}}).then(e=>e.json()).then(e=>{r||O.current||(e.ok&&Array.isArray(e.data)&&e.data.length>0?i(e.data):i([]))}).catch(()=>{!r&&!O.current&&i([])}).finally(()=>{r||o(!1)})):i([]),()=>{r=!0}},[e,t,n]);let L=(0,J.useCallback)((e,t)=>{if(e.trim()){if(O.current){let e=T.current,t=[...E.current];i(n=>{let r=n[n.length-1];return r?.role===`assistant`?[...n.slice(0,-1),{...r,id:`final-${Date.now()}`,content:e||r.content,events:t.length>0?t:r.events}]:n}),F(JSON.stringify({type:`cancel`}))}i(t=>[...t,{id:`user-${Date.now()}`,role:`user`,content:e,timestamp:new Date().toISOString()}]),T.current=``,E.current=[],k.current=null,O.current=!0,c(!0),u(`connecting`),v(null),F(JSON.stringify({type:`message`,content:e,permissionMode:t?.permissionMode}))}},[F]),z=(0,J.useCallback)((e,t,n)=>{if(F(JSON.stringify({type:`approval_response`,requestId:e,approved:t,data:n})),t&&n){let t=E.current.find(t=>t.type===`approval_request`&&t.requestId===e&&t.tool===`AskUserQuestion`);if(t){let e=t.input;e&&typeof e==`object`&&(e.answers=n)}i(e=>[...e])}v(null)},[F]),ee=(0,J.useCallback)(()=>{if(!O.current)return;F(JSON.stringify({type:`cancel`}));let e=T.current,t=[...E.current];i(n=>{let r=n[n.length-1];return r?.role===`assistant`?[...n.slice(0,-1),{...r,id:`final-${Date.now()}`,content:e||r.content,events:t.length>0?t:r.events}]:n}),T.current=``,E.current=[],k.current=null,O.current=!1,c(!1),v(null)},[F]),te=(0,J.useCallback)(()=>{w(!1),I(),j.current?.()},[I]),B=(0,J.useCallback)(()=>{!e||!n||(o(!0),fetch(`${g(n)}/chat/sessions/${e}/messages?providerId=${t}`,{headers:{Authorization:`Bearer ${_()}`}}).then(e=>e.json()).then(e=>{e.ok&&Array.isArray(e.data)&&e.data.length>0&&(i(e.data),T.current=``,E.current=[])}).catch(()=>{}).finally(()=>o(!1)))},[e,t,n]);return j.current=B,{messages:r,messagesLoading:a,isStreaming:s,streamingStatus:l,connectingElapsed:d,thinkingWarningThreshold:p,pendingApproval:h,contextWindowPct:y,sessionTitle:x,sendMessage:L,respondToApproval:z,cancelStreaming:ee,reconnect:te,refetchMessages:B,isConnected:C}}var Oe=12e4;function ke(e,t=`claude`){let[n,r]=(0,J.useState)({}),[i,a]=(0,J.useState)(!1),[o,s]=(0,J.useState)(null),c=(0,J.useRef)(null),l=(0,J.useCallback)((n=!1)=>{if(!e)return;a(!0);let i=n?`&refresh=1`:``;fetch(`${g(e)}/chat/usage?providerId=${t}${i}`,{headers:{Authorization:`Bearer ${_()}`}}).then(e=>e.json()).then(e=>{e.ok&&e.data&&(r(t=>({...t,...e.data})),e.data.lastFetchedAt&&s(e.data.lastFetchedAt))}).catch(()=>{}).finally(()=>a(!1))},[e,t]);return(0,J.useEffect)(()=>(l(),c.current=setInterval(()=>l(),Oe),()=>{c.current&&clearInterval(c.current)}),[l]),{usageInfo:n,usageLoading:i,lastFetchedAt:o,refreshUsage:(0,J.useCallback)(()=>l(!0),[l])}}var Ae={damping:.7,stiffness:.05,mass:1.25},je=70,Me=1e3/60,Ne=350,Pe=!1;globalThis.document?.addEventListener(`mousedown`,()=>{Pe=!0}),globalThis.document?.addEventListener(`mouseup`,()=>{Pe=!1}),globalThis.document?.addEventListener(`click`,()=>{Pe=!1});var Fe=(e={})=>{let[t,n]=(0,J.useState)(!1),[r,i]=(0,J.useState)(e.initial!==!1),[a,o]=(0,J.useState)(!1),s=(0,J.useRef)(null);s.current=e;let c=(0,J.useCallback)(()=>{if(!Pe)return!1;let e=window.getSelection();if(!e||!e.rangeCount)return!1;let t=e.getRangeAt(0);return t.commonAncestorContainer.contains(g.current)||g.current?.contains(t.commonAncestorContainer)},[]),l=(0,J.useCallback)(e=>{d.isAtBottom=e,i(e)},[]),u=(0,J.useCallback)(e=>{d.escapedFromLock=e,n(e)},[]),d=(0,J.useMemo)(()=>{let n;return{escapedFromLock:t,isAtBottom:r,resizeDifference:0,accumulated:0,velocity:0,listeners:new Set,get scrollTop(){return g.current?.scrollTop??0},set scrollTop(e){g.current&&(g.current.scrollTop=e,d.ignoreScrollToTop=g.current.scrollTop)},get targetScrollTop(){return!g.current||!_.current?0:g.current.scrollHeight-1-g.current.clientHeight},get calculatedTargetScrollTop(){if(!g.current||!_.current)return 0;let{targetScrollTop:t}=this;if(!e.targetScrollTop)return t;if(n?.targetScrollTop===t)return n.calculatedScrollTop;let r=Math.max(Math.min(e.targetScrollTop(t,{scrollElement:g.current,contentElement:_.current}),t),0);return n={targetScrollTop:t,calculatedScrollTop:r},requestAnimationFrame(()=>{n=void 0}),r},get scrollDifference(){return this.calculatedTargetScrollTop-this.scrollTop},get isNearBottom(){return this.scrollDifference<=je}}},[]),f=(0,J.useCallback)((e={})=>{typeof e==`string`&&(e={animation:e}),e.preserveScrollPosition||l(!0);let t=Date.now()+(Number(e.wait)||0),n=Re(s.current,e.animation),{ignoreEscapes:r=!1}=e,i,a=d.calculatedTargetScrollTop;e.duration instanceof Promise?e.duration.finally(()=>{i=Date.now()}):i=t+(e.duration??0);let o=async()=>{let e=new Promise(requestAnimationFrame).then(()=>{if(!d.isAtBottom)return d.animation=void 0,!1;let{scrollTop:l}=d,u=performance.now(),p=(u-(d.lastTick??u))/Me;if(d.animation||={behavior:n,promise:e,ignoreEscapes:r},d.animation.behavior===n&&(d.lastTick=u),c()||t>Date.now())return o();if(l<Math.min(a,d.calculatedTargetScrollTop)){if(d.animation?.behavior===n){if(n===`instant`)return d.scrollTop=d.calculatedTargetScrollTop,o();d.velocity=(n.damping*d.velocity+n.stiffness*d.scrollDifference)/n.mass,d.accumulated+=d.velocity*p,d.scrollTop+=d.accumulated,d.scrollTop!==l&&(d.accumulated=0)}return o()}return i>Date.now()?(a=d.calculatedTargetScrollTop,o()):(d.animation=void 0,d.scrollTop<d.calculatedTargetScrollTop?f({animation:Re(s.current,s.current.resize),ignoreEscapes:r,duration:Math.max(0,i-Date.now())||void 0}):d.isAtBottom)});return e.then(e=>(requestAnimationFrame(()=>{d.animation||(d.lastTick=void 0,d.velocity=0)}),e))};return e.wait!==!0&&(d.animation=void 0),d.animation?.behavior===n?d.animation.promise:o()},[l,c,d]),p=(0,J.useCallback)(()=>{u(!0),l(!1)},[u,l]),m=(0,J.useCallback)(({target:e})=>{if(e!==g.current)return;let{scrollTop:t,ignoreScrollToTop:n}=d,{lastScrollTop:r=t}=d;d.lastScrollTop=t,d.ignoreScrollToTop=void 0,n&&n>t&&(r=n),o(d.isNearBottom),setTimeout(()=>{if(d.resizeDifference||t===n)return;if(c()){u(!0),l(!1);return}let e=t>r,i=t<r;if(d.animation?.ignoreEscapes){d.scrollTop=r;return}i&&(u(!0),l(!1)),e&&u(!1),!d.escapedFromLock&&d.isNearBottom&&l(!0)},1)},[u,l,c,d]),h=(0,J.useCallback)(({target:e,deltaY:t})=>{let n=e;for(;![`scroll`,`auto`].includes(getComputedStyle(n).overflow);){if(!n.parentElement)return;n=n.parentElement}n===g.current&&t<0&&g.current.scrollHeight>g.current.clientHeight&&!d.animation?.ignoreEscapes&&(u(!0),l(!1))},[u,l,d]),g=Ie(e=>{g.current?.removeEventListener(`scroll`,m),g.current?.removeEventListener(`wheel`,h),e?.addEventListener(`scroll`,m,{passive:!0}),e?.addEventListener(`wheel`,h,{passive:!0})},[]),_=Ie(e=>{if(d.resizeObserver?.disconnect(),!e)return;let t;d.resizeObserver=new ResizeObserver(([e])=>{let{height:n}=e.contentRect,r=n-(t??n);if(d.resizeDifference=r,d.scrollTop>d.targetScrollTop&&(d.scrollTop=d.targetScrollTop),o(d.isNearBottom),r>=0){let e=Re(s.current,t?s.current.resize:s.current.initial);f({animation:e,wait:!0,preserveScrollPosition:!0,duration:e===`instant`?void 0:Ne})}else d.isNearBottom&&(u(!1),l(!0));t=n,requestAnimationFrame(()=>{setTimeout(()=>{d.resizeDifference===r&&(d.resizeDifference=0)},1)})}),d.resizeObserver?.observe(e)},[]);return{contentRef:_,scrollRef:g,scrollToBottom:f,stopScroll:p,isAtBottom:r||a,isNearBottom:a,escapedFromLock:t,state:d}};function Ie(e,t){let n=(0,J.useCallback)(t=>(n.current=t,e(t)),t);return n}var Le=new Map;function Re(...e){let t={...Ae},n=!1;for(let r of e){if(r===`instant`){n=!0;continue}typeof r==`object`&&(n=!1,t.damping=r.damping??t.damping,t.stiffness=r.stiffness??t.stiffness,t.mass=r.mass??t.mass)}let r=JSON.stringify(t);return Le.has(r)||Le.set(r,Object.freeze(t)),n?`instant`:Le.get(r)}var ze=(0,J.createContext)(null),Be=typeof window<`u`?J.useLayoutEffect:J.useEffect;function Ve({instance:e,children:t,resize:n,initial:r,mass:i,damping:a,stiffness:o,targetScrollTop:s,contextRef:c,...l}){let u=(0,J.useRef)(null),d=Fe({mass:i,damping:a,stiffness:o,resize:n,initial:r,targetScrollTop:J.useCallback((e,t)=>(y?.targetScrollTop??s)?.(e,t)??e,[s])}),{scrollRef:f,contentRef:p,scrollToBottom:m,stopScroll:h,isAtBottom:g,escapedFromLock:_,state:v}=e??d,y=(0,J.useMemo)(()=>({scrollToBottom:m,stopScroll:h,scrollRef:f,isAtBottom:g,escapedFromLock:_,contentRef:p,state:v,get targetScrollTop(){return u.current},set targetScrollTop(e){u.current=e}}),[m,g,p,f,h,_,v]);return(0,J.useImperativeHandle)(c,()=>y,[y]),Be(()=>{f.current&&getComputedStyle(f.current).overflow===`visible`&&(f.current.style.overflow=`auto`)},[]),J.createElement(ze.Provider,{value:y},J.createElement(`div`,{...l},typeof t==`function`?t(y):t))}(function(e){function t({children:e,scrollClassName:t,...n}){let r=He();return J.createElement(`div`,{ref:r.scrollRef,style:{height:`100%`,width:`100%`,scrollbarGutter:`stable both-edges`},className:t},J.createElement(`div`,{...n,ref:r.contentRef},typeof e==`function`?e(r):e))}e.Content=t})(Ve||={});function He(){let e=(0,J.useContext)(ze);if(!e)throw Error(`use-stick-to-bottom component context must be used within a StickToBottom component`);return e}var X=s();function Ue(e){let t=e.type===`approval_request`;return{toolName:e.type===`tool_use`?e.tool:t?e.tool??`Tool`:`Tool`,input:e.type===`tool_use`?e.input:t?e.input??{}:{}}}function We({tool:e,result:t,completed:n,projectName:i}){let[a,o]=(0,J.useState)(!1);if(e.type===`error`)return(0,X.jsxs)(`div`,{className:`flex items-center gap-2 rounded bg-red-500/10 border border-red-500/20 px-2 py-1.5 text-xs text-red-400`,children:[(0,X.jsx)(L,{className:`size-3`}),(0,X.jsx)(`span`,{children:e.message})]});let{toolName:s,input:c}=Ue(e),l=t?.type===`tool_result`,u=l&&!!t.isError,d=s===`AskUserQuestion`&&!!c?.answers,f=(s===`Agent`||s===`Task`)&&e.type===`tool_use`,p=f?e.children:void 0,m=p&&p.length>0;return(0,X.jsxs)(`div`,{className:`rounded border text-xs ${f?`border-accent/30 bg-accent/5`:`border-border bg-background`}`,children:[(0,X.jsxs)(`button`,{onClick:()=>o(!a),className:`flex items-center gap-2 px-2 py-1.5 w-full text-left hover:bg-surface transition-colors min-w-0`,children:[a?(0,X.jsx)(r,{className:`size-3 shrink-0`}):(0,X.jsx)(O,{className:`size-3 shrink-0`}),u?(0,X.jsx)(U,{className:`size-3 text-red-400 shrink-0`}):l||d||n?(0,X.jsx)(I,{className:`size-3 text-green-400 shrink-0`}):(0,X.jsx)(j,{className:`size-3 text-yellow-400 shrink-0 animate-spin`}),(0,X.jsx)(`span`,{className:`truncate text-text-primary`,children:(0,X.jsx)(Ge,{name:s,input:c})}),m&&(0,X.jsxs)(`span`,{className:`ml-auto text-[10px] text-text-subtle shrink-0`,children:[p.length,` steps`]})]}),a&&(0,X.jsxs)(`div`,{className:`px-2 pb-2 space-y-1.5`,children:[(e.type===`tool_use`||e.type===`approval_request`)&&(0,X.jsx)(Ke,{name:s,input:c,projectName:i}),m&&(0,X.jsx)(Xe,{events:p,projectName:i}),l&&(0,X.jsx)(Je,{toolName:s,output:t.output})]})]})}function Ge({name:e,input:t}){let n=e=>String(e??``);switch(e){case`Read`:case`Write`:case`Edit`:case`MultiEdit`:case`NotebookEdit`:return(0,X.jsxs)(X.Fragment,{children:[e,` `,(0,X.jsx)(`span`,{className:`text-text-subtle`,children:h(n(t.file_path))})]});case`Bash`:return(0,X.jsxs)(X.Fragment,{children:[e,` `,(0,X.jsx)(`span`,{className:`font-mono text-text-subtle`,children:Z(n(t.command),60)})]});case`Glob`:return(0,X.jsxs)(X.Fragment,{children:[e,` `,(0,X.jsx)(`span`,{className:`font-mono text-text-subtle`,children:n(t.pattern)})]});case`Grep`:return(0,X.jsxs)(X.Fragment,{children:[e,` `,(0,X.jsx)(`span`,{className:`font-mono text-text-subtle`,children:Z(n(t.pattern),40)})]});case`WebSearch`:return(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(E,{className:`size-3 inline`}),` `,e,` `,(0,X.jsx)(`span`,{className:`text-text-subtle`,children:Z(n(t.query),50)})]});case`WebFetch`:return(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(oe,{className:`size-3 inline`}),` `,e,` `,(0,X.jsx)(`span`,{className:`text-text-subtle`,children:Z(n(t.url),50)})]});case`ToolSearch`:return(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(E,{className:`size-3 inline`}),` `,e,` `,(0,X.jsx)(`span`,{className:`text-text-subtle`,children:Z(n(t.query),50)})]});case`Agent`:case`Task`:return(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(B,{className:`size-3 inline`}),` `,e,` `,(0,X.jsx)(`span`,{className:`text-text-subtle`,children:Z(n(t.description||t.prompt),60)})]});case`TodoWrite`:{let n=Array.isArray(t.todos)?t.todos:[],r=n.filter(e=>e.status===`completed`).length;return(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(K,{className:`size-3 inline`}),` `,e,` `,(0,X.jsxs)(`span`,{className:`text-text-subtle`,children:[r,`/`,n.length,` done`]})]})}case`AskUserQuestion`:{let n=Array.isArray(t.questions)?t.questions:[],r=!!t.answers;return(0,X.jsxs)(X.Fragment,{children:[e,` `,(0,X.jsxs)(`span`,{className:`text-text-subtle`,children:[n.length,` question`,n.length===1?``:`s`,r?` ✓`:``]})]})}default:return(0,X.jsx)(X.Fragment,{children:e})}}function Ke({name:e,input:t,projectName:n}){let r=e=>String(e??``),{openTab:i}=d(),a=e=>{n&&i({type:`editor`,title:h(e),metadata:{filePath:e,projectName:n},projectId:n,closable:!0})},o=(e,t,r)=>{i({type:`git-diff`,title:`Diff ${h(e)}`,metadata:{filePath:e,projectName:n,original:t,modified:r},projectId:n??null,closable:!0})};switch(e){case`Bash`:return(0,X.jsxs)(`div`,{className:`space-y-1`,children:[!!t.description&&(0,X.jsx)(`p`,{className:`text-text-subtle italic`,children:r(t.description)}),(0,X.jsx)(`pre`,{className:`font-mono text-text-secondary overflow-x-auto whitespace-pre-wrap break-all`,children:r(t.command)})]});case`Read`:case`Write`:case`Edit`:case`MultiEdit`:case`NotebookEdit`:{let n=r(t.file_path);return(0,X.jsxs)(`div`,{className:`space-y-1`,children:[(0,X.jsxs)(`button`,{type:`button`,className:`font-mono text-text-secondary break-all hover:text-primary hover:underline text-left flex items-center gap-1`,onClick:()=>a(n),title:`Open file in editor`,children:[(0,X.jsx)(l,{className:`size-3 shrink-0`}),n]}),e===`Edit`&&(!!t.old_string||!!t.new_string)&&(0,X.jsxs)(`button`,{type:`button`,className:`text-text-subtle hover:text-primary hover:underline text-left flex items-center gap-1`,onClick:()=>o(n,r(t.old_string),r(t.new_string)),title:`View diff in new tab`,children:[(0,X.jsx)(c,{className:`size-3 shrink-0`}),`View Diff`]}),e===`Write`&&!!t.content&&(0,X.jsx)(`pre`,{className:`font-mono text-text-subtle overflow-x-auto max-h-32 whitespace-pre-wrap`,children:Z(r(t.content),300)})]})}case`Glob`:return(0,X.jsxs)(`p`,{className:`font-mono text-text-secondary`,children:[r(t.pattern),t.path?` in ${r(t.path)}`:``]});case`Grep`:return(0,X.jsxs)(`div`,{className:`space-y-0.5`,children:[(0,X.jsxs)(`p`,{className:`font-mono text-text-secondary`,children:[`/`,r(t.pattern),`/`]}),!!t.path&&(0,X.jsxs)(`p`,{className:`text-text-subtle`,children:[`in `,r(t.path)]})]});case`TodoWrite`:return(0,X.jsx)(qe,{todos:t.todos??[]});case`Agent`:case`Task`:return(0,X.jsxs)(`div`,{className:`space-y-1`,children:[!!t.description&&(0,X.jsx)(`p`,{className:`text-text-secondary font-medium`,children:r(t.description)}),!!t.subagent_type&&(0,X.jsxs)(`p`,{className:`text-text-subtle`,children:[`Type: `,r(t.subagent_type)]}),!!t.prompt&&(0,X.jsx)(Ze,{content:r(t.prompt),maxHeight:`max-h-48`})]});case`ToolSearch`:return(0,X.jsxs)(`div`,{className:`space-y-0.5`,children:[(0,X.jsx)(`p`,{className:`font-mono text-text-secondary`,children:r(t.query)}),!!t.max_results&&(0,X.jsxs)(`p`,{className:`text-text-subtle`,children:[`Max results: `,r(t.max_results)]})]});case`WebFetch`:return(0,X.jsxs)(`div`,{className:`space-y-0.5`,children:[(0,X.jsxs)(`a`,{href:r(t.url),target:`_blank`,rel:`noopener noreferrer`,className:`font-mono text-primary hover:underline break-all flex items-center gap-1`,children:[(0,X.jsx)(oe,{className:`size-3 shrink-0`}),r(t.url)]}),!!t.prompt&&(0,X.jsx)(`p`,{className:`text-text-subtle`,children:Z(r(t.prompt),100)})]});case`AskUserQuestion`:{let e=t.questions??[],n=t.answers??{};return(0,X.jsx)(`div`,{className:`space-y-2`,children:e.map((e,t)=>(0,X.jsxs)(`div`,{className:`space-y-0.5`,children:[(0,X.jsxs)(`p`,{className:`text-text-primary font-medium`,children:[e.header?`${e.header}: `:``,e.question]}),(0,X.jsx)(`div`,{className:`flex flex-wrap gap-1`,children:e.options.map((t,r)=>(0,X.jsx)(`span`,{className:`inline-block rounded px-1.5 py-0.5 text-xs border ${(n[e.question]??``).split(`, `).includes(t.label)?`border-accent bg-accent/20 text-text-primary`:`border-border text-text-subtle`}`,children:t.label},r))}),n[e.question]&&(0,X.jsxs)(`p`,{className:`text-foreground text-xs`,children:[`Answer: `,n[e.question]]})]},t))})}default:return(0,X.jsx)(`pre`,{className:`overflow-x-auto text-text-secondary font-mono whitespace-pre-wrap break-all`,children:JSON.stringify(t,null,2)})}}function qe({todos:e}){return(0,X.jsx)(`div`,{className:`space-y-0.5`,children:e.map((e,t)=>(0,X.jsxs)(`div`,{className:`flex items-start gap-1.5`,children:[(0,X.jsx)(`span`,{className:`shrink-0 mt-0.5 ${e.status===`completed`?`text-green-400`:e.status===`in_progress`?`text-yellow-400`:`text-text-subtle`}`,children:e.status===`completed`?`✓`:e.status===`in_progress`?`▶`:`○`}),(0,X.jsx)(`span`,{className:e.status===`completed`?`line-through text-text-subtle`:`text-text-secondary`,children:e.content})]},t))})}function Je({toolName:e,output:t}){let[n,r]=(0,J.useState)(!1),i=(0,J.useMemo)(()=>{if(e!==`Agent`&&e!==`Task`)return null;try{let e=JSON.parse(t);if(Array.isArray(e)){let t=e.filter(e=>e.type===`text`&&e.text).map(e=>e.text).join(`
3
-
4
- `);if(t)return t}if(typeof e==`string`)return e}catch{if(t&&!t.startsWith(`[{`))return t}return null},[e,t]);return i?(0,X.jsxs)(`div`,{className:`border-t border-border pt-1.5 space-y-1`,children:[(0,X.jsx)(Ze,{content:i,maxHeight:`max-h-60`}),(0,X.jsxs)(`button`,{type:`button`,onClick:()=>r(!n),className:`flex items-center gap-1 text-[10px] text-text-subtle hover:text-text-secondary transition-colors`,children:[(0,X.jsx)(ae,{className:`size-3`}),n?`Hide`:`Show`,` raw`]}),n&&(0,X.jsx)(`pre`,{className:`overflow-x-auto text-text-subtle font-mono max-h-40 whitespace-pre-wrap break-all text-[10px]`,children:t})]}):(0,X.jsx)(Ye,{output:t})}function Ye({output:e}){let t=e.split(`
5
- `).length,n=t>3||e.length>200,[i,a]=(0,J.useState)(n);return(0,X.jsxs)(`div`,{className:`border-t border-border pt-1.5`,children:[n&&(0,X.jsxs)(`button`,{type:`button`,onClick:()=>a(!i),className:`flex items-center gap-1 text-[10px] text-text-subtle hover:text-text-secondary transition-colors mb-1`,children:[i?(0,X.jsx)(O,{className:`size-3`}):(0,X.jsx)(r,{className:`size-3`}),`Output (`,t,` lines)`]}),(0,X.jsx)(`pre`,{className:`overflow-x-auto text-text-subtle font-mono whitespace-pre-wrap break-all ${i?`max-h-16 overflow-hidden`:`max-h-60`}`,children:e})]})}function Xe({events:e,projectName:t}){let n=[],r=``;for(let t of e)if(t.type===`text`)r+=t.content;else if(t.type===`tool_use`)r&&=(n.push({kind:`text`,content:r}),``),n.push({kind:`tool`,tool:t});else if(t.type===`tool_result`){let e=t.toolUseId,r=e?n.find(t=>t.kind===`tool`&&t.tool.type===`tool_use`&&t.tool.toolUseId===e&&!t.result):n.findLast(e=>e.kind===`tool`&&!e.result);r&&(r.result=t)}return r&&n.push({kind:`text`,content:r}),(0,X.jsx)(`div`,{className:`border-l-2 border-accent/20 pl-2 space-y-1 mt-1`,children:n.map((e,n)=>e.kind===`text`?(0,X.jsx)(`div`,{className:`text-text-secondary text-[11px]`,children:(0,X.jsx)(Ze,{content:e.content,maxHeight:`max-h-24`})},`st-${n}`):(0,X.jsx)(We,{tool:e.tool,result:e.result,completed:!!e.result,projectName:t},`sc-${n}`))})}function Ze({content:e,maxHeight:t=`max-h-48`}){return(0,X.jsx)(H,{content:e,className:`text-text-secondary overflow-auto ${t}`})}function Z(e,t=50){return e?e.length>t?e.slice(0,t)+`…`:e:``}function Qe(e){let[t,n]=(0,J.useState)({}),[r,i]=(0,J.useState)({}),[a,o]=(0,J.useState)(0),s=(0,J.useCallback)((e,t)=>{n(n=>({...n,[e]:[t]})),i(t=>({...t,[e]:``}))},[]),c=(0,J.useCallback)((e,t)=>{n(n=>{let r=n[e]||[];return{...n,[e]:r.includes(t)?r.filter(e=>e!==t):[...r,t]}})},[]),l=(0,J.useCallback)((e,t)=>{i(n=>({...n,[e]:t})),t&&n(t=>({...t,[e]:[]}))},[]),u=(0,J.useCallback)(e=>(t[e]?.length??0)>0||(r[e]?.trim().length??0)>0,[t,r]);return{answers:t,customInputs:r,activeTab:a,setActiveTab:o,handleSingleSelect:s,handleMultiSelect:c,handleCustomInput:l,hasAnswer:u,allAnswered:(0,J.useMemo)(()=>e.every((e,t)=>u(t)),[e,u]),getFinalAnswer:(0,J.useCallback)(e=>r[e]?.trim()||(t[e]??[]).join(`, `),[t,r]),goToNextTab:(0,J.useCallback)(()=>o(t=>Math.min(t+1,e.length-1)),[e.length]),goToPrevTab:(0,J.useCallback)(()=>o(e=>Math.max(e-1,0)),[])}}function $e(e){let[t,n]=(0,J.useState)(0),r=(0,J.useRef)(null);return(0,J.useEffect)(()=>n(0),[e.activeTab]),(0,J.useEffect)(()=>{if(!e.enabled)return;let i=r=>{let i=document.activeElement===e.customInputRef.current;if(!i&&r.key>=`1`&&r.key<=`9`){r.preventDefault();let t=parseInt(r.key)-1;t<e.totalOptions-1&&(n(t),e.onSelectOption(t));return}if(!i&&(r.key===`o`||r.key===`O`||r.key===`0`)){r.preventDefault(),e.customInputRef.current?.focus(),n(e.totalOptions-1);return}if(r.key===`Tab`&&e.questions.length>1){r.preventDefault(),r.shiftKey?e.goToPrevTab():e.goToNextTab();return}if(!i){if(r.key===`ArrowLeft`){r.preventDefault(),e.goToPrevTab();return}if(r.key===`ArrowRight`){r.preventDefault(),e.goToNextTab();return}if(r.key===`ArrowUp`){r.preventDefault(),n(e=>Math.max(0,e-1));return}if(r.key===`ArrowDown`){r.preventDefault(),n(t=>Math.min(e.totalOptions-1,t+1));return}if(r.key===` `){r.preventDefault(),e.onSelectOption(t);return}}if(r.key===`Enter`){r.preventDefault(),e.allAnswered?e.onSubmit():e.hasAnswer(e.activeTab)&&e.goToNextTab();return}r.key===`Escape`&&i&&e.customInputRef.current?.blur()},a=r.current;return a&&(a.addEventListener(`keydown`,i),a.setAttribute(`tabindex`,`0`),a.contains(document.activeElement)||a.focus()),()=>{a?.removeEventListener(`keydown`,i)}},[e,t]),{focusedOption:t,setFocusedOption:n,containerRef:r}}function et({questions:e,onSubmit:t,onSkip:n}){let r=(0,J.useRef)(null),i=Qe(e),a=e[i.activeTab],o=a?a.options.length+1:0,s=e.length>1,c=(0,J.useCallback)(()=>{if(!i.allAnswered)return;let n={};e.forEach((e,t)=>{n[e.question]=i.getFinalAnswer(t)}),t(n)},[i.allAnswered,i.getFinalAnswer,e,t]),l=(0,J.useCallback)(e=>{if(!(!a||e<0))if(e<a.options.length){let t=a.options[e]?.label;if(!t)return;a.multiSelect?i.handleMultiSelect(i.activeTab,t):i.handleSingleSelect(i.activeTab,t)}else e===a.options.length&&r.current?.focus()},[a,i]),u=$e({questions:e,activeTab:i.activeTab,totalOptions:o,allAnswered:i.allAnswered,hasAnswer:i.hasAnswer,onSelectOption:l,goToNextTab:i.goToNextTab,goToPrevTab:i.goToPrevTab,onSubmit:c,customInputRef:r,enabled:!0}),d=(0,J.useCallback)(e=>{l(e),u.setFocusedOption(e)},[l,u.setFocusedOption]);return(0,X.jsxs)(`div`,{ref:u.containerRef,className:`rounded-lg border-2 border-primary/30 bg-primary/5 p-3 space-y-3 outline-none animate-in slide-in-from-bottom-2`,children:[(0,X.jsxs)(`div`,{className:`flex items-center justify-between text-sm font-medium text-text-primary`,children:[(0,X.jsxs)(`span`,{children:[`AI has `,s?`${e.length} questions`:`a question`]}),(0,X.jsxs)(`span`,{className:`text-[10px] text-text-secondary font-normal`,children:[s?`←→ tabs · `:``,`↑↓ options · 1-`,Math.min(o-1,9),` select · Enter submit`]})]}),s&&(0,X.jsx)(`div`,{className:`flex gap-1 p-1 bg-background rounded-md overflow-x-auto border border-border`,children:e.map((e,t)=>(0,X.jsxs)(`button`,{className:`flex items-center gap-1.5 px-3 py-1.5 rounded text-xs whitespace-nowrap transition-all ${i.activeTab===t?`bg-primary text-primary-foreground`:i.hasAnswer(t)?`text-primary bg-transparent`:`text-text-secondary hover:bg-surface-elevated`}`,onClick:()=>{i.setActiveTab(t),u.setFocusedOption(0)},tabIndex:-1,children:[(0,X.jsx)(`span`,{className:`flex items-center justify-center w-4 h-4 rounded-full text-[10px] font-semibold ${i.activeTab===t?`bg-white/20`:i.hasAnswer(t)?`bg-primary/20 text-primary`:`bg-surface-elevated text-text-secondary`}`,children:i.hasAnswer(t)?`✓`:t+1}),(0,X.jsx)(`span`,{className:`max-w-[100px] overflow-hidden text-ellipsis`,children:e.header||`Q${t+1}`})]},t))}),a&&(0,X.jsxs)(`div`,{className:`space-y-2`,children:[!s&&a.header&&(0,X.jsx)(`div`,{className:`text-[11px] font-semibold uppercase tracking-wide text-text-secondary`,children:a.header}),(0,X.jsx)(`div`,{className:`text-sm text-text-primary`,children:a.question}),a.multiSelect&&(0,X.jsx)(`div`,{className:`text-[11px] text-text-secondary`,children:`Select multiple`}),(0,X.jsxs)(`div`,{className:`flex flex-col gap-1.5`,children:[a.options.map((e,t)=>{let n=(i.answers[i.activeTab]||[]).includes(e.label),r=u.focusedOption===t;return(0,X.jsxs)(`button`,{onClick:()=>d(t),className:`text-left flex items-start gap-2.5 rounded px-2.5 py-2 text-xs border transition-all ${n?`border-primary bg-primary/10 text-text-primary`:`border-border bg-background text-text-secondary hover:border-primary/40 hover:bg-primary/5`} ${r?`ring-2 ring-primary/40 ring-offset-1 ring-offset-background`:``}`,children:[(0,X.jsx)(`span`,{className:`flex items-center justify-center w-4.5 h-4.5 rounded text-[10px] font-semibold shrink-0 mt-px ${n?`bg-primary/20 text-primary`:`bg-surface-elevated text-text-secondary`}`,children:t+1}),(0,X.jsxs)(`div`,{className:`flex flex-col gap-0.5 flex-1`,children:[(0,X.jsx)(`span`,{className:`font-medium text-text-primary`,children:e.label}),e.description&&(0,X.jsx)(`span`,{className:`text-[11px] text-text-secondary`,children:e.description})]})]},t)}),(0,X.jsxs)(`div`,{className:`flex items-start gap-2.5 rounded px-2.5 py-2 text-xs border border-dashed transition-all border-border bg-transparent ${u.focusedOption===o-1?`ring-2 ring-primary/40 ring-offset-1 ring-offset-background`:``}`,children:[(0,X.jsx)(`span`,{className:`flex items-center justify-center w-4.5 h-4.5 rounded bg-surface-elevated text-text-secondary text-[10px] font-semibold shrink-0 mt-px`,children:`O`}),(0,X.jsx)(`input`,{ref:r,type:`text`,className:`flex-1 px-2 py-1 text-xs bg-surface border border-border rounded text-text-primary outline-none placeholder:text-text-subtle focus:border-primary`,placeholder:`Other (press O to type)...`,value:i.customInputs[i.activeTab]||``,onChange:e=>i.handleCustomInput(i.activeTab,e.target.value),onFocus:()=>u.setFocusedOption(o-1)})]})]})]}),(0,X.jsxs)(`div`,{className:`flex gap-2 justify-end pt-1`,children:[s&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`button`,{className:`px-3 py-1.5 text-xs rounded border border-border bg-background text-text-primary hover:bg-surface-elevated disabled:opacity-40 disabled:cursor-not-allowed transition-colors`,onClick:i.goToPrevTab,disabled:i.activeTab===0,tabIndex:-1,children:`← Prev`}),(0,X.jsx)(`button`,{className:`px-3 py-1.5 text-xs rounded border border-border bg-background text-text-primary hover:bg-surface-elevated disabled:opacity-40 disabled:cursor-not-allowed transition-colors`,onClick:i.goToNextTab,disabled:i.activeTab===e.length-1,tabIndex:-1,children:`Next →`})]}),(0,X.jsx)(`button`,{onClick:n,className:`px-4 py-1.5 rounded border border-border bg-background text-text-secondary text-xs hover:bg-surface-elevated transition-colors`,tabIndex:-1,children:`Skip`}),(0,X.jsxs)(`button`,{onClick:c,disabled:!i.allAnswered,className:`px-4 py-1.5 rounded bg-primary text-primary-foreground text-xs font-medium hover:bg-primary/80 transition-colors disabled:opacity-40 disabled:cursor-not-allowed`,tabIndex:-1,children:[`Submit `,i.allAnswered?`✓`:`(${e.filter((e,t)=>i.hasAnswer(t)).length}/${e.length})`]})]})]})}function tt({messages:e,messagesLoading:t,pendingApproval:n,onApprovalResponse:r,isStreaming:i,streamingStatus:a,connectingElapsed:o,thinkingWarningThreshold:s,projectName:c,onFork:l}){return t?(0,X.jsxs)(`div`,{className:`flex flex-col items-center justify-center h-full gap-3 text-text-secondary`,children:[(0,X.jsx)(B,{className:`size-10 text-text-subtle animate-pulse`}),(0,X.jsx)(`p`,{className:`text-sm`,children:`Loading messages...`})]}):e.length===0&&!i?(0,X.jsxs)(`div`,{className:`flex flex-col items-center justify-center h-full gap-3 text-text-secondary`,children:[(0,X.jsx)(B,{className:`size-10 text-text-subtle`}),(0,X.jsx)(`p`,{className:`text-sm`,children:`Send a message to start the conversation`})]}):(0,X.jsxs)(Ve,{className:`flex-1 overflow-y-auto`,resize:`smooth`,initial:`instant`,children:[(0,X.jsxs)(Ve.Content,{className:`p-4 space-y-4`,children:[e.filter(e=>{let t=e.content&&e.content.trim().length>0,n=e.events&&e.events.length>0;return t||n}).map(e=>(0,X.jsx)(rt,{message:e,isStreaming:i&&e.id.startsWith(`streaming-`),projectName:c,onFork:e.role===`user`&&l?()=>l(e.content):void 0},e.id)),n&&(n.tool===`AskUserQuestion`?(0,X.jsx)(yt,{approval:n,onRespond:r}):(0,X.jsx)(vt,{approval:n,onRespond:r})),i&&(0,X.jsx)(gt,{lastMessage:e[e.length-1],streamingStatus:a,elapsed:o,warningThreshold:s})]}),(0,X.jsx)(nt,{})]})}function nt(){let{isAtBottom:e,scrollToBottom:t}=He();return e?null:(0,X.jsxs)(`button`,{onClick:()=>t(),className:`absolute bottom-4 left-1/2 -translate-x-1/2 z-10 flex items-center gap-1 px-3 py-1 rounded-full bg-surface-elevated border border-border text-xs text-text-secondary hover:text-foreground shadow-lg transition-all`,children:[(0,X.jsx)(r,{className:`size-3`}),`Scroll to bottom`]})}function rt({message:e,isStreaming:t,projectName:n,onFork:r}){return e.role===`user`?(0,X.jsx)(ut,{content:e.content,projectName:n,onFork:r}):e.role===`system`?(0,X.jsxs)(`div`,{className:`flex items-center gap-2 rounded-lg bg-red-500/10 border border-red-500/20 px-3 py-2 text-sm text-red-400`,children:[(0,X.jsx)(L,{className:`size-4 shrink-0`}),(0,X.jsx)(`p`,{children:e.content})]}):(0,X.jsxs)(`div`,{className:`flex flex-col gap-2`,children:[e.events&&e.events.length>0?(0,X.jsx)(pt,{events:e.events,isStreaming:t,projectName:n}):e.content&&(0,X.jsx)(`div`,{className:`text-sm text-text-primary`,children:(0,X.jsx)(_t,{content:e.content,projectName:n})}),!t&&e.accountLabel&&(0,X.jsxs)(`p`,{className:`text-[10px] select-none`,style:{color:`var(--color-text-subtle)`},children:[`via `,e.accountLabel]})]})}var it=new Set([`.png`,`.jpg`,`.jpeg`,`.gif`,`.webp`]);function at(e){return e.replace(/<(system-reminder|available-deferred-tools|antml:[\w-]+|fast_mode_info|claudeMd|gitStatus|currentDate)[\s\S]*?<\/\1>/g,``).trim()}function ot(e){let t=e.match(/^\[Attached file: (.+?)\]\n\n?/);if(t)return{files:[t[1]],text:e.slice(t[0].length)};let n=e.match(/^\[Attached files:\n([\s\S]+?)\]\n\n?/);return n?{files:n[1].split(`
6
- `).map(e=>e.trim()).filter(Boolean),text:e.slice(n[0].length)}:{files:[],text:e}}function st(e,t){let n=h(e);return`/api/project/${encodeURIComponent(t??`_`)}/chat/uploads/${encodeURIComponent(n)}`}function ct(e){let t=e.lastIndexOf(`.`);return t===-1?!1:it.has(e.slice(t).toLowerCase())}function lt(e){return e.toLowerCase().endsWith(`.pdf`)}function ut({content:e,projectName:t,onFork:n}){let{files:r,text:i}=(0,J.useMemo)(()=>{let t=ot(e);return{files:t.files,text:at(t.text)}},[e]);return(0,X.jsx)(`div`,{className:`flex justify-end group/user`,children:(0,X.jsxs)(`div`,{className:`rounded-lg bg-primary/10 px-3 py-2 text-sm text-text-primary max-w-[85%] space-y-2 relative`,children:[r.length>0&&(0,X.jsx)(`div`,{className:`flex flex-wrap gap-2`,children:r.map((e,n)=>ct(e)?(0,X.jsx)(dt,{src:st(e,t),alt:h(e)||`image`},n):lt(e)?(0,X.jsx)(ft,{src:st(e,t),filename:h(e)||`document.pdf`,mimeType:`application/pdf`},n):(0,X.jsxs)(`div`,{className:`flex items-center gap-1.5 rounded-md border border-border bg-background/50 px-2 py-1 text-xs text-text-secondary`,children:[(0,X.jsx)(k,{className:`size-3.5 shrink-0`}),(0,X.jsx)(`span`,{className:`truncate max-w-40`,children:h(e)})]},n))}),i&&(0,X.jsx)(`p`,{className:`whitespace-pre-wrap break-words`,children:i}),n&&(0,X.jsx)(`button`,{onClick:n,title:`Retry from this message (fork session)`,className:`absolute -left-8 top-1/2 -translate-y-1/2 opacity-0 group-hover/user:opacity-100 transition-opacity size-6 flex items-center justify-center rounded bg-surface border border-border text-text-subtle hover:text-text-primary hover:bg-surface-elevated`,children:(0,X.jsx)(a,{className:`size-3`})})]})})}function dt({src:e,alt:t}){let[n,r]=(0,J.useState)(null),[i,a]=(0,J.useState)(!1);return(0,J.useEffect)(()=>{let t,n=_();return fetch(e,{headers:n?{Authorization:`Bearer ${n}`}:{}}).then(e=>{if(!e.ok)throw Error(`Failed to load`);return e.blob()}).then(e=>{let n=URL.createObjectURL(e);t=n,r(n)}).catch(()=>a(!0)),()=>{t&&URL.revokeObjectURL(t)}},[e]),i?(0,X.jsxs)(`div`,{className:`flex items-center gap-1.5 rounded-md border border-border bg-background/50 px-2 py-1 text-xs text-text-secondary`,children:[(0,X.jsx)(G,{className:`size-3.5 shrink-0`}),(0,X.jsx)(`span`,{className:`truncate max-w-40`,children:t})]}):n?(0,X.jsx)(`a`,{href:n,target:`_blank`,rel:`noopener noreferrer`,className:`block`,children:(0,X.jsx)(`img`,{src:n,alt:t,className:`rounded-md max-h-48 max-w-full object-contain border border-border`})}):(0,X.jsx)(`div`,{className:`rounded-md bg-surface border border-border h-24 w-32 animate-pulse`})}function ft({src:e,filename:t,mimeType:n}){let[r,i]=(0,J.useState)(!1);return(0,X.jsxs)(`button`,{type:`button`,onClick:(0,J.useCallback)(async()=>{i(!0);try{let t=_(),r=await fetch(e,{headers:t?{Authorization:`Bearer ${t}`}:{}});if(!r.ok)throw Error(`Failed to load`);let i=await r.blob(),a=URL.createObjectURL(new Blob([i],{type:n}));window.open(a,`_blank`),setTimeout(()=>URL.revokeObjectURL(a),6e4)}catch{window.open(e,`_blank`)}finally{i(!1)}},[e,n]),disabled:r,className:`flex items-center gap-1.5 rounded-md border border-border bg-background/50 px-2 py-1 text-xs text-text-secondary hover:bg-surface hover:text-text-primary transition-colors cursor-pointer disabled:opacity-50`,children:[(0,X.jsx)(k,{className:`size-3.5 shrink-0 text-red-400`}),(0,X.jsx)(`span`,{className:`truncate max-w-40`,children:t}),r&&(0,X.jsx)(`span`,{className:`animate-spin text-[10px]`,children:`...`})]})}function pt({events:e,isStreaming:t,projectName:n}){let r=[],i=``,a=``;for(let t=0;t<e.length;t++){let n=e[t];if(n.type===`thinking`){i&&=(r.push({kind:`text`,content:i}),``),a+=n.content;continue}a&&=(r.push({kind:`thinking`,content:a}),``),n.type===`text`?i+=n.content:n.type===`tool_use`?(i&&=(r.push({kind:`text`,content:i}),``),r.push({kind:`tool`,tool:n})):n.type===`tool_result`||(i&&=(r.push({kind:`text`,content:i}),``),r.push({kind:`tool`,tool:n}))}a&&r.push({kind:`thinking`,content:a}),i&&r.push({kind:`text`,content:i});let o=e.filter(e=>e.type===`tool_result`);for(let e of o){let t=e.toolUseId;if(t){let n=r.find(e=>e.kind===`tool`&&e.tool.type===`tool_use`&&e.tool.toolUseId===t);if(n){n.result=e;continue}}let n=r.find(e=>e.kind===`tool`&&!e.result);n&&(n.result=e)}for(let e=0;e<r.length;e++){let n=r[e];if(n.kind===`tool`&&!n.result){let i=!1;if(n.tool.type===`tool_use`&&n.tool.tool===`Read`){let t=n.tool.input?.file_path;t&&(i=r.slice(e+1).some(e=>e.kind===`tool`&&e.result&&e.tool.type===`tool_use`&&e.tool.tool===`Edit`&&e.tool.input?.file_path===t))}n.completed=i||!t}}return(0,X.jsx)(X.Fragment,{children:r.map((e,i)=>{if(e.kind===`thinking`)return(0,X.jsx)(mt,{content:e.content,isStreaming:t&&i===r.length-1},`think-${i}`);if(e.kind===`text`){let a=t&&i===r.length-1;return(0,X.jsx)(`div`,{className:`text-sm text-text-primary`,children:(0,X.jsx)(ht,{content:e.content,animate:a,projectName:n})},`text-${i}`)}return(0,X.jsx)(We,{tool:e.tool,result:e.result,completed:e.completed,projectName:n},`tool-${i}`)})})}function mt({content:e,isStreaming:t}){let[n,r]=(0,J.useState)(t);return(0,J.useEffect)(()=>{!t&&e.length>0&&r(!1)},[t,e.length]),(0,X.jsxs)(`div`,{className:`rounded border border-border/50 bg-surface/30 text-xs`,children:[(0,X.jsxs)(`button`,{onClick:()=>r(!n),className:`flex items-center gap-2 px-2 py-1.5 w-full text-left hover:bg-surface transition-colors text-text-subtle`,children:[t?(0,X.jsx)(j,{className:`size-3 animate-spin`}):(0,X.jsx)(O,{className:`size-3 transition-transform ${n?`rotate-90`:``}`}),(0,X.jsxs)(`span`,{children:[`Thinking`,t?`...`:``]}),!t&&(0,X.jsx)(`span`,{className:`text-text-subtle/50 ml-auto`,children:e.length>100?`${Math.round(e.length/4)} tokens`:``})]}),n&&(0,X.jsx)(`div`,{className:`px-2 pb-2 text-text-subtle/80 whitespace-pre-wrap max-h-60 overflow-y-auto text-[11px] leading-relaxed`,children:e})]})}function ht({content:e,animate:t,projectName:n}){return(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(_t,{content:e,projectName:n}),t&&(0,X.jsx)(`span`,{className:`text-text-subtle text-sm animate-pulse`,children:`Thinking...`})]})}function gt({lastMessage:e,streamingStatus:t,elapsed:n,warningThreshold:r=15}){let i=!e||e.role!==`assistant`,a=e?.events?.length?e.events[e.events.length-1].type===`tool_result`:!1;return!i&&!a?null:(0,X.jsxs)(`div`,{className:`flex flex-col gap-1 text-sm`,children:[(0,X.jsxs)(`div`,{className:`flex items-center gap-2 text-text-subtle`,children:[(0,X.jsx)(j,{className:`size-3 animate-spin`}),(0,X.jsxs)(`span`,{children:[`Thinking`,i&&(n??0)>0&&(0,X.jsxs)(`span`,{className:`text-text-subtle/60`,children:[`... (`,n,`s)`]})]})]}),i&&(n??0)>=r&&(0,X.jsx)(`p`,{className:`text-xs text-yellow-500/80 ml-5`,children:`Taking longer than usual — may be rate-limited or API slow. Try sending a new message to retry.`})]})}function _t({content:e,projectName:t}){return(0,X.jsx)(H,{content:e,projectName:t,codeActions:!0})}function vt({approval:e,onRespond:t}){return(0,X.jsxs)(`div`,{className:`rounded-lg border-2 border-yellow-500/40 bg-yellow-500/10 p-3 space-y-2`,children:[(0,X.jsxs)(`div`,{className:`flex items-center gap-2 text-yellow-400 text-sm font-medium`,children:[(0,X.jsx)(de,{className:`size-4`}),(0,X.jsx)(`span`,{children:`Tool Approval Required`})]}),(0,X.jsx)(`div`,{className:`text-xs text-text-primary`,children:(0,X.jsx)(`span`,{className:`font-medium`,children:e.tool})}),(0,X.jsx)(`pre`,{className:`text-xs font-mono text-text-secondary overflow-x-auto bg-background rounded p-2 border border-border`,children:JSON.stringify(e.input,null,2)}),(0,X.jsxs)(`div`,{className:`flex gap-2`,children:[(0,X.jsx)(`button`,{onClick:()=>t(e.requestId,!0),className:`px-4 py-1.5 rounded bg-green-600 text-white text-xs font-medium hover:bg-green-500 transition-colors`,children:`Allow`}),(0,X.jsx)(`button`,{onClick:()=>t(e.requestId,!1),className:`px-4 py-1.5 rounded bg-red-600 text-white text-xs font-medium hover:bg-red-500 transition-colors`,children:`Deny`})]})]})}function yt({approval:e,onRespond:t}){return(0,X.jsx)(et,{questions:e.input.questions??[],onSubmit:n=>t(e.requestId,!0,n),onSkip:()=>t(e.requestId,!1)})}var bt=new Set([`image/png`,`image/jpeg`,`image/gif`,`image/webp`]),xt=new Set([`application/pdf`]),St=[`text/`,`application/json`,`application/xml`,`application/javascript`,`application/typescript`,`application/x-yaml`,`application/toml`,`application/x-sh`],Ct=new Set(`.ts,.tsx,.js,.jsx,.mjs,.cjs,.py,.rb,.go,.rs,.java,.kt,.swift,.c,.cpp,.h,.hpp,.cs,.json,.yaml,.yml,.toml,.xml,.md,.mdx,.txt,.csv,.tsv,.html,.css,.scss,.less,.sass,.sh,.bash,.zsh,.fish,.sql,.graphql,.gql,.env,.ini,.cfg,.conf,.dockerfile,.makefile,.vue,.svelte,.astro,.ipynb`.split(`,`));function wt(e){return bt.has(e.type)}function Tt(e){if(bt.has(e.type)||xt.has(e.type)||St.some(t=>e.type.startsWith(t)))return!0;let t=Et(e.name);return!!(t&&Ct.has(t))}function Et(e){let t=e.lastIndexOf(`.`);return t===-1?``:e.slice(t).toLowerCase()}function Dt({attachments:e,onRemove:t}){return e.length===0?null:(0,X.jsx)(`div`,{className:`flex flex-wrap gap-1.5 px-2 md:px-4 pt-2`,children:e.map(e=>(0,X.jsxs)(`div`,{className:`flex items-center gap-1.5 rounded-md border border-border bg-surface px-2 py-1 text-xs text-text-secondary max-w-48`,children:[e.previewUrl?(0,X.jsx)(`img`,{src:e.previewUrl,alt:e.name,className:`size-5 rounded object-cover shrink-0`}):e.isImage?(0,X.jsx)(G,{className:`size-3.5 shrink-0 text-text-subtle`}):(0,X.jsx)(k,{className:`size-3.5 shrink-0 text-text-subtle`}),(0,X.jsx)(`span`,{className:`truncate`,children:e.name}),e.status===`uploading`?(0,X.jsx)(j,{className:`size-3 shrink-0 animate-spin text-text-subtle`}):e.status===`error`?(0,X.jsx)(`span`,{className:`text-red-500 shrink-0`,title:`Upload failed`,children:`!`}):null,(0,X.jsx)(`button`,{type:`button`,onClick:()=>t(e.id),className:`shrink-0 rounded-sm p-0.5 hover:bg-border/50 transition-colors`,"aria-label":`Remove ${e.name}`,children:(0,X.jsx)(n,{className:`size-3`})})]},e.id))})}var Q=[{id:`default`,label:`Ask before edits`,icon:se,description:`Claude will ask for approval before making each edit`},{id:`acceptEdits`,label:`Edit automatically`,icon:ae,description:`Claude will edit files without asking first`},{id:`plan`,label:`Plan mode`,icon:W,description:`Claude will present a plan before editing`},{id:`bypassPermissions`,label:`Bypass permissions`,icon:q,description:`Claude will not ask before running commands`}];function Ot(e){return Q.find(t=>t.id===e)?.label??`Unknown`}function kt(e){return Q.find(t=>t.id===e)?.icon??se}function At({value:e,onChange:t,open:n,onOpenChange:r}){let a=(0,J.useRef)(null),o=(0,J.useRef)(0);(0,J.useEffect)(()=>{if(!n)return;let e=e=>{a.current&&!a.current.contains(e.target)&&r(!1)};return document.addEventListener(`mousedown`,e),()=>document.removeEventListener(`mousedown`,e)},[n,r]),(0,J.useEffect)(()=>{n&&(o.current=Q.findIndex(t=>t.id===e),o.current<0&&(o.current=0))},[n,e]);let s=(0,J.useCallback)(e=>{if(e.key===`Escape`){r(!1);return}if(e.key===`ArrowDown`||e.key===`ArrowUp`){e.preventDefault();let t=e.key===`ArrowDown`?1:-1;o.current=(o.current+t+Q.length)%Q.length,(a.current?.querySelector(`[data-idx="${o.current}"]`))?.focus()}if(e.key===`Enter`){e.preventDefault();let n=Q[o.current];n&&(t(n.id),r(!1))}},[t,r]);return n?(0,X.jsxs)(`div`,{ref:a,role:`listbox`,"aria-label":`Permission modes`,onKeyDown:s,onMouseDown:e=>e.stopPropagation(),onClick:e=>e.stopPropagation(),className:`absolute bottom-full left-0 mb-1 z-50 w-72 md:w-80 rounded-lg border border-border bg-surface shadow-lg`,children:[(0,X.jsxs)(`div`,{className:`flex items-center justify-between px-3 py-2 border-b border-border`,children:[(0,X.jsx)(`span`,{className:`text-xs font-medium text-text-secondary`,children:`Modes`}),(0,X.jsx)(`kbd`,{className:`text-[10px] px-1.5 py-0.5 rounded bg-surface-elevated text-text-subtle border border-border`,children:`Shift + Tab`})]}),(0,X.jsx)(`div`,{className:`py-1`,children:Q.map((n,a)=>{let o=n.icon,s=n.id===e;return(0,X.jsxs)(`button`,{"data-idx":a,role:`option`,"aria-selected":s,tabIndex:0,onClick:()=>{t(n.id),r(!1)},className:`w-full flex items-start gap-3 px-3 py-2.5 text-left transition-colors hover:bg-surface-elevated focus:bg-surface-elevated focus:outline-none ${s?`bg-surface-elevated`:``}`,children:[(0,X.jsx)(o,{className:`size-4 mt-0.5 shrink-0 text-text-secondary`}),(0,X.jsxs)(`div`,{className:`flex-1 min-w-0`,children:[(0,X.jsx)(`div`,{className:`text-sm font-medium text-text-primary`,children:n.label}),(0,X.jsx)(`div`,{className:`text-xs text-text-subtle leading-snug`,children:n.description})]}),s&&(0,X.jsx)(i,{className:`size-4 mt-0.5 shrink-0 text-primary`})]},n.id)})})]}):null}function jt(e){let t=[];function n(e){for(let r of e)t.push(r),r.children&&n(r.children)}return n(e),t}function Mt({items:e,filter:t,onSelect:n,onClose:r,visible:i}){let[a,o]=(0,J.useState)(0),s=(0,J.useRef)(null),c=(()=>{if(!t)return e.slice(0,50);let n=t.toLowerCase();return e.filter(e=>e.path.toLowerCase().includes(n)||e.name.toLowerCase().includes(n)).slice(0,50)})();(0,J.useEffect)(()=>{o(0)},[t]),(0,J.useEffect)(()=>{let e=s.current;e&&e.children[a]?.scrollIntoView({block:`nearest`})},[a]);let l=(0,J.useCallback)(e=>{if(!i||c.length===0)return!1;switch(e.key){case`ArrowUp`:return e.preventDefault(),o(e=>e>0?e-1:c.length-1),!0;case`ArrowDown`:return e.preventDefault(),o(e=>e<c.length-1?e+1:0),!0;case`Enter`:case`Tab`:return e.preventDefault(),c[a]&&n(c[a]),!0;case`Escape`:return e.preventDefault(),r(),!0}return!1},[i,c,a,n,r]);return(0,J.useEffect)(()=>{if(!i)return;let e=e=>{l(e)&&e.stopPropagation()};return document.addEventListener(`keydown`,e,!0),()=>document.removeEventListener(`keydown`,e,!0)},[i,l]),!i||c.length===0?null:(0,X.jsx)(`div`,{className:`max-h-52 overflow-y-auto border-b border-border bg-surface`,children:(0,X.jsx)(`div`,{ref:s,className:`py-1`,children:c.map((e,t)=>(0,X.jsxs)(`button`,{className:`flex items-center gap-2 w-full px-3 py-1.5 text-left transition-colors ${t===a?`bg-primary/10 text-primary`:`hover:bg-surface-hover text-text-primary`}`,onMouseEnter:()=>o(t),onClick:()=>n(e),children:[(0,X.jsx)(`span`,{className:`shrink-0`,children:e.type===`directory`?(0,X.jsx)(N,{className:`size-4 text-amber-500`}):(0,X.jsx)(D,{className:`size-4 text-blue-400`})}),(0,X.jsx)(`span`,{className:`text-sm truncate`,children:e.path})]},e.path))})})}var Nt=(0,J.memo)(function({onSend:e,isStreaming:t,onCancel:n,disabled:r,projectName:i,onSlashStateChange:a,onSlashItemsLoaded:o,slashSelected:s,onFileStateChange:c,onFileItemsLoaded:l,fileSelected:u,externalFiles:d,initialValue:f,autoFocus:p,permissionMode:h,onModeChange:y}){let[b,x]=(0,J.useState)(f??``),[S,C]=(0,J.useState)([]),[w,T]=(0,J.useState)(!1),E=(0,J.useRef)(null),D=(0,J.useRef)(null),O=(0,J.useRef)(null),k=(0,J.useRef)([]),A=(0,J.useRef)([]);(0,J.useEffect)(()=>{f&&(x(f),setTimeout(()=>{let e=E.current;e&&(e.focus(),e.selectionStart=e.selectionEnd=e.value.length)},50))},[f]),(0,J.useEffect)(()=>{p&&setTimeout(()=>{(window.matchMedia(`(min-width: 768px)`).matches?E.current:D.current)?.focus()},100)},[]),(0,J.useEffect)(()=>{if(!i){k.current=[],o?.([]);return}v.get(`${g(i)}/chat/slash-items`).then(e=>{k.current=e,o?.(e)}).catch(()=>{k.current=[],o?.([])})},[i]),(0,J.useEffect)(()=>{if(!i){A.current=[],l?.([]);return}v.get(`${g(i)}/files/tree?depth=5`).then(e=>{let t=jt(e);A.current=t,l?.(t)}).catch(()=>{A.current=[],l?.([])})},[i]),(0,J.useEffect)(()=>{if(!s)return;let e=E.current,t=e?.selectionStart??b.length,n=b.slice(0,t),r=b.slice(t),i=n.replace(/(?:^|\s)\/\S*$/,e=>`${e.startsWith(`/`)?``:e[0]}/${s.name} `);x(i+r),a?.(!1,``),c?.(!1,``),e&&(e.focus(),setTimeout(()=>{e.selectionStart=e.selectionEnd=i.length},0))},[s]),(0,J.useEffect)(()=>{if(!u)return;let e=E.current;if(!e)return;let t=e.selectionStart,n=b.slice(0,t),r=b.slice(t),i=n.match(/@(\S*)$/);if(i){let t=n.length-i[0].length;x(n.slice(0,t)+`@${u.path} `+r);let a=t+u.path.length+2;setTimeout(()=>{e.selectionStart=e.selectionEnd=a,e.focus()},0)}else{let t=b+`@${u.path} `;x(t),setTimeout(()=>{e.selectionStart=e.selectionEnd=t.length,e.focus()},0)}c?.(!1,``)},[u]),(0,J.useEffect)(()=>{!d||d.length===0||M(d)},[d]);let j=(0,J.useCallback)(async e=>{if(!i)return null;try{let t=new FormData;t.append(`files`,e);let n={},r=_();r&&(n.Authorization=`Bearer ${r}`);let a=await(await fetch(`${g(i)}/chat/upload`,{method:`POST`,headers:n,body:t})).json();return a.ok&&Array.isArray(a.data)&&a.data.length>0?a.data[0].path:null}catch{return null}},[i]),M=(0,J.useCallback)(e=>{for(let t of e){if(!Tt(t)){x(e=>e+(e.length>0&&!e.endsWith(` `)?` `:``)+t.name);continue}let e=m(),n=wt(t),r=n?URL.createObjectURL(t):void 0,i={id:e,name:t.name,file:t,isImage:n,previewUrl:r,status:`uploading`};C(e=>[...e,i]),j(t).then(t=>{C(n=>n.map(n=>n.id===e?{...n,serverPath:t??void 0,status:t?`ready`:`error`}:n))})}(D.current??E.current)?.focus()},[j]),N=(0,J.useCallback)(e=>{C(t=>{let n=t.find(t=>t.id===e);return n?.previewUrl&&URL.revokeObjectURL(n.previewUrl),t.filter(t=>t.id!==e)})},[]),P=(0,J.useCallback)(()=>{let t=b.trim(),n=S.filter(e=>e.status===`ready`);if(!(!t&&n.length===0)&&!r){a?.(!1,``),c?.(!1,``),e(t,n),x(``);for(let e of S)e.previewUrl&&URL.revokeObjectURL(e.previewUrl);C([]),E.current&&(E.current.style.height=`auto`),D.current&&(D.current.style.height=`auto`)}},[b,S,r,e,a,c]),F=(0,J.useCallback)(e=>{if(e.key===`Enter`&&!e.shiftKey){e.preventDefault(),P();return}if(e.shiftKey&&e.key===`Tab`){e.preventDefault();let t=[`default`,`acceptEdits`,`plan`,`bypassPermissions`],n=t[(t.indexOf(h??`bypassPermissions`)+1)%t.length];y?.(n)}},[P,h,y]),I=(0,J.useCallback)((e,t)=>{let n=e.slice(0,t),r=n.match(/(?:^|\s)\/(\S*)$/);if(r&&k.current.length>0){a?.(!0,r[1]??``),c?.(!1,``);return}let i=n.match(/@(\S*)$/);if(i&&A.current.length>0){c?.(!0,i[1]??``),a?.(!1,``);return}a?.(!1,``),c?.(!1,``)},[a,c]),L=(0,J.useCallback)((e,t)=>{x(e),I(e,t)},[I]),R=(0,J.useCallback)(e=>{let t=e?.target??E.current;t&&(t.style.height=`auto`,t.style.height=Math.min(t.scrollHeight,160)+`px`)},[]),z=(0,J.useCallback)(e=>{let t=e.clipboardData?.items;if(!t)return;let n=[];for(let e of t)if(e.kind===`file`){let t=e.getAsFile();t&&n.push(t)}n.length>0&&(e.preventDefault(),M(n))},[M]),ee=(0,J.useCallback)(e=>{e.preventDefault();let t=Array.from(e.dataTransfer.files);t.length>0&&M(t)},[M]),te=(0,J.useCallback)(e=>{e.preventDefault()},[]),B=(0,J.useCallback)(()=>{O.current?.click()},[]),ne=(0,J.useCallback)(e=>{let t=Array.from(e.target.files??[]);t.length>0&&M(t),e.target.value=``},[M]),V=b.trim().length>0||S.some(e=>e.status===`ready`),H=t&&!V;return(0,X.jsxs)(`div`,{className:`p-2 md:p-3 bg-background`,children:[(0,X.jsxs)(`div`,{className:`border border-border rounded-xl md:rounded-2xl bg-surface shadow-sm cursor-text`,onClick:e=>{r||e.target instanceof HTMLTextAreaElement||(window.matchMedia(`(min-width: 768px)`).matches?E.current:D.current)?.focus()},children:[(0,X.jsx)(Dt,{attachments:S,onRemove:N}),(0,X.jsxs)(`div`,{className:`flex items-center gap-1 px-2 pt-2 md:hidden relative`,children:[(0,X.jsx)(Pt,{mode:h??`bypassPermissions`,onClick:()=>T(e=>!e)}),(0,X.jsx)(At,{value:h??`bypassPermissions`,onChange:e=>y?.(e),open:w,onOpenChange:T})]}),(0,X.jsxs)(`div`,{className:`flex items-end gap-1 md:hidden px-2 py-2`,children:[(0,X.jsx)(`button`,{type:`button`,onClick:e=>{e.stopPropagation(),B()},disabled:r,className:`flex items-center justify-center size-7 shrink-0 rounded-full text-text-subtle hover:text-text-primary transition-colors disabled:opacity-50`,"aria-label":`Attach file`,children:(0,X.jsx)(le,{className:`size-4`})}),(0,X.jsx)(`textarea`,{ref:D,value:b,onChange:e=>{L(e.target.value,e.target.selectionStart),R(e)},onKeyDown:F,onPaste:z,onDrop:ee,onDragOver:te,placeholder:t?`Follow-up...`:`Ask anything...`,disabled:r,rows:1,className:`flex-1 resize-none bg-transparent py-1.5 text-sm text-foreground placeholder:text-text-subtle focus:outline-none disabled:opacity-50 max-h-20`}),H?(0,X.jsx)(`button`,{onClick:e=>{e.stopPropagation(),n?.()},className:`flex items-center justify-center size-7 shrink-0 rounded-full bg-red-600 text-white hover:bg-red-500 transition-colors`,"aria-label":`Stop`,children:(0,X.jsx)(me,{className:`size-3`})}):(0,X.jsx)(`button`,{onClick:e=>{e.stopPropagation(),P()},disabled:r||!V,className:`flex items-center justify-center size-7 shrink-0 rounded-full bg-primary text-primary-foreground hover:bg-primary/90 disabled:opacity-30 transition-colors`,"aria-label":`Send`,children:(0,X.jsx)(ie,{className:`size-3.5`})})]}),(0,X.jsxs)(`div`,{className:`hidden md:block`,children:[(0,X.jsx)(`textarea`,{ref:E,value:b,onChange:e=>{L(e.target.value,e.target.selectionStart),R(e)},onKeyDown:F,onPaste:z,onDrop:ee,onDragOver:te,placeholder:t?`Follow-up or Stop...`:`Ask anything...`,disabled:r,rows:1,className:`w-full resize-none bg-transparent px-4 pt-3 pb-1 text-sm text-foreground placeholder:text-text-subtle focus:outline-none disabled:opacity-50 max-h-40`}),(0,X.jsxs)(`div`,{className:`flex items-center justify-between px-3 pb-2`,children:[(0,X.jsxs)(`div`,{className:`flex items-center gap-1`,children:[(0,X.jsx)(`button`,{type:`button`,onClick:e=>{e.stopPropagation(),B()},disabled:r,className:`flex items-center justify-center size-8 rounded-full text-text-subtle hover:text-text-primary hover:bg-surface-elevated transition-colors disabled:opacity-50`,"aria-label":`Attach file`,children:(0,X.jsx)(le,{className:`size-4`})}),(0,X.jsxs)(`div`,{className:`relative`,children:[(0,X.jsx)(Pt,{mode:h??`bypassPermissions`,onClick:()=>T(e=>!e)}),(0,X.jsx)(At,{value:h??`bypassPermissions`,onChange:e=>y?.(e),open:w,onOpenChange:T})]})]}),(0,X.jsx)(`div`,{className:`flex items-center gap-1`,children:H?(0,X.jsx)(`button`,{onClick:e=>{e.stopPropagation(),n?.()},className:`flex items-center justify-center size-8 rounded-full bg-red-600 text-white hover:bg-red-500 transition-colors`,"aria-label":`Stop response`,children:(0,X.jsx)(me,{className:`size-3.5`})}):(0,X.jsx)(`button`,{onClick:e=>{e.stopPropagation(),P()},disabled:r||!V,className:`flex items-center justify-center size-8 rounded-full bg-primary text-primary-foreground hover:bg-primary/90 disabled:opacity-30 disabled:cursor-not-allowed transition-colors`,"aria-label":`Send message`,children:(0,X.jsx)(ie,{className:`size-4`})})})]})]})]}),(0,X.jsx)(`input`,{ref:O,type:`file`,multiple:!0,className:`hidden`,onChange:ne})]})});function Pt({mode:e,onClick:t}){let n=kt(e),r=Ot(e);return(0,X.jsxs)(`button`,{type:`button`,onClick:e=>{e.stopPropagation(),t()},className:`inline-flex items-center gap-1 px-2 py-1 rounded-md text-[11px] text-text-subtle hover:text-text-primary hover:bg-surface-elevated transition-colors border border-transparent hover:border-border`,"aria-label":`Permission mode: ${r}`,children:[(0,X.jsx)(n,{className:`size-3`}),(0,X.jsx)(`span`,{className:`max-w-[100px] truncate`,children:r})]})}function Ft({items:e,filter:t,onSelect:n,onClose:r,visible:i}){let[a,o]=(0,J.useState)(0),s=(0,J.useRef)(null),c=e.filter(e=>{let n=t.toLowerCase();return e.name.toLowerCase().includes(n)||e.description.toLowerCase().includes(n)});(0,J.useEffect)(()=>{o(0)},[t]),(0,J.useEffect)(()=>{let e=s.current;e&&e.children[a]?.scrollIntoView({block:`nearest`})},[a]);let l=(0,J.useCallback)(e=>{if(!i||c.length===0)return!1;switch(e.key){case`ArrowUp`:return e.preventDefault(),o(e=>e>0?e-1:c.length-1),!0;case`ArrowDown`:return e.preventDefault(),o(e=>e<c.length-1?e+1:0),!0;case`Enter`:case`Tab`:return e.preventDefault(),c[a]&&n(c[a]),!0;case`Escape`:return e.preventDefault(),r(),!0}return!1},[i,c,a,n,r]);return(0,J.useEffect)(()=>{if(!i)return;let e=e=>{l(e)&&e.stopPropagation()};return document.addEventListener(`keydown`,e,!0),()=>document.removeEventListener(`keydown`,e,!0)},[i,l]),!i||c.length===0?null:(0,X.jsx)(`div`,{className:`max-h-52 overflow-y-auto border-b border-border bg-surface`,children:(0,X.jsx)(`div`,{ref:s,className:`py-1`,children:c.map((e,t)=>(0,X.jsxs)(`button`,{className:`flex items-start gap-3 w-full px-3 py-2 text-left transition-colors ${t===a?`bg-primary/10 text-primary`:`hover:bg-surface-hover text-text-primary`}`,onMouseEnter:()=>o(t),onClick:()=>n(e),children:[(0,X.jsx)(`span`,{className:`shrink-0 mt-0.5`,children:e.type===`skill`?(0,X.jsx)(pe,{className:`size-4 text-amber-500`}):(0,X.jsx)(F,{className:`size-4 text-blue-500`})}),(0,X.jsxs)(`div`,{className:`min-w-0 flex-1`,children:[(0,X.jsxs)(`div`,{className:`flex items-baseline gap-2`,children:[(0,X.jsxs)(`span`,{className:`font-medium text-sm`,children:[`/`,e.name]}),e.argumentHint&&(0,X.jsx)(`span`,{className:`text-xs text-text-subtle`,children:e.argumentHint}),(0,X.jsx)(`span`,{className:`text-xs text-text-subtle capitalize ml-auto`,children:e.scope===`user`?`global`:e.type})]}),e.description&&(0,X.jsx)(`p`,{className:`text-xs text-text-subtle mt-0.5 line-clamp-2`,children:e.description})]})]},`${e.type}-${e.name}`))})})}function It(e){return e>=90?`text-red-500`:e>=70?`text-amber-500`:`text-green-500`}function Lt(e){return e>=90?`bg-red-500`:e>=70?`bg-amber-500`:`bg-green-500`}function Rt(e){if(!e)return null;let t=null;if(e.resetsInMinutes!=null)t=e.resetsInMinutes;else if(e.resetsInHours!=null)t=Math.round(e.resetsInHours*60);else if(e.resetsAt){let n=new Date(e.resetsAt).getTime()-Date.now();t=n>0?Math.ceil(n/6e4):0}if(t==null)return null;if(t<=0)return`now`;let n=Math.floor(t/1440),r=Math.floor(t%1440/60),i=t%60;return n>0?i>0?`${n}d ${r}h ${i}m`:r>0?`${n}d ${r}h`:`${n}d`:r>0?i>0?`${r}h ${i}m`:`${r}h`:`${i}m`}function $({label:e,bucket:t}){if(!t)return null;let n=Math.round(t.utilization*100),r=Rt(t);return(0,X.jsxs)(`div`,{className:`space-y-1`,children:[(0,X.jsxs)(`div`,{className:`flex items-center justify-between`,children:[(0,X.jsx)(`span`,{className:`text-xs font-medium text-text-primary`,children:e}),r&&(0,X.jsxs)(`span`,{className:`text-[10px] text-text-subtle`,children:[`↻ `,r]})]}),(0,X.jsxs)(`div`,{className:`flex items-center gap-2`,children:[(0,X.jsx)(`div`,{className:`flex-1 h-2 rounded-full bg-border overflow-hidden`,children:(0,X.jsx)(`div`,{className:`h-full rounded-full transition-all ${Lt(n)}`,style:{width:`${Math.min(n,100)}%`}})}),(0,X.jsxs)(`span`,{className:`text-xs font-medium tabular-nums w-10 text-right ${It(n)}`,children:[n,`%`]})]})]})}function zt(e){if(!e)return null;let t=Math.round((Date.now()-e)/1e3);if(t<5)return`just now`;if(t<60)return`${t}s ago`;let n=Math.floor(t/60);if(n<60)return`${n}m ago`;let r=Math.floor(n/60),i=n%60;return r<24?i>0?`${r}h ${i}m ago`:`${r}h ago`:`${Math.floor(r/24)}d ago`}function Bt({entry:e,isActive:t,accountInfo:n,onToggle:r,onVerify:i,verifyingId:a,onViewProfile:o,flash:s}){let{usage:c}=e,l=c.session||c.weekly||c.weeklyOpus||c.weeklySonnet,u=n?.status??e.accountStatus;return(0,X.jsxs)(`div`,{className:`rounded-md border p-2 space-y-1.5 transition-colors duration-500 ${s?`bg-primary/10 border-primary/40`:``} ${t?`border-primary/30 bg-primary/5`:`border-border/50`}`,children:[(0,X.jsxs)(`div`,{className:`flex items-center gap-1.5`,children:[(0,X.jsx)(`span`,{className:`text-xs font-medium truncate flex-1 min-w-0`,children:e.accountLabel??e.accountId.slice(0,8)}),!e.isOAuth&&(0,X.jsx)(`span`,{className:`text-[9px] text-text-subtle shrink-0`,children:`API key`}),(0,X.jsxs)(`div`,{className:`flex items-center gap-0.5 shrink-0`,children:[o&&n?.profileData&&(0,X.jsx)(`button`,{className:`p-1 rounded cursor-pointer text-text-subtle hover:text-foreground hover:bg-surface-elevated transition-colors`,onClick:()=>o(n.profileData),title:`View profile`,children:(0,X.jsx)(P,{className:`size-3`})}),i&&(0,X.jsx)(`button`,{className:`p-1 rounded cursor-pointer text-text-subtle hover:text-green-600 hover:bg-surface-elevated transition-colors`,onClick:()=>i(e.accountId),disabled:a===e.accountId,title:`Verify token`,children:a===e.accountId?(0,X.jsx)(j,{className:`size-3 animate-spin`}):(0,X.jsx)(fe,{className:`size-3`})}),r&&(0,X.jsx)(ne,{checked:u!==`disabled`,onCheckedChange:()=>r(e.accountId,u),disabled:u===`cooldown`,className:`scale-[0.6] cursor-pointer`})]})]}),l?(0,X.jsxs)(`div`,{className:`space-y-1.5`,children:[(0,X.jsx)($,{label:`5-Hour Session`,bucket:c.session}),(0,X.jsx)($,{label:`Weekly`,bucket:c.weekly}),(0,X.jsx)($,{label:`Weekly (Opus)`,bucket:c.weeklyOpus}),(0,X.jsx)($,{label:`Weekly (Sonnet)`,bucket:c.weeklySonnet})]}):(0,X.jsx)(`p`,{className:`text-[10px] text-text-subtle`,children:e.isOAuth?`No usage data yet`:`Usage tracking not available for API keys`}),c.lastFetchedAt&&(0,X.jsxs)(`p`,{className:`text-[9px] text-text-subtle`,children:[`Updated: `,zt(new Date(c.lastFetchedAt).getTime())]})]})}function Vt({usage:e,visible:t,onClose:r,onReload:i,loading:a,lastFetchedAt:o}){let[s,c]=(0,J.useState)([]),[l,u]=(0,J.useState)([]),[d,f]=(0,J.useState)(null),[p,m]=(0,J.useState)(!0),[h,g]=(0,J.useState)(!1),[_,v]=(0,J.useState)(new Set),[y,T]=(0,J.useState)(null),[E,D]=(0,J.useState)(null),O=(0,J.useRef)([]);async function k(){let e=s.length>0;e?g(!0):m(!0);let[t,n,r]=await Promise.allSettled([C(),w(),b()]);if(t.status===`fulfilled`){let n=t.value;if(e&&O.current.length>0){let e=new Set,t=new Map(O.current.map(e=>[e.accountId,e]));for(let r of n){let n=t.get(r.accountId);if(!n){e.add(r.accountId);continue}let i=n.usage,a=r.usage;(i.session?.utilization!==a.session?.utilization||i.weekly?.utilization!==a.weekly?.utilization||i.weeklyOpus?.utilization!==a.weeklyOpus?.utilization||i.weeklySonnet?.utilization!==a.weeklySonnet?.utilization)&&e.add(r.accountId)}e.size>0&&(v(e),setTimeout(()=>v(new Set),1500))}O.current=n,c(n)}n.status===`fulfilled`&&u(n.value),r.status===`fulfilled`&&f(r.value?.id??null),m(!1),g(!1)}if((0,J.useEffect)(()=>{t&&k()},[t]),(0,J.useEffect)(()=>{!t||!o||k()},[o]),!t)return null;let A=new Map(l.map(e=>[e.id,e])),j=e.queryCostUsd!=null||e.totalCostUsd!=null,N=s.length>0;async function P(e,t){await x(e,{status:t===`disabled`?`active`:`disabled`}),k(),i?.()}async function F(e){T(e);try{await S(e),k()}catch{}T(null)}return(0,X.jsxs)(`div`,{className:`border-b border-border bg-surface px-3 py-2.5 space-y-2.5 max-h-[350px] overflow-y-auto`,children:[(0,X.jsxs)(`div`,{className:`flex items-center justify-between`,children:[(0,X.jsxs)(`div`,{className:`flex items-center gap-2`,children:[(0,X.jsx)(`span`,{className:`text-xs font-semibold text-text-primary`,children:`Usage & Accounts`}),o&&(0,X.jsx)(`span`,{className:`text-[10px] text-text-subtle`,children:zt(new Date(o).getTime())})]}),(0,X.jsxs)(`div`,{className:`flex items-center gap-1`,children:[i&&(0,X.jsx)(`button`,{onClick:()=>{i(),k()},disabled:a||h,className:`text-xs text-text-subtle hover:text-text-primary px-1 disabled:opacity-50 cursor-pointer`,title:`Refresh`,children:(0,X.jsx)(M,{className:`size-3 ${a||h?`animate-spin`:``}`})}),(0,X.jsx)(`button`,{onClick:r,className:`text-xs text-text-subtle hover:text-text-primary px-1 cursor-pointer`,children:(0,X.jsx)(n,{className:`size-3`})})]})]}),N||p?(0,X.jsx)(`div`,{className:`grid grid-cols-[repeat(auto-fill,minmax(180px,1fr))] gap-1.5`,children:p?(0,X.jsx)(`p`,{className:`text-[10px] text-text-subtle`,children:`Loading...`}):s.map(t=>(0,X.jsx)(Bt,{entry:t,isActive:t.accountId===(d??e.activeAccountId),accountInfo:A.get(t.accountId),onToggle:P,onVerify:F,verifyingId:y,onViewProfile:D,flash:_.has(t.accountId)},t.accountId))}):(0,X.jsx)(X.Fragment,{children:e.session||e.weekly||e.weeklyOpus||e.weeklySonnet?(0,X.jsxs)(`div`,{className:`space-y-2.5`,children:[(0,X.jsx)($,{label:`5-Hour Session`,bucket:e.session}),(0,X.jsx)($,{label:`Weekly`,bucket:e.weekly}),(0,X.jsx)($,{label:`Weekly (Opus)`,bucket:e.weeklyOpus}),(0,X.jsx)($,{label:`Weekly (Sonnet)`,bucket:e.weeklySonnet})]}):(0,X.jsx)(`p`,{className:`text-xs text-text-subtle`,children:`No usage data available`})}),j&&(0,X.jsxs)(`div`,{className:`border-t border-border pt-2 space-y-1`,children:[e.queryCostUsd!=null&&(0,X.jsxs)(`div`,{className:`flex items-center justify-between text-xs`,children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Last query`}),(0,X.jsxs)(`span`,{className:`text-text-primary font-medium tabular-nums`,children:[`$`,e.queryCostUsd.toFixed(4)]})]}),e.totalCostUsd!=null&&(0,X.jsxs)(`div`,{className:`flex items-center justify-between text-xs`,children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Session total`}),(0,X.jsxs)(`span`,{className:`text-text-primary font-medium tabular-nums`,children:[`$`,e.totalCostUsd.toFixed(4)]})]})]}),E&&(0,X.jsxs)(`div`,{className:`border-t border-border pt-2`,children:[(0,X.jsxs)(`div`,{className:`flex items-center justify-between mb-1`,children:[(0,X.jsx)(`span`,{className:`text-[10px] font-medium text-text-subtle`,children:`Profile`}),(0,X.jsx)(`button`,{className:`text-text-subtle hover:text-foreground cursor-pointer`,onClick:()=>D(null),children:(0,X.jsx)(n,{className:`size-3`})})]}),(0,X.jsxs)(`div`,{className:`grid grid-cols-[70px_1fr] gap-x-2 gap-y-0.5 text-[10px]`,children:[E.account?.display_name&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Name`}),(0,X.jsx)(`span`,{children:E.account.display_name})]}),E.account?.email&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Email`}),(0,X.jsx)(`span`,{children:E.account.email})]}),E.organization?.name&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Org`}),(0,X.jsx)(`span`,{children:E.organization.name})]}),E.organization?.organization_type&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Type`}),(0,X.jsx)(`span`,{children:E.organization.organization_type})]}),E.organization?.rate_limit_tier&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Tier`}),(0,X.jsx)(`span`,{children:E.organization.rate_limit_tier})]}),E.organization?.subscription_status&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Status`}),(0,X.jsx)(`span`,{children:E.organization.subscription_status})]})]})]})]})}function Ht(e){try{return new Date(e).toLocaleDateString(void 0,{month:`short`,day:`numeric`})}catch{return``}}function Ut(e){return e>=90?`text-red-500`:e>=70?`text-amber-500`:`text-green-500`}function Wt({projectName:e,usageInfo:t,contextWindowPct:r,usageLoading:a,refreshUsage:o,lastFetchedAt:s,sessionId:c,onSelectSession:l,onBugReport:u,isConnected:f,onReconnect:p}){let[m,h]=(0,J.useState)(null),[_,y]=(0,J.useState)([]),[b,x]=(0,J.useState)(!1),S=R(e=>c?e.notifications.has(c):!1),C=R(e=>e.clearForSession),[w,T]=(0,J.useState)(``),[D,O]=(0,J.useState)(null),[k,N]=(0,J.useState)(``),P=(0,J.useRef)(null),F=d(e=>e.openTab),I=e=>{h(t=>t===e?null:e)},L=(0,J.useCallback)(async()=>{if(e){x(!0);try{y(await v.get(`${g(e)}/chat/sessions`))}catch{}finally{x(!1)}}},[e]);(0,J.useEffect)(()=>{m===`history`&&_.length===0&&L()},[m]);function B(t){l?(l(t),h(null)):F({type:`chat`,title:t.title||`Chat`,projectId:e??null,metadata:{projectName:e,sessionId:t.id},closable:!0})}let ne=(0,J.useCallback)((e,t)=>{t.stopPropagation(),O(e.id),N(e.title||``),setTimeout(()=>P.current?.select(),0)},[]),V=(0,J.useCallback)(async()=>{if(!D||!k.trim()||!e){O(null);return}try{await v.patch(`${g(e)}/chat/sessions/${D}`,{title:k.trim()}),y(e=>e.map(e=>e.id===D?{...e,title:k.trim()}:e))}catch{}O(null)},[D,k,e]),H=(0,J.useCallback)(()=>O(null),[]),ie=w.trim()?_.filter(e=>(e.title||``).toLowerCase().includes(w.toLowerCase())):_,U=t.fiveHour==null?null:Math.round(t.fiveHour*100),W=t.sevenDay==null?null:Math.round(t.sevenDay*100),ae=U!=null||W!=null?Ut(Math.max(U??0,W??0)):`text-text-subtle`;return(0,X.jsxs)(`div`,{className:`border-b border-border/50`,children:[(0,X.jsxs)(`div`,{className:`flex items-center gap-1 px-2 py-1`,children:[(0,X.jsxs)(`button`,{onClick:()=>I(`history`),className:`flex items-center gap-1 px-1.5 py-0.5 rounded text-[11px] transition-colors ${m===`history`?`text-primary bg-primary/10`:`text-text-secondary hover:text-foreground hover:bg-surface-elevated`}`,children:[(0,X.jsx)(ce,{className:`size-3`}),(0,X.jsx)(`span`,{children:`History`})]}),(0,X.jsx)(`button`,{onClick:()=>I(`config`),className:`p-1 rounded transition-colors ${m===`config`?`text-primary bg-primary/10`:`text-text-subtle hover:text-text-secondary hover:bg-surface-elevated`}`,title:`AI Settings`,children:(0,X.jsx)(ue,{className:`size-3`})}),(0,X.jsxs)(`button`,{onClick:()=>I(`usage`),className:`flex items-center gap-1 px-1.5 py-0.5 rounded text-[11px] font-medium tabular-nums transition-colors hover:bg-surface-elevated ${m===`usage`?`bg-primary/10`:``} ${ae}`,title:`Usage limits`,children:[(0,X.jsx)(re,{className:`size-3`}),t.activeAccountLabel&&(0,X.jsxs)(`span`,{className:`text-text-secondary font-normal truncate max-w-[60px]`,children:[`[`,t.activeAccountLabel,`]`]}),(0,X.jsxs)(`span`,{children:[`5h:`,U==null?`--%`:`${U}%`]}),(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`·`}),(0,X.jsxs)(`span`,{children:[`Wk:`,W==null?`--%`:`${W}%`]}),r!=null&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`·`}),(0,X.jsxs)(`span`,{className:Ut(r),children:[`Ctx:`,r,`%`]})]})]}),(0,X.jsx)(`div`,{className:`flex-1`}),S&&c&&(0,X.jsx)(`button`,{onClick:()=>C(c),className:`p-1 rounded text-amber-500 hover:text-amber-400 hover:bg-surface-elevated transition-colors`,title:`Mark as read`,children:(0,X.jsx)(A,{className:`size-3`})}),p&&(0,X.jsx)(`button`,{onClick:p,className:`size-4 flex items-center justify-center`,title:f?`Connected`:`Disconnected — click to reconnect`,children:(0,X.jsx)(`span`,{className:`size-2 rounded-full ${f?`bg-green-500`:`bg-red-500 animate-pulse`}`})})]}),m===`history`&&(0,X.jsxs)(`div`,{className:`border-t border-border/30 bg-surface`,children:[(0,X.jsxs)(`div`,{className:`flex items-center gap-1.5 px-2 py-1 border-b border-border/30`,children:[(0,X.jsx)(E,{className:`size-3 text-text-subtle shrink-0`}),(0,X.jsx)(`input`,{type:`text`,value:w,onChange:e=>T(e.target.value),placeholder:`Search sessions...`,className:`flex-1 bg-transparent text-[11px] text-text-primary outline-none placeholder:text-text-subtle`}),(0,X.jsx)(`button`,{onClick:L,disabled:b,className:`p-0.5 rounded text-text-subtle hover:text-text-secondary transition-colors disabled:opacity-50`,title:`Refresh`,children:(0,X.jsx)(M,{className:`size-3 ${b?`animate-spin`:``}`})})]}),(0,X.jsx)(`div`,{className:`max-h-[200px] overflow-y-auto`,children:b&&_.length===0?(0,X.jsx)(`div`,{className:`flex items-center justify-center py-3`,children:(0,X.jsx)(j,{className:`size-3.5 animate-spin text-text-subtle`})}):ie.length===0?(0,X.jsx)(`div`,{className:`flex items-center justify-center py-3 text-[11px] text-text-subtle`,children:w?`No matching sessions`:`No sessions yet`}):ie.map(e=>(0,X.jsxs)(`div`,{className:`flex items-center gap-2 w-full px-3 py-1.5 text-left hover:bg-surface-elevated transition-colors group`,children:[(0,X.jsx)(ee,{className:`size-3 shrink-0 text-text-subtle`}),D===e.id?(0,X.jsxs)(`form`,{className:`flex items-center gap-1 flex-1 min-w-0`,onSubmit:e=>{e.preventDefault(),V()},children:[(0,X.jsx)(`input`,{ref:P,value:k,onChange:e=>N(e.target.value),onBlur:V,onKeyDown:e=>{e.key===`Escape`&&H()},className:`flex-1 min-w-0 bg-surface-elevated text-[11px] text-text-primary px-1 py-0.5 rounded border border-border outline-none focus:border-primary`,autoFocus:!0}),(0,X.jsx)(`button`,{type:`submit`,className:`p-0.5 text-green-500 hover:text-green-400`,onClick:e=>e.stopPropagation(),children:(0,X.jsx)(i,{className:`size-3`})}),(0,X.jsx)(`button`,{type:`button`,className:`p-0.5 text-text-subtle hover:text-text-secondary`,onClick:e=>{e.stopPropagation(),H()},children:(0,X.jsx)(n,{className:`size-3`})})]}):(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`button`,{onClick:()=>B(e),className:`text-[11px] truncate flex-1 text-left`,children:e.title||`Untitled`}),(0,X.jsx)(`button`,{onClick:t=>ne(e,t),className:`p-0.5 rounded text-text-subtle hover:text-text-secondary opacity-0 group-hover:opacity-100 transition-opacity`,title:`Rename session`,children:(0,X.jsx)(te,{className:`size-3`})})]}),D!==e.id&&e.updatedAt&&(0,X.jsx)(`span`,{className:`text-[10px] text-text-subtle shrink-0`,children:Ht(e.updatedAt)})]},e.id))})]}),m===`config`&&(0,X.jsx)(`div`,{className:`border-t border-border/30 bg-surface px-3 py-2 max-h-[280px] overflow-y-auto`,children:(0,X.jsx)(z,{compact:!0})}),m===`usage`&&(0,X.jsx)(Vt,{usage:t,visible:!0,onClose:()=>h(null),onReload:o,loading:a,lastFetchedAt:s})]})}function Gt({metadata:e,tabId:t}){let[n,r]=(0,J.useState)(e?.sessionId??null),[i,a]=(0,J.useState)(e?.providerId??`claude`),[o,s]=(0,J.useState)([]),[c,l]=(0,J.useState)(!1),[m,h]=(0,J.useState)(``),[_,b]=(0,J.useState)(null),[x,S]=(0,J.useState)([]),[C,w]=(0,J.useState)(!1),[E,D]=(0,J.useState)(``),[O,k]=(0,J.useState)(null),[A,j]=(0,J.useState)(e?.permissionMode??void 0),[M,N]=(0,J.useState)(!1),[P,F]=(0,J.useState)(null),I=(0,J.useRef)(0),L=e?.projectName??``,z=d(e=>e.updateTab),ee=f(e=>e.version),{usageInfo:te,usageLoading:B,lastFetchedAt:ne,refreshUsage:H}=ke(L,i);(0,J.useEffect)(()=>{A||y().then(e=>{let t=e.providers[e.default_provider??`claude`];j(t?.permission_mode??`bypassPermissions`)}).catch(()=>{})},[]),(0,J.useEffect)(()=>{!t||!n||z(t,{metadata:{...e,sessionId:n,providerId:i,permissionMode:A}})},[n,i,A]);let{messages:re,messagesLoading:ie,isStreaming:U,streamingStatus:W,connectingElapsed:ae,thinkingWarningThreshold:oe,pendingApproval:se,contextWindowPct:ce,sessionTitle:G,sendMessage:K,respondToApproval:le,cancelStreaming:ue,reconnect:de,refetchMessages:fe,isConnected:q}=De(n,i,L);(0,J.useEffect)(()=>{if(!n||!t)return;let e=()=>{if(document.hidden)return;let{panels:e,focusedPanelId:r}=u.getState();e[r]?.activeTabId===t&&R.getState().clearForSession(n)};e(),document.addEventListener(`visibilitychange`,e);let r=u.subscribe(e);return()=>{document.removeEventListener(`visibilitychange`,e),r()}},[n,t]),(0,J.useEffect)(()=>{t&&G&&z(t,{title:G})},[G]);let pe=(0,J.useRef)(e?.pendingMessage);(0,J.useEffect)(()=>{if(pe.current&&q&&n){let n=pe.current;pe.current=void 0,t&&z(t,{metadata:{...e,pendingMessage:void 0}}),setTimeout(()=>K(n,{permissionMode:A}),100)}},[q,n]),(0,J.useCallback)(()=>{d.getState().openTab({type:`chat`,title:`AI Chat`,metadata:{projectName:L},projectId:L||null,closable:!0})},[L]);let me=(0,J.useCallback)(e=>{r(e.id),a(e.providerId),t&&z(t,{title:e.title||`Chat`})},[t,z]),he=(0,J.useCallback)(async e=>{if(!(!n||!L))try{let{api:t,projectUrl:r}=await p(async()=>{let{api:e,projectUrl:t}=await import(`./api-client-B0aMOJxF.js`).then(e=>e.n);return{api:e,projectUrl:t}},__vite__mapDeps([0,1])),a=await t.post(`${r(L)}/chat/sessions/${n}/fork?providerId=${i}`);d.getState().openTab({type:`chat`,title:`Fork: ${e.slice(0,30)}`,metadata:{projectName:L,sessionId:a.id,providerId:i,pendingMessage:e},projectId:L||null,closable:!0})}catch(e){console.error(`Fork failed:`,e)}},[n,L,i]),ge=(0,J.useCallback)((e,t)=>{if(t.length===0)return e;let n=t.filter(e=>e.serverPath).map(e=>e.serverPath).join(`
7
- `);return n?(t.length===1?`[Attached file: ${n}]\n\n`:`[Attached files:\n${n}\n]\n\n`)+e:e},[]),_e=(0,J.useCallback)(async(e,t=[])=>{let o=ge(e,t);if(o.trim()){if(!n)try{let t=L,n=await v.post(`${g(t)}/chat/sessions`,{providerId:i,title:e.slice(0,50)});r(n.id),a(n.providerId),setTimeout(()=>{K(o,{permissionMode:A})},500);return}catch(e){console.error(`Failed to create session:`,e);return}K(o,{permissionMode:A})}},[n,i,L,K,ge,A]),ve=(0,J.useCallback)((e,t)=>{l(e),h(t)},[]),ye=(0,J.useCallback)(e=>{b(e),l(!1),h(``),setTimeout(()=>b(null),50)},[]),be=(0,J.useCallback)(()=>{l(!1),h(``)},[]),Y=(0,J.useCallback)((e,t)=>{w(e),D(t)},[]),xe=(0,J.useCallback)(e=>{k(e),w(!1),D(``),setTimeout(()=>k(null),50)},[]),Se=(0,J.useCallback)(()=>{w(!1),D(``)},[]);return(0,X.jsxs)(`div`,{className:`flex flex-col h-full relative`,onDragEnter:(0,J.useCallback)(e=>{e.preventDefault(),I.current++,e.dataTransfer.types.includes(`Files`)&&N(!0)},[]),onDragLeave:(0,J.useCallback)(e=>{e.preventDefault(),I.current--,I.current===0&&N(!1)},[]),onDragOver:(0,J.useCallback)(e=>{e.preventDefault()},[]),onDrop:(0,J.useCallback)(e=>{e.preventDefault(),I.current=0,N(!1);let t=Array.from(e.dataTransfer.files);t.length>0&&(F(t),setTimeout(()=>F(null),100))},[]),children:[M&&(0,X.jsx)(`div`,{className:`absolute inset-0 z-50 flex items-center justify-center bg-background/80 backdrop-blur-sm border-2 border-dashed border-primary rounded-lg pointer-events-none`,children:(0,X.jsxs)(`div`,{className:`flex flex-col items-center gap-2 text-primary`,children:[(0,X.jsx)(T,{className:`size-8`}),(0,X.jsx)(`span`,{className:`text-sm font-medium`,children:`Drop files to attach`})]})}),(0,X.jsx)(tt,{messages:re,messagesLoading:ie,pendingApproval:se,onApprovalResponse:le,isStreaming:U,streamingStatus:W,connectingElapsed:ae,thinkingWarningThreshold:oe,projectName:L,onFork:U?void 0:he}),(0,X.jsxs)(`div`,{className:`border-t border-border bg-background shrink-0`,children:[(0,X.jsx)(Wt,{projectName:L,usageInfo:te,contextWindowPct:ce,usageLoading:B,refreshUsage:H,lastFetchedAt:ne,sessionId:n,onSelectSession:me,onBugReport:n?()=>V(ee,{sessionId:n,projectName:L}):void 0,isConnected:q,onReconnect:()=>{q||de(),fe()}}),(0,X.jsx)(Ft,{items:o,filter:m,onSelect:ye,onClose:be,visible:c}),(0,X.jsx)(Mt,{items:x,filter:E,onSelect:xe,onClose:Se,visible:C}),(0,X.jsx)(Nt,{onSend:_e,isStreaming:U,onCancel:ue,autoFocus:!e?.sessionId,projectName:L,onSlashStateChange:ve,onSlashItemsLoaded:s,slashSelected:_,onFileStateChange:Y,onFileItemsLoaded:S,fileSelected:O,externalFiles:P,permissionMode:A,onModeChange:j})]})]})}export{Gt as ChatTab};