1
0
mirror of https://github.com/oceanprotocol/docs.git synced 2024-11-26 19:49:26 +01:00
docs/gatsby-node.js

131 lines
4.4 KiB
JavaScript
Raw Normal View History

const path = require('path')
const { createFilePath } = require('gatsby-source-filesystem')
2018-11-07 12:24:53 +01:00
exports.onCreateNode = ({ node, getNode, actions }) => {
const { createNodeField } = actions
2018-11-08 16:03:16 +01:00
if (node.internal.type === 'MarkdownRemark') {
const fileNode = getNode(node.parent)
const parsedFilePath = path.parse(fileNode.relativePath)
2018-11-14 15:17:19 +01:00
let slug = createFilePath({ node, getNode, basePath: 'content' })
let section = parsedFilePath.dir
if (node.frontmatter.slug) {
;({ slug } = node.frontmatter)
}
if (node.frontmatter.section) {
;({ section } = node.frontmatter)
}
createNodeField({
node,
name: 'slug',
value: slug
})
createNodeField({
node,
name: 'section',
value: section
})
}
}
exports.createPages = ({ graphql, actions }) => {
const { createPage } = actions
return new Promise((resolve, reject) => {
resolve(
graphql(
`
{
2018-11-09 22:10:35 +01:00
allMarkdownRemark(
filter: { fileAbsolutePath: { regex: "/content/" } }
) {
edges {
node {
fields {
slug
section
}
}
}
}
2018-11-14 15:17:19 +01:00
architectureDocs: allMarkdownRemark(
filter: {
fileAbsolutePath: {
regex: "/dev-ocean/doc/architecture/"
}
2018-11-14 15:17:19 +01:00
}
) {
edges {
node {
fields {
slug
section
}
frontmatter {
slug
title
description
section
}
}
}
}
}
`
).then(result => {
if (result.errors) {
/* eslint-disable-next-line no-console */
console.log(result.errors)
reject(result.errors)
}
const docTemplate = path.resolve('./src/templates/Doc.jsx')
const posts = result.data.allMarkdownRemark.edges
// Create Doc pages
posts.forEach(post => {
createPage({
path: `${post.node.fields.slug}`,
component: docTemplate,
context: {
slug: post.node.fields.slug,
section: post.node.fields.section
}
})
})
// Create Architecture section from dev-ocean contents
2018-11-14 15:17:19 +01:00
const postsArchitecture = result.data.architectureDocs.edges
postsArchitecture
// only grab files with required frontmatter defined
.filter(
post =>
post.node.frontmatter.slug &&
post.node.frontmatter.title &&
post.node.frontmatter.description &&
post.node.frontmatter.section
)
.forEach(post => {
createPage({
path: `${post.node.fields.slug}`,
component: docTemplate,
context: {
slug: post.node.fields.slug,
section: post.node.fields.section
}
})
2018-11-14 15:17:19 +01:00
})
resolve()
})
)
})
}