37 lines
965 B
TypeScript
37 lines
965 B
TypeScript
import { AutoLinkPlugin } from "@lexical/react/LexicalAutoLinkPlugin";
|
|
|
|
const URL_MATCHER =
|
|
/((https?:\/\/(www\.)?)|(www\.))[-a-zA-Z0-9@:%._+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%_+.~#?&//=]*)/;
|
|
|
|
const EMAIL_MATCHER =
|
|
/(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))/;
|
|
|
|
const MATCHERS = [
|
|
(text: any) => {
|
|
const match = URL_MATCHER.exec(text);
|
|
return (
|
|
match && {
|
|
index: match.index,
|
|
length: match[0].length,
|
|
text: match[0],
|
|
url: match[0],
|
|
}
|
|
);
|
|
},
|
|
(text: any) => {
|
|
const match = EMAIL_MATCHER.exec(text);
|
|
return (
|
|
match && {
|
|
index: match.index,
|
|
length: match[0].length,
|
|
text: match[0],
|
|
url: `mailto:${match[0]}`,
|
|
}
|
|
);
|
|
},
|
|
];
|
|
|
|
export default function PlaygroundAutoLinkPlugin() {
|
|
return <AutoLinkPlugin matchers={MATCHERS} />;
|
|
}
|