This article is based on my personal hands-on experience and provides a brief overview of how I used the giscus to add a comment section to articles in both the
.md
and.org
formats posts on my website.This post is also available in: 中文
Setting Up a Comment Section with Disqus for Org-Mode Hugo Blog Posts
1. Introduction to giscus
giscus is a comment system based on Github Discussions. It is quite similar to another comment system based on Github Issues, utterances.
The author of giscus, laymonage (Sage Abdullahe), mentioned in his/her blog post Introducing giscus:
He/She was an utterances user, until Github introduced the discussions feature, which inspired the idea of using discussions as a backend for the comment system.
When Github introduced discussions, they also stated:
"Until now, GitHub only offered issues and pull requests as places to have these conversations. But issues and pull requests both have a linear format—well suited for merging code, but not for creating a community knowledge base. Conversations need their own place —that’s what GitHub Discussions is for."
In short, compared to Issues, Discussions is more suitable for "discussions": "Conversations need their own place."
Rather than further elaborating, there are demonstrations available on the homepages of both systems. You can explore and compare the functionalities themselves:
utteranc.es, giscus
2. How to use giscus
Based on the information provided on the giscus homepage, it's easy to summarize the three steps required to use giscus:
- Configure your GitHub repository.
- Generate the embedding code.
- Enable giscus.
2.1 Github Repository Configuration
giscus relies on the GitHub repository's discussions feature, so you'll need a repository with discussions enabled as its backend. You can choose to create a brand-new repository dedicated to the website's comments section, or, like me, use your existing website GitHub repository.
2.1.1 Enable GitHub Discussions
To enable GitHub Discussions for the selected repository to serve as the comments backend: Go to the repository's homepage -> Click on the Settings tab -> Select General on the left side -> Under the Features section on the right side -> Check the Discussions option.
2.1.2 Install the giscus App
Visit github.com/apps/giscus and install giscus for the specified GitHub repository.
2.2 Generate Embed Code
The giscus website provides a straightforward and user-friendly process for generating the required code. Simply fill out the form to obtain the necessary code:
- Language: I need to use different comment section UI languages for the English and Chinese versions of the blog. So I manually modify
data-lang="zh-CN"
ordata-lang="en"
. - Repository: Enter the repository in the specified format. The page will automatically check if the target repository meets the requirements and retrieve the necessary information to generate the code.
Mapping:
- pathname
- For example, in this article, it will be
/posts/20230827_en-b49c5a4d/
. - URL
- I haven't tested this, but it might be in the format
blog.limewolf.top/posts/20230827_en-b49c5a4d/
. - <title>
- For example, in this article, it's
Setting Up a Comment Section With Disqus for Org-Mode Hugo Blog Posts - Limewolf🐺's Den
. - og:title
- If your blog uses Open Graph protocol, it might be
Setting Up a Comment Section with Disqus for Org-Mode Hugo Blog Posts
. - Specific Term
- As the name suggests, customize a specific term.
- Number
- Specify a specific discussion number for the comment section.
Since I want different language versions of the same article to share the same comment section (to discuss the same topic together and have a seamless experience), I chose to use the
Specific Term
to map the discussion to giscus. For example, in the guestbook of this site, the giscus code is configured like this:data-mapping="specific" data-term="Comment: guestbook"
The associated pages are as follows:
Guestbook (Chinese page), Guestbook (English page), GitHub Discussions.- Discussion Category: As the author suggests, to make sure your discussions are not disrupted, choose announcements and check "Only match this category."
- Features: These are self-explanatory features.
2.3 Enable giscus
2.3.1 Enable in Markdown Pages
Simply place the HTML code generated from the giscus website where you want to insert the comment section (e.g., at the end of the article).
2.3.2 Enable in Org-Mode Pages
You need to include the HTML code within an export HTML
block, like this: (You can insert it anywhere in the article)
#+BEGIN_EXPORT HTML
<script src="https://giscus.app/client.js"
......
crossorigin="anonymous"
async>
</script>
#+END_EXPORT
Fin.
Using giscus turned out to be much simpler than I expected. I quickly got the hang of using it to create a guestbook for my site. The only minor obstacle I encountered was when embedding it into my
.org
articles.Thanks to the powerful assistance of ChatGPT in helping me overcome the obstacles.
So, there are no more details to describe in this article, right?
Feel free to discuss and ask questions in the comment section!Thanks to giscus and its author laymonage for providing crucial support for interactivity on this blog.
Thank you for reading!
:)