-
Notifications
You must be signed in to change notification settings - Fork 97
/
gatsby-node.js
134 lines (122 loc) · 3.81 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
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
const _ = require('lodash')
const path = require('path')
const createPaginatedPages = require('gatsby-paginate')
exports.onCreateNode = ({ node, actions, getNode }) => {
const { createNodeField } = actions
let slug
if (node.internal.type === `MarkdownRemark`) {
const fileNode = getNode(node.parent)
const parsedFilePath = path.parse(fileNode.relativePath)
if (Object.prototype.hasOwnProperty.call(node, 'frontmatter')) {
if (Object.prototype.hasOwnProperty.call(node.frontmatter, 'slug') && Object.prototype.hasOwnProperty.call(node.frontmatter, 'cover')) {
slug = `/blog/${_.kebabCase(node.frontmatter.slug)}`
} else if (Object.prototype.hasOwnProperty.call(node.frontmatter, 'slug')) {
slug = `/${_.kebabCase(node.frontmatter.slug)}`
} else if (parsedFilePath.name !== 'index' && parsedFilePath.dir !== '') {
slug = `/${parsedFilePath.dir}/${parsedFilePath.name}/`
} else if (parsedFilePath.dir === '') {
slug = `/`
} else {
slug = `/${parsedFilePath.dir}/`
}
}
createNodeField({
name: `slug`,
node,
value: slug,
})
}
}
exports.createPages = ({ actions, graphql }) => {
const { createPage } = actions
return graphql(`
{
allMarkdownRemark(limit: 1000, sort: { order: DESC, fields: [frontmatter___date] }) {
edges {
node {
excerpt(pruneLength: 400)
id
fields {
slug
}
frontmatter {
title
cover {
childImageSharp{
fluid (maxWidth:500, quality:50){
src
srcSet
aspectRatio
sizes
base64
}
}
publicURL
}
tags
templateKey
date(formatString: "MMMM DD, YYYY")
}
}
}
}
}
`).then(result => {
if (result.errors) {
result.errors.forEach(e => console.error(e.toString()))
return Promise.reject(result.errors)
}
const postsAndPages = result.data.allMarkdownRemark.edges
// Post pages:
let posts = []
// Iterate through each post/page, putting all found posts (where templateKey = article-page) into `posts`
postsAndPages.forEach(edge => {
if (_.isMatch(edge.node.frontmatter, { templateKey: 'article-page' })) {
posts = posts.concat(edge)
}
})
createPaginatedPages({
edges: posts,
createPage: createPage,
pageTemplate: 'src/templates/blog.js',
pageLength: 6, // This is optional and defaults to 10 if not used
pathPrefix: 'blog', // This is optional and defaults to an empty string if not used
context: {}, // This is optional and defaults to an empty object if not used
})
postsAndPages.forEach(edge => {
const id = edge.node.id
createPage({
path: edge.node.fields.slug,
tags: edge.node.frontmatter.tags,
component: path.resolve(
`src/templates/${String(edge.node.frontmatter.templateKey)}.js`,
),
// additional data can be passed via context
context: {
id,
},
})
})
// Tag pages:
let tags = []
// Iterate through each post, putting all found tags into `tags`
postsAndPages.forEach(edge => {
if (_.get(edge, `node.frontmatter.tags`)) {
tags = tags.concat(edge.node.frontmatter.tags)
}
})
// Eliminate duplicate tags
tags = _.uniq(tags)
// Make tag pages
tags.forEach(tag => {
const tagPath = `/tags/${_.kebabCase(tag)}/`
createPage({
path: tagPath,
component: path.resolve(`src/templates/tags.js`),
context: {
tag,
},
})
})
})
}