mirror of
http://10.0.2.1:3031/sauer/claude-code.git
synced 2026-06-30 15:36:57 +10:00
132 lines
14 KiB
TypeScript
132 lines
14 KiB
TypeScript
|
|
import { c as _c } from "react/compiler-runtime";
|
||
|
|
import * as React from 'react';
|
||
|
|
import { Box, Text } from '../../ink.js';
|
||
|
|
import { isShutdownApproved, isShutdownRejected, isShutdownRequest, type ShutdownRejectedMessage, type ShutdownRequestMessage } from '../../utils/teammateMailbox.js';
|
||
|
|
type ShutdownRequestProps = {
|
||
|
|
request: ShutdownRequestMessage;
|
||
|
|
};
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Renders a shutdown request with a warning-colored border.
|
||
|
|
*/
|
||
|
|
export function ShutdownRequestDisplay(t0) {
|
||
|
|
const $ = _c(7);
|
||
|
|
const {
|
||
|
|
request
|
||
|
|
} = t0;
|
||
|
|
let t1;
|
||
|
|
if ($[0] !== request.from) {
|
||
|
|
t1 = <Box marginBottom={1}><Text color="warning" bold={true}>Shutdown request from {request.from}</Text></Box>;
|
||
|
|
$[0] = request.from;
|
||
|
|
$[1] = t1;
|
||
|
|
} else {
|
||
|
|
t1 = $[1];
|
||
|
|
}
|
||
|
|
let t2;
|
||
|
|
if ($[2] !== request.reason) {
|
||
|
|
t2 = request.reason && <Box><Text>Reason: {request.reason}</Text></Box>;
|
||
|
|
$[2] = request.reason;
|
||
|
|
$[3] = t2;
|
||
|
|
} else {
|
||
|
|
t2 = $[3];
|
||
|
|
}
|
||
|
|
let t3;
|
||
|
|
if ($[4] !== t1 || $[5] !== t2) {
|
||
|
|
t3 = <Box flexDirection="column" marginY={1}><Box borderStyle="round" borderColor="warning" flexDirection="column" paddingX={1} paddingY={1}>{t1}{t2}</Box></Box>;
|
||
|
|
$[4] = t1;
|
||
|
|
$[5] = t2;
|
||
|
|
$[6] = t3;
|
||
|
|
} else {
|
||
|
|
t3 = $[6];
|
||
|
|
}
|
||
|
|
return t3;
|
||
|
|
}
|
||
|
|
type ShutdownRejectedProps = {
|
||
|
|
response: ShutdownRejectedMessage;
|
||
|
|
};
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Renders a shutdown rejected message with a subtle (grey) border.
|
||
|
|
*/
|
||
|
|
export function ShutdownRejectedDisplay(t0) {
|
||
|
|
const $ = _c(8);
|
||
|
|
const {
|
||
|
|
response
|
||
|
|
} = t0;
|
||
|
|
let t1;
|
||
|
|
if ($[0] !== response.from) {
|
||
|
|
t1 = <Text color="subtle" bold={true}>Shutdown rejected by {response.from}</Text>;
|
||
|
|
$[0] = response.from;
|
||
|
|
$[1] = t1;
|
||
|
|
} else {
|
||
|
|
t1 = $[1];
|
||
|
|
}
|
||
|
|
let t2;
|
||
|
|
if ($[2] !== response.reason) {
|
||
|
|
t2 = <Box marginTop={1} borderStyle="dashed" borderColor="subtle" borderLeft={false} borderRight={false} paddingX={1}><Text>Reason: {response.reason}</Text></Box>;
|
||
|
|
$[2] = response.reason;
|
||
|
|
$[3] = t2;
|
||
|
|
} else {
|
||
|
|
t2 = $[3];
|
||
|
|
}
|
||
|
|
let t3;
|
||
|
|
if ($[4] === Symbol.for("react.memo_cache_sentinel")) {
|
||
|
|
t3 = <Box marginTop={1}><Text dimColor={true}>Teammate is continuing to work. You may request shutdown again later.</Text></Box>;
|
||
|
|
$[4] = t3;
|
||
|
|
} else {
|
||
|
|
t3 = $[4];
|
||
|
|
}
|
||
|
|
let t4;
|
||
|
|
if ($[5] !== t1 || $[6] !== t2) {
|
||
|
|
t4 = <Box flexDirection="column" marginY={1}><Box borderStyle="round" borderColor="subtle" flexDirection="column" paddingX={1} paddingY={1}>{t1}{t2}{t3}</Box></Box>;
|
||
|
|
$[5] = t1;
|
||
|
|
$[6] = t2;
|
||
|
|
$[7] = t4;
|
||
|
|
} else {
|
||
|
|
t4 = $[7];
|
||
|
|
}
|
||
|
|
return t4;
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Try to parse and render a shutdown message from raw content.
|
||
|
|
* Returns the rendered component if it's a shutdown message, null otherwise.
|
||
|
|
*/
|
||
|
|
export function tryRenderShutdownMessage(content: string): React.ReactNode | null {
|
||
|
|
const request = isShutdownRequest(content);
|
||
|
|
if (request) {
|
||
|
|
return <ShutdownRequestDisplay request={request} />;
|
||
|
|
}
|
||
|
|
|
||
|
|
// Shutdown approved is handled inline by the caller — skip it here
|
||
|
|
if (isShutdownApproved(content)) {
|
||
|
|
return null;
|
||
|
|
}
|
||
|
|
const rejected = isShutdownRejected(content);
|
||
|
|
if (rejected) {
|
||
|
|
return <ShutdownRejectedDisplay response={rejected} />;
|
||
|
|
}
|
||
|
|
return null;
|
||
|
|
}
|
||
|
|
|
||
|
|
/**
|
||
|
|
* Get a brief summary text for a shutdown message.
|
||
|
|
* Used in places like the inbox queue where we want a short description.
|
||
|
|
* Returns null if the content is not a shutdown message.
|
||
|
|
*/
|
||
|
|
export function getShutdownMessageSummary(content: string): string | null {
|
||
|
|
const request = isShutdownRequest(content);
|
||
|
|
if (request) {
|
||
|
|
return `[Shutdown Request from ${request.from}]${request.reason ? ` ${request.reason}` : ''}`;
|
||
|
|
}
|
||
|
|
const approved = isShutdownApproved(content);
|
||
|
|
if (approved) {
|
||
|
|
return `[Shutdown Approved] ${approved.from} is now exiting`;
|
||
|
|
}
|
||
|
|
const rejected = isShutdownRejected(content);
|
||
|
|
if (rejected) {
|
||
|
|
return `[Shutdown Rejected] ${rejected.from}: ${rejected.reason}`;
|
||
|
|
}
|
||
|
|
return null;
|
||
|
|
}
|
||
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsIkJveCIsIlRleHQiLCJpc1NodXRkb3duQXBwcm92ZWQiLCJpc1NodXRkb3duUmVqZWN0ZWQiLCJpc1NodXRkb3duUmVxdWVzdCIsIlNodXRkb3duUmVqZWN0ZWRNZXNzYWdlIiwiU2h1dGRvd25SZXF1ZXN0TWVzc2FnZSIsIlNodXRkb3duUmVxdWVzdFByb3BzIiwicmVxdWVzdCIsIlNodXRkb3duUmVxdWVzdERpc3BsYXkiLCJ0MCIsIiQiLCJfYyIsInQxIiwiZnJvbSIsInQyIiwicmVhc29uIiwidDMiLCJTaHV0ZG93blJlamVjdGVkUHJvcHMiLCJyZXNwb25zZSIsIlNodXRkb3duUmVqZWN0ZWREaXNwbGF5IiwiU3ltYm9sIiwiZm9yIiwidDQiLCJ0cnlSZW5kZXJTaHV0ZG93bk1lc3NhZ2UiLCJjb250ZW50IiwiUmVhY3ROb2RlIiwicmVqZWN0ZWQiLCJnZXRTaHV0ZG93bk1lc3NhZ2VTdW1tYXJ5IiwiYXBwcm92ZWQiXSwic291cmNlcyI6WyJTaHV0ZG93bk1lc3NhZ2UudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQm94LCBUZXh0IH0gZnJvbSAnLi4vLi4vaW5rLmpzJ1xuaW1wb3J0IHtcbiAgaXNTaHV0ZG93bkFwcHJvdmVkLFxuICBpc1NodXRkb3duUmVqZWN0ZWQsXG4gIGlzU2h1dGRvd25SZXF1ZXN0LFxuICB0eXBlIFNodXRkb3duUmVqZWN0ZWRNZXNzYWdlLFxuICB0eXBlIFNodXRkb3duUmVxdWVzdE1lc3NhZ2UsXG59IGZyb20gJy4uLy4uL3V0aWxzL3RlYW1tYXRlTWFpbGJveC5qcydcblxudHlwZSBTaHV0ZG93blJlcXVlc3RQcm9wcyA9IHtcbiAgcmVxdWVzdDogU2h1dGRvd25SZXF1ZXN0TWVzc2FnZVxufVxuXG4vKipcbiAqIFJlbmRlcnMgYSBzaHV0ZG93biByZXF1ZXN0IHdpdGggYSB3YXJuaW5nLWNvbG9yZWQgYm9yZGVyLlxuICovXG5leHBvcnQgZnVuY3Rpb24gU2h1dGRvd25SZXF1ZXN0RGlzcGxheSh7XG4gIHJlcXVlc3QsXG59OiBTaHV0ZG93blJlcXVlc3RQcm9wcyk6IFJlYWN0LlJlYWN0Tm9kZSB7XG4gIHJldHVybiAoXG4gICAgPEJveCBmbGV4RGlyZWN0aW9uPVwiY29sdW1uXCIgbWFyZ2luWT17MX0+XG4gICAgICA8Qm94XG4gICAgICAgIGJvcmRlclN0eWxlPVwicm91bmRcIlxuICAgICAgICBib3JkZXJDb2xvcj1cIndhcm5pbmdcIlxuICAgICAgICBmbGV4RGlyZWN0aW9uPVwiY29sdW1uXCJcbiAgICAgICAgcGFkZGluZ1g9ezF9XG4gICAgICAgIHBhZGRpbmdZPXsxfVxuICAgICAgPlxuICAgICAgICA8Qm94IG1hcmdpbkJvdHRvbT17MX0+XG4gICAgICAgICAgPFRleHQgY29sb3I9XCJ3YXJuaW5nXCIgYm9sZD5cbiAgICAgICAgICAgIFNodXRkb3duIHJlcXVlc3QgZnJvbSB7cmVxdWVzdC5mcm9tfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgPC9Cb3g+XG4gICAgICAgIHtyZXF1ZXN0LnJlYXNvbiAmJiAoXG4gICAgICAgICAgPEJveD5cbiAgICAgICAgICAgIDxUZXh0PlJlYXNvbjoge3JlcXVlc3QucmVhc29ufTwvVGV4dD5cbiAgICAgICAgICA8L0JveD5cbiAgICAgICAgKX1cbiAgICAgIDwvQm94PlxuICAgIDwvQm94PlxuICApXG59XG5cbnR5cGUgU2h1dGRvd25SZWplY3RlZFByb3BzID0ge1xuICByZXNwb25zZTogU2h1dGRvd25SZWplY3RlZE1lc3NhZ2Vcbn1cblxuLyoqXG4gKiBSZW5kZXJzIGEgc2h1dGRvd24gcmVqZWN0ZWQgbWVzc2FnZSB3aXRoIGEgc3VidGxlIChncmV5KSBib3JkZXIuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBTaHV0ZG93blJlamVjdGVkRGlzcGxheSh7XG4gIHJlc3BvbnNlLFxufTogU2h1dGRvd25SZWplY3RlZFByb3BzKTogUmVhY3QuUmVhY3ROb2RlIHtcbiAgcmV0dXJuIChcbiAgICA8Qm94IGZsZXhEaXJlY3Rpb249XCJjb2x1bW5cIiBtYXJnaW5ZPXsxfT5cbiAgICAgIDxCb3hcbiAgICAgICAgYm9yZGVyU3R5bGU9XCJyb3VuZFwiXG4gICAgICAgIGJvcmRlckNvbG9yPVwic3VidGxlXCJcbiAgICAgICAgZmxleERpcmVjdGlvbj1cImNvbHVtblwiXG4gICAgICAgIHBhZGRpbmdYPXsxfVxuICAgICAgICBwYWRkaW5nWT17MX1cbiAgICAgID5cbiAgICAgICAgPFRleHQgY29sb3I9XCJzdWJ0bGVcIiBib2xkPlxuICAgICAgICAgIFNodXRkb3duIHJlamVjdGVkIGJ5IHtyZXNwb25zZS5mcm9tfVxuICAgICAgICA8L1RleHQ+XG4gICAgICAgIDxCb3hcbiAgICAgICAgICBtYXJnaW5Ub3A9ezF9XG4gICAgICAgICAgYm9yZGVyU3R5bGU9XCJkYXNoZWRcIlxuICAgICAgICAgIGJvcmRlckNvbG9yPVwic3VidGxlXCJcbiAgICAgICAgICBib3JkZXJMZWZ0PXtmYWxzZX1cbiAgICAgICAgICBib3JkZXJSaWdodD17ZmFsc2V9XG4gICAgICAgICAgcGFkZGluZ1g9ezF9XG4gICAgICAgID5cbiAgICAgICAgICA8VGV4dD5SZWFzb246IHtyZXNwb25zZS5yZWFzb259PC9UZXh0PlxuICAgICAgICA8L0JveD5cbiAgICAgICAgPEJveCBtYXJnaW5Ub3A9ezF9PlxuICAgICAgICAgIDxUZXh0IGRpbUNvbG9yPlxuICAgICAgICAgICAgVGVhbW1hdGUgaXMgY29udGludWluZyB0byB3b3JrLiBZb3UgbWF5IHJlcXVlc3Qgc2h1dGRvd24gYWdhaW5cbiAgICAgICAgICAgIGxhdGVyLlxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgPC9Cb3g+XG4gICAgICA8L0JveD5cbiAgICA8L0JveD5cbiAgKVxufVxuXG4vKipcbiAqIFRyeSB0byBwYXJzZSBhbmQgcmVuZGVyIGEgc2h1dGRvd24gbWVzc2FnZSBmcm9tIHJhdyBjb250ZW50LlxuICogUmV0dXJucyB0aGUgcmVuZGVyZWQgY29tcG9uZW50IGlmIGl0J3MgYSBzaHV0ZG93biBtZXNzYWdlLCBudWxsIG90aGVyd2lzZS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHRyeVJlbmRlclNodXRkb3duTWVzc2FnZShcbiAgY29udGVudDogc3RyaW5nLFxuKTogUmVhY3QuUmVhY3ROb2RlIHwgbnVsbCB7XG4gIGNvbnN0IHJlcXVlc3QgPSBpc1NodXRkb3duUmVxdWVzdChjb250ZW50KVxuICBpZiAocmVxdWVzdCkge1xuICAgIHJldHVybiA8U2h1dGRvd25SZXF1ZXN0RGlzcGxheSByZXF1ZXN0PXtyZXF1ZXN0fSAvPlxuICB9XG5cbiAgLy8gU2h1dGRvd24gYXBwcm92ZWQgaXMgaGFuZGxlZCBpbmx
|