forked from expo/expo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
next.config.js
105 lines (101 loc) · 3.79 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
/* eslint-disable import/order */
const { copySync, removeSync } = require('fs-extra');
const merge = require('lodash/merge');
const { join } = require('path');
const semver = require('semver');
const navigation = require('./constants/navigation-data');
const versions = require('./constants/versions');
const { version, betaVersion } = require('./package.json');
// To generate a sitemap, we need context about the supported versions and navigational data
const createSitemap = require('./scripts/create-sitemap');
// copy versions/v(latest version) to versions/latest
// (Next.js only half-handles symlinks)
const vLatest = join('pages', 'versions', `v${version}/`);
const latest = join('pages', 'versions', 'latest/');
removeSync(latest);
copySync(vLatest, latest);
module.exports = {
trailingSlash: true,
// Rather than use `@zeit/next-mdx`, we replicate it
pageExtensions: ['js', 'jsx', 'ts', 'tsx', 'md', 'mdx'],
webpack: (config, options) => {
// Add preval support for `constants/*` only and move it to the `.next/preval` cache.
// It's to prevent over-usage and separate the cache to allow manually invalidation.
// See: https://github.com/kentcdodds/babel-plugin-preval/issues/19
config.module.rules.push({
test: /.jsx?$/,
include: [join(__dirname, 'constants')],
use: merge({}, options.defaultLoaders.babel, {
options: {
// Keep this path in sync with package.json and other scripts that clear the cache
cacheDirectory: '.next/preval',
plugins: ['preval'],
},
}),
});
// Add support for MDX with our custom loader
config.module.rules.push({
test: /.mdx?$/, // load both .md and .mdx files
use: [
options.defaultLoaders.babel,
{
loader: '@mdx-js/loader',
options: {
remarkPlugins: [
require('./mdx-plugins/remark-heading-meta'),
require('./mdx-plugins/remark-link-rewrite'),
],
},
},
join(__dirname, './common/md-loader'),
],
});
// Fix inline or browser MDX usage: https://mdxjs.com/getting-started/webpack#running-mdx-in-the-browser
config.node = { fs: 'empty' };
return config;
},
// Create a map of all pages to export
async exportPathMap(defaultPathMap, { dev, outDir }) {
if (dev) {
return defaultPathMap;
}
const pathMap = Object.assign(
...Object.entries(defaultPathMap).map(([pathname, page]) => {
if (pathname.match(/\/v[1-9][^/]*$/)) {
// ends in "/v<version>"
pathname += '/index.html'; // TODO: find out why we need to do this
}
if (pathname.match(/unversioned/)) {
return {};
} else {
// hide versions greater than the package.json version number
const versionMatch = pathname.match(/\/v(\d\d\.\d\.\d)\//);
if (
versionMatch &&
versionMatch[1] &&
semver.gt(versionMatch[1], betaVersion || version)
) {
return {};
}
return { [pathname]: page };
}
})
);
// Create a sitemap for crawlers like Google and Algolia
createSitemap({
pathMap,
domain: 'https://docs.expo.io',
output: join(outDir, 'sitemap.xml'),
// Some of the search engines only track the first N items from the sitemap,
// this makes sure our starting and general guides are first, and API index last (in order from new to old)
pathsPriority: [
...navigation.startingDirectories,
...navigation.generalDirectories,
...versions.VERSIONS.map(version => `versions/${version}`),
],
// Some of our pages are "hidden" and should not be added to the sitemap
pathsHidden: navigation.previewDirectories,
});
return pathMap;
},
};