@standardagents/client 0.14.1 → 0.15.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +7 -0
- package/dist/index.d.ts +18 -1
- package/dist/index.js +54 -6
- package/dist/index.js.map +1 -1
- package/package.json +2 -2
package/README.md
CHANGED
|
@@ -103,6 +103,10 @@ const messages = await client.getMessages('thread-123', {
|
|
|
103
103
|
})
|
|
104
104
|
```
|
|
105
105
|
|
|
106
|
+
Use `getMessagesPage()` when you need pagination metadata, or pass `ids` to
|
|
107
|
+
hydrate specific messages. `includeWorkblocks` expands requested tool-call
|
|
108
|
+
messages to the complete workblock they belong to.
|
|
109
|
+
|
|
106
110
|
##### `sendMessage(threadId, payload): Promise<Message>`
|
|
107
111
|
|
|
108
112
|
Send a message to a thread.
|
|
@@ -236,6 +240,7 @@ const workblocks = transformToWorkblocks(messages)
|
|
|
236
240
|
// Each workblock contains:
|
|
237
241
|
// - type: 'workblock'
|
|
238
242
|
// - workItems: array of tool calls and results
|
|
243
|
+
// - log_ids: log IDs for LLM requests represented by the block
|
|
239
244
|
// - status: 'pending' | 'completed'
|
|
240
245
|
```
|
|
241
246
|
|
|
@@ -281,6 +286,7 @@ interface WorkMessage {
|
|
|
281
286
|
reasoning_content?: string | null
|
|
282
287
|
status: 'pending' | 'completed'
|
|
283
288
|
workItems: WorkItem[]
|
|
289
|
+
log_ids?: string[]
|
|
284
290
|
created_at: number
|
|
285
291
|
depth?: number
|
|
286
292
|
}
|
|
@@ -293,6 +299,7 @@ interface WorkItem {
|
|
|
293
299
|
content?: string
|
|
294
300
|
status: 'success' | 'error' | null
|
|
295
301
|
tool_call_id?: string
|
|
302
|
+
log_id?: string | null
|
|
296
303
|
}
|
|
297
304
|
|
|
298
305
|
type ThreadMessage = Message | WorkMessage
|
package/dist/index.d.ts
CHANGED
|
@@ -95,6 +95,8 @@ interface WorkItem {
|
|
|
95
95
|
content: string | null;
|
|
96
96
|
status?: "pending" | "success" | "error" | null;
|
|
97
97
|
tool_call_id?: string;
|
|
98
|
+
created_at?: number;
|
|
99
|
+
log_id?: string | null;
|
|
98
100
|
}
|
|
99
101
|
interface WorkMessage {
|
|
100
102
|
id: string;
|
|
@@ -104,7 +106,11 @@ interface WorkMessage {
|
|
|
104
106
|
workItems: WorkItem[];
|
|
105
107
|
status: "pending" | "completed" | "failed";
|
|
106
108
|
created_at: number;
|
|
109
|
+
updated_at?: number;
|
|
110
|
+
request_sent_at?: number | null;
|
|
111
|
+
response_completed_at?: number | null;
|
|
107
112
|
depth?: number;
|
|
113
|
+
log_ids?: string[];
|
|
108
114
|
/**
|
|
109
115
|
* Deprecated: no longer auto-populated from tool-result attachments.
|
|
110
116
|
* Use real message attachments in thread history instead.
|
|
@@ -160,6 +166,13 @@ interface GetMessagesOptions {
|
|
|
160
166
|
offset?: number;
|
|
161
167
|
depth?: number;
|
|
162
168
|
includeSilent?: boolean;
|
|
169
|
+
ids?: string[];
|
|
170
|
+
includeWorkblocks?: boolean;
|
|
171
|
+
}
|
|
172
|
+
interface MessagesPage {
|
|
173
|
+
messages: Message[];
|
|
174
|
+
total: number;
|
|
175
|
+
hasMore: boolean;
|
|
163
176
|
}
|
|
164
177
|
interface MessageDataEvent {
|
|
165
178
|
type: "message_data";
|
|
@@ -264,6 +277,10 @@ declare class AgentBuilderClient {
|
|
|
264
277
|
* Get messages from a thread with optional pagination and filtering
|
|
265
278
|
*/
|
|
266
279
|
getMessages(id: string, options?: GetMessagesOptions): Promise<Message[]>;
|
|
280
|
+
/**
|
|
281
|
+
* Get a paginated message page from a thread.
|
|
282
|
+
*/
|
|
283
|
+
getMessagesPage(id: string, options?: GetMessagesOptions): Promise<MessagesPage>;
|
|
267
284
|
/**
|
|
268
285
|
* Send a message to a thread
|
|
269
286
|
*/
|
|
@@ -595,4 +612,4 @@ declare function generatePendingFileId(): string;
|
|
|
595
612
|
*/
|
|
596
613
|
declare function readFileAsDataUrl(file: File): Promise<string>;
|
|
597
614
|
|
|
598
|
-
export { AgentBuilderClient, type AgentBuilderConfig, type AttachmentPayload, type AttachmentRef, type ConnectionStatus, type CreateThreadPayload, type CustomEvent, type ErrorEvent, type FileUpdateCallback, FileUploadManager, type GetMessagesOptions, type GroupedThreadMessage, type ImageProcessingResult, type LogDataEvent, type LogStreamEvent, type LogWebSocketCallbacks, type Message, type MessageChunkEvent, type MessageDataEvent, type MessageStreamEvent, type MessageWebSocketCallbacks, type PendingAttachment, type SendMessagePayload, type StatusMessage, type StatusMessageKind, type StoppedByUserEvent, type SubagentBlockMessage, type SubagentGroupBlockMessage, type SubagentThreadMessage, type Thread, type ThreadConnectionCallbacks, ThreadConnectionManager, type ThreadConnectionOptions, type ThreadEvent, type ThreadFile, type ThreadMessage, type UploadOptions, type WorkItem, type WorkMessage, canGenerateThumbnails, generateImageThumbnail, generatePendingFileId, isImageMimeType, messagesToFiles, parseAttachments, readFileAsDataUrl, transformToSubagentBlocks, transformToWorkblocks };
|
|
615
|
+
export { AgentBuilderClient, type AgentBuilderConfig, type AttachmentPayload, type AttachmentRef, type ConnectionStatus, type CreateThreadPayload, type CustomEvent, type ErrorEvent, type FileUpdateCallback, FileUploadManager, type GetMessagesOptions, type GroupedThreadMessage, type ImageProcessingResult, type LogDataEvent, type LogStreamEvent, type LogWebSocketCallbacks, type Message, type MessageChunkEvent, type MessageDataEvent, type MessageStreamEvent, type MessageWebSocketCallbacks, type MessagesPage, type PendingAttachment, type SendMessagePayload, type StatusMessage, type StatusMessageKind, type StoppedByUserEvent, type SubagentBlockMessage, type SubagentGroupBlockMessage, type SubagentThreadMessage, type Thread, type ThreadConnectionCallbacks, ThreadConnectionManager, type ThreadConnectionOptions, type ThreadEvent, type ThreadFile, type ThreadMessage, type UploadOptions, type WorkItem, type WorkMessage, canGenerateThumbnails, generateImageThumbnail, generatePendingFileId, isImageMimeType, messagesToFiles, parseAttachments, readFileAsDataUrl, transformToSubagentBlocks, transformToWorkblocks };
|
package/dist/index.js
CHANGED
|
@@ -46,11 +46,20 @@ var AgentBuilderClient = class {
|
|
|
46
46
|
* Get messages from a thread with optional pagination and filtering
|
|
47
47
|
*/
|
|
48
48
|
async getMessages(id, options = {}) {
|
|
49
|
+
const data = await this.getMessagesPage(id, options);
|
|
50
|
+
return data.messages || [];
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Get a paginated message page from a thread.
|
|
54
|
+
*/
|
|
55
|
+
async getMessagesPage(id, options = {}) {
|
|
49
56
|
const params = new URLSearchParams();
|
|
50
57
|
if (options.limit !== void 0) params.set("limit", String(options.limit));
|
|
51
58
|
if (options.offset !== void 0) params.set("offset", String(options.offset));
|
|
52
59
|
if (options.depth !== void 0) params.set("depth", String(options.depth));
|
|
53
60
|
if (options.includeSilent !== void 0) params.set("includeSilent", String(options.includeSilent));
|
|
61
|
+
if (options.ids !== void 0 && options.ids.length > 0) params.set("ids", options.ids.join(","));
|
|
62
|
+
if (options.includeWorkblocks !== void 0) params.set("includeWorkblocks", String(options.includeWorkblocks));
|
|
54
63
|
const queryString = params.toString();
|
|
55
64
|
const url = `${this.endpoint}/threads/${id}/messages${queryString ? `?${queryString}` : ""}`;
|
|
56
65
|
const response = await fetch(url, {
|
|
@@ -61,7 +70,11 @@ var AgentBuilderClient = class {
|
|
|
61
70
|
throw new Error(`Failed to get messages: ${response.statusText}`);
|
|
62
71
|
}
|
|
63
72
|
const data = await response.json();
|
|
64
|
-
return
|
|
73
|
+
return {
|
|
74
|
+
messages: data.messages || [],
|
|
75
|
+
total: data.total || 0,
|
|
76
|
+
hasMore: !!data.hasMore
|
|
77
|
+
};
|
|
65
78
|
}
|
|
66
79
|
/**
|
|
67
80
|
* Send a message to a thread
|
|
@@ -714,7 +727,14 @@ function transformToWorkblocks(messages) {
|
|
|
714
727
|
let workblockStatus = "completed";
|
|
715
728
|
const firstMessageId = message.id;
|
|
716
729
|
const firstCreatedAt = message.created_at;
|
|
730
|
+
let latestTimestamp = Math.max(
|
|
731
|
+
message.created_at,
|
|
732
|
+
message.response_completed_at ?? 0
|
|
733
|
+
);
|
|
734
|
+
let requestSentAt = message.request_sent_at ?? message.created_at;
|
|
717
735
|
const depth = message.depth;
|
|
736
|
+
const logIds = /* @__PURE__ */ new Set();
|
|
737
|
+
if (message.log_id) logIds.add(message.log_id);
|
|
718
738
|
if (message.status === "pending") {
|
|
719
739
|
workblockStatus = "pending";
|
|
720
740
|
} else if (message.status === "failed") {
|
|
@@ -731,13 +751,21 @@ function transformToWorkblocks(messages) {
|
|
|
731
751
|
content: toolCall.function?.arguments || null,
|
|
732
752
|
status: null,
|
|
733
753
|
// Will be updated below based on matching results
|
|
734
|
-
tool_call_id: toolCall.id
|
|
754
|
+
tool_call_id: toolCall.id,
|
|
755
|
+
created_at: message.created_at,
|
|
756
|
+
log_id: message.log_id ?? null
|
|
735
757
|
});
|
|
736
758
|
}
|
|
737
759
|
let j = i + 1;
|
|
738
760
|
while (j < messages.length) {
|
|
739
761
|
const nextMessage = messages[j];
|
|
740
762
|
if (nextMessage.role === "tool") {
|
|
763
|
+
latestTimestamp = Math.max(
|
|
764
|
+
latestTimestamp,
|
|
765
|
+
nextMessage.created_at,
|
|
766
|
+
nextMessage.response_completed_at ?? 0
|
|
767
|
+
);
|
|
768
|
+
if (nextMessage.log_id) logIds.add(nextMessage.log_id);
|
|
741
769
|
const resultStatus = nextMessage.tool_status || "pending";
|
|
742
770
|
workItems.push({
|
|
743
771
|
id: nextMessage.id,
|
|
@@ -745,7 +773,9 @@ function transformToWorkblocks(messages) {
|
|
|
745
773
|
name: nextMessage.name || void 0,
|
|
746
774
|
content: nextMessage.content,
|
|
747
775
|
status: resultStatus,
|
|
748
|
-
tool_call_id: nextMessage.tool_call_id || void 0
|
|
776
|
+
tool_call_id: nextMessage.tool_call_id || void 0,
|
|
777
|
+
created_at: nextMessage.created_at,
|
|
778
|
+
log_id: nextMessage.log_id ?? null
|
|
749
779
|
});
|
|
750
780
|
j++;
|
|
751
781
|
} else if (nextMessage.role === "assistant" && nextMessage.tool_calls) {
|
|
@@ -755,6 +785,16 @@ function transformToWorkblocks(messages) {
|
|
|
755
785
|
} catch (error) {
|
|
756
786
|
break;
|
|
757
787
|
}
|
|
788
|
+
latestTimestamp = Math.max(
|
|
789
|
+
latestTimestamp,
|
|
790
|
+
nextMessage.created_at,
|
|
791
|
+
nextMessage.response_completed_at ?? 0
|
|
792
|
+
);
|
|
793
|
+
requestSentAt = Math.min(
|
|
794
|
+
requestSentAt,
|
|
795
|
+
nextMessage.request_sent_at ?? nextMessage.created_at
|
|
796
|
+
);
|
|
797
|
+
if (nextMessage.log_id) logIds.add(nextMessage.log_id);
|
|
758
798
|
if (nextMessage.status === "pending") {
|
|
759
799
|
workblockStatus = "pending";
|
|
760
800
|
} else if (nextMessage.status === "failed" && workblockStatus !== "pending") {
|
|
@@ -773,7 +813,9 @@ function transformToWorkblocks(messages) {
|
|
|
773
813
|
name: toolCall.function?.name,
|
|
774
814
|
content: toolCall.function?.arguments || null,
|
|
775
815
|
status: null,
|
|
776
|
-
tool_call_id: toolCall.id
|
|
816
|
+
tool_call_id: toolCall.id,
|
|
817
|
+
created_at: nextMessage.created_at,
|
|
818
|
+
log_id: nextMessage.log_id ?? null
|
|
777
819
|
});
|
|
778
820
|
}
|
|
779
821
|
j++;
|
|
@@ -794,7 +836,9 @@ function transformToWorkblocks(messages) {
|
|
|
794
836
|
name: toolName,
|
|
795
837
|
content: null,
|
|
796
838
|
status: orphan.status,
|
|
797
|
-
tool_call_id: orphan.tool_call_id
|
|
839
|
+
tool_call_id: orphan.tool_call_id,
|
|
840
|
+
created_at: orphan.created_at,
|
|
841
|
+
log_id: orphan.log_id ?? null
|
|
798
842
|
};
|
|
799
843
|
workItems.splice(orphanIndex, 0, syntheticCall);
|
|
800
844
|
}
|
|
@@ -819,7 +863,11 @@ function transformToWorkblocks(messages) {
|
|
|
819
863
|
workItems,
|
|
820
864
|
status: workblockStatus,
|
|
821
865
|
created_at: firstCreatedAt,
|
|
822
|
-
|
|
866
|
+
updated_at: latestTimestamp,
|
|
867
|
+
request_sent_at: requestSentAt,
|
|
868
|
+
response_completed_at: workblockStatus === "pending" ? null : latestTimestamp,
|
|
869
|
+
depth,
|
|
870
|
+
log_ids: Array.from(logIds)
|
|
823
871
|
};
|
|
824
872
|
result.push(workblock);
|
|
825
873
|
i = j;
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/client/AgentBuilderClient.ts","../src/connection/ThreadConnectionManager.ts","../src/utils/attachments.ts","../src/utils/imageProcessing.ts","../src/utils/fileHelpers.ts","../src/uploads/FileUploadManager.ts","../src/utils/workblocks.ts","../src/utils/subagentBlocks.ts"],"sourcesContent":["import type {\n Message,\n Thread,\n SendMessagePayload,\n GetMessagesOptions,\n MessageWebSocketCallbacks,\n LogWebSocketCallbacks,\n MessageStreamEvent,\n LogStreamEvent,\n ThreadEvent,\n CreateThreadPayload,\n AttachmentRef,\n} from '../types'\n\nexport class AgentBuilderClient {\n private endpoint: string\n private token: string | null\n\n constructor(endpoint: string) {\n // Normalize endpoint by removing trailing slash\n this.endpoint = endpoint.replace(/\\/$/, '')\n\n // Read auth token from localStorage\n this.token = typeof localStorage !== 'undefined'\n ? localStorage.getItem('agentbuilder_auth_token')\n : null\n }\n\n /**\n * Get the current endpoint\n */\n getEndpoint(): string {\n return this.endpoint\n }\n\n /**\n * Create a new thread\n */\n async createThread(payload: CreateThreadPayload): Promise<Thread> {\n const response = await fetch(`${this.endpoint}/threads`, {\n method: 'POST',\n headers: {\n ...this.getHeaders(),\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify(payload),\n })\n\n if (!response.ok) {\n throw new Error(`Failed to create thread: ${response.statusText}`)\n }\n\n return response.json()\n }\n\n /**\n * Get thread metadata\n */\n async getThread(id: string): Promise<Thread> {\n const response = await fetch(`${this.endpoint}/threads/${id}`, {\n method: 'GET',\n headers: this.getHeaders(),\n })\n\n if (!response.ok) {\n throw new Error(`Failed to get thread: ${response.statusText}`)\n }\n\n return response.json()\n }\n\n /**\n * Get messages from a thread with optional pagination and filtering\n */\n async getMessages(\n id: string,\n options: GetMessagesOptions = {}\n ): Promise<Message[]> {\n const params = new URLSearchParams()\n\n if (options.limit !== undefined) params.set('limit', String(options.limit))\n if (options.offset !== undefined) params.set('offset', String(options.offset))\n if (options.depth !== undefined) params.set('depth', String(options.depth))\n if (options.includeSilent !== undefined) params.set('includeSilent', String(options.includeSilent))\n\n const queryString = params.toString()\n const url = `${this.endpoint}/threads/${id}/messages${queryString ? `?${queryString}` : ''}`\n\n const response = await fetch(url, {\n method: 'GET',\n headers: this.getHeaders(),\n })\n\n if (!response.ok) {\n throw new Error(`Failed to get messages: ${response.statusText}`)\n }\n\n const data = await response.json()\n return data.messages || []\n }\n\n /**\n * Send a message to a thread\n */\n async sendMessage(\n id: string,\n payload: SendMessagePayload\n ): Promise<Message> {\n const response = await fetch(`${this.endpoint}/threads/${id}/messages`, {\n method: 'POST',\n headers: {\n ...this.getHeaders(),\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify(payload),\n })\n\n if (!response.ok) {\n throw new Error(`Failed to send message: ${response.statusText}`)\n }\n\n return response.json()\n }\n\n /**\n * Stop execution of a thread\n */\n async stopExecution(id: string): Promise<void> {\n const response = await fetch(`${this.endpoint}/threads/${id}/stop`, {\n method: 'POST',\n headers: this.getHeaders(),\n })\n\n if (!response.ok) {\n throw new Error(`Failed to stop execution: ${response.statusText}`)\n }\n\n await response.json()\n }\n\n /**\n * Delete a message from a thread\n * @param threadId - The thread ID\n * @param messageId - The message ID to delete\n * @returns Object with success status\n */\n async deleteMessage(\n threadId: string,\n messageId: string\n ): Promise<{ success: boolean }> {\n const response = await fetch(\n `${this.endpoint}/threads/${threadId}/messages/${messageId}`,\n {\n method: 'DELETE',\n headers: this.getHeaders(),\n }\n )\n\n if (!response.ok) {\n throw new Error(`Failed to delete message: ${response.statusText}`)\n }\n\n return response.json()\n }\n\n /**\n * Options for file upload\n */\n /**\n * Upload a file to a thread's filesystem\n * @param threadId - The thread ID\n * @param file - The file to upload\n * @param options - Optional upload options\n * @param options.thumbnail - Base64-encoded thumbnail data (for images)\n * @param options.width - Image width in pixels\n * @param options.height - Image height in pixels\n * @returns AttachmentRef with file metadata\n */\n async uploadFile(\n threadId: string,\n file: File,\n options?: {\n thumbnail?: string\n width?: number\n height?: number\n }\n ): Promise<AttachmentRef> {\n const encodedFilename = encodeURIComponent(file.name)\n const url = `${this.endpoint}/threads/${threadId}/fs/${encodedFilename}`\n\n // If thumbnail provided, use JSON format with base64 data\n if (options?.thumbnail) {\n const base64Data = await this.fileToBase64(file)\n\n const response = await fetch(url, {\n method: 'POST',\n headers: {\n ...this.getHeaders(),\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n data: base64Data,\n mimeType: file.type,\n thumbnail: options.thumbnail,\n metadata: {\n width: options.width,\n height: options.height,\n },\n }),\n })\n\n if (!response.ok) {\n throw new Error(`Failed to upload file: ${response.statusText}`)\n }\n\n return response.json()\n }\n\n // For non-image files or when no thumbnail, use raw binary upload\n const response = await fetch(url, {\n method: 'POST',\n headers: {\n ...this.getHeaders(),\n 'Content-Type': file.type,\n },\n body: file,\n })\n\n if (!response.ok) {\n throw new Error(`Failed to upload file: ${response.statusText}`)\n }\n\n return response.json()\n }\n\n /**\n * Convert a File to base64 string\n */\n private fileToBase64(file: File): Promise<string> {\n return new Promise((resolve, reject) => {\n const reader = new FileReader()\n reader.onload = () => {\n const result = reader.result as string\n // Remove data URL prefix (e.g., \"data:image/jpeg;base64,\")\n const base64 = result.split(',')[1]\n resolve(base64)\n }\n reader.onerror = () => reject(new Error('Failed to read file'))\n reader.readAsDataURL(file)\n })\n }\n\n /**\n * Get the full URL for a file in a thread's filesystem\n */\n getFileUrl(threadId: string, path: string): string {\n // Normalize path - remove leading slash and encode special characters\n const normalizedPath = path.startsWith('/') ? path.slice(1) : path\n const encodedPath = normalizedPath\n .split('/')\n .map(segment => encodeURIComponent(segment))\n .join('/')\n\n return `${this.endpoint}/threads/${threadId}/fs/${encodedPath}`\n }\n\n /**\n * Get the thumbnail URL for an image in a thread's filesystem\n */\n getThumbnailUrl(threadId: string, path: string): string {\n return `${this.getFileUrl(threadId, path)}?thumbnail=true`\n }\n\n /**\n * List all files in a thread's filesystem\n * @param threadId - The thread ID\n * @returns Array of file records\n */\n async listFiles(threadId: string): Promise<Array<{\n path: string\n name: string\n mimeType: string\n size: number\n isDirectory: boolean\n createdAt?: number\n updatedAt?: number\n }>> {\n // Use find API to recursively list all files\n const response = await fetch(\n `${this.endpoint}/threads/${threadId}/fs?find=**/*&type=file`,\n {\n method: 'GET',\n headers: this.getHeaders(),\n }\n )\n\n if (!response.ok) {\n throw new Error(`Failed to list files: ${response.statusText}`)\n }\n\n const data = await response.json()\n return data.files || []\n }\n\n /**\n * Connect to message WebSocket for real-time message updates\n */\n connectMessageWebSocket(\n id: string,\n callbacks: MessageWebSocketCallbacks = {},\n options: { includeSilent?: boolean; depth?: number } = {}\n ): WebSocket {\n const params = new URLSearchParams()\n\n if (this.token) params.set('token', this.token)\n if (options.includeSilent !== undefined) params.set('includeSilent', String(options.includeSilent))\n if (options.depth !== undefined) params.set('depth', String(options.depth))\n\n const wsProtocol = this.endpoint.startsWith('https') ? 'wss' : 'ws'\n const wsEndpoint = this.endpoint.replace(/^https?/, wsProtocol)\n const url = `${wsEndpoint}/threads/${id}/stream?${params.toString()}`\n\n const ws = new WebSocket(url)\n\n ws.onopen = () => {\n callbacks.onOpen?.()\n }\n\n ws.onmessage = (event) => {\n try {\n // Handle pong response from heartbeat ping\n if (typeof event.data === 'string' && event.data === 'pong') {\n return\n }\n\n const data = JSON.parse(event.data) as MessageStreamEvent\n\n switch (data.type) {\n case 'message_data':\n callbacks.onMessage?.(data)\n break\n case 'message_chunk':\n callbacks.onChunk?.(data)\n break\n case 'event':\n callbacks.onEvent?.(data as ThreadEvent)\n break\n case 'error':\n callbacks.onError?.(data)\n break\n }\n } catch (error) {\n console.error('Failed to parse WebSocket message:', error)\n }\n }\n\n ws.onerror = (event) => {\n console.error('WebSocket error:', event)\n callbacks.onError?.({ type: 'error', error: 'WebSocket connection error' })\n }\n\n ws.onclose = (event) => {\n console.log(`[AgentBuilderClient] Message WebSocket closed - code: ${event.code}, reason: ${event.reason || 'none'}, wasClean: ${event.wasClean}`)\n callbacks.onClose?.()\n }\n\n return ws\n }\n\n /**\n * Connect to log WebSocket for custom events\n */\n connectLogWebSocket(\n id: string,\n callbacks: LogWebSocketCallbacks = {}\n ): WebSocket {\n const params = new URLSearchParams()\n\n if (this.token) params.set('token', this.token)\n\n const wsProtocol = this.endpoint.startsWith('https') ? 'wss' : 'ws'\n const wsEndpoint = this.endpoint.replace(/^https?/, wsProtocol)\n const url = `${wsEndpoint}/threads/${id}?${params.toString()}`\n\n const ws = new WebSocket(url)\n\n ws.onopen = () => {\n callbacks.onOpen?.()\n }\n\n ws.onmessage = (event) => {\n try {\n // Handle pong response from heartbeat ping\n if (typeof event.data === 'string' && event.data === 'pong') {\n return\n }\n\n const data = JSON.parse(event.data) as LogStreamEvent\n\n switch (data.type) {\n case 'log_data':\n callbacks.onLog?.(data)\n break\n case 'custom':\n callbacks.onCustom?.(data)\n break\n case 'stopped_by_user':\n callbacks.onStopped?.(data)\n break\n }\n } catch (error) {\n console.error('Failed to parse WebSocket message:', error)\n }\n }\n\n ws.onerror = (event) => {\n console.error('WebSocket error:', event)\n }\n\n ws.onclose = () => {\n callbacks.onClose?.()\n }\n\n return ws\n }\n\n /**\n * Get headers for HTTP requests\n */\n private getHeaders(): Record<string, string> {\n const headers: Record<string, string> = {}\n\n if (this.token) {\n headers['Authorization'] = `Bearer ${this.token}`\n }\n\n return headers\n }\n}\n","import { AgentBuilderClient } from '../client/AgentBuilderClient'\nimport type {\n ConnectionStatus,\n ThreadConnectionCallbacks,\n MessageDataEvent,\n MessageChunkEvent,\n ThreadEvent,\n ErrorEvent,\n} from '../types'\n\nexport interface ThreadConnectionOptions {\n /** Maximum message depth to stream (default: 0 for top-level only) */\n depth?: number\n /** Whether to include silent messages (default: false) */\n includeSilent?: boolean\n /** Heartbeat interval in milliseconds (default: 30000) */\n heartbeatInterval?: number\n /** Maximum reconnection delay in milliseconds (default: 30000) */\n maxReconnectDelay?: number\n}\n\n/**\n * ThreadConnectionManager handles WebSocket connection lifecycle for a thread.\n * Provides automatic reconnection with exponential backoff and heartbeat keep-alive.\n *\n * This class is framework-agnostic. React and Vue SDKs use this internally\n * and handle their own reactive state management.\n *\n * @example\n * ```typescript\n * const manager = new ThreadConnectionManager(client, 'thread-123', {\n * onMessage: (event) => updateMessages(event.data),\n * onChunk: (event) => appendChunk(event.chunk),\n * onStatusChange: (status) => setConnectionStatus(status),\n * })\n *\n * manager.connect()\n * // ... later\n * manager.disconnect()\n * ```\n */\nexport class ThreadConnectionManager {\n private client: AgentBuilderClient\n private threadId: string\n private callbacks: ThreadConnectionCallbacks\n private options: Required<ThreadConnectionOptions>\n\n private ws: WebSocket | null = null\n private status: ConnectionStatus = 'disconnected'\n private reconnectAttempts: number = 0\n private reconnectTimeout: ReturnType<typeof setTimeout> | null = null\n private heartbeatInterval: ReturnType<typeof setInterval> | null = null\n private isReconnecting: boolean = false\n private shouldReconnect: boolean = true\n\n constructor(\n client: AgentBuilderClient,\n threadId: string,\n callbacks: ThreadConnectionCallbacks = {},\n options: ThreadConnectionOptions = {}\n ) {\n this.client = client\n this.threadId = threadId\n this.callbacks = callbacks\n this.options = {\n depth: options.depth ?? 0,\n includeSilent: options.includeSilent ?? false,\n heartbeatInterval: options.heartbeatInterval ?? 30000,\n maxReconnectDelay: options.maxReconnectDelay ?? 30000,\n }\n }\n\n /**\n * Get current connection status\n */\n getStatus(): ConnectionStatus {\n return this.status\n }\n\n /**\n * Get the thread ID this manager is connected to\n */\n getThreadId(): string {\n return this.threadId\n }\n\n /**\n * Connect to the thread WebSocket\n */\n connect(): void {\n if (this.ws && this.ws.readyState !== WebSocket.CLOSED) {\n // Already connected or connecting\n return\n }\n\n this.shouldReconnect = true\n this.isReconnecting = false\n this.setStatus('connecting')\n\n this.ws = this.client.connectMessageWebSocket(\n this.threadId,\n {\n onOpen: () => {\n this.setStatus('connected')\n this.reconnectAttempts = 0\n this.isReconnecting = false\n this.startHeartbeat()\n },\n onMessage: (event: MessageDataEvent) => {\n this.callbacks.onMessage?.(event)\n },\n onChunk: (event: MessageChunkEvent) => {\n this.callbacks.onChunk?.(event)\n },\n onEvent: (event: ThreadEvent) => {\n this.callbacks.onEvent?.(event)\n },\n onError: (event: ErrorEvent) => {\n this.callbacks.onError?.(event)\n },\n onClose: () => {\n this.clearTimers()\n this.scheduleReconnect()\n },\n },\n {\n depth: this.options.depth,\n includeSilent: this.options.includeSilent,\n }\n )\n }\n\n /**\n * Disconnect from the thread WebSocket\n */\n disconnect(): void {\n this.shouldReconnect = false\n this.clearTimers()\n\n if (this.ws) {\n this.ws.close()\n this.ws = null\n }\n\n this.reconnectAttempts = 0\n this.isReconnecting = false\n this.setStatus('disconnected')\n }\n\n /**\n * Update callbacks without reconnecting\n */\n updateCallbacks(callbacks: Partial<ThreadConnectionCallbacks>): void {\n this.callbacks = { ...this.callbacks, ...callbacks }\n }\n\n /**\n * Update options (requires reconnect to take effect for depth/includeSilent)\n */\n updateOptions(options: Partial<ThreadConnectionOptions>): void {\n this.options = { ...this.options, ...options }\n }\n\n private setStatus(status: ConnectionStatus): void {\n if (this.status !== status) {\n this.status = status\n this.callbacks.onStatusChange?.(status)\n }\n }\n\n private startHeartbeat(): void {\n this.clearHeartbeat()\n\n this.heartbeatInterval = setInterval(() => {\n if (this.ws && this.ws.readyState === WebSocket.OPEN) {\n this.ws.send('ping')\n }\n }, this.options.heartbeatInterval)\n }\n\n private clearHeartbeat(): void {\n if (this.heartbeatInterval) {\n clearInterval(this.heartbeatInterval)\n this.heartbeatInterval = null\n }\n }\n\n private clearReconnectTimeout(): void {\n if (this.reconnectTimeout) {\n clearTimeout(this.reconnectTimeout)\n this.reconnectTimeout = null\n }\n }\n\n private clearTimers(): void {\n this.clearHeartbeat()\n this.clearReconnectTimeout()\n }\n\n private scheduleReconnect(): void {\n if (!this.shouldReconnect || this.isReconnecting) {\n this.setStatus('disconnected')\n return\n }\n\n this.isReconnecting = true\n this.setStatus('reconnecting')\n\n // Exponential backoff: 1s, 2s, 4s, 8s, 16s, 30s (max)\n const delay = Math.min(\n 1000 * Math.pow(2, this.reconnectAttempts),\n this.options.maxReconnectDelay\n )\n this.reconnectAttempts++\n\n this.reconnectTimeout = setTimeout(() => {\n if (this.shouldReconnect) {\n this.connect()\n }\n }, delay)\n }\n}\n","import type { Message, AttachmentRef, ThreadFile } from '../types'\n\n/**\n * Parse attachments from a message\n * Handles both JSON string and already-parsed array formats\n * Returns empty array if no attachments or invalid data\n */\nexport function parseAttachments(message: Message): AttachmentRef[] {\n if (!message.attachments) {\n return []\n }\n\n // If already an array, return it directly\n if (Array.isArray(message.attachments)) {\n return message.attachments\n }\n\n // Otherwise try to parse as JSON string\n try {\n const parsed = JSON.parse(message.attachments)\n if (!Array.isArray(parsed)) {\n return []\n }\n return parsed\n } catch {\n return []\n }\n}\n\n/**\n * Check if a MIME type represents an image\n */\nexport function isImageMimeType(mimeType: string): boolean {\n return mimeType.toLowerCase().startsWith('image/')\n}\n\n/**\n * Convert messages to ThreadFile array\n * Extracts all committed files from message attachments\n */\nexport function messagesToFiles(messages: Message[]): ThreadFile[] {\n const files: ThreadFile[] = []\n\n for (const message of messages) {\n const attachments = parseAttachments(message)\n\n for (const attachment of attachments) {\n files.push({\n id: attachment.id,\n name: attachment.name,\n mimeType: attachment.mimeType,\n size: attachment.size,\n isImage: isImageMimeType(attachment.mimeType),\n localPreviewUrl: null, // Committed files don't have local preview\n status: 'committed',\n path: attachment.path,\n width: attachment.width,\n height: attachment.height,\n messageId: message.id,\n })\n }\n }\n\n return files\n}\n","/**\n * Image processing utilities for thumbnail generation\n * These functions require a browser environment with Canvas support\n */\n\nconst THUMBNAIL_SIZE = 256\n\n/**\n * Result of processing an image file\n */\nexport interface ImageProcessingResult {\n /** Base64-encoded thumbnail data (without data URL prefix) */\n thumbnail: string\n /** Original image width */\n width: number\n /** Original image height */\n height: number\n}\n\n/**\n * Load an image from a File object\n */\nfunction loadImage(file: File): Promise<HTMLImageElement> {\n return new Promise((resolve, reject) => {\n const img = new Image()\n const objectUrl = URL.createObjectURL(file)\n\n img.onload = () => {\n URL.revokeObjectURL(objectUrl)\n resolve(img)\n }\n img.onerror = () => {\n URL.revokeObjectURL(objectUrl)\n reject(new Error('Failed to load image'))\n }\n img.src = objectUrl\n })\n}\n\n/**\n * Create a thumbnail from an image element\n * Returns base64 data without the data URL prefix\n */\nfunction createThumbnailFromImage(img: HTMLImageElement): string {\n const { width, height } = img\n const aspectRatio = width / height\n\n let thumbWidth: number\n let thumbHeight: number\n\n if (aspectRatio > 1) {\n thumbWidth = Math.min(THUMBNAIL_SIZE, width)\n thumbHeight = Math.floor(thumbWidth / aspectRatio)\n } else {\n thumbHeight = Math.min(THUMBNAIL_SIZE, height)\n thumbWidth = Math.floor(thumbHeight * aspectRatio)\n }\n\n const canvas = document.createElement('canvas')\n canvas.width = thumbWidth\n canvas.height = thumbHeight\n\n const ctx = canvas.getContext('2d')\n if (!ctx) {\n throw new Error('Failed to get canvas context')\n }\n\n ctx.drawImage(img, 0, 0, thumbWidth, thumbHeight)\n\n // Return WebP for smaller size, strip data URL prefix\n const dataUrl = canvas.toDataURL('image/webp', 0.8)\n return dataUrl.split(',')[1]\n}\n\n/**\n * Process an image file to generate a thumbnail\n * @param file - The image file to process\n * @returns Promise with thumbnail data and dimensions\n */\nexport async function generateImageThumbnail(file: File): Promise<ImageProcessingResult> {\n const img = await loadImage(file)\n\n return {\n thumbnail: createThumbnailFromImage(img),\n width: img.width,\n height: img.height,\n }\n}\n\n/**\n * Check if the current environment supports Canvas (for thumbnail generation)\n */\nexport function canGenerateThumbnails(): boolean {\n return typeof document !== 'undefined' && typeof document.createElement === 'function'\n}\n","/**\n * File upload helper utilities\n */\n\n/**\n * Generate a unique ID for pending file uploads.\n * Uses timestamp + random string to ensure uniqueness.\n */\nexport function generatePendingFileId(): string {\n return `pending-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`\n}\n\n/**\n * Read a file as a data URL for image preview.\n * Returns a base64-encoded data URL that can be used as an image src.\n */\nexport function readFileAsDataUrl(file: File): Promise<string> {\n return new Promise((resolve, reject) => {\n const reader = new FileReader()\n reader.onload = () => resolve(reader.result as string)\n reader.onerror = reject\n reader.readAsDataURL(file)\n })\n}\n","/**\n * FileUploadManager - Framework-agnostic file upload management\n *\n * Handles the common logic for file uploads across Vue and React packages.\n * Each framework integrates this manager with its own state management.\n */\n\nimport type { ThreadFile, AttachmentRef } from '../types'\nimport type { AgentBuilderClient } from '../client/AgentBuilderClient'\nimport { isImageMimeType } from '../utils/attachments'\nimport { generateImageThumbnail } from '../utils/imageProcessing'\nimport { generatePendingFileId, readFileAsDataUrl } from '../utils/fileHelpers'\n\n/**\n * Callback for receiving file state updates during upload\n */\nexport type FileUpdateCallback = (updates: Partial<ThreadFile>) => void\n\n/**\n * Options for upload execution\n */\nexport interface UploadOptions {\n /** Generate and upload thumbnail for images (default: true) */\n generateThumbnail?: boolean\n /** Generate local preview URL for images (default: true) */\n generatePreview?: boolean\n}\n\n/**\n * FileUploadManager handles the upload lifecycle for files.\n *\n * Usage:\n * 1. Call queueFiles() to create pending file objects for immediate UI display\n * 2. Call executeUpload() for each file to start the actual upload\n * 3. Receive state updates via the callback to update your framework's state\n *\n * @example\n * ```typescript\n * const manager = new FileUploadManager()\n *\n * // Queue files for UI display\n * const pendingFiles = manager.queueFiles(selectedFiles)\n * setState(prev => [...prev, ...pendingFiles])\n *\n * // Start uploads\n * for (const pending of pendingFiles) {\n * manager.executeUpload(threadId, file, pending.id, client, (updates) => {\n * setState(prev => prev.map(f =>\n * f.id === pending.id ? { ...f, ...updates } : f\n * ))\n * })\n * }\n * ```\n */\nexport class FileUploadManager {\n /**\n * Create a pending file object from a File.\n * The returned object can be immediately added to state for UI feedback.\n */\n createPendingFile(file: File): ThreadFile {\n return {\n id: generatePendingFileId(),\n name: file.name,\n mimeType: file.type,\n size: file.size,\n isImage: isImageMimeType(file.type),\n localPreviewUrl: null,\n status: 'uploading',\n }\n }\n\n /**\n * Queue multiple files for upload.\n * Returns an array of pending file objects paired with their source File objects.\n *\n * @param files - Files to queue (File array or FileList)\n * @returns Array of [ThreadFile, File] tuples\n */\n queueFiles(files: File[] | FileList): Array<{ pending: ThreadFile; file: File }> {\n return Array.from(files).map(file => ({\n pending: this.createPendingFile(file),\n file,\n }))\n }\n\n /**\n * Execute the upload for a file.\n *\n * This method:\n * 1. Generates a local preview for images (async, non-blocking)\n * 2. Generates a thumbnail for images (if supported)\n * 3. Uploads the file to the server\n * 4. Calls onUpdate with state changes at each step\n *\n * @param threadId - The thread to upload to\n * @param file - The file to upload\n * @param pendingId - The ID of the pending file (from queueFiles)\n * @param client - The AgentBuilderClient instance\n * @param onUpdate - Callback for state updates\n * @param options - Upload options\n */\n async executeUpload(\n threadId: string,\n file: File,\n pendingId: string,\n client: AgentBuilderClient,\n onUpdate: FileUpdateCallback,\n options: UploadOptions = {}\n ): Promise<AttachmentRef> {\n const {\n generateThumbnail = true,\n generatePreview = true,\n } = options\n\n const isImage = isImageMimeType(file.type)\n\n // Generate local preview for images (async, doesn't block upload)\n if (isImage && generatePreview) {\n readFileAsDataUrl(file)\n .then(dataUrl => onUpdate({ localPreviewUrl: dataUrl }))\n .catch(err => console.error('Failed to generate preview:', err))\n }\n\n try {\n // Prepare upload options for images\n let uploadOptions: Parameters<typeof client.uploadFile>[2] | undefined\n\n if (isImage && generateThumbnail) {\n try {\n const result = await generateImageThumbnail(file)\n uploadOptions = {\n thumbnail: result.thumbnail,\n width: result.width,\n height: result.height,\n }\n } catch (err) {\n // If thumbnail generation fails, continue without it\n console.warn('Failed to generate thumbnail:', err)\n }\n }\n\n // Upload the file\n const attachment = await client.uploadFile(threadId, file, uploadOptions)\n\n // Update with server response\n onUpdate({\n id: attachment.id,\n status: 'ready',\n path: attachment.path,\n width: attachment.width,\n height: attachment.height,\n })\n\n return attachment\n } catch (err) {\n // Update with error state\n onUpdate({\n status: 'error',\n error: err instanceof Error ? err.message : 'Failed to upload file',\n })\n throw err\n }\n }\n\n /**\n * Execute uploads for multiple files in parallel.\n *\n * @param threadId - The thread to upload to\n * @param items - Array of pending/file pairs from queueFiles()\n * @param client - The AgentBuilderClient instance\n * @param onUpdate - Callback receiving (pendingId, updates) for each file\n * @param options - Upload options\n * @returns Array of upload results (AttachmentRef or Error for each file)\n */\n async executeUploads(\n threadId: string,\n items: Array<{ pending: ThreadFile; file: File }>,\n client: AgentBuilderClient,\n onUpdate: (pendingId: string, updates: Partial<ThreadFile>) => void,\n options: UploadOptions = {}\n ): Promise<Array<AttachmentRef | Error>> {\n const promises = items.map(({ pending, file }) =>\n this.executeUpload(\n threadId,\n file,\n pending.id,\n client,\n (updates) => onUpdate(pending.id, updates),\n options\n ).catch(err => err instanceof Error ? err : new Error(String(err)))\n )\n\n return Promise.all(promises)\n }\n}\n","import type { Message, WorkMessage, WorkItem, ThreadMessage } from '../types'\n\n/**\n * Transform a flat list of messages into a list with workblocks.\n * Groups consecutive assistant tool_calls and their tool results into WorkMessage objects.\n *\n * A workblock starts when an assistant message has tool_calls,\n * and continues to include ALL subsequent messages until:\n * - A user message appears\n * - An assistant message without tool_calls appears\n *\n * This means multiple assistant messages with tool_calls in a row\n * (with their tool results in between) are merged into a single workblock.\n */\nexport function transformToWorkblocks(messages: Message[]): ThreadMessage[] {\n if (messages.length === 0) {\n return []\n }\n\n const result: ThreadMessage[] = []\n let i = 0\n\n while (i < messages.length) {\n const message = messages[i]\n\n // Check if this is an assistant message with tool_calls\n if (message.role === 'assistant' && message.tool_calls) {\n // Try to parse tool_calls\n let toolCalls: any[]\n try {\n toolCalls = JSON.parse(message.tool_calls)\n } catch (error) {\n // If we can't parse tool_calls, treat it as a regular message\n result.push(message)\n i++\n continue\n }\n\n // Start building a workblock\n const workItems: WorkItem[] = []\n const contentParts: string[] = []\n let reasoningContent: string | null = message.reasoning_content || null\n let workblockStatus: 'pending' | 'completed' | 'failed' = 'completed'\n const firstMessageId = message.id\n const firstCreatedAt = message.created_at\n const depth = message.depth\n\n // Track if the current assistant message is pending\n if (message.status === 'pending') {\n workblockStatus = 'pending'\n } else if (message.status === 'failed') {\n workblockStatus = 'failed'\n }\n\n // Collect content from the first assistant message\n if (message.content) {\n contentParts.push(message.content)\n }\n\n // Add tool calls as work items\n for (const toolCall of toolCalls) {\n workItems.push({\n id: toolCall.id || message.id,\n type: 'tool_call',\n name: toolCall.function?.name,\n content: toolCall.function?.arguments || null,\n status: null, // Will be updated below based on matching results\n tool_call_id: toolCall.id,\n })\n }\n\n // Continue collecting messages while we see tool results or more assistant tool_calls\n let j = i + 1\n while (j < messages.length) {\n const nextMessage = messages[j]\n\n if (nextMessage.role === 'tool') {\n // Tool result - add to workblock\n const resultStatus = nextMessage.tool_status || 'pending'\n\n workItems.push({\n id: nextMessage.id,\n type: 'tool_result',\n name: nextMessage.name || undefined,\n content: nextMessage.content,\n status: resultStatus,\n tool_call_id: nextMessage.tool_call_id || undefined,\n })\n\n j++\n } else if (nextMessage.role === 'assistant' && nextMessage.tool_calls) {\n // Another assistant message with tool_calls - merge into same workblock\n let nextToolCalls: any[]\n try {\n nextToolCalls = JSON.parse(nextMessage.tool_calls)\n } catch (error) {\n // Can't parse, stop merging here\n break\n }\n\n // Update status if this message is pending/failed\n if (nextMessage.status === 'pending') {\n workblockStatus = 'pending'\n } else if (nextMessage.status === 'failed' && workblockStatus !== 'pending') {\n workblockStatus = 'failed'\n }\n\n // Collect content\n if (nextMessage.content) {\n contentParts.push(nextMessage.content)\n }\n\n // Collect reasoning content (use first non-null)\n if (!reasoningContent && nextMessage.reasoning_content) {\n reasoningContent = nextMessage.reasoning_content\n }\n\n // Add tool calls\n for (const toolCall of nextToolCalls) {\n workItems.push({\n id: toolCall.id || nextMessage.id,\n type: 'tool_call',\n name: toolCall.function?.name,\n content: toolCall.function?.arguments || null,\n status: null,\n tool_call_id: toolCall.id,\n })\n }\n j++\n } else {\n // User message or assistant without tool_calls - stop collecting\n break\n }\n }\n\n // Find orphaned tool_results (results without matching tool_calls) and create synthetic tool_calls\n const toolCallIds = new Set(workItems.filter(w => w.type === 'tool_call').map(w => w.tool_call_id))\n const orphanedResults = workItems.filter(\n w => w.type === 'tool_result' && w.tool_call_id && !toolCallIds.has(w.tool_call_id)\n )\n\n // Insert synthetic tool_calls for orphaned results\n for (const orphan of orphanedResults) {\n // Find the position of this orphan in workItems\n const orphanIndex = workItems.indexOf(orphan)\n // Extract tool name from error message or use generic\n const toolName = orphan.content?.match(/Tool not found: (\\w+)/)?.[1] || 'unknown_tool'\n\n // Insert a synthetic tool_call before the result\n const syntheticCall: WorkItem = {\n id: `synthetic-${orphan.tool_call_id}`,\n type: 'tool_call',\n name: toolName,\n content: null,\n status: orphan.status,\n tool_call_id: orphan.tool_call_id,\n }\n workItems.splice(orphanIndex, 0, syntheticCall)\n }\n\n // Update tool call statuses based on their matching results\n for (const item of workItems) {\n if (item.type === 'tool_call' && item.tool_call_id && item.status === null) {\n // Find matching result\n const matchingResult = workItems.find(\n wi => wi.type === 'tool_result' && wi.tool_call_id === item.tool_call_id\n )\n if (matchingResult) {\n // Tool call inherits status from its result\n item.status = matchingResult.status\n } else {\n // No result yet - tool call is pending\n item.status = 'pending'\n }\n }\n }\n\n // Combine content parts\n const combinedContent = contentParts.length > 0 ? contentParts.join('') : null\n\n // Create the workblock\n const workblock: WorkMessage = {\n id: firstMessageId,\n type: 'workblock',\n content: combinedContent,\n reasoning_content: reasoningContent,\n workItems,\n status: workblockStatus,\n created_at: firstCreatedAt,\n depth,\n }\n\n result.push(workblock)\n\n // Move index past all consumed messages\n i = j\n } else {\n // Not a workblock, pass through unchanged\n result.push(message)\n i++\n }\n }\n\n return result\n}\n","import type {\n Message,\n StatusMessage,\n SubagentBlockMessage,\n SubagentGroupBlockMessage,\n SubagentThreadMessage,\n ThreadMessage,\n WorkMessage,\n WorkItem,\n} from \"../types\"\nimport { transformToWorkblocks } from \"./workblocks\"\n\ntype TransformOptions = {\n includeWorkblocks?: boolean\n}\n\nconst SUBAGENT_TOOLS = new Set([\"subagent_create\", \"subagent_message\", \"send_to_agent\"])\nconst SUBAGENT_NAME_PATTERN = /subagent/i\n\nfunction isWorkblock(message: SubagentThreadMessage): message is WorkMessage {\n return (message as WorkMessage).type === \"workblock\"\n}\n\nfunction isStatusMessage(message: SubagentThreadMessage): message is StatusMessage {\n return (message as StatusMessage).type === \"status\"\n}\n\nfunction asOptionalString(value: unknown): string | null {\n if (typeof value !== \"string\") {\n return null\n }\n const normalized = value.trim()\n return normalized.length > 0 ? normalized : null\n}\n\nfunction getMetadataString(\n message: Message,\n key: string\n): string | null {\n if (!message.metadata || typeof message.metadata !== \"object\") {\n return null\n }\n return asOptionalString((message.metadata as Record<string, unknown>)[key])\n}\n\nfunction extractSubagentIdFromContent(content: string | null | undefined): string | null {\n if (!content) {\n return null\n }\n const fromToolResult = content.match(/Reference:\\s*([0-9a-fA-F-]{36})/)\n if (fromToolResult?.[1]) {\n return fromToolResult[1].toLowerCase()\n }\n const fromSubagentMessage = content.match(/reference:\\s*([0-9a-fA-F-]{36})/i)\n if (fromSubagentMessage?.[1]) {\n return fromSubagentMessage[1].toLowerCase()\n }\n return null\n}\n\nfunction inferSubagentStatus(message: Message): string | null {\n const explicit = asOptionalString(message.subagent_status)\n if (explicit) {\n return explicit\n }\n const content = message.content || \"\"\n if (/was initiated successfully/i.test(content) || /Message sent to subagent/i.test(content)) {\n return \"running\"\n }\n if (/has returned the following result/i.test(content)) {\n return \"idle\"\n }\n if (/has reported a failure/i.test(content) || /execution stopped before completion/i.test(content)) {\n return \"terminated\"\n }\n return null\n}\n\nfunction getSystemStatusKind(message: Message): StatusMessage[\"status_kind\"] | null {\n if (message.role !== \"system\") {\n return null\n }\n const metadataKind = getMetadataString(message, \"status_kind\")\n if (\n metadataKind === \"execution_stopped\" ||\n metadataKind === \"subagent_started\" ||\n metadataKind === \"subagent_event\"\n ) {\n return metadataKind\n }\n if (getMetadataString(message, \"subagent_event\") === \"parent_handoff\") {\n return \"subagent_event\"\n }\n const content = (message.content || \"\").trim()\n if (/execution\\s+stopped/i.test(content)) {\n return \"execution_stopped\"\n }\n if (/subagents?\\s+started:/i.test(content)) {\n return \"subagent_started\"\n }\n return null\n}\n\nfunction createSystemStatusMessage(message: Message): StatusMessage {\n const kind = getSystemStatusKind(message) ?? undefined\n return {\n id: `status:${message.id}`,\n type: \"status\",\n role: \"system\",\n content: message.content || \"Execution stopped by user\",\n created_at: message.created_at,\n depth: message.depth,\n silent: false,\n status_kind: kind,\n }\n}\n\nfunction isSubagentSignalMessage(message: Message): boolean {\n if (message.role === \"tool\" && asOptionalString(message.subagent_id)) {\n return true\n }\n\n if (message.role === \"tool\" && message.name && SUBAGENT_TOOLS.has(message.name)) {\n return true\n }\n\n const content = message.content || \"\"\n if (/subagent\\s*\\(reference:/i.test(content)) {\n return true\n }\n if (/the subagent was initiated successfully/i.test(content)) {\n return true\n }\n if (/message sent to subagent/i.test(content)) {\n return true\n }\n\n return false\n}\n\nfunction extractSubagentId(message: Message): string | null {\n const direct = asOptionalString(message.subagent_id)\n if (direct) {\n return direct\n }\n\n const metadata = message.metadata\n if (metadata && typeof metadata === \"object\") {\n const snake = asOptionalString((metadata as Record<string, unknown>).subagent_id)\n if (snake) {\n return snake\n }\n const camel = asOptionalString((metadata as Record<string, unknown>).subagentId)\n if (camel) {\n return camel\n }\n }\n\n return extractSubagentIdFromContent(message.content)\n}\n\nfunction parseToolCalls(toolCalls: string | null | undefined): Array<{\n id?: string\n function?: { name?: string }\n}> {\n if (!toolCalls) {\n return []\n }\n try {\n const parsed = JSON.parse(toolCalls)\n return Array.isArray(parsed) ? parsed : []\n } catch {\n return []\n }\n}\n\nfunction parseToolArguments(raw: string | null | undefined): Record<string, unknown> {\n if (!raw) {\n return {}\n }\n try {\n const parsed = JSON.parse(raw)\n return parsed && typeof parsed === \"object\" ? (parsed as Record<string, unknown>) : {}\n } catch {\n return {}\n }\n}\n\nfunction isLikelySubagentToolName(toolName: string | undefined): boolean {\n if (!toolName) {\n return false\n }\n if (SUBAGENT_TOOLS.has(toolName)) {\n return true\n }\n return SUBAGENT_NAME_PATTERN.test(toolName)\n}\n\nfunction getSubagentThreadNameFromWorkItem(item: WorkItem): string | null {\n const args = parseToolArguments(item.content)\n const name = asOptionalString(args.name)\n return name\n}\n\nfunction getSubagentIdFromWorkItem(\n item: WorkItem,\n toolCallIdToSubagentId: Map<string, string>\n): string | null {\n if (item.tool_call_id) {\n const mapped = toolCallIdToSubagentId.get(item.tool_call_id)\n if (mapped) {\n return mapped\n }\n }\n return extractSubagentIdFromContent(item.content)\n}\n\nfunction createSubagentBlock(\n subagentId: string,\n message: Message\n): SubagentBlockMessage {\n const inferredStatus = inferSubagentStatus(message)\n return {\n id: `subagent:${subagentId}`,\n type: \"subagent_block\",\n subagent_id: subagentId,\n subagent_name: message.subagent_name ?? null,\n subagent_title: message.subagent_title ?? null,\n subagent_description: message.subagent_description ?? null,\n subagent_status: inferredStatus ?? null,\n subagent_resumable: message.subagent_resumable ?? null,\n subagent_blocking: message.subagent_blocking ?? null,\n subagent_thread_name: message.subagent_thread_name ?? null,\n subagent_spawn_group_id: message.subagent_spawn_group_id ?? null,\n messages: [message],\n created_at: message.created_at,\n updated_at: message.created_at,\n depth: message.depth,\n }\n}\n\nfunction mergeSubagentBlock(block: SubagentBlockMessage, message: Message): void {\n block.messages.push(message)\n block.updated_at = Math.max(block.updated_at, message.created_at)\n block.created_at = Math.min(block.created_at, message.created_at)\n block.depth = message.depth ?? block.depth\n\n if (message.subagent_name !== undefined) {\n block.subagent_name = message.subagent_name ?? block.subagent_name ?? null\n }\n if (message.subagent_title !== undefined) {\n block.subagent_title = message.subagent_title ?? block.subagent_title ?? null\n }\n if (message.subagent_description !== undefined) {\n block.subagent_description =\n message.subagent_description ?? block.subagent_description ?? null\n }\n const inferredStatus = inferSubagentStatus(message)\n if (inferredStatus !== null) {\n block.subagent_status = inferredStatus\n }\n if (message.subagent_resumable !== undefined) {\n block.subagent_resumable =\n message.subagent_resumable ?? block.subagent_resumable ?? null\n }\n if (message.subagent_blocking !== undefined) {\n block.subagent_blocking =\n message.subagent_blocking ?? block.subagent_blocking ?? null\n }\n if (message.subagent_thread_name !== undefined) {\n block.subagent_thread_name =\n message.subagent_thread_name ?? block.subagent_thread_name ?? null\n }\n if (message.subagent_spawn_group_id !== undefined) {\n block.subagent_spawn_group_id =\n message.subagent_spawn_group_id ?? block.subagent_spawn_group_id ?? null\n }\n}\n\nfunction shouldSkipWorkblock(\n workblock: WorkMessage,\n resolvedSubagentIds: Set<string>\n): boolean {\n const toolCalls = workblock.workItems.filter((item) => item.type === \"tool_call\")\n if (toolCalls.length === 0) {\n return false\n }\n if (!toolCalls.every((item) => item.name && SUBAGENT_TOOLS.has(item.name))) {\n return false\n }\n return resolvedSubagentIds.size > 0\n}\n\nfunction inferBlockingFromToolResult(\n workblock: WorkMessage,\n toolCallId: string | undefined\n): boolean | null {\n if (!toolCallId) {\n return null\n }\n const result = workblock.workItems.find(\n (item) => item.type === \"tool_result\" && item.tool_call_id === toolCallId\n )\n if (!result || result.status !== \"success\") {\n return null\n }\n\n const text = (result.content || \"\").toLowerCase()\n if (text.includes(\"was initiated successfully\") || text.includes(\"results will be delivered when complete\")) {\n return false\n }\n if (text.length > 0) {\n return true\n }\n return null\n}\n\nfunction createPendingSubagentBlock(\n workblock: WorkMessage,\n toolCall: WorkItem,\n index: number,\n status: \"pending\" | \"running\"\n): SubagentBlockMessage {\n const toolName = asOptionalString(toolCall.name) ?? \"Subagent\"\n const pseudoSubagentId = toolCall.tool_call_id\n ? `pending:${toolCall.tool_call_id}`\n : `pending:${workblock.id}:${index}`\n const createdAt = workblock.created_at + index\n const isBuiltinLifecycleTool = !!toolCall.name && SUBAGENT_TOOLS.has(toolCall.name)\n\n return {\n id: `subagent:${pseudoSubagentId}`,\n type: \"subagent_block\",\n subagent_id: pseudoSubagentId,\n subagent_name: toolName,\n subagent_title: toolName,\n subagent_description: null,\n subagent_status: status,\n subagent_resumable: isBuiltinLifecycleTool ? true : false,\n subagent_blocking: isBuiltinLifecycleTool ? null : true,\n subagent_thread_name: getSubagentThreadNameFromWorkItem(toolCall),\n subagent_spawn_group_id: workblock.id,\n messages: [],\n created_at: createdAt,\n updated_at: createdAt,\n depth: workblock.depth,\n }\n}\n\ntype BlockPlacement = {\n block: SubagentBlockMessage\n startIndex: number | undefined\n displayIndex: number | undefined\n groupKey: string\n}\n\ntype BlockGroup = {\n groupKey: string\n startIndex: number | undefined\n displayIndex: number | undefined\n blocks: SubagentBlockMessage[]\n}\n\nfunction createGroupStartMarker(group: BlockGroup): StatusMessage | null {\n if (group.startIndex === undefined || group.displayIndex === undefined) {\n return null\n }\n if (group.startIndex === group.displayIndex) {\n return null\n }\n\n const names = group.blocks\n .map((block) => block.subagent_thread_name || block.subagent_title || block.subagent_name || \"Subagent\")\n .filter((name, index, arr) => arr.indexOf(name) === index)\n\n let label: string\n if (names.length <= 1) {\n label = `Subagent started: ${names[0] || \"Subagent\"}`\n } else if (names.length <= 3) {\n label = `Subagents started: ${names.join(\", \")}`\n } else {\n label = `Subagents started: ${names.length} subagents`\n }\n\n const createdAt =\n Math.min(...group.blocks.map((block) => block.created_at)) || Date.now() * 1000\n const depth = group.blocks[0]?.depth\n\n return {\n id: `subagent-start:${group.groupKey}`,\n type: \"status\",\n role: \"system\",\n content: label,\n created_at: createdAt,\n status_kind: \"subagent_started\",\n silent: false,\n depth,\n }\n}\n\nfunction getSubagentDisplayName(block: SubagentBlockMessage | undefined): string {\n return (\n block?.subagent_thread_name ||\n block?.subagent_title ||\n block?.subagent_name ||\n \"Subagent\"\n )\n}\n\nfunction createSubagentEventStatusMessage(\n message: Message,\n block: SubagentBlockMessage | undefined\n): StatusMessage | null {\n if (!message.content) {\n return null\n }\n\n const content = message.content\n const name = getSubagentDisplayName(block)\n\n let label: string | null = null\n if (/has returned the following result/i.test(content)) {\n label = `Subagent replied: ${name}`\n } else if (\n /has reported a failure/i.test(content) ||\n /execution stopped before completion/i.test(content)\n ) {\n label = `Subagent failed: ${name}`\n }\n\n if (!label) {\n return null\n }\n\n return {\n id: `status:subagent-event:${message.id}`,\n type: \"status\",\n role: \"system\",\n content: label,\n created_at: message.created_at,\n depth: message.depth,\n silent: false,\n status_kind: \"subagent_event\",\n subagent_id: block?.subagent_id ?? message.subagent_id ?? null,\n }\n}\n\nfunction buildGroupedBlock(group: BlockGroup): SubagentBlockMessage | SubagentGroupBlockMessage {\n if (group.blocks.length === 1) {\n return group.blocks[0]\n }\n\n const sorted = [...group.blocks].sort((a, b) => {\n const aName = (a.subagent_thread_name || a.subagent_title || a.subagent_name || \"\").toLowerCase()\n const bName = (b.subagent_thread_name || b.subagent_title || b.subagent_name || \"\").toLowerCase()\n if (aName !== bName) {\n return aName.localeCompare(bName)\n }\n return a.created_at - b.created_at\n })\n\n return {\n id: `subagent-group:${group.groupKey}`,\n type: \"subagent_group_block\",\n group_id: group.groupKey,\n subagents: sorted,\n created_at: Math.min(...sorted.map((block) => block.created_at)),\n updated_at: Math.max(...sorted.map((block) => block.updated_at)),\n depth: sorted[0]?.depth,\n }\n}\n\n/**\n * Transform thread messages into a stream that preserves workblocks while also\n * collapsing subagent-tagged messages into anchor-based subagent blocks.\n *\n * The subagent block is anchored to the originating `subagent_create` workblock\n * when possible, and subagent-tagged messages are rendered inside that block.\n */\nexport function transformToSubagentBlocks(\n messages: Message[],\n options: TransformOptions = {}\n): SubagentThreadMessage[] {\n if (messages.length === 0) {\n return []\n }\n\n const includeWorkblocks = options.includeWorkblocks ?? false\n const baseMessages: SubagentThreadMessage[] = includeWorkblocks\n ? (transformToWorkblocks(messages) as ThreadMessage[])\n : messages\n\n const toolCallIdToSubagentId = new Map<string, string>()\n for (const message of messages) {\n if (message.role !== \"tool\") {\n continue\n }\n if (!message.tool_call_id) {\n continue\n }\n const subagentId = extractSubagentId(message)\n if (subagentId) {\n toolCallIdToSubagentId.set(message.tool_call_id, subagentId)\n }\n }\n\n const anchorIndexBySubagentId = new Map<string, number>()\n const threadNameBySubagentId = new Map<string, string>()\n const inferredFlagsBySubagentId = new Map<\n string,\n { resumable: boolean | null; blocking: boolean | null }\n >()\n const pendingPlacements: BlockPlacement[] = []\n const skipWorkblockIndexes = new Set<number>()\n const indexByBaseEntryId = new Map<string, number>()\n\n baseMessages.forEach((entry, index) => {\n indexByBaseEntryId.set(entry.id, index)\n\n if (!isWorkblock(entry)) {\n return\n }\n\n const resolvedFromWorkblock = new Set<string>()\n const toolCalls = entry.workItems.filter((item) => item.type === \"tool_call\")\n const pendingSubagentToolCalls: WorkItem[] = []\n\n for (const toolCall of toolCalls) {\n if (!isLikelySubagentToolName(toolCall.name)) {\n continue\n }\n const subagentId = getSubagentIdFromWorkItem(toolCall, toolCallIdToSubagentId)\n if (!subagentId) {\n if (toolCall.status === \"pending\") {\n pendingSubagentToolCalls.push(toolCall)\n }\n continue\n }\n resolvedFromWorkblock.add(subagentId)\n if (!anchorIndexBySubagentId.has(subagentId)) {\n anchorIndexBySubagentId.set(subagentId, index)\n }\n const threadName = getSubagentThreadNameFromWorkItem(toolCall)\n if (threadName && !threadNameBySubagentId.has(subagentId)) {\n threadNameBySubagentId.set(subagentId, threadName)\n }\n\n const currentFlags = inferredFlagsBySubagentId.get(subagentId) ?? {\n resumable: null,\n blocking: null,\n }\n if (toolCall.name === \"subagent_create\" || toolCall.name === \"subagent_message\" || toolCall.name === \"send_to_agent\") {\n currentFlags.resumable = true\n }\n if (toolCall.name === \"subagent_create\") {\n const inferredBlocking = inferBlockingFromToolResult(entry, toolCall.tool_call_id)\n if (inferredBlocking !== null) {\n currentFlags.blocking = inferredBlocking\n }\n }\n inferredFlagsBySubagentId.set(subagentId, currentFlags)\n }\n\n if (pendingSubagentToolCalls.length > 0) {\n pendingSubagentToolCalls.forEach((toolCall, pendingIndex) => {\n const pendingStatus: \"pending\" | \"running\" =\n pendingIndex === 0 ? \"running\" : \"pending\"\n const block = createPendingSubagentBlock(\n entry,\n toolCall,\n pendingIndex,\n pendingStatus\n )\n pendingPlacements.push({\n block,\n startIndex: index,\n displayIndex: index,\n groupKey: `start:${index}`,\n })\n })\n }\n\n if (shouldSkipWorkblock(entry, resolvedFromWorkblock)) {\n skipWorkblockIndexes.add(index)\n }\n })\n\n const blocksBySubagentId = new Map<string, SubagentBlockMessage>()\n const signaledSubagentIds = new Set<string>()\n for (const message of messages) {\n const subagentId = extractSubagentId(message)\n if (!subagentId) {\n continue\n }\n if (isSubagentSignalMessage(message)) {\n signaledSubagentIds.add(subagentId)\n }\n }\n\n for (const message of messages) {\n const subagentId = extractSubagentId(message)\n if (!subagentId || !signaledSubagentIds.has(subagentId)) {\n continue\n }\n\n const existing = blocksBySubagentId.get(subagentId)\n if (!existing) {\n blocksBySubagentId.set(subagentId, createSubagentBlock(subagentId, message))\n } else {\n mergeSubagentBlock(existing, message)\n }\n }\n\n if (blocksBySubagentId.size === 0 && pendingPlacements.length === 0) {\n return baseMessages.map((entry) => {\n if (isStatusMessage(entry)) {\n return entry\n }\n if (isWorkblock(entry)) {\n return entry\n }\n const raw = entry as Message\n if (getSystemStatusKind(raw)) {\n return createSystemStatusMessage(raw)\n }\n return raw\n })\n }\n\n const placements: BlockPlacement[] = []\n const endAnchoredBlocks: SubagentBlockMessage[] = []\n\n for (const [subagentId, block] of blocksBySubagentId) {\n const inferredThreadName = threadNameBySubagentId.get(subagentId)\n if (!block.subagent_thread_name && inferredThreadName) {\n block.subagent_thread_name = inferredThreadName\n }\n const inferredFlags = inferredFlagsBySubagentId.get(subagentId)\n if (block.subagent_resumable === null && inferredFlags?.resumable !== null && inferredFlags?.resumable !== undefined) {\n block.subagent_resumable = inferredFlags.resumable\n }\n if (block.subagent_blocking === null && inferredFlags?.blocking !== null && inferredFlags?.blocking !== undefined) {\n block.subagent_blocking = inferredFlags.blocking\n }\n\n let startIndex = anchorIndexBySubagentId.get(subagentId)\n let displayIndex: number | undefined\n\n for (const childMessage of block.messages) {\n const messageIndex = indexByBaseEntryId.get(childMessage.id)\n if (messageIndex === undefined) {\n continue\n }\n if (displayIndex === undefined || messageIndex > displayIndex) {\n displayIndex = messageIndex\n }\n }\n\n if (startIndex === undefined && block.subagent_spawn_group_id) {\n startIndex = indexByBaseEntryId.get(block.subagent_spawn_group_id)\n }\n\n if (displayIndex === undefined) {\n if (startIndex !== undefined) {\n displayIndex = startIndex\n } else if (block.subagent_spawn_group_id) {\n displayIndex = indexByBaseEntryId.get(block.subagent_spawn_group_id)\n }\n }\n\n if (startIndex === undefined && displayIndex !== undefined) {\n startIndex = displayIndex\n }\n\n if (displayIndex === undefined) {\n endAnchoredBlocks.push(block)\n continue\n }\n\n const groupKey =\n block.subagent_spawn_group_id\n ? `spawn:${block.subagent_spawn_group_id}`\n : startIndex !== undefined\n ? `start:${startIndex}`\n : `subagent:${subagentId}`\n\n placements.push({\n block,\n startIndex,\n displayIndex,\n groupKey,\n })\n }\n\n for (const placement of pendingPlacements) {\n placements.push(placement)\n }\n\n const groupsByKey = new Map<string, BlockGroup>()\n for (const placement of placements) {\n const existing = groupsByKey.get(placement.groupKey)\n if (!existing) {\n groupsByKey.set(placement.groupKey, {\n groupKey: placement.groupKey,\n startIndex: placement.startIndex,\n displayIndex: placement.displayIndex,\n blocks: [placement.block],\n })\n continue\n }\n\n if (existing.startIndex === undefined) {\n existing.startIndex = placement.startIndex\n }\n if (placement.startIndex !== undefined && existing.startIndex !== undefined) {\n existing.startIndex = Math.min(existing.startIndex, placement.startIndex)\n }\n if (existing.displayIndex === undefined) {\n existing.displayIndex = placement.displayIndex\n }\n if (placement.displayIndex !== undefined && existing.displayIndex !== undefined) {\n existing.displayIndex = Math.max(existing.displayIndex, placement.displayIndex)\n }\n existing.blocks.push(placement.block)\n }\n\n const groupedByDisplayIndex = new Map<number, Array<SubagentBlockMessage | SubagentGroupBlockMessage>>()\n const startMarkersByIndex = new Map<number, StatusMessage[]>()\n const eventMarkersByIndex = new Map<number, StatusMessage[]>()\n\n for (const group of groupsByKey.values()) {\n const groupedBlock = buildGroupedBlock(group)\n if (group.displayIndex !== undefined) {\n const existing = groupedByDisplayIndex.get(group.displayIndex) ?? []\n existing.push(groupedBlock)\n groupedByDisplayIndex.set(group.displayIndex, existing)\n }\n\n const marker = createGroupStartMarker(group)\n if (marker && group.startIndex !== undefined) {\n const existing = startMarkersByIndex.get(group.startIndex) ?? []\n existing.push(marker)\n startMarkersByIndex.set(group.startIndex, existing)\n }\n }\n\n for (const rawMessage of messages) {\n const subagentId = extractSubagentId(rawMessage)\n if (!subagentId) {\n continue\n }\n const messageIndex = indexByBaseEntryId.get(rawMessage.id)\n if (messageIndex === undefined) {\n continue\n }\n const block = blocksBySubagentId.get(subagentId)\n const marker = createSubagentEventStatusMessage(rawMessage, block)\n if (!marker) {\n continue\n }\n const existing = eventMarkersByIndex.get(messageIndex) ?? []\n existing.push(marker)\n eventMarkersByIndex.set(messageIndex, existing)\n }\n\n for (const [displayIndex, items] of groupedByDisplayIndex) {\n items.sort((a, b) => a.created_at - b.created_at)\n groupedByDisplayIndex.set(displayIndex, items)\n }\n for (const [startIndex, markers] of startMarkersByIndex) {\n markers.sort((a, b) => a.created_at - b.created_at)\n startMarkersByIndex.set(startIndex, markers)\n }\n for (const [markerIndex, markers] of eventMarkersByIndex) {\n markers.sort((a, b) => a.created_at - b.created_at)\n eventMarkersByIndex.set(markerIndex, markers)\n }\n\n endAnchoredBlocks.sort((a, b) => a.created_at - b.created_at)\n\n const result: SubagentThreadMessage[] = []\n const insertedSubagentIds = new Set<string>()\n\n for (let i = 0; i < baseMessages.length; i++) {\n const startMarkers = startMarkersByIndex.get(i) ?? []\n for (const marker of startMarkers) {\n result.push(marker)\n }\n\n const eventMarkers = eventMarkersByIndex.get(i) ?? []\n for (const marker of eventMarkers) {\n result.push(marker)\n }\n\n const displayBlocks = groupedByDisplayIndex.get(i) ?? []\n for (const item of displayBlocks) {\n if ((item as SubagentGroupBlockMessage).type === \"subagent_group_block\") {\n const group = item as SubagentGroupBlockMessage\n for (const block of group.subagents) {\n insertedSubagentIds.add(block.subagent_id)\n }\n result.push(group)\n } else {\n const block = item as SubagentBlockMessage\n if (!insertedSubagentIds.has(block.subagent_id)) {\n result.push(block)\n insertedSubagentIds.add(block.subagent_id)\n }\n }\n }\n\n const entry = baseMessages[i]\n if (isStatusMessage(entry)) {\n result.push(entry)\n continue\n }\n\n if (isWorkblock(entry)) {\n if (skipWorkblockIndexes.has(i)) {\n continue\n }\n result.push(entry)\n continue\n }\n\n const rawEntry = entry as Message\n if (getSystemStatusKind(rawEntry)) {\n result.push(createSystemStatusMessage(rawEntry))\n continue\n }\n\n if (extractSubagentId(rawEntry)) {\n continue\n }\n result.push(rawEntry)\n }\n\n for (const block of endAnchoredBlocks) {\n if (!insertedSubagentIds.has(block.subagent_id)) {\n result.push(block)\n insertedSubagentIds.add(block.subagent_id)\n }\n }\n\n return result\n}\n"],"mappings":";AAcO,IAAM,qBAAN,MAAyB;AAAA,EACtB;AAAA,EACA;AAAA,EAER,YAAY,UAAkB;AAE5B,SAAK,WAAW,SAAS,QAAQ,OAAO,EAAE;AAG1C,SAAK,QAAQ,OAAO,iBAAiB,cACjC,aAAa,QAAQ,yBAAyB,IAC9C;AAAA,EACN;AAAA;AAAA;AAAA;AAAA,EAKA,cAAsB;AACpB,WAAO,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,aAAa,SAA+C;AAChE,UAAM,WAAW,MAAM,MAAM,GAAG,KAAK,QAAQ,YAAY;AAAA,MACvD,QAAQ;AAAA,MACR,SAAS;AAAA,QACP,GAAG,KAAK,WAAW;AAAA,QACnB,gBAAgB;AAAA,MAClB;AAAA,MACA,MAAM,KAAK,UAAU,OAAO;AAAA,IAC9B,CAAC;AAED,QAAI,CAAC,SAAS,IAAI;AAChB,YAAM,IAAI,MAAM,4BAA4B,SAAS,UAAU,EAAE;AAAA,IACnE;AAEA,WAAO,SAAS,KAAK;AAAA,EACvB;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,UAAU,IAA6B;AAC3C,UAAM,WAAW,MAAM,MAAM,GAAG,KAAK,QAAQ,YAAY,EAAE,IAAI;AAAA,MAC7D,QAAQ;AAAA,MACR,SAAS,KAAK,WAAW;AAAA,IAC3B,CAAC;AAED,QAAI,CAAC,SAAS,IAAI;AAChB,YAAM,IAAI,MAAM,yBAAyB,SAAS,UAAU,EAAE;AAAA,IAChE;AAEA,WAAO,SAAS,KAAK;AAAA,EACvB;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,YACJ,IACA,UAA8B,CAAC,GACX;AACpB,UAAM,SAAS,IAAI,gBAAgB;AAEnC,QAAI,QAAQ,UAAU,OAAW,QAAO,IAAI,SAAS,OAAO,QAAQ,KAAK,CAAC;AAC1E,QAAI,QAAQ,WAAW,OAAW,QAAO,IAAI,UAAU,OAAO,QAAQ,MAAM,CAAC;AAC7E,QAAI,QAAQ,UAAU,OAAW,QAAO,IAAI,SAAS,OAAO,QAAQ,KAAK,CAAC;AAC1E,QAAI,QAAQ,kBAAkB,OAAW,QAAO,IAAI,iBAAiB,OAAO,QAAQ,aAAa,CAAC;AAElG,UAAM,cAAc,OAAO,SAAS;AACpC,UAAM,MAAM,GAAG,KAAK,QAAQ,YAAY,EAAE,YAAY,cAAc,IAAI,WAAW,KAAK,EAAE;AAE1F,UAAM,WAAW,MAAM,MAAM,KAAK;AAAA,MAChC,QAAQ;AAAA,MACR,SAAS,KAAK,WAAW;AAAA,IAC3B,CAAC;AAED,QAAI,CAAC,SAAS,IAAI;AAChB,YAAM,IAAI,MAAM,2BAA2B,SAAS,UAAU,EAAE;AAAA,IAClE;AAEA,UAAM,OAAO,MAAM,SAAS,KAAK;AACjC,WAAO,KAAK,YAAY,CAAC;AAAA,EAC3B;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,YACJ,IACA,SACkB;AAClB,UAAM,WAAW,MAAM,MAAM,GAAG,KAAK,QAAQ,YAAY,EAAE,aAAa;AAAA,MACtE,QAAQ;AAAA,MACR,SAAS;AAAA,QACP,GAAG,KAAK,WAAW;AAAA,QACnB,gBAAgB;AAAA,MAClB;AAAA,MACA,MAAM,KAAK,UAAU,OAAO;AAAA,IAC9B,CAAC;AAED,QAAI,CAAC,SAAS,IAAI;AAChB,YAAM,IAAI,MAAM,2BAA2B,SAAS,UAAU,EAAE;AAAA,IAClE;AAEA,WAAO,SAAS,KAAK;AAAA,EACvB;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,cAAc,IAA2B;AAC7C,UAAM,WAAW,MAAM,MAAM,GAAG,KAAK,QAAQ,YAAY,EAAE,SAAS;AAAA,MAClE,QAAQ;AAAA,MACR,SAAS,KAAK,WAAW;AAAA,IAC3B,CAAC;AAED,QAAI,CAAC,SAAS,IAAI;AAChB,YAAM,IAAI,MAAM,6BAA6B,SAAS,UAAU,EAAE;AAAA,IACpE;AAEA,UAAM,SAAS,KAAK;AAAA,EACtB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,cACJ,UACA,WAC+B;AAC/B,UAAM,WAAW,MAAM;AAAA,MACrB,GAAG,KAAK,QAAQ,YAAY,QAAQ,aAAa,SAAS;AAAA,MAC1D;AAAA,QACE,QAAQ;AAAA,QACR,SAAS,KAAK,WAAW;AAAA,MAC3B;AAAA,IACF;AAEA,QAAI,CAAC,SAAS,IAAI;AAChB,YAAM,IAAI,MAAM,6BAA6B,SAAS,UAAU,EAAE;AAAA,IACpE;AAEA,WAAO,SAAS,KAAK;AAAA,EACvB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAeA,MAAM,WACJ,UACA,MACA,SAKwB;AACxB,UAAM,kBAAkB,mBAAmB,KAAK,IAAI;AACpD,UAAM,MAAM,GAAG,KAAK,QAAQ,YAAY,QAAQ,OAAO,eAAe;AAGtE,QAAI,SAAS,WAAW;AACtB,YAAM,aAAa,MAAM,KAAK,aAAa,IAAI;AAE/C,YAAMA,YAAW,MAAM,MAAM,KAAK;AAAA,QAChC,QAAQ;AAAA,QACR,SAAS;AAAA,UACP,GAAG,KAAK,WAAW;AAAA,UACnB,gBAAgB;AAAA,QAClB;AAAA,QACA,MAAM,KAAK,UAAU;AAAA,UACnB,MAAM;AAAA,UACN,UAAU,KAAK;AAAA,UACf,WAAW,QAAQ;AAAA,UACnB,UAAU;AAAA,YACR,OAAO,QAAQ;AAAA,YACf,QAAQ,QAAQ;AAAA,UAClB;AAAA,QACF,CAAC;AAAA,MACH,CAAC;AAED,UAAI,CAACA,UAAS,IAAI;AAChB,cAAM,IAAI,MAAM,0BAA0BA,UAAS,UAAU,EAAE;AAAA,MACjE;AAEA,aAAOA,UAAS,KAAK;AAAA,IACvB;AAGA,UAAM,WAAW,MAAM,MAAM,KAAK;AAAA,MAChC,QAAQ;AAAA,MACR,SAAS;AAAA,QACP,GAAG,KAAK,WAAW;AAAA,QACnB,gBAAgB,KAAK;AAAA,MACvB;AAAA,MACA,MAAM;AAAA,IACR,CAAC;AAED,QAAI,CAAC,SAAS,IAAI;AAChB,YAAM,IAAI,MAAM,0BAA0B,SAAS,UAAU,EAAE;AAAA,IACjE;AAEA,WAAO,SAAS,KAAK;AAAA,EACvB;AAAA;AAAA;AAAA;AAAA,EAKQ,aAAa,MAA6B;AAChD,WAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,YAAM,SAAS,IAAI,WAAW;AAC9B,aAAO,SAAS,MAAM;AACpB,cAAM,SAAS,OAAO;AAEtB,cAAM,SAAS,OAAO,MAAM,GAAG,EAAE,CAAC;AAClC,gBAAQ,MAAM;AAAA,MAChB;AACA,aAAO,UAAU,MAAM,OAAO,IAAI,MAAM,qBAAqB,CAAC;AAC9D,aAAO,cAAc,IAAI;AAAA,IAC3B,CAAC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA,EAKA,WAAW,UAAkB,MAAsB;AAEjD,UAAM,iBAAiB,KAAK,WAAW,GAAG,IAAI,KAAK,MAAM,CAAC,IAAI;AAC9D,UAAM,cAAc,eACjB,MAAM,GAAG,EACT,IAAI,aAAW,mBAAmB,OAAO,CAAC,EAC1C,KAAK,GAAG;AAEX,WAAO,GAAG,KAAK,QAAQ,YAAY,QAAQ,OAAO,WAAW;AAAA,EAC/D;AAAA;AAAA;AAAA;AAAA,EAKA,gBAAgB,UAAkB,MAAsB;AACtD,WAAO,GAAG,KAAK,WAAW,UAAU,IAAI,CAAC;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,UAAU,UAQZ;AAEF,UAAM,WAAW,MAAM;AAAA,MACrB,GAAG,KAAK,QAAQ,YAAY,QAAQ;AAAA,MACpC;AAAA,QACE,QAAQ;AAAA,QACR,SAAS,KAAK,WAAW;AAAA,MAC3B;AAAA,IACF;AAEA,QAAI,CAAC,SAAS,IAAI;AAChB,YAAM,IAAI,MAAM,yBAAyB,SAAS,UAAU,EAAE;AAAA,IAChE;AAEA,UAAM,OAAO,MAAM,SAAS,KAAK;AACjC,WAAO,KAAK,SAAS,CAAC;AAAA,EACxB;AAAA;AAAA;AAAA;AAAA,EAKA,wBACE,IACA,YAAuC,CAAC,GACxC,UAAuD,CAAC,GAC7C;AACX,UAAM,SAAS,IAAI,gBAAgB;AAEnC,QAAI,KAAK,MAAO,QAAO,IAAI,SAAS,KAAK,KAAK;AAC9C,QAAI,QAAQ,kBAAkB,OAAW,QAAO,IAAI,iBAAiB,OAAO,QAAQ,aAAa,CAAC;AAClG,QAAI,QAAQ,UAAU,OAAW,QAAO,IAAI,SAAS,OAAO,QAAQ,KAAK,CAAC;AAE1E,UAAM,aAAa,KAAK,SAAS,WAAW,OAAO,IAAI,QAAQ;AAC/D,UAAM,aAAa,KAAK,SAAS,QAAQ,WAAW,UAAU;AAC9D,UAAM,MAAM,GAAG,UAAU,YAAY,EAAE,WAAW,OAAO,SAAS,CAAC;AAEnE,UAAM,KAAK,IAAI,UAAU,GAAG;AAE5B,OAAG,SAAS,MAAM;AAChB,gBAAU,SAAS;AAAA,IACrB;AAEA,OAAG,YAAY,CAAC,UAAU;AACxB,UAAI;AAEF,YAAI,OAAO,MAAM,SAAS,YAAY,MAAM,SAAS,QAAQ;AAC3D;AAAA,QACF;AAEA,cAAM,OAAO,KAAK,MAAM,MAAM,IAAI;AAElC,gBAAQ,KAAK,MAAM;AAAA,UACjB,KAAK;AACH,sBAAU,YAAY,IAAI;AAC1B;AAAA,UACF,KAAK;AACH,sBAAU,UAAU,IAAI;AACxB;AAAA,UACF,KAAK;AACH,sBAAU,UAAU,IAAmB;AACvC;AAAA,UACF,KAAK;AACH,sBAAU,UAAU,IAAI;AACxB;AAAA,QACJ;AAAA,MACF,SAAS,OAAO;AACd,gBAAQ,MAAM,sCAAsC,KAAK;AAAA,MAC3D;AAAA,IACF;AAEA,OAAG,UAAU,CAAC,UAAU;AACtB,cAAQ,MAAM,oBAAoB,KAAK;AACvC,gBAAU,UAAU,EAAE,MAAM,SAAS,OAAO,6BAA6B,CAAC;AAAA,IAC5E;AAEA,OAAG,UAAU,CAAC,UAAU;AACtB,cAAQ,IAAI,yDAAyD,MAAM,IAAI,aAAa,MAAM,UAAU,MAAM,eAAe,MAAM,QAAQ,EAAE;AACjJ,gBAAU,UAAU;AAAA,IACtB;AAEA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,oBACE,IACA,YAAmC,CAAC,GACzB;AACX,UAAM,SAAS,IAAI,gBAAgB;AAEnC,QAAI,KAAK,MAAO,QAAO,IAAI,SAAS,KAAK,KAAK;AAE9C,UAAM,aAAa,KAAK,SAAS,WAAW,OAAO,IAAI,QAAQ;AAC/D,UAAM,aAAa,KAAK,SAAS,QAAQ,WAAW,UAAU;AAC9D,UAAM,MAAM,GAAG,UAAU,YAAY,EAAE,IAAI,OAAO,SAAS,CAAC;AAE5D,UAAM,KAAK,IAAI,UAAU,GAAG;AAE5B,OAAG,SAAS,MAAM;AAChB,gBAAU,SAAS;AAAA,IACrB;AAEA,OAAG,YAAY,CAAC,UAAU;AACxB,UAAI;AAEF,YAAI,OAAO,MAAM,SAAS,YAAY,MAAM,SAAS,QAAQ;AAC3D;AAAA,QACF;AAEA,cAAM,OAAO,KAAK,MAAM,MAAM,IAAI;AAElC,gBAAQ,KAAK,MAAM;AAAA,UACjB,KAAK;AACH,sBAAU,QAAQ,IAAI;AACtB;AAAA,UACF,KAAK;AACH,sBAAU,WAAW,IAAI;AACzB;AAAA,UACF,KAAK;AACH,sBAAU,YAAY,IAAI;AAC1B;AAAA,QACJ;AAAA,MACF,SAAS,OAAO;AACd,gBAAQ,MAAM,sCAAsC,KAAK;AAAA,MAC3D;AAAA,IACF;AAEA,OAAG,UAAU,CAAC,UAAU;AACtB,cAAQ,MAAM,oBAAoB,KAAK;AAAA,IACzC;AAEA,OAAG,UAAU,MAAM;AACjB,gBAAU,UAAU;AAAA,IACtB;AAEA,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKQ,aAAqC;AAC3C,UAAM,UAAkC,CAAC;AAEzC,QAAI,KAAK,OAAO;AACd,cAAQ,eAAe,IAAI,UAAU,KAAK,KAAK;AAAA,IACjD;AAEA,WAAO;AAAA,EACT;AACF;;;AC7YO,IAAM,0BAAN,MAA8B;AAAA,EAC3B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAEA,KAAuB;AAAA,EACvB,SAA2B;AAAA,EAC3B,oBAA4B;AAAA,EAC5B,mBAAyD;AAAA,EACzD,oBAA2D;AAAA,EAC3D,iBAA0B;AAAA,EAC1B,kBAA2B;AAAA,EAEnC,YACE,QACA,UACA,YAAuC,CAAC,GACxC,UAAmC,CAAC,GACpC;AACA,SAAK,SAAS;AACd,SAAK,WAAW;AAChB,SAAK,YAAY;AACjB,SAAK,UAAU;AAAA,MACb,OAAO,QAAQ,SAAS;AAAA,MACxB,eAAe,QAAQ,iBAAiB;AAAA,MACxC,mBAAmB,QAAQ,qBAAqB;AAAA,MAChD,mBAAmB,QAAQ,qBAAqB;AAAA,IAClD;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,YAA8B;AAC5B,WAAO,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA,EAKA,cAAsB;AACpB,WAAO,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA,EAKA,UAAgB;AACd,QAAI,KAAK,MAAM,KAAK,GAAG,eAAe,UAAU,QAAQ;AAEtD;AAAA,IACF;AAEA,SAAK,kBAAkB;AACvB,SAAK,iBAAiB;AACtB,SAAK,UAAU,YAAY;AAE3B,SAAK,KAAK,KAAK,OAAO;AAAA,MACpB,KAAK;AAAA,MACL;AAAA,QACE,QAAQ,MAAM;AACZ,eAAK,UAAU,WAAW;AAC1B,eAAK,oBAAoB;AACzB,eAAK,iBAAiB;AACtB,eAAK,eAAe;AAAA,QACtB;AAAA,QACA,WAAW,CAAC,UAA4B;AACtC,eAAK,UAAU,YAAY,KAAK;AAAA,QAClC;AAAA,QACA,SAAS,CAAC,UAA6B;AACrC,eAAK,UAAU,UAAU,KAAK;AAAA,QAChC;AAAA,QACA,SAAS,CAAC,UAAuB;AAC/B,eAAK,UAAU,UAAU,KAAK;AAAA,QAChC;AAAA,QACA,SAAS,CAAC,UAAsB;AAC9B,eAAK,UAAU,UAAU,KAAK;AAAA,QAChC;AAAA,QACA,SAAS,MAAM;AACb,eAAK,YAAY;AACjB,eAAK,kBAAkB;AAAA,QACzB;AAAA,MACF;AAAA,MACA;AAAA,QACE,OAAO,KAAK,QAAQ;AAAA,QACpB,eAAe,KAAK,QAAQ;AAAA,MAC9B;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,aAAmB;AACjB,SAAK,kBAAkB;AACvB,SAAK,YAAY;AAEjB,QAAI,KAAK,IAAI;AACX,WAAK,GAAG,MAAM;AACd,WAAK,KAAK;AAAA,IACZ;AAEA,SAAK,oBAAoB;AACzB,SAAK,iBAAiB;AACtB,SAAK,UAAU,cAAc;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA,EAKA,gBAAgB,WAAqD;AACnE,SAAK,YAAY,EAAE,GAAG,KAAK,WAAW,GAAG,UAAU;AAAA,EACrD;AAAA;AAAA;AAAA;AAAA,EAKA,cAAc,SAAiD;AAC7D,SAAK,UAAU,EAAE,GAAG,KAAK,SAAS,GAAG,QAAQ;AAAA,EAC/C;AAAA,EAEQ,UAAU,QAAgC;AAChD,QAAI,KAAK,WAAW,QAAQ;AAC1B,WAAK,SAAS;AACd,WAAK,UAAU,iBAAiB,MAAM;AAAA,IACxC;AAAA,EACF;AAAA,EAEQ,iBAAuB;AAC7B,SAAK,eAAe;AAEpB,SAAK,oBAAoB,YAAY,MAAM;AACzC,UAAI,KAAK,MAAM,KAAK,GAAG,eAAe,UAAU,MAAM;AACpD,aAAK,GAAG,KAAK,MAAM;AAAA,MACrB;AAAA,IACF,GAAG,KAAK,QAAQ,iBAAiB;AAAA,EACnC;AAAA,EAEQ,iBAAuB;AAC7B,QAAI,KAAK,mBAAmB;AAC1B,oBAAc,KAAK,iBAAiB;AACpC,WAAK,oBAAoB;AAAA,IAC3B;AAAA,EACF;AAAA,EAEQ,wBAA8B;AACpC,QAAI,KAAK,kBAAkB;AACzB,mBAAa,KAAK,gBAAgB;AAClC,WAAK,mBAAmB;AAAA,IAC1B;AAAA,EACF;AAAA,EAEQ,cAAoB;AAC1B,SAAK,eAAe;AACpB,SAAK,sBAAsB;AAAA,EAC7B;AAAA,EAEQ,oBAA0B;AAChC,QAAI,CAAC,KAAK,mBAAmB,KAAK,gBAAgB;AAChD,WAAK,UAAU,cAAc;AAC7B;AAAA,IACF;AAEA,SAAK,iBAAiB;AACtB,SAAK,UAAU,cAAc;AAG7B,UAAM,QAAQ,KAAK;AAAA,MACjB,MAAO,KAAK,IAAI,GAAG,KAAK,iBAAiB;AAAA,MACzC,KAAK,QAAQ;AAAA,IACf;AACA,SAAK;AAEL,SAAK,mBAAmB,WAAW,MAAM;AACvC,UAAI,KAAK,iBAAiB;AACxB,aAAK,QAAQ;AAAA,MACf;AAAA,IACF,GAAG,KAAK;AAAA,EACV;AACF;;;ACtNO,SAAS,iBAAiB,SAAmC;AAClE,MAAI,CAAC,QAAQ,aAAa;AACxB,WAAO,CAAC;AAAA,EACV;AAGA,MAAI,MAAM,QAAQ,QAAQ,WAAW,GAAG;AACtC,WAAO,QAAQ;AAAA,EACjB;AAGA,MAAI;AACF,UAAM,SAAS,KAAK,MAAM,QAAQ,WAAW;AAC7C,QAAI,CAAC,MAAM,QAAQ,MAAM,GAAG;AAC1B,aAAO,CAAC;AAAA,IACV;AACA,WAAO;AAAA,EACT,QAAQ;AACN,WAAO,CAAC;AAAA,EACV;AACF;AAKO,SAAS,gBAAgB,UAA2B;AACzD,SAAO,SAAS,YAAY,EAAE,WAAW,QAAQ;AACnD;AAMO,SAAS,gBAAgB,UAAmC;AACjE,QAAM,QAAsB,CAAC;AAE7B,aAAW,WAAW,UAAU;AAC9B,UAAM,cAAc,iBAAiB,OAAO;AAE5C,eAAW,cAAc,aAAa;AACpC,YAAM,KAAK;AAAA,QACT,IAAI,WAAW;AAAA,QACf,MAAM,WAAW;AAAA,QACjB,UAAU,WAAW;AAAA,QACrB,MAAM,WAAW;AAAA,QACjB,SAAS,gBAAgB,WAAW,QAAQ;AAAA,QAC5C,iBAAiB;AAAA;AAAA,QACjB,QAAQ;AAAA,QACR,MAAM,WAAW;AAAA,QACjB,OAAO,WAAW;AAAA,QAClB,QAAQ,WAAW;AAAA,QACnB,WAAW,QAAQ;AAAA,MACrB,CAAC;AAAA,IACH;AAAA,EACF;AAEA,SAAO;AACT;;;AC3DA,IAAM,iBAAiB;AAiBvB,SAAS,UAAU,MAAuC;AACxD,SAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,UAAM,MAAM,IAAI,MAAM;AACtB,UAAM,YAAY,IAAI,gBAAgB,IAAI;AAE1C,QAAI,SAAS,MAAM;AACjB,UAAI,gBAAgB,SAAS;AAC7B,cAAQ,GAAG;AAAA,IACb;AACA,QAAI,UAAU,MAAM;AAClB,UAAI,gBAAgB,SAAS;AAC7B,aAAO,IAAI,MAAM,sBAAsB,CAAC;AAAA,IAC1C;AACA,QAAI,MAAM;AAAA,EACZ,CAAC;AACH;AAMA,SAAS,yBAAyB,KAA+B;AAC/D,QAAM,EAAE,OAAO,OAAO,IAAI;AAC1B,QAAM,cAAc,QAAQ;AAE5B,MAAI;AACJ,MAAI;AAEJ,MAAI,cAAc,GAAG;AACnB,iBAAa,KAAK,IAAI,gBAAgB,KAAK;AAC3C,kBAAc,KAAK,MAAM,aAAa,WAAW;AAAA,EACnD,OAAO;AACL,kBAAc,KAAK,IAAI,gBAAgB,MAAM;AAC7C,iBAAa,KAAK,MAAM,cAAc,WAAW;AAAA,EACnD;AAEA,QAAM,SAAS,SAAS,cAAc,QAAQ;AAC9C,SAAO,QAAQ;AACf,SAAO,SAAS;AAEhB,QAAM,MAAM,OAAO,WAAW,IAAI;AAClC,MAAI,CAAC,KAAK;AACR,UAAM,IAAI,MAAM,8BAA8B;AAAA,EAChD;AAEA,MAAI,UAAU,KAAK,GAAG,GAAG,YAAY,WAAW;AAGhD,QAAM,UAAU,OAAO,UAAU,cAAc,GAAG;AAClD,SAAO,QAAQ,MAAM,GAAG,EAAE,CAAC;AAC7B;AAOA,eAAsB,uBAAuB,MAA4C;AACvF,QAAM,MAAM,MAAM,UAAU,IAAI;AAEhC,SAAO;AAAA,IACL,WAAW,yBAAyB,GAAG;AAAA,IACvC,OAAO,IAAI;AAAA,IACX,QAAQ,IAAI;AAAA,EACd;AACF;AAKO,SAAS,wBAAiC;AAC/C,SAAO,OAAO,aAAa,eAAe,OAAO,SAAS,kBAAkB;AAC9E;;;ACtFO,SAAS,wBAAgC;AAC9C,SAAO,WAAW,KAAK,IAAI,CAAC,IAAI,KAAK,OAAO,EAAE,SAAS,EAAE,EAAE,OAAO,GAAG,CAAC,CAAC;AACzE;AAMO,SAAS,kBAAkB,MAA6B;AAC7D,SAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC,UAAM,SAAS,IAAI,WAAW;AAC9B,WAAO,SAAS,MAAM,QAAQ,OAAO,MAAgB;AACrD,WAAO,UAAU;AACjB,WAAO,cAAc,IAAI;AAAA,EAC3B,CAAC;AACH;;;AC+BO,IAAM,oBAAN,MAAwB;AAAA;AAAA;AAAA;AAAA;AAAA,EAK7B,kBAAkB,MAAwB;AACxC,WAAO;AAAA,MACL,IAAI,sBAAsB;AAAA,MAC1B,MAAM,KAAK;AAAA,MACX,UAAU,KAAK;AAAA,MACf,MAAM,KAAK;AAAA,MACX,SAAS,gBAAgB,KAAK,IAAI;AAAA,MAClC,iBAAiB;AAAA,MACjB,QAAQ;AAAA,IACV;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,WAAW,OAAsE;AAC/E,WAAO,MAAM,KAAK,KAAK,EAAE,IAAI,WAAS;AAAA,MACpC,SAAS,KAAK,kBAAkB,IAAI;AAAA,MACpC;AAAA,IACF,EAAE;AAAA,EACJ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAkBA,MAAM,cACJ,UACA,MACA,WACA,QACA,UACA,UAAyB,CAAC,GACF;AACxB,UAAM;AAAA,MACJ,oBAAoB;AAAA,MACpB,kBAAkB;AAAA,IACpB,IAAI;AAEJ,UAAM,UAAU,gBAAgB,KAAK,IAAI;AAGzC,QAAI,WAAW,iBAAiB;AAC9B,wBAAkB,IAAI,EACnB,KAAK,aAAW,SAAS,EAAE,iBAAiB,QAAQ,CAAC,CAAC,EACtD,MAAM,SAAO,QAAQ,MAAM,+BAA+B,GAAG,CAAC;AAAA,IACnE;AAEA,QAAI;AAEF,UAAI;AAEJ,UAAI,WAAW,mBAAmB;AAChC,YAAI;AACF,gBAAM,SAAS,MAAM,uBAAuB,IAAI;AAChD,0BAAgB;AAAA,YACd,WAAW,OAAO;AAAA,YAClB,OAAO,OAAO;AAAA,YACd,QAAQ,OAAO;AAAA,UACjB;AAAA,QACF,SAAS,KAAK;AAEZ,kBAAQ,KAAK,iCAAiC,GAAG;AAAA,QACnD;AAAA,MACF;AAGA,YAAM,aAAa,MAAM,OAAO,WAAW,UAAU,MAAM,aAAa;AAGxE,eAAS;AAAA,QACP,IAAI,WAAW;AAAA,QACf,QAAQ;AAAA,QACR,MAAM,WAAW;AAAA,QACjB,OAAO,WAAW;AAAA,QAClB,QAAQ,WAAW;AAAA,MACrB,CAAC;AAED,aAAO;AAAA,IACT,SAAS,KAAK;AAEZ,eAAS;AAAA,QACP,QAAQ;AAAA,QACR,OAAO,eAAe,QAAQ,IAAI,UAAU;AAAA,MAC9C,CAAC;AACD,YAAM;AAAA,IACR;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAYA,MAAM,eACJ,UACA,OACA,QACA,UACA,UAAyB,CAAC,GACa;AACvC,UAAM,WAAW,MAAM;AAAA,MAAI,CAAC,EAAE,SAAS,KAAK,MAC1C,KAAK;AAAA,QACH;AAAA,QACA;AAAA,QACA,QAAQ;AAAA,QACR;AAAA,QACA,CAAC,YAAY,SAAS,QAAQ,IAAI,OAAO;AAAA,QACzC;AAAA,MACF,EAAE,MAAM,SAAO,eAAe,QAAQ,MAAM,IAAI,MAAM,OAAO,GAAG,CAAC,CAAC;AAAA,IACpE;AAEA,WAAO,QAAQ,IAAI,QAAQ;AAAA,EAC7B;AACF;;;ACpLO,SAAS,sBAAsB,UAAsC;AAC1E,MAAI,SAAS,WAAW,GAAG;AACzB,WAAO,CAAC;AAAA,EACV;AAEA,QAAM,SAA0B,CAAC;AACjC,MAAI,IAAI;AAER,SAAO,IAAI,SAAS,QAAQ;AAC1B,UAAM,UAAU,SAAS,CAAC;AAG1B,QAAI,QAAQ,SAAS,eAAe,QAAQ,YAAY;AAEtD,UAAI;AACJ,UAAI;AACF,oBAAY,KAAK,MAAM,QAAQ,UAAU;AAAA,MAC3C,SAAS,OAAO;AAEd,eAAO,KAAK,OAAO;AACnB;AACA;AAAA,MACF;AAGA,YAAM,YAAwB,CAAC;AAC/B,YAAM,eAAyB,CAAC;AAChC,UAAI,mBAAkC,QAAQ,qBAAqB;AACnE,UAAI,kBAAsD;AAC1D,YAAM,iBAAiB,QAAQ;AAC/B,YAAM,iBAAiB,QAAQ;AAC/B,YAAM,QAAQ,QAAQ;AAGtB,UAAI,QAAQ,WAAW,WAAW;AAChC,0BAAkB;AAAA,MACpB,WAAW,QAAQ,WAAW,UAAU;AACtC,0BAAkB;AAAA,MACpB;AAGA,UAAI,QAAQ,SAAS;AACnB,qBAAa,KAAK,QAAQ,OAAO;AAAA,MACnC;AAGA,iBAAW,YAAY,WAAW;AAChC,kBAAU,KAAK;AAAA,UACb,IAAI,SAAS,MAAM,QAAQ;AAAA,UAC3B,MAAM;AAAA,UACN,MAAM,SAAS,UAAU;AAAA,UACzB,SAAS,SAAS,UAAU,aAAa;AAAA,UACzC,QAAQ;AAAA;AAAA,UACR,cAAc,SAAS;AAAA,QACzB,CAAC;AAAA,MACH;AAGA,UAAI,IAAI,IAAI;AACZ,aAAO,IAAI,SAAS,QAAQ;AAC1B,cAAM,cAAc,SAAS,CAAC;AAE9B,YAAI,YAAY,SAAS,QAAQ;AAE/B,gBAAM,eAAe,YAAY,eAAe;AAEhD,oBAAU,KAAK;AAAA,YACb,IAAI,YAAY;AAAA,YAChB,MAAM;AAAA,YACN,MAAM,YAAY,QAAQ;AAAA,YAC1B,SAAS,YAAY;AAAA,YACrB,QAAQ;AAAA,YACR,cAAc,YAAY,gBAAgB;AAAA,UAC5C,CAAC;AAED;AAAA,QACF,WAAW,YAAY,SAAS,eAAe,YAAY,YAAY;AAErE,cAAI;AACJ,cAAI;AACF,4BAAgB,KAAK,MAAM,YAAY,UAAU;AAAA,UACnD,SAAS,OAAO;AAEd;AAAA,UACF;AAGA,cAAI,YAAY,WAAW,WAAW;AACpC,8BAAkB;AAAA,UACpB,WAAW,YAAY,WAAW,YAAY,oBAAoB,WAAW;AAC3E,8BAAkB;AAAA,UACpB;AAGA,cAAI,YAAY,SAAS;AACvB,yBAAa,KAAK,YAAY,OAAO;AAAA,UACvC;AAGA,cAAI,CAAC,oBAAoB,YAAY,mBAAmB;AACtD,+BAAmB,YAAY;AAAA,UACjC;AAGA,qBAAW,YAAY,eAAe;AACpC,sBAAU,KAAK;AAAA,cACb,IAAI,SAAS,MAAM,YAAY;AAAA,cAC/B,MAAM;AAAA,cACN,MAAM,SAAS,UAAU;AAAA,cACzB,SAAS,SAAS,UAAU,aAAa;AAAA,cACzC,QAAQ;AAAA,cACR,cAAc,SAAS;AAAA,YACzB,CAAC;AAAA,UACH;AACA;AAAA,QACF,OAAO;AAEL;AAAA,QACF;AAAA,MACF;AAGA,YAAM,cAAc,IAAI,IAAI,UAAU,OAAO,OAAK,EAAE,SAAS,WAAW,EAAE,IAAI,OAAK,EAAE,YAAY,CAAC;AAClG,YAAM,kBAAkB,UAAU;AAAA,QAChC,OAAK,EAAE,SAAS,iBAAiB,EAAE,gBAAgB,CAAC,YAAY,IAAI,EAAE,YAAY;AAAA,MACpF;AAGA,iBAAW,UAAU,iBAAiB;AAEpC,cAAM,cAAc,UAAU,QAAQ,MAAM;AAE5C,cAAM,WAAW,OAAO,SAAS,MAAM,uBAAuB,IAAI,CAAC,KAAK;AAGxE,cAAM,gBAA0B;AAAA,UAC9B,IAAI,aAAa,OAAO,YAAY;AAAA,UACpC,MAAM;AAAA,UACN,MAAM;AAAA,UACN,SAAS;AAAA,UACT,QAAQ,OAAO;AAAA,UACf,cAAc,OAAO;AAAA,QACvB;AACA,kBAAU,OAAO,aAAa,GAAG,aAAa;AAAA,MAChD;AAGA,iBAAW,QAAQ,WAAW;AAC5B,YAAI,KAAK,SAAS,eAAe,KAAK,gBAAgB,KAAK,WAAW,MAAM;AAE1E,gBAAM,iBAAiB,UAAU;AAAA,YAC/B,QAAM,GAAG,SAAS,iBAAiB,GAAG,iBAAiB,KAAK;AAAA,UAC9D;AACA,cAAI,gBAAgB;AAElB,iBAAK,SAAS,eAAe;AAAA,UAC/B,OAAO;AAEL,iBAAK,SAAS;AAAA,UAChB;AAAA,QACF;AAAA,MACF;AAGA,YAAM,kBAAkB,aAAa,SAAS,IAAI,aAAa,KAAK,EAAE,IAAI;AAG1E,YAAM,YAAyB;AAAA,QAC7B,IAAI;AAAA,QACJ,MAAM;AAAA,QACN,SAAS;AAAA,QACT,mBAAmB;AAAA,QACnB;AAAA,QACA,QAAQ;AAAA,QACR,YAAY;AAAA,QACZ;AAAA,MACF;AAEA,aAAO,KAAK,SAAS;AAGrB,UAAI;AAAA,IACN,OAAO;AAEL,aAAO,KAAK,OAAO;AACnB;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AACT;;;AC5LA,IAAM,iBAAiB,oBAAI,IAAI,CAAC,mBAAmB,oBAAoB,eAAe,CAAC;AACvF,IAAM,wBAAwB;AAE9B,SAAS,YAAY,SAAwD;AAC3E,SAAQ,QAAwB,SAAS;AAC3C;AAEA,SAAS,gBAAgB,SAA0D;AACjF,SAAQ,QAA0B,SAAS;AAC7C;AAEA,SAAS,iBAAiB,OAA+B;AACvD,MAAI,OAAO,UAAU,UAAU;AAC7B,WAAO;AAAA,EACT;AACA,QAAM,aAAa,MAAM,KAAK;AAC9B,SAAO,WAAW,SAAS,IAAI,aAAa;AAC9C;AAEA,SAAS,kBACP,SACA,KACe;AACf,MAAI,CAAC,QAAQ,YAAY,OAAO,QAAQ,aAAa,UAAU;AAC7D,WAAO;AAAA,EACT;AACA,SAAO,iBAAkB,QAAQ,SAAqC,GAAG,CAAC;AAC5E;AAEA,SAAS,6BAA6B,SAAmD;AACvF,MAAI,CAAC,SAAS;AACZ,WAAO;AAAA,EACT;AACA,QAAM,iBAAiB,QAAQ,MAAM,iCAAiC;AACtE,MAAI,iBAAiB,CAAC,GAAG;AACvB,WAAO,eAAe,CAAC,EAAE,YAAY;AAAA,EACvC;AACA,QAAM,sBAAsB,QAAQ,MAAM,kCAAkC;AAC5E,MAAI,sBAAsB,CAAC,GAAG;AAC5B,WAAO,oBAAoB,CAAC,EAAE,YAAY;AAAA,EAC5C;AACA,SAAO;AACT;AAEA,SAAS,oBAAoB,SAAiC;AAC5D,QAAM,WAAW,iBAAiB,QAAQ,eAAe;AACzD,MAAI,UAAU;AACZ,WAAO;AAAA,EACT;AACA,QAAM,UAAU,QAAQ,WAAW;AACnC,MAAI,8BAA8B,KAAK,OAAO,KAAK,4BAA4B,KAAK,OAAO,GAAG;AAC5F,WAAO;AAAA,EACT;AACA,MAAI,qCAAqC,KAAK,OAAO,GAAG;AACtD,WAAO;AAAA,EACT;AACA,MAAI,0BAA0B,KAAK,OAAO,KAAK,uCAAuC,KAAK,OAAO,GAAG;AACnG,WAAO;AAAA,EACT;AACA,SAAO;AACT;AAEA,SAAS,oBAAoB,SAAuD;AAClF,MAAI,QAAQ,SAAS,UAAU;AAC7B,WAAO;AAAA,EACT;AACA,QAAM,eAAe,kBAAkB,SAAS,aAAa;AAC7D,MACE,iBAAiB,uBACjB,iBAAiB,sBACjB,iBAAiB,kBACjB;AACA,WAAO;AAAA,EACT;AACA,MAAI,kBAAkB,SAAS,gBAAgB,MAAM,kBAAkB;AACrE,WAAO;AAAA,EACT;AACA,QAAM,WAAW,QAAQ,WAAW,IAAI,KAAK;AAC7C,MAAI,uBAAuB,KAAK,OAAO,GAAG;AACxC,WAAO;AAAA,EACT;AACA,MAAI,yBAAyB,KAAK,OAAO,GAAG;AAC1C,WAAO;AAAA,EACT;AACA,SAAO;AACT;AAEA,SAAS,0BAA0B,SAAiC;AAClE,QAAM,OAAO,oBAAoB,OAAO,KAAK;AAC7C,SAAO;AAAA,IACL,IAAI,UAAU,QAAQ,EAAE;AAAA,IACxB,MAAM;AAAA,IACN,MAAM;AAAA,IACN,SAAS,QAAQ,WAAW;AAAA,IAC5B,YAAY,QAAQ;AAAA,IACpB,OAAO,QAAQ;AAAA,IACf,QAAQ;AAAA,IACR,aAAa;AAAA,EACf;AACF;AAEA,SAAS,wBAAwB,SAA2B;AAC1D,MAAI,QAAQ,SAAS,UAAU,iBAAiB,QAAQ,WAAW,GAAG;AACpE,WAAO;AAAA,EACT;AAEA,MAAI,QAAQ,SAAS,UAAU,QAAQ,QAAQ,eAAe,IAAI,QAAQ,IAAI,GAAG;AAC/E,WAAO;AAAA,EACT;AAEA,QAAM,UAAU,QAAQ,WAAW;AACnC,MAAI,2BAA2B,KAAK,OAAO,GAAG;AAC5C,WAAO;AAAA,EACT;AACA,MAAI,2CAA2C,KAAK,OAAO,GAAG;AAC5D,WAAO;AAAA,EACT;AACA,MAAI,4BAA4B,KAAK,OAAO,GAAG;AAC7C,WAAO;AAAA,EACT;AAEA,SAAO;AACT;AAEA,SAAS,kBAAkB,SAAiC;AAC1D,QAAM,SAAS,iBAAiB,QAAQ,WAAW;AACnD,MAAI,QAAQ;AACV,WAAO;AAAA,EACT;AAEA,QAAM,WAAW,QAAQ;AACzB,MAAI,YAAY,OAAO,aAAa,UAAU;AAC5C,UAAM,QAAQ,iBAAkB,SAAqC,WAAW;AAChF,QAAI,OAAO;AACT,aAAO;AAAA,IACT;AACA,UAAM,QAAQ,iBAAkB,SAAqC,UAAU;AAC/E,QAAI,OAAO;AACT,aAAO;AAAA,IACT;AAAA,EACF;AAEA,SAAO,6BAA6B,QAAQ,OAAO;AACrD;AAiBA,SAAS,mBAAmB,KAAyD;AACnF,MAAI,CAAC,KAAK;AACR,WAAO,CAAC;AAAA,EACV;AACA,MAAI;AACF,UAAM,SAAS,KAAK,MAAM,GAAG;AAC7B,WAAO,UAAU,OAAO,WAAW,WAAY,SAAqC,CAAC;AAAA,EACvF,QAAQ;AACN,WAAO,CAAC;AAAA,EACV;AACF;AAEA,SAAS,yBAAyB,UAAuC;AACvE,MAAI,CAAC,UAAU;AACb,WAAO;AAAA,EACT;AACA,MAAI,eAAe,IAAI,QAAQ,GAAG;AAChC,WAAO;AAAA,EACT;AACA,SAAO,sBAAsB,KAAK,QAAQ;AAC5C;AAEA,SAAS,kCAAkC,MAA+B;AACxE,QAAM,OAAO,mBAAmB,KAAK,OAAO;AAC5C,QAAM,OAAO,iBAAiB,KAAK,IAAI;AACvC,SAAO;AACT;AAEA,SAAS,0BACP,MACA,wBACe;AACf,MAAI,KAAK,cAAc;AACrB,UAAM,SAAS,uBAAuB,IAAI,KAAK,YAAY;AAC3D,QAAI,QAAQ;AACV,aAAO;AAAA,IACT;AAAA,EACF;AACA,SAAO,6BAA6B,KAAK,OAAO;AAClD;AAEA,SAAS,oBACP,YACA,SACsB;AACtB,QAAM,iBAAiB,oBAAoB,OAAO;AAClD,SAAO;AAAA,IACL,IAAI,YAAY,UAAU;AAAA,IAC1B,MAAM;AAAA,IACN,aAAa;AAAA,IACb,eAAe,QAAQ,iBAAiB;AAAA,IACxC,gBAAgB,QAAQ,kBAAkB;AAAA,IAC1C,sBAAsB,QAAQ,wBAAwB;AAAA,IACtD,iBAAiB,kBAAkB;AAAA,IACnC,oBAAoB,QAAQ,sBAAsB;AAAA,IAClD,mBAAmB,QAAQ,qBAAqB;AAAA,IAChD,sBAAsB,QAAQ,wBAAwB;AAAA,IACtD,yBAAyB,QAAQ,2BAA2B;AAAA,IAC5D,UAAU,CAAC,OAAO;AAAA,IAClB,YAAY,QAAQ;AAAA,IACpB,YAAY,QAAQ;AAAA,IACpB,OAAO,QAAQ;AAAA,EACjB;AACF;AAEA,SAAS,mBAAmB,OAA6B,SAAwB;AAC/E,QAAM,SAAS,KAAK,OAAO;AAC3B,QAAM,aAAa,KAAK,IAAI,MAAM,YAAY,QAAQ,UAAU;AAChE,QAAM,aAAa,KAAK,IAAI,MAAM,YAAY,QAAQ,UAAU;AAChE,QAAM,QAAQ,QAAQ,SAAS,MAAM;AAErC,MAAI,QAAQ,kBAAkB,QAAW;AACvC,UAAM,gBAAgB,QAAQ,iBAAiB,MAAM,iBAAiB;AAAA,EACxE;AACA,MAAI,QAAQ,mBAAmB,QAAW;AACxC,UAAM,iBAAiB,QAAQ,kBAAkB,MAAM,kBAAkB;AAAA,EAC3E;AACA,MAAI,QAAQ,yBAAyB,QAAW;AAC9C,UAAM,uBACJ,QAAQ,wBAAwB,MAAM,wBAAwB;AAAA,EAClE;AACA,QAAM,iBAAiB,oBAAoB,OAAO;AAClD,MAAI,mBAAmB,MAAM;AAC3B,UAAM,kBAAkB;AAAA,EAC1B;AACA,MAAI,QAAQ,uBAAuB,QAAW;AAC5C,UAAM,qBACJ,QAAQ,sBAAsB,MAAM,sBAAsB;AAAA,EAC9D;AACA,MAAI,QAAQ,sBAAsB,QAAW;AAC3C,UAAM,oBACJ,QAAQ,qBAAqB,MAAM,qBAAqB;AAAA,EAC5D;AACA,MAAI,QAAQ,yBAAyB,QAAW;AAC9C,UAAM,uBACJ,QAAQ,wBAAwB,MAAM,wBAAwB;AAAA,EAClE;AACA,MAAI,QAAQ,4BAA4B,QAAW;AACjD,UAAM,0BACJ,QAAQ,2BAA2B,MAAM,2BAA2B;AAAA,EACxE;AACF;AAEA,SAAS,oBACP,WACA,qBACS;AACT,QAAM,YAAY,UAAU,UAAU,OAAO,CAAC,SAAS,KAAK,SAAS,WAAW;AAChF,MAAI,UAAU,WAAW,GAAG;AAC1B,WAAO;AAAA,EACT;AACA,MAAI,CAAC,UAAU,MAAM,CAAC,SAAS,KAAK,QAAQ,eAAe,IAAI,KAAK,IAAI,CAAC,GAAG;AAC1E,WAAO;AAAA,EACT;AACA,SAAO,oBAAoB,OAAO;AACpC;AAEA,SAAS,4BACP,WACA,YACgB;AAChB,MAAI,CAAC,YAAY;AACf,WAAO;AAAA,EACT;AACA,QAAM,SAAS,UAAU,UAAU;AAAA,IACjC,CAAC,SAAS,KAAK,SAAS,iBAAiB,KAAK,iBAAiB;AAAA,EACjE;AACA,MAAI,CAAC,UAAU,OAAO,WAAW,WAAW;AAC1C,WAAO;AAAA,EACT;AAEA,QAAM,QAAQ,OAAO,WAAW,IAAI,YAAY;AAChD,MAAI,KAAK,SAAS,4BAA4B,KAAK,KAAK,SAAS,yCAAyC,GAAG;AAC3G,WAAO;AAAA,EACT;AACA,MAAI,KAAK,SAAS,GAAG;AACnB,WAAO;AAAA,EACT;AACA,SAAO;AACT;AAEA,SAAS,2BACP,WACA,UACA,OACA,QACsB;AACtB,QAAM,WAAW,iBAAiB,SAAS,IAAI,KAAK;AACpD,QAAM,mBAAmB,SAAS,eAC9B,WAAW,SAAS,YAAY,KAChC,WAAW,UAAU,EAAE,IAAI,KAAK;AACpC,QAAM,YAAY,UAAU,aAAa;AACzC,QAAM,yBAAyB,CAAC,CAAC,SAAS,QAAQ,eAAe,IAAI,SAAS,IAAI;AAElF,SAAO;AAAA,IACL,IAAI,YAAY,gBAAgB;AAAA,IAChC,MAAM;AAAA,IACN,aAAa;AAAA,IACb,eAAe;AAAA,IACf,gBAAgB;AAAA,IAChB,sBAAsB;AAAA,IACtB,iBAAiB;AAAA,IACjB,oBAAoB,yBAAyB,OAAO;AAAA,IACpD,mBAAmB,yBAAyB,OAAO;AAAA,IACnD,sBAAsB,kCAAkC,QAAQ;AAAA,IAChE,yBAAyB,UAAU;AAAA,IACnC,UAAU,CAAC;AAAA,IACX,YAAY;AAAA,IACZ,YAAY;AAAA,IACZ,OAAO,UAAU;AAAA,EACnB;AACF;AAgBA,SAAS,uBAAuB,OAAyC;AACvE,MAAI,MAAM,eAAe,UAAa,MAAM,iBAAiB,QAAW;AACtE,WAAO;AAAA,EACT;AACA,MAAI,MAAM,eAAe,MAAM,cAAc;AAC3C,WAAO;AAAA,EACT;AAEA,QAAM,QAAQ,MAAM,OACjB,IAAI,CAAC,UAAU,MAAM,wBAAwB,MAAM,kBAAkB,MAAM,iBAAiB,UAAU,EACtG,OAAO,CAAC,MAAM,OAAO,QAAQ,IAAI,QAAQ,IAAI,MAAM,KAAK;AAE3D,MAAI;AACJ,MAAI,MAAM,UAAU,GAAG;AACrB,YAAQ,qBAAqB,MAAM,CAAC,KAAK,UAAU;AAAA,EACrD,WAAW,MAAM,UAAU,GAAG;AAC5B,YAAQ,sBAAsB,MAAM,KAAK,IAAI,CAAC;AAAA,EAChD,OAAO;AACL,YAAQ,sBAAsB,MAAM,MAAM;AAAA,EAC5C;AAEA,QAAM,YACJ,KAAK,IAAI,GAAG,MAAM,OAAO,IAAI,CAAC,UAAU,MAAM,UAAU,CAAC,KAAK,KAAK,IAAI,IAAI;AAC7E,QAAM,QAAQ,MAAM,OAAO,CAAC,GAAG;AAE/B,SAAO;AAAA,IACL,IAAI,kBAAkB,MAAM,QAAQ;AAAA,IACpC,MAAM;AAAA,IACN,MAAM;AAAA,IACN,SAAS;AAAA,IACT,YAAY;AAAA,IACZ,aAAa;AAAA,IACb,QAAQ;AAAA,IACR;AAAA,EACF;AACF;AAEA,SAAS,uBAAuB,OAAiD;AAC/E,SACE,OAAO,wBACP,OAAO,kBACP,OAAO,iBACP;AAEJ;AAEA,SAAS,iCACP,SACA,OACsB;AACtB,MAAI,CAAC,QAAQ,SAAS;AACpB,WAAO;AAAA,EACT;AAEA,QAAM,UAAU,QAAQ;AACxB,QAAM,OAAO,uBAAuB,KAAK;AAEzC,MAAI,QAAuB;AAC3B,MAAI,qCAAqC,KAAK,OAAO,GAAG;AACtD,YAAQ,qBAAqB,IAAI;AAAA,EACnC,WACE,0BAA0B,KAAK,OAAO,KACtC,uCAAuC,KAAK,OAAO,GACnD;AACA,YAAQ,oBAAoB,IAAI;AAAA,EAClC;AAEA,MAAI,CAAC,OAAO;AACV,WAAO;AAAA,EACT;AAEA,SAAO;AAAA,IACL,IAAI,yBAAyB,QAAQ,EAAE;AAAA,IACvC,MAAM;AAAA,IACN,MAAM;AAAA,IACN,SAAS;AAAA,IACT,YAAY,QAAQ;AAAA,IACpB,OAAO,QAAQ;AAAA,IACf,QAAQ;AAAA,IACR,aAAa;AAAA,IACb,aAAa,OAAO,eAAe,QAAQ,eAAe;AAAA,EAC5D;AACF;AAEA,SAAS,kBAAkB,OAAqE;AAC9F,MAAI,MAAM,OAAO,WAAW,GAAG;AAC7B,WAAO,MAAM,OAAO,CAAC;AAAA,EACvB;AAEA,QAAM,SAAS,CAAC,GAAG,MAAM,MAAM,EAAE,KAAK,CAAC,GAAG,MAAM;AAC9C,UAAM,SAAS,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,iBAAiB,IAAI,YAAY;AAChG,UAAM,SAAS,EAAE,wBAAwB,EAAE,kBAAkB,EAAE,iBAAiB,IAAI,YAAY;AAChG,QAAI,UAAU,OAAO;AACnB,aAAO,MAAM,cAAc,KAAK;AAAA,IAClC;AACA,WAAO,EAAE,aAAa,EAAE;AAAA,EAC1B,CAAC;AAED,SAAO;AAAA,IACL,IAAI,kBAAkB,MAAM,QAAQ;AAAA,IACpC,MAAM;AAAA,IACN,UAAU,MAAM;AAAA,IAChB,WAAW;AAAA,IACX,YAAY,KAAK,IAAI,GAAG,OAAO,IAAI,CAAC,UAAU,MAAM,UAAU,CAAC;AAAA,IAC/D,YAAY,KAAK,IAAI,GAAG,OAAO,IAAI,CAAC,UAAU,MAAM,UAAU,CAAC;AAAA,IAC/D,OAAO,OAAO,CAAC,GAAG;AAAA,EACpB;AACF;AASO,SAAS,0BACd,UACA,UAA4B,CAAC,GACJ;AACzB,MAAI,SAAS,WAAW,GAAG;AACzB,WAAO,CAAC;AAAA,EACV;AAEA,QAAM,oBAAoB,QAAQ,qBAAqB;AACvD,QAAM,eAAwC,oBACzC,sBAAsB,QAAQ,IAC/B;AAEJ,QAAM,yBAAyB,oBAAI,IAAoB;AACvD,aAAW,WAAW,UAAU;AAC9B,QAAI,QAAQ,SAAS,QAAQ;AAC3B;AAAA,IACF;AACA,QAAI,CAAC,QAAQ,cAAc;AACzB;AAAA,IACF;AACA,UAAM,aAAa,kBAAkB,OAAO;AAC5C,QAAI,YAAY;AACd,6BAAuB,IAAI,QAAQ,cAAc,UAAU;AAAA,IAC7D;AAAA,EACF;AAEA,QAAM,0BAA0B,oBAAI,IAAoB;AACxD,QAAM,yBAAyB,oBAAI,IAAoB;AACvD,QAAM,4BAA4B,oBAAI,IAGpC;AACF,QAAM,oBAAsC,CAAC;AAC7C,QAAM,uBAAuB,oBAAI,IAAY;AAC7C,QAAM,qBAAqB,oBAAI,IAAoB;AAEnD,eAAa,QAAQ,CAAC,OAAO,UAAU;AACrC,uBAAmB,IAAI,MAAM,IAAI,KAAK;AAEtC,QAAI,CAAC,YAAY,KAAK,GAAG;AACvB;AAAA,IACF;AAEA,UAAM,wBAAwB,oBAAI,IAAY;AAC9C,UAAM,YAAY,MAAM,UAAU,OAAO,CAAC,SAAS,KAAK,SAAS,WAAW;AAC5E,UAAM,2BAAuC,CAAC;AAE9C,eAAW,YAAY,WAAW;AAChC,UAAI,CAAC,yBAAyB,SAAS,IAAI,GAAG;AAC5C;AAAA,MACF;AACA,YAAM,aAAa,0BAA0B,UAAU,sBAAsB;AAC7E,UAAI,CAAC,YAAY;AACf,YAAI,SAAS,WAAW,WAAW;AACjC,mCAAyB,KAAK,QAAQ;AAAA,QACxC;AACA;AAAA,MACF;AACA,4BAAsB,IAAI,UAAU;AACpC,UAAI,CAAC,wBAAwB,IAAI,UAAU,GAAG;AAC5C,gCAAwB,IAAI,YAAY,KAAK;AAAA,MAC/C;AACA,YAAM,aAAa,kCAAkC,QAAQ;AAC7D,UAAI,cAAc,CAAC,uBAAuB,IAAI,UAAU,GAAG;AACzD,+BAAuB,IAAI,YAAY,UAAU;AAAA,MACnD;AAEA,YAAM,eAAe,0BAA0B,IAAI,UAAU,KAAK;AAAA,QAChE,WAAW;AAAA,QACX,UAAU;AAAA,MACZ;AACA,UAAI,SAAS,SAAS,qBAAqB,SAAS,SAAS,sBAAsB,SAAS,SAAS,iBAAiB;AACpH,qBAAa,YAAY;AAAA,MAC3B;AACA,UAAI,SAAS,SAAS,mBAAmB;AACvC,cAAM,mBAAmB,4BAA4B,OAAO,SAAS,YAAY;AACjF,YAAI,qBAAqB,MAAM;AAC7B,uBAAa,WAAW;AAAA,QAC1B;AAAA,MACF;AACA,gCAA0B,IAAI,YAAY,YAAY;AAAA,IACxD;AAEA,QAAI,yBAAyB,SAAS,GAAG;AACvC,+BAAyB,QAAQ,CAAC,UAAU,iBAAiB;AAC3D,cAAM,gBACJ,iBAAiB,IAAI,YAAY;AACnC,cAAM,QAAQ;AAAA,UACZ;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,QACF;AACA,0BAAkB,KAAK;AAAA,UACrB;AAAA,UACA,YAAY;AAAA,UACZ,cAAc;AAAA,UACd,UAAU,SAAS,KAAK;AAAA,QAC1B,CAAC;AAAA,MACH,CAAC;AAAA,IACH;AAEA,QAAI,oBAAoB,OAAO,qBAAqB,GAAG;AACrD,2BAAqB,IAAI,KAAK;AAAA,IAChC;AAAA,EACF,CAAC;AAED,QAAM,qBAAqB,oBAAI,IAAkC;AACjE,QAAM,sBAAsB,oBAAI,IAAY;AAC5C,aAAW,WAAW,UAAU;AAC9B,UAAM,aAAa,kBAAkB,OAAO;AAC5C,QAAI,CAAC,YAAY;AACf;AAAA,IACF;AACA,QAAI,wBAAwB,OAAO,GAAG;AACpC,0BAAoB,IAAI,UAAU;AAAA,IACpC;AAAA,EACF;AAEA,aAAW,WAAW,UAAU;AAC9B,UAAM,aAAa,kBAAkB,OAAO;AAC5C,QAAI,CAAC,cAAc,CAAC,oBAAoB,IAAI,UAAU,GAAG;AACvD;AAAA,IACF;AAEA,UAAM,WAAW,mBAAmB,IAAI,UAAU;AAClD,QAAI,CAAC,UAAU;AACb,yBAAmB,IAAI,YAAY,oBAAoB,YAAY,OAAO,CAAC;AAAA,IAC7E,OAAO;AACL,yBAAmB,UAAU,OAAO;AAAA,IACtC;AAAA,EACF;AAEA,MAAI,mBAAmB,SAAS,KAAK,kBAAkB,WAAW,GAAG;AACnE,WAAO,aAAa,IAAI,CAAC,UAAU;AACjC,UAAI,gBAAgB,KAAK,GAAG;AAC1B,eAAO;AAAA,MACT;AACA,UAAI,YAAY,KAAK,GAAG;AACtB,eAAO;AAAA,MACT;AACA,YAAM,MAAM;AACZ,UAAI,oBAAoB,GAAG,GAAG;AAC5B,eAAO,0BAA0B,GAAG;AAAA,MACtC;AACA,aAAO;AAAA,IACT,CAAC;AAAA,EACH;AAEA,QAAM,aAA+B,CAAC;AACtC,QAAM,oBAA4C,CAAC;AAEnD,aAAW,CAAC,YAAY,KAAK,KAAK,oBAAoB;AACpD,UAAM,qBAAqB,uBAAuB,IAAI,UAAU;AAChE,QAAI,CAAC,MAAM,wBAAwB,oBAAoB;AACrD,YAAM,uBAAuB;AAAA,IAC/B;AACA,UAAM,gBAAgB,0BAA0B,IAAI,UAAU;AAC9D,QAAI,MAAM,uBAAuB,QAAQ,eAAe,cAAc,QAAQ,eAAe,cAAc,QAAW;AACpH,YAAM,qBAAqB,cAAc;AAAA,IAC3C;AACA,QAAI,MAAM,sBAAsB,QAAQ,eAAe,aAAa,QAAQ,eAAe,aAAa,QAAW;AACjH,YAAM,oBAAoB,cAAc;AAAA,IAC1C;AAEA,QAAI,aAAa,wBAAwB,IAAI,UAAU;AACvD,QAAI;AAEJ,eAAW,gBAAgB,MAAM,UAAU;AACzC,YAAM,eAAe,mBAAmB,IAAI,aAAa,EAAE;AAC3D,UAAI,iBAAiB,QAAW;AAC9B;AAAA,MACF;AACA,UAAI,iBAAiB,UAAa,eAAe,cAAc;AAC7D,uBAAe;AAAA,MACjB;AAAA,IACF;AAEA,QAAI,eAAe,UAAa,MAAM,yBAAyB;AAC7D,mBAAa,mBAAmB,IAAI,MAAM,uBAAuB;AAAA,IACnE;AAEA,QAAI,iBAAiB,QAAW;AAC9B,UAAI,eAAe,QAAW;AAC5B,uBAAe;AAAA,MACjB,WAAW,MAAM,yBAAyB;AACxC,uBAAe,mBAAmB,IAAI,MAAM,uBAAuB;AAAA,MACrE;AAAA,IACF;AAEA,QAAI,eAAe,UAAa,iBAAiB,QAAW;AAC1D,mBAAa;AAAA,IACf;AAEA,QAAI,iBAAiB,QAAW;AAC9B,wBAAkB,KAAK,KAAK;AAC5B;AAAA,IACF;AAEA,UAAM,WACJ,MAAM,0BACF,SAAS,MAAM,uBAAuB,KACtC,eAAe,SACb,SAAS,UAAU,KACnB,YAAY,UAAU;AAE9B,eAAW,KAAK;AAAA,MACd;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF,CAAC;AAAA,EACH;AAEA,aAAW,aAAa,mBAAmB;AACzC,eAAW,KAAK,SAAS;AAAA,EAC3B;AAEA,QAAM,cAAc,oBAAI,IAAwB;AAChD,aAAW,aAAa,YAAY;AAClC,UAAM,WAAW,YAAY,IAAI,UAAU,QAAQ;AACnD,QAAI,CAAC,UAAU;AACb,kBAAY,IAAI,UAAU,UAAU;AAAA,QAClC,UAAU,UAAU;AAAA,QACpB,YAAY,UAAU;AAAA,QACtB,cAAc,UAAU;AAAA,QACxB,QAAQ,CAAC,UAAU,KAAK;AAAA,MAC1B,CAAC;AACD;AAAA,IACF;AAEA,QAAI,SAAS,eAAe,QAAW;AACrC,eAAS,aAAa,UAAU;AAAA,IAClC;AACA,QAAI,UAAU,eAAe,UAAa,SAAS,eAAe,QAAW;AAC3E,eAAS,aAAa,KAAK,IAAI,SAAS,YAAY,UAAU,UAAU;AAAA,IAC1E;AACA,QAAI,SAAS,iBAAiB,QAAW;AACvC,eAAS,eAAe,UAAU;AAAA,IACpC;AACA,QAAI,UAAU,iBAAiB,UAAa,SAAS,iBAAiB,QAAW;AAC/E,eAAS,eAAe,KAAK,IAAI,SAAS,cAAc,UAAU,YAAY;AAAA,IAChF;AACA,aAAS,OAAO,KAAK,UAAU,KAAK;AAAA,EACtC;AAEA,QAAM,wBAAwB,oBAAI,IAAqE;AACvG,QAAM,sBAAsB,oBAAI,IAA6B;AAC7D,QAAM,sBAAsB,oBAAI,IAA6B;AAE7D,aAAW,SAAS,YAAY,OAAO,GAAG;AACxC,UAAM,eAAe,kBAAkB,KAAK;AAC5C,QAAI,MAAM,iBAAiB,QAAW;AACpC,YAAM,WAAW,sBAAsB,IAAI,MAAM,YAAY,KAAK,CAAC;AACnE,eAAS,KAAK,YAAY;AAC1B,4BAAsB,IAAI,MAAM,cAAc,QAAQ;AAAA,IACxD;AAEA,UAAM,SAAS,uBAAuB,KAAK;AAC3C,QAAI,UAAU,MAAM,eAAe,QAAW;AAC5C,YAAM,WAAW,oBAAoB,IAAI,MAAM,UAAU,KAAK,CAAC;AAC/D,eAAS,KAAK,MAAM;AACpB,0BAAoB,IAAI,MAAM,YAAY,QAAQ;AAAA,IACpD;AAAA,EACF;AAEA,aAAW,cAAc,UAAU;AACjC,UAAM,aAAa,kBAAkB,UAAU;AAC/C,QAAI,CAAC,YAAY;AACf;AAAA,IACF;AACA,UAAM,eAAe,mBAAmB,IAAI,WAAW,EAAE;AACzD,QAAI,iBAAiB,QAAW;AAC9B;AAAA,IACF;AACA,UAAM,QAAQ,mBAAmB,IAAI,UAAU;AAC/C,UAAM,SAAS,iCAAiC,YAAY,KAAK;AACjE,QAAI,CAAC,QAAQ;AACX;AAAA,IACF;AACA,UAAM,WAAW,oBAAoB,IAAI,YAAY,KAAK,CAAC;AAC3D,aAAS,KAAK,MAAM;AACpB,wBAAoB,IAAI,cAAc,QAAQ;AAAA,EAChD;AAEA,aAAW,CAAC,cAAc,KAAK,KAAK,uBAAuB;AACzD,UAAM,KAAK,CAAC,GAAG,MAAM,EAAE,aAAa,EAAE,UAAU;AAChD,0BAAsB,IAAI,cAAc,KAAK;AAAA,EAC/C;AACA,aAAW,CAAC,YAAY,OAAO,KAAK,qBAAqB;AACvD,YAAQ,KAAK,CAAC,GAAG,MAAM,EAAE,aAAa,EAAE,UAAU;AAClD,wBAAoB,IAAI,YAAY,OAAO;AAAA,EAC7C;AACA,aAAW,CAAC,aAAa,OAAO,KAAK,qBAAqB;AACxD,YAAQ,KAAK,CAAC,GAAG,MAAM,EAAE,aAAa,EAAE,UAAU;AAClD,wBAAoB,IAAI,aAAa,OAAO;AAAA,EAC9C;AAEA,oBAAkB,KAAK,CAAC,GAAG,MAAM,EAAE,aAAa,EAAE,UAAU;AAE5D,QAAM,SAAkC,CAAC;AACzC,QAAM,sBAAsB,oBAAI,IAAY;AAE5C,WAAS,IAAI,GAAG,IAAI,aAAa,QAAQ,KAAK;AAC5C,UAAM,eAAe,oBAAoB,IAAI,CAAC,KAAK,CAAC;AACpD,eAAW,UAAU,cAAc;AACjC,aAAO,KAAK,MAAM;AAAA,IACpB;AAEA,UAAM,eAAe,oBAAoB,IAAI,CAAC,KAAK,CAAC;AACpD,eAAW,UAAU,cAAc;AACjC,aAAO,KAAK,MAAM;AAAA,IACpB;AAEA,UAAM,gBAAgB,sBAAsB,IAAI,CAAC,KAAK,CAAC;AACvD,eAAW,QAAQ,eAAe;AAChC,UAAK,KAAmC,SAAS,wBAAwB;AACvE,cAAM,QAAQ;AACd,mBAAW,SAAS,MAAM,WAAW;AACnC,8BAAoB,IAAI,MAAM,WAAW;AAAA,QAC3C;AACA,eAAO,KAAK,KAAK;AAAA,MACnB,OAAO;AACL,cAAM,QAAQ;AACd,YAAI,CAAC,oBAAoB,IAAI,MAAM,WAAW,GAAG;AAC/C,iBAAO,KAAK,KAAK;AACjB,8BAAoB,IAAI,MAAM,WAAW;AAAA,QAC3C;AAAA,MACF;AAAA,IACF;AAEA,UAAM,QAAQ,aAAa,CAAC;AAC5B,QAAI,gBAAgB,KAAK,GAAG;AAC1B,aAAO,KAAK,KAAK;AACjB;AAAA,IACF;AAEA,QAAI,YAAY,KAAK,GAAG;AACtB,UAAI,qBAAqB,IAAI,CAAC,GAAG;AAC/B;AAAA,MACF;AACA,aAAO,KAAK,KAAK;AACjB;AAAA,IACF;AAEA,UAAM,WAAW;AACjB,QAAI,oBAAoB,QAAQ,GAAG;AACjC,aAAO,KAAK,0BAA0B,QAAQ,CAAC;AAC/C;AAAA,IACF;AAEA,QAAI,kBAAkB,QAAQ,GAAG;AAC/B;AAAA,IACF;AACA,WAAO,KAAK,QAAQ;AAAA,EACtB;AAEA,aAAW,SAAS,mBAAmB;AACrC,QAAI,CAAC,oBAAoB,IAAI,MAAM,WAAW,GAAG;AAC/C,aAAO,KAAK,KAAK;AACjB,0BAAoB,IAAI,MAAM,WAAW;AAAA,IAC3C;AAAA,EACF;AAEA,SAAO;AACT;","names":["response"]}
|
|
1
|
+
{"version":3,"sources":["../src/client/AgentBuilderClient.ts","../src/connection/ThreadConnectionManager.ts","../src/utils/attachments.ts","../src/utils/imageProcessing.ts","../src/utils/fileHelpers.ts","../src/uploads/FileUploadManager.ts","../src/utils/workblocks.ts","../src/utils/subagentBlocks.ts"],"sourcesContent":["import type {\n Message,\n Thread,\n SendMessagePayload,\n GetMessagesOptions,\n MessagesPage,\n MessageWebSocketCallbacks,\n LogWebSocketCallbacks,\n MessageStreamEvent,\n LogStreamEvent,\n ThreadEvent,\n CreateThreadPayload,\n AttachmentRef,\n} from '../types'\n\nexport class AgentBuilderClient {\n private endpoint: string\n private token: string | null\n\n constructor(endpoint: string) {\n // Normalize endpoint by removing trailing slash\n this.endpoint = endpoint.replace(/\\/$/, '')\n\n // Read auth token from localStorage\n this.token = typeof localStorage !== 'undefined'\n ? localStorage.getItem('agentbuilder_auth_token')\n : null\n }\n\n /**\n * Get the current endpoint\n */\n getEndpoint(): string {\n return this.endpoint\n }\n\n /**\n * Create a new thread\n */\n async createThread(payload: CreateThreadPayload): Promise<Thread> {\n const response = await fetch(`${this.endpoint}/threads`, {\n method: 'POST',\n headers: {\n ...this.getHeaders(),\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify(payload),\n })\n\n if (!response.ok) {\n throw new Error(`Failed to create thread: ${response.statusText}`)\n }\n\n return response.json()\n }\n\n /**\n * Get thread metadata\n */\n async getThread(id: string): Promise<Thread> {\n const response = await fetch(`${this.endpoint}/threads/${id}`, {\n method: 'GET',\n headers: this.getHeaders(),\n })\n\n if (!response.ok) {\n throw new Error(`Failed to get thread: ${response.statusText}`)\n }\n\n return response.json()\n }\n\n /**\n * Get messages from a thread with optional pagination and filtering\n */\n async getMessages(\n id: string,\n options: GetMessagesOptions = {}\n ): Promise<Message[]> {\n const data = await this.getMessagesPage(id, options)\n return data.messages || []\n }\n\n /**\n * Get a paginated message page from a thread.\n */\n async getMessagesPage(\n id: string,\n options: GetMessagesOptions = {}\n ): Promise<MessagesPage> {\n const params = new URLSearchParams()\n\n if (options.limit !== undefined) params.set('limit', String(options.limit))\n if (options.offset !== undefined) params.set('offset', String(options.offset))\n if (options.depth !== undefined) params.set('depth', String(options.depth))\n if (options.includeSilent !== undefined) params.set('includeSilent', String(options.includeSilent))\n if (options.ids !== undefined && options.ids.length > 0) params.set('ids', options.ids.join(','))\n if (options.includeWorkblocks !== undefined) params.set('includeWorkblocks', String(options.includeWorkblocks))\n\n const queryString = params.toString()\n const url = `${this.endpoint}/threads/${id}/messages${queryString ? `?${queryString}` : ''}`\n\n const response = await fetch(url, {\n method: 'GET',\n headers: this.getHeaders(),\n })\n\n if (!response.ok) {\n throw new Error(`Failed to get messages: ${response.statusText}`)\n }\n\n const data = await response.json()\n return {\n messages: data.messages || [],\n total: data.total || 0,\n hasMore: !!data.hasMore,\n }\n }\n\n /**\n * Send a message to a thread\n */\n async sendMessage(\n id: string,\n payload: SendMessagePayload\n ): Promise<Message> {\n const response = await fetch(`${this.endpoint}/threads/${id}/messages`, {\n method: 'POST',\n headers: {\n ...this.getHeaders(),\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify(payload),\n })\n\n if (!response.ok) {\n throw new Error(`Failed to send message: ${response.statusText}`)\n }\n\n return response.json()\n }\n\n /**\n * Stop execution of a thread\n */\n async stopExecution(id: string): Promise<void> {\n const response = await fetch(`${this.endpoint}/threads/${id}/stop`, {\n method: 'POST',\n headers: this.getHeaders(),\n })\n\n if (!response.ok) {\n throw new Error(`Failed to stop execution: ${response.statusText}`)\n }\n\n await response.json()\n }\n\n /**\n * Delete a message from a thread\n * @param threadId - The thread ID\n * @param messageId - The message ID to delete\n * @returns Object with success status\n */\n async deleteMessage(\n threadId: string,\n messageId: string\n ): Promise<{ success: boolean }> {\n const response = await fetch(\n `${this.endpoint}/threads/${threadId}/messages/${messageId}`,\n {\n method: 'DELETE',\n headers: this.getHeaders(),\n }\n )\n\n if (!response.ok) {\n throw new Error(`Failed to delete message: ${response.statusText}`)\n }\n\n return response.json()\n }\n\n /**\n * Options for file upload\n */\n /**\n * Upload a file to a thread's filesystem\n * @param threadId - The thread ID\n * @param file - The file to upload\n * @param options - Optional upload options\n * @param options.thumbnail - Base64-encoded thumbnail data (for images)\n * @param options.width - Image width in pixels\n * @param options.height - Image height in pixels\n * @returns AttachmentRef with file metadata\n */\n async uploadFile(\n threadId: string,\n file: File,\n options?: {\n thumbnail?: string\n width?: number\n height?: number\n }\n ): Promise<AttachmentRef> {\n const encodedFilename = encodeURIComponent(file.name)\n const url = `${this.endpoint}/threads/${threadId}/fs/${encodedFilename}`\n\n // If thumbnail provided, use JSON format with base64 data\n if (options?.thumbnail) {\n const base64Data = await this.fileToBase64(file)\n\n const response = await fetch(url, {\n method: 'POST',\n headers: {\n ...this.getHeaders(),\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n data: base64Data,\n mimeType: file.type,\n thumbnail: options.thumbnail,\n metadata: {\n width: options.width,\n height: options.height,\n },\n }),\n })\n\n if (!response.ok) {\n throw new Error(`Failed to upload file: ${response.statusText}`)\n }\n\n return response.json()\n }\n\n // For non-image files or when no thumbnail, use raw binary upload\n const response = await fetch(url, {\n method: 'POST',\n headers: {\n ...this.getHeaders(),\n 'Content-Type': file.type,\n },\n body: file,\n })\n\n if (!response.ok) {\n throw new Error(`Failed to upload file: ${response.statusText}`)\n }\n\n return response.json()\n }\n\n /**\n * Convert a File to base64 string\n */\n private fileToBase64(file: File): Promise<string> {\n return new Promise((resolve, reject) => {\n const reader = new FileReader()\n reader.onload = () => {\n const result = reader.result as string\n // Remove data URL prefix (e.g., \"data:image/jpeg;base64,\")\n const base64 = result.split(',')[1]\n resolve(base64)\n }\n reader.onerror = () => reject(new Error('Failed to read file'))\n reader.readAsDataURL(file)\n })\n }\n\n /**\n * Get the full URL for a file in a thread's filesystem\n */\n getFileUrl(threadId: string, path: string): string {\n // Normalize path - remove leading slash and encode special characters\n const normalizedPath = path.startsWith('/') ? path.slice(1) : path\n const encodedPath = normalizedPath\n .split('/')\n .map(segment => encodeURIComponent(segment))\n .join('/')\n\n return `${this.endpoint}/threads/${threadId}/fs/${encodedPath}`\n }\n\n /**\n * Get the thumbnail URL for an image in a thread's filesystem\n */\n getThumbnailUrl(threadId: string, path: string): string {\n return `${this.getFileUrl(threadId, path)}?thumbnail=true`\n }\n\n /**\n * List all files in a thread's filesystem\n * @param threadId - The thread ID\n * @returns Array of file records\n */\n async listFiles(threadId: string): Promise<Array<{\n path: string\n name: string\n mimeType: string\n size: number\n isDirectory: boolean\n createdAt?: number\n updatedAt?: number\n }>> {\n // Use find API to recursively list all files\n const response = await fetch(\n `${this.endpoint}/threads/${threadId}/fs?find=**/*&type=file`,\n {\n method: 'GET',\n headers: this.getHeaders(),\n }\n )\n\n if (!response.ok) {\n throw new Error(`Failed to list files: ${response.statusText}`)\n }\n\n const data = await response.json()\n return data.files || []\n }\n\n /**\n * Connect to message WebSocket for real-time message updates\n */\n connectMessageWebSocket(\n id: string,\n callbacks: MessageWebSocketCallbacks = {},\n options: { includeSilent?: boolean; depth?: number } = {}\n ): WebSocket {\n const params = new URLSearchParams()\n\n if (this.token) params.set('token', this.token)\n if (options.includeSilent !== undefined) params.set('includeSilent', String(options.includeSilent))\n if (options.depth !== undefined) params.set('depth', String(options.depth))\n\n const wsProtocol = this.endpoint.startsWith('https') ? 'wss' : 'ws'\n const wsEndpoint = this.endpoint.replace(/^https?/, wsProtocol)\n const url = `${wsEndpoint}/threads/${id}/stream?${params.toString()}`\n\n const ws = new WebSocket(url)\n\n ws.onopen = () => {\n callbacks.onOpen?.()\n }\n\n ws.onmessage = (event) => {\n try {\n // Handle pong response from heartbeat ping\n if (typeof event.data === 'string' && event.data === 'pong') {\n return\n }\n\n const data = JSON.parse(event.data) as MessageStreamEvent\n\n switch (data.type) {\n case 'message_data':\n callbacks.onMessage?.(data)\n break\n case 'message_chunk':\n callbacks.onChunk?.(data)\n break\n case 'event':\n callbacks.onEvent?.(data as ThreadEvent)\n break\n case 'error':\n callbacks.onError?.(data)\n break\n }\n } catch (error) {\n console.error('Failed to parse WebSocket message:', error)\n }\n }\n\n ws.onerror = (event) => {\n console.error('WebSocket error:', event)\n callbacks.onError?.({ type: 'error', error: 'WebSocket connection error' })\n }\n\n ws.onclose = (event) => {\n console.log(`[AgentBuilderClient] Message WebSocket closed - code: ${event.code}, reason: ${event.reason || 'none'}, wasClean: ${event.wasClean}`)\n callbacks.onClose?.()\n }\n\n return ws\n }\n\n /**\n * Connect to log WebSocket for custom events\n */\n connectLogWebSocket(\n id: string,\n callbacks: LogWebSocketCallbacks = {}\n ): WebSocket {\n const params = new URLSearchParams()\n\n if (this.token) params.set('token', this.token)\n\n const wsProtocol = this.endpoint.startsWith('https') ? 'wss' : 'ws'\n const wsEndpoint = this.endpoint.replace(/^https?/, wsProtocol)\n const url = `${wsEndpoint}/threads/${id}?${params.toString()}`\n\n const ws = new WebSocket(url)\n\n ws.onopen = () => {\n callbacks.onOpen?.()\n }\n\n ws.onmessage = (event) => {\n try {\n // Handle pong response from heartbeat ping\n if (typeof event.data === 'string' && event.data === 'pong') {\n return\n }\n\n const data = JSON.parse(event.data) as LogStreamEvent\n\n switch (data.type) {\n case 'log_data':\n callbacks.onLog?.(data)\n break\n case 'custom':\n callbacks.onCustom?.(data)\n break\n case 'stopped_by_user':\n callbacks.onStopped?.(data)\n break\n }\n } catch (error) {\n console.error('Failed to parse WebSocket message:', error)\n }\n }\n\n ws.onerror = (event) => {\n console.error('WebSocket error:', event)\n }\n\n ws.onclose = () => {\n callbacks.onClose?.()\n }\n\n return ws\n }\n\n /**\n * Get headers for HTTP requests\n */\n private getHeaders(): Record<string, string> {\n const headers: Record<string, string> = {}\n\n if (this.token) {\n headers['Authorization'] = `Bearer ${this.token}`\n }\n\n return headers\n }\n}\n","import { AgentBuilderClient } from '../client/AgentBuilderClient'\nimport type {\n ConnectionStatus,\n ThreadConnectionCallbacks,\n MessageDataEvent,\n MessageChunkEvent,\n ThreadEvent,\n ErrorEvent,\n} from '../types'\n\nexport interface ThreadConnectionOptions {\n /** Maximum message depth to stream (default: 0 for top-level only) */\n depth?: number\n /** Whether to include silent messages (default: false) */\n includeSilent?: boolean\n /** Heartbeat interval in milliseconds (default: 30000) */\n heartbeatInterval?: number\n /** Maximum reconnection delay in milliseconds (default: 30000) */\n maxReconnectDelay?: number\n}\n\n/**\n * ThreadConnectionManager handles WebSocket connection lifecycle for a thread.\n * Provides automatic reconnection with exponential backoff and heartbeat keep-alive.\n *\n * This class is framework-agnostic. React and Vue SDKs use this internally\n * and handle their own reactive state management.\n *\n * @example\n * ```typescript\n * const manager = new ThreadConnectionManager(client, 'thread-123', {\n * onMessage: (event) => updateMessages(event.data),\n * onChunk: (event) => appendChunk(event.chunk),\n * onStatusChange: (status) => setConnectionStatus(status),\n * })\n *\n * manager.connect()\n * // ... later\n * manager.disconnect()\n * ```\n */\nexport class ThreadConnectionManager {\n private client: AgentBuilderClient\n private threadId: string\n private callbacks: ThreadConnectionCallbacks\n private options: Required<ThreadConnectionOptions>\n\n private ws: WebSocket | null = null\n private status: ConnectionStatus = 'disconnected'\n private reconnectAttempts: number = 0\n private reconnectTimeout: ReturnType<typeof setTimeout> | null = null\n private heartbeatInterval: ReturnType<typeof setInterval> | null = null\n private isReconnecting: boolean = false\n private shouldReconnect: boolean = true\n\n constructor(\n client: AgentBuilderClient,\n threadId: string,\n callbacks: ThreadConnectionCallbacks = {},\n options: ThreadConnectionOptions = {}\n ) {\n this.client = client\n this.threadId = threadId\n this.callbacks = callbacks\n this.options = {\n depth: options.depth ?? 0,\n includeSilent: options.includeSilent ?? false,\n heartbeatInterval: options.heartbeatInterval ?? 30000,\n maxReconnectDelay: options.maxReconnectDelay ?? 30000,\n }\n }\n\n /**\n * Get current connection status\n */\n getStatus(): ConnectionStatus {\n return this.status\n }\n\n /**\n * Get the thread ID this manager is connected to\n */\n getThreadId(): string {\n return this.threadId\n }\n\n /**\n * Connect to the thread WebSocket\n */\n connect(): void {\n if (this.ws && this.ws.readyState !== WebSocket.CLOSED) {\n // Already connected or connecting\n return\n }\n\n this.shouldReconnect = true\n this.isReconnecting = false\n this.setStatus('connecting')\n\n this.ws = this.client.connectMessageWebSocket(\n this.threadId,\n {\n onOpen: () => {\n this.setStatus('connected')\n this.reconnectAttempts = 0\n this.isReconnecting = false\n this.startHeartbeat()\n },\n onMessage: (event: MessageDataEvent) => {\n this.callbacks.onMessage?.(event)\n },\n onChunk: (event: MessageChunkEvent) => {\n this.callbacks.onChunk?.(event)\n },\n onEvent: (event: ThreadEvent) => {\n this.callbacks.onEvent?.(event)\n },\n onError: (event: ErrorEvent) => {\n this.callbacks.onError?.(event)\n },\n onClose: () => {\n this.clearTimers()\n this.scheduleReconnect()\n },\n },\n {\n depth: this.options.depth,\n includeSilent: this.options.includeSilent,\n }\n )\n }\n\n /**\n * Disconnect from the thread WebSocket\n */\n disconnect(): void {\n this.shouldReconnect = false\n this.clearTimers()\n\n if (this.ws) {\n this.ws.close()\n this.ws = null\n }\n\n this.reconnectAttempts = 0\n this.isReconnecting = false\n this.setStatus('disconnected')\n }\n\n /**\n * Update callbacks without reconnecting\n */\n updateCallbacks(callbacks: Partial<ThreadConnectionCallbacks>): void {\n this.callbacks = { ...this.callbacks, ...callbacks }\n }\n\n /**\n * Update options (requires reconnect to take effect for depth/includeSilent)\n */\n updateOptions(options: Partial<ThreadConnectionOptions>): void {\n this.options = { ...this.options, ...options }\n }\n\n private setStatus(status: ConnectionStatus): void {\n if (this.status !== status) {\n this.status = status\n this.callbacks.onStatusChange?.(status)\n }\n }\n\n private startHeartbeat(): void {\n this.clearHeartbeat()\n\n this.heartbeatInterval = setInterval(() => {\n if (this.ws && this.ws.readyState === WebSocket.OPEN) {\n this.ws.send('ping')\n }\n }, this.options.heartbeatInterval)\n }\n\n private clearHeartbeat(): void {\n if (this.heartbeatInterval) {\n clearInterval(this.heartbeatInterval)\n this.heartbeatInterval = null\n }\n }\n\n private clearReconnectTimeout(): void {\n if (this.reconnectTimeout) {\n clearTimeout(this.reconnectTimeout)\n this.reconnectTimeout = null\n }\n }\n\n private clearTimers(): void {\n this.clearHeartbeat()\n this.clearReconnectTimeout()\n }\n\n private scheduleReconnect(): void {\n if (!this.shouldReconnect || this.isReconnecting) {\n this.setStatus('disconnected')\n return\n }\n\n this.isReconnecting = true\n this.setStatus('reconnecting')\n\n // Exponential backoff: 1s, 2s, 4s, 8s, 16s, 30s (max)\n const delay = Math.min(\n 1000 * Math.pow(2, this.reconnectAttempts),\n this.options.maxReconnectDelay\n )\n this.reconnectAttempts++\n\n this.reconnectTimeout = setTimeout(() => {\n if (this.shouldReconnect) {\n this.connect()\n }\n }, delay)\n }\n}\n","import type { Message, AttachmentRef, ThreadFile } from '../types'\n\n/**\n * Parse attachments from a message\n * Handles both JSON string and already-parsed array formats\n * Returns empty array if no attachments or invalid data\n */\nexport function parseAttachments(message: Message): AttachmentRef[] {\n if (!message.attachments) {\n return []\n }\n\n // If already an array, return it directly\n if (Array.isArray(message.attachments)) {\n return message.attachments\n }\n\n // Otherwise try to parse as JSON string\n try {\n const parsed = JSON.parse(message.attachments)\n if (!Array.isArray(parsed)) {\n return []\n }\n return parsed\n } catch {\n return []\n }\n}\n\n/**\n * Check if a MIME type represents an image\n */\nexport function isImageMimeType(mimeType: string): boolean {\n return mimeType.toLowerCase().startsWith('image/')\n}\n\n/**\n * Convert messages to ThreadFile array\n * Extracts all committed files from message attachments\n */\nexport function messagesToFiles(messages: Message[]): ThreadFile[] {\n const files: ThreadFile[] = []\n\n for (const message of messages) {\n const attachments = parseAttachments(message)\n\n for (const attachment of attachments) {\n files.push({\n id: attachment.id,\n name: attachment.name,\n mimeType: attachment.mimeType,\n size: attachment.size,\n isImage: isImageMimeType(attachment.mimeType),\n localPreviewUrl: null, // Committed files don't have local preview\n status: 'committed',\n path: attachment.path,\n width: attachment.width,\n height: attachment.height,\n messageId: message.id,\n })\n }\n }\n\n return files\n}\n","/**\n * Image processing utilities for thumbnail generation\n * These functions require a browser environment with Canvas support\n */\n\nconst THUMBNAIL_SIZE = 256\n\n/**\n * Result of processing an image file\n */\nexport interface ImageProcessingResult {\n /** Base64-encoded thumbnail data (without data URL prefix) */\n thumbnail: string\n /** Original image width */\n width: number\n /** Original image height */\n height: number\n}\n\n/**\n * Load an image from a File object\n */\nfunction loadImage(file: File): Promise<HTMLImageElement> {\n return new Promise((resolve, reject) => {\n const img = new Image()\n const objectUrl = URL.createObjectURL(file)\n\n img.onload = () => {\n URL.revokeObjectURL(objectUrl)\n resolve(img)\n }\n img.onerror = () => {\n URL.revokeObjectURL(objectUrl)\n reject(new Error('Failed to load image'))\n }\n img.src = objectUrl\n })\n}\n\n/**\n * Create a thumbnail from an image element\n * Returns base64 data without the data URL prefix\n */\nfunction createThumbnailFromImage(img: HTMLImageElement): string {\n const { width, height } = img\n const aspectRatio = width / height\n\n let thumbWidth: number\n let thumbHeight: number\n\n if (aspectRatio > 1) {\n thumbWidth = Math.min(THUMBNAIL_SIZE, width)\n thumbHeight = Math.floor(thumbWidth / aspectRatio)\n } else {\n thumbHeight = Math.min(THUMBNAIL_SIZE, height)\n thumbWidth = Math.floor(thumbHeight * aspectRatio)\n }\n\n const canvas = document.createElement('canvas')\n canvas.width = thumbWidth\n canvas.height = thumbHeight\n\n const ctx = canvas.getContext('2d')\n if (!ctx) {\n throw new Error('Failed to get canvas context')\n }\n\n ctx.drawImage(img, 0, 0, thumbWidth, thumbHeight)\n\n // Return WebP for smaller size, strip data URL prefix\n const dataUrl = canvas.toDataURL('image/webp', 0.8)\n return dataUrl.split(',')[1]\n}\n\n/**\n * Process an image file to generate a thumbnail\n * @param file - The image file to process\n * @returns Promise with thumbnail data and dimensions\n */\nexport async function generateImageThumbnail(file: File): Promise<ImageProcessingResult> {\n const img = await loadImage(file)\n\n return {\n thumbnail: createThumbnailFromImage(img),\n width: img.width,\n height: img.height,\n }\n}\n\n/**\n * Check if the current environment supports Canvas (for thumbnail generation)\n */\nexport function canGenerateThumbnails(): boolean {\n return typeof document !== 'undefined' && typeof document.createElement === 'function'\n}\n","/**\n * File upload helper utilities\n */\n\n/**\n * Generate a unique ID for pending file uploads.\n * Uses timestamp + random string to ensure uniqueness.\n */\nexport function generatePendingFileId(): string {\n return `pending-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`\n}\n\n/**\n * Read a file as a data URL for image preview.\n * Returns a base64-encoded data URL that can be used as an image src.\n */\nexport function readFileAsDataUrl(file: File): Promise<string> {\n return new Promise((resolve, reject) => {\n const reader = new FileReader()\n reader.onload = () => resolve(reader.result as string)\n reader.onerror = reject\n reader.readAsDataURL(file)\n })\n}\n","/**\n * FileUploadManager - Framework-agnostic file upload management\n *\n * Handles the common logic for file uploads across Vue and React packages.\n * Each framework integrates this manager with its own state management.\n */\n\nimport type { ThreadFile, AttachmentRef } from '../types'\nimport type { AgentBuilderClient } from '../client/AgentBuilderClient'\nimport { isImageMimeType } from '../utils/attachments'\nimport { generateImageThumbnail } from '../utils/imageProcessing'\nimport { generatePendingFileId, readFileAsDataUrl } from '../utils/fileHelpers'\n\n/**\n * Callback for receiving file state updates during upload\n */\nexport type FileUpdateCallback = (updates: Partial<ThreadFile>) => void\n\n/**\n * Options for upload execution\n */\nexport interface UploadOptions {\n /** Generate and upload thumbnail for images (default: true) */\n generateThumbnail?: boolean\n /** Generate local preview URL for images (default: true) */\n generatePreview?: boolean\n}\n\n/**\n * FileUploadManager handles the upload lifecycle for files.\n *\n * Usage:\n * 1. Call queueFiles() to create pending file objects for immediate UI display\n * 2. Call executeUpload() for each file to start the actual upload\n * 3. Receive state updates via the callback to update your framework's state\n *\n * @example\n * ```typescript\n * const manager = new FileUploadManager()\n *\n * // Queue files for UI display\n * const pendingFiles = manager.queueFiles(selectedFiles)\n * setState(prev => [...prev, ...pendingFiles])\n *\n * // Start uploads\n * for (const pending of pendingFiles) {\n * manager.executeUpload(threadId, file, pending.id, client, (updates) => {\n * setState(prev => prev.map(f =>\n * f.id === pending.id ? { ...f, ...updates } : f\n * ))\n * })\n * }\n * ```\n */\nexport class FileUploadManager {\n /**\n * Create a pending file object from a File.\n * The returned object can be immediately added to state for UI feedback.\n */\n createPendingFile(file: File): ThreadFile {\n return {\n id: generatePendingFileId(),\n name: file.name,\n mimeType: file.type,\n size: file.size,\n isImage: isImageMimeType(file.type),\n localPreviewUrl: null,\n status: 'uploading',\n }\n }\n\n /**\n * Queue multiple files for upload.\n * Returns an array of pending file objects paired with their source File objects.\n *\n * @param files - Files to queue (File array or FileList)\n * @returns Array of [ThreadFile, File] tuples\n */\n queueFiles(files: File[] | FileList): Array<{ pending: ThreadFile; file: File }> {\n return Array.from(files).map(file => ({\n pending: this.createPendingFile(file),\n file,\n }))\n }\n\n /**\n * Execute the upload for a file.\n *\n * This method:\n * 1. Generates a local preview for images (async, non-blocking)\n * 2. Generates a thumbnail for images (if supported)\n * 3. Uploads the file to the server\n * 4. Calls onUpdate with state changes at each step\n *\n * @param threadId - The thread to upload to\n * @param file - The file to upload\n * @param pendingId - The ID of the pending file (from queueFiles)\n * @param client - The AgentBuilderClient instance\n * @param onUpdate - Callback for state updates\n * @param options - Upload options\n */\n async executeUpload(\n threadId: string,\n file: File,\n pendingId: string,\n client: AgentBuilderClient,\n onUpdate: FileUpdateCallback,\n options: UploadOptions = {}\n ): Promise<AttachmentRef> {\n const {\n generateThumbnail = true,\n generatePreview = true,\n } = options\n\n const isImage = isImageMimeType(file.type)\n\n // Generate local preview for images (async, doesn't block upload)\n if (isImage && generatePreview) {\n readFileAsDataUrl(file)\n .then(dataUrl => onUpdate({ localPreviewUrl: dataUrl }))\n .catch(err => console.error('Failed to generate preview:', err))\n }\n\n try {\n // Prepare upload options for images\n let uploadOptions: Parameters<typeof client.uploadFile>[2] | undefined\n\n if (isImage && generateThumbnail) {\n try {\n const result = await generateImageThumbnail(file)\n uploadOptions = {\n thumbnail: result.thumbnail,\n width: result.width,\n height: result.height,\n }\n } catch (err) {\n // If thumbnail generation fails, continue without it\n console.warn('Failed to generate thumbnail:', err)\n }\n }\n\n // Upload the file\n const attachment = await client.uploadFile(threadId, file, uploadOptions)\n\n // Update with server response\n onUpdate({\n id: attachment.id,\n status: 'ready',\n path: attachment.path,\n width: attachment.width,\n height: attachment.height,\n })\n\n return attachment\n } catch (err) {\n // Update with error state\n onUpdate({\n status: 'error',\n error: err instanceof Error ? err.message : 'Failed to upload file',\n })\n throw err\n }\n }\n\n /**\n * Execute uploads for multiple files in parallel.\n *\n * @param threadId - The thread to upload to\n * @param items - Array of pending/file pairs from queueFiles()\n * @param client - The AgentBuilderClient instance\n * @param onUpdate - Callback receiving (pendingId, updates) for each file\n * @param options - Upload options\n * @returns Array of upload results (AttachmentRef or Error for each file)\n */\n async executeUploads(\n threadId: string,\n items: Array<{ pending: ThreadFile; file: File }>,\n client: AgentBuilderClient,\n onUpdate: (pendingId: string, updates: Partial<ThreadFile>) => void,\n options: UploadOptions = {}\n ): Promise<Array<AttachmentRef | Error>> {\n const promises = items.map(({ pending, file }) =>\n this.executeUpload(\n threadId,\n file,\n pending.id,\n client,\n (updates) => onUpdate(pending.id, updates),\n options\n ).catch(err => err instanceof Error ? err : new Error(String(err)))\n )\n\n return Promise.all(promises)\n }\n}\n","import type { Message, WorkMessage, WorkItem, ThreadMessage } from '../types'\n\n/**\n * Transform a flat list of messages into a list with workblocks.\n * Groups consecutive assistant tool_calls and their tool results into WorkMessage objects.\n *\n * A workblock starts when an assistant message has tool_calls,\n * and continues to include ALL subsequent messages until:\n * - A user message appears\n * - An assistant message without tool_calls appears\n *\n * This means multiple assistant messages with tool_calls in a row\n * (with their tool results in between) are merged into a single workblock.\n */\nexport function transformToWorkblocks(messages: Message[]): ThreadMessage[] {\n if (messages.length === 0) {\n return []\n }\n\n const result: ThreadMessage[] = []\n let i = 0\n\n while (i < messages.length) {\n const message = messages[i]\n\n // Check if this is an assistant message with tool_calls\n if (message.role === 'assistant' && message.tool_calls) {\n // Try to parse tool_calls\n let toolCalls: any[]\n try {\n toolCalls = JSON.parse(message.tool_calls)\n } catch (error) {\n // If we can't parse tool_calls, treat it as a regular message\n result.push(message)\n i++\n continue\n }\n\n // Start building a workblock\n const workItems: WorkItem[] = []\n const contentParts: string[] = []\n let reasoningContent: string | null = message.reasoning_content || null\n let workblockStatus: 'pending' | 'completed' | 'failed' = 'completed'\n const firstMessageId = message.id\n const firstCreatedAt = message.created_at\n let latestTimestamp = Math.max(\n message.created_at,\n message.response_completed_at ?? 0\n )\n let requestSentAt = message.request_sent_at ?? message.created_at\n const depth = message.depth\n const logIds = new Set<string>()\n if (message.log_id) logIds.add(message.log_id)\n\n // Track if the current assistant message is pending\n if (message.status === 'pending') {\n workblockStatus = 'pending'\n } else if (message.status === 'failed') {\n workblockStatus = 'failed'\n }\n\n // Collect content from the first assistant message\n if (message.content) {\n contentParts.push(message.content)\n }\n\n // Add tool calls as work items\n for (const toolCall of toolCalls) {\n workItems.push({\n id: toolCall.id || message.id,\n type: 'tool_call',\n name: toolCall.function?.name,\n content: toolCall.function?.arguments || null,\n status: null, // Will be updated below based on matching results\n tool_call_id: toolCall.id,\n created_at: message.created_at,\n log_id: message.log_id ?? null,\n })\n }\n\n // Continue collecting messages while we see tool results or more assistant tool_calls\n let j = i + 1\n while (j < messages.length) {\n const nextMessage = messages[j]\n\n if (nextMessage.role === 'tool') {\n latestTimestamp = Math.max(\n latestTimestamp,\n nextMessage.created_at,\n nextMessage.response_completed_at ?? 0\n )\n if (nextMessage.log_id) logIds.add(nextMessage.log_id)\n\n // Tool result - add to workblock\n const resultStatus = nextMessage.tool_status || 'pending'\n\n workItems.push({\n id: nextMessage.id,\n type: 'tool_result',\n name: nextMessage.name || undefined,\n content: nextMessage.content,\n status: resultStatus,\n tool_call_id: nextMessage.tool_call_id || undefined,\n created_at: nextMessage.created_at,\n log_id: nextMessage.log_id ?? null,\n })\n\n j++\n } else if (nextMessage.role === 'assistant' && nextMessage.tool_calls) {\n // Another assistant message with tool_calls - merge into same workblock\n let nextToolCalls: any[]\n try {\n nextToolCalls = JSON.parse(nextMessage.tool_calls)\n } catch (error) {\n // Can't parse, stop merging here\n break\n }\n\n // Update status if this message is pending/failed\n latestTimestamp = Math.max(\n latestTimestamp,\n nextMessage.created_at,\n nextMessage.response_completed_at ?? 0\n )\n requestSentAt = Math.min(\n requestSentAt,\n nextMessage.request_sent_at ?? nextMessage.created_at\n )\n if (nextMessage.log_id) logIds.add(nextMessage.log_id)\n\n // Update status if this message is pending/failed\n if (nextMessage.status === 'pending') {\n workblockStatus = 'pending'\n } else if (nextMessage.status === 'failed' && workblockStatus !== 'pending') {\n workblockStatus = 'failed'\n }\n\n // Collect content\n if (nextMessage.content) {\n contentParts.push(nextMessage.content)\n }\n\n // Collect reasoning content (use first non-null)\n if (!reasoningContent && nextMessage.reasoning_content) {\n reasoningContent = nextMessage.reasoning_content\n }\n\n // Add tool calls\n for (const toolCall of nextToolCalls) {\n workItems.push({\n id: toolCall.id || nextMessage.id,\n type: 'tool_call',\n name: toolCall.function?.name,\n content: toolCall.function?.arguments || null,\n status: null,\n tool_call_id: toolCall.id,\n created_at: nextMessage.created_at,\n log_id: nextMessage.log_id ?? null,\n })\n }\n j++\n } else {\n // User message or assistant without tool_calls - stop collecting\n break\n }\n }\n\n // Find orphaned tool_results (results without matching tool_calls) and create synthetic tool_calls\n const toolCallIds = new Set(workItems.filter(w => w.type === 'tool_call').map(w => w.tool_call_id))\n const orphanedResults = workItems.filter(\n w => w.type === 'tool_result' && w.tool_call_id && !toolCallIds.has(w.tool_call_id)\n )\n\n // Insert synthetic tool_calls for orphaned results\n for (const orphan of orphanedResults) {\n // Find the position of this orphan in workItems\n const orphanIndex = workItems.indexOf(orphan)\n // Extract tool name from error message or use generic\n const toolName = orphan.content?.match(/Tool not found: (\\w+)/)?.[1] || 'unknown_tool'\n\n // Insert a synthetic tool_call before the result\n const syntheticCall: WorkItem = {\n id: `synthetic-${orphan.tool_call_id}`,\n type: 'tool_call',\n name: toolName,\n content: null,\n status: orphan.status,\n tool_call_id: orphan.tool_call_id,\n created_at: orphan.created_at,\n log_id: orphan.log_id ?? null,\n }\n workItems.splice(orphanIndex, 0, syntheticCall)\n }\n\n // Update tool call statuses based on their matching results\n for (const item of workItems) {\n if (item.type === 'tool_call' && item.tool_call_id && item.status === null) {\n // Find matching result\n const matchingResult = workItems.find(\n wi => wi.type === 'tool_result' && wi.tool_call_id === item.tool_call_id\n )\n if (matchingResult) {\n // Tool call inherits status from its result\n item.status = matchingResult.status\n } else {\n // No result yet - tool call is pending\n item.status = 'pending'\n }\n }\n }\n\n // Combine content parts\n const combinedContent = contentParts.length > 0 ? contentParts.join('') : null\n\n // Create the workblock\n const workblock: WorkMessage = {\n id: firstMessageId,\n type: 'workblock',\n content: combinedContent,\n reasoning_content: reasoningContent,\n workItems,\n status: workblockStatus,\n created_at: firstCreatedAt,\n updated_at: latestTimestamp,\n request_sent_at: requestSentAt,\n response_completed_at: workblockStatus === 'pending' ? null : latestTimestamp,\n depth,\n log_ids: Array.from(logIds),\n }\n\n result.push(workblock)\n\n // Move index past all consumed messages\n i = j\n } else {\n // Not a workblock, pass through unchanged\n result.push(message)\n i++\n }\n }\n\n return result\n}\n","import type {\n Message,\n StatusMessage,\n SubagentBlockMessage,\n SubagentGroupBlockMessage,\n SubagentThreadMessage,\n ThreadMessage,\n WorkMessage,\n WorkItem,\n} from \"../types\"\nimport { transformToWorkblocks } from \"./workblocks\"\n\ntype TransformOptions = {\n includeWorkblocks?: boolean\n}\n\nconst SUBAGENT_TOOLS = new Set([\"subagent_create\", \"subagent_message\", \"send_to_agent\"])\nconst SUBAGENT_NAME_PATTERN = /subagent/i\n\nfunction isWorkblock(message: SubagentThreadMessage): message is WorkMessage {\n return (message as WorkMessage).type === \"workblock\"\n}\n\nfunction isStatusMessage(message: SubagentThreadMessage): message is StatusMessage {\n return (message as StatusMessage).type === \"status\"\n}\n\nfunction asOptionalString(value: unknown): string | null {\n if (typeof value !== \"string\") {\n return null\n }\n const normalized = value.trim()\n return normalized.length > 0 ? normalized : null\n}\n\nfunction getMetadataString(\n message: Message,\n key: string\n): string | null {\n if (!message.metadata || typeof message.metadata !== \"object\") {\n return null\n }\n return asOptionalString((message.metadata as Record<string, unknown>)[key])\n}\n\nfunction extractSubagentIdFromContent(content: string | null | undefined): string | null {\n if (!content) {\n return null\n }\n const fromToolResult = content.match(/Reference:\\s*([0-9a-fA-F-]{36})/)\n if (fromToolResult?.[1]) {\n return fromToolResult[1].toLowerCase()\n }\n const fromSubagentMessage = content.match(/reference:\\s*([0-9a-fA-F-]{36})/i)\n if (fromSubagentMessage?.[1]) {\n return fromSubagentMessage[1].toLowerCase()\n }\n return null\n}\n\nfunction inferSubagentStatus(message: Message): string | null {\n const explicit = asOptionalString(message.subagent_status)\n if (explicit) {\n return explicit\n }\n const content = message.content || \"\"\n if (/was initiated successfully/i.test(content) || /Message sent to subagent/i.test(content)) {\n return \"running\"\n }\n if (/has returned the following result/i.test(content)) {\n return \"idle\"\n }\n if (/has reported a failure/i.test(content) || /execution stopped before completion/i.test(content)) {\n return \"terminated\"\n }\n return null\n}\n\nfunction getSystemStatusKind(message: Message): StatusMessage[\"status_kind\"] | null {\n if (message.role !== \"system\") {\n return null\n }\n const metadataKind = getMetadataString(message, \"status_kind\")\n if (\n metadataKind === \"execution_stopped\" ||\n metadataKind === \"subagent_started\" ||\n metadataKind === \"subagent_event\"\n ) {\n return metadataKind\n }\n if (getMetadataString(message, \"subagent_event\") === \"parent_handoff\") {\n return \"subagent_event\"\n }\n const content = (message.content || \"\").trim()\n if (/execution\\s+stopped/i.test(content)) {\n return \"execution_stopped\"\n }\n if (/subagents?\\s+started:/i.test(content)) {\n return \"subagent_started\"\n }\n return null\n}\n\nfunction createSystemStatusMessage(message: Message): StatusMessage {\n const kind = getSystemStatusKind(message) ?? undefined\n return {\n id: `status:${message.id}`,\n type: \"status\",\n role: \"system\",\n content: message.content || \"Execution stopped by user\",\n created_at: message.created_at,\n depth: message.depth,\n silent: false,\n status_kind: kind,\n }\n}\n\nfunction isSubagentSignalMessage(message: Message): boolean {\n if (message.role === \"tool\" && asOptionalString(message.subagent_id)) {\n return true\n }\n\n if (message.role === \"tool\" && message.name && SUBAGENT_TOOLS.has(message.name)) {\n return true\n }\n\n const content = message.content || \"\"\n if (/subagent\\s*\\(reference:/i.test(content)) {\n return true\n }\n if (/the subagent was initiated successfully/i.test(content)) {\n return true\n }\n if (/message sent to subagent/i.test(content)) {\n return true\n }\n\n return false\n}\n\nfunction extractSubagentId(message: Message): string | null {\n const direct = asOptionalString(message.subagent_id)\n if (direct) {\n return direct\n }\n\n const metadata = message.metadata\n if (metadata && typeof metadata === \"object\") {\n const snake = asOptionalString((metadata as Record<string, unknown>).subagent_id)\n if (snake) {\n return snake\n }\n const camel = asOptionalString((metadata as Record<string, unknown>).subagentId)\n if (camel) {\n return camel\n }\n }\n\n return extractSubagentIdFromContent(message.content)\n}\n\nfunction parseToolCalls(toolCalls: string | null | undefined): Array<{\n id?: string\n function?: { name?: string }\n}> {\n if (!toolCalls) {\n return []\n }\n try {\n const parsed = JSON.parse(toolCalls)\n return Array.isArray(parsed) ? parsed : []\n } catch {\n return []\n }\n}\n\nfunction parseToolArguments(raw: string | null | undefined): Record<string, unknown> {\n if (!raw) {\n return {}\n }\n try {\n const parsed = JSON.parse(raw)\n return parsed && typeof parsed === \"object\" ? (parsed as Record<string, unknown>) : {}\n } catch {\n return {}\n }\n}\n\nfunction isLikelySubagentToolName(toolName: string | undefined): boolean {\n if (!toolName) {\n return false\n }\n if (SUBAGENT_TOOLS.has(toolName)) {\n return true\n }\n return SUBAGENT_NAME_PATTERN.test(toolName)\n}\n\nfunction getSubagentThreadNameFromWorkItem(item: WorkItem): string | null {\n const args = parseToolArguments(item.content)\n const name = asOptionalString(args.name)\n return name\n}\n\nfunction getSubagentIdFromWorkItem(\n item: WorkItem,\n toolCallIdToSubagentId: Map<string, string>\n): string | null {\n if (item.tool_call_id) {\n const mapped = toolCallIdToSubagentId.get(item.tool_call_id)\n if (mapped) {\n return mapped\n }\n }\n return extractSubagentIdFromContent(item.content)\n}\n\nfunction createSubagentBlock(\n subagentId: string,\n message: Message\n): SubagentBlockMessage {\n const inferredStatus = inferSubagentStatus(message)\n return {\n id: `subagent:${subagentId}`,\n type: \"subagent_block\",\n subagent_id: subagentId,\n subagent_name: message.subagent_name ?? null,\n subagent_title: message.subagent_title ?? null,\n subagent_description: message.subagent_description ?? null,\n subagent_status: inferredStatus ?? null,\n subagent_resumable: message.subagent_resumable ?? null,\n subagent_blocking: message.subagent_blocking ?? null,\n subagent_thread_name: message.subagent_thread_name ?? null,\n subagent_spawn_group_id: message.subagent_spawn_group_id ?? null,\n messages: [message],\n created_at: message.created_at,\n updated_at: message.created_at,\n depth: message.depth,\n }\n}\n\nfunction mergeSubagentBlock(block: SubagentBlockMessage, message: Message): void {\n block.messages.push(message)\n block.updated_at = Math.max(block.updated_at, message.created_at)\n block.created_at = Math.min(block.created_at, message.created_at)\n block.depth = message.depth ?? block.depth\n\n if (message.subagent_name !== undefined) {\n block.subagent_name = message.subagent_name ?? block.subagent_name ?? null\n }\n if (message.subagent_title !== undefined) {\n block.subagent_title = message.subagent_title ?? block.subagent_title ?? null\n }\n if (message.subagent_description !== undefined) {\n block.subagent_description =\n message.subagent_description ?? block.subagent_description ?? null\n }\n const inferredStatus = inferSubagentStatus(message)\n if (inferredStatus !== null) {\n block.subagent_status = inferredStatus\n }\n if (message.subagent_resumable !== undefined) {\n block.subagent_resumable =\n message.subagent_resumable ?? block.subagent_resumable ?? null\n }\n if (message.subagent_blocking !== undefined) {\n block.subagent_blocking =\n message.subagent_blocking ?? block.subagent_blocking ?? null\n }\n if (message.subagent_thread_name !== undefined) {\n block.subagent_thread_name =\n message.subagent_thread_name ?? block.subagent_thread_name ?? null\n }\n if (message.subagent_spawn_group_id !== undefined) {\n block.subagent_spawn_group_id =\n message.subagent_spawn_group_id ?? block.subagent_spawn_group_id ?? null\n }\n}\n\nfunction shouldSkipWorkblock(\n workblock: WorkMessage,\n resolvedSubagentIds: Set<string>\n): boolean {\n const toolCalls = workblock.workItems.filter((item) => item.type === \"tool_call\")\n if (toolCalls.length === 0) {\n return false\n }\n if (!toolCalls.every((item) => item.name && SUBAGENT_TOOLS.has(item.name))) {\n return false\n }\n return resolvedSubagentIds.size > 0\n}\n\nfunction inferBlockingFromToolResult(\n workblock: WorkMessage,\n toolCallId: string | undefined\n): boolean | null {\n if (!toolCallId) {\n return null\n }\n const result = workblock.workItems.find(\n (item) => item.type === \"tool_result\" && item.tool_call_id === toolCallId\n )\n if (!result || result.status !== \"success\") {\n return null\n }\n\n const text = (result.content || \"\").toLowerCase()\n if (text.includes(\"was initiated successfully\") || text.includes(\"results will be delivered when complete\")) {\n return false\n }\n if (text.length > 0) {\n return true\n }\n return null\n}\n\nfunction createPendingSubagentBlock(\n workblock: WorkMessage,\n toolCall: WorkItem,\n index: number,\n status: \"pending\" | \"running\"\n): SubagentBlockMessage {\n const toolName = asOptionalString(toolCall.name) ?? \"Subagent\"\n const pseudoSubagentId = toolCall.tool_call_id\n ? `pending:${toolCall.tool_call_id}`\n : `pending:${workblock.id}:${index}`\n const createdAt = workblock.created_at + index\n const isBuiltinLifecycleTool = !!toolCall.name && SUBAGENT_TOOLS.has(toolCall.name)\n\n return {\n id: `subagent:${pseudoSubagentId}`,\n type: \"subagent_block\",\n subagent_id: pseudoSubagentId,\n subagent_name: toolName,\n subagent_title: toolName,\n subagent_description: null,\n subagent_status: status,\n subagent_resumable: isBuiltinLifecycleTool ? true : false,\n subagent_blocking: isBuiltinLifecycleTool ? null : true,\n subagent_thread_name: getSubagentThreadNameFromWorkItem(toolCall),\n subagent_spawn_group_id: workblock.id,\n messages: [],\n created_at: createdAt,\n updated_at: createdAt,\n depth: workblock.depth,\n }\n}\n\ntype BlockPlacement = {\n block: SubagentBlockMessage\n startIndex: number | undefined\n displayIndex: number | undefined\n groupKey: string\n}\n\ntype BlockGroup = {\n groupKey: string\n startIndex: number | undefined\n displayIndex: number | undefined\n blocks: SubagentBlockMessage[]\n}\n\nfunction createGroupStartMarker(group: BlockGroup): StatusMessage | null {\n if (group.startIndex === undefined || group.displayIndex === undefined) {\n return null\n }\n if (group.startIndex === group.displayIndex) {\n return null\n }\n\n const names = group.blocks\n .map((block) => block.subagent_thread_name || block.subagent_title || block.subagent_name || \"Subagent\")\n .filter((name, index, arr) => arr.indexOf(name) === index)\n\n let label: string\n if (names.length <= 1) {\n label = `Subagent started: ${names[0] || \"Subagent\"}`\n } else if (names.length <= 3) {\n label = `Subagents started: ${names.join(\", \")}`\n } else {\n label = `Subagents started: ${names.length} subagents`\n }\n\n const createdAt =\n Math.min(...group.blocks.map((block) => block.created_at)) || Date.now() * 1000\n const depth = group.blocks[0]?.depth\n\n return {\n id: `subagent-start:${group.groupKey}`,\n type: \"status\",\n role: \"system\",\n content: label,\n created_at: createdAt,\n status_kind: \"subagent_started\",\n silent: false,\n depth,\n }\n}\n\nfunction getSubagentDisplayName(block: SubagentBlockMessage | undefined): string {\n return (\n block?.subagent_thread_name ||\n block?.subagent_title ||\n block?.subagent_name ||\n \"Subagent\"\n )\n}\n\nfunction createSubagentEventStatusMessage(\n message: Message,\n block: SubagentBlockMessage | undefined\n): StatusMessage | null {\n if (!message.content) {\n return null\n }\n\n const content = message.content\n const name = getSubagentDisplayName(block)\n\n let label: string | null = null\n if (/has returned the following result/i.test(content)) {\n label = `Subagent replied: ${name}`\n } else if (\n /has reported a failure/i.test(content) ||\n /execution stopped before completion/i.test(content)\n ) {\n label = `Subagent failed: ${name}`\n }\n\n if (!label) {\n return null\n }\n\n return {\n id: `status:subagent-event:${message.id}`,\n type: \"status\",\n role: \"system\",\n content: label,\n created_at: message.created_at,\n depth: message.depth,\n silent: false,\n status_kind: \"subagent_event\",\n subagent_id: block?.subagent_id ?? message.subagent_id ?? null,\n }\n}\n\nfunction buildGroupedBlock(group: BlockGroup): SubagentBlockMessage | SubagentGroupBlockMessage {\n if (group.blocks.length === 1) {\n return group.blocks[0]\n }\n\n const sorted = [...group.blocks].sort((a, b) => {\n const aName = (a.subagent_thread_name || a.subagent_title || a.subagent_name || \"\").toLowerCase()\n const bName = (b.subagent_thread_name || b.subagent_title || b.subagent_name || \"\").toLowerCase()\n if (aName !== bName) {\n return aName.localeCompare(bName)\n }\n return a.created_at - b.created_at\n })\n\n return {\n id: `subagent-group:${group.groupKey}`,\n type: \"subagent_group_block\",\n group_id: group.groupKey,\n subagents: sorted,\n created_at: Math.min(...sorted.map((block) => block.created_at)),\n updated_at: Math.max(...sorted.map((block) => block.updated_at)),\n depth: sorted[0]?.depth,\n }\n}\n\n/**\n * Transform thread messages into a stream that preserves workblocks while also\n * collapsing subagent-tagged messages into anchor-based subagent blocks.\n *\n * The subagent block is anchored to the originating `subagent_create` workblock\n * when possible, and subagent-tagged messages are rendered inside that block.\n */\nexport function transformToSubagentBlocks(\n messages: Message[],\n options: TransformOptions = {}\n): SubagentThreadMessage[] {\n if (messages.length === 0) {\n return []\n }\n\n const includeWorkblocks = options.includeWorkblocks ?? false\n const baseMessages: SubagentThreadMessage[] = includeWorkblocks\n ? (transformToWorkblocks(messages) as ThreadMessage[])\n : messages\n\n const toolCallIdToSubagentId = new Map<string, string>()\n for (const message of messages) {\n if (message.role !== \"tool\") {\n continue\n }\n if (!message.tool_call_id) {\n continue\n }\n const subagentId = extractSubagentId(message)\n if (subagentId) {\n toolCallIdToSubagentId.set(message.tool_call_id, subagentId)\n }\n }\n\n const anchorIndexBySubagentId = new Map<string, number>()\n const threadNameBySubagentId = new Map<string, string>()\n const inferredFlagsBySubagentId = new Map<\n string,\n { resumable: boolean | null; blocking: boolean | null }\n >()\n const pendingPlacements: BlockPlacement[] = []\n const skipWorkblockIndexes = new Set<number>()\n const indexByBaseEntryId = new Map<string, number>()\n\n baseMessages.forEach((entry, index) => {\n indexByBaseEntryId.set(entry.id, index)\n\n if (!isWorkblock(entry)) {\n return\n }\n\n const resolvedFromWorkblock = new Set<string>()\n const toolCalls = entry.workItems.filter((item) => item.type === \"tool_call\")\n const pendingSubagentToolCalls: WorkItem[] = []\n\n for (const toolCall of toolCalls) {\n if (!isLikelySubagentToolName(toolCall.name)) {\n continue\n }\n const subagentId = getSubagentIdFromWorkItem(toolCall, toolCallIdToSubagentId)\n if (!subagentId) {\n if (toolCall.status === \"pending\") {\n pendingSubagentToolCalls.push(toolCall)\n }\n continue\n }\n resolvedFromWorkblock.add(subagentId)\n if (!anchorIndexBySubagentId.has(subagentId)) {\n anchorIndexBySubagentId.set(subagentId, index)\n }\n const threadName = getSubagentThreadNameFromWorkItem(toolCall)\n if (threadName && !threadNameBySubagentId.has(subagentId)) {\n threadNameBySubagentId.set(subagentId, threadName)\n }\n\n const currentFlags = inferredFlagsBySubagentId.get(subagentId) ?? {\n resumable: null,\n blocking: null,\n }\n if (toolCall.name === \"subagent_create\" || toolCall.name === \"subagent_message\" || toolCall.name === \"send_to_agent\") {\n currentFlags.resumable = true\n }\n if (toolCall.name === \"subagent_create\") {\n const inferredBlocking = inferBlockingFromToolResult(entry, toolCall.tool_call_id)\n if (inferredBlocking !== null) {\n currentFlags.blocking = inferredBlocking\n }\n }\n inferredFlagsBySubagentId.set(subagentId, currentFlags)\n }\n\n if (pendingSubagentToolCalls.length > 0) {\n pendingSubagentToolCalls.forEach((toolCall, pendingIndex) => {\n const pendingStatus: \"pending\" | \"running\" =\n pendingIndex === 0 ? \"running\" : \"pending\"\n const block = createPendingSubagentBlock(\n entry,\n toolCall,\n pendingIndex,\n pendingStatus\n )\n pendingPlacements.push({\n block,\n startIndex: index,\n displayIndex: index,\n groupKey: `start:${index}`,\n })\n })\n }\n\n if (shouldSkipWorkblock(entry, resolvedFromWorkblock)) {\n skipWorkblockIndexes.add(index)\n }\n })\n\n const blocksBySubagentId = new Map<string, SubagentBlockMessage>()\n const signaledSubagentIds = new Set<string>()\n for (const message of messages) {\n const subagentId = extractSubagentId(message)\n if (!subagentId) {\n continue\n }\n if (isSubagentSignalMessage(message)) {\n signaledSubagentIds.add(subagentId)\n }\n }\n\n for (const message of messages) {\n const subagentId = extractSubagentId(message)\n if (!subagentId || !signaledSubagentIds.has(subagentId)) {\n continue\n }\n\n const existing = blocksBySubagentId.get(subagentId)\n if (!existing) {\n blocksBySubagentId.set(subagentId, createSubagentBlock(subagentId, message))\n } else {\n mergeSubagentBlock(existing, message)\n }\n }\n\n if (blocksBySubagentId.size === 0 && pendingPlacements.length === 0) {\n return baseMessages.map((entry) => {\n if (isStatusMessage(entry)) {\n return entry\n }\n if (isWorkblock(entry)) {\n return entry\n }\n const raw = entry as Message\n if (getSystemStatusKind(raw)) {\n return createSystemStatusMessage(raw)\n }\n return raw\n })\n }\n\n const placements: BlockPlacement[] = []\n const endAnchoredBlocks: SubagentBlockMessage[] = []\n\n for (const [subagentId, block] of blocksBySubagentId) {\n const inferredThreadName = threadNameBySubagentId.get(subagentId)\n if (!block.subagent_thread_name && inferredThreadName) {\n block.subagent_thread_name = inferredThreadName\n }\n const inferredFlags = inferredFlagsBySubagentId.get(subagentId)\n if (block.subagent_resumable === null && inferredFlags?.resumable !== null && inferredFlags?.resumable !== undefined) {\n block.subagent_resumable = inferredFlags.resumable\n }\n if (block.subagent_blocking === null && inferredFlags?.blocking !== null && inferredFlags?.blocking !== undefined) {\n block.subagent_blocking = inferredFlags.blocking\n }\n\n let startIndex = anchorIndexBySubagentId.get(subagentId)\n let displayIndex: number | undefined\n\n for (const childMessage of block.messages) {\n const messageIndex = indexByBaseEntryId.get(childMessage.id)\n if (messageIndex === undefined) {\n continue\n }\n if (displayIndex === undefined || messageIndex > displayIndex) {\n displayIndex = messageIndex\n }\n }\n\n if (startIndex === undefined && block.subagent_spawn_group_id) {\n startIndex = indexByBaseEntryId.get(block.subagent_spawn_group_id)\n }\n\n if (displayIndex === undefined) {\n if (startIndex !== undefined) {\n displayIndex = startIndex\n } else if (block.subagent_spawn_group_id) {\n displayIndex = indexByBaseEntryId.get(block.subagent_spawn_group_id)\n }\n }\n\n if (startIndex === undefined && displayIndex !== undefined) {\n startIndex = displayIndex\n }\n\n if (displayIndex === undefined) {\n endAnchoredBlocks.push(block)\n continue\n }\n\n const groupKey =\n block.subagent_spawn_group_id\n ? `spawn:${block.subagent_spawn_group_id}`\n : startIndex !== undefined\n ? `start:${startIndex}`\n : `subagent:${subagentId}`\n\n placements.push({\n block,\n startIndex,\n displayIndex,\n groupKey,\n })\n }\n\n for (const placement of pendingPlacements) {\n placements.push(placement)\n }\n\n const groupsByKey = new Map<string, BlockGroup>()\n for (const placement of placements) {\n const existing = groupsByKey.get(placement.groupKey)\n if (!existing) {\n groupsByKey.set(placement.groupKey, {\n groupKey: placement.groupKey,\n startIndex: placement.startIndex,\n displayIndex: placement.displayIndex,\n blocks: [placement.block],\n })\n continue\n }\n\n if (existing.startIndex === undefined) {\n existing.startIndex = placement.startIndex\n }\n if (placement.startIndex !== undefined && existing.startIndex !== undefined) {\n existing.startIndex = Math.min(existing.startIndex, placement.startIndex)\n }\n if (existing.displayIndex === undefined) {\n existing.displayIndex = placement.displayIndex\n }\n if (placement.displayIndex !== undefined && existing.displayIndex !== undefined) {\n existing.displayIndex = Math.max(existing.displayIndex, placement.displayIndex)\n }\n existing.blocks.push(placement.block)\n }\n\n const groupedByDisplayIndex = new Map<number, Array<SubagentBlockMessage | SubagentGroupBlockMessage>>()\n const startMarkersByIndex = new Map<number, StatusMessage[]>()\n const eventMarkersByIndex = new Map<number, StatusMessage[]>()\n\n for (const group of groupsByKey.values()) {\n const groupedBlock = buildGroupedBlock(group)\n if (group.displayIndex !== undefined) {\n const existing = groupedByDisplayIndex.get(group.displayIndex) ?? []\n existing.push(groupedBlock)\n groupedByDisplayIndex.set(group.displayIndex, existing)\n }\n\n const marker = createGroupStartMarker(group)\n if (marker && group.startIndex !== undefined) {\n const existing = startMarkersByIndex.get(group.startIndex) ?? []\n existing.push(marker)\n startMarkersByIndex.set(group.startIndex, existing)\n }\n }\n\n for (const rawMessage of messages) {\n const subagentId = extractSubagentId(rawMessage)\n if (!subagentId) {\n continue\n }\n const messageIndex = indexByBaseEntryId.get(rawMessage.id)\n if (messageIndex === undefined) {\n continue\n }\n const block = blocksBySubagentId.get(subagentId)\n const marker = createSubagentEventStatusMessage(rawMessage, block)\n if (!marker) {\n continue\n }\n const existing = eventMarkersByIndex.get(messageIndex) ?? []\n existing.push(marker)\n eventMarkersByIndex.set(messageIndex, existing)\n }\n\n for (const [displayIndex, items] of groupedByDisplayIndex) {\n items.sort((a, b) => a.created_at - b.created_at)\n groupedByDisplayIndex.set(displayIndex, items)\n }\n for (const [startIndex, markers] of startMarkersByIndex) {\n markers.sort((a, b) => a.created_at - b.created_at)\n startMarkersByIndex.set(startIndex, markers)\n }\n for (const [markerIndex, markers] of eventMarkersByIndex) {\n markers.sort((a, b) => a.created_at - b.created_at)\n eventMarkersByIndex.set(markerIndex, markers)\n }\n\n endAnchoredBlocks.sort((a, b) => a.created_at - b.created_at)\n\n const result: SubagentThreadMessage[] = []\n const insertedSubagentIds = new Set<string>()\n\n for (let i = 0; i < baseMessages.length; i++) {\n const startMarkers = startMarkersByIndex.get(i) ?? []\n for (const marker of startMarkers) {\n result.push(marker)\n }\n\n const eventMarkers = eventMarkersByIndex.get(i) ?? []\n for (const marker of eventMarkers) {\n result.push(marker)\n }\n\n const displayBlocks = groupedByDisplayIndex.get(i) ?? []\n for (const item of displayBlocks) {\n if ((item as SubagentGroupBlockMessage).type === \"subagent_group_block\") {\n const group = item as SubagentGroupBlockMessage\n for (const block of group.subagents) {\n insertedSubagentIds.add(block.subagent_id)\n }\n result.push(group)\n } else {\n const block = item as SubagentBlockMessage\n if (!insertedSubagentIds.has(block.subagent_id)) {\n result.push(block)\n insertedSubagentIds.add(block.subagent_id)\n }\n }\n }\n\n const entry = baseMessages[i]\n if (isStatusMessage(entry)) {\n result.push(entry)\n continue\n }\n\n if (isWorkblock(entry)) {\n if (skipWorkblockIndexes.has(i)) {\n continue\n }\n result.push(entry)\n continue\n }\n\n const rawEntry = entry as Message\n if (getSystemStatusKind(rawEntry)) {\n result.push(createSystemStatusMessage(rawEntry))\n continue\n }\n\n if (extractSubagentId(rawEntry)) {\n continue\n }\n result.push(rawEntry)\n }\n\n for (const block of endAnchoredBlocks) {\n if (!insertedSubagentIds.has(block.subagent_id)) {\n result.push(block)\n insertedSubagentIds.add(block.subagent_id)\n }\n }\n\n return result\n}\n"],"mappings":"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","names":["response"]}
|
package/package.json
CHANGED