-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnext.config.mjs
124 lines (110 loc) · 2.8 KB
/
next.config.mjs
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
115
116
117
118
119
120
121
122
123
124
import path from "node:path";
import mdx from "@next/mdx";
import { globby } from "globby";
import nextPWA from "next-pwa";
import runtimeCaching from "next-pwa/cache.js";
import transpileModules from "next-transpile-modules";
import remarkGfm from "remark-gfm";
const withTM = transpileModules(["@mui/joy"]); // Pass the modules you would like to see transpiled
const withPWA = nextPWA({
disable: process.env.NODE_ENV === "development",
dest: "public",
register: true,
skipWaiting: true,
runtimeCaching,
buildExcludes: [/middleware-manifest.json$/],
});
import nextI18Next from "./next-i18next.config.js";
const withMDX = mdx({
extension: /\.mdx?$/,
options: {
// If you use remark-gfm, you'll need to use next.config.mjs
// as the package is ESM only
// https://github.com/remarkjs/remark-gfm#install
remarkPlugins: [remarkGfm],
rehypePlugins: [],
// If you use `MDXProvider`, uncomment the following line.
providerImportSource: "@mdx-js/react",
},
});
const { i18n } = nextI18Next;
const { defaultLocale, locales } = i18n;
const extraLocales = locales.filter(locale => locale !== defaultLocale);
// Define an array of routes that need rewrites and redirects
const mdxFiles = await globby(`src/pages/**/index.mdx`);
const routes = mdxFiles.map(filePath => {
const relativePath = path.relative("src/pages", filePath).replaceAll("\\", "/");
return path.dirname(relativePath);
});
/**
*
* @type {import('next').NextConfig} config
*/
const nextConfig = {
i18n,
reactStrictMode: true,
pageExtensions: ["ts", "tsx", "mdx"],
swcMinify: true,
images: {
remotePatterns: [
{
protocol: "https",
hostname: "images.unsplash.com",
},
{
protocol: "https",
hostname: "cdn.sanity.io",
},
],
formats: ["image/webp"],
},
async rewrites() {
const rewrites = [
{
source: "/sitemap.xml",
destination: "/api/sitemap",
},
];
// Generate rewrites for all extraLocales
for (const route of routes) {
for (const locale of extraLocales) {
rewrites.push({
source: `/${locale}/${route}`,
destination: `/${route}/${locale}`,
locale: false,
});
}
}
return {
beforeFiles: rewrites,
};
},
async redirects() {
const redirects = [];
// Generate redirects for all extraLocales
for (const route of routes) {
for (const locale of extraLocales) {
redirects.push({
source: `/${route}/${locale}`,
destination: `/${locale}/${route}`,
permanent: true,
});
}
}
return redirects;
},
};
/**
*
* @param plugins
* @param {import('next').NextConfig} nextConfig
* @returns {import('next').NextConfigObject}
*/
function withPlugins(plugins, nextConfig) {
let config = nextConfig;
for (const plugin of plugins) {
config = plugin(config);
}
return config;
}
export default withPlugins([withPWA, withTM, withMDX], nextConfig);