source dump of claude code
at main 270 lines 30 kB view raw
1import { c as _c } from "react/compiler-runtime"; 2import type { TextBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'; 3import React, { useContext } from 'react'; 4import { ERROR_MESSAGE_USER_ABORT } from 'src/services/compact/compact.js'; 5import { isRateLimitErrorMessage } from 'src/services/rateLimitMessages.js'; 6import { BLACK_CIRCLE } from '../../constants/figures.js'; 7import { Box, NoSelect, Text } from '../../ink.js'; 8import { 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'; 9import { isEmptyMessageText, NO_RESPONSE_REQUESTED } from '../../utils/messages.js'; 10import { getUpgradeMessage } from '../../utils/model/contextWindowUpgradeCheck.js'; 11import { getDefaultSonnetModel, renderModelName } from '../../utils/model/model.js'; 12import { isMacOsKeychainLocked } from '../../utils/secureStorage/macOsKeychainStorage.js'; 13import { CtrlOToExpand } from '../CtrlOToExpand.js'; 14import { InterruptedByUser } from '../InterruptedByUser.js'; 15import { Markdown } from '../Markdown.js'; 16import { MessageResponse } from '../MessageResponse.js'; 17import { MessageActionsSelectedContext } from '../messageActions.js'; 18import { RateLimitMessage } from './RateLimitMessage.js'; 19const MAX_API_ERROR_CHARS = 1000; 20type Props = { 21 param: TextBlockParam; 22 addMargin: boolean; 23 shouldShowDot: boolean; 24 verbose: boolean; 25 width?: number | string; 26 onOpenRateLimitOptions?: () => void; 27}; 28function 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} 47export 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":[]}