diff options
Diffstat (limited to 'packages/cli/src/ui/utils/InlineMarkdownRenderer.tsx')
| -rw-r--r-- | packages/cli/src/ui/utils/InlineMarkdownRenderer.tsx | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/packages/cli/src/ui/utils/InlineMarkdownRenderer.tsx b/packages/cli/src/ui/utils/InlineMarkdownRenderer.tsx index ff8d6257..4c05a28f 100644 --- a/packages/cli/src/ui/utils/InlineMarkdownRenderer.tsx +++ b/packages/cli/src/ui/utils/InlineMarkdownRenderer.tsx @@ -22,10 +22,15 @@ interface RenderInlineProps { } const RenderInlineInternal: React.FC<RenderInlineProps> = ({ text }) => { + // Early return for plain text without markdown or URLs + if (!/[*_~`<[https?:]/.test(text)) { + return <Text>{text}</Text>; + } + const nodes: React.ReactNode[] = []; let lastIndex = 0; const inlineRegex = - /(\*\*.*?\*\*|\*.*?\*|_.*?_|~~.*?~~|\[.*?\]\(.*?\)|`+.+?`+|<u>.*?<\/u>)/g; + /(\*\*.*?\*\*|\*.*?\*|_.*?_|~~.*?~~|\[.*?\]\(.*?\)|`+.+?`+|<u>.*?<\/u>|https?:\/\/\S+)/g; let match; while ((match = inlineRegex.exec(text)) !== null) { @@ -126,6 +131,12 @@ const RenderInlineInternal: React.FC<RenderInlineProps> = ({ text }) => { )} </Text> ); + } else if (fullMatch.match(/^https?:\/\//)) { + renderedNode = ( + <Text key={key} color={Colors.AccentBlue}> + {fullMatch} + </Text> + ); } } catch (e) { console.error('Error parsing inline markdown part:', fullMatch, e); |
