-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvite.config.js
79 lines (77 loc) · 1.96 KB
/
vite.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
import { defineConfig } from "vite"
import react from "@vitejs/plugin-react"
import { visualizer } from "rollup-plugin-visualizer"
import { VitePWA } from "vite-plugin-pwa"
import compression from "vite-plugin-compression"
export default defineConfig({
plugins: [
react(),
visualizer({
open: false,
gzipSize: true,
brotliSize: true,
}),
VitePWA({
registerType: "autoUpdate",
includeAssets: ["favicon.ico", "robots.txt", "apple-touch-icon.png"],
manifest: {
name: "Chess Master",
short_name: "Chess",
description: "Chess Master - Play chess online",
theme_color: "#242424",
icons: [
{
src: "pwa-192x192.png",
sizes: "192x192",
type: "image/png",
},
{
src: "pwa-512x512.png",
sizes: "512x512",
type: "image/png",
},
],
},
}),
// Add compression for assets
compression({
algorithm: "gzip",
ext: ".gz",
}),
compression({
algorithm: "brotliCompress",
ext: ".br",
}),
],
build: {
// Enable minification
minify: "terser",
terserOptions: {
compress: {
drop_console: true,
drop_debugger: true,
},
},
// Split chunks for better caching
rollupOptions: {
output: {
manualChunks: {
"react-vendor": ["react", "react-dom", "react-router-dom"],
"redux-vendor": ["react-redux", "@reduxjs/toolkit"],
"chess-vendor": ["chess.js"],
"ui-vendor": ["framer-motion", "lucide-react"],
},
},
},
// Generate source maps for production (optional, can be disabled for smaller files)
sourcemap: false,
},
// Optimize dependencies
optimizeDeps: {
include: ["react", "react-dom", "react-router-dom", "react-redux", "chess.js", "framer-motion"],
},
// Enable server compression
server: {
compress: true,
},
})