Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/MeiK2333/github-style
https://github.com/MeiK2333/github-style
blog hugo hugo-theme
Last synced: 3 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/MeiK2333/github-style
- Owner: MeiK2333
- License: mit
- Created: 2019-10-21T03:53:00.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2024-09-30T02:15:12.000Z (4 months ago)
- Last Synced: 2024-10-11T22:21:57.567Z (3 months ago)
- Topics: blog, hugo, hugo-theme
- Language: CSS
- Homepage: https://themes.gohugo.io/themes/github-style
- Size: 2.14 MB
- Stars: 567
- Watchers: 10
- Forks: 178
- Open Issues: 27
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-starred - MeiK2333/github-style - (others)
README
# github-style
## Init hugo site
```bash
hugo new site mysite
cd mysite
```## Install the theme
```bash
git submodule add [email protected]:MeiK2333/github-style.git themes/github-style
```## Update the theme
If you just installed the theme, it is already in the latest version. If not, you can update using the below commands
```bash
cd themes/github-style
git pull
```Then, you need to rename the previous `posts` folder to `post`
```bash
cd
mv content/posts content/post
```## Setup readme
```bash
hugo new readme.md
echo '`Hello World!`' > content/readme.md
```## Pin post
```
---
pin: true
---
```## Add new post
Hugo will create a post with `draft: true`, change it to false in order for it to show in the website.
```
hugo new post/title_of_the_post.md
```## Limit display content
### Approach 1: use summary
```
---
title: "title"
date: 2019-10-22T18:46:47+08:00
draft: false
summary: "The summary content"
---
```### Approach 2: use ``
Use `` to separate content that will display in the posts page as abstraction and the rest of the content. This is different from summary, as summary will not appear in the post.
```
---
title: "title"
date: 2019-10-22T18:46:47+08:00
draft: false
---
abstraction show in the post pageother content
```## Add last modified date
add to `config.toml`
```toml
lastmod = true[frontmatter]
lastmod = ["lastmod", ":fileModTime", ":default"]
```## Use [gitalk](https://github.com/gitalk/gitalk) to support comments
add to `config.toml`
```toml
enableGitalk = true[params.gitalk]
clientID = "Your client ID"
clientSecret = "Your client secret"
repo = "repo"
owner = "Your Github username"
admin = "Your Github username"
id = "location.pathname"
labels = "gitalk"
perPage = 30
pagerDirection = "last"
createIssueManually = true
distractionFreeMode = false
```## Support LaTeX
In you post add `math: true` to [front matter](https://gohugo.io/content-management/front-matter/)
```
---
katex: math
---
```Then the [katex script](https://katex.org/docs/autorender.html) will auto render the string enclosed by delimiters.
```
# replace ... with latex formula
display inline \\( ... \\)
display block $$ ... $$
```![latex example](https://raw.githubusercontent.com/MeiK2333/github-style/master/images/latex_example.png)
## Support MathJax
you can add MathJax:true to frontmatter```
mathJax: true
```
## config.toml example```toml
baseURL = "https://meik2333.com/"
languageCode = "zh-cn"
title = "MeiK's blog"
theme = "github-style"
pygmentsCodeFences = true
pygmentsUseClasses = true[params]
author = "MeiK"
description = "In solitude, where we are least alone."
github = "MeiK2333"
facebook = "MeiK2333"
twitter = "MeiK2333"
linkedin = "MeiK2333"
instagram = "MeiK2333"
tumblr = "MeiK2333"
email = "[email protected]"
url = "https://meik2333.com"
keywords = "blog, google analytics"
rss = true
lastmod = true
userStatusEmoji = "đ"
favicon = "/images/github.png"
avatar = "/images/avatar.png"
headerIcon = "/images/GitHub-Mark-Light-32px.png"
location = "China"
enableGitalk = true[params.gitalk]
clientID = "Your client ID"
clientSecret = "Your client secret"
repo = "repo"
owner = "MeiK2333"
admin = "MeiK2333"
id = "location.pathname"
labels = "gitalk"
perPage = 15
pagerDirection = "last"
createIssueManually = true
distractionFreeMode = false[[params.links]]
title = "Link"
href = "https://github.com/meik2333"
[[params.links]]
title = "Link2"
href = "https://meik2333.com"
icon = "https://meik2333.com/images/avatar.png"[frontmatter]
lastmod = ["lastmod", ":fileModTime", ":default"][services]
[services.googleAnalytics]
ID = "UA-123456-789"```
## Support collapsible block
You can create a collapsible block like this:
```
{{}}block content
{{}}
```And it will show like this:
summary title
block content
## Support local search
add to `config.toml`
```toml
[params]
enableSearch = true[outputs]
home = ["html", "json"][outputFormats.json]
mediaType = "application/json"
baseName = "index"
isPlainText = false
```We can do local search now, it is implemented by `fuse.js`.
## deploy.sh example
There are various way to deploy to github, here is a link to official [document](https://gohugo.io/hosting-and-deployment/hosting-on-github/).
Here is an sample. Note line 22 have `env HUGO_ENV="production"`, makes sure googleAnalysis is loaded during production, but is not loaded when we are testing it in localhost.
```bash
#!/bin/shif [ "`git status -s`" ]
then
echo "The working directory is dirty. Please commit any pending changes."
exit 1;
fiecho "Deleting old publication"
rm -rf public
mkdir public
git worktree prune
rm -rf .git/worktrees/public/echo "Checking out gh-pages branch into public"
git worktree add -B gh-pages public origin/gh-pagesecho "Removing existing files"
rm -rf public/*echo "Generating site"
env HUGO_ENV="production" hugo -t github-styleecho "Updating gh-pages branch"
cd public && git add --all && git commit -m "Publishing to gh-pages (publish.sh)"#echo "Pushing to github"
#git push --all
```Then you can verify the site is working and use `git push --all` to push the change to github. If you don't want to check again every time, you can uncomment the `#git push --all` in the script.
## TODO
- éĺć é˘ĺŻźčŞďźéŁçŠćĺżĺźĺ Ľç JS ĺ¨ć§ĺśĺ°ćĽéă