This repository was archived by the owner on Sep 7, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathgridsome.server.js
67 lines (57 loc) · 1.45 KB
/
gridsome.server.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
module.exports = function (api) {
api.loadSource(({
addCollection
}) => {
// Use the Data Store API here: https://gridsome.org/docs/data-store-api/
})
api.createPages(({
createPage
}) => {
// Use the Pages API here: https://gridsome.org/docs/pages-api/
})
api.onCreateNode(options => {
if (options.internal.typeName === 'Blog') {
options.tags = (typeof options.tags === 'string') ? options.tags.split(',').map(string => string.trim()) : options.tags;
options.author = (typeof options.author === 'string') ? options.author.split(',').map(string => string.trim()) : options.author;
return {
...options
};
}
})
api.createPages(async ({
graphql,
createPage
}) => {
// Use the Pages API here: https://gridsome.org/docs/pages-api
const {
data
} = await graphql(`{
allBlog {
edges {
previous {
id
}
next {
id
}
node {
id
path
}
}
}
}
`);
data.allBlog.edges.forEach(function(element) {
createPage({
path: element.node.path,
component: './src/templates/BlogPost.vue',
context: {
previousElement: (element.previous) ? element.previous.id : '##empty##',
nextElement: (element.next) ? element.next.id : '##empty##',
id: element.node.id
}
});
});
});
}