Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/7sferry/gatsbyan
My Personal Blog at https://ferry.vercel.app/
https://github.com/7sferry/gatsbyan
blog contentful gatsby static-site utterances
Last synced: 3 months ago
JSON representation
My Personal Blog at https://ferry.vercel.app/
- Host: GitHub
- URL: https://github.com/7sferry/gatsbyan
- Owner: 7sferry
- License: mit
- Created: 2020-02-02T16:49:03.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-05-23T08:40:56.000Z (8 months ago)
- Last Synced: 2024-05-23T08:41:13.529Z (8 months ago)
- Topics: blog, contentful, gatsby, static-site, utterances
- Language: TypeScript
- Homepage: https://ferry.now.sh
- Size: 10.3 MB
- Stars: 2
- Watchers: 2
- Forks: 2
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
README
# gatsbyan [![Website](https://img.shields.io/website?down_color=lightgrey&down_message=offline&style=plastic&up_color=green&up_message=online&url=https%3A%2F%2Fferry.vercel.app%2F)](https://ferry.vercel.app/) ![GitHub top language](https://img.shields.io/github/languages/top/7sferry/gatsbyan?style=plastic) ![GitHub](https://img.shields.io/github/license/7sferry/gatsbyan?style=plastic)
This is template for GatsbyJS that I use on production for my personal blog at https://ferry.now.sh
For a clean template, take a look at https://github.com/7sferry/Gatsbyan1.0
![](https://github.com/7sferry/Gatsbyan1.0/blob/master/static/example.png?raw=true)
## Features:
- Contentful CMS
- Comment
- Tags
- SEO
- Archives by date
- Pagination
- Dark Mode
- Blog Search
- Full PWA
- Many more...## Tech used:
- GatsbyJS
- Typescript
- Contentful CMS
- Bootstrap
- Algolia
- Google Analytics
- Prism
- many others, you can check the pakcage.json## Requirements:
- Node JS - I used Node v18.8.1
- Gatsby CLI - I used gatsby-cli v2.10.10
- Typescript - I used Typescript 5.0.4
- Git
- Contentful CMS account
- Google account - optional for analytics and analytics reporter
- Algolia account - optional for blog search## Step to Install:
- run 'npm install'
- create file .env on your root projects directory
- set your spaceId and token from contenful CMS on '.env'
(you can look at [here](https://github.com/7sferry/gatsbyan#step-to-get-spaceid-and-token))
- you could change every properties on config at 'config.ts' or modify SEO variables at '/src.components/SEO.js'
- you also could change utterances config for comment section at '/src.components/Comment.tsx' or remove it if you don't want.
- if you use Algolia, you must specify GATSBY_ALGOLIA_APP_ID, GATSBY_ALGOLIA_INDEX_NAME, GATSBY_ALGOLIA_SEARCH_KEY, ALGOLIA_ADMIN_KEY on '.env'. Or turn it off on gatsby-config and gatsby-node & remove search folder inside 'templates' folder and Algolia.tsx on utils if you don't use it.
- if you use Analytics & Analytics Reporter, you must specify ANALYTICS_PRIVATE_KEY, ANALYTICS_VIEW_ID,
ANALYTICS_GA4, ANALYTICS_TRACKING_ID, ANALYTICS_EMAIL on '.env'. Or turn it off on gatsby-config & remove
AnalyticsPage.tsx and AnalyticsPage on RightSidebar.tsx if you don't use it.
- execute 'npm run develop' on cli
- your site will be run on http://localhost:8000## Step to get SpaceId and Token:
- after login and open the homepage content, click burger menu on the top left
![](https://github.com/7sferry/Gatsbyan1.0/blob/master/static/click%20burger%20menu.jpg?raw=true)
- create new space
![](https://github.com/7sferry/Gatsbyan1.0/blob/master/static/2.%20create%20space.jpg?raw=true)
- choose space type
![](https://github.com/7sferry/Gatsbyan1.0/blob/master/static/3.%20choose%20space%20type.jpg?raw=true)
- write down your space name and choose 'create an example' then choose blog tab and click proceed
![](https://github.com/7sferry/Gatsbyan1.0/blob/master/static/4.%20write%20down%20your%20space%20name%20and%20choose%20create%20an%20example%20and%20choose%20blog.jpg?raw=true)
- after everything has been set, go to content tab and you will see 4 default contents
![](https://github.com/7sferry/Gatsbyan1.0/blob/master/static/5.%20go%20to%20content%20tab%20and%20there%20shoulde%20be%204%20default%20contents.png?raw=true)
- go to media tab and publish all draft images (by default heroImage is required and you can't build your site with
unpublished images)![](https://github.com/7sferry/Gatsbyan1.0/blob/master/static/6.%20go%20to%20media%20tab%20and%20publish%20all%20images.png?raw=true)
- open setting tab and choose 'API keys'. Click 'Add api key' on the top right. Copy space ID and token to your '.env'
file you created before![](https://github.com/7sferry/Gatsbyan1.0/blob/master/static/7.%20open%20setting%20and%20add%20api%20key%20copy-paste%20spaceid%20and%20token%20to%20env.jpg?raw=true)
- execute 'npm run develop' on cli
- now you should be able to access your content at http://localhost:8000## via DockerFile
to run this with docker, execute `docker build -t gatsbyan .`
and `docker run -p 8000:8000 --rm -m 1g --cpus 2 --name gatsbyan gatsbyan`.## via Docker Compose
to run this using docker compose, execute `docker compose -f compose.yaml up -d`
You can deploy your site to any static site hosting like netlify, vercel, or anywhere. There is webhook on netlify
and you can set this up later to your site hosting for content update everytime you publish your content.here is the [google page speed insight](https://developers.google.com/speed/pagespeed/insights/) score for both mobile and desktop
![](https://github.com/7sferry/Gatsbyan1.0/blob/master/static/mobile.png?raw=true)![](https://github.com/7sferry/Gatsbyan1.0/blob/master/static/desktop.png?raw=true)
If you having trouble setting this up, don't hesitate to contact me 😎