This commit is contained in:
ct
2025-07-15 04:49:58 +08:00
parent f718bb4aaa
commit 23e72d238c

View File

@@ -39,64 +39,79 @@ export default defineConfig({
build: {
rollupOptions: {
output: {
manualChunks: (id) => {
// Skip manual chunks for SSR builds to avoid conflicts
if (process.env.NODE_ENV === 'development' && id.includes('ssr')) {
return;
}
// React core - keep separate and first
if (id.includes('react') || id.includes('react-dom')) {
return 'react-vendor';
}
// Heavy libraries
if (id.includes('@ffmpeg')) {
return 'ffmpeg';
}
if (id.includes('motion')) {
return 'motion';
}
if (id.includes('konva')) {
return 'canvas';
}
if (id.includes('recharts')) {
return 'charts';
}
// Radix UI components
if (id.includes('@radix-ui')) {
return 'radix-ui';
}
manualChunks: {
// React MUST be first and separate to avoid dependency issues
'react-vendor': ['react', 'react-dom'],
// Heavy libraries that can be safely separated
'ffmpeg': ['@ffmpeg/ffmpeg', '@ffmpeg/util'],
'motion': ['motion'],
'canvas': ['konva', 'react-konva', 'react-konva-utils'],
'charts': ['recharts'],
// UI libraries that depend on React
'radix-ui': [
'@radix-ui/react-accordion',
'@radix-ui/react-alert-dialog',
'@radix-ui/react-aspect-ratio',
'@radix-ui/react-avatar',
'@radix-ui/react-checkbox',
'@radix-ui/react-collapsible',
'@radix-ui/react-context-menu',
'@radix-ui/react-dialog',
'@radix-ui/react-dropdown-menu',
'@radix-ui/react-hover-card',
'@radix-ui/react-label',
'@radix-ui/react-menubar',
'@radix-ui/react-navigation-menu',
'@radix-ui/react-popover',
'@radix-ui/react-progress',
'@radix-ui/react-radio-group',
'@radix-ui/react-scroll-area',
'@radix-ui/react-select',
'@radix-ui/react-separator',
'@radix-ui/react-slider',
'@radix-ui/react-slot',
'@radix-ui/react-switch',
'@radix-ui/react-tabs',
'@radix-ui/react-toggle',
'@radix-ui/react-toggle-group',
'@radix-ui/react-tooltip'
],
// Form libraries
if (id.includes('react-hook-form') || id.includes('@hookform') || id.includes('zod')) {
return 'forms';
}
'forms': ['react-hook-form', '@hookform/resolvers', 'zod'],
// UI utilities
if (id.includes('tailwind-merge') || id.includes('class-variance-authority') ||
id.includes('clsx') || id.includes('lucide-react') || id.includes('sonner') ||
id.includes('cmdk') || id.includes('next-themes')) {
return 'ui-utils';
}
'ui-utils': [
'tailwind-merge',
'class-variance-authority',
'clsx',
'lucide-react',
'sonner',
'cmdk',
'next-themes'
],
// Other React components
if (id.includes('react-day-picker') || id.includes('react-error-boundary') ||
id.includes('embla-carousel-react') || id.includes('react-resizable-panels')) {
return 'react-components';
}
'react-components': [
'react-day-picker',
'react-error-boundary',
'embla-carousel-react',
'react-resizable-panels'
],
// Non-React utilities
if (id.includes('date-fns') || id.includes('axios') || id.includes('mitt') ||
id.includes('zustand') || id.includes('embla-carousel-autoplay')) {
return 'utils';
}
'utils': [
'date-fns',
'axios',
'mitt',
'zustand',
'embla-carousel-autoplay'
],
// Inertia
if (id.includes('@inertiajs')) {
return 'inertia';
}
'inertia': ['@inertiajs/react']
}
}
},