# Hugo themes A collection of all themes that were created by the Hugo community. See a complete listing of all of these themes along with screenshots and demos at [themes.gohugo.io](http://themes.gohugo.io/). Every theme in this list will automatically be added to the theme site. Theme updates aren't scheduled but usually happen at least once a week. ## Build script For the curious, [here's how](buildThemeSite.sh) this automatic adding is accomplished. # Installation ## Installing all themes If you would like to install all of the available Hugo themes, simply clone the entire repository from within your working directory with this command: git clone --depth 1 --recursive https://github.com/spf13/hugoThemes.git themes ## Installing a single theme
cd themes
git clone URL_TO_THEME
# Adding a theme to the list
* Create your theme using hugo new theme THEMENAME
;
* Test your theme against https://github.com/spf13/HugoBasicExample;
* Add a `theme.toml` file to the root of the theme and add some metadata about the theme;
* Add a descriptive `README.md` to the root of the theme;
* Add `/images/screenshot.png` and `/images/tn.png` (see below);
* Open up a new Issue with a link to the theme's repository on GitHub.
If your theme doesn't fit into the `Hugo Basic Example` site, we encourage theme authors to supply a self-contained Hugo site in `/exampleSite`.
**NOTE:** The folder name here is important, as this folder will be picked up and used by the script that generates the Hugo Theme Site. It mirrors the root directory of a Hugo website and allows you to add custom content, assets and a config file with preset values.
The build script for the theme site also expects a `static` folder in the `exampleSite` directory. You don't have to populate the folder with assets (unless you want to use specific ones for the demo). To make the folder trackable add an empty file like `.gitkeep`.
See [Artist theme's exampleSite](https://github.com/digitalcraftsman/hugo-artists-theme/tree/master/exampleSite) for a good example. And please make the site's content as neutral as possible.
Each theme needs:
1. To be added to the hugoThemes repo;
1. To have the right fields in `theme.toml`;
1. To have the right images; and
1. A good README.
## theme.toml
This file contains metadata about the theme and its creator. The following fields are required:
```toml
name = "Hyde"
license = "MIT"
licenselink = "https://github.com/spf13/hyde/blob/master/LICENSE.md"
description = "An elegant open source and mobile first theme"
homepage = "http://siteforthistheme.com/"
tags = ["blog", "company"]
features = ["blog", ]
min_version = 0.13
[author]
name = "spf13"
homepage = "http://spf13.com/"
# If porting an existing theme
[original]
author = "mdo"
homepage = "http://hyde.getpoole.com/"
repo = "https://www.github.com/mdo/hyde"
```
> **Notes:**
>
> 1. This is different from the file created by `hugo new theme` in the old v0.12.
> The current Hugo v0.13 does create the same template with the new fields
> except `min_version` that was added in 0.14-DEV.
>
> 2. Only `theme.toml` is accepted, not `theme.yaml` or not `theme.json`.
## Media
Screenshots are used as preview in the list. Make sure that they have the right dimensions:
* Thumbnail should be 900×600 in pixels
* Screenshot should be 1500×1000 in pixels
* Media must be located in:
* [ThemeDir]/images/screenshot.png
* [ThemeDir]/images/tn.png
Additional media may be provided in that same directory.
## README.md
Your theme's README file
(which should be written in Markdown and called `README.md`)
serves a double purpose.
This is because its content will appear in two places—i.e., it will appear:
1. On your theme's details page at [themes.gohugo.io](http://themes.gohugo.io/); and
1. At GitHub (as usual), on your theme's regular main page.
**Note:** If you add screenshots to the README please make use of absolute file paths instead of relative ones like `/images/screenshot.png`. Relative paths work great on GitHub but they don't correspond to the directory structure of [themes.gohugo.io](http://themes.gohugo.io/). Therefore, browsers will not be able to display screenshots on the theme site under the given (relative) path.