-
Notifications
You must be signed in to change notification settings - Fork 0
/
gatsby-node.ts
87 lines (74 loc) · 1.84 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
import { GatsbyNode } from "gatsby";
import path from "path";
export const createSchemaCustomization: GatsbyNode["createSchemaCustomization"] =
({ actions }) => {
actions.createTypes(`
type Query {
site: Site!
}
type Mdx implements Node {
frontmatter: MdxFrontmatter!
}
type MdxFrontmatter {
date: Date! @dateformat
title: String!
slug: String!
tags: [String!]!
hero_image_alt: String!
hero_image_link: String!
}
type Site implements Node {
siteMetadata: SiteSiteMetadata!
}
type SiteSiteMetadata {
title: String!
}
`);
};
export const onCreateWebpackConfig: GatsbyNode["onCreateWebpackConfig"] = ({
stage,
actions,
}) => {
actions.setWebpackConfig({
resolve: {
alias: {
"~components": `${__dirname}/src/components`,
"~pages": `${__dirname}/src/pages`,
},
extensions: [".ts", ".tsx", ".js", ".jsx"],
},
});
};
export const createPages: GatsbyNode["createPages"] = async ({
actions,
graphql,
reporter,
}) => {
const { createPage } = actions;
const tagTemplate = path.resolve("src/templates/tags.tsx");
const result: { errors?: unknown; data?: Queries.TagListQuery } =
await graphql(`
query TagList {
allMdx {
group(field: { frontmatter: { tags: SELECT } }) {
name: fieldValue
totalCount
}
}
}
`);
if (result.errors || !result.data) {
reporter.panicOnBuild('🚨 ERROR: Loading "createPages" query');
return;
}
const tags = result.data.allMdx.group;
tags.forEach((tag: Queries.TagListQuery["allMdx"]["group"][0]) => {
createPage({
path: `/tags/${tag.name}/`,
component: tagTemplate,
context: {
tag: tag.name,
},
});
});
};