-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathnext.config.js
38 lines (37 loc) · 1.1 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
const { variables: { len16 } } = require("./hacss.config.js");
const { loader: extractCssLoader } = require("next/dist/build/webpack/plugins/mini-css-extract-plugin.js").default;
module.exports = require("@next/mdx")({ extension: /\.mdx$/ })({
pageExtensions: ["js", "jsx", "mdx", "tsx"],
webpack: (config, { dev }) => ({
...config,
module: {
...config.module,
rules: [
...config.module.rules,
{
test: /@hacss\/build/,
use: [
dev ? "style-loader" : extractCssLoader,
{ loader: "css-loader", options: { url: false } },
"postcss-loader",
{
loader: "string-replace-loader",
options: {
search: /^./,
replace: x => `@lost gutter ${len16};${x}`,
},
},
{
loader: "val-loader",
options: {
sources: ["components", "pages", "utils"].map(
x => `./${x}/**/*.(ts|tsx)`
),
},
},
],
},
],
},
}),
});