Skip to content

napitek/apollo

Repository files navigation

apollo

Modern and minimalistic blog theme powered by Zola. See a live preview here.

Named after the greek god of knowledge, wisdom and intellect

Dark theme

blog-dark

Light theme

blog-light

Features

  • Pagination
  • Themes (light, dark, auto)
  • Projects page
  • Analytics using GoatCounter / Umami
  • Social Links
  • MathJax Rendering
  • Taxonomies
  • Meta Tags For Individual Pages
  • Search
  • Categories

Installation

  1. Download the theme
git submodule add https://github.com/not-matthias/apollo themes/apollo
  1. Add the following to the top of your config.toml
theme = "apollo"
taxonomies = [{ name = "tags" }]

[extra]
theme = "auto"
socials = [
  # Configure socials here
]
menu = [
  # Configure menu bar here
]

# See this for more options: https://github.com/not-matthias/apollo/blob/main/config.toml#L14
  1. Copy the example content
cp -r themes/apollo/content/* content/

Options

Comment

You can enable comment (Giscus) for each page:

[extra]
comment = true

And then save your script from Giscus to templates/_giscus_script.html.

Additional stylesheets

You can add stylesheets to override the theme:

[extra]
stylesheets = [
    "override.css",
    "something_else.css"
]

These filenames are relative to the root of the site. In this example, the two CSS files would be in the static folder.

MathJax

To enable MathJax equation rendering, set the variable mathjax to true in the extra section of your config.toml. Set mathjax_dollar_inline_enable to true to render inline math by surrounding them inside $..$.

[extra]
mathjax = true
mathjax_dollar_inline_enable = true

Config

Customize <meta/> tags

The following TOML and YAML code will yiled two <meta/> tags, <meta property="og:title" content="the og title"/>, <meta property="og:description" content="the og description"/>.

TOML:

title = "post title"
description = "post desc"
date = "2023-01-01"

[extra]
meta = [
    {property = "og:title", content = "the og title"},
    {property = "og:description", content = "the og description"},
]

YAML:

title: "post title"
description: "post desc"
date: "2023-01-01"
extra:
    meta:
        - property: "og:title"
          content: "the og title"
        - property: "og:description"
          content: "the og description"

If the og:title, the og:description, or the "description" are not set, the page's title and description will be used. That is, the following TOML code generates <meta property="og:title" content="post title"/>, <meta property="og:description" content="post desc"/>, and <meta property="og:description" content="post desc"/> as default values.

title = "post title"
description = "post desc"
date = "2023-01-01"

References

This theme is based on archie-zola.

About

Modern and minimalistic blog theme.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • HTML 41.5%
  • JavaScript 30.8%
  • SCSS 27.5%
  • Nix 0.2%