Make https addresses in text fields render as links

This commit is contained in:
Piotr Rogowski 2023-06-02 12:30:04 +02:00
parent adeda4310b
commit e59cebf10a
No known key found for this signature in database
GPG Key ID: 4A842D702D9C6F8F
1 changed files with 23 additions and 6 deletions

View File

@ -6,16 +6,33 @@ const TextField = ({ title }: { title: string }) => {
'!': 'warning', '!': 'warning',
}; };
const type = types[title.charAt(0)]; const type = types[title.charAt(0)];
const message = type ? title.substring(1) : title;
let messageTag = <span>message</span>;
// check if message contains a link and render it as a link
const linkRegex = /https?:\/\/[^\s]+/g;
const linkMatch = message.match(linkRegex);
if (linkMatch) {
const link = linkMatch[0];
const linkIndex = message.indexOf(link);
const beforeLink = message.substring(0, linkIndex);
const afterLink = message.substring(linkIndex + link.length);
messageTag = (
<>
{beforeLink}
<a href={link} target='_blank' rel='noreferrer' style={{ color: 'inherit' }}>
{link}
</a>
{afterLink}
</>
);
}
return ( return (
<Typography.Paragraph style={{ display: 'flex', justifyContent: 'center' }}> <Typography.Paragraph style={{ display: 'flex', justifyContent: 'center' }}>
{type ? ( {type ? (
<Alert <Alert message={messageTag} type={type} showIcon style={{ width: '100%', maxWidth: 700 }} />
message={type ? title.substring(1) : title}
type={type}
showIcon
style={{ width: '100%', maxWidth: 700 }}
/>
) : ( ) : (
<Typography.Text type='secondary'>{title}</Typography.Text> <Typography.Text type='secondary'>{title}</Typography.Text>
)} )}