Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/anarion80/astro-ghost-simply

A beautiful Astro theme for headless Ghost CMS sites, based on Ghost Simply theme
https://github.com/anarion80/astro-ghost-simply

astro cms ghost headless headless-cms theme

Last synced: about 1 month ago
JSON representation

A beautiful Astro theme for headless Ghost CMS sites, based on Ghost Simply theme

Awesome Lists containing this project

README

        

# Astro Starter Ghost with Simply Theme

[![Netlify Status](https://api.netlify.com/api/v1/badges/eb5fb344-5cf0-4bbe-9a7d-1a5494684357/deploy-status)](https://app.netlify.com/sites/curious-cobbler-55f37b/deploys)

A starter template to build lightning fast websites with [Ghost](https://ghost.org) (as headless CMS in this case) & [Astro](https://astro.build), using the excellent [Simply Ghost Theme](https://github.com/godofredoninja/simply).
Rewritten from Handlebars theme to Astro/React.

**Demo:** [https://astro-ghost-simply.netlify.app/](https://astro-ghost-simply.netlify.app/)

 

![astro-ghost-simply](https://user-images.githubusercontent.com/2185791/133974213-7f41e2e5-427d-4a0b-8024-e0d2ac3c4dd0.png)
 

## 🚀 What is working

- Basic posts
- Related Articles
- Social share buttons support for posts
- Previous and next Post
- Different Home Page variants and Post formats
- Post Format (:warning: use internal tags and not `custom_template` field!)
- [Post Default](https://godofredo.ninja/ghost-theme/simply/post-format/#post-default)
- [Post Full](https://godofredo.ninja/ghost-theme/simply/post-format/#post-full)
- [Post Wide](https://godofredo.ninja/ghost-theme/simply/post-format/#post-wide)
- [Post Header Image](https://godofredo.ninja/ghost-theme/simply/post-format/#post-header-image)
- [Post Image](https://godofredo.ninja/ghost-theme/simply/post-format/#post-image)
- [Post Image Right](https://godofredo.ninja/ghost-theme/simply/post-format/#post-image-right)
- [Post Sidebar](https://godofredo.ninja/ghost-theme/simply/post-format/#post-sidebar)
- [Post not Image](https://godofredo.ninja/ghost-theme/simply/post-format/#post-not-image)
- [Layouts Header](https://godofredo.ninja/ghost-theme/simply/layouts/#header)
- Header Default
- [Header with DropDown Menu](https://godofredo.ninja/ghost-theme/simply/layouts/#headerdefault)
- [Layouts Footer](https://godofredo.ninja/ghost-theme/simply/layouts/#footer)
- Footer Default
- Footer Dark
- Footer Not Menu Secondary
- Responsive Video
- YouTube
- Vimeo
- kickstarter
- Dailymotion
- New Ghost cards (GIF, buttons, NFT, callouts, toggles, quotes, products, audio, video, files, headers)
- Archive (:warning: use internal tags and not `custom_template` field!)
- [Authors Page](https://godofredo.ninja/ghost-theme/simply/authors-and-tags-page/#authors-page)
- [Tags Page](https://godofredo.ninja/ghost-theme/simply/authors-and-tags-page/#tags-page)
- Page
- 404
- [Contact](https://godofredo.ninja/ghost-theme/simply/contact-page/) (:warning: use internal tags and not `custom_template` field!)
- [Podcasts Page](https://godofredo.ninja/ghost-theme/simply/podcasts-page/) (:warning: no need to create the page, just use internal tags on the post)
- [Portfolio Page](https://godofredo.ninja/ghost-theme/simply/portfolio-page/) (:warning: no need to create the page, just use internal tags on the post)
- [Kusi Doc](https://godofredo.ninja/ghost-theme/simply/kusi-doc/) for the documentation of your project (:warning: use internal tags and not `custom_template` field!)
- Hamburger navigation menu
- Header Transparency
- Support for [different Languages](https://godofredo.ninja/ghost-theme/simply/languages)
- [Social accounts link](https://godofredo.ninja/ghost-theme/simply/settings/#socialmedia)
- Lazy Loading for feature-images
- Light Mode / Dark Mode
- Fast search functionality
- Medium style image zoom
- Resize Image Galleries
- [PrismJS syntax highlighting](https://prismjs.com/index.html#supported-languages) - basic only
- [GDPR Cookie Consent](https://github.com/jop-software/astro-cookieconsent)

## ❌ What is not yet working

- Members subscribing via email
- Pagination Infinite Scroll - not for static sites
- Comments
- All Membership features

## ✏ What could be improved

- Move videoResponsive and resizeImageGalleries to build time using some rehype plugin
- Convert this from a starter to a proper theme

## 🏗 Installing

The easiest way to run this project locally is to run the following command in your desired directory.

```bash
# npm 6.x
npm create astro@latest --template anarion80/astro-ghost-simply

# npm 7+, extra double-dash is needed:
npm create astro@latest -- --template anarion80/astro-ghost-simply

# yarn
yarn create astro --template anarion80/astro-ghost-simply
```

 

## 🏃‍♂️ Running

Start the development server. You now have an Astro site pulling content from headless Ghost. You do not need to have original [Simply Ghost Theme](https://github.com/godofredoninja/simply) installed in your Ghost instance, nor have any additional Routes set up there.

```bash
npm run dev
```

By default, the starter will populate content from a default Ghost install located at .

To use your own install, you will need to edit the `.env` config file with your credentials. Change the `GHOST_API_URL` value to the URL of your Ghost site. For Ghost(Pro) customers, this is the Ghost URL ending in `.ghost.io`, and for people using the self-hosted version of Ghost, it's the same URL used to access your site.

Next, update the `GHOST_API_KEY` value to a key associated with the Ghost site. A key can be provided by creating an integration within Ghost Admin. Navigate to Integrations and click "Add new integration". Name the integration appropriately and click create.

```shell
GHOST_API_KEY="secret_api_key"
GHOST_API_URL="https://gatsby.ghost.io"

```

Finally, configure your desired URL in `utils/siteConfig.js`, so links (e. g. canonical links) are generated correctly. You should also update other values in there needed for menu, social sharing and search.

```js
{
menuDropdown: [
{
label: `About`,
url: `/about`,
},
.
.
.
],
followSocialMedia: [
{
service: `youtube`,
title: `YOUR_TITLE`,
url: `YOUR_URL`,
},
.
.
.
],
searchSettings: {
key: `YOUR_GHOST_API_KEY`,
url: `YOUR_GHOST_URL`,
/* This is optional */
options: {
keys: [`title`, `plaintext`],
limit: 10,
},
/* This is optional to perform filtering of the ghost api */
api: {
resource: `posts`,
parameters: {
limit: `all`,
fields: [`title`, `slug`, `plaintext`],
filter: ``,
include: ``,
order: ``,
formats: ``,
},
},
},
}
```

To use custom post templates, add a particular internal tag to the post (i.e. `#custom-post-wide`, `#custom-kusi-doc`, etc).

Demo and the repo is the "maximum version" with all possible types of Home Page variants, Post Templates, Portfolio, Docs, etc. Adjust/remove as needed.

 

## ✈ Deploying with Netlify

Click this button and it will help you create a new repo, create a new Netlify project, and deploy!

[![Deploy to Netlify Button](https://www.netlify.com/img/deploy/button.svg)](https://app.netlify.com/start/deploy?repository=https://github.com/anarion80/astro-ghost-simply)

Content API Keys are generally not considered to be sensitive information, they exist so that they can be changed in the event of abuse; so most people commit it directly to their `.env` config file. If you prefer to keep this information out of your repository you can remove this config and set [Netlify ENV variables](https://www.netlify.com/docs/continuous-deployment/#build-environment-variables) for production builds instead.

Once deployed, you can set up a [Ghost + Netlify Integration](https://docs.ghost.org/integrations/netlify/) to use deploy hooks from Ghost to trigger Netlify rebuilds. That way, any time data changes in Ghost, your site will rebuild on Netlify.

 

## ⚡ Optimising

You can disable the default Ghost Handlebars Theme front-end by enabling the `Make this site private` flag within your Ghost settings. This enables password protection in front of the Ghost install and sets `` so your Astro front-end becomes the source of truth for SEO.

 

## 🛠 Extra options

```bash
# Run a production build, locally
npm run build

# Preview a production build, locally
npm run preview
```

 

## 📝 Copyright & License

Copyright (c) 2023-2024 anarion80 - Released under the [GPLv3 license](LICENSE).