-
Notifications
You must be signed in to change notification settings - Fork 7.6k
/
Copy pathonCreateNode.js
92 lines (74 loc) · 2.58 KB
/
onCreateNode.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
/**
* Copyright (c) 2013-present, Facebook, Inc.
*
* @emails react-core
*/
'use strict';
const path = require('path');
// Parse date information out of blog post filename.
const BLOG_POST_FILENAME_REGEX = /([0-9]+)\-([0-9]+)\-([0-9]+)\-(.+)\.md$/;
function buildRedirectString(permalink, redirect_from) {
if (!permalink || !permalink.endsWith('.html')) {
return redirect_from ? JSON.stringify(redirect_from) : '';
}
let basePath = permalink.slice(0, -'.html'.length);
let redirects = [basePath, basePath + '/'];
if (Array.isArray(redirect_from)) {
redirects = redirects.concat(redirect_from);
}
return JSON.stringify(redirects);
}
// Add custom fields to MarkdownRemark nodes.
module.exports = exports.onCreateNode = ({node, actions, getNode}) => {
const {createNodeField} = actions;
switch (node.internal.type) {
case 'MarkdownRemark':
const {permalink, redirect_from} = node.frontmatter;
const {relativePath, sourceInstanceName} = getNode(node.parent);
let slug = permalink;
if (!slug) {
if (relativePath.includes('blog')) {
// Blog posts don't have embedded permalinks.
// Their slugs follow a pattern: /blog/<year>/<month>/<day>/<slug>.html
// The date portion comes from the file name: <date>-<title>.md
const match = BLOG_POST_FILENAME_REGEX.exec(relativePath);
const year = match[1];
const month = match[2];
const day = match[3];
const filename = match[4];
slug = `/blog/${year}/${month}/${day}/${filename}.html`;
const date = new Date(year, month - 1, day);
// Blog posts are sorted by date and display the date in their header.
createNodeField({
node,
name: 'date',
value: date.toJSON(),
});
}
}
if (!slug) {
// This will likely only happen for the partials in /content/home.
slug = `/${relativePath.replace('.md', '.html')}`;
}
// Used to generate URL to view this content.
createNodeField({
node,
name: 'slug',
value: slug,
});
// Used to generate a GitHub edit link.
// this presumes that the name in gastby-config.js refers to parent folder
createNodeField({
node,
name: 'path',
value: path.join(sourceInstanceName, relativePath),
});
// Used by createPages() above to register redirects.
createNodeField({
node,
name: 'redirect',
value: buildRedirectString(permalink, redirect_from),
});
return;
}
};