πŸ“„ File detail

components/messages/UserResourceUpdateMessage.tsx

🧩 .tsxπŸ“ 121 linesπŸ’Ύ 12,363 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 UserResourceUpdateMessage β€” mainly types, interfaces, or factory objects. Dependencies touch React UI and @anthropic-ai. It composes internal code from constants and ink (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 * as React from 'react'; import { REFRESH_ARROW } from '../../constants/figures.js'; import { Box, Text } from '../../ink.js';

πŸ“€ Exports (heuristic)

  • UserResourceUpdateMessage

πŸ“š External import roots

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

  • react
  • @anthropic-ai

πŸ–₯️ Source preview

import { c as _c } from "react/compiler-runtime";
import type { TextBlockParam } from '@anthropic-ai/sdk/resources/index.mjs';
import * as React from 'react';
import { REFRESH_ARROW } from '../../constants/figures.js';
import { Box, Text } from '../../ink.js';
type Props = {
  addMargin: boolean;
  param: TextBlockParam;
};
type ParsedUpdate = {
  kind: 'resource' | 'polling';
  server: string;
  /** URI for resource updates, tool name for polling updates */
  target: string;
  reason?: string;
};

// Parse resource and polling updates from XML format
function parseUpdates(text: string): ParsedUpdate[] {
  const updates: ParsedUpdate[] = [];

  // Match <mcp-resource-update server="..." uri="...">
  const resourceRegex = /<mcp-resource-update\s+server="([^"]+)"\s+uri="([^"]+)"[^>]*>(?:[\s\S]*?<reason>([^<]+)<\/reason>)?/g;
  let match;
  while ((match = resourceRegex.exec(text)) !== null) {
    updates.push({
      kind: 'resource',
      server: match[1] ?? '',
      target: match[2] ?? '',
      reason: match[3]
    });
  }

  // Match <mcp-polling-update type="tool" server="..." tool="...">
  const pollingRegex = /<mcp-polling-update\s+type="([^"]+)"\s+server="([^"]+)"\s+tool="([^"]+)"[^>]*>(?:[\s\S]*?<reason>([^<]+)<\/reason>)?/g;
  while ((match = pollingRegex.exec(text)) !== null) {
    updates.push({
      kind: 'polling',
      server: match[2] ?? '',
      target: match[3] ?? '',
      reason: match[4]
    });
  }
  return updates;
}

// Format URI for display - show just the meaningful part
function formatUri(uri: string): string {
  // For file:// URIs, show just the filename
  if (uri.startsWith('file://')) {
    const path = uri.slice(7);
    const parts = path.split('/');
    return parts[parts.length - 1] || path;
  }
  // For other URIs, show the whole thing but truncated
  if (uri.length > 40) {
    return uri.slice(0, 39) + '\u2026';
  }
  return uri;
}
export function UserResourceUpdateMessage(t0) {
  const $ = _c(12);
  const {
    addMargin,
    param: t1
  } = t0;
  const {
    text
  } = t1;
  let T0;
  let t2;
  let t3;
  let t4;
  let t5;
  if ($[0] !== addMargin || $[1] !== text) {
    t5 = Symbol.for("react.early_return_sentinel");
    bb0: {
      const updates = parseUpdates(text);
      if (updates.length === 0) {
        t5 = null;
        break bb0;
      }
      T0 = Box;
      t2 = "column";
      t3 = addMargin ? 1 : 0;
      t4 = updates.map(_temp);
    }
    $[0] = addMargin;
    $[1] = text;
    $[2] = T0;
    $[3] = t2;
    $[4] = t3;
    $[5] = t4;
    $[6] = t5;
  } else {
    T0 = $[2];
    t2 = $[3];
    t3 = $[4];
    t4 = $[5];
    t5 = $[6];
  }
  if (t5 !== Symbol.for("react.early_return_sentinel")) {
    return t5;
  }
  let t6;
  if ($[7] !== T0 || $[8] !== t2 || $[9] !== t3 || $[10] !== t4) {
    t6 = <T0 flexDirection={t2} marginTop={t3}>{t4}</T0>;
    $[7] = T0;
    $[8] = t2;
    $[9] = t3;
    $[10] = t4;
    $[11] = t6;
  } else {
    t6 = $[11];
  }
  return t6;
}
function _temp(update, i) {
  return <Box key={i}><Text><Text color="success">{REFRESH_ARROW}</Text>{" "}<Text dimColor={true}>{update.server}:</Text>{" "}<Text color="suggestion">{update.kind === "resource" ? formatUri(update.target) : update.target}</Text>{update.reason && <Text dimColor={true}> Β· {update.reason}</Text>}</Text></Box>;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["TextBlockParam","React","REFRESH_ARROW","Box","Text","Props","addMargin","param","ParsedUpdate","kind","server","target","reason","parseUpdates","text","updates","resourceRegex","match","exec","push","pollingRegex","formatUri","uri","startsWith","path","slice","parts","split","length","UserResourceUpdateMessage","t0","$","_c","t1","T0","t2","t3","t4","t5","Symbol","for","bb0","map","_temp","t6","update","i"],"sources":["UserResourceUpdateMessage.tsx"],"sourcesContent":["import type { TextBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'\nimport * as React from 'react'\nimport { REFRESH_ARROW } from '../../constants/figures.js'\nimport { Box, Text } from '../../ink.js'\n\ntype Props = {\n  addMargin: boolean\n  param: TextBlockParam\n}\n\ntype ParsedUpdate = {\n  kind: 'resource' | 'polling'\n  server: string\n  /** URI for resource updates, tool name for polling updates */\n  target: string\n  reason?: string\n}\n\n// Parse resource and polling updates from XML format\nfunction parseUpdates(text: string): ParsedUpdate[] {\n  const updates: ParsedUpdate[] = []\n\n  // Match <mcp-resource-update server=\"...\" uri=\"...\">\n  const resourceRegex =\n    /<mcp-resource-update\\s+server=\"([^\"]+)\"\\s+uri=\"([^\"]+)\"[^>]*>(?:[\\s\\S]*?<reason>([^<]+)<\\/reason>)?/g\n  let match\n  while ((match = resourceRegex.exec(text)) !== null) {\n    updates.push({\n      kind: 'resource',\n      server: match[1] ?? '',\n      target: match[2] ?? '',\n      reason: match[3],\n    })\n  }\n\n  // Match <mcp-polling-update type=\"tool\" server=\"...\" tool=\"...\">\n  const pollingRegex =\n    /<mcp-polling-update\\s+type=\"([^\"]+)\"\\s+server=\"([^\"]+)\"\\s+tool=\"([^\"]+)\"[^>]*>(?:[\\s\\S]*?<reason>([^<]+)<\\/reason>)?/g\n  while ((match = pollingRegex.exec(text)) !== null) {\n    updates.push({\n      kind: 'polling',\n      server: match[2] ?? '',\n      target: match[3] ?? '',\n      reason: match[4],\n    })\n  }\n\n  return updates\n}\n\n// Format URI for display - show just the meaningful part\nfunction formatUri(uri: string): string {\n  // For file:// URIs, show just the filename\n  if (uri.startsWith('file://')) {\n    const path = uri.slice(7)\n    const parts = path.split('/')\n    return parts[parts.length - 1] || path\n  }\n  // For other URIs, show the whole thing but truncated\n  if (uri.length > 40) {\n    return uri.slice(0, 39) + '\\u2026'\n  }\n  return uri\n}\n\nexport function UserResourceUpdateMessage({\n  addMargin,\n  param: { text },\n}: Props): React.ReactNode {\n  const updates = parseUpdates(text)\n  if (updates.length === 0) return null\n\n  return (\n    <Box flexDirection=\"column\" marginTop={addMargin ? 1 : 0}>\n      {updates.map((update, i) => (\n        <Box key={i}>\n          <Text>\n            <Text color=\"success\">{REFRESH_ARROW}</Text>{' '}\n            <Text dimColor>{update.server}:</Text>{' '}\n            <Text color=\"suggestion\">\n              {update.kind === 'resource'\n                ? formatUri(update.target)\n                : update.target}\n            </Text>\n            {update.reason && <Text dimColor> · {update.reason}</Text>}\n          </Text>\n        </Box>\n      ))}\n    </Box>\n  )\n}\n"],"mappings":"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","ignoreList":[]}