PlanApprovalMessage.tsx
components/messages/PlanApprovalMessage.tsx
222
Lines
25339
Bytes
4
Exports
8
Imports
10
Keywords
What this is
This page documents one file from the repository and includes its full source so you can read it without leaving the docs site.
Beginner explanation
This file is one piece of the larger system. Its name, directory, imports, and exports show where it fits. Start by reading the exports and related files first.
How it is used
Start from the exports list and related files. Those are the easiest clues for where this file fits into the system.
Expert explanation
Architecturally, this file intersects with planner-verifier-agents, ui-flow. It contains 222 lines, 8 detected imports, and 4 detected exports.
Important relationships
- components/messages/AdvisorMessage.tsx
- components/messages/AssistantRedactedThinkingMessage.tsx
- components/messages/AssistantTextMessage.tsx
- components/messages/AssistantThinkingMessage.tsx
- components/messages/AssistantToolUseMessage.tsx
- components/messages/AttachmentMessage.tsx
- components/messages/CollapsedReadSearchContent.tsx
- components/messages/CompactBoundaryMessage.tsx
Detected exports
PlanApprovalRequestDisplayPlanApprovalResponseDisplaytryRenderPlanApprovalMessageformatTeammateMessageContent
Keywords
requestplancontenttextresponseelsesendernamemessageapprovalflexdirection
Detected imports
react/compiler-runtimereact../../components/Markdown.js../../ink.js../../utils/slowOperations.js../../utils/teammateMailbox.js./ShutdownMessage.js./TaskAssignmentMessage.js
Source notes
This page embeds the full file contents. Small or leaf files are still indexed honestly instead of being over-explained.
Full source
import { c as _c } from "react/compiler-runtime";
import * as React from 'react';
import { Markdown } from '../../components/Markdown.js';
import { Box, Text } from '../../ink.js';
import { jsonParse } from '../../utils/slowOperations.js';
import { type IdleNotificationMessage, isIdleNotification, isPlanApprovalRequest, isPlanApprovalResponse, type PlanApprovalRequestMessage, type PlanApprovalResponseMessage } from '../../utils/teammateMailbox.js';
import { getShutdownMessageSummary } from './ShutdownMessage.js';
import { getTaskAssignmentSummary } from './TaskAssignmentMessage.js';
type PlanApprovalRequestProps = {
request: PlanApprovalRequestMessage;
};
/**
* Renders a plan approval request with a planMode-colored border,
* showing the plan content and instructions for approving/rejecting.
*/
export function PlanApprovalRequestDisplay(t0) {
const $ = _c(10);
const {
request
} = t0;
let t1;
if ($[0] !== request.from) {
t1 = <Box marginBottom={1}><Text color="planMode" bold={true}>Plan Approval Request from {request.from}</Text></Box>;
$[0] = request.from;
$[1] = t1;
} else {
t1 = $[1];
}
let t2;
if ($[2] !== request.planContent) {
t2 = <Box borderStyle="dashed" borderColor="subtle" borderLeft={false} borderRight={false} flexDirection="column" paddingX={1} marginBottom={1}><Markdown>{request.planContent}</Markdown></Box>;
$[2] = request.planContent;
$[3] = t2;
} else {
t2 = $[3];
}
let t3;
if ($[4] !== request.planFilePath) {
t3 = <Text dimColor={true}>Plan file: {request.planFilePath}</Text>;
$[4] = request.planFilePath;
$[5] = t3;
} else {
t3 = $[5];
}
let t4;
if ($[6] !== t1 || $[7] !== t2 || $[8] !== t3) {
t4 = <Box flexDirection="column" marginY={1}><Box borderStyle="round" borderColor="planMode" flexDirection="column" paddingX={1}>{t1}{t2}{t3}</Box></Box>;
$[6] = t1;
$[7] = t2;
$[8] = t3;
$[9] = t4;
} else {
t4 = $[9];
}
return t4;
}
type PlanApprovalResponseProps = {
response: PlanApprovalResponseMessage;
senderName: string;
};
/**
* Renders a plan approval response with a success (green) or error (red) border.
*/
export function PlanApprovalResponseDisplay(t0) {
const $ = _c(13);
const {
response,
senderName
} = t0;
if (response.approved) {
let t1;
if ($[0] !== senderName) {
t1 = <Box><Text color="success" bold={true}>✓ Plan Approved by {senderName}</Text></Box>;
$[0] = senderName;
$[1] = t1;
} else {
t1 = $[1];
}
let t2;
if ($[2] === Symbol.for("react.memo_cache_sentinel")) {
t2 = <Box marginTop={1}><Text>You can now proceed with implementation. Your plan mode restrictions have been lifted.</Text></Box>;
$[2] = t2;
} else {
t2 = $[2];
}
let t3;
if ($[3] !== t1) {
t3 = <Box flexDirection="column" marginY={1}><Box borderStyle="round" borderColor="success" flexDirection="column" paddingX={1} paddingY={1}>{t1}{t2}</Box></Box>;
$[3] = t1;
$[4] = t3;
} else {
t3 = $[4];
}
return t3;
}
let t1;
if ($[5] !== senderName) {
t1 = <Box><Text color="error" bold={true}>✗ Plan Rejected by {senderName}</Text></Box>;
$[5] = senderName;
$[6] = t1;
} else {
t1 = $[6];
}
let t2;
if ($[7] !== response.feedback) {
t2 = response.feedback && <Box marginTop={1} borderStyle="dashed" borderColor="subtle" borderLeft={false} borderRight={false} paddingX={1}><Text>Feedback: {response.feedback}</Text></Box>;
$[7] = response.feedback;
$[8] = t2;
} else {
t2 = $[8];
}
let t3;
if ($[9] === Symbol.for("react.memo_cache_sentinel")) {
t3 = <Box marginTop={1}><Text dimColor={true}>Please revise your plan based on the feedback and call ExitPlanMode again.</Text></Box>;
$[9] = t3;
} else {
t3 = $[9];
}
let t4;
if ($[10] !== t1 || $[11] !== t2) {
t4 = <Box flexDirection="column" marginY={1}><Box borderStyle="round" borderColor="error" flexDirection="column" paddingX={1} paddingY={1}>{t1}{t2}{t3}</Box></Box>;
$[10] = t1;
$[11] = t2;
$[12] = t4;
} else {
t4 = $[12];
}
return t4;
}
/**
* Try to parse and render a plan approval message from raw content.
* Returns the rendered component if it's a plan approval message, null otherwise.
*/
export function tryRenderPlanApprovalMessage(content: string, senderName: string): React.ReactNode | null {
const request = isPlanApprovalRequest(content);
if (request) {
return <PlanApprovalRequestDisplay request={request} />;
}
const response = isPlanApprovalResponse(content);
if (response) {
return <PlanApprovalResponseDisplay response={response} senderName={senderName} />;
}
return null;
}
/**
* Get a brief summary text for a plan approval message.
* Used in places like the inbox queue where we want a short description.
* Returns null if the content is not a plan approval message.
*/
function getPlanApprovalSummary(content: string): string | null {
const request = isPlanApprovalRequest(content);
if (request) {
return `[Plan Approval Request from ${request.from}]`;
}
const response = isPlanApprovalResponse(content);
if (response) {
if (response.approved) {
return '[Plan Approved] You can now proceed with implementation';
} else {
return `[Plan Rejected] ${response.feedback || 'Please revise your plan'}`;
}
}
return null;
}
/**
* Get a brief summary text for an idle notification.
*/
function getIdleNotificationSummary(msg: IdleNotificationMessage): string {
const parts: string[] = ['Agent idle'];
if (msg.completedTaskId) {
const status = msg.completedStatus || 'completed';
parts.push(`Task ${msg.completedTaskId} ${status}`);
}
if (msg.summary) {
parts.push(`Last DM: ${msg.summary}`);
}
return parts.join(' · ');
}
/**
* Format teammate message content for display.
* If it's a structured message (plan approval, shutdown, or idle), returns a formatted summary.
* Otherwise returns the original content.
*/
export function formatTeammateMessageContent(content: string): string {
const planSummary = getPlanApprovalSummary(content);
if (planSummary) {
return planSummary;
}
const shutdownSummary = getShutdownMessageSummary(content);
if (shutdownSummary) {
return shutdownSummary;
}
const idleMsg = isIdleNotification(content);
if (idleMsg) {
return getIdleNotificationSummary(idleMsg);
}
const taskAssignmentSummary = getTaskAssignmentSummary(content);
if (taskAssignmentSummary) {
return taskAssignmentSummary;
}
// Check for teammate_terminated message
try {
const parsed = jsonParse(content) as {
type?: string;
message?: string;
};
if (parsed?.type === 'teammate_terminated' && parsed.message) {
return parsed.message;
}
} catch {
// Not JSON
}
return content;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","Markdown","Box","Text","jsonParse","IdleNotificationMessage","isIdleNotification","isPlanApprovalRequest","isPlanApprovalResponse","PlanApprovalRequestMessage","PlanApprovalResponseMessage","getShutdownMessageSummary","getTaskAssignmentSummary","PlanApprovalRequestProps","request","PlanApprovalRequestDisplay","t0","$","_c","t1","from","t2","planContent","t3","planFilePath","t4","PlanApprovalResponseProps","response","senderName","PlanApprovalResponseDisplay","approved","Symbol","for","feedback","tryRenderPlanApprovalMessage","content","ReactNode","getPlanApprovalSummary","getIdleNotificationSummary","msg","parts","completedTaskId","status","completedStatus","push","summary","join","formatTeammateMessageContent","planSummary","shutdownSummary","idleMsg","taskAssignmentSummary","parsed","type","message"],"sources":["PlanApprovalMessage.tsx"],"sourcesContent":["import * as React from 'react'\nimport { Markdown } from '../../components/Markdown.js'\nimport { Box, Text } from '../../ink.js'\nimport { jsonParse } from '../../utils/slowOperations.js'\nimport {\n  type IdleNotificationMessage,\n  isIdleNotification,\n  isPlanApprovalRequest,\n  isPlanApprovalResponse,\n  type PlanApprovalRequestMessage,\n  type PlanApprovalResponseMessage,\n} from '../../utils/teammateMailbox.js'\nimport { getShutdownMessageSummary } from './ShutdownMessage.js'\nimport { getTaskAssignmentSummary } from './TaskAssignmentMessage.js'\n\ntype PlanApprovalRequestProps = {\n  request: PlanApprovalRequestMessage\n}\n\n/**\n * Renders a plan approval request with a planMode-colored border,\n * showing the plan content and instructions for approving/rejecting.\n */\nexport function PlanApprovalRequestDisplay({\n  request,\n}: PlanApprovalRequestProps): React.ReactNode {\n  return (\n    <Box flexDirection=\"column\" marginY={1}>\n      <Box\n        borderStyle=\"round\"\n        borderColor=\"planMode\"\n        flexDirection=\"column\"\n        paddingX={1}\n      >\n        <Box marginBottom={1}>\n          <Text color=\"planMode\" bold>\n            Plan Approval Request from {request.from}\n          </Text>\n        </Box>\n        <Box\n          borderStyle=\"dashed\"\n          borderColor=\"subtle\"\n          borderLeft={false}\n          borderRight={false}\n          flexDirection=\"column\"\n          paddingX={1}\n          marginBottom={1}\n        >\n          <Markdown>{request.planContent}</Markdown>\n        </Box>\n        <Text dimColor>Plan file: {request.planFilePath}</Text>\n      </Box>\n    </Box>\n  )\n}\n\ntype PlanApprovalResponseProps = {\n  response: PlanApprovalResponseMessage\n  senderName: string\n}\n\n/**\n * Renders a plan approval response with a success (green) or error (red) border.\n */\nexport function PlanApprovalResponseDisplay({\n  response,\n  senderName,\n}: PlanApprovalResponseProps): React.ReactNode {\n  if (response.approved) {\n    return (\n      <Box flexDirection=\"column\" marginY={1}>\n        <Box\n          borderStyle=\"round\"\n          borderColor=\"success\"\n          flexDirection=\"column\"\n          paddingX={1}\n          paddingY={1}\n        >\n          <Box>\n            <Text color=\"success\" bold>\n              ✓ Plan Approved by {senderName}\n            </Text>\n          </Box>\n          <Box marginTop={1}>\n            <Text>\n              You can now proceed with implementation. Your plan mode\n              restrictions have been lifted.\n            </Text>\n          </Box>\n        </Box>\n      </Box>\n    )\n  }\n\n  return (\n    <Box flexDirection=\"column\" marginY={1}>\n      <Box\n        borderStyle=\"round\"\n        borderColor=\"error\"\n        flexDirection=\"column\"\n        paddingX={1}\n        paddingY={1}\n      >\n        <Box>\n          <Text color=\"error\" bold>\n            ✗ Plan Rejected by {senderName}\n          </Text>\n        </Box>\n        {response.feedback && (\n          <Box\n            marginTop={1}\n            borderStyle=\"dashed\"\n            borderColor=\"subtle\"\n            borderLeft={false}\n            borderRight={false}\n            paddingX={1}\n          >\n            <Text>Feedback: {response.feedback}</Text>\n          </Box>\n        )}\n        <Box marginTop={1}>\n          <Text dimColor>\n            Please revise your plan based on the feedback and call ExitPlanMode\n            again.\n          </Text>\n        </Box>\n      </Box>\n    </Box>\n  )\n}\n\n/**\n * Try to parse and render a plan approval message from raw content.\n * Returns the rendered component if it's a plan approval message, null otherwise.\n */\nexport function tryRenderPlanApprovalMessage(\n  content: string,\n  senderName: string,\n): React.ReactNode | null {\n  const request = isPlanApprovalRequest(content)\n  if (request) {\n    return <PlanApprovalRequestDisplay request={request} />\n  }\n\n  const response = isPlanApprovalResponse(content)\n  if (response) {\n    return (\n      <PlanApprovalResponseDisplay\n        response={response}\n        senderName={senderName}\n      />\n    )\n  }\n\n  return null\n}\n\n/**\n * Get a brief summary text for a plan approval message.\n * Used in places like the inbox queue where we want a short description.\n * Returns null if the content is not a plan approval message.\n */\nfunction getPlanApprovalSummary(content: string): string | null {\n  const request = isPlanApprovalRequest(content)\n  if (request) {\n    return `[Plan Approval Request from ${request.from}]`\n  }\n\n  const response = isPlanApprovalResponse(content)\n  if (response) {\n    if (response.approved) {\n      return '[Plan Approved] You can now proceed with implementation'\n    } else {\n      return `[Plan Rejected] ${response.feedback || 'Please revise your plan'}`\n    }\n  }\n\n  return null\n}\n\n/**\n * Get a brief summary text for an idle notification.\n */\nfunction getIdleNotificationSummary(msg: IdleNotificationMessage): string {\n  const parts: string[] = ['Agent idle']\n  if (msg.completedTaskId) {\n    const status = msg.completedStatus || 'completed'\n    parts.push(`Task ${msg.completedTaskId} ${status}`)\n  }\n  if (msg.summary) {\n    parts.push(`Last DM: ${msg.summary}`)\n  }\n  return parts.join(' · ')\n}\n\n/**\n * Format teammate message content for display.\n * If it's a structured message (plan approval, shutdown, or idle), returns a formatted summary.\n * Otherwise returns the original content.\n */\nexport function formatTeammateMessageContent(content: string): string {\n  const planSummary = getPlanApprovalSummary(content)\n  if (planSummary) {\n    return planSummary\n  }\n\n  const shutdownSummary = getShutdownMessageSummary(content)\n  if (shutdownSummary) {\n    return shutdownSummary\n  }\n\n  const idleMsg = isIdleNotification(content)\n  if (idleMsg) {\n    return getIdleNotificationSummary(idleMsg)\n  }\n\n  const taskAssignmentSummary = getTaskAssignmentSummary(content)\n  if (taskAssignmentSummary) {\n    return taskAssignmentSummary\n  }\n\n  // Check for teammate_terminated message\n  try {\n    const parsed = jsonParse(content) as { type?: string; message?: string }\n    if (parsed?.type === 'teammate_terminated' && parsed.message) {\n      return parsed.message\n    }\n  } catch {\n    // Not JSON\n  }\n\n  return content\n}\n"],"mappings":"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","ignoreList":[]}