2022-06-03 13:38:45 +00:00
|
|
|
import type * as fromMarkdown from 'mdast-util-from-markdown';
|
|
|
|
import type { Tag } from 'mdast-util-mdx-jsx';
|
2022-06-06 16:49:53 +00:00
|
|
|
import { mdxFromMarkdown, mdxToMarkdown } from './mdast-util-mdxish.js';
|
2022-06-08 17:43:10 +00:00
|
|
|
import { mdxjs } from './mdxjs.js';
|
2022-05-24 22:02:11 +00:00
|
|
|
|
2022-06-10 22:32:23 +00:00
|
|
|
// Prepare markdown extensions once to prevent performance issues
|
|
|
|
const extMdxJs = mdxjs({});
|
|
|
|
const extMdxFromMarkdown = makeFromMarkdownLessStrict(mdxFromMarkdown());
|
|
|
|
const extMdxToMarkdown = mdxToMarkdown();
|
|
|
|
|
|
|
|
export default function remarkMdxish(this: any) {
|
2022-05-24 22:03:29 +00:00
|
|
|
const data = this.data();
|
2022-05-24 22:02:11 +00:00
|
|
|
|
2022-06-10 22:32:23 +00:00
|
|
|
add('micromarkExtensions', extMdxJs);
|
|
|
|
add('fromMarkdownExtensions', extMdxFromMarkdown);
|
|
|
|
add('toMarkdownExtensions', extMdxToMarkdown);
|
2022-05-24 22:02:11 +00:00
|
|
|
|
2022-05-24 22:03:29 +00:00
|
|
|
function add(field: string, value: unknown) {
|
|
|
|
const list = data[field] ? data[field] : (data[field] = []);
|
|
|
|
list.push(value);
|
|
|
|
}
|
2022-05-24 22:02:11 +00:00
|
|
|
}
|
2022-06-03 13:38:45 +00:00
|
|
|
|
|
|
|
function makeFromMarkdownLessStrict(extensions: fromMarkdown.Extension[]) {
|
2022-06-03 13:39:43 +00:00
|
|
|
extensions.forEach((extension) => {
|
2022-06-03 13:38:45 +00:00
|
|
|
// Fix exit handlers that are too strict
|
2022-06-03 13:39:43 +00:00
|
|
|
['mdxJsxFlowTag', 'mdxJsxTextTag'].forEach((exitHandler) => {
|
|
|
|
if (!extension.exit || !extension.exit[exitHandler]) return;
|
|
|
|
extension.exit[exitHandler] = chainHandlers(fixSelfClosing, extension.exit[exitHandler]);
|
2022-06-03 13:38:45 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
return extensions;
|
|
|
|
}
|
|
|
|
|
|
|
|
const selfClosingTags = new Set([
|
2022-06-03 13:39:43 +00:00
|
|
|
'area',
|
|
|
|
'base',
|
|
|
|
'br',
|
|
|
|
'col',
|
|
|
|
'embed',
|
|
|
|
'hr',
|
|
|
|
'img',
|
|
|
|
'input',
|
|
|
|
'link',
|
|
|
|
'meta',
|
|
|
|
'source',
|
|
|
|
'track',
|
|
|
|
'wbr',
|
2022-06-03 13:38:45 +00:00
|
|
|
]);
|
|
|
|
|
|
|
|
function fixSelfClosing(this: fromMarkdown.CompileContext) {
|
|
|
|
const tag = this.getData('mdxJsxTag') as Tag;
|
2022-06-03 13:39:43 +00:00
|
|
|
if (tag.name && selfClosingTags.has(tag.name)) tag.selfClosing = true;
|
2022-06-03 13:38:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function chainHandlers(...handlers: fromMarkdown.Handle[]) {
|
2022-06-03 13:39:43 +00:00
|
|
|
return function handlerChain(this: fromMarkdown.CompileContext, token: fromMarkdown.Token) {
|
|
|
|
handlers.forEach((handler) => handler.call(this, token));
|
2022-06-03 13:38:45 +00:00
|
|
|
};
|
|
|
|
}
|