RWKV-Runner/frontend/vite.config.ts

56 lines
1.3 KiB
TypeScript
Raw Normal View History

2023-11-07 11:27:21 +00:00
// @ts-ignore
import { dependencies } from './package.json';
import { defineConfig } from 'vite';
2023-05-06 15:39:23 +00:00
import react from '@vitejs/plugin-react';
2023-11-07 11:27:21 +00:00
import { visualizer } from 'rollup-plugin-visualizer';
// dependencies that exist anywhere
const vendor = [
'react', 'react-dom', 'react-router', 'react-router-dom',
'@fluentui/react-icons',
'mobx', 'mobx-react-lite',
'i18next', 'react-i18next',
'usehooks-ts', 'react-toastify',
'classnames'
];
const embedded = [
// split @fluentui/react-components by components
'@fluentui/react-components',
// dependencies that exist in single component
'react-beautiful-dnd',
'@magenta/music', 'html-midi-player',
'react-markdown', 'rehype-highlight', 'rehype-raw', 'remark-breaks', 'remark-gfm'
];
function renderChunks(deps: Record<string, string>) {
let chunks = {};
Object.keys(deps).forEach((key) => {
if ([...vendor, ...embedded].includes(key)) return;
chunks[key] = [key];
});
return chunks;
}
2023-05-03 15:38:54 +00:00
// https://vitejs.dev/config/
export default defineConfig({
2023-05-06 15:39:23 +00:00
plugins: [react(),
visualizer({
template: 'treemap',
gzipSize: true,
brotliSize: true
2023-11-07 11:27:21 +00:00
})],
build: {
chunkSizeWarningLimit: 3000,
rollupOptions: {
output: {
manualChunks: {
vendor,
...renderChunks(dependencies)
}
}
}
}
2023-05-06 15:39:23 +00:00
});