32 lines
1.0 KiB
TypeScript
32 lines
1.0 KiB
TypeScript
import { createVueToMarkdownRenderFn } from './vueToMarkdown';
|
|
import type { MarkdownOptions } from '../md/markdown/markdown';
|
|
import type { Plugin } from 'vite';
|
|
import { createMarkdownToVueRenderFn } from '../md/markdownToVue';
|
|
|
|
interface Options {
|
|
root?: string;
|
|
markdown?: MarkdownOptions;
|
|
}
|
|
|
|
export default (options: Options = {}): Plugin => {
|
|
const { root, markdown } = options;
|
|
const vueToMarkdown = createVueToMarkdownRenderFn(root);
|
|
const markdownToVue = createMarkdownToVueRenderFn(root, markdown);
|
|
return {
|
|
name: 'vueToMdToVue',
|
|
async transform(code, id) {
|
|
if (
|
|
(id.endsWith('.vue') && id.indexOf('/demo/') > -1 && id.indexOf('index.vue') === -1) ||
|
|
id.indexOf('/examples/App.vue') > -1
|
|
) {
|
|
const res = vueToMarkdown(code, id);
|
|
// transform .md files into vueSrc so plugin-vue can handle it
|
|
return {
|
|
code: res.ignore ? res.vueSrc : (await markdownToVue(res.vueSrc, id)).vueSrc,
|
|
map: null,
|
|
};
|
|
}
|
|
},
|
|
};
|
|
};
|