-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgatsby-node.js
71 lines (60 loc) · 1.37 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
exports.onCreateWebpackConfig = ({ actions: { setWebpackConfig } }) => {
setWebpackConfig({
resolve: {
alias: {
react: require.resolve('react'),
'react-dom': require.resolve('react-dom'),
},
},
})
}
let graphql
// Use this API to capture the graphql executor function
exports.createPages = (args) => {
graphql = args.graphql
}
// Add context from CMS to created pages
exports.onCreatePage = async (args) => {
const {
page,
reporter,
actions: { createPage, deletePage },
} = args
// Only add context to home page
if (
page.path !== '/' &&
(page.context === undefined ||
typeof page.context.originalPath !== 'string' ||
page.context.originalPath !== '/')
) {
return
}
const { data, errors } = await graphql(`
query CMSContent {
vtexCmsPageContent(type: { eq: "home" }) {
blocks {
name
props
}
}
}
`)
if (Array.isArray(errors) && errors.length > 0) {
reporter.panicOnBuild(errors.toString())
return
}
const {
vtexCmsPageContent: { blocks },
} = data
const { searchParams } = blocks.find((x) => x.name === 'DynamicShelf').props
// Add context to home page
const pageWithNewContext = {
...page,
context: {
...page.context,
...searchParams,
},
}
deletePage(page)
createPage(pageWithNewContext)
}