/ components / messages / AssistantTextMessage.tsx
AssistantTextMessage.tsx
  1  import { c as _c } from "react/compiler-runtime";
  2  import type { TextBlockParam } from '@anthropic-ai/sdk/resources/index.mjs';
  3  import React, { useContext } from 'react';
  4  import { ERROR_MESSAGE_USER_ABORT } from 'src/services/compact/compact.js';
  5  import { isRateLimitErrorMessage } from 'src/services/rateLimitMessages.js';
  6  import { BLACK_CIRCLE } from '../../constants/figures.js';
  7  import { Box, NoSelect, Text } from '../../ink.js';
  8  import { API_ERROR_MESSAGE_PREFIX, API_TIMEOUT_ERROR_MESSAGE, CREDIT_BALANCE_TOO_LOW_ERROR_MESSAGE, CUSTOM_OFF_SWITCH_MESSAGE, INVALID_API_KEY_ERROR_MESSAGE, INVALID_API_KEY_ERROR_MESSAGE_EXTERNAL, ORG_DISABLED_ERROR_MESSAGE_ENV_KEY, ORG_DISABLED_ERROR_MESSAGE_ENV_KEY_WITH_OAUTH, PROMPT_TOO_LONG_ERROR_MESSAGE, startsWithApiErrorPrefix, TOKEN_REVOKED_ERROR_MESSAGE } from '../../services/api/errors.js';
  9  import { isEmptyMessageText, NO_RESPONSE_REQUESTED } from '../../utils/messages.js';
 10  import { getUpgradeMessage } from '../../utils/model/contextWindowUpgradeCheck.js';
 11  import { getDefaultSonnetModel, renderModelName } from '../../utils/model/model.js';
 12  import { isMacOsKeychainLocked } from '../../utils/secureStorage/macOsKeychainStorage.js';
 13  import { CtrlOToExpand } from '../CtrlOToExpand.js';
 14  import { InterruptedByUser } from '../InterruptedByUser.js';
 15  import { Markdown } from '../Markdown.js';
 16  import { MessageResponse } from '../MessageResponse.js';
 17  import { MessageActionsSelectedContext } from '../messageActions.js';
 18  import { RateLimitMessage } from './RateLimitMessage.js';
 19  const MAX_API_ERROR_CHARS = 1000;
 20  type Props = {
 21    param: TextBlockParam;
 22    addMargin: boolean;
 23    shouldShowDot: boolean;
 24    verbose: boolean;
 25    width?: number | string;
 26    onOpenRateLimitOptions?: () => void;
 27  };
 28  function InvalidApiKeyMessage() {
 29    const $ = _c(2);
 30    let t0;
 31    if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
 32      t0 = isMacOsKeychainLocked();
 33      $[0] = t0;
 34    } else {
 35      t0 = $[0];
 36    }
 37    const isKeychainLocked = t0;
 38    let t1;
 39    if ($[1] === Symbol.for("react.memo_cache_sentinel")) {
 40      t1 = <MessageResponse><Box flexDirection="column"><Text color="error">{INVALID_API_KEY_ERROR_MESSAGE}</Text>{isKeychainLocked && <Text dimColor={true}>· Run in another terminal: security unlock-keychain</Text>}</Box></MessageResponse>;
 41      $[1] = t1;
 42    } else {
 43      t1 = $[1];
 44    }
 45    return t1;
 46  }
 47  export function AssistantTextMessage(t0) {
 48    const $ = _c(34);
 49    const {
 50      param: t1,
 51      addMargin,
 52      shouldShowDot,
 53      verbose,
 54      onOpenRateLimitOptions
 55    } = t0;
 56    const {
 57      text
 58    } = t1;
 59    const isSelected = useContext(MessageActionsSelectedContext);
 60    if (isEmptyMessageText(text)) {
 61      return null;
 62    }
 63    if (isRateLimitErrorMessage(text)) {
 64      let t2;
 65      if ($[0] !== onOpenRateLimitOptions || $[1] !== text) {
 66        t2 = <RateLimitMessage text={text} onOpenRateLimitOptions={onOpenRateLimitOptions} />;
 67        $[0] = onOpenRateLimitOptions;
 68        $[1] = text;
 69        $[2] = t2;
 70      } else {
 71        t2 = $[2];
 72      }
 73      return t2;
 74    }
 75    switch (text) {
 76      case NO_RESPONSE_REQUESTED:
 77        {
 78          return null;
 79        }
 80      case PROMPT_TOO_LONG_ERROR_MESSAGE:
 81        {
 82          let t2;
 83          if ($[3] === Symbol.for("react.memo_cache_sentinel")) {
 84            t2 = getUpgradeMessage("warning");
 85            $[3] = t2;
 86          } else {
 87            t2 = $[3];
 88          }
 89          const upgradeHint = t2;
 90          let t3;
 91          if ($[4] === Symbol.for("react.memo_cache_sentinel")) {
 92            t3 = <MessageResponse height={1}><Text color="error">Context limit reached · /compact or /clear to continue{upgradeHint ? ` · ${upgradeHint}` : ""}</Text></MessageResponse>;
 93            $[4] = t3;
 94          } else {
 95            t3 = $[4];
 96          }
 97          return t3;
 98        }
 99      case CREDIT_BALANCE_TOO_LOW_ERROR_MESSAGE:
100        {
101          let t2;
102          if ($[5] === Symbol.for("react.memo_cache_sentinel")) {
103            t2 = <MessageResponse height={1}><Text color="error">Credit balance too low · Add funds: https://platform.claude.com/settings/billing</Text></MessageResponse>;
104            $[5] = t2;
105          } else {
106            t2 = $[5];
107          }
108          return t2;
109        }
110      case INVALID_API_KEY_ERROR_MESSAGE:
111        {
112          let t2;
113          if ($[6] === Symbol.for("react.memo_cache_sentinel")) {
114            t2 = <InvalidApiKeyMessage />;
115            $[6] = t2;
116          } else {
117            t2 = $[6];
118          }
119          return t2;
120        }
121      case INVALID_API_KEY_ERROR_MESSAGE_EXTERNAL:
122        {
123          let t2;
124          if ($[7] === Symbol.for("react.memo_cache_sentinel")) {
125            t2 = <MessageResponse height={1}><Text color="error">{INVALID_API_KEY_ERROR_MESSAGE_EXTERNAL}</Text></MessageResponse>;
126            $[7] = t2;
127          } else {
128            t2 = $[7];
129          }
130          return t2;
131        }
132      case ORG_DISABLED_ERROR_MESSAGE_ENV_KEY:
133      case ORG_DISABLED_ERROR_MESSAGE_ENV_KEY_WITH_OAUTH:
134        {
135          let t2;
136          if ($[8] !== text) {
137            t2 = <MessageResponse><Text color="error">{text}</Text></MessageResponse>;
138            $[8] = text;
139            $[9] = t2;
140          } else {
141            t2 = $[9];
142          }
143          return t2;
144        }
145      case TOKEN_REVOKED_ERROR_MESSAGE:
146        {
147          let t2;
148          if ($[10] === Symbol.for("react.memo_cache_sentinel")) {
149            t2 = <MessageResponse height={1}><Text color="error">{TOKEN_REVOKED_ERROR_MESSAGE}</Text></MessageResponse>;
150            $[10] = t2;
151          } else {
152            t2 = $[10];
153          }
154          return t2;
155        }
156      case API_TIMEOUT_ERROR_MESSAGE:
157        {
158          let t2;
159          if ($[11] === Symbol.for("react.memo_cache_sentinel")) {
160            t2 = <MessageResponse height={1}><Text color="error">{API_TIMEOUT_ERROR_MESSAGE}{process.env.API_TIMEOUT_MS && <>{" "}(API_TIMEOUT_MS={process.env.API_TIMEOUT_MS}ms, try increasing it)</>}</Text></MessageResponse>;
161            $[11] = t2;
162          } else {
163            t2 = $[11];
164          }
165          return t2;
166        }
167      case CUSTOM_OFF_SWITCH_MESSAGE:
168        {
169          let t2;
170          if ($[12] === Symbol.for("react.memo_cache_sentinel")) {
171            t2 = <Text color="error">We are experiencing high demand for Opus 4.</Text>;
172            $[12] = t2;
173          } else {
174            t2 = $[12];
175          }
176          let t3;
177          if ($[13] === Symbol.for("react.memo_cache_sentinel")) {
178            t3 = <MessageResponse><Box flexDirection="column" gap={1}>{t2}<Text>To continue immediately, use /model to switch to{" "}{renderModelName(getDefaultSonnetModel())} and continue coding.</Text></Box></MessageResponse>;
179            $[13] = t3;
180          } else {
181            t3 = $[13];
182          }
183          return t3;
184        }
185      case ERROR_MESSAGE_USER_ABORT:
186        {
187          let t2;
188          if ($[14] === Symbol.for("react.memo_cache_sentinel")) {
189            t2 = <MessageResponse height={1}><InterruptedByUser /></MessageResponse>;
190            $[14] = t2;
191          } else {
192            t2 = $[14];
193          }
194          return t2;
195        }
196      default:
197        {
198          if (startsWithApiErrorPrefix(text)) {
199            const truncated = !verbose && text.length > MAX_API_ERROR_CHARS;
200            const t2 = text === API_ERROR_MESSAGE_PREFIX ? `${API_ERROR_MESSAGE_PREFIX}: Please wait a moment and try again.` : truncated ? text.slice(0, MAX_API_ERROR_CHARS) + "\u2026" : text;
201            let t3;
202            if ($[15] !== t2) {
203              t3 = <Text color="error">{t2}</Text>;
204              $[15] = t2;
205              $[16] = t3;
206            } else {
207              t3 = $[16];
208            }
209            let t4;
210            if ($[17] !== truncated) {
211              t4 = truncated && <CtrlOToExpand />;
212              $[17] = truncated;
213              $[18] = t4;
214            } else {
215              t4 = $[18];
216            }
217            let t5;
218            if ($[19] !== t3 || $[20] !== t4) {
219              t5 = <MessageResponse><Box flexDirection="column">{t3}{t4}</Box></MessageResponse>;
220              $[19] = t3;
221              $[20] = t4;
222              $[21] = t5;
223            } else {
224              t5 = $[21];
225            }
226            return t5;
227          }
228          const t2 = addMargin ? 1 : 0;
229          const t3 = isSelected ? "messageActionsBackground" : undefined;
230          let t4;
231          if ($[22] !== isSelected || $[23] !== shouldShowDot) {
232            t4 = shouldShowDot && <NoSelect fromLeftEdge={true} minWidth={2}><Text color={isSelected ? "suggestion" : "text"}>{BLACK_CIRCLE}</Text></NoSelect>;
233            $[22] = isSelected;
234            $[23] = shouldShowDot;
235            $[24] = t4;
236          } else {
237            t4 = $[24];
238          }
239          let t5;
240          if ($[25] !== text) {
241            t5 = <Box flexDirection="column"><Markdown>{text}</Markdown></Box>;
242            $[25] = text;
243            $[26] = t5;
244          } else {
245            t5 = $[26];
246          }
247          let t6;
248          if ($[27] !== t4 || $[28] !== t5) {
249            t6 = <Box flexDirection="row">{t4}{t5}</Box>;
250            $[27] = t4;
251            $[28] = t5;
252            $[29] = t6;
253          } else {
254            t6 = $[29];
255          }
256          let t7;
257          if ($[30] !== t2 || $[31] !== t3 || $[32] !== t6) {
258            t7 = <Box alignItems="flex-start" flexDirection="row" justifyContent="space-between" marginTop={t2} width="100%" backgroundColor={t3}>{t6}</Box>;
259            $[30] = t2;
260            $[31] = t3;
261            $[32] = t6;
262            $[33] = t7;
263          } else {
264            t7 = $[33];
265          }
266          return t7;
267        }
268    }
269  }
270  //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["TextBlockParam","React","useContext","ERROR_MESSAGE_USER_ABORT","isRateLimitErrorMessage","BLACK_CIRCLE","Box","NoSelect","Text","API_ERROR_MESSAGE_PREFIX","API_TIMEOUT_ERROR_MESSAGE","CREDIT_BALANCE_TOO_LOW_ERROR_MESSAGE","CUSTOM_OFF_SWITCH_MESSAGE","INVALID_API_KEY_ERROR_MESSAGE","INVALID_API_KEY_ERROR_MESSAGE_EXTERNAL","ORG_DISABLED_ERROR_MESSAGE_ENV_KEY","ORG_DISABLED_ERROR_MESSAGE_ENV_KEY_WITH_OAUTH","PROMPT_TOO_LONG_ERROR_MESSAGE","startsWithApiErrorPrefix","TOKEN_REVOKED_ERROR_MESSAGE","isEmptyMessageText","NO_RESPONSE_REQUESTED","getUpgradeMessage","getDefaultSonnetModel","renderModelName","isMacOsKeychainLocked","CtrlOToExpand","InterruptedByUser","Markdown","MessageResponse","MessageActionsSelectedContext","RateLimitMessage","MAX_API_ERROR_CHARS","Props","param","addMargin","shouldShowDot","verbose","width","onOpenRateLimitOptions","InvalidApiKeyMessage","$","_c","t0","Symbol","for","isKeychainLocked","t1","AssistantTextMessage","text","isSelected","t2","upgradeHint","t3","process","env","API_TIMEOUT_MS","truncated","length","slice","t4","t5","undefined","t6","t7"],"sources":["AssistantTextMessage.tsx"],"sourcesContent":["import type { TextBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'\nimport React, { useContext } from 'react'\nimport { ERROR_MESSAGE_USER_ABORT } from 'src/services/compact/compact.js'\nimport { isRateLimitErrorMessage } from 'src/services/rateLimitMessages.js'\nimport { BLACK_CIRCLE } from '../../constants/figures.js'\nimport { Box, NoSelect, Text } from '../../ink.js'\nimport {\n  API_ERROR_MESSAGE_PREFIX,\n  API_TIMEOUT_ERROR_MESSAGE,\n  CREDIT_BALANCE_TOO_LOW_ERROR_MESSAGE,\n  CUSTOM_OFF_SWITCH_MESSAGE,\n  INVALID_API_KEY_ERROR_MESSAGE,\n  INVALID_API_KEY_ERROR_MESSAGE_EXTERNAL,\n  ORG_DISABLED_ERROR_MESSAGE_ENV_KEY,\n  ORG_DISABLED_ERROR_MESSAGE_ENV_KEY_WITH_OAUTH,\n  PROMPT_TOO_LONG_ERROR_MESSAGE,\n  startsWithApiErrorPrefix,\n  TOKEN_REVOKED_ERROR_MESSAGE,\n} from '../../services/api/errors.js'\nimport {\n  isEmptyMessageText,\n  NO_RESPONSE_REQUESTED,\n} from '../../utils/messages.js'\nimport { getUpgradeMessage } from '../../utils/model/contextWindowUpgradeCheck.js'\nimport {\n  getDefaultSonnetModel,\n  renderModelName,\n} from '../../utils/model/model.js'\nimport { isMacOsKeychainLocked } from '../../utils/secureStorage/macOsKeychainStorage.js'\nimport { CtrlOToExpand } from '../CtrlOToExpand.js'\nimport { InterruptedByUser } from '../InterruptedByUser.js'\nimport { Markdown } from '../Markdown.js'\nimport { MessageResponse } from '../MessageResponse.js'\nimport { MessageActionsSelectedContext } from '../messageActions.js'\nimport { RateLimitMessage } from './RateLimitMessage.js'\n\nconst MAX_API_ERROR_CHARS = 1000\n\ntype Props = {\n  param: TextBlockParam\n  addMargin: boolean\n  shouldShowDot: boolean\n  verbose: boolean\n  width?: number | string\n  onOpenRateLimitOptions?: () => void\n}\n\nfunction InvalidApiKeyMessage(): React.ReactNode {\n  const isKeychainLocked = isMacOsKeychainLocked()\n\n  return (\n    <MessageResponse>\n      <Box flexDirection=\"column\">\n        <Text color=\"error\">{INVALID_API_KEY_ERROR_MESSAGE}</Text>\n        {isKeychainLocked && (\n          <Text dimColor>\n            · Run in another terminal: security unlock-keychain\n          </Text>\n        )}\n      </Box>\n    </MessageResponse>\n  )\n}\n\nexport function AssistantTextMessage({\n  param: { text },\n  addMargin,\n  shouldShowDot,\n  verbose,\n  onOpenRateLimitOptions,\n}: Props): React.ReactNode {\n  const isSelected = useContext(MessageActionsSelectedContext)\n  if (isEmptyMessageText(text)) {\n    return null\n  }\n\n  // Handle all rate limit error messages from getRateLimitErrorMessage\n  // Use the exported function to avoid fragile string coupling\n  if (isRateLimitErrorMessage(text)) {\n    return (\n      <RateLimitMessage\n        text={text}\n        onOpenRateLimitOptions={onOpenRateLimitOptions}\n      />\n    )\n  }\n\n  switch (text) {\n    // Local JSX commands don't need a response, but we still want Claude to see them\n    // Tool results render their own interrupt messages\n    case NO_RESPONSE_REQUESTED:\n      return null\n\n    case PROMPT_TOO_LONG_ERROR_MESSAGE: {\n      const upgradeHint = getUpgradeMessage('warning')\n      return (\n        <MessageResponse height={1}>\n          <Text color=\"error\">\n            Context limit reached · /compact or /clear to continue\n            {upgradeHint ? ` · ${upgradeHint}` : ''}\n          </Text>\n        </MessageResponse>\n      )\n    }\n\n    case CREDIT_BALANCE_TOO_LOW_ERROR_MESSAGE:\n      return (\n        <MessageResponse height={1}>\n          <Text color=\"error\">\n            Credit balance too low &middot; Add funds:\n            https://platform.claude.com/settings/billing\n          </Text>\n        </MessageResponse>\n      )\n\n    case INVALID_API_KEY_ERROR_MESSAGE:\n      return <InvalidApiKeyMessage />\n\n    case INVALID_API_KEY_ERROR_MESSAGE_EXTERNAL:\n      return (\n        <MessageResponse height={1}>\n          <Text color=\"error\">{INVALID_API_KEY_ERROR_MESSAGE_EXTERNAL}</Text>\n        </MessageResponse>\n      )\n\n    case ORG_DISABLED_ERROR_MESSAGE_ENV_KEY:\n    case ORG_DISABLED_ERROR_MESSAGE_ENV_KEY_WITH_OAUTH:\n      return (\n        <MessageResponse>\n          <Text color=\"error\">{text}</Text>\n        </MessageResponse>\n      )\n\n    case TOKEN_REVOKED_ERROR_MESSAGE:\n      return (\n        <MessageResponse height={1}>\n          <Text color=\"error\">{TOKEN_REVOKED_ERROR_MESSAGE}</Text>\n        </MessageResponse>\n      )\n\n    case API_TIMEOUT_ERROR_MESSAGE:\n      return (\n        <MessageResponse height={1}>\n          <Text color=\"error\">\n            {API_TIMEOUT_ERROR_MESSAGE}\n            {process.env.API_TIMEOUT_MS && (\n              <>\n                {' '}\n                (API_TIMEOUT_MS={process.env.API_TIMEOUT_MS}ms, try increasing\n                it)\n              </>\n            )}\n          </Text>\n        </MessageResponse>\n      )\n\n    case CUSTOM_OFF_SWITCH_MESSAGE:\n      return (\n        <MessageResponse>\n          <Box flexDirection=\"column\" gap={1}>\n            <Text color=\"error\">\n              We are experiencing high demand for Opus 4.\n            </Text>\n            <Text>\n              To continue immediately, use /model to switch to{' '}\n              {renderModelName(getDefaultSonnetModel())} and continue coding.\n            </Text>\n          </Box>\n        </MessageResponse>\n      )\n\n    // TODO: Move this to a user turn\n    case ERROR_MESSAGE_USER_ABORT:\n      return (\n        <MessageResponse height={1}>\n          <InterruptedByUser />\n        </MessageResponse>\n      )\n\n    default:\n      if (startsWithApiErrorPrefix(text)) {\n        const truncated = !verbose && text.length > MAX_API_ERROR_CHARS\n        return (\n          <MessageResponse>\n            <Box flexDirection=\"column\">\n              <Text color=\"error\">\n                {text === API_ERROR_MESSAGE_PREFIX\n                  ? `${API_ERROR_MESSAGE_PREFIX}: Please wait a moment and try again.`\n                  : truncated\n                    ? text.slice(0, MAX_API_ERROR_CHARS) + '…'\n                    : text}\n              </Text>\n              {truncated && <CtrlOToExpand />}\n            </Box>\n          </MessageResponse>\n        )\n      }\n      return (\n        <Box\n          alignItems=\"flex-start\"\n          flexDirection=\"row\"\n          justifyContent=\"space-between\"\n          marginTop={addMargin ? 1 : 0}\n          width=\"100%\"\n          backgroundColor={isSelected ? 'messageActionsBackground' : undefined}\n        >\n          <Box flexDirection=\"row\">\n            {shouldShowDot && (\n              <NoSelect fromLeftEdge minWidth={2}>\n                <Text color={isSelected ? 'suggestion' : 'text'}>\n                  {BLACK_CIRCLE}\n                </Text>\n              </NoSelect>\n            )}\n            <Box flexDirection=\"column\">\n              <Markdown>{text}</Markdown>\n            </Box>\n          </Box>\n        </Box>\n      )\n  }\n}\n"],"mappings":"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","ignoreList":[]}