webapp/vite.config.ts

61 lines
1.7 KiB
TypeScript
Raw Normal View History

2024-09-15 19:39:32 +00:00
// biome-ignore lint/correctness/noNodejsModules: <explanation>
import path from 'node:path'
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-15 19:39:32 +00:00
// import { visualizer } from 'rollup-plugin-visualizer'
2024-09-12 06:56:53 +00:00
2024-09-15 19:39:32 +00:00
const isDev = process.env.NODE_ENV !== 'production'
console.log(`[vite.config] development mode: ${isDev}`)
2024-09-12 06:56:53 +00:00
const polyfillOptions = {
include: ['path', 'stream', 'util'],
exclude: ['http'],
globals: {
Buffer: true
},
overrides: {
fs: 'memfs'
},
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'),
'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,
rollupOptions: {
// plugins: [visualizer()]
output: {
manualChunks: {
icons: ['./src/components/_shared/Icon/Icon.tsx'],
session: ['./src/context/session.tsx'],
editor: ['./src/context/editor.tsx'],
connect: ['./src/context/connect.tsx']
}
}
}
}
}