-
-
Notifications
You must be signed in to change notification settings - Fork 47
/
Copy pathvite.config.ts
44 lines (39 loc) · 1.28 KB
/
vite.config.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
import { sveltekit } from '@sveltejs/kit/vite';
import path from 'path';
// @ts-expect-error -- Missing types
import svelteMd from 'vite-plugin-svelte-md';
import { rules as pluginRules } from 'eslint-plugin-svelte';
import svelteMdOption from './tools/vite-plugin-svelte-md-option.mjs';
import generateRoutes from './tools/generate-routes.mjs';
import type { UserConfig } from 'vite';
import { fileURLToPath } from 'url';
generateRoutes();
const dirname = path.dirname(fileURLToPath(import.meta.url));
/** @type {import('vite').UserConfig} */
const config: UserConfig = {
plugins: [
svelteMd(
svelteMdOption({
baseUrl: '/eslint-plugin-svelte',
root: path.join(dirname, '../docs')
})
),
sveltekit()
],
define: {
RULES_META: JSON.stringify(Object.values(pluginRules).map((rule) => ({ meta: rule.meta })))
},
ssr: {
// vite-plugin-svelte recognizes svelte-eslint-parser as a library that runs on svelte.
// This confuses the SSR on the Dev server.
// This is the workaround for that.
// https://github.com/sveltejs/vite-plugin-svelte/blob/a1d141e890ac0d1572a46e2bec705aa090236560/packages/vite-plugin-svelte/src/utils/dependencies.ts#L114
external: ['svelte-eslint-parser']
},
build: {
commonjsOptions: {
ignoreDynamicRequires: true
}
}
};
export default config;