-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgatsby-node.js
84 lines (77 loc) · 1.99 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
const path = require('path');
exports.onCreateWebpackConfig = ({ actions }) => {
actions.setWebpackConfig({
resolve: {
alias: {
'@components': path.resolve(__dirname, './src/components'),
'@styles': path.resolve(__dirname, './src/styles'),
},
},
});
};
exports.createPages = async ({ actions, graphql }) => {
const { createPage } = actions;
// language=GraphQL <- Enables code formatting for Gatsby's unique GraphQL function
const {
// Query Contentful content types that render to a page
// The slug field is the bare minimum required for page creation
data: {
allFlipbooks,
allLocales,
},
} = await graphql(`
{
allFlipbooks: allContentfulFlipbook {
edges {
node {
slug
node_locale
}
}
}
allLocales: allContentfulLocale {
edges {
node {
code
}
}
}
}
`);
// Pair content types with page templates
const pageTypes = [
{
entries: allFlipbooks.edges,
slugPrefix: '/',
template: './src/templates/Flipbook/index.js',
},
];
const locales = allLocales.edges.map(({ node }) => node.code);
pageTypes.forEach((pageType) => {
pageType.entries.forEach(({ node }) => {
// Ensure slug exists
if (node.slug !== null) {
// Create pages specific to each locale
locales.forEach((locale) => {
createPage({
component: path.resolve(pageType.template),
context: {
slug: node.slug,
locales: [locale],
},
path: `${pageType.slugPrefix + locale}/${node.slug}`,
});
});
// Create a page that includes all locales
createPage({
component: path.resolve(pageType.template),
context: {
slug: node.slug,
locales,
},
path: pageType.slugPrefix + node.slug,
});
}
});
});
};