-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathgridsome.server.js
More file actions
92 lines (79 loc) · 2.26 KB
/
gridsome.server.js
File metadata and controls
92 lines (79 loc) · 2.26 KB
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
// 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`
module.exports = function (api) {
api.loadSource(async actions => {
// Use the Data Store API here: https://gridsome.org/docs/data-store-api/
const Courses = require('./data/courses.json');
const DisciplineRelations = require('./data/disciplines.json');
const courses = actions.addCollection({
typeName: 'Courses'
})
const disciplines = actions.addCollection({
typeName: 'DisciplinesRelation'
})
for (i of DisciplineRelations.disciplines) {
disciplines.addNode(i)
}
for (i of Courses.course) {
courses.addNode(i)
}
//courses.addNode(Courses)
})
api.createPages(async ({ createPage, graphql }) => {
const { data } = await graphql(`{
allCourses {
edges {
node {
id
name
disciplines {
Code
Semester
}
}
}
}
allDisciplines {
edges {
node {
title
periodo
slug
content
}
}
}
}`)
data.allCourses.edges.forEach(element => {
dsc = []
for (d of element.node.disciplines) {
dsc.push(d.Code)
}
createPage({
path: `/courses/${element.node.id}`,
component: './src/templates/Course.vue',
context: {
title: element.node.name,
codes: dsc
}
})
});
data.allDisciplines.edges.forEach(element => {
const sp = element.node.slug.split('/')
const editLink = "https://github.com/OpenSourceLabUFV/espia-so/edit/main/disciplinas/" + sp[2].toUpperCase() + "/README.md"
createPage({
path: element.node.slug,
component: './src/templates/Discipline.vue',
context: {
title: element.node.title,
content: element.node.content,
editLink: editLink
}
})
});
// Use the Pages API here: https://gridsome.org/docs/pages-api/
})
}