-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvite.config.app.ts
90 lines (87 loc) · 2.48 KB
/
vite.config.app.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
import fs from "fs";
import path from "path";
import { defineConfig } from "vite";
import matter from "gray-matter";
import ViteVue from "@vitejs/plugin-vue";
import VitePages from "vite-plugin-pages";
import ViteMarkdown from "vite-plugin-md";
import MarkdownItExternalLinks from "markdown-it-external-links";
import ViteFonts from "vite-plugin-fonts";
import ViteIcons from "unplugin-icons/vite";
import monaco from "vite-plugin-monaco-editor";
//@ts-ignore
const ViteMonaco = monaco.default;
import postcss from "./postcss.config";
import { utoa } from "./src/app/functions/encoding";
function editorPlugin(md) {
const defaultFence = md.renderer.rules.fence;
md.renderer.rules.fence = function () {
const [tokens, idx, _options, _env, _slf] = arguments;
const lang = tokens[idx].info.trim();
const content = tokens[idx].content;
if (lang === "md") {
return `
<Editor source="${utoa(content)}" />
`;
}
return defaultFence(...arguments);
};
return md;
}
export default defineConfig({
resolve: {
alias: {
vue: "vue/dist/vue.esm-bundler.js",
},
},
css: { postcss },
plugins: [
ViteVue({ reactivityTransform: true, include: [/\.vue$/, /\.md$/] }),
VitePages({
extensions: ["vue", "md"],
dirs: "docs",
extendRoute(route) {
const routePath = path.resolve(__dirname, route.component.slice(1));
const md = fs.readFileSync(routePath, "utf-8");
const { data } = matter(md);
route.meta = Object.assign(route.meta || {}, { frontmatter: data });
return route;
},
}),
ViteMarkdown({
wrapperComponent: "Layout",
markdownItOptions: { typographer: false, breaks: true },
markdownItSetup: (md) =>
md.use(editorPlugin).use(MarkdownItExternalLinks, {
externalClassName: null,
externalTarget: "_blank",
}),
}),
//@ts-ignore
ViteFonts.default({
google: {
families: [
{
name: "IBM Plex Sans",
styles: "ital,wght@0,400;0,500;0,700;1,400;1,500;1,700",
},
{ name: "Cousine" },
],
},
}),
ViteIcons({ autoInstall: true }),
ViteMonaco({}),
],
build: {
emptyOutDir: false,
outDir: "dist/docs",
rollupOptions: {
output: {
manualChunks: {
htmlWorker: [`monaco-editor/esm/vs/language/html/html.worker`],
editorWorker: [`monaco-editor/esm/vs/editor/editor.worker`],
},
},
},
},
});