-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgatsby-node.js
113 lines (98 loc) · 2.59 KB
/
gatsby-node.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
106
107
108
109
110
111
112
113
const path = require('path');
const fs = require('fs/promises');
const demoTemplate = path.resolve('./src/templates/demo.jsx');
const categoryTemplate = path.resolve('./src/templates/category.jsx');
exports.onCreateWebpackConfig = ({ actions, loaders }) => {
actions.setWebpackConfig({
module: {
rules: [
{},
{
resourceQuery: /raw/,
type: 'asset/source',
},
],
},
});
};
function defaultCode() {
return [
{
name: 'index.js',
language: 'javascript',
},
{
name: 'index.html',
language: 'html'
}
];
}
exports.createPages = async ({ graphql, actions, reporter }) => {
const { createPage } = actions;
const result = await graphql(`
query {
allMdx {
nodes {
excerpt
body
frontmatter {
key
alias
slug
title
type
code {
name
language
}
}
internal {
contentFilePath
}
}
}
}
`);
async function loadSourceFiles(demo) {
const codeFiles = demo.frontmatter.code || defaultCode();
const promises = [];
codeFiles.forEach(codeFile => {
const filePath = path.resolve('static/code', demo.frontmatter.slug.slice(1), codeFile.name);
promises.push(fs.readFile(filePath, 'utf-8').then(content => codeFile.code = content));
});
await Promise.all(promises);
return codeFiles;
}
async function createDemo(demo, path) {
const codeFiles = await loadSourceFiles(demo);
createPage({
path,
context: {
excerpt: demo.excerpt,
codeFiles
},
component: `${demoTemplate}?__contentFilePath=${demo.internal.contentFilePath}`
});
}
const demos = result.data.allMdx.nodes.filter(node => node.frontmatter.type === 'demo' || node.frontmatter.type === 'listing');
const promises = [];
demos.forEach(demo => {
promises.push(createDemo(demo, demo.frontmatter.slug));
if (demo.frontmatter.alias) {
promises.push(createDemo(demo, demo.frontmatter.alias));
}
});
await Promise.all(promises);
const categories = result.data.allMdx.nodes.filter(node => node.frontmatter.type === 'category');
categories.forEach(category => {
createPage({
context: {
excerpt: category.excerpt,
body: category.body,
key: category.frontmatter.key
},
path: category.frontmatter.slug,
component: `${categoryTemplate}?__contentFilePath=${category.internal.contentFilePath}`
});
});
};