import { Fragment } from 'react' import { SiteLink } from './site-link' // Return a JSX span, linkifying @username, #hashtags, and https://... export function Linkify(props: { text: string }) { const { text } = props const regex = /(?:^|\s)(?:[@#][a-z0-9_]+|https?:\/\/\S+)/gi const matches = text.match(regex) || [] const links = matches.map((match) => { // Matches are in the form: " @username" or "https://example.com" const whitespace = match.match(/^\s/) const symbol = match.trim().substring(0, 1) const tag = match.trim().substring(1) const href = { '@': `/${tag}`, '#': `/tag/${tag}`, }[symbol] ?? match return ( <> {whitespace} {symbol} {tag} ) }) return ( {text.split(regex).map((part, i) => ( {part} {links[i]} ))} ) }