Go to file
James Panther c90f8138a6
👷 Add Test Build workflow
2021-08-19 15:26:29 +10:00
.github 👷 Add Test Build workflow 2021-08-19 15:26:29 +10:00
archetypes 🎉 Initial commit 2021-08-11 15:28:33 +10:00
assets 💄 Style updates to enhance design consistency 2021-08-18 12:54:18 +10:00
config/_default 🚑 Fix theme parameter breaking Hugo Modules 2021-08-19 14:34:05 +10:00
data Add i18n support 2021-08-17 16:48:08 +10:00
exampleSite 📝 Add instructions for Hugo Modules installation 2021-08-19 14:40:57 +10:00
i18n ♻️ Move homepage recent articles to partial 2021-08-18 14:35:54 +10:00
images 📝 Complete documentation overhaul 2021-08-16 17:19:10 +10:00
layouts 💄 Fix style issue with button shortcode 2021-08-19 14:09:43 +10:00
static 💄 Fix style issue with button shortcode 2021-08-19 14:09:43 +10:00
.gitignore 🙈 Update .gitignore 2021-08-14 14:45:44 +10:00
.prettierrc 🔧 Update Prettier config 2021-08-17 11:03:47 +10:00
CHANGELOG.md 📝 Add instructions for Hugo Modules installation 2021-08-19 14:40:57 +10:00
CONTRIBUTING.md 📝 Add contributing guidelines 2021-08-19 11:49:20 +10:00
LICENSE 🎉 Initial commit 2021-08-11 15:28:33 +10:00
README.md 📝 Add instructions for Hugo Modules installation 2021-08-19 14:40:57 +10:00
go.mod Add Hugo module support 2021-08-18 16:01:53 +10:00
package-lock.json 🔧 Change package name 2021-08-18 17:10:40 +10:00
package.json 🩹 Standardise project URLs to be lowercase 2021-08-19 09:36:00 +10:00
release.sh 🔨 Add release script 2021-08-18 18:03:31 +10:00
tailwind.config.js 💄 Style updates to enhance design consistency 2021-08-18 12:54:18 +10:00
theme.toml 🩹 Standardise project URLs to be lowercase 2021-08-19 09:36:00 +10:00

README.md

Congo

Congo is designed to be a simple, lightweight theme for Hugo. It's built using Tailwind CSS with a clean and minimalist design that prioritises to your content.

🌏 Demo site
📑 Theme documentation
🐛 Bug reports & issues
💡 Questions & feature requests

Screenshot

Features

  • Built with Tailwind CSS JIT for minified stylesheets without any excess code
  • Fully responsive layout
  • Dark mode (auto-switching based upon browser)
  • Highly customisable configuration
  • Multiple homepage layouts
  • Flexible with any content types, taxonomies and menus
  • Ability to link to posts on third-party websites
  • Diagrams and visualisations using Mermaid JS
  • SVG icons from FontAwesome 5
  • Heading anchors, Buttons, Badges and more
  • HTML and Emoji support in articles
  • SEO friendly with links for sharing to social media
  • RSS feeds
  • Fathom Analytics and Google Analytics support
  • Favicons support
  • Comments support
  • Advanced customisation using simple Tailwind colour definitions and styles
  • Fully documented

Installation

This is a simplified set of instructions and assumes a basic understanding of building Hugo sites and installing themes. For detailed instructions, refer to the full theme documentation.

There are a few ways to install the Congo theme into your Hugo website.

Install using Hugo

This method is the quickest and easiest for keeping the theme up-to-date. Hugo Modules uses Go to initialise and manage modules so you need to ensure you have Go installed before proceeding.

  1. Download and install Go. You can check if it's already installed by using the command go version.

  2. From your Hugo project's directory, initiate the Hugo Modules system for your website:

    hugo mod init github.com/<username>/<repo-name>
    
  3. Add the theme to your configuration by creating a new file config/_default/module.toml and adding the following:

    [[imports]]
    path = "github.com/jpanther/congo"
    
  4. Start your server using hugo server and the theme will be downloaded automatically.

  5. Continue to set up the theme configuration files.

Install using git

Change into the directory for your Hugo website, initialise a new repository and add Congo as a submodule.

cd mywebsite
git init
git submodule add -b stable https://github.com/jpanther/congo.git themes/congo

Then continue to set up the theme configuration files.

Install manually

Download the latest release of the theme from: https://github.com/jpanther/congo/releases/latest

Extract the archive, rename the folder to congo and move it to the themes/ directory inside your Hugo project.

Then continue to set up the theme configuration files.

Set up theme configuration files

In the root folder of your website, delete the config.toml file that was generated by Hugo. Copy the *.toml config files from the theme into your config/_default/ folder. This will ensure you have all the correct theme settings and will enable you to easily customise the theme.

Depending on how you installed the theme you will find the theme config files in different places:

  • Hugo Modules: In the Hugo cache directory, or download a copy from GitHub
  • Git submodule or Manual install: themes/congo/config/_default

Important: If you didn't use Hugo Modules to install Congo, you must add the line theme = "congo" to the top of your config.toml file.

You're now all set up to use Congo. From here you can add some content and start the Hugo server.

Configuration

For all the theme options and detailed configuration instructions, refer to the Congo docs.

A few things you need to set for a new installation:

# config/_default/config.toml

baseURL = "https://your_domain.com"
languageCode = "en-AU"
title = "My awesome website"

[author]
name = "Your name"
links = [
  { twitter = "https://twitter.com/jpanther" }
]

Advanced customisation

There are a couple of ways you can make style changes to Congo.

If you just need to add or override some simple styles, you can do so by creating a custom.css file in your project's static/css/ folder. This file will be loaded automatically after the theme's default styles.

Alternatively, if you'd like to make a major change, you can take advantage of Tailwind CSS's JIT compiler and rebuild the entire theme CSS from scratch.

Note: Building the theme manually is intended for advanced users.

Change into the themes/congo/ folder and install the project dependencies.

npm install

Once installed, you can edit the themes/congo/tailwind.config.js to change the styles that are applied throughout the theme. You can also adjust specific styles in themes/congo/assets/css/main.css.

To allow for easy theme colour changes, Congo defines a primary and secondary colour palette that is used throughout the theme. In order to change the colour across the entire theme, simply edit the tailwind.config.js file accordingly.

For example, to change to a green colour scheme, you could apply these changes:

  // themes/congo/tailwind.config.js

  theme: {
    colors: {
      transparent: "transparent",
      white: colors.white,
      gray: colors.gray,
      primary: colors.lime,
      secondary: colors.teal,
    },
    ...
  }

For a full list of colours available, and their corresponding configuration values, see the official Tailwind docs.

After editing the configuration, you need to rebuild the theme's stylesheets.

npm run build

This will automatically output a minified CSS file to /themes/congo/static/css/main.css.

To aid with testing style changes, you can also run the Tailwind JIT comiler in watch mode.

npm run dev

Now whenever you make a change, the (non-minified) CSS files will be rebuilt automatically. This mode is useful to run when using hugo server to preview your site during development. Remember to perform a full build before publishing your website.


Contributing

Congo is still very much a work in progress. I intend to keep adding features and making changes as required.

Feel free to get in touch with any issues or suggestions for new features you'd like to see.

If you're able to fix a bug or implement a new feature, I welcome PRs for this purpose. Learn more in the contributing guidelines.