source dump of claude code
at main 121 lines 12 kB view raw
1import { c as _c } from "react/compiler-runtime"; 2import type { TextBlockParam } from '@anthropic-ai/sdk/resources/index.mjs'; 3import * as React from 'react'; 4import { REFRESH_ARROW } from '../../constants/figures.js'; 5import { Box, Text } from '../../ink.js'; 6type Props = { 7 addMargin: boolean; 8 param: TextBlockParam; 9}; 10type ParsedUpdate = { 11 kind: 'resource' | 'polling'; 12 server: string; 13 /** URI for resource updates, tool name for polling updates */ 14 target: string; 15 reason?: string; 16}; 17 18// Parse resource and polling updates from XML format 19function parseUpdates(text: string): ParsedUpdate[] { 20 const updates: ParsedUpdate[] = []; 21 22 // Match <mcp-resource-update server="..." uri="..."> 23 const resourceRegex = /<mcp-resource-update\s+server="([^"]+)"\s+uri="([^"]+)"[^>]*>(?:[\s\S]*?<reason>([^<]+)<\/reason>)?/g; 24 let match; 25 while ((match = resourceRegex.exec(text)) !== null) { 26 updates.push({ 27 kind: 'resource', 28 server: match[1] ?? '', 29 target: match[2] ?? '', 30 reason: match[3] 31 }); 32 } 33 34 // Match <mcp-polling-update type="tool" server="..." tool="..."> 35 const pollingRegex = /<mcp-polling-update\s+type="([^"]+)"\s+server="([^"]+)"\s+tool="([^"]+)"[^>]*>(?:[\s\S]*?<reason>([^<]+)<\/reason>)?/g; 36 while ((match = pollingRegex.exec(text)) !== null) { 37 updates.push({ 38 kind: 'polling', 39 server: match[2] ?? '', 40 target: match[3] ?? '', 41 reason: match[4] 42 }); 43 } 44 return updates; 45} 46 47// Format URI for display - show just the meaningful part 48function formatUri(uri: string): string { 49 // For file:// URIs, show just the filename 50 if (uri.startsWith('file://')) { 51 const path = uri.slice(7); 52 const parts = path.split('/'); 53 return parts[parts.length - 1] || path; 54 } 55 // For other URIs, show the whole thing but truncated 56 if (uri.length > 40) { 57 return uri.slice(0, 39) + '\u2026'; 58 } 59 return uri; 60} 61export function UserResourceUpdateMessage(t0) { 62 const $ = _c(12); 63 const { 64 addMargin, 65 param: t1 66 } = t0; 67 const { 68 text 69 } = t1; 70 let T0; 71 let t2; 72 let t3; 73 let t4; 74 let t5; 75 if ($[0] !== addMargin || $[1] !== text) { 76 t5 = Symbol.for("react.early_return_sentinel"); 77 bb0: { 78 const updates = parseUpdates(text); 79 if (updates.length === 0) { 80 t5 = null; 81 break bb0; 82 } 83 T0 = Box; 84 t2 = "column"; 85 t3 = addMargin ? 1 : 0; 86 t4 = updates.map(_temp); 87 } 88 $[0] = addMargin; 89 $[1] = text; 90 $[2] = T0; 91 $[3] = t2; 92 $[4] = t3; 93 $[5] = t4; 94 $[6] = t5; 95 } else { 96 T0 = $[2]; 97 t2 = $[3]; 98 t3 = $[4]; 99 t4 = $[5]; 100 t5 = $[6]; 101 } 102 if (t5 !== Symbol.for("react.early_return_sentinel")) { 103 return t5; 104 } 105 let t6; 106 if ($[7] !== T0 || $[8] !== t2 || $[9] !== t3 || $[10] !== t4) { 107 t6 = <T0 flexDirection={t2} marginTop={t3}>{t4}</T0>; 108 $[7] = T0; 109 $[8] = t2; 110 $[9] = t3; 111 $[10] = t4; 112 $[11] = t6; 113 } else { 114 t6 = $[11]; 115 } 116 return t6; 117} 118function _temp(update, i) { 119 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>; 120} 121//# 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":[]}