From 9d6015a871c1a38fe84ae4bebb3d7a3a36cd7edb Mon Sep 17 00:00:00 2001 From: Dustin Schau Date: Fri, 28 Sep 2018 14:25:10 -0500 Subject: [PATCH] fix: refactor plugin to use source-filesystem and onCreateNode --- gatsby-config.js | 4 +- .../gatsby-node.js | 45 ++++++++++--------- src/pages/index.js | 21 +++++++-- 3 files changed, 43 insertions(+), 27 deletions(-) diff --git a/gatsby-config.js b/gatsby-config.js index 7f4982ae..1b8d122e 100644 --- a/gatsby-config.js +++ b/gatsby-config.js @@ -33,14 +33,14 @@ module.exports = { { resolve: 'gatsby-source-filesystem', options: { - path: `${__dirname}/src/pages`, name: 'pages', + path: `${__dirname}/src/pages` }, }, { resolve: 'gatsby-source-filesystem', options: { - name: 'packages', + name: 'content', path: `${__dirname}/content/`, }, }, diff --git a/plugins/gatsby-transformer-home-example-code/gatsby-node.js b/plugins/gatsby-transformer-home-example-code/gatsby-node.js index e8d81331..172ea06f 100644 --- a/plugins/gatsby-transformer-home-example-code/gatsby-node.js +++ b/plugins/gatsby-transformer-home-example-code/gatsby-node.js @@ -1,28 +1,29 @@ -const {readdirSync, readFileSync} = require('fs'); -const {join, resolve} = require('path'); +const crypto = require(`crypto`) + +// docblock goes here +const createContentDigest = obj => crypto + .createHash(`md5`) + .update(obj) + .digest(`hex`) // Store code snippets in GraphQL for the home page examples. // Snippets will be matched with markdown templates of the same name. -exports.sourceNodes = ({graphql, actions}) => { +exports.onCreateNode = async ({node, loadNodeContent, actions}) => { const {createNode} = actions; + const {absolutePath, ext, name, relativeDirectory, sourceInstanceName} = node - const path = resolve(__dirname, '../../content/home/examples'); - const files = readdirSync(path); - - files.forEach(file => { - if (file.match(/\.js$/)) { - const code = readFileSync(join(path, file), 'utf8'); - const id = file.replace(/\.js$/, ''); - - createNode({ - id, - children: [], - parent: 'EXAMPLES', - internal: { - type: 'ExampleCode', - contentDigest: JSON.stringify(code), - }, - }); - } - }); + if (sourceInstanceName === 'content' && relativeDirectory === 'home/examples' && ext === '.js') { + const code = await loadNodeContent(node); + createNode({ + id: name, + children: [], + parent: 'EXAMPLES', + code, + mdAbsolutePath: absolutePath.replace(/\.js$/, '.md'), + internal: { + type: 'ExampleCode', + contentDigest: createContentDigest(JSON.stringify(code)), + }, + }); + } }; diff --git a/src/pages/index.js b/src/pages/index.js index c0bf8fc1..b4fade2b 100644 --- a/src/pages/index.js +++ b/src/pages/index.js @@ -37,7 +37,12 @@ class Home extends Component { render() { const {babelLoaded} = this.state; const {data, location} = this.props; - const {examples, marketing} = data; + const {codeExamples, examples, marketing} = data; + + const code = codeExamples.edges.reduce((lookup, { node }) => { + lookup[node.mdAbsolutePath] = node.code; + return lookup; + }, {}); return ( @@ -262,7 +267,7 @@ class Home extends Component { marginTop: 80, }, }}> - +

{node.frontmatter.title}

( export const pageQuery = graphql` query IndexMarkdown { + codeExamples: allExampleCode { + edges { + node { + id + code + mdAbsolutePath + } + } + } + examples: allMarkdownRemark( filter: {fileAbsolutePath: {regex: "//home/examples//"}} sort: {fields: [frontmatter___order], order: ASC} ) { edges { node { - code + fileAbsolutePath fields { slug }