-
Notifications
You must be signed in to change notification settings - Fork 0
/
gridsome.server.js
65 lines (53 loc) · 1.58 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
// Server API makes it possible to hook into various parts of Gridsome
// on server-side and add custom data to the GraphQL data layer.
// Learn more: https://gridsome.org/docs/server-api/
// Changes here require a server restart.
// To restart press CTRL + C in terminal and run `gridsome develop`
const fallguys = require('fallguys-api')
module.exports = function (api) {
api.loadSource(async ({ addCollection }) => {
// Use the Data Store API here: https://gridsome.org/docs/data-store-api/
const today = await fallguys.getDaily();
const collection = addCollection({
typeName: 'Daily'
})
for (const item of today.pcStore) {
collection.addNode(item)
}
});
api.createPages(async ({ createPage, graphql }) => {
// Use the Pages API here: https://gridsome.org/docs/pages-api/
const data = await graphql(`
query{
allDaily{
edges{
node{
uid
name
rarity
icon
price
currency
}
}
}
}
`)
const featuredItemsLength = data.data.allDaily.edges.length;
if (!featuredItemsLength) {
console.error('No featured items found from Fall Guys API')
throw "No featured items found from Fall Guys API";
}
const { crownIcon, kudosIcon } = fallguys;
createPage({
path: '/',
component: './src/templates/ShopPage.vue',
context: {
crownIcon,
kudosIcon,
items: data.data.allDaily.edges,
updatedDate: new Date()
}
})
})
}