mirror of https://github.com/buster-so/buster.git
61 lines
1.6 KiB
TypeScript
61 lines
1.6 KiB
TypeScript
import tailwindcss from '@tailwindcss/vite';
|
|
import { tanstackStart } from '@tanstack/react-start/plugin/vite';
|
|
import viteReact from '@vitejs/plugin-react';
|
|
import { defineConfig } from 'vite';
|
|
import checker from 'vite-plugin-checker';
|
|
import viteTsConfigPaths from 'vite-tsconfig-paths';
|
|
|
|
const config = defineConfig({
|
|
server: { port: 3000 },
|
|
plugins: [
|
|
// this is the plugin that enables path aliases
|
|
viteTsConfigPaths({ projects: ['./tsconfig.json'] }),
|
|
tailwindcss(),
|
|
tanstackStart({ customViteReactPlugin: true }),
|
|
viteReact(),
|
|
!process.env.VITEST
|
|
? checker({
|
|
typescript: true,
|
|
biome: true,
|
|
})
|
|
: undefined,
|
|
],
|
|
build: {
|
|
rollupOptions: {
|
|
output: {
|
|
// Force lodash and lodash-es into a dedicated vendor chunk
|
|
manualChunks(id) {
|
|
if (id.includes('node_modules/lodash')) {
|
|
return 'vendor-lodash';
|
|
}
|
|
if (id.includes('node_modules/lodash-es')) {
|
|
return 'vendor-lodash';
|
|
}
|
|
// Move supabase modules to their own chunk
|
|
if (id.includes('node_modules/@supabase')) {
|
|
return 'vendor-supabase';
|
|
}
|
|
|
|
if (id.includes('components/ui/icons')) {
|
|
return 'vendor-icons';
|
|
}
|
|
|
|
if (id.includes('components/ui')) {
|
|
return 'vendor-ui';
|
|
}
|
|
|
|
if (id.includes('zod')) {
|
|
return 'vendor-zod';
|
|
}
|
|
|
|
if (id.includes('@tanstack')) {
|
|
return 'vendor-tanstack';
|
|
}
|
|
},
|
|
},
|
|
},
|
|
},
|
|
});
|
|
|
|
export default config;
|