diff options
Diffstat (limited to 'packages/markdown-support/src/codeblock.ts')
-rw-r--r-- | packages/markdown-support/src/codeblock.ts | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/packages/markdown-support/src/codeblock.ts b/packages/markdown-support/src/codeblock.ts new file mode 100644 index 000000000..2f48c6631 --- /dev/null +++ b/packages/markdown-support/src/codeblock.ts @@ -0,0 +1,43 @@ +import { visit } from 'unist-util-visit'; + +/** */ +export function remarkCodeBlock() { + const visitor = (node: any) => { + const { data, meta } = node; + let lang = node.lang || 'html'; // default to html matches GFM behavior. + + let currentClassName = data?.hProperties?.class ?? ''; + node.data = node.data || {}; + node.data.hProperties = node.data.hProperties || {}; + node.data.hProperties = { ...node.data.hProperties, class: `language-${lang} ${currentClassName}`.trim(), lang, meta }; + + return node; + }; + return () => (tree: any) => visit(tree, 'code', visitor); +} + +/** */ +export function rehypeCodeBlock() { + const escapeCode = (code: any) => { + code.children = code.children.map((child: any) => { + if (child.type === 'text') { + return { ...child, value: child.value.replace(/\{/g, '{') }; + } + return child; + }); + }; + const visitor = (node: any) => { + if (node.tagName === 'code') { + escapeCode(node); + return; + } + + if (node.tagName !== 'pre') return; + const code = node.children[0]; + if (code.tagName !== 'code') return; + node.properties = { ...code.properties }; + + return node; + }; + return () => (tree: any) => visit(tree, 'element', visitor); +} |