2019-11-04 13:09:44 +00:00
# Zzo theme for Hugo
2019-11-11 08:22:08 +00:00
Thank you for click me!. Zzo theme is a blog theme for Hugo with free(always), and many features. If you find any bugs, or wanna share your custom color skin, or have some good idea to share with me and others who use this theme, feel free to open [github ](https://github.com/zzossig/hugo-theme-zzo/issues ) issue or pull request so that I can make this theme better.
2019-11-04 13:09:44 +00:00
## Table of contents
* [Features ](#features )
* [Reference ](#reference )
* [Dependency ](#dependency )
* [Minimum Hugo version ](#minimum-hugo-version )
* [Installation ](#installation )
* [Updating ](#updating )
* [Run example site ](#run-example-site )
* [Configuration ](#configuration )
* [Layout ](#layout )
* [Gallery ](#gallery )
* [Multi Language ](#multi-language )
2019-11-07 06:14:35 +00:00
* [Customizing ](#customizing )
2019-11-15 09:29:35 +00:00
* [Marmaid, Katex, MathJax, Flowchart.js ](#external-library )
2019-11-04 13:09:44 +00:00
* [Shortcodes ](#shortcodes )
## Features
* Multiple sub themes(dark, light, solarized, hacker)
* A mobile menu
* CSS grid and flex for layout
* HTML5
* Hugo Pipes for js and sass
* jQuery
* Simple blog
* Minify css
* Meta tags and JSON-LD
* Multilingual (i18n)
* Responsive design
* RSS and JSON feeds with full content
* Search with Lunr
* Gallery with Masonry, Photoswipe
* Prism.js for highlight code
* Lazy image load with lazysizes
## Reference
I have referenced:
* [zen theme ](https://github.com/frjo/hugo-theme-zen )
* [docdock theme ](https://github.com/vjeantet/hugo-theme-docdock )
* [learn theme ](https://github.com/matcornic/hugo-theme-learn/ )
2019-11-08 02:15:12 +00:00
* [academic theme ](https://sourcethemes.com/academic/ )
2019-11-04 13:09:44 +00:00
* [overreacted.io ](https://github.com/gaearon/overreacted.io )
## Dependency
Zzo theme is using this library.
* jquery@3.4.1
* mark.js
* clipboard.js
* lazysizes
* masonry
* lunr
* jquery.toc
* photoswipe
* prism
## Minimum Hugo version
Hugo version 0.58.0 or higher is required.
## Installation
First of all, You need to add config files.
Follow the [Configuration ](#configuration ) step.
2019-11-06 00:33:16 +00:00
Then, You can download and unpack the theme manually from Github but it's easier to use git to clone the repo.
2019-11-04 13:09:44 +00:00
From the root of your site:
```bash
$ git clone https://github.com/zzossig/hugo-theme-zzo.git themes/zzo
```
If you use git to version control your site, highly recommended, it's best to add the zzo theme as a submodule.
From the root of your site:
```bash
git submodule add https://github.com/zzossig/hugo-theme-zzo.git themes/zzo
```
## Updating
From the root of your site:
```bash
git submodule update --remote --merge
```
## Run example site
2019-11-05 01:11:07 +00:00
From the root of themes/zzo/exampleSite:
2019-11-04 13:09:44 +00:00
```bash
2019-11-04 15:23:24 +00:00
hugo server --themesDir ../..
2019-11-04 13:09:44 +00:00
```
## Configuration
2019-11-06 01:14:38 +00:00
0. From the root of your site: delete config.toml file and add the files below
2019-11-06 01:13:03 +00:00
2019-11-04 13:09:44 +00:00
1. config folder structure
```bash
root
├── config
│ ├── _default
│ │ ├── config.toml
│ │ ├── languages.toml
│ │ ├── menus.en.toml
│ │ ├── params.toml
```
2. config.toml
```bash
baseURL = "http://example.org/"
title = "Hugo Zzo Theme"
theme = "zzo"
defaultContentLanguage = "en"
2019-11-07 18:09:15 +00:00
defaultContentLanguageInSubdir = true
hasCJKLanguage = true
2019-11-04 13:09:44 +00:00
summaryLength = 70
2019-11-15 08:37:32 +00:00
copyright = "© {year}, All Rights Reserved"
2019-11-04 13:09:44 +00:00
timeout = 10000
enableEmoji = true
paginate = 7
rssLimit = 100
[outputs]
home = [ "HTML", "RSS", "JSON" ]
[taxonomies]
category = "categories"
tag = "tags"
series = "series"
```
3. languages.toml
```bash
[en]
title = "Hugo Zzo Theme"
languageName = "English"
weight = 1
[ko]
title = "Hugo Zzo Theme"
languageName = "한국어"
weight = 2
```
4. menus.en.toml
2019-11-04 15:45:35 +00:00
You shoud make your own menu.
2019-11-04 13:09:44 +00:00
```bash
[[main]]
2019-11-06 01:18:51 +00:00
identifier = "about"
name = "about"
url = "about"
2019-11-07 18:09:15 +00:00
weight = 1
2019-11-06 01:18:51 +00:00
[[main]]
identifier = "archive"
name = "archive"
url = "archive"
2019-11-07 18:09:15 +00:00
weight = 2
2019-11-06 01:18:51 +00:00
[[main]]
identifier = "gallery"
name = "gallery"
url = "gallery"
2019-11-07 18:09:15 +00:00
weight = 3
2019-11-06 01:18:51 +00:00
[[main]]
parent = "gallery"
name = "cartoon"
url = "gallery/cartoon"
[[main]]
parent = "gallery"
name = "photo"
url = "gallery/photo"
[[main]]
identifier = "posts"
name = "posts"
url = "posts"
2019-11-07 18:09:15 +00:00
weight = 4
2019-11-06 01:18:51 +00:00
[[main]]
identifier = "notes"
name = "notes"
url = "notes"
2019-11-07 18:09:15 +00:00
weight = 5
2019-11-04 15:45:35 +00:00
...
2019-11-04 13:09:44 +00:00
```
5. params.toml
```bash
2019-11-11 03:11:03 +00:00
logoText = "Zzo"
2019-11-04 13:09:44 +00:00
description = "The Zzo theme for Hugo example site."
2019-11-17 11:01:09 +00:00
custom_css = []
custom_js = []
2019-11-14 15:02:27 +00:00
2019-11-15 08:37:32 +00:00
# header
homeHeaderType = "slide" # text, img, slide
2019-11-17 11:01:09 +00:00
swiperCount = 3 # only works when homeHeaderType = slide
2019-11-04 13:09:44 +00:00
# body
enableBreadcrumb = true
enablePhotoSwipe = true
enableSearch = true
enableMark = true
2019-11-09 19:52:09 +00:00
enableGoToTop = true
enableWhoami = true
2019-11-12 10:03:15 +00:00
summaryShape = "card" # card, classic, compact
2019-11-17 11:01:09 +00:00
archiveGroupByDate = "2006" # "2006-01": group by month, "2006": group by year
archivePaginate = 20
paginateWindow = 1
# whoami
2019-11-15 08:37:32 +00:00
myname = "zzossig"
2019-11-17 11:01:09 +00:00
email = "zzossig@gmail.com"
whoami = "Web Developer"
useGravatar = false
location = "Seoul, Korea"
organization = "Hugo"
link = "https://github.com/zzossig/hugo-theme-zzo"
2019-11-04 13:09:44 +00:00
# sidebar
2019-11-15 08:37:32 +00:00
enableBio = true
2019-11-12 10:03:15 +00:00
enableSidebar = true
2019-11-04 13:09:44 +00:00
enableSidebarTags = true
enableSidebarSeries = true
enableSidebarCategories = true
2019-11-12 10:03:15 +00:00
enableToc = true
2019-11-14 03:31:02 +00:00
enableTocSwitch = true
2019-11-11 03:11:03 +00:00
itemsPerCategory = 5
2019-11-13 08:06:51 +00:00
enableSideSubscribe = false
2019-11-14 08:18:50 +00:00
searchLanguages = ['en'] # checkout lunr.js supported language
2019-11-04 13:09:44 +00:00
2019-11-09 19:52:09 +00:00
# comment
enableComment = false
disqus_shortname = ""
commento = false
2019-11-04 13:09:44 +00:00
# footer
showPoweredBy = true
showFeedLinks = true
showSocialLinks = true
enableLangChange = true
enableThemeChange = true
2019-11-10 11:01:34 +00:00
themeOptions = ["dark", "light", "hacker", "solarized", "custom"]
2019-11-04 13:09:44 +00:00
[socialOptions]
2019-11-09 19:52:09 +00:00
email = "mailto:your@email.com"
2019-11-04 13:09:44 +00:00
facebook = "http://example.org/"
twitter = "http://example.org/"
github = "http://example.org/"
stack-overflow = ""
instagram = ""
google-plus = ""
youtube = ""
medium = ""
tumblr = ""
linkedin = ""
2019-11-09 19:52:09 +00:00
pinterest = ""
2019-11-04 13:09:44 +00:00
stack-exchange = ""
```
## Layout
### CSS grid for layout
Modern CSS grid is the easiest and cleanest way to layout your pages.
The CSS grid layout are in `assets/sass/layout/_grid.scss` . A lot can be done by just reordering "grid-template-rows".
2019-11-11 14:44:13 +00:00
### grid structure
2019-11-04 13:09:44 +00:00
| left | right |
|--- |--- |
| 1 | 2 |
| 3 | 4 |
| 5 | 6 |
| 7 | 8 |
* left, right column width ratio => 5 : 2
* 1 => .navbar-main
* 2 => .navbar-side
* 1 + 2 => .navbar
* 3 => .header-main
* 4 => .header-side
* 3 + 4 => .header
* 5 => .main-main
* 6 => .main-side
* 5 + 6 => .main
* 7 => .footer-main
* 8 => .footer-side
* 7 + 8 => .footer
### grid structure example applied in home page
```html
< div class = "navbar" > < / div >
< div class = "header" > < / div >
< div >
< div class = "main-main" > < / div >
< div class = "main-side" > < / div >
< / div >
< div class = "footer > < / div >
```
## Gallery
2019-11-13 08:06:51 +00:00
There are two ways to make gallery. You can specify **mode** at frontmatter.
```bash
content/gallery/mygallery/index.md
---
title: "{{ replace .Name "-" " " | title }}"
date: {{ .Date }}
description:
type: gallery
mode: one-by-one # at-once or one-by-one
tags:
-
series:
-
categories:
-
images: # when mode is one-by-one, images front matter works
- image: image1.jpg
caption: caption1
- image: image2.jpg
caption: caption2
...
---
```
If you set the mode to one-by-one, list.html page will use images frontmatter above. If you set the mode to at-once, list.html page will not use images frontmatter and just read all files under the static/gallery/mygallery folder.
2019-11-04 13:09:44 +00:00
1. Make a gallery folder under the content folder
```bash
root
├── content
│ ├── gallery
```
2. Make a sub folder under the gallery folder
```bash
root
├── content
│ ├── gallery
│ │ ├── mygallery
```
3. Make a index.md file under the sub folder using this command
```bash
2019-11-06 00:33:16 +00:00
hugo new gallery/mygallery/index.md
2019-11-04 13:09:44 +00:00
```
4. Put your images in static folder
```bash
root
├── static
│ ├── gallery
│ │ ├── mygallery
│ │ │ ├── ...your images here
```
## Multi Language
The default language of this theme is English. If you want to use another language, follow these steps
1. Make a menu file.
```bash
root
├── config
│ ├── _default
│ │ ├── ...
│ │ ├── menus.ko.toml
```
```bash
config/_default/menus.ko.toml
[[main]]
identifier = "about"
name = "about"
2019-11-04 15:23:24 +00:00
url = "/about/"
2019-11-04 13:09:44 +00:00
weight = 1
[[main]]
identifier = "archive"
name = "archive"
2019-11-04 15:23:24 +00:00
url = "/archive/"
2019-11-04 13:09:44 +00:00
weight = 2
...
```
2. Make a content file. Add your language code before the md extension.
```bash
hugo new about/index.ko.md
hugo new posts/markdown-syntax.ko.md
...
```
3. Make an i18n file.
```bash
i18n/ko.toml
[search-placeholder]
other = "검색..."
[summary-dateformat]
other = "2006년 01월 02일"
[taxo-tags]
other = "태그"
...
```
2019-11-07 06:14:35 +00:00
## Customizing
2019-11-11 03:11:03 +00:00
It's better idea not to modify zzo theme's folder if you wanna future support and upgrade. (You can modify if it doesn't matter) If you want more customizing options, open an issue.
2019-11-07 06:14:35 +00:00
### custom css
1. Add this line of code to your params.toml file
```bash
config/_default/params.toml
...
custom_css = ["css/custom.css", "scss/custom.scss", ...]
...
```
2. Add your file to assets folder. Filename must match with config params you set above.
```bash
assets/scss/custom.scss
assets/css/custom.css
```
3. If you want to modify zzo theme's default color, you should override the theme style. For example, if you want to change the body background-color, because I set the background-color in #body selector, not in body tag selector, you should override body background-color there. body tag selector won't work. And make sure to set !important.
```css
assets/scss/custom.scss or assets/css/custom.css
...
#body {
background-color: red !important;
}
...
```
### custom js
1. Add this line of code to your params.toml file
```bash
config/_default/params.toml
...
custom_js = ["js/custom.js", ...]
...
```
2. Add your file to assets folder. Filename must match with config params you set above.
```bash
assets/js/custom.js
```
### custom skin(sub theme)
2019-11-08 02:15:12 +00:00
1. Make a skin.toml file in data folder. (data/skin.toml)
2. Copy the contents of themes/zzo/data/skin.toml file and paste it into the skin.toml file you created above.
3. Change the color you want.
4. Edit config/_default/params.toml file. The option name must be custom.
```bash
...
themeOptions = ["custom", "dark", ...]
...
```
5. Once you change the skin.toml file, restart hugo.
### custom font
1. Make a font.toml file in data folder. (data/font.toml)
2. Copy the contents of themes/zzo/data/font.toml file and paste it into the font.toml file you created above.
3. Change the font you want. Make sure that you have imported that font.
2019-11-04 13:09:44 +00:00
2019-11-08 02:15:12 +00:00
4. Once you change the font.toml file, restart hugo.
2019-11-04 13:09:44 +00:00
2019-11-11 14:44:13 +00:00
```toml
data/font.toml example
search_placeholder = "'Montserrat', sans-serif"
summary_title = "'Montserrat', sans-serif"
summary_subtitle = "'Merriweather', serif"
summary_text = "'Merriweather', serif"
taxo_titie = "'Montserrat', sans-serif"
footer_content = "'Montserrat', sans-serif"
header_title = "'Montserrat', sans-serif"
navbar_item = "'Montserrat', sans-serif"
sidebar_title = "'Montserrat', sans-serif"
sidebar_list = "inherit"
page_not_found = "'Montserrat', sans-serif"
gallery_contents = "'Merriweather', serif"
list_title = "'Montserrat', sans-serif"
list_desc = "'Merriweather', serif"
single_title = "'Montserrat', sans-serif"
single_contents = "'Merriweather', serif"
```
2019-11-11 03:11:03 +00:00
### custom header
2019-11-15 09:29:35 +00:00
You may want to change home page header. There are 4 options which is slider, image, text, empty.
* Empty
1. Set params at config/_default/params.toml(homeHeaderType=""). Empty string or just delete it.
* Slider
This project use swiper library for slider header component.
1. Set params at config/_default/params.toml(homeHeaderType="slide", swiperCount).
2. Make slide-{number}.html file to layouts/partials/header folder.
3. Make swiper.json file that contains options to data folder.
* Image
1. Set homeHeaderType param to "img"
2. Add image to static/images/header/background.jpg. Filename must be background
3. If you want add some contents, make a file at layouts/partials/header/header-img-content.html and edit as you want.
* Text
1. Make a file at layouts/partials/header/header-text.html
2. Edit the file as you want.
2019-11-11 03:11:03 +00:00
2019-11-11 14:44:13 +00:00
### custom grid
1. Make a grid.toml file in data folder. (data/grid.toml)
2. Copy the contents of themes/zzo/data/grid.toml file and paste it into the grid.toml file you created above.
3. Change the grid you want.
4. Once you change the grid.toml file, restart hugo.
```toml
data/grid.toml example
2019-11-17 11:01:09 +00:00
grid_max_width = "960"
grid_max_unit = "px" # "px", "\"%\"" Using% is limited to using full width.
2019-11-11 14:44:13 +00:00
grid_main_main_width = "5"
2019-11-17 11:01:09 +00:00
grid_main_main_unit = "fr" # "fr", "px"
2019-11-11 14:44:13 +00:00
grid_main_side_width = "2"
2019-11-17 11:01:09 +00:00
grid_main_side_unit = "fr" # "fr", "px"
grid_column_gap_width = "32"
grid_column_gap_unit = "px" # "px"
grid_navbar_height = "50px" # "px"
2019-11-11 14:44:13 +00:00
grid_row_gap = "0"
```
2019-11-15 09:29:35 +00:00
## External Library
If you want use external libraries, this theme currently supporting Katex, MathJax, Mermaid, Flowchart.js. Just add some front matter.
```bash
---
title: "{{ replace .Name "-" " " | title }}"
date: {{ .Date }}
...
libraries:
- katex
- mathjax
- flowchartjs
- mermaid
---
```
You can add some config option parameters at data/flowchartjs.json
2019-11-04 13:09:44 +00:00
## Shortcodes
### warning
```bash
{{% alert theme="info" %}}**this** is a text{{% /alert %}}
{{% alert theme="success" %}}**Yeahhh !** is a text{{% /alert %}}
{{% alert theme="warning" %}}**Be carefull** is a text{{% /alert %}}
{{% alert theme="danger" %}}**Beware !** is a text{{% /alert %}}
```
### expand
```bash
{{%expand "Expand me" %}}Good job{{% /expand%}}
```
### img
```bash
{{% img src="https://example.com" title="Image4" caption="Image description" alt="image alt" %}}
```
### notice
```bash
{{% notice note %}}
A notice disclaimer
{{% /notice %}}
2019-11-06 01:13:03 +00:00
```