import morphdom from "morphdom"; import { unified } from "unified"; import remarkParse from "remark-parse"; import remarkGfm from "remark-gfm"; import remarkMath from "remark-math"; import remarkRehype from "remark-rehype"; import rehypeRaw from "rehype-raw"; import rehypeKatex from "rehype-katex"; import rehypeParse from "rehype-parse"; import rehypeSanitize, { defaultSchema } from "rehype-sanitize"; import rehypeStringify from "rehype-stringify"; import "katex/contrib/copy-tex"; import { visit } from "unist-util-visit"; import { toText } from "hast-util-to-text"; import { removePosition } from "unist-util-remove-position"; import { highlight } from "../hooks/cell_editor/live_editor/highlight"; import { renderMermaid } from "./markdown/mermaid"; import { escapeHtml } from "../lib/utils"; /** * Renders markdown content in the given container. */ class Markdown { constructor( container, content, { baseUrl = null, defaultCodeLanguage = null, emptyText = "", allowedUriSchemes = [], useDarkTheme = false, } = {}, ) { this.container = container; this.content = content; this.baseUrl = baseUrl; this.defaultCodeLanguage = defaultCodeLanguage; this.emptyText = emptyText; this.allowedUriSchemes = allowedUriSchemes; this.useDarkTheme = useDarkTheme; this.render(); } /** * Sets new markdown content to be rendered in the container. */ setContent(content) { this.content = content; this.render(); } /** @private */ render() { this.getHtml().then((html) => { // Wrap the HTML in another element, so that we // can use morphdom's childrenOnly option const wrappedHtml = `
${html}