-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvite.config.js
123 lines (116 loc) · 3.26 KB
/
vite.config.js
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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
import { resolve } from 'path';
import { defineConfig, build } from 'vite';
import checker from 'vite-plugin-checker';
import dts from 'vite-plugin-dts';
import fs from 'fs';
import mdx from '@mdx-js/rollup';
const cachedEntries = getEntries();
function fixMdxExports() {
return {
name: 'fix-mdx-exports',
transform(code, id) {
if (id.endsWith('.mdx')) {
const fixedCode = code
.replace(
/^(?!export )function\s+_createMdxContent/gm,
'export function _createMdxContent'
)
.replace(
/^(?!export )function\s+MDXContent/gm,
'export default function MDXContent'
);
return {
code: fixedCode,
map: null,
};
}
return null;
},
};
}
export default defineConfig(async ({ mode }) => {
return {
assetsInclude: ['**/*.woff', '**/*.woff2'],
plugins: [
checker({
typescript: true,
eslint: {
useFlatConfig: true,
lintCommand: 'eslint "./src/**/*.{ts,tsx}"',
},
}),
dts({
outputDir: ['dist'],
}),
mdx({
jsxImportSource: 'lithent', // Preact의 JSX pragma 사용
outputFormat: 'esm',
}),
fixMdxExports(),
],
resolve: {
alias: {
'@': resolve(__dirname, './src'),
'@assets': resolve(__dirname, './assets'),
},
},
build: {
lib: {
entry: cachedEntries,
formats: ['es'],
fileName: format => `[name]-[hash].${format}.js`, // 파일 이름 패턴 지정
},
rollupOptions: {
output: {
// 파일 구조를 유지하는 설정
entryFileNames: assetInfo => {
const relativePath = assetInfo.facadeModuleId.replace(
`${resolve(__dirname, 'src')}/`,
''
);
const dir = relativePath.substring(
0,
relativePath.lastIndexOf('/')
);
return dir ? `${dir}/[name]-[hash].js` : `[name]-[hash].js`;
},
assetFileNames: assetInfo => {
const relativePath = assetInfo.name.replace(
`${resolve(__dirname, 'src')}/`,
''
);
const dir = relativePath.substring(
0,
relativePath.lastIndexOf('/')
);
return dir
? `${dir}/[name]-[hash][extname]`
: `[name]-[hash][extname]`;
},
chunkFileNames: assetInfo => {
return `[name]-[hash].js`;
},
},
},
},
test: {
environment: 'jsdom',
includeSource: ['src/tests/*.{js,ts,jsx,tsx}'],
},
};
});
function getEntries() {
const entriesDir = resolve(__dirname, 'src/pages');
const utilDir = resolve(__dirname, 'src');
const files = fs.readdirSync(entriesDir);
const entries = files.reduce((entries, file) => {
const name = file; // 확장자 제거
entries[name] = resolve(entriesDir, file);
return entries;
}, {});
entries['load.ts'] = `${utilDir}/base/load.ts`;
entries['layout.tsx'] = `${utilDir}/layout.tsx`;
entries['Oops.tsx'] = `${utilDir}/components/Oops.tsx`;
entries['NotFound.tsx'] = `${utilDir}/components/NotFound.tsx`;
return entries;
}