| | |
| | | import calloutScript from "../../components/scripts/callout.inline.ts" |
| | | // @ts-ignore |
| | | import checkboxScript from "../../components/scripts/checkbox.inline.ts" |
| | | // @ts-ignore |
| | | import mermaidExtensionScript from "../../components/scripts/mermaid.inline.ts" |
| | | import mermaidStyle from "../../components/styles/mermaid.inline.scss" |
| | | import { FilePath, pathToRoot, slugTag, slugifyFilePath } from "../../util/path" |
| | | import { toHast } from "mdast-util-to-hast" |
| | | import { toHtml } from "hast-util-to-html" |
| | |
| | | export const tableRegex = new RegExp(/^\|([^\n])+\|\n(\|)( ?:?-{3,}:? ?\|)+\n(\|([^\n])+\|\n?)+/gm) |
| | | |
| | | // matches any wikilink, only used for escaping wikilinks inside tables |
| | | export const tableWikilinkRegex = new RegExp(/(!?\[\[[^\]]*?\]\])/g) |
| | | export const tableWikilinkRegex = new RegExp(/(!?\[\[[^\]]*?\]\]|\[\^[^\]]*?\])/g) |
| | | |
| | | const highlightRegex = new RegExp(/==([^=]+)==/g) |
| | | const commentRegex = new RegExp(/%%[\s\S]*?%%/g) |
| | |
| | | src = src.toString() |
| | | } |
| | | |
| | | src = src.replace(commentRegex, "") |
| | | src = (src as string).replace(commentRegex, "") |
| | | } |
| | | |
| | | // pre-transform blockquotes |
| | |
| | | src = src.toString() |
| | | } |
| | | |
| | | src = src.replace(calloutLineRegex, (value) => { |
| | | src = (src as string).replace(calloutLineRegex, (value) => { |
| | | // force newline after title of callout |
| | | return value + "\n> " |
| | | }) |
| | |
| | | } |
| | | |
| | | // replace all wikilinks inside a table first |
| | | src = src.replace(tableRegex, (value) => { |
| | | src = (src as string).replace(tableRegex, (value) => { |
| | | // escape all aliases and headers in wikilinks inside a table |
| | | return value.replace(tableWikilinkRegex, (_value, raw) => { |
| | | // const [raw]: (string | undefined)[] = capture |
| | |
| | | }) |
| | | |
| | | // replace all other wikilinks |
| | | src = src.replace(wikilinkRegex, (value, ...capture) => { |
| | | src = (src as string).replace(wikilinkRegex, (value, ...capture) => { |
| | | const [rawFp, rawHeader, rawAlias]: (string | undefined)[] = capture |
| | | |
| | | const [fp, anchor] = splitAnchor(`${rawFp ?? ""}${rawHeader ?? ""}`) |
| | |
| | | |
| | | if (opts.mermaid) { |
| | | plugins.push(() => { |
| | | return (tree: Root, _file) => { |
| | | return (tree: Root, file) => { |
| | | visit(tree, "code", (node: Code) => { |
| | | if (node.lang === "mermaid") { |
| | | file.data.hasMermaidDiagram = true |
| | | node.data = { |
| | | hProperties: { |
| | | className: ["mermaid"], |
| | |
| | | }) |
| | | } |
| | | |
| | | if (opts.mermaid) { |
| | | js.push({ |
| | | script: mermaidExtensionScript, |
| | | loadTime: "afterDOMReady", |
| | | moduleType: "module", |
| | | contentType: "inline", |
| | | }) |
| | | css.push({ |
| | | content: mermaidStyle, |
| | | inline: true, |
| | | }) |
| | | } |
| | | |
| | | return { js, css } |
| | | }, |
| | | } |
| | |
| | | interface DataMap { |
| | | blocks: Record<string, Element> |
| | | htmlAst: HtmlRoot |
| | | hasMermaidDiagram: boolean | undefined |
| | | } |
| | | } |