Not a unique name I know.
Warning
- NOT READY FOR PUBLIC CONSUMPTION
- This is an experiment creating a Hugo theme.
- This is my first time creating a theme.
- This is my first time navigating Hugo modules.
- Work in progress.
- It's pretty barebones.
- TailwindCSS v4.
- Has Dark and Light Mode based on system settings.
- Mobile'ish.
- There has been some attention paid to a11y, but it may still fall short while I work through things.
- Early attempts at i18n.
mkdir my-new-blog
hugo new site my-new-blog
hugo mod init github.com/org/repo
Edit hugo.toml
languageCode = 'en-us'
baseURL = 'https://example.com/'
title = 'My Simpl Themed Site'
[[menus.main]]
[params.Author]
github = 'username'
name = 'name'
[build]
_merge = 'deep'
[markup]
_merge = 'deep'
[module]
[[module.imports]]
path = "github.com/esacteksab/simpl"
This theme requires TailwindCSS, and PostCSS copy the package.json
, tailwind.config.js
and postcss.config.js
from GitHub esacteksab/simpl to my-new-blog
. Before we install packages, there may be things you don't want. Edit package.json
accordingly. When ready, install the packages:
npm i
Then build/serve with hugo
hugo
hugo serve -D
By default, the site displays Home
, Posts
and Tags
. You can override this in your hugo.toml
with [[menus.main]]
.
If you want no items in the menu simply define an empty TOML table:
languageCode = 'en-us'
baseURL = 'https://example.com/'
title = 'My Simpl Themed Site'
[[menus.main]]
If you just want Home
and Posts
, you can do so like below:
baseURL = 'https://example.com/'
languageCode = 'en-us'
title = 'My Simpl Themed Site'
[[menus.main]]
name = 'Home'
pageRef = '/'
weight = 10
[[menus.main]]
name = 'Posts'
pageRef = '/posts'
weight = 20
You can add others and change the weight
to define the order in which they're displayed. Hugo's documentation on Menus is well written and should help you further.
The site uses a list of various social media platforms defined in social.toml
in the theme's data
directory.
In combination with some Hugo parameters. In your hugo.toml
add the following:
[params.Author]
github = 'username'
gitlab = 'username'
linkedin = 'username'
These map to the declarations in social.toml
mentioned above:
[[social_icons]]
id = "github"
url = "https://github.com/%s"
title = "GitHub"
icon = "fab fa-github"
[[social_icons]]
id = "gitlab"
url = "https://gitlab.com/%s"
title = "GitLab"
icon = "fab fa-gitlab"
[[social_icons]]
id = "linkedin"
url = "https://linkedin.com/in/%s"
title = "LinkedIn"
icon = "fab fa-linkedin"
The username
above is mapped to %s
if you're uncertain what the value should be.
The site by default tries to load some files related to (MDN): favicon that don't exist in the static
directory of the theme. I use favicon.io to convert an existing PNG to ico. They provide you with a .zip
that contains the files you need.
ls favicon_io
android-chrome-192x192.png
android-chrome-512x512.png
apple-touch-icon.png
favicon.ico
favicon-16x16.png
favicon-32x32.png
site.webmanifest
You can put these in your static
dir and they will exist where they should when the site is built and published.
Hugo's documentation on Host and deploy is pretty extensive. Cloudflare also publishes a Hugo specific guide.
I develop almost excusively on GitHub, so I use Cloudflare's Git integration.
A few things to note that I learned by trial and error:
- If you're using a custom domain, you will need to deploy after you've configured custom domain. This ensures your stylesheets use the appropriate hostname.
- This theme was built with Hugo Extended Edition, so in Cloudflare, you can pass an environment variable
HUGO_VERSION
with a value of0.145.0+extended
to ensure it uses the extended edition.
Any questions, please don't hesitate to open an Issue. I'm new to Hugo so we'll figure it out together!