Skip to content

Starter app for anyone who wants a Gatsby, Contentful CMS powered tech blog that runs on markdown and can be hosted for free! Check out my blog www.faesel.com to see it in use

License

Notifications You must be signed in to change notification settings

faesel/gatsby-techblog-starter

Repository files navigation

Introduction

This is a tech blog template built with Gatsby, Contentful and Disqus. Its free to use for anyone this includes all costs aside from a custom domain (which is optional), and really easy to configure. Check it out here faesel.com.

The aim of this project is to encourage developers to move away from 'paid for' blogging services that limit readership with subscription models, and truly become owners of their words.

⭐ Features

  1. Content management through Contentful & Markdown Editing
  2. Built in mobile responsive with offline support
  3. Build in SEO Optimization built in
  4. Built in code rendering with theming
  5. Built in embedding of sites like Twitter, Youtube etc..
  6. Built in sitemap generation
  7. Built in RSS generation

🔧 Configuration (REQUIRED)

This blog is setup to be easy to configure and get up and running. There are only really two sources of configuration required, in Contentful and in code. I have added some other optional steps if you want to customise further.

Prerequisites

Before you can begin you need the following free accounts setup:

  1. Google account for Google Analytics
  2. Contentful account
  3. Disqus account

Contentful

Contentful is a popular API first content management system. Registration is free and it fulfills all the needs of this blog.

After registering on Contentful your able to define a content model for your blog. This basically represents the structure needed for every blog post.

Below are two ways to create the schema needed for this template:

Using contentful importer

Simply run the following command:

npm run setup SPACE_ID CONTENTFUL_MANAGEMENT_TOKEN 

A json template is located in the root of this project > contentful > export.json that contains the full structure needed.

Note The space id and management token can be found by navigating to Settings > API Keys > Content Management Tokens.

Creating it manually

The structure for this blog is as follows:

Name Type
Hero Media
Title Short Text
Tags Short Text, List
Slug Short Text
Date Published Date & Time
BodyM Long Text (Set to markdown)

Once this is setup you can source your Space Id and Access token under Settings > API Keys > Content delivery / preview tokens

In code

All the code changes needed can be found in the gatsby-config.js file. The main ones to change are as follows:

module.exports = {
    siteMetadata: {
        title: 'FAESEL.COM',
        author: 'Faesel Saeed',
        description: '',
        siteUrl: 'https://www.faesel.com', //Use the fully qualified url
        social: {
            twitter: 'https://twitter.com/@faeselsaeed', //Use the fully qualified url
            linkedin: '',
            github: '',
            flickr: '',
            email: '[email protected]'
        },
    },
}

Along with the config file there are also some environment variables that need setting:

CONTENTFUL_SPACE_ID=CAN BE SOURCED FROM CONTENTFUL SETTINGS
CONTENTFUL_ACCESS_TOKEN=CAN BE SOURCED FROM CONTENTFUL SETTINGS
GOOGLE_TRACKING_ID=CAN BE SOURCED FROM GOOGLE ANAYTICS
GATSBY_DISQUS_NAME=CAN BE SOURCED FROM DISCUS

🏃‍♂️ How to run the project

  1. To run for development - npm run develop
  2. To clean out temp files - npm run clean

Url for accessing the website: http://localhost:8000

Url for accessing graphql: http://localhost:8000/___graphql

💫 Deploy

The deployment script in the packages file is intended to be pushed to use GitHub Pages personal repo. Due to this it pushes to the master branch (with personal repo's you dont have a choice on this).

  1. To deploy changes - npm run deploy

Link:

https://username.github.io/

🎨 Colors (OPTIONAL)

Color palette was chosen from coolors.co.

https://coolors.co/palettes/trending

All colors can be found in colours.scss file

👩‍💻 Customising Rendering code (OPTIONAL)

Code styles can be found here: https://docs.deckdeckgo.com/components/code/

Link to gatsby docs here: https://www.gatsbyjs.org/packages/gatsby-remark-highlight-code/#theme

🖊 Typography & Icons (OPTIONAL)

Typography

https://www.gatsbyjs.org/docs/typography-js/

Icons

https://react-icons.github.io/react-icons/icons?name=fi

📺 Embedding content

You can embed content such as twitter tweets or Youtube videos into your blog posts. Click below for a full list of embedded link formats:

https://github.com/MichaelDeBoey/gatsby-remark-embedder

🚀 Changelog

  • 19/07/2020 - Added ability to embed assets like youtube videos, or tweets.
  • 26/07/2020 - Added a website manifest file, and offline support
  • 27/07/2020 - Modified links in markdown to have target _blank and nofollow
  • 02/08/2020 - Added Github style auto link headers, added icons for post publish date and reading time
  • 14/08/2020 - Added code to remove trailing slashes from urls

About

Starter app for anyone who wants a Gatsby, Contentful CMS powered tech blog that runs on markdown and can be hosted for free! Check out my blog www.faesel.com to see it in use

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published