@standardagents/client 0.12.8 → 0.13.0-next.c55f029

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/dist/index.d.ts CHANGED
@@ -16,7 +16,17 @@ interface Message {
16
16
  reasoning_details?: string | null;
17
17
  parent_id?: string | null;
18
18
  depth?: number;
19
+ metadata?: Record<string, unknown>;
19
20
  attachments?: string | AttachmentRef[] | null;
21
+ subagent_id?: string | null;
22
+ subagent_name?: string | null;
23
+ subagent_title?: string | null;
24
+ subagent_description?: string | null;
25
+ subagent_status?: string | null;
26
+ subagent_resumable?: boolean | null;
27
+ subagent_blocking?: boolean | null;
28
+ subagent_thread_name?: string | null;
29
+ subagent_spawn_group_id?: string | null;
20
30
  }
21
31
  /**
22
32
  * Attachment reference stored in messages.attachments (JSON array)
@@ -95,9 +105,53 @@ interface WorkMessage {
95
105
  status: "pending" | "completed" | "failed";
96
106
  created_at: number;
97
107
  depth?: number;
108
+ /**
109
+ * Deprecated: no longer auto-populated from tool-result attachments.
110
+ * Use real message attachments in thread history instead.
111
+ */
98
112
  attachments?: AttachmentRef[];
99
113
  }
114
+ interface SubagentBlockMessage {
115
+ id: string;
116
+ type: "subagent_block";
117
+ subagent_id: string;
118
+ subagent_name?: string | null;
119
+ subagent_title?: string | null;
120
+ subagent_description?: string | null;
121
+ subagent_status?: string | null;
122
+ subagent_resumable?: boolean | null;
123
+ subagent_blocking?: boolean | null;
124
+ subagent_thread_name?: string | null;
125
+ subagent_spawn_group_id?: string | null;
126
+ messages: Message[];
127
+ created_at: number;
128
+ updated_at: number;
129
+ depth?: number;
130
+ }
131
+ interface SubagentGroupBlockMessage {
132
+ id: string;
133
+ type: "subagent_group_block";
134
+ group_id: string;
135
+ subagents: SubagentBlockMessage[];
136
+ created_at: number;
137
+ updated_at: number;
138
+ depth?: number;
139
+ }
140
+ type StatusMessageKind = "execution_stopped" | "subagent_started" | "subagent_event";
141
+ interface StatusMessage {
142
+ id: string;
143
+ type: "status";
144
+ role: "system";
145
+ content: string;
146
+ created_at: number;
147
+ depth?: number;
148
+ silent?: false;
149
+ status_kind?: StatusMessageKind;
150
+ subagent_id?: string | null;
151
+ }
100
152
  type ThreadMessage = Message | WorkMessage;
153
+ type SubagentThreadMessage = Message | WorkMessage | SubagentBlockMessage | SubagentGroupBlockMessage | StatusMessage;
154
+ type GroupedThreadMessage = Message | WorkMessage | SubagentBlockMessage | SubagentGroupBlockMessage | StatusMessage;
101
155
  interface AgentBuilderConfig {
102
156
  endpoint: string;
103
157
  }
@@ -473,6 +527,18 @@ declare class FileUploadManager {
473
527
  */
474
528
  declare function transformToWorkblocks(messages: Message[]): ThreadMessage[];
475
529
 
530
+ type TransformOptions = {
531
+ includeWorkblocks?: boolean;
532
+ };
533
+ /**
534
+ * Transform thread messages into a stream that preserves workblocks while also
535
+ * collapsing subagent-tagged messages into anchor-based subagent blocks.
536
+ *
537
+ * The subagent block is anchored to the originating `subagent_create` workblock
538
+ * when possible, and subagent-tagged messages are rendered inside that block.
539
+ */
540
+ declare function transformToSubagentBlocks(messages: Message[], options?: TransformOptions): SubagentThreadMessage[];
541
+
476
542
  /**
477
543
  * Parse attachments from a message
478
544
  * Handles both JSON string and already-parsed array formats
@@ -529,4 +595,4 @@ declare function generatePendingFileId(): string;
529
595
  */
530
596
  declare function readFileAsDataUrl(file: File): Promise<string>;
531
597
 
532
- export { AgentBuilderClient, type AgentBuilderConfig, type AttachmentPayload, type AttachmentRef, type ConnectionStatus, type CreateThreadPayload, type CustomEvent, type ErrorEvent, type FileUpdateCallback, FileUploadManager, type GetMessagesOptions, type ImageProcessingResult, type LogDataEvent, type LogStreamEvent, type LogWebSocketCallbacks, type Message, type MessageChunkEvent, type MessageDataEvent, type MessageStreamEvent, type MessageWebSocketCallbacks, type PendingAttachment, type SendMessagePayload, type StoppedByUserEvent, 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, transformToWorkblocks };
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 };
package/dist/index.js CHANGED
@@ -710,7 +710,6 @@ function transformToWorkblocks(messages) {
710
710
  }
711
711
  const workItems = [];
712
712
  const contentParts = [];
713
- const collectedAttachments = [];
714
713
  let reasoningContent = message.reasoning_content || null;
715
714
  let workblockStatus = "completed";
716
715
  const firstMessageId = message.id;
@@ -748,20 +747,6 @@ function transformToWorkblocks(messages) {
748
747
  status: resultStatus,
749
748
  tool_call_id: nextMessage.tool_call_id || void 0
750
749
  });
751
- if (nextMessage.attachments) {
752
- try {
753
- let attachments;
754
- if (typeof nextMessage.attachments === "string") {
755
- attachments = JSON.parse(nextMessage.attachments);
756
- } else if (Array.isArray(nextMessage.attachments)) {
757
- attachments = nextMessage.attachments;
758
- } else {
759
- attachments = [];
760
- }
761
- collectedAttachments.push(...attachments);
762
- } catch {
763
- }
764
- }
765
750
  j++;
766
751
  } else if (nextMessage.role === "assistant" && nextMessage.tool_calls) {
767
752
  let nextToolCalls;
@@ -834,8 +819,7 @@ function transformToWorkblocks(messages) {
834
819
  workItems,
835
820
  status: workblockStatus,
836
821
  created_at: firstCreatedAt,
837
- depth,
838
- attachments: collectedAttachments.length > 0 ? collectedAttachments : void 0
822
+ depth
839
823
  };
840
824
  result.push(workblock);
841
825
  i = j;
@@ -846,6 +830,658 @@ function transformToWorkblocks(messages) {
846
830
  }
847
831
  return result;
848
832
  }
833
+
834
+ // src/utils/subagentBlocks.ts
835
+ var SUBAGENT_TOOLS = /* @__PURE__ */ new Set(["subagent_create", "subagent_message", "send_to_agent"]);
836
+ var SUBAGENT_NAME_PATTERN = /subagent/i;
837
+ function isWorkblock(message) {
838
+ return message.type === "workblock";
839
+ }
840
+ function isStatusMessage(message) {
841
+ return message.type === "status";
842
+ }
843
+ function asOptionalString(value) {
844
+ if (typeof value !== "string") {
845
+ return null;
846
+ }
847
+ const normalized = value.trim();
848
+ return normalized.length > 0 ? normalized : null;
849
+ }
850
+ function getMetadataString(message, key) {
851
+ if (!message.metadata || typeof message.metadata !== "object") {
852
+ return null;
853
+ }
854
+ return asOptionalString(message.metadata[key]);
855
+ }
856
+ function extractSubagentIdFromContent(content) {
857
+ if (!content) {
858
+ return null;
859
+ }
860
+ const fromToolResult = content.match(/Reference:\s*([0-9a-fA-F-]{36})/);
861
+ if (fromToolResult?.[1]) {
862
+ return fromToolResult[1].toLowerCase();
863
+ }
864
+ const fromSubagentMessage = content.match(/reference:\s*([0-9a-fA-F-]{36})/i);
865
+ if (fromSubagentMessage?.[1]) {
866
+ return fromSubagentMessage[1].toLowerCase();
867
+ }
868
+ return null;
869
+ }
870
+ function inferSubagentStatus(message) {
871
+ const explicit = asOptionalString(message.subagent_status);
872
+ if (explicit) {
873
+ return explicit;
874
+ }
875
+ const content = message.content || "";
876
+ if (/was initiated successfully/i.test(content) || /Message sent to subagent/i.test(content)) {
877
+ return "running";
878
+ }
879
+ if (/has returned the following result/i.test(content)) {
880
+ return "idle";
881
+ }
882
+ if (/has reported a failure/i.test(content) || /execution stopped before completion/i.test(content)) {
883
+ return "terminated";
884
+ }
885
+ return null;
886
+ }
887
+ function getSystemStatusKind(message) {
888
+ if (message.role !== "system") {
889
+ return null;
890
+ }
891
+ const metadataKind = getMetadataString(message, "status_kind");
892
+ if (metadataKind === "execution_stopped" || metadataKind === "subagent_started" || metadataKind === "subagent_event") {
893
+ return metadataKind;
894
+ }
895
+ if (getMetadataString(message, "subagent_event") === "parent_handoff") {
896
+ return "subagent_event";
897
+ }
898
+ const content = (message.content || "").trim();
899
+ if (/execution\s+stopped/i.test(content)) {
900
+ return "execution_stopped";
901
+ }
902
+ if (/subagents?\s+started:/i.test(content)) {
903
+ return "subagent_started";
904
+ }
905
+ return null;
906
+ }
907
+ function createSystemStatusMessage(message) {
908
+ const kind = getSystemStatusKind(message) ?? void 0;
909
+ return {
910
+ id: `status:${message.id}`,
911
+ type: "status",
912
+ role: "system",
913
+ content: message.content || "Execution stopped by user",
914
+ created_at: message.created_at,
915
+ depth: message.depth,
916
+ silent: false,
917
+ status_kind: kind
918
+ };
919
+ }
920
+ function isSubagentSignalMessage(message) {
921
+ if (message.role === "tool" && asOptionalString(message.subagent_id)) {
922
+ return true;
923
+ }
924
+ if (message.role === "tool" && message.name && SUBAGENT_TOOLS.has(message.name)) {
925
+ return true;
926
+ }
927
+ const content = message.content || "";
928
+ if (/subagent\s*\(reference:/i.test(content)) {
929
+ return true;
930
+ }
931
+ if (/the subagent was initiated successfully/i.test(content)) {
932
+ return true;
933
+ }
934
+ if (/message sent to subagent/i.test(content)) {
935
+ return true;
936
+ }
937
+ return false;
938
+ }
939
+ function extractSubagentId(message) {
940
+ const direct = asOptionalString(message.subagent_id);
941
+ if (direct) {
942
+ return direct;
943
+ }
944
+ const metadata = message.metadata;
945
+ if (metadata && typeof metadata === "object") {
946
+ const snake = asOptionalString(metadata.subagent_id);
947
+ if (snake) {
948
+ return snake;
949
+ }
950
+ const camel = asOptionalString(metadata.subagentId);
951
+ if (camel) {
952
+ return camel;
953
+ }
954
+ }
955
+ return extractSubagentIdFromContent(message.content);
956
+ }
957
+ function parseToolArguments(raw) {
958
+ if (!raw) {
959
+ return {};
960
+ }
961
+ try {
962
+ const parsed = JSON.parse(raw);
963
+ return parsed && typeof parsed === "object" ? parsed : {};
964
+ } catch {
965
+ return {};
966
+ }
967
+ }
968
+ function isLikelySubagentToolName(toolName) {
969
+ if (!toolName) {
970
+ return false;
971
+ }
972
+ if (SUBAGENT_TOOLS.has(toolName)) {
973
+ return true;
974
+ }
975
+ return SUBAGENT_NAME_PATTERN.test(toolName);
976
+ }
977
+ function getSubagentThreadNameFromWorkItem(item) {
978
+ const args = parseToolArguments(item.content);
979
+ const name = asOptionalString(args.name);
980
+ return name;
981
+ }
982
+ function getSubagentIdFromWorkItem(item, toolCallIdToSubagentId) {
983
+ if (item.tool_call_id) {
984
+ const mapped = toolCallIdToSubagentId.get(item.tool_call_id);
985
+ if (mapped) {
986
+ return mapped;
987
+ }
988
+ }
989
+ return extractSubagentIdFromContent(item.content);
990
+ }
991
+ function createSubagentBlock(subagentId, message) {
992
+ const inferredStatus = inferSubagentStatus(message);
993
+ return {
994
+ id: `subagent:${subagentId}`,
995
+ type: "subagent_block",
996
+ subagent_id: subagentId,
997
+ subagent_name: message.subagent_name ?? null,
998
+ subagent_title: message.subagent_title ?? null,
999
+ subagent_description: message.subagent_description ?? null,
1000
+ subagent_status: inferredStatus ?? null,
1001
+ subagent_resumable: message.subagent_resumable ?? null,
1002
+ subagent_blocking: message.subagent_blocking ?? null,
1003
+ subagent_thread_name: message.subagent_thread_name ?? null,
1004
+ subagent_spawn_group_id: message.subagent_spawn_group_id ?? null,
1005
+ messages: [message],
1006
+ created_at: message.created_at,
1007
+ updated_at: message.created_at,
1008
+ depth: message.depth
1009
+ };
1010
+ }
1011
+ function mergeSubagentBlock(block, message) {
1012
+ block.messages.push(message);
1013
+ block.updated_at = Math.max(block.updated_at, message.created_at);
1014
+ block.created_at = Math.min(block.created_at, message.created_at);
1015
+ block.depth = message.depth ?? block.depth;
1016
+ if (message.subagent_name !== void 0) {
1017
+ block.subagent_name = message.subagent_name ?? block.subagent_name ?? null;
1018
+ }
1019
+ if (message.subagent_title !== void 0) {
1020
+ block.subagent_title = message.subagent_title ?? block.subagent_title ?? null;
1021
+ }
1022
+ if (message.subagent_description !== void 0) {
1023
+ block.subagent_description = message.subagent_description ?? block.subagent_description ?? null;
1024
+ }
1025
+ const inferredStatus = inferSubagentStatus(message);
1026
+ if (inferredStatus !== null) {
1027
+ block.subagent_status = inferredStatus;
1028
+ }
1029
+ if (message.subagent_resumable !== void 0) {
1030
+ block.subagent_resumable = message.subagent_resumable ?? block.subagent_resumable ?? null;
1031
+ }
1032
+ if (message.subagent_blocking !== void 0) {
1033
+ block.subagent_blocking = message.subagent_blocking ?? block.subagent_blocking ?? null;
1034
+ }
1035
+ if (message.subagent_thread_name !== void 0) {
1036
+ block.subagent_thread_name = message.subagent_thread_name ?? block.subagent_thread_name ?? null;
1037
+ }
1038
+ if (message.subagent_spawn_group_id !== void 0) {
1039
+ block.subagent_spawn_group_id = message.subagent_spawn_group_id ?? block.subagent_spawn_group_id ?? null;
1040
+ }
1041
+ }
1042
+ function shouldSkipWorkblock(workblock, resolvedSubagentIds) {
1043
+ const toolCalls = workblock.workItems.filter((item) => item.type === "tool_call");
1044
+ if (toolCalls.length === 0) {
1045
+ return false;
1046
+ }
1047
+ if (!toolCalls.every((item) => item.name && SUBAGENT_TOOLS.has(item.name))) {
1048
+ return false;
1049
+ }
1050
+ return resolvedSubagentIds.size > 0;
1051
+ }
1052
+ function inferBlockingFromToolResult(workblock, toolCallId) {
1053
+ if (!toolCallId) {
1054
+ return null;
1055
+ }
1056
+ const result = workblock.workItems.find(
1057
+ (item) => item.type === "tool_result" && item.tool_call_id === toolCallId
1058
+ );
1059
+ if (!result || result.status !== "success") {
1060
+ return null;
1061
+ }
1062
+ const text = (result.content || "").toLowerCase();
1063
+ if (text.includes("was initiated successfully") || text.includes("results will be delivered when complete")) {
1064
+ return false;
1065
+ }
1066
+ if (text.length > 0) {
1067
+ return true;
1068
+ }
1069
+ return null;
1070
+ }
1071
+ function createPendingSubagentBlock(workblock, toolCall, index, status) {
1072
+ const toolName = asOptionalString(toolCall.name) ?? "Subagent";
1073
+ const pseudoSubagentId = toolCall.tool_call_id ? `pending:${toolCall.tool_call_id}` : `pending:${workblock.id}:${index}`;
1074
+ const createdAt = workblock.created_at + index;
1075
+ const isBuiltinLifecycleTool = !!toolCall.name && SUBAGENT_TOOLS.has(toolCall.name);
1076
+ return {
1077
+ id: `subagent:${pseudoSubagentId}`,
1078
+ type: "subagent_block",
1079
+ subagent_id: pseudoSubagentId,
1080
+ subagent_name: toolName,
1081
+ subagent_title: toolName,
1082
+ subagent_description: null,
1083
+ subagent_status: status,
1084
+ subagent_resumable: isBuiltinLifecycleTool ? true : false,
1085
+ subagent_blocking: isBuiltinLifecycleTool ? null : true,
1086
+ subagent_thread_name: getSubagentThreadNameFromWorkItem(toolCall),
1087
+ subagent_spawn_group_id: workblock.id,
1088
+ messages: [],
1089
+ created_at: createdAt,
1090
+ updated_at: createdAt,
1091
+ depth: workblock.depth
1092
+ };
1093
+ }
1094
+ function createGroupStartMarker(group) {
1095
+ if (group.startIndex === void 0 || group.displayIndex === void 0) {
1096
+ return null;
1097
+ }
1098
+ if (group.startIndex === group.displayIndex) {
1099
+ return null;
1100
+ }
1101
+ const names = group.blocks.map((block) => block.subagent_thread_name || block.subagent_title || block.subagent_name || "Subagent").filter((name, index, arr) => arr.indexOf(name) === index);
1102
+ let label;
1103
+ if (names.length <= 1) {
1104
+ label = `Subagent started: ${names[0] || "Subagent"}`;
1105
+ } else if (names.length <= 3) {
1106
+ label = `Subagents started: ${names.join(", ")}`;
1107
+ } else {
1108
+ label = `Subagents started: ${names.length} subagents`;
1109
+ }
1110
+ const createdAt = Math.min(...group.blocks.map((block) => block.created_at)) || Date.now() * 1e3;
1111
+ const depth = group.blocks[0]?.depth;
1112
+ return {
1113
+ id: `subagent-start:${group.groupKey}`,
1114
+ type: "status",
1115
+ role: "system",
1116
+ content: label,
1117
+ created_at: createdAt,
1118
+ status_kind: "subagent_started",
1119
+ silent: false,
1120
+ depth
1121
+ };
1122
+ }
1123
+ function getSubagentDisplayName(block) {
1124
+ return block?.subagent_thread_name || block?.subagent_title || block?.subagent_name || "Subagent";
1125
+ }
1126
+ function createSubagentEventStatusMessage(message, block) {
1127
+ if (!message.content) {
1128
+ return null;
1129
+ }
1130
+ const content = message.content;
1131
+ const name = getSubagentDisplayName(block);
1132
+ let label = null;
1133
+ if (/has returned the following result/i.test(content)) {
1134
+ label = `Subagent replied: ${name}`;
1135
+ } else if (/has reported a failure/i.test(content) || /execution stopped before completion/i.test(content)) {
1136
+ label = `Subagent failed: ${name}`;
1137
+ }
1138
+ if (!label) {
1139
+ return null;
1140
+ }
1141
+ return {
1142
+ id: `status:subagent-event:${message.id}`,
1143
+ type: "status",
1144
+ role: "system",
1145
+ content: label,
1146
+ created_at: message.created_at,
1147
+ depth: message.depth,
1148
+ silent: false,
1149
+ status_kind: "subagent_event",
1150
+ subagent_id: block?.subagent_id ?? message.subagent_id ?? null
1151
+ };
1152
+ }
1153
+ function buildGroupedBlock(group) {
1154
+ if (group.blocks.length === 1) {
1155
+ return group.blocks[0];
1156
+ }
1157
+ const sorted = [...group.blocks].sort((a, b) => {
1158
+ const aName = (a.subagent_thread_name || a.subagent_title || a.subagent_name || "").toLowerCase();
1159
+ const bName = (b.subagent_thread_name || b.subagent_title || b.subagent_name || "").toLowerCase();
1160
+ if (aName !== bName) {
1161
+ return aName.localeCompare(bName);
1162
+ }
1163
+ return a.created_at - b.created_at;
1164
+ });
1165
+ return {
1166
+ id: `subagent-group:${group.groupKey}`,
1167
+ type: "subagent_group_block",
1168
+ group_id: group.groupKey,
1169
+ subagents: sorted,
1170
+ created_at: Math.min(...sorted.map((block) => block.created_at)),
1171
+ updated_at: Math.max(...sorted.map((block) => block.updated_at)),
1172
+ depth: sorted[0]?.depth
1173
+ };
1174
+ }
1175
+ function transformToSubagentBlocks(messages, options = {}) {
1176
+ if (messages.length === 0) {
1177
+ return [];
1178
+ }
1179
+ const includeWorkblocks = options.includeWorkblocks ?? false;
1180
+ const baseMessages = includeWorkblocks ? transformToWorkblocks(messages) : messages;
1181
+ const toolCallIdToSubagentId = /* @__PURE__ */ new Map();
1182
+ for (const message of messages) {
1183
+ if (message.role !== "tool") {
1184
+ continue;
1185
+ }
1186
+ if (!message.tool_call_id) {
1187
+ continue;
1188
+ }
1189
+ const subagentId = extractSubagentId(message);
1190
+ if (subagentId) {
1191
+ toolCallIdToSubagentId.set(message.tool_call_id, subagentId);
1192
+ }
1193
+ }
1194
+ const anchorIndexBySubagentId = /* @__PURE__ */ new Map();
1195
+ const threadNameBySubagentId = /* @__PURE__ */ new Map();
1196
+ const inferredFlagsBySubagentId = /* @__PURE__ */ new Map();
1197
+ const pendingPlacements = [];
1198
+ const skipWorkblockIndexes = /* @__PURE__ */ new Set();
1199
+ const indexByBaseEntryId = /* @__PURE__ */ new Map();
1200
+ baseMessages.forEach((entry, index) => {
1201
+ indexByBaseEntryId.set(entry.id, index);
1202
+ if (!isWorkblock(entry)) {
1203
+ return;
1204
+ }
1205
+ const resolvedFromWorkblock = /* @__PURE__ */ new Set();
1206
+ const toolCalls = entry.workItems.filter((item) => item.type === "tool_call");
1207
+ const pendingSubagentToolCalls = [];
1208
+ for (const toolCall of toolCalls) {
1209
+ if (!isLikelySubagentToolName(toolCall.name)) {
1210
+ continue;
1211
+ }
1212
+ const subagentId = getSubagentIdFromWorkItem(toolCall, toolCallIdToSubagentId);
1213
+ if (!subagentId) {
1214
+ if (toolCall.status === "pending") {
1215
+ pendingSubagentToolCalls.push(toolCall);
1216
+ }
1217
+ continue;
1218
+ }
1219
+ resolvedFromWorkblock.add(subagentId);
1220
+ if (!anchorIndexBySubagentId.has(subagentId)) {
1221
+ anchorIndexBySubagentId.set(subagentId, index);
1222
+ }
1223
+ const threadName = getSubagentThreadNameFromWorkItem(toolCall);
1224
+ if (threadName && !threadNameBySubagentId.has(subagentId)) {
1225
+ threadNameBySubagentId.set(subagentId, threadName);
1226
+ }
1227
+ const currentFlags = inferredFlagsBySubagentId.get(subagentId) ?? {
1228
+ resumable: null,
1229
+ blocking: null
1230
+ };
1231
+ if (toolCall.name === "subagent_create" || toolCall.name === "subagent_message" || toolCall.name === "send_to_agent") {
1232
+ currentFlags.resumable = true;
1233
+ }
1234
+ if (toolCall.name === "subagent_create") {
1235
+ const inferredBlocking = inferBlockingFromToolResult(entry, toolCall.tool_call_id);
1236
+ if (inferredBlocking !== null) {
1237
+ currentFlags.blocking = inferredBlocking;
1238
+ }
1239
+ }
1240
+ inferredFlagsBySubagentId.set(subagentId, currentFlags);
1241
+ }
1242
+ if (pendingSubagentToolCalls.length > 0) {
1243
+ pendingSubagentToolCalls.forEach((toolCall, pendingIndex) => {
1244
+ const pendingStatus = pendingIndex === 0 ? "running" : "pending";
1245
+ const block = createPendingSubagentBlock(
1246
+ entry,
1247
+ toolCall,
1248
+ pendingIndex,
1249
+ pendingStatus
1250
+ );
1251
+ pendingPlacements.push({
1252
+ block,
1253
+ startIndex: index,
1254
+ displayIndex: index,
1255
+ groupKey: `start:${index}`
1256
+ });
1257
+ });
1258
+ }
1259
+ if (shouldSkipWorkblock(entry, resolvedFromWorkblock)) {
1260
+ skipWorkblockIndexes.add(index);
1261
+ }
1262
+ });
1263
+ const blocksBySubagentId = /* @__PURE__ */ new Map();
1264
+ const signaledSubagentIds = /* @__PURE__ */ new Set();
1265
+ for (const message of messages) {
1266
+ const subagentId = extractSubagentId(message);
1267
+ if (!subagentId) {
1268
+ continue;
1269
+ }
1270
+ if (isSubagentSignalMessage(message)) {
1271
+ signaledSubagentIds.add(subagentId);
1272
+ }
1273
+ }
1274
+ for (const message of messages) {
1275
+ const subagentId = extractSubagentId(message);
1276
+ if (!subagentId || !signaledSubagentIds.has(subagentId)) {
1277
+ continue;
1278
+ }
1279
+ const existing = blocksBySubagentId.get(subagentId);
1280
+ if (!existing) {
1281
+ blocksBySubagentId.set(subagentId, createSubagentBlock(subagentId, message));
1282
+ } else {
1283
+ mergeSubagentBlock(existing, message);
1284
+ }
1285
+ }
1286
+ if (blocksBySubagentId.size === 0 && pendingPlacements.length === 0) {
1287
+ return baseMessages.map((entry) => {
1288
+ if (isStatusMessage(entry)) {
1289
+ return entry;
1290
+ }
1291
+ if (isWorkblock(entry)) {
1292
+ return entry;
1293
+ }
1294
+ const raw = entry;
1295
+ if (getSystemStatusKind(raw)) {
1296
+ return createSystemStatusMessage(raw);
1297
+ }
1298
+ return raw;
1299
+ });
1300
+ }
1301
+ const placements = [];
1302
+ const endAnchoredBlocks = [];
1303
+ for (const [subagentId, block] of blocksBySubagentId) {
1304
+ const inferredThreadName = threadNameBySubagentId.get(subagentId);
1305
+ if (!block.subagent_thread_name && inferredThreadName) {
1306
+ block.subagent_thread_name = inferredThreadName;
1307
+ }
1308
+ const inferredFlags = inferredFlagsBySubagentId.get(subagentId);
1309
+ if (block.subagent_resumable === null && inferredFlags?.resumable !== null && inferredFlags?.resumable !== void 0) {
1310
+ block.subagent_resumable = inferredFlags.resumable;
1311
+ }
1312
+ if (block.subagent_blocking === null && inferredFlags?.blocking !== null && inferredFlags?.blocking !== void 0) {
1313
+ block.subagent_blocking = inferredFlags.blocking;
1314
+ }
1315
+ let startIndex = anchorIndexBySubagentId.get(subagentId);
1316
+ let displayIndex;
1317
+ for (const childMessage of block.messages) {
1318
+ const messageIndex = indexByBaseEntryId.get(childMessage.id);
1319
+ if (messageIndex === void 0) {
1320
+ continue;
1321
+ }
1322
+ if (displayIndex === void 0 || messageIndex > displayIndex) {
1323
+ displayIndex = messageIndex;
1324
+ }
1325
+ }
1326
+ if (startIndex === void 0 && block.subagent_spawn_group_id) {
1327
+ startIndex = indexByBaseEntryId.get(block.subagent_spawn_group_id);
1328
+ }
1329
+ if (displayIndex === void 0) {
1330
+ if (startIndex !== void 0) {
1331
+ displayIndex = startIndex;
1332
+ } else if (block.subagent_spawn_group_id) {
1333
+ displayIndex = indexByBaseEntryId.get(block.subagent_spawn_group_id);
1334
+ }
1335
+ }
1336
+ if (startIndex === void 0 && displayIndex !== void 0) {
1337
+ startIndex = displayIndex;
1338
+ }
1339
+ if (displayIndex === void 0) {
1340
+ endAnchoredBlocks.push(block);
1341
+ continue;
1342
+ }
1343
+ const groupKey = block.subagent_spawn_group_id ? `spawn:${block.subagent_spawn_group_id}` : startIndex !== void 0 ? `start:${startIndex}` : `subagent:${subagentId}`;
1344
+ placements.push({
1345
+ block,
1346
+ startIndex,
1347
+ displayIndex,
1348
+ groupKey
1349
+ });
1350
+ }
1351
+ for (const placement of pendingPlacements) {
1352
+ placements.push(placement);
1353
+ }
1354
+ const groupsByKey = /* @__PURE__ */ new Map();
1355
+ for (const placement of placements) {
1356
+ const existing = groupsByKey.get(placement.groupKey);
1357
+ if (!existing) {
1358
+ groupsByKey.set(placement.groupKey, {
1359
+ groupKey: placement.groupKey,
1360
+ startIndex: placement.startIndex,
1361
+ displayIndex: placement.displayIndex,
1362
+ blocks: [placement.block]
1363
+ });
1364
+ continue;
1365
+ }
1366
+ if (existing.startIndex === void 0) {
1367
+ existing.startIndex = placement.startIndex;
1368
+ }
1369
+ if (placement.startIndex !== void 0 && existing.startIndex !== void 0) {
1370
+ existing.startIndex = Math.min(existing.startIndex, placement.startIndex);
1371
+ }
1372
+ if (existing.displayIndex === void 0) {
1373
+ existing.displayIndex = placement.displayIndex;
1374
+ }
1375
+ if (placement.displayIndex !== void 0 && existing.displayIndex !== void 0) {
1376
+ existing.displayIndex = Math.max(existing.displayIndex, placement.displayIndex);
1377
+ }
1378
+ existing.blocks.push(placement.block);
1379
+ }
1380
+ const groupedByDisplayIndex = /* @__PURE__ */ new Map();
1381
+ const startMarkersByIndex = /* @__PURE__ */ new Map();
1382
+ const eventMarkersByIndex = /* @__PURE__ */ new Map();
1383
+ for (const group of groupsByKey.values()) {
1384
+ const groupedBlock = buildGroupedBlock(group);
1385
+ if (group.displayIndex !== void 0) {
1386
+ const existing = groupedByDisplayIndex.get(group.displayIndex) ?? [];
1387
+ existing.push(groupedBlock);
1388
+ groupedByDisplayIndex.set(group.displayIndex, existing);
1389
+ }
1390
+ const marker = createGroupStartMarker(group);
1391
+ if (marker && group.startIndex !== void 0) {
1392
+ const existing = startMarkersByIndex.get(group.startIndex) ?? [];
1393
+ existing.push(marker);
1394
+ startMarkersByIndex.set(group.startIndex, existing);
1395
+ }
1396
+ }
1397
+ for (const rawMessage of messages) {
1398
+ const subagentId = extractSubagentId(rawMessage);
1399
+ if (!subagentId) {
1400
+ continue;
1401
+ }
1402
+ const messageIndex = indexByBaseEntryId.get(rawMessage.id);
1403
+ if (messageIndex === void 0) {
1404
+ continue;
1405
+ }
1406
+ const block = blocksBySubagentId.get(subagentId);
1407
+ const marker = createSubagentEventStatusMessage(rawMessage, block);
1408
+ if (!marker) {
1409
+ continue;
1410
+ }
1411
+ const existing = eventMarkersByIndex.get(messageIndex) ?? [];
1412
+ existing.push(marker);
1413
+ eventMarkersByIndex.set(messageIndex, existing);
1414
+ }
1415
+ for (const [displayIndex, items] of groupedByDisplayIndex) {
1416
+ items.sort((a, b) => a.created_at - b.created_at);
1417
+ groupedByDisplayIndex.set(displayIndex, items);
1418
+ }
1419
+ for (const [startIndex, markers] of startMarkersByIndex) {
1420
+ markers.sort((a, b) => a.created_at - b.created_at);
1421
+ startMarkersByIndex.set(startIndex, markers);
1422
+ }
1423
+ for (const [markerIndex, markers] of eventMarkersByIndex) {
1424
+ markers.sort((a, b) => a.created_at - b.created_at);
1425
+ eventMarkersByIndex.set(markerIndex, markers);
1426
+ }
1427
+ endAnchoredBlocks.sort((a, b) => a.created_at - b.created_at);
1428
+ const result = [];
1429
+ const insertedSubagentIds = /* @__PURE__ */ new Set();
1430
+ for (let i = 0; i < baseMessages.length; i++) {
1431
+ const startMarkers = startMarkersByIndex.get(i) ?? [];
1432
+ for (const marker of startMarkers) {
1433
+ result.push(marker);
1434
+ }
1435
+ const eventMarkers = eventMarkersByIndex.get(i) ?? [];
1436
+ for (const marker of eventMarkers) {
1437
+ result.push(marker);
1438
+ }
1439
+ const displayBlocks = groupedByDisplayIndex.get(i) ?? [];
1440
+ for (const item of displayBlocks) {
1441
+ if (item.type === "subagent_group_block") {
1442
+ const group = item;
1443
+ for (const block of group.subagents) {
1444
+ insertedSubagentIds.add(block.subagent_id);
1445
+ }
1446
+ result.push(group);
1447
+ } else {
1448
+ const block = item;
1449
+ if (!insertedSubagentIds.has(block.subagent_id)) {
1450
+ result.push(block);
1451
+ insertedSubagentIds.add(block.subagent_id);
1452
+ }
1453
+ }
1454
+ }
1455
+ const entry = baseMessages[i];
1456
+ if (isStatusMessage(entry)) {
1457
+ result.push(entry);
1458
+ continue;
1459
+ }
1460
+ if (isWorkblock(entry)) {
1461
+ if (skipWorkblockIndexes.has(i)) {
1462
+ continue;
1463
+ }
1464
+ result.push(entry);
1465
+ continue;
1466
+ }
1467
+ const rawEntry = entry;
1468
+ if (getSystemStatusKind(rawEntry)) {
1469
+ result.push(createSystemStatusMessage(rawEntry));
1470
+ continue;
1471
+ }
1472
+ if (extractSubagentId(rawEntry)) {
1473
+ continue;
1474
+ }
1475
+ result.push(rawEntry);
1476
+ }
1477
+ for (const block of endAnchoredBlocks) {
1478
+ if (!insertedSubagentIds.has(block.subagent_id)) {
1479
+ result.push(block);
1480
+ insertedSubagentIds.add(block.subagent_id);
1481
+ }
1482
+ }
1483
+ return result;
1484
+ }
849
1485
  export {
850
1486
  AgentBuilderClient,
851
1487
  FileUploadManager,
@@ -857,6 +1493,7 @@ export {
857
1493
  messagesToFiles,
858
1494
  parseAttachments,
859
1495
  readFileAsDataUrl,
1496
+ transformToSubagentBlocks,
860
1497
  transformToWorkblocks
861
1498
  };
862
1499
  //# sourceMappingURL=index.js.map
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"],"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, AttachmentRef } 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 const collectedAttachments: AttachmentRef[] = []\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 // Collect attachments from tool results\n // Handle both JSON string and already-parsed array formats\n if (nextMessage.attachments) {\n try {\n let attachments: AttachmentRef[]\n if (typeof nextMessage.attachments === 'string') {\n attachments = JSON.parse(nextMessage.attachments) as AttachmentRef[]\n } else if (Array.isArray(nextMessage.attachments)) {\n attachments = nextMessage.attachments as unknown as AttachmentRef[]\n } else {\n attachments = []\n }\n collectedAttachments.push(...attachments)\n } catch {\n // Ignore parse errors\n }\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 attachments: collectedAttachments.length > 0 ? collectedAttachments : undefined,\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"],"mappings":"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","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 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":"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","names":["response"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@standardagents/client",
3
- "version": "0.12.8",
3
+ "version": "0.13.0-next.c55f029",
4
4
  "private": false,
5
5
  "publishConfig": {
6
6
  "access": "restricted",