-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgatsby-node.ts
108 lines (104 loc) · 2.34 KB
/
gatsby-node.ts
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
import type { GatsbyNode } from "gatsby"
import path from "path"
type AllMarkdownRemark = {
postsRemark: {
edges: {
node: {
fields: {
slug: string
}
frontmatter: {
title: string
tags: string[]
}
}
}[]
}
tagsGroup: {
group: {
fieldValue: string
}[]
}
}
export const onCreateWebpackConfig: GatsbyNode["onCreateWebpackConfig"] = ({
actions,
}) => {
actions.setWebpackConfig({
resolve: {
alias: {
"@/components": path.resolve(__dirname, "src/components"),
"@/lib/utils": path.resolve(__dirname, "src/lib/utils"),
},
},
})
}
export const createPages: GatsbyNode["createPages"] = async ({
graphql,
actions,
}) => {
const { createPage } = actions
const blogPost = path.resolve("./src/templates/blog-post.tsx")
const tagTemplate = path.resolve("src/templates/tags.tsx")
const result = await graphql(`
{
postsRemark: allMarkdownRemark(
sort: { frontmatter: { date: DESC } }
limit: 2000
) {
edges {
node {
fields {
slug
}
frontmatter {
title
tags
}
}
}
}
tagsGroup: allMarkdownRemark(limit: 2000) {
group(field: { frontmatter: { tags: SELECT } }) {
fieldValue
}
}
}
`)
// handle errors
if (result.errors) {
throw result.errors
}
// Create blog posts pages.
const data = result.data as AllMarkdownRemark
const posts = data.postsRemark.edges
posts.forEach((post, index) => {
const previous = index === posts.length - 1 ? null : posts[index + 1].node
const next = index === 0 ? null : posts[index - 1].node
createPage({
path: post.node.fields.slug,
component: blogPost,
context: {
slug: post.node.fields.slug,
previous,
next,
},
})
})
const kebabCase = (str: string) =>
str
.replace(/([a-z])([A-Z])/g, "$1-$2")
.replace(/[\s_]+/g, "-")
.toLowerCase()
// Extract tag data from query
const tags = data.tagsGroup.group
// Make tag pages
tags.forEach((tag) => {
createPage({
path: `/tags/${kebabCase(tag.fieldValue)}/`,
component: tagTemplate,
context: {
tag: tag.fieldValue,
},
})
})
}