Update 2024-08-20: this is an old post, it refers to an old website.
If you like this website, maybe you would like to have a similar page for yourself too. In this post, I’m going to describe the major steps involved.
Let’s start!
1. Install Hugo
This website has been built using a static site generator called Hugo. So, the very first thing to do would be to install Hugo.
In my case (Arch Linux), I would run the following:
pacman -S hugo
For Debian-based systems (such as Ubuntu), you would run:
sudo snap install hugo --channel=extended
2. Create a new website
The following command creates a new site, that is basically a folder called <your-site-name> that contains the essential elements of a Hugo website.
hugo new site <your-site-name> --format yml
3. Choose a theme
This website use PaperMod theme, but you can choose whichever you like from this list of Hugo themes.
Amend and launch the following command following your previous choices.
cd <your-site-name>
git submodule add --depth=1 https://github.com/adityatelange/hugo-PaperMod.git themes/PaperMod
4. Add some content
To add content to your website, you can create a new post or a new section.
The command below creates a new post.
hugo new posts/<your-post-name>.md
The command below creates a new section.
hugo new <your-section-name>/_index.md
To help you understand the difference between a post and a section, I will show you a snapshot of the folder structure of this website.
.
├── config.yml # core file for customization
├── content # root for all the content
│ ├── bio # section
│ │ └── _index.md # makes the section a `single` page
│ ├── _index.md # to rename the section name
│ └── posts # another section, this has been left as a `list` page (the default)
│ ├── how-to-install-arch-linux.md # a post, that is a `single` page
│ ├── how-to-create-a-personal-website-with-hugo.md # another post
│ ├── _index.md # to rename the section name
│ └── routine.md # again, another post
├── layouts # this section overraids the ./themes/PaperMod/layouts/ settings
│ ├── _default
│ │ └── single.html
│ ├── partials
│ │ └── comments.html
│ └── shortcodes
│ └── video.html # the content allows to embed videos in posts
└── static # contains files that can be embedded by your pages
├── homer-arch.mp4
├── LorenzoPalloniCV.pdf
└── me_thinking_cropped.jpeg
5. Start the Hugo server
hugo server -D
This command will start a live server to check changes while developing. The -D
flag allows to build drafts. It would be helpful to check the changes in the website while you are developing it.
6. Site Configuration
The config.yml
file is the core file for customization. It is theme-specific and contains the basic settings for your website. You can have a look at config.yml
file for this website to have an idea of the settings you can change for the PaperMod theme.
7. Let GitHub to host your website
⚠️ ATTENTION ⚠️: Follow the instructions described here (First Deployment with GITHUB_TOKEN
).
Follow the instructions described here. Pull your new repository.
git clone git@github.com:lorenzopalloni/lorenzopalloni.github.io.git
cp -r ./<your-site-name>/* -t lorenzopalloni.github.io
cd lorenzopalloni.github.io
mkdir -p .github/workflows/
touch .github/workflows/gh-pages.yml
In .github/workflows/gh-pages.yml
copy the following:
name: GitHub Pages
on:
push:
branches:
- main # Set a branch to deploy
pull_request:
jobs:
deploy:
runs-on: ubuntu-20.04
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
steps:
- uses: actions/checkout@v3
with:
submodules: true # Fetch Hugo themes (true OR recursive)
fetch-depth: 0 # Fetch all history for .GitInfo and .Lastmod
- name: Setup Hugo
uses: peaceiris/actions-hugo@v2
with:
hugo-version: '0.91.2'
# extended: true
- name: Build
run: hugo --minify
- name: Deploy
uses: peaceiris/actions-gh-pages@v3
if: ${{ github.ref == 'refs/heads/main' }}
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
publish_dir: ./public
8. Compile your new website
To compile your new website, you would need to run the following command.
hugo
9. Deploy your new website
To deploy your new website, you would need to push your changes to GitHub.
git add .
git commit -m "Initial commit"
git push
If you have followed all the steps, you should be able to see your new website at https://<your-github-username>.github.io
.
10. Enjoy your new website 🎉
If you would like to add some features to your website, such as allowing comments of your posts, embedding videos, and more, you can check out another post I wrote about Personal Website With Hugo Maintainance And Enhancements.
I hope you have found this post useful somehow.
In case you have any questions or comments, please write them below, I’ll be happy to discuss with you. In the meanwhile, have a beautiful day! 😊