3. site configuration

GatsbyJs site can be configured using the file gatsby-config.js

Create the file in the project's root folder.

touch gatsby-config.js

options

Gatsby provides various options to configure the site, but for this post, we'll use the following options.

  • Plugins
  • siteMetadata

plugins

Plugins are Node.js packages that implement Gatsby APIs.

The config file gatsby-config.js accepts an array of plugins. Some plugins may need only to be listed by name, while others may take options (see the docs for individual plugins).

We'll use the following plugins:

Install them using below commands:

npm install gatsby-source-filesystem gatsby-transformer-remark

siteMetadata

Data that you want to share across the site(e.g.: site title) can be stored in siteMetadata.

Example:

siteMetadata: {
    title: 'theRDnotes',
    siteUrl: 'https://www.theRDnotes.com',
    description: 'my personal tech notebook... wip...'
  }

configuration

Keeping the above-written notes in mind.
Let's configure our site.

And the file gatsby-config.js should have the following content

const siteMetadata = {
    title: `theRDnotes`,
    description: `my personal tech notebook... wip...`,
};

module.exports = {
    siteMetadata: siteMetadata,
    plugins: [
        `gatsby-transformer-remark`,
        {
            resolve: `gatsby-source-filesystem`,
            options: {
                path: `${__dirname}/notes`,
                name: `notes`,
            },
        }
    ],
};

slug

theory

A Slug is a part of the URL that uniquely identifies a page on your website.

Example:
In www.example.com/hello-world URL, hello-world is the slug

Tip: Slugs should be easy to read for humans and search engines.

I'll show you two ways we can use slug.

  1. Hard code the slug in the frontmatter of markdown files.
  2. Dynamically generating the slug from filesystem based paths

Initially I thought of using the second approach.
Then realized that if in future I need to re-organize my markdown files. That will re-generate the slug in build process.
Which will result in broken links incoming into your blog. πŸ™…β€β™‚οΈ

Therefore, In our blog, we'll use the first approach i.e. mentioning the slug in the frontmatter itself.

Notice we've already placed slug in our two sample markdown files created in the last post.
So nothing is needed to be done for now.

liked second approach? πŸ˜•

Don't you worry my friend! Below section explains to implement that πŸ₯³

So our post content is in the form of markdown files and we need a logic to create slugs dynamically from markdown files.

Action items:

  • Create slugs from markdown files
  • Store them somewhere to be read later.

Thankfully gatsby-source-filesystem plugin has a function to do the same, using which we'll create slugs and store them under MarkdownRemark node. Then using GraphQL, we'll read them back.

practical

First, we need to create gatsby-node.js file project's root.

touch gatsby-node.js

Add the following to gatsby-node.js file.

const { createFilePath } = require(`gatsby-source-filesystem`)

exports.onCreateNode = ({ node, getNode, actions }) => {
  const { createNodeField } = actions
  if (node.internal.type === `MarkdownRemark`) {
    const slug = createFilePath({ node, getNode, basePath: `notes` })
    createNodeField({
      node,
      name: `slug`,
      value: slug,
    })
  }
}

onCreateNode is a Gatsby Node API. Called when a node is created. Developers can implement this to extend transform the node.

createFilePath is a helper function to create a URL from a file’s path on the file system.

createNodeField is a function to extend a node. The new node field is placed under the fields key on the extended node object.

config'd

In the next part, we'll test our configuration using a tool called GraphiQL.

Also, we'll write GraphQL queries required for our blog.

Helpful?

If you think this is helpful 🎈
Don't keep it to yourself πŸ™Š

Share it with your lovely followers at twitter πŸ—½

Feedback!

powered by Β EventsCounter.com
lets connect viatwitter