Hugo Utterances Module

Donate

Become a backer or sponsor to support our work.

Sponsors

This module add support for Utterances comments engine, a lightweight comments widget built on GitHub issues.

Modulegithub.com/hugomods/utterances
StatsGitHub Stars Used By Used By Used By Used By

Features

  • Flexible and Configurable.
  • JS APIs: change theme on the fly, it’s usually used in the case of color(dark/light) changed.

Installation

Requires extended Hugo and Go.

Append the github.com/hugomods/utterances to the module.imports.

1[[module.imports]]
2path = "github.com/hugomods/utterances"

Site Parameters

NameTypeRequiredDefaultDescription
endpointStringYhttps://utteranc.es/The client script endpoint.
repoStringY-The GitHub repository, user/repo.
mappingStringNpathnameThe mapping between blog posts and GitHub issues. Available options: pathname, url, title, og:title.
themeStringNpreferred-color-schemeAvailable options: github-light, github-dark, github-dark-orange, icy-dark, dark-blue, photon-dark, preferred-color-scheme, boxy-light, gruvbox-dark.
labelStringNcommentsThe label that will be assigned to issues created by Utterances.

See the configuration for details.

Usage

See the example site and it’s source code.

Configuration

Firstly, we’ll need to tweak the site parameters listed above.

Import Script

Then place the following partial to your template where you want the comments to appear.

1{{ partial "utterances/script" . }}

Or specify another options than .Site.Params.utterances, it’s used to specify multiple Utterances configurations.

The global options will be merged into the custom options.

1{{ partial "utterances/script-with-options" .Site.Params.blog.utterances }}

JS APIs

You may want to change the Utterances theme on the fly, a common example is changing the Utterances to the corresponding theme when the user switches colors(dark/light).

1import Utterances from 'mods/utterances/js';
2
3const utterances = new Utterances();
4utterances.setTheme('github-dark');

You can find the real example on the example site.