-
Notifications
You must be signed in to change notification settings - Fork 0
/
gatsby-node.ts
105 lines (91 loc) · 2.26 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
import * as path from 'path';
import type { CreateNodeArgs, CreatePagesArgs, CreateSchemaCustomizationArgs } from 'gatsby';
import { createFilePath } from 'gatsby-source-filesystem';
export const createPages = async ({ graphql, actions, reporter }: CreatePagesArgs) => {
const blogPost = path.resolve('./src/templates/blog-post.tsx');
const result: {
errors?: Error;
data?: {
allMarkdownRemark: {
nodes: GatsbyTypes.MarkdownRemark[]
}
}
} = await graphql(`
{
allMarkdownRemark(
sort: { fields: [frontmatter___date], order: ASC }
limit: 1000
) {
nodes {
id
fields {
slug
}
}
}
}
`);
if (result.errors) {
reporter.panicOnBuild(
'There was an error loading your blog posts',
result.errors
);
return;
}
const posts = result.data?.allMarkdownRemark.nodes;
if (posts !== undefined && posts.length > 0) {
posts.forEach((post, index) => {
const previousPostId = index === 0 ? null : posts[index - 1].id;
const nextPostId = index === posts.length - 1 ? null : posts[index + 1].id;
actions.createPage({
path: post.fields?.slug || '',
component: blogPost,
context: {
id: post.id,
previousPostId,
nextPostId,
},
});
});
}
};
export const onCreateNode = ({ node, actions, getNode }: CreateNodeArgs) => {
if (node.internal.type === 'MarkdownRemark') {
const value = createFilePath({ node, getNode });
actions.createNodeField({
name: 'slug',
node,
value,
});
}
};
export const createSchemaCustomization = ({ actions }: CreateSchemaCustomizationArgs) => {
actions.createTypes(`
type SiteSiteMetadata {
author: String
description: String
siteUrl: String
social: Social
}
type Social {
github: String
twitter: String
facebook: String
linkedin: String
instagram: String
}
type MarkdownRemark implements Node {
frontmatter: Frontmatter
fields: Fields
}
type Frontmatter {
title: String
description: String
date: Date @dateformat
tags: [String]
}
type Fields {
slug: String
}
`);
};