-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvite.config.ts
56 lines (52 loc) · 1.6 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
45
46
47
48
49
50
51
52
53
54
55
56
import { defineConfig } from 'vite';
import dts from 'vite-plugin-dts';
import fs, { readdirSync } from 'fs';
import path, { resolve } from 'path';
// Function to dynamically generate entry points
const getComponentEntries = () => {
const componentsDir = resolve(__dirname, 'src/components');
const componentFolders = readdirSync(componentsDir).filter((file) =>
fs.statSync(resolve(componentsDir, file)).isDirectory()
);
const entries = {};
componentFolders.forEach((folder) => {
const componentFiles = readdirSync(resolve(componentsDir, folder)).filter(
(file) => file.endsWith('.ts')
);
componentFiles.forEach((file) => {
const name = path.basename(file, '.ts');
entries[name] = resolve(componentsDir, folder, file);
});
});
return entries;
};
export default defineConfig({
plugins: [
dts({
rollupTypes: true,
include: ['src/components/**/*.ts', 'src/vite-env.d.ts']
})
],
build: {
lib: {
entry: 'src/components/index.ts', // Ensure this is your main entry point exporting types
formats: ['es', 'cjs']
},
outDir: 'dist',
rollupOptions: {
input: getComponentEntries(),
output: {
inlineDynamicImports: false,
entryFileNames: '[name].js', // Customize this as needed
chunkFileNames: '[name].js',
assetFileNames: '[name][extname]',
// Add a manual entry point rename if necessary
manualChunks: (id) => {
if (id.includes('node_modules')) {
return 'vendor'; // Group all node_modules into a vendor chunk
}
}
}
}
}
});