2024-06-26 16:32:45 +08:00
|
|
|
// https://github.com/parcel-bundler/parcel/pull/7922#issuecomment-1750704973
|
|
|
|
|
|
|
|
import { compile } from '@mdx-js/mdx';
|
|
|
|
import { default as ThrowableDiagnostic } from '@parcel/diagnostic';
|
|
|
|
import { Transformer } from '@parcel/plugin';
|
2024-06-27 13:06:44 +08:00
|
|
|
import rehypeMdxCodeProps from 'rehype-mdx-code-props';
|
2024-07-04 14:27:14 +08:00
|
|
|
import remarkGfm from 'remark-gfm';
|
2024-06-26 16:32:45 +08:00
|
|
|
|
|
|
|
export default new Transformer({
|
|
|
|
async transform({ asset }) {
|
|
|
|
const source = await asset.getCode();
|
|
|
|
|
|
|
|
let codeVFile;
|
|
|
|
|
|
|
|
try {
|
|
|
|
codeVFile = await compile(source, {
|
|
|
|
development: true,
|
|
|
|
jsx: true,
|
|
|
|
providerImportSource: '@mdx-js/react',
|
2024-07-04 14:27:14 +08:00
|
|
|
remarkPlugins: [remarkGfm],
|
2024-06-27 13:06:44 +08:00
|
|
|
rehypePlugins: [[rehypeMdxCodeProps, { tagName: 'code' }]],
|
2024-06-26 16:32:45 +08:00
|
|
|
});
|
|
|
|
} catch (error) {
|
|
|
|
const { start, end } = error.position;
|
|
|
|
|
|
|
|
const highlight = {
|
|
|
|
message: error.reason,
|
|
|
|
start,
|
|
|
|
end,
|
|
|
|
};
|
|
|
|
|
|
|
|
if (!(end.line && end.column)) {
|
|
|
|
highlight.end = { ...start };
|
|
|
|
}
|
|
|
|
|
|
|
|
// Adjust for parser and reporter differences
|
|
|
|
highlight.start.column -= 1;
|
|
|
|
highlight.end.column -= 1;
|
|
|
|
|
|
|
|
throw new ThrowableDiagnostic({
|
|
|
|
diagnostic: {
|
|
|
|
message: 'Unable to compile MDX',
|
|
|
|
codeFrames: [
|
|
|
|
{
|
|
|
|
filePath: asset.filePath,
|
|
|
|
code: source,
|
|
|
|
codeHighlights: [highlight],
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
const code = String(codeVFile);
|
|
|
|
|
|
|
|
asset.type = 'jsx';
|
|
|
|
asset.setCode(code);
|
|
|
|
|
|
|
|
return [asset];
|
|
|
|
},
|
|
|
|
});
|