-
Notifications
You must be signed in to change notification settings - Fork 1.3k
Expand file tree
/
Copy pathvite.config.js
More file actions
98 lines (88 loc) · 3.27 KB
/
vite.config.js
File metadata and controls
98 lines (88 loc) · 3.27 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
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
import { defineConfig } from 'vite';
import { resolve } from 'path';
import { fileURLToPath, URL } from 'node:url';
const __dirname = fileURLToPath(new URL('.', import.meta.url));
export default defineConfig({
plugins: [],
root: 'src-modern',
publicDir: '../public-assets',
base: './',
build: {
outDir: '../dist-modern',
emptyOutDir: true,
sourcemap: false,
// Warn for chunks over 500KB
chunkSizeWarningLimit: 500,
rollupOptions: {
input: {
main: resolve(__dirname, 'src-modern/index.html'),
analytics: resolve(__dirname, 'src-modern/analytics.html'),
calendar: resolve(__dirname, 'src-modern/calendar.html'),
elements: resolve(__dirname, 'src-modern/elements.html'),
'elements-alerts': resolve(__dirname, 'src-modern/elements-alerts.html'),
'elements-badges': resolve(__dirname, 'src-modern/elements-badges.html'),
'elements-buttons': resolve(__dirname, 'src-modern/elements-buttons.html'),
'elements-cards': resolve(__dirname, 'src-modern/elements-cards.html'),
'elements-forms': resolve(__dirname, 'src-modern/elements-forms.html'),
'elements-modals': resolve(__dirname, 'src-modern/elements-modals.html'),
'elements-tables': resolve(__dirname, 'src-modern/elements-tables.html'),
files: resolve(__dirname, 'src-modern/files.html'),
forms: resolve(__dirname, 'src-modern/forms.html'),
help: resolve(__dirname, 'src-modern/help.html'),
messages: resolve(__dirname, 'src-modern/messages.html'),
orders: resolve(__dirname, 'src-modern/orders.html'),
products: resolve(__dirname, 'src-modern/products.html'),
reports: resolve(__dirname, 'src-modern/reports.html'),
security: resolve(__dirname, 'src-modern/security.html'),
settings: resolve(__dirname, 'src-modern/settings.html'),
users: resolve(__dirname, 'src-modern/users.html'),
},
output: {
// Manual chunk splitting for better caching
manualChunks: {
// Core Bootstrap framework
'vendor-bootstrap': ['bootstrap', '@popperjs/core'],
// Charting libraries
'vendor-charts': ['chart.js', 'apexcharts'],
// UI utilities
'vendor-ui': ['alpinejs', 'sweetalert2', 'dayjs'],
},
// Asset naming for better caching
chunkFileNames: 'assets/[name]-[hash].js',
entryFileNames: 'assets/[name]-[hash].js',
assetFileNames: 'assets/[name]-[hash].[ext]',
},
},
},
server: {
port: 3000,
open: true,
// Enable CORS for development
cors: true,
},
preview: {
port: 4173,
open: true,
},
css: {
// Enable CSS source maps in development
devSourcemap: true,
preprocessorOptions: {
scss: {
api: 'modern-compiler',
silenceDeprecations: ['legacy-js-api', 'import', 'global-builtin', 'color-functions', 'if-function'],
},
},
},
resolve: {
alias: {
'@': resolve(__dirname, 'src-modern'),
'~bootstrap': resolve(__dirname, 'node_modules/bootstrap'),
},
},
// Optimize dependencies
optimizeDeps: {
include: ['bootstrap', 'alpinejs', 'chart.js', 'apexcharts', 'sweetalert2', 'dayjs'],
exclude: ['lucide'], // Optional dependency, loaded dynamically
},
});