π File detail
components/messages/PlanApprovalMessage.tsx
π― Use case
This file lives under βcomponents/β, which covers shared React UI pieces. On the API surface it exposes PlanApprovalRequestDisplay, PlanApprovalResponseDisplay, tryRenderPlanApprovalMessage, and formatTeammateMessageContent β mainly functions, hooks, or classes. Dependencies touch React UI. It composes internal code from components, ink, utils, ShutdownMessage, and TaskAssignmentMessage (relative imports).
Generated from folder role, exports, dependency roots, and inline comments β not hand-reviewed for every path.
π§ Inline summary
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';
π€ Exports (heuristic)
PlanApprovalRequestDisplayPlanApprovalResponseDisplaytryRenderPlanApprovalMessageformatTeammateMessageContent
π External import roots
Package roots from from "β¦" (relative paths omitted).
react
π₯οΈ Source preview
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":[]}