gatsby-wordpress-balsa-theme
A Gatsby theme plugin for creating blogs from headless WordPress CMS.
Turn your WordPress blog into a lightning fast static website. This Gatsby theme is a frontend replacement of the WordPress engine featuring the standard Balsa theme skin and functionality. All content is sourced from a headless WordPress CMS.
This theme is being used at Draftbox. Get lightning fast, secure front-end for your WordPress or Ghost blog, in 5 minutes or less, without coding. For our fellow devs, we also provide code export feature.
Demo
Play with the Demo to get a first impression.
Features
- Balsa theme by Draftbox
- SEO optimized
- Fully responsive
- Gatsby images
- Styled 404 page
- RSS Feed
- AMP Pages
- Sitemap
- Contact Form
- Subscribe Form
- Social Sharing
- Composable and extensible
Installation
Head over to the starter repo to get up and running quickly!
If you want to add this blog theme to an existing site, follow these instructions:
-
Install the blog theme
yarn add @draftbox-co/gatsby-wordpress-balsa-theme
npm install @draftbox-co/gatsby-wordpress-balsa-theme --save
-
Create following files in your root directory with your desired config.
- Create siteConfig.js in root directory and configure it as shown below.
module.exports = {
siteUrl: "https://wp-balsa-preview.draftbox.com",
postsPerPage: 10,
siteTitleMeta: "Built with Draftbox",
siteDescriptionMeta:
"Lightning fast, secure front-end for your WordPress or Ghost blog, without coding",
shareImageWidth: 1000,
shareImageHeight: 523,
shortTitle: "Built with Draftbox",
siteIcon: "favicon.png",
backgroundColor: "#e9e9e9",
themeColor: "#15171A",
apiUrl: "https://wordpress.theasdfghjkl.com",
subscribeWidget: {
title: "Subscribe to Draftbox",
helpText: "Get the latest posts delivered right to your inbox.",
successMessage: "Thanks for subscribing to Draftbox.",
},
header: {
navigation: [
{
label: "Home",
url: "https://wp-balsa-preview.draftbox.com/",
},
{
label: "Contact",
url: "https://wp-balsa-preview.draftbox.com/contact",
},
],
},
footer: {
copyright: "Built with Draftbox",
navigation: [
{
label: "Home",
url: "https://wp-balsa-preview.draftbox.com/",
},
{
label: "Sitemap",
url: "https://wp-balsa-preview.draftbox.com/sitemap.xml",
},
{
label: "RSS",
url: "https://wp-balsa-preview.draftbox.com/rss.xml",
},
{
label: "Contact",
url: "https://wp-balsa-preview.draftbox.com/contact",
},
{
label: "External Link",
url: "https://spectrum.chat/gatsby-js/themes?tab=posts",
},
],
},
socialLinks: {
twitter: "https://twitter.com/draftboxhq",
facebook: "https://facebook.com/",
instagram: "https://www.instagram.com/",
linkedin: "https://linkedin.com/",
github: "https://github.com/draftbox-co",
},
contactWidget: {
title: "Contact Built with Draftbox",
successMessage: "We’ll get in touch with you soon.",
},
};
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.
- Create .wordpress-config.json in root directory and configure it as shown below.
{
"baseUrl": "yourwordpressblog.com",
"protocol": "https",
"hostingWPCOM": false,
"useACF": true,
"includedRoutes": [
"**/categories",
"**/posts",
"**/pages",
"**/media",
"**/tags",
"**/taxonomies",
"**/users"
]
}
In the configuration shown above, the most important fields to be changed are baseUrl
and hostingWPCOM
. Update those with your configuration. example shown above works great for self hosted wordpress.
If your blog is hosted on wordpress.com you will have to add few extra keys for reference check out wordpress-source-docs.
-
Add the following configuration to your gatsby-config.js
file
let siteConfig;
let wordpressConfig;
try {
siteConfig = require(`./siteConfig`);
wordpressConfig = require(`./.wordpress-config`);
console.log(wordpressConfig);
} catch (e) {
console.log(e);
}
module.exports = {
plugins: [
{
resolve: `@draftbox-co/gatsby-wordpress-balsa-theme`,
options: {
wordpressConfig,
siteConfig: siteConfig,
},
},
],
};
Authors
Contributions
PRs are welcome! Consider contributing to this project if you are missing feature that is also useful for others.
Copyright & License
Copyright (c) 2020 Draftbox - Released under the MIT license.