-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgatsby-node.js
110 lines (100 loc) · 2.23 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
const _ = require(`lodash`);
const path = require(`path`);
const { paginate } = require('gatsby-awesome-pagination');
exports.createPages = async ({ graphql, actions }) => {
const { createPage } = actions;
const works = await graphql(
`
{
allContentfulWork(
sort: { fields: [updatedAt], order: DESC }
filter: { node_locale: { eq: "ja" } }
) {
edges {
node {
id
concept
date
slug
title
description {
json
}
tags {
title
}
thumbnail {
title
fluid(maxWidth: 1440) {
base64
aspectRatio
src
srcSet
sizes
}
}
}
}
}
}
`
);
const tags = await graphql(
`
{
allContentfulTag {
edges {
node {
title
}
}
}
}
`
);
if (works.errors) {
throw works.errors;
}
if (tags.errors) {
throw tags.errors;
}
const worksEdges = works.data.allContentfulWork.edges;
const tagsEdges = tags.data.allContentfulTag.edges;
const workTemplate = path.resolve(`./src/templates/work.tsx`);
_.each(worksEdges, (edge, i) => {
createPage({
path: `/works/${edge.node.slug}`,
component: workTemplate,
context: {
work: edge.node,
defaultPosition: i,
},
});
});
paginate({
createPage,
items: worksEdges,
itemsPerPage: 12,
pathPrefix: '/works',
component: path.resolve('./src/templates/works.tsx'),
});
_.each(tagsEdges, edge => {
const title = edge.node.title;
const works = worksEdges.filter(edge => {
if (edge.node.tags) {
return edge.node.tags.find(tag => tag.title === title);
}
return false;
});
paginate({
createPage,
items: works,
itemsPerPage: 12,
pathPrefix: `/works/t/${title}`,
component: path.resolve('./src/templates/tags.tsx'),
context: {
tag: title,
},
});
});
};