πŸ“„ File detail

components/messages/AssistantTextMessage.tsx

🧩 .tsxπŸ“ 270 linesπŸ’Ύ 30,427 bytesπŸ“ text
← Back to All Files

🎯 Use case

This file lives under β€œcomponents/”, which covers shared React UI pieces. On the API surface it exposes AssistantTextMessage β€” mainly types, interfaces, or factory objects. Dependencies touch React UI, @anthropic-ai, and src. It composes internal code from constants, ink, services, utils, and CtrlOToExpand (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 type { TextBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'; import React, { useContext } from 'react'; import { ERROR_MESSAGE_USER_ABORT } from 'src/services/compact/compact.js'; import { isRateLimitErrorMessage } from 'src/services/rateLimitMessages.js';

πŸ“€ Exports (heuristic)

  • AssistantTextMessage

πŸ“š External import roots

Package roots from from "…" (relative paths omitted).

  • react
  • @anthropic-ai
  • src

πŸ–₯️ Source preview

import { c as _c } from "react/compiler-runtime";
import type { TextBlockParam } from '@anthropic-ai/sdk/resources/index.mjs';
import React, { useContext } from 'react';
import { ERROR_MESSAGE_USER_ABORT } from 'src/services/compact/compact.js';
import { isRateLimitErrorMessage } from 'src/services/rateLimitMessages.js';
import { BLACK_CIRCLE } from '../../constants/figures.js';
import { Box, NoSelect, Text } from '../../ink.js';
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';
import { isEmptyMessageText, NO_RESPONSE_REQUESTED } from '../../utils/messages.js';
import { getUpgradeMessage } from '../../utils/model/contextWindowUpgradeCheck.js';
import { getDefaultSonnetModel, renderModelName } from '../../utils/model/model.js';
import { isMacOsKeychainLocked } from '../../utils/secureStorage/macOsKeychainStorage.js';
import { CtrlOToExpand } from '../CtrlOToExpand.js';
import { InterruptedByUser } from '../InterruptedByUser.js';
import { Markdown } from '../Markdown.js';
import { MessageResponse } from '../MessageResponse.js';
import { MessageActionsSelectedContext } from '../messageActions.js';
import { RateLimitMessage } from './RateLimitMessage.js';
const MAX_API_ERROR_CHARS = 1000;
type Props = {
  param: TextBlockParam;
  addMargin: boolean;
  shouldShowDot: boolean;
  verbose: boolean;
  width?: number | string;
  onOpenRateLimitOptions?: () => void;
};
function InvalidApiKeyMessage() {
  const $ = _c(2);
  let t0;
  if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
    t0 = isMacOsKeychainLocked();
    $[0] = t0;
  } else {
    t0 = $[0];
  }
  const isKeychainLocked = t0;
  let t1;
  if ($[1] === Symbol.for("react.memo_cache_sentinel")) {
    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>;
    $[1] = t1;
  } else {
    t1 = $[1];
  }
  return t1;
}
export function AssistantTextMessage(t0) {
  const $ = _c(34);
  const {
    param: t1,
    addMargin,
    shouldShowDot,
    verbose,
    onOpenRateLimitOptions
  } = t0;
  const {
    text
  } = t1;
  const isSelected = useContext(MessageActionsSelectedContext);
  if (isEmptyMessageText(text)) {
    return null;
  }
  if (isRateLimitErrorMessage(text)) {
    let t2;
    if ($[0] !== onOpenRateLimitOptions || $[1] !== text) {
      t2 = <RateLimitMessage text={text} onOpenRateLimitOptions={onOpenRateLimitOptions} />;
      $[0] = onOpenRateLimitOptions;
      $[1] = text;
      $[2] = t2;
    } else {
      t2 = $[2];
    }
    return t2;
  }
  switch (text) {
    case NO_RESPONSE_REQUESTED:
      {
        return null;
      }
    case PROMPT_TOO_LONG_ERROR_MESSAGE:
      {
        let t2;
        if ($[3] === Symbol.for("react.memo_cache_sentinel")) {
          t2 = getUpgradeMessage("warning");
          $[3] = t2;
        } else {
          t2 = $[3];
        }
        const upgradeHint = t2;
        let t3;
        if ($[4] === Symbol.for("react.memo_cache_sentinel")) {
          t3 = <MessageResponse height={1}><Text color="error">Context limit reached Β· /compact or /clear to continue{upgradeHint ? ` Β· ${upgradeHint}` : ""}</Text></MessageResponse>;
          $[4] = t3;
        } else {
          t3 = $[4];
        }
        return t3;
      }
    case CREDIT_BALANCE_TOO_LOW_ERROR_MESSAGE:
      {
        let t2;
        if ($[5] === Symbol.for("react.memo_cache_sentinel")) {
          t2 = <MessageResponse height={1}><Text color="error">Credit balance too low Β· Add funds: https://platform.claude.com/settings/billing</Text></MessageResponse>;
          $[5] = t2;
        } else {
          t2 = $[5];
        }
        return t2;
      }
    case INVALID_API_KEY_ERROR_MESSAGE:
      {
        let t2;
        if ($[6] === Symbol.for("react.memo_cache_sentinel")) {
          t2 = <InvalidApiKeyMessage />;
          $[6] = t2;
        } else {
          t2 = $[6];
        }
        return t2;
      }
    case INVALID_API_KEY_ERROR_MESSAGE_EXTERNAL:
      {
        let t2;
        if ($[7] === Symbol.for("react.memo_cache_sentinel")) {
          t2 = <MessageResponse height={1}><Text color="error">{INVALID_API_KEY_ERROR_MESSAGE_EXTERNAL}</Text></MessageResponse>;
          $[7] = t2;
        } else {
          t2 = $[7];
        }
        return t2;
      }
    case ORG_DISABLED_ERROR_MESSAGE_ENV_KEY:
    case ORG_DISABLED_ERROR_MESSAGE_ENV_KEY_WITH_OAUTH:
      {
        let t2;
        if ($[8] !== text) {
          t2 = <MessageResponse><Text color="error">{text}</Text></MessageResponse>;
          $[8] = text;
          $[9] = t2;
        } else {
          t2 = $[9];
        }
        return t2;
      }
    case TOKEN_REVOKED_ERROR_MESSAGE:
      {
        let t2;
        if ($[10] === Symbol.for("react.memo_cache_sentinel")) {
          t2 = <MessageResponse height={1}><Text color="error">{TOKEN_REVOKED_ERROR_MESSAGE}</Text></MessageResponse>;
          $[10] = t2;
        } else {
          t2 = $[10];
        }
        return t2;
      }
    case API_TIMEOUT_ERROR_MESSAGE:
      {
        let t2;
        if ($[11] === Symbol.for("react.memo_cache_sentinel")) {
          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>;
          $[11] = t2;
        } else {
          t2 = $[11];
        }
        return t2;
      }
    case CUSTOM_OFF_SWITCH_MESSAGE:
      {
        let t2;
        if ($[12] === Symbol.for("react.memo_cache_sentinel")) {
          t2 = <Text color="error">We are experiencing high demand for Opus 4.</Text>;
          $[12] = t2;
        } else {
          t2 = $[12];
        }
        let t3;
        if ($[13] === Symbol.for("react.memo_cache_sentinel")) {
          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>;
          $[13] = t3;
        } else {
          t3 = $[13];
        }
        return t3;
      }
    case ERROR_MESSAGE_USER_ABORT:
      {
        let t2;
        if ($[14] === Symbol.for("react.memo_cache_sentinel")) {
          t2 = <MessageResponse height={1}><InterruptedByUser /></MessageResponse>;
          $[14] = t2;
        } else {
          t2 = $[14];
        }
        return t2;
      }
    default:
      {
        if (startsWithApiErrorPrefix(text)) {
          const truncated = !verbose && text.length > MAX_API_ERROR_CHARS;
          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;
          let t3;
          if ($[15] !== t2) {
            t3 = <Text color="error">{t2}</Text>;
            $[15] = t2;
            $[16] = t3;
          } else {
            t3 = $[16];
          }
          let t4;
          if ($[17] !== truncated) {
            t4 = truncated && <CtrlOToExpand />;
            $[17] = truncated;
            $[18] = t4;
          } else {
            t4 = $[18];
          }
          let t5;
          if ($[19] !== t3 || $[20] !== t4) {
            t5 = <MessageResponse><Box flexDirection="column">{t3}{t4}</Box></MessageResponse>;
            $[19] = t3;
            $[20] = t4;
            $[21] = t5;
          } else {
            t5 = $[21];
          }
          return t5;
        }
        const t2 = addMargin ? 1 : 0;
        const t3 = isSelected ? "messageActionsBackground" : undefined;
        let t4;
        if ($[22] !== isSelected || $[23] !== shouldShowDot) {
          t4 = shouldShowDot && <NoSelect fromLeftEdge={true} minWidth={2}><Text color={isSelected ? "suggestion" : "text"}>{BLACK_CIRCLE}</Text></NoSelect>;
          $[22] = isSelected;
          $[23] = shouldShowDot;
          $[24] = t4;
        } else {
          t4 = $[24];
        }
        let t5;
        if ($[25] !== text) {
          t5 = <Box flexDirection="column"><Markdown>{text}</Markdown></Box>;
          $[25] = text;
          $[26] = t5;
        } else {
          t5 = $[26];
        }
        let t6;
        if ($[27] !== t4 || $[28] !== t5) {
          t6 = <Box flexDirection="row">{t4}{t5}</Box>;
          $[27] = t4;
          $[28] = t5;
          $[29] = t6;
        } else {
          t6 = $[29];
        }
        let t7;
        if ($[30] !== t2 || $[31] !== t3 || $[32] !== t6) {
          t7 = <Box alignItems="flex-start" flexDirection="row" justifyContent="space-between" marginTop={t2} width="100%" backgroundColor={t3}>{t6}</Box>;
          $[30] = t2;
          $[31] = t3;
          $[32] = t6;
          $[33] = t7;
        } else {
          t7 = $[33];
        }
        return t7;
      }
  }
}
//# 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":[]}