feat(configuration): enhance Vite config for React and Ant Design integration
- Updated Vite configuration to ensure a single React instance and prevent context issues by adding 'react/jsx-runtime' to deduplication. - Improved manual chunking strategy to keep React core together and optimize Ant Design component loading. - Adjusted build settings for better source map handling and chunk size warnings. - Centralized Ant Design imports in `antd-imports.ts` to ensure React is available for all components. - Removed exclusions for Ant Design to enhance compatibility and performance.
This commit is contained in:
@@ -7,6 +7,9 @@
|
|||||||
* - Separate icon imports to avoid loading entire icon set
|
* - Separate icon imports to avoid loading entire icon set
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
// Ensure React is available for Ant Design components
|
||||||
|
import React from 'react';
|
||||||
|
|
||||||
// Core Components - Import as default exports for better tree-shaking
|
// Core Components - Import as default exports for better tree-shaking
|
||||||
import Button from 'antd/es/button';
|
import Button from 'antd/es/button';
|
||||||
import Input from 'antd/es/input';
|
import Input from 'antd/es/input';
|
||||||
@@ -59,6 +62,7 @@ import theme from 'antd/es/theme';
|
|||||||
|
|
||||||
// Re-export all components
|
// Re-export all components
|
||||||
export {
|
export {
|
||||||
|
React, // Export React to ensure it's available
|
||||||
Button,
|
Button,
|
||||||
Input,
|
Input,
|
||||||
Select,
|
Select,
|
||||||
|
|||||||
@@ -28,8 +28,8 @@ export default defineConfig(({ command, mode }) => {
|
|||||||
{ find: '@layouts', replacement: path.resolve(__dirname, './src/layouts') },
|
{ find: '@layouts', replacement: path.resolve(__dirname, './src/layouts') },
|
||||||
{ find: '@services', replacement: path.resolve(__dirname, './src/services') },
|
{ find: '@services', replacement: path.resolve(__dirname, './src/services') },
|
||||||
],
|
],
|
||||||
// **Ensure single React instance**
|
// **Ensure single React instance to prevent context issues**
|
||||||
dedupe: ['react', 'react-dom'],
|
dedupe: ['react', 'react-dom', 'react/jsx-runtime'],
|
||||||
},
|
},
|
||||||
|
|
||||||
// **CSS Configuration**
|
// **CSS Configuration**
|
||||||
@@ -49,26 +49,20 @@ export default defineConfig(({ command, mode }) => {
|
|||||||
port: 5173,
|
port: 5173,
|
||||||
host: true,
|
host: true,
|
||||||
open: true,
|
open: true,
|
||||||
hmr: {
|
|
||||||
overlay: false,
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
|
|
||||||
// **Build**
|
// **Build Configuration**
|
||||||
build: {
|
build: {
|
||||||
// **Target**
|
// **Output Directory**
|
||||||
target: ['es2020'], // Updated to a more modern target, adjust according to your needs
|
|
||||||
|
|
||||||
// **Output**
|
|
||||||
outDir: 'build',
|
outDir: 'build',
|
||||||
assetsDir: 'assets',
|
|
||||||
cssCodeSplit: true,
|
|
||||||
|
|
||||||
// **Sourcemaps**
|
// **Source Maps**
|
||||||
sourcemap: false,
|
sourcemap: false,
|
||||||
|
|
||||||
// **Minification**
|
// **Minification**
|
||||||
minify: 'terser',
|
minify: 'terser',
|
||||||
|
|
||||||
|
// **Terser Options**
|
||||||
terserOptions: {
|
terserOptions: {
|
||||||
compress: {
|
compress: {
|
||||||
drop_console: isProduction,
|
drop_console: isProduction,
|
||||||
@@ -76,18 +70,25 @@ export default defineConfig(({ command, mode }) => {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
// **Chunk Size Warnings**
|
|
||||||
chunkSizeWarningLimit: 1000,
|
|
||||||
|
|
||||||
// **Rollup Options**
|
// **Rollup Options**
|
||||||
rollupOptions: {
|
rollupOptions: {
|
||||||
|
// **External dependencies to prevent bundling issues**
|
||||||
|
external: (id) => {
|
||||||
|
// Don't externalize anything for now to prevent context issues
|
||||||
|
return false;
|
||||||
|
},
|
||||||
output: {
|
output: {
|
||||||
// **Manual Chunking Strategy**
|
// **Manual Chunking Strategy - Fixed for React context issues**
|
||||||
manualChunks: (id) => {
|
manualChunks: (id) => {
|
||||||
// Vendor libraries
|
// Vendor libraries
|
||||||
if (id.includes('node_modules')) {
|
if (id.includes('node_modules')) {
|
||||||
// Ant Design - Split into smaller chunks
|
// React core - keep together to prevent context issues
|
||||||
if (id.includes('antd/es')) {
|
if (id.includes('react') && !id.includes('react-router') && !id.includes('react-redux') && !id.includes('react-i18next')) {
|
||||||
|
return 'react-core';
|
||||||
|
}
|
||||||
|
|
||||||
|
// Ant Design - Split into smaller chunks but ensure React dependency
|
||||||
|
if (id.includes('antd/es') || id.includes('antd/lib')) {
|
||||||
// Split antd by component types for better caching
|
// Split antd by component types for better caching
|
||||||
if (id.includes('date-picker') || id.includes('time-picker') || id.includes('calendar')) {
|
if (id.includes('date-picker') || id.includes('time-picker') || id.includes('calendar')) {
|
||||||
return 'antd-date';
|
return 'antd-date';
|
||||||
@@ -172,44 +173,11 @@ export default defineConfig(({ command, mode }) => {
|
|||||||
return 'common';
|
return 'common';
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
// **File Naming Strategies**
|
|
||||||
chunkFileNames: (chunkInfo) => {
|
|
||||||
const facadeModuleId = chunkInfo.facadeModuleId ? chunkInfo.facadeModuleId.split('/').pop() : 'chunk';
|
|
||||||
return `assets/js/[name]-[hash].js`;
|
|
||||||
},
|
|
||||||
entryFileNames: 'assets/js/[name]-[hash].js',
|
|
||||||
assetFileNames: (assetInfo) => {
|
|
||||||
if (!assetInfo.name) return 'assets/[name]-[hash].[ext]';
|
|
||||||
const info = assetInfo.name.split('.');
|
|
||||||
let extType = info[info.length - 1];
|
|
||||||
if (/png|jpe?g|svg|gif|tiff|bmp|ico/i.test(extType)) {
|
|
||||||
extType = 'img';
|
|
||||||
} else if (/woff2?|eot|ttf|otf/i.test(extType)) {
|
|
||||||
extType = 'fonts';
|
|
||||||
}
|
|
||||||
return `assets/${extType}/[name]-[hash].[ext]`;
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
|
|
||||||
// **Tree shaking optimization**
|
|
||||||
treeshake: {
|
|
||||||
moduleSideEffects: false,
|
|
||||||
unknownGlobalSideEffects: false,
|
|
||||||
},
|
|
||||||
|
|
||||||
// **External dependencies (if any should be externalized)**
|
|
||||||
external: [],
|
|
||||||
|
|
||||||
// **Preserve modules to avoid context issues**
|
|
||||||
preserveEntrySignatures: 'strict',
|
|
||||||
},
|
},
|
||||||
|
|
||||||
// **Experimental features for better performance**
|
// **Chunk Size Warning Limit**
|
||||||
reportCompressedSize: false, // Disable to speed up build
|
chunkSizeWarningLimit: 1000,
|
||||||
|
|
||||||
// **CSS optimization**
|
|
||||||
cssMinify: isProduction,
|
|
||||||
},
|
},
|
||||||
|
|
||||||
// **Optimization**
|
// **Optimization**
|
||||||
@@ -217,20 +185,23 @@ export default defineConfig(({ command, mode }) => {
|
|||||||
include: [
|
include: [
|
||||||
'react',
|
'react',
|
||||||
'react-dom',
|
'react-dom',
|
||||||
|
'react/jsx-runtime',
|
||||||
'react-router-dom',
|
'react-router-dom',
|
||||||
'@reduxjs/toolkit',
|
'@reduxjs/toolkit',
|
||||||
'react-redux',
|
'react-redux',
|
||||||
'react-i18next',
|
'react-i18next',
|
||||||
'dayjs',
|
'dayjs',
|
||||||
|
// Include antd core to prevent context issues
|
||||||
|
'antd/es/config-provider',
|
||||||
|
'antd/es/button',
|
||||||
|
'antd/es/input',
|
||||||
|
'antd/es/select',
|
||||||
],
|
],
|
||||||
exclude: [
|
// Don't exclude antd to prevent React context issues
|
||||||
// Exclude antd from pre-bundling to allow better tree-shaking
|
exclude: [],
|
||||||
'antd',
|
|
||||||
'@ant-design/icons',
|
|
||||||
],
|
|
||||||
},
|
},
|
||||||
|
|
||||||
// **Define global constants**
|
// **Define Global Constants**
|
||||||
define: {
|
define: {
|
||||||
__DEV__: !isProduction,
|
__DEV__: !isProduction,
|
||||||
},
|
},
|
||||||
|
|||||||
Reference in New Issue
Block a user