-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnext.config.js
114 lines (103 loc) · 2.76 KB
/
next.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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
/**
* @type {import('next').NextConfig}
*/
const withNextIntl = require("next-intl/plugin")(
// This is the default (also the `src` folder is supported out of the box)
"./src/i18n.ts"
);
const {
withHydrationOverlayWebpack,
} = require("@builder.io/react-hydration-overlay/webpack");
module.exports = withNextIntl({
reactStrictMode: true,
productionBrowserSourceMaps: true,
webpack: (config, { isServer }) => {
// Custom Terser settings
if (!isServer) {
config.optimization.minimizer.push(
new TerserPlugin({
terserOptions: {
compress: {
drop_console: true, // Optionally remove console logs in production
},
},
})
);
}
},
// Add headers for caching static assets
async headers() {
return [
{
source: "/_next/(.*)",
headers: [
{
key: "Cache-Control",
value: "public, max-age=31536000, immutable",
},
],
},
{
source: "/images/(.*)",
headers: [
{
key: "Cache-Control",
value: "public, max-age=604800, must-revalidate",
},
],
},
];
},
async rewrites() {
return [
{
source: "/robots.ts",
destination: "/src/app/robots.ts",
},
];
},
webpack: (config, { isServer }) => {
// Apply withHydrationOverlayWebpack configuration
config = withHydrationOverlayWebpack({
appRootSelector: "#__next",
isMainAppEntryPoint: (entryPointName) =>
!isServer &&
(entryPointName === "pages/_app" || entryPointName === "main-app"),
})(config);
// Add a rule to handle video files
config.module.rules.push({
test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/,
use: {
loader: "file-loader",
options: {
publicPath: "/_next/static/media/", // Adjust the path as needed
outputPath: `${isServer ? "../" : ""}static/media/`, // Adjust the path as needed
name: "[name].[ext]",
},
},
});
// Add a rule to handle SVG files
config.module.rules.push({
test: /\.svg$/,
use: ["@svgr/webpack"],
});
// Adjust resolve fallbacks
config.resolve.fallback = { fs: false, path: false };
return config;
},
eslint: {
dirs: ["src"], // Only run ESLint on the 'src' directory during production builds (next build)
},
// Custom PostCSS Configuration
// postcssLoaderOptions: {
// plugins: {
// "postcss-preset-env": {
// autoprefixer: { grid: true }, // Enables autoprefixer
// },
// },
// },
// babel: {
// presets: ["next/babel"],
// plugins: [["@babel/plugin-transform-react-jsx", { runtime: "automatic" }]],
// },
});