mirror of
https://github.com/LemmyNet/lemmy-ui.git
synced 2025-01-10 20:15:50 +00:00
Use shorter regex in community link parser
This commit is contained in:
parent
fc0c063426
commit
73147ae37c
2 changed files with 39 additions and 32 deletions
|
@ -33,6 +33,6 @@ export const emDash = "\u2014";
|
||||||
* /u/username@server.com
|
* /u/username@server.com
|
||||||
*/
|
*/
|
||||||
export const instanceLinkRegex =
|
export const instanceLinkRegex =
|
||||||
/(\/[c|m|u]\/[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}|![a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,})/g;
|
/(\/[c|m|u]\/|!)[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}/g;
|
||||||
|
|
||||||
export const testHost = "0.0.0.0:8536";
|
export const testHost = "0.0.0.0:8536";
|
||||||
|
|
|
@ -73,7 +73,7 @@ const html5EmbedConfig = {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
function localCommunityLinkParser(md) {
|
function localCommunityLinkParser(md: MarkdownIt) {
|
||||||
md.core.ruler.push("replace-text", state => {
|
md.core.ruler.push("replace-text", state => {
|
||||||
for (let i = 0; i < state.tokens.length; i++) {
|
for (let i = 0; i < state.tokens.length; i++) {
|
||||||
if (state.tokens[i].type !== "inline") {
|
if (state.tokens[i].type !== "inline") {
|
||||||
|
@ -83,42 +83,49 @@ function localCommunityLinkParser(md) {
|
||||||
for (let j = inlineTokens.length - 1; j >= 0; j--) {
|
for (let j = inlineTokens.length - 1; j >= 0; j--) {
|
||||||
if (
|
if (
|
||||||
inlineTokens[j].type === "text" &&
|
inlineTokens[j].type === "text" &&
|
||||||
instanceLinkRegex.test(inlineTokens[j].content)
|
new RegExp(instanceLinkRegex).test(inlineTokens[j].content)
|
||||||
) {
|
) {
|
||||||
const textParts = inlineTokens[j].content.split(instanceLinkRegex);
|
const text = inlineTokens[j].content;
|
||||||
|
const matches = Array.from(text.matchAll(instanceLinkRegex));
|
||||||
|
|
||||||
|
let lastIndex = 0;
|
||||||
const newTokens: Token[] = [];
|
const newTokens: Token[] = [];
|
||||||
|
|
||||||
for (const part of textParts) {
|
for (const match: RegExpMatchArray of matches) {
|
||||||
let linkClass = "community-link";
|
// If there is plain text before the match, add it as a separate token
|
||||||
if (instanceLinkRegex.test(part)) {
|
if (match.index !== undefined && match.index > lastIndex) {
|
||||||
// Rewrite !community@server.com and KBin /m/community@server.com to local urls
|
|
||||||
let href;
|
|
||||||
if (part.startsWith("!")) {
|
|
||||||
href = "/c/" + part.substring(1);
|
|
||||||
} else if (part.startsWith("/m/")) {
|
|
||||||
href = "/c/" + part.substring(3);
|
|
||||||
} else {
|
|
||||||
href = part;
|
|
||||||
if (part.startsWith("/u/")) {
|
|
||||||
linkClass = "user-link";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const linkOpenToken = new state.Token("link_open", "a", 1);
|
|
||||||
linkOpenToken.attrs = [
|
|
||||||
["href", href],
|
|
||||||
["class", linkClass],
|
|
||||||
];
|
|
||||||
const textToken = new state.Token("text", "", 0);
|
const textToken = new state.Token("text", "", 0);
|
||||||
textToken.content = part;
|
textToken.content = text.slice(lastIndex, match.index);
|
||||||
const linkCloseToken = new state.Token("link_close", "a", -1);
|
|
||||||
|
|
||||||
newTokens.push(linkOpenToken, textToken, linkCloseToken);
|
|
||||||
} else {
|
|
||||||
const textToken = new state.Token("text", "", 0);
|
|
||||||
textToken.content = part;
|
|
||||||
newTokens.push(textToken);
|
newTokens.push(textToken);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Determine the new href
|
||||||
|
let href;
|
||||||
|
if (match[0].startsWith("!")) {
|
||||||
|
href = "/c/" + match[0].substring(1);
|
||||||
|
} else if (match[0].startsWith("/m/")) {
|
||||||
|
href = "/c/" + match[0].substring(3);
|
||||||
|
} else {
|
||||||
|
href = match[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
const linkOpenToken = new state.Token("link_open", "a", 1);
|
||||||
|
linkOpenToken.attrs = [["href", href]];
|
||||||
|
const textToken = new state.Token("text", "", 0);
|
||||||
|
textToken.content = match[0];
|
||||||
|
const linkCloseToken = new state.Token("link_close", "a", -1);
|
||||||
|
|
||||||
|
newTokens.push(linkOpenToken, textToken, linkCloseToken);
|
||||||
|
|
||||||
|
lastIndex =
|
||||||
|
(match.index !== undefined ? match.index : 0) + match[0].length;
|
||||||
|
}
|
||||||
|
|
||||||
|
// If there is plain text after the last match, add it as a separate token
|
||||||
|
if (lastIndex < text.length) {
|
||||||
|
const textToken = new state.Token("text", "", 0);
|
||||||
|
textToken.content = text.slice(lastIndex);
|
||||||
|
newTokens.push(textToken);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Replace the original token with the new tokens
|
// Replace the original token with the new tokens
|
||||||
|
|
Loading…
Reference in a new issue