source dump of claude code
at main 206 lines 24 kB view raw
1import { c as _c } from "react/compiler-runtime"; 2import type { TextBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'; 3import figures from 'figures'; 4import * as React from 'react'; 5import { TEAMMATE_MESSAGE_TAG } from '../../constants/xml.js'; 6import { Ansi, Box, Text, type TextProps } from '../../ink.js'; 7import { toInkColor } from '../../utils/ink.js'; 8import { jsonParse } from '../../utils/slowOperations.js'; 9import { isShutdownApproved } from '../../utils/teammateMailbox.js'; 10import { MessageResponse } from '../MessageResponse.js'; 11import { tryRenderPlanApprovalMessage } from './PlanApprovalMessage.js'; 12import { tryRenderShutdownMessage } from './ShutdownMessage.js'; 13import { tryRenderTaskAssignmentMessage } from './TaskAssignmentMessage.js'; 14type Props = { 15 addMargin: boolean; 16 param: TextBlockParam; 17 isTranscriptMode?: boolean; 18}; 19type ParsedMessage = { 20 teammateId: string; 21 content: string; 22 color?: string; 23 summary?: string; 24}; 25const TEAMMATE_MSG_REGEX = new RegExp(`<${TEAMMATE_MESSAGE_TAG}\\s+teammate_id="([^"]+)"(?:\\s+color="([^"]+)")?(?:\\s+summary="([^"]+)")?>\\n?([\\s\\S]*?)\\n?<\\/${TEAMMATE_MESSAGE_TAG}>`, 'g'); 26 27/** 28 * Parse all teammate messages from XML format: 29 * <teammate-message teammate_id="alice" color="red" summary="Brief update">message content</teammate-message> 30 * Supports multiple messages in a single text block. 31 */ 32function parseTeammateMessages(text: string): ParsedMessage[] { 33 const messages: ParsedMessage[] = []; 34 // Use matchAll to find all matches (this is a RegExp method, not child_process) 35 for (const match of text.matchAll(TEAMMATE_MSG_REGEX)) { 36 if (match[1] && match[4]) { 37 messages.push({ 38 teammateId: match[1], 39 color: match[2], 40 // may be undefined 41 summary: match[3], 42 // may be undefined 43 content: match[4].trim() 44 }); 45 } 46 } 47 return messages; 48} 49function getDisplayName(teammateId: string): string { 50 if (teammateId === 'leader') { 51 return 'leader'; 52 } 53 return teammateId; 54} 55export function UserTeammateMessage({ 56 addMargin, 57 param: { 58 text 59 }, 60 isTranscriptMode 61}: Props): React.ReactNode { 62 const messages = parseTeammateMessages(text).filter(msg => { 63 // Pre-filter shutdown lifecycle messages to avoid empty wrapper 64 // Box elements creating blank lines between model turns 65 if (isShutdownApproved(msg.content)) { 66 return false; 67 } 68 try { 69 const parsed = jsonParse(msg.content); 70 if (parsed?.type === 'teammate_terminated') return false; 71 } catch { 72 // Not JSON, keep the message 73 } 74 return true; 75 }); 76 if (messages.length === 0) { 77 return null; 78 } 79 return <Box flexDirection="column" marginTop={addMargin ? 1 : 0} width="100%"> 80 {messages.map((msg_0, index) => { 81 const inkColor = toInkColor(msg_0.color); 82 const displayName = getDisplayName(msg_0.teammateId); 83 84 // Try to render as plan approval message (request or response) 85 const planApprovalElement = tryRenderPlanApprovalMessage(msg_0.content, displayName); 86 if (planApprovalElement) { 87 return <React.Fragment key={index}>{planApprovalElement}</React.Fragment>; 88 } 89 90 // Try to render as shutdown message (request or rejected) 91 const shutdownElement = tryRenderShutdownMessage(msg_0.content); 92 if (shutdownElement) { 93 return <React.Fragment key={index}>{shutdownElement}</React.Fragment>; 94 } 95 96 // Try to render as task assignment message 97 const taskAssignmentElement = tryRenderTaskAssignmentMessage(msg_0.content); 98 if (taskAssignmentElement) { 99 return <React.Fragment key={index}>{taskAssignmentElement}</React.Fragment>; 100 } 101 102 // Try to parse as structured JSON message 103 let parsedIdleNotification: { 104 type?: string; 105 } | null = null; 106 try { 107 parsedIdleNotification = jsonParse(msg_0.content); 108 } catch { 109 // Not JSON 110 } 111 112 // Hide idle notifications - they are processed silently 113 if (parsedIdleNotification?.type === 'idle_notification') { 114 return null; 115 } 116 117 // Task completed notification - show which task was completed 118 if (parsedIdleNotification?.type === 'task_completed') { 119 const taskCompleted = parsedIdleNotification as { 120 type: string; 121 from: string; 122 taskId: string; 123 taskSubject?: string; 124 }; 125 return <Box key={index} flexDirection="column" marginTop={1}> 126 <Text color={inkColor}>{`@${displayName}${figures.pointer}`}</Text> 127 <MessageResponse> 128 <Text color="success"></Text> 129 <Text> 130 {' '} 131 Completed task #{taskCompleted.taskId} 132 {taskCompleted.taskSubject && <Text dimColor> ({taskCompleted.taskSubject})</Text>} 133 </Text> 134 </MessageResponse> 135 </Box>; 136 } 137 138 // Default: plain text message (truncated) 139 return <TeammateMessageContent key={index} displayName={displayName} inkColor={inkColor} content={msg_0.content} summary={msg_0.summary} isTranscriptMode={isTranscriptMode} />; 140 })} 141 </Box>; 142} 143type TeammateMessageContentProps = { 144 displayName: string; 145 inkColor: TextProps['color']; 146 content: string; 147 summary?: string; 148 isTranscriptMode?: boolean; 149}; 150export function TeammateMessageContent(t0) { 151 const $ = _c(14); 152 const { 153 displayName, 154 inkColor, 155 content, 156 summary, 157 isTranscriptMode 158 } = t0; 159 const t1 = `@${displayName}${figures.pointer}`; 160 let t2; 161 if ($[0] !== inkColor || $[1] !== t1) { 162 t2 = <Text color={inkColor}>{t1}</Text>; 163 $[0] = inkColor; 164 $[1] = t1; 165 $[2] = t2; 166 } else { 167 t2 = $[2]; 168 } 169 let t3; 170 if ($[3] !== summary) { 171 t3 = summary && <Text> {summary}</Text>; 172 $[3] = summary; 173 $[4] = t3; 174 } else { 175 t3 = $[4]; 176 } 177 let t4; 178 if ($[5] !== t2 || $[6] !== t3) { 179 t4 = <Box>{t2}{t3}</Box>; 180 $[5] = t2; 181 $[6] = t3; 182 $[7] = t4; 183 } else { 184 t4 = $[7]; 185 } 186 let t5; 187 if ($[8] !== content || $[9] !== isTranscriptMode) { 188 t5 = isTranscriptMode && <Box paddingLeft={2}><Text><Ansi>{content}</Ansi></Text></Box>; 189 $[8] = content; 190 $[9] = isTranscriptMode; 191 $[10] = t5; 192 } else { 193 t5 = $[10]; 194 } 195 let t6; 196 if ($[11] !== t4 || $[12] !== t5) { 197 t6 = <Box flexDirection="column" marginTop={1}>{t4}{t5}</Box>; 198 $[11] = t4; 199 $[12] = t5; 200 $[13] = t6; 201 } else { 202 t6 = $[13]; 203 } 204 return t6; 205} 206//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["TextBlockParam","figures","React","TEAMMATE_MESSAGE_TAG","Ansi","Box","Text","TextProps","toInkColor","jsonParse","isShutdownApproved","MessageResponse","tryRenderPlanApprovalMessage","tryRenderShutdownMessage","tryRenderTaskAssignmentMessage","Props","addMargin","param","isTranscriptMode","ParsedMessage","teammateId","content","color","summary","TEAMMATE_MSG_REGEX","RegExp","parseTeammateMessages","text","messages","match","matchAll","push","trim","getDisplayName","UserTeammateMessage","ReactNode","filter","msg","parsed","type","length","map","index","inkColor","displayName","planApprovalElement","shutdownElement","taskAssignmentElement","parsedIdleNotification","taskCompleted","from","taskId","taskSubject","pointer","TeammateMessageContentProps","TeammateMessageContent","t0","$","_c","t1","t2","t3","t4","t5","t6"],"sources":["UserTeammateMessage.tsx"],"sourcesContent":["import type { TextBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'\nimport figures from 'figures'\nimport * as React from 'react'\nimport { TEAMMATE_MESSAGE_TAG } from '../../constants/xml.js'\nimport { Ansi, Box, Text, type TextProps } from '../../ink.js'\nimport { toInkColor } from '../../utils/ink.js'\nimport { jsonParse } from '../../utils/slowOperations.js'\nimport { isShutdownApproved } from '../../utils/teammateMailbox.js'\nimport { MessageResponse } from '../MessageResponse.js'\nimport { tryRenderPlanApprovalMessage } from './PlanApprovalMessage.js'\nimport { tryRenderShutdownMessage } from './ShutdownMessage.js'\nimport { tryRenderTaskAssignmentMessage } from './TaskAssignmentMessage.js'\n\ntype Props = {\n  addMargin: boolean\n  param: TextBlockParam\n  isTranscriptMode?: boolean\n}\n\ntype ParsedMessage = {\n  teammateId: string\n  content: string\n  color?: string\n  summary?: string\n}\n\nconst TEAMMATE_MSG_REGEX = new RegExp(\n  `<${TEAMMATE_MESSAGE_TAG}\\\\s+teammate_id=\"([^\"]+)\"(?:\\\\s+color=\"([^\"]+)\")?(?:\\\\s+summary=\"([^\"]+)\")?>\\\\n?([\\\\s\\\\S]*?)\\\\n?<\\\\/${TEAMMATE_MESSAGE_TAG}>`,\n  'g',\n)\n\n/**\n * Parse all teammate messages from XML format:\n * <teammate-message teammate_id=\"alice\" color=\"red\" summary=\"Brief update\">message content</teammate-message>\n * Supports multiple messages in a single text block.\n */\nfunction parseTeammateMessages(text: string): ParsedMessage[] {\n  const messages: ParsedMessage[] = []\n  // Use matchAll to find all matches (this is a RegExp method, not child_process)\n  for (const match of text.matchAll(TEAMMATE_MSG_REGEX)) {\n    if (match[1] && match[4]) {\n      messages.push({\n        teammateId: match[1],\n        color: match[2], // may be undefined\n        summary: match[3], // may be undefined\n        content: match[4].trim(),\n      })\n    }\n  }\n\n  return messages\n}\n\nfunction getDisplayName(teammateId: string): string {\n  if (teammateId === 'leader') {\n    return 'leader'\n  }\n  return teammateId\n}\n\nexport function UserTeammateMessage({\n  addMargin,\n  param: { text },\n  isTranscriptMode,\n}: Props): React.ReactNode {\n  const messages = parseTeammateMessages(text).filter(msg => {\n    // Pre-filter shutdown lifecycle messages to avoid empty wrapper\n    // Box elements creating blank lines between model turns\n    if (isShutdownApproved(msg.content)) {\n      return false\n    }\n    try {\n      const parsed = jsonParse(msg.content)\n      if (parsed?.type === 'teammate_terminated') return false\n    } catch {\n      // Not JSON, keep the message\n    }\n    return true\n  })\n  if (messages.length === 0) {\n    return null\n  }\n\n  return (\n    <Box flexDirection=\"column\" marginTop={addMargin ? 1 : 0} width=\"100%\">\n      {messages.map((msg, index) => {\n        const inkColor = toInkColor(msg.color)\n        const displayName = getDisplayName(msg.teammateId)\n\n        // Try to render as plan approval message (request or response)\n        const planApprovalElement = tryRenderPlanApprovalMessage(\n          msg.content,\n          displayName,\n        )\n        if (planApprovalElement) {\n          return (\n            <React.Fragment key={index}>{planApprovalElement}</React.Fragment>\n          )\n        }\n\n        // Try to render as shutdown message (request or rejected)\n        const shutdownElement = tryRenderShutdownMessage(msg.content)\n        if (shutdownElement) {\n          return <React.Fragment key={index}>{shutdownElement}</React.Fragment>\n        }\n\n        // Try to render as task assignment message\n        const taskAssignmentElement = tryRenderTaskAssignmentMessage(\n          msg.content,\n        )\n        if (taskAssignmentElement) {\n          return (\n            <React.Fragment key={index}>{taskAssignmentElement}</React.Fragment>\n          )\n        }\n\n        // Try to parse as structured JSON message\n        let parsedIdleNotification: { type?: string } | null = null\n        try {\n          parsedIdleNotification = jsonParse(msg.content)\n        } catch {\n          // Not JSON\n        }\n\n        // Hide idle notifications - they are processed silently\n        if (parsedIdleNotification?.type === 'idle_notification') {\n          return null\n        }\n\n        // Task completed notification - show which task was completed\n        if (parsedIdleNotification?.type === 'task_completed') {\n          const taskCompleted = parsedIdleNotification as {\n            type: string\n            from: string\n            taskId: string\n            taskSubject?: string\n          }\n          return (\n            <Box key={index} flexDirection=\"column\" marginTop={1}>\n              <Text\n                color={inkColor}\n              >{`@${displayName}${figures.pointer}`}</Text>\n              <MessageResponse>\n                <Text color=\"success\">✓</Text>\n                <Text>\n                  {' '}\n                  Completed task #{taskCompleted.taskId}\n                  {taskCompleted.taskSubject && (\n                    <Text dimColor> ({taskCompleted.taskSubject})</Text>\n                  )}\n                </Text>\n              </MessageResponse>\n            </Box>\n          )\n        }\n\n        // Default: plain text message (truncated)\n        return (\n          <TeammateMessageContent\n            key={index}\n            displayName={displayName}\n            inkColor={inkColor}\n            content={msg.content}\n            summary={msg.summary}\n            isTranscriptMode={isTranscriptMode}\n          />\n        )\n      })}\n    </Box>\n  )\n}\n\ntype TeammateMessageContentProps = {\n  displayName: string\n  inkColor: TextProps['color']\n  content: string\n  summary?: string\n  isTranscriptMode?: boolean\n}\n\nexport function TeammateMessageContent({\n  displayName,\n  inkColor,\n  content,\n  summary,\n  isTranscriptMode,\n}: TeammateMessageContentProps): React.ReactNode {\n  return (\n    <Box flexDirection=\"column\" marginTop={1}>\n      <Box>\n        <Text color={inkColor}>{`@${displayName}${figures.pointer}`}</Text>\n        {summary && <Text> {summary}</Text>}\n      </Box>\n      {isTranscriptMode && (\n        <Box paddingLeft={2}>\n          <Text>\n            <Ansi>{content}</Ansi>\n          </Text>\n        </Box>\n      )}\n    </Box>\n  )\n}\n"],"mappings":"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","ignoreList":[]}