-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathvite.config.js
More file actions
63 lines (62 loc) · 1.58 KB
/
vite.config.js
File metadata and controls
63 lines (62 loc) · 1.58 KB
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
import { defineConfig } from 'vite';
import react from '@vitejs/plugin-react';
import tailwindcss from '@tailwindcss/vite';
import { resolve } from 'path';
import { copyFileSync, mkdirSync } from 'fs';
export default defineConfig({
plugins: [
react(),
tailwindcss(),
{
name: 'copy-pdf-worker',
closeBundle() {
const src = resolve(
__dirname,
'src/attachments/lib/pdf.worker.min.mjs'
);
const dest = resolve(__dirname, 'dist/pdf.worker.min.mjs');
try {
copyFileSync(src, dest);
console.log('✓ Copied pdf.worker.min.mjs to dist/');
} catch (err) {
console.error('Failed to copy pdf.worker.min.mjs:', err);
}
},
},
],
build: {
lib: {
entry: resolve(__dirname, 'src/index.js'),
name: 'ReactAttachmentKit',
formats: ['es', 'cjs'],
fileName: (format) =>
`react-attachment-kit.${format === 'es' ? 'js' : 'cjs'}`,
},
rollupOptions: {
external: [
'react',
'react-dom',
'react/jsx-runtime',
'react-pdf',
'react-intersection-observer',
'media-chrome/react',
],
output: {
globals: {
react: 'React',
'react-dom': 'ReactDOM',
'react/jsx-runtime': 'jsxRuntime',
},
assetFileNames: (assetInfo) => {
if (assetInfo.name?.endsWith('.css')) {
return 'style.css';
}
return assetInfo.name;
},
},
},
cssCodeSplit: false,
sourcemap: true,
emptyOutDir: true,
},
});