gatsby-starter-try-ghost
A Gatsby starter for creating blogs from headless Ghost CMS.
Turn your Ghost blog into a flaring fast static website. This Gatsby theme is a front-end replacement of the Ghost Handlebars engine featuring the standard Ghost Casper skin and functionality. All content is sourced from a headless Ghost CMS.
Demo
Play with the Demo to get a first impression.
Features
- Ghost Casper look and feel
- Infinite Scroll ✨ 🆕
- Gatsby images 🚀 🆕
- Sticky navigation headers
- Hover on author avatar
- Styled 404 page
- SEO optimized
- Fully responsive
- Advanced routing 🆕
- Composable and extensible
Performance
Included Plugins
The following plugins have been included for convenience:
If you don't need them, you can take them out in gatsby-config.js
and package.json
which may save you some time during the build process.
More Plugins
Additional features can be integrated by installing Gatsby themes or plugins. The following plugins have been tested to work with gatsby-starter-try-ghost
:
Getting Started
-
Install this starter by running
gatsby new try-ghost https://github.com/styxlab/gatsby-starter-try-ghost
-
Change directory
cd try-ghost
-
Run
gatsby develop
and visit your site at http://localhost:8000
.
Configure
module.exports = {
siteUrl: `https://your-blog.com`,
postsPerPage: 3,
siteTitleMeta: `Gatsby Starter Ghost CMS`,
siteDescriptionMeta: `Turn your Ghost blog into a flaring fast static site with Gatsby`,
shareImageWidth: 1000,
shareImageHeight: 523,
shortTitle: `Ghost`,
siteIcon: `favicon.png`,
backgroundColor: `#e9e9e9`,
themeColor: `#15171A`,
}
In the configuration shown above, the most important fields to be changed are siteUrl
, siteTitleMeta
and siteDescriptionMeta
. Update at least those to fit your needs.
Ghost Content API keys
All content is sourced from a Ghost CMS. By default, content is fetched from the demo location at https://cms.gotsby.org
. Surely you want to source your own content. In your base directory try-ghost
, add a new file .ghost.json
that contains the following JSON structure:
{
"development": {
"apiUrl": "http://localhost:2368",
"contentApiKey": "9fccdb0e4ea5b572e2e5b92942"
},
"production": {
"apiUrl": "http://localhost:2368",
"contentApiKey": "9fccdb0e4ea5b572e2e5b92942"
}
}
Change the url and keys to match your own Ghost CMS Content API keys.
Deploy
gatsby build
After completion of the build process your static site can be found in the public/
folder. Copy those files over to your webserver.
Deploy on Gatsby Cloud
Fork gatsby-starter-try-ghost
in GitHub. After logging into Gatsby Cloud make sure Gatsby Cloud has access rights to your forked repository. Select I already have a Gatsby Site and then pick gatsby-starter-try-ghost. Skip integrations. For a first test also skip content keys. The build should start immediately and show the demo site. Provide content keys in order to source in your own content from Ghost CMS.
Ensure headless mode of Ghost CMS
For best SEO results it is strongly recommended to disable the default Ghost Handlebars theme front-end by selecting the Make this site private flag within your Ghost admin settings. This enables password protection in front of the Ghost install and sets <meta name="robots" content="noindex" />
so your Gatsby front-end becomes the authoritative source for search engines.
Reporting issues
Please report all bugs and issues at gatsby-theme-try-ghost/issues as all development is happening there.
Copyright & License
Copyright (c) 2020 styxlab - Released under the MIT license.