Files
www_threefold_io/gridsome.server.js
2021-03-31 15:41:26 +02:00

206 lines
4.8 KiB
JavaScript

// 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`
var private = process.env.SHOWPRIVATE
if (private == "true")
private = null
else if (private == "false")
private = 1
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.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
}
});
});
});
api.createPages(async({
graphql,
createPage
}) => {
// Use the Pages API here: https://gridsome.org/docs/pages-api
const {
data
} = await graphql(`{
allNews {
edges {
previous {
id
}
next {
id
}
node {
id
path
}
}
}
}
`);
data.allNews.edges.forEach(function(element) {
createPage({
path: element.node.path,
component: './src/templates/NewsPost.vue',
context: {
previousElement: (element.previous) ? element.previous.id : '##empty##',
nextElement: (element.next) ? element.next.id : '##empty##',
id: element.node.id
}
});
});
});
api.createPages(async({ graphql, createPage }) => {
const { data } = await graphql(`{
allProjectTag(filter: { title: {in: ["foundation"]}}) {
edges {
node {
id
path
}
}
}
}`)
data.allProjectTag.edges.forEach(({ node }) => {
createPage({
path: `${node.path}`,
component: './src/templates/Tag.vue',
context: {
id: node.id,
private: private
}
})
})
})
api.createPages(async({ graphql, createPage }) => {
const { data } = await graphql(`{
allBlogTag {
edges {
node {
id
path
}
}
}
}`)
data.allBlogTag.edges.forEach(({ node }) => {
createPage({
path: `${node.path}`,
component: './src/templates/Tag.vue',
context: {
id: node.id,
private: private
}
})
})
})
api.createPages(async({ graphql, createPage }) => {
const { data } = await graphql(`{
allNewsTag {
edges {
node {
id
path
}
}
}
}`)
data.allNewsTag.edges.forEach(({ node }) => {
createPage({
path: `${node.path}`,
component: './src/templates/Tag.vue',
context: {
id: node.id,
private: private
}
})
})
})
api.createPages(({ createPage }) => {
createPage({
path: '/partners',
component: './src/templates/Partners.vue',
context: {
private: private
}
})
})
api.createPages(({ createPage }) => {
createPage({
path: '/team',
component: './src/templates/Team.vue',
context: {
private: private
}
})
});
api.createPages(({ createPage }) => {
createPage({
path: '/search',
component: './src/templates/Search.vue',
context: {
private: private
}
})
});
}