forked from nodejs/nodejs.org
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnext.constants.mjs
141 lines (127 loc) · 5.49 KB
/
next.constants.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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
'use strict';
import { blogData } from './next.json.mjs';
import { defaultLocale } from './next.locales.mjs';
/**
* This is used for telling Next.js if the Website is deployed on Vercel
*
* Can be used for conditionally enabling features that we know are Vercel only
*
* @see https://vercel.com/docs/concepts/projects/environment-variables/system-environment-variables#framework-environment-variables
*/
export const VERCEL_ENV = process.env.NEXT_PUBLIC_VERCEL_ENV || undefined;
/**
* This is used for telling Next.js to to a Static Export Build of the Website
*
* This is used for static/without a Node.js server hosting, such as on our
* legacy Website Build Environment on Node.js's DigitalOcean Droplet.
*
* Note that this is a manual Environment Variable defined by us during `npm run deploy`
*/
export const ENABLE_STATIC_EXPORT =
process.env.NEXT_STATIC_EXPORT === 'true' ||
process.env.NEXT_STATIC_EXPORT === true;
/**
* This is used for any place that requires the full canonical URL path for the Node.js Website (and its deployment), such as for example, the Node.js RSS Feed.
*
* This variable can either come from the Vercel Deployment as `NEXT_PUBLIC_VERCEL_URL` or from the `NEXT_PUBLIC_BASE_URL` Environment Variable that is manually defined
* by us if necessary. Otherwise it will fallback to the default Node.js Website URL.
*
* @see https://vercel.com/docs/concepts/projects/environment-variables/system-environment-variables#framework-environment-variables
*/
export const BASE_URL = process.env.NEXT_PUBLIC_BASE_URL
? process.env.NEXT_PUBLIC_BASE_URL
: process.env.NEXT_PUBLIC_VERCEL_URL
? `https://${process.env.NEXT_PUBLIC_VERCEL_URL}`
: 'https://nodejs.org';
/**
* This is used for any place that requires the Node.js distribution URL (which by default is nodejs.org/dist)
*
* Note that this is a manual Environment Variable defined by us if necessary.
*/
export const DIST_URL =
process.env.NEXT_PUBLIC_DIST_URL || 'https://nodejs.org/dist/';
/**
* This is used for any place that requires the Node.js API Docs URL (which by default is nodejs.org/docs)
*
* Note that this is a manual Environment Variable defined by us if necessary.
*/
export const DOCS_URL =
process.env.NEXT_PUBLIC_DOCS_URL || 'https://nodejs.org/docs/';
/**
* Supports a manual override of the base path of the Website
*
* This is useful when running the deployment on a subdirectory
* of a domain, such as when hosted on GitHub Pages.
*
* Note that this is a manual Environment Variable defined by us if necessary.
*/
export const BASE_PATH = process.env.NEXT_PUBLIC_BASE_PATH || '';
/**
* This ReGeX is used to remove the `index.md(x)` suffix of a name and to remove
* the `.md(x)` extensions of a filename.
*
* This RegEx is used to transform the file system pathnames into acceptable
* Route Segments for Next.js Dynamic Routes on `pages/[...path].tsx`
*/
export const MD_EXTENSION_REGEX = /((\/)?(index))?\.mdx?$/i;
/**
* This is a shorthand to the Default Locale if you're only interested
* on the Locale Code.
*
* This should only be used outside of the Next.js Application itself
* as within React context the `useLocale` hook should be used instead.
*/
export const DEFAULT_LOCALE_CODE = defaultLocale.code;
/**
* This indicates the path to the Legacy JavaScript File that is used
* on the legacy Website.
*
* @deprecated The Legacy Website is due to be removed soon and this file
* and its usages should be removed
*/
export const LEGACY_JAVASCRIPT_FILE = `${BASE_PATH}/static/js/legacyMain.js`;
/**
* This is a list of all static routes or pages from the Website that we do not
* want to allow to be statically built on our Static Export Build.
*
* @type {((route: import('./types').RouteSegment) => boolean)[]} A list of Ignored Routes by Regular Expressions
*/
export const STATIC_ROUTES_IGNORES = [
// This is used to ignore is used to ignore all blog routes except for the English language
route => !route.localised && /^blog\//.test(route.pathname),
// This is used to ignore the blog/pagination meta route
route => /^blog\/pagination/.test(route.pathname),
];
/**
* This is a list of all dynamic routes or pages from the Website that we do not
* want to allow to be dynamically access by our Dynamic Route Engine
*
* @type {RegExp[]} A list of Ignored Routes by Regular Expressions
*/
export const DYNAMIC_ROUTES_IGNORES = [
// This is used to ignore the blog/pagination route
/^blog\/pagination/,
];
/**
* This is a list of all static routes that we want to rewrite their pathnames
* into something else. This is useful when you want to have the current pathname in the route
* but replace the actual Markdown file that is being loaded by the Dynamic Route to something else
*
* @type {[RegexExp, (pathname: string) => string][]}
*/
export const DYNAMIC_ROUTES_REWRITES = [
[/^blog\/year-/, () => 'blog/pagination'],
];
/**
* This is a constant that should be used during runtime by (`getStaticPaths`) on `pages/[...path].tsx`
*
* This function is used to provide an extra set of routes that are not provided by `next.dynamic.mjs`
* static route discovery. This can happen when we have dynamic routes that **must** be provided
* within the static export (static build) of the website. This constant usually would be used along
* with a matching pathname on `DYNAMIC_ROUTES_REWRITES`.
*
* @returns {string[]} A list of all the Dynamic Routes that are generated by the Website
*/
export const DYNAMIC_GENERATED_ROUTES = () => [
...blogData.pagination.map(year => `en/blog/year-${year}`),
];