Params Configurations
This doc introduces all the parameters that can be configured in the [params]
.
Example
[params]
# zenMode = true
lightTheme = "emerald"
darkTheme = "forest"
# backgroundImage = "me/background.jpg"
# backgroundImageDark = ""
images = ["me/background.jpg"]
author = "g1eny0ung"
description = "g1eny0ung 的生活记录~"
avatar = "me/yy.jpg"
headerTitle = "g1eny0ung 的博客"
motto = "与其感慨路难行,不如马上出发。"
# footerBottomText = ""
rss = true
utterancesRepo = "g1eny0ung/g1eny0ung.github.io"
# valine = true
# LEANCLOUD_APP_ID = ""
# LEANCLOUD_APP_KEY = ""
# waline = true
# walineServer = ""
email = "[email protected]"
siteStartYear = 2016
favicon = "favicon.ico"
# Syntax highlighting
customSyntaxHighlighting = true
# options
stickyNav = true
# reorderNavItems = ["search", "rss", "posts", "categories", "tags"]
# collapseNavItems = ["posts", "categories", "tags"]
# noDefaultSummaryCover = true
showTableOfContents = true
showSummaryCoverInPost = true
imageZoomableInPost = true
showPrevNextPost = true
# reorderShares = ["x", "facebook", "whatsapp"]
[params.advanced]
# customCSS = ["css/custom.css"]
# customJS = []
[params.experimental]
jsDate = true
jsDateFormat = "yyyy年MM月dd日"
Basic
zenMode
Zen mode is a simple layout that allows you to concentrate on reading and writing. It uses a simple and clean interface rather than the default masonry layout.
👉 View Zen Mode for more details.
Light and Dark Mode
Required.
You can first add these two parameters to the [params]
, they are default themes for light and dark mode.
lightTheme = "emerald"
darkTheme = "forest"
For using other themes, view Light and Dark Mode for more details.
backgroundImage
Define a global background image.
backgroundImageDark
Define a global background image in dark mode.
images
View https://gohugo.io/templates/internal/#open-graph for more details.
Use the first one of site images as the fallback image for Open Graph.
author
The author field will be used as:
<meta name="author" content="g1eny0ung" />
- In the summary of post cards
description
The description field will be used as <meta name="description" content="g1eny0ung 的生活记录~" />
avatar
Your personal avatar.
headerTitle
The global title of the website.
motto
A motto that will be displayed below the headerTitle
. This field is optional.
footerBottomText
Used to display text at the bottom of the site footer, below the siteStartYear
field. This field supports HTML.
If this field is not specified, the default text will be displayed as:
🌱 Powered by Hugo with theme Dream.
rss
Enable RSS.
utterancesRepo
Utterances is a lightweight comments widget built on GitHub Issues.
By setting utterancesRepo
, each post will have a comment section powered by GitHub Issues.
View https://utteranc.es for more details.
valine
Valine is a fast, simple & efficient LeanCloud based no backend comment system. You can view https://valine.js.org/en/index.html for more details.
To make it work, you still need to set these two parameters:
[params]
LEANCLOUD_APP_ID = ""
LEANCLOUD_APP_KEY = ""
To customize Valine, you can create a partial file named valine.html
in the layouts/partials
folder.
Here is an example.
You still need to set the valine
parameter to true
to enable Valine when using a custom partial file.
Other related parameters will be ingored.
waline
Waline is a simple comment system with backend support fork from Valine. You can view https://waline.js.org/en/ for more details.
To enable Waline, you need to set the waline
parameter to true
and
set the walineServer
parameter to your Waline server address:
waline = true
walineServer = "https://your-waline-server.com"
If you want to customize Waline,
you can create a partial file named waline.html
in the layouts/partials
folder.
Here is an example.
You still need to set the waline
parameter to true
to enable Waline when using a custom partial file.
Other related parameters will be ingored.
siteStartYear
Set the start year of your site, it will be displayed as siteStartYear - currentYear (eg: 2016 - 2020) in the site footer.
favicon
Custom the favicon, place it in the static
folder.
customSyntaxHighlighting
View Syntax highlighting for more details.
stickyNav
Make navbar sticky when scrolling.
reorderNavItems
Reorder the navigation items.
This parameter is an array of strings, the default value is:
reorderNavItems = ["search", "rss", "posts", "categories", "tags"]
The names of these default items are fixed, and they are the navigation items provided by the Dream theme by default.
This parameter also allows you to remove the default navigation items.
For example, if you don’t want to show the rss
item, you can set the value as:
reorderNavItems = ["search", "posts", "categories", "tags"]
For reordering custom navigation items, see Custom Navbar Items.
collapseNavItems
In mobile, this parameter will not take effect because all navigation items will be collapsed into a dropdown menu.
Collapse specific navigation items to a dropdown menu.
For example, if you want to collapse the posts
, categories
, and tags
items, you can set the value as:
collapseNavItems = ["posts", "categories", "tags"]
For collapsing custom navigation items, see Custom Navbar Items.
noDefaultSummaryCover
If you are not specify the cover
field in the front matter of your posts,
a default cover image will be displayed in the summary cards.
If you don’t want this behavior, you can set this param to true
.
showTableOfContents
Show table of contents in the single post page.
showSummaryCoverInPost
Show summary cover image in the single post page.
imageZoomableInPost
Make images zoomable in the single post page. This feature uses medium-zoom under the hood.
For advanced usage, you may want to customize the medium-zoom options. Dream allows you to
create a partial file named medium-zoom.html
in the layouts/partials
folder to replace the
default behavior. For example, you can put the following code in the medium-zoom.html
file:
<script type="module">
import mediumZoom from 'https://cdn.jsdelivr.net/npm/[email protected]/+esm';
mediumZoom('#dream-single-post-content img', {
// Put your custom options here.
}) // #dream-single-post-content is the id of the post content.
// You can also further control the logic of zooming images.
// Like zooming lazy-loaded images.
</script>
showPrevNextPost
Show previous and next post links in the single post page.
reorderShares
Same as reorderNavItems, reorder the share buttons in the single post page.
This parameter is an array of strings, the default value is:
reorderShares = ["x", "facebook", "whatsapp"]
This parameter also allows you to remove the default share items.
For example, if you don’t want to show the whatsapp
item, you can set the value as:
reorderShares = ["x", "facebook"]
Advanced
Generally, the following advanced parameters are not necessary to be set. Their main purpose is to further customize the entire theme.
customCSS
Add your custom CSS files after the theme CSS files.
For example, create a folder named css
under static
, then add custom.css
into it.
View Custom Theme for more details.
customJS
Like customCSS
, add your custom JS files after the theme JS files.
View Custom Theme for more details.
Experimental
The experimental parameters are often not perfect. They have advantages as well as certain disadvantages.
jsDate
Use Luxon to replace the Hugo built-in .Format function. This allows you to define the time format more flexibly.
You may not want to use this param if you want the final date is generated at compile time. After setting this param, all dates will output as an RFC3339 format and all rest format operations will be executed after the page is loaded.
For how to define the format, see below.
jsDateFormat
Refer to this page (https://moment.github.io/luxon/docs/manual/formatting.html) to define your date format.
For example, yyyy-MM-dd
represents a date format like 2021-04-17
.