webapp/vite.config.ts

68 lines
2.0 KiB
TypeScript
Raw Normal View History

2024-09-19 16:15:51 +00:00
// biome-ignore lint/correctness/noNodejsModules: used during build
2024-09-15 19:39:32 +00:00
import path from 'node:path'
2024-09-24 06:48:39 +00:00
// import { visualizer } from 'rollup-plugin-visualizer'
import dotenv from 'dotenv'
2024-09-12 06:56:53 +00:00
import { CSSOptions } from 'vite'
import mkcert from 'vite-plugin-mkcert'
import { PolyfillOptions, nodePolyfills } from 'vite-plugin-node-polyfills'
import sassDts from 'vite-plugin-sass-dts'
2024-09-24 06:48:39 +00:00
// Load environment variables from .env file
dotenv.config()
export const isDev = process.env.NODE_ENV !== 'production'
console.log(`[vite.config] ${process.env.NODE_ENV} mode`)
2024-09-12 06:56:53 +00:00
const polyfillOptions = {
include: ['path', 'stream', 'util'],
exclude: ['http'],
2024-09-24 06:48:39 +00:00
globals: { Buffer: true },
overrides: { fs: 'memfs' },
2024-09-12 06:56:53 +00:00
protocolImports: true
} as PolyfillOptions
export default {
2024-09-15 19:39:32 +00:00
resolve: {
alias: {
2024-09-16 12:57:00 +00:00
'~': path.resolve('./src'),
'@': path.resolve('./public'),
'/icons': path.resolve('./public/icons'),
'/fonts': path.resolve('./public/fonts'),
2024-09-19 16:15:05 +00:00
bootstrap: path.resolve('./node_modules/bootstrap')
2024-09-15 19:39:32 +00:00
}
},
2024-09-12 06:56:53 +00:00
envPrefix: 'PUBLIC_',
2024-09-15 19:39:32 +00:00
plugins: [isDev && mkcert(), nodePolyfills(polyfillOptions), sassDts()],
2024-09-12 06:56:53 +00:00
css: {
preprocessorOptions: {
scss: {
2024-09-16 13:50:44 +00:00
silenceDeprecations: ['mixed-decls'],
2024-09-16 09:03:43 +00:00
additionalData: '@import "~/styles/imports";\n',
2024-09-16 12:57:00 +00:00
includePaths: ['./public', './src/styles', './node_modules']
2024-09-12 06:56:53 +00:00
}
} as CSSOptions['preprocessorOptions']
},
build: {
target: 'esnext',
sourcemap: true,
2024-09-24 06:48:39 +00:00
minify: 'terser', // explicit terser usage
terserOptions: {
compress: {
drop_console: true // removes console logs in production
}
},
2024-09-12 06:56:53 +00:00
rollupOptions: {
// plugins: [visualizer()]
output: {
manualChunks: {
icons: ['./src/components/_shared/Icon/Icon.tsx'],
session: ['./src/context/session.tsx'],
2024-09-24 06:48:39 +00:00
localize: ['./src/context/localize.tsx'],
2024-09-12 06:56:53 +00:00
editor: ['./src/context/editor.tsx'],
connect: ['./src/context/connect.tsx']
}
}
}
}
}