This is a brochure website for the International Interactive Computing Collaboration (2i2c). It is built from the [academic hugo theme].
This website is hosted by GitHub Pages, and we use Netlify to display previews of the website from PRs.
- Automatic GitHub link shortening. This theme will automatically shorten GitHub links and add a little GitHub icon to the front. For example, see the Jack Eddy Symposium blog post.
We currently build this site with Hugo Blox-Bootstrap v5.9.6. This version recommends Hugo v0.125.3.
-
Install the Hugo extended listed above from the latest releases page
- Ensure that you have the extended version
-
Clone this repository locally:
git clone https://github.com/2i2c-org/2i2c-brochure cd 2i2c-brochure
-
The content for this site lives in
content/
. Each folder inside is a page. -
These folders have a collection of markdown snippets that are stitched into a single page.
- Their order is determined by the
weight:
metadata on each page.
- Their order is determined by the
-
Preview the site locally with:
hugo serve -D
-
Push your changes to the repository and Netlify will automatically update the website.
We have a GitHub workflow to check for broken links. This runs each week and will open an issue if it finds any broken links.
To manually run it, trigger a workflow dispatch
here.
This repository is configured with the pyspelling package. It will analyze all of the markdown files in content/
and tell you if there are any un-recognized words.
To use pyspelling
, first install it:
pip install pyspelling
Then install the aspell
package:
sudo apt-get install aspell
Finally, you can run pyspelling
on the repository like so:
pyspelling
Note that pyspelling may find some errors that are simply un-recognized, but correct, words. For example, HTML elements. To make these errors pass, you can add them to the list of custom spelling words here:
.custom-dictionary.txt
.
For more information, see the pyspelling
documentation.
For text-based pages, we generate social media previews by automatically adding page title text to an image template. The template is defined in this Figma board and we use Hugo image filters to add text to it. See the hugo partial template we use for details and links.
The Featured Image will also be used to generate previews in social media. You can generate an image designed specifically for social media (similar to GitHub social media link previes). To do so, follow these steps:
-
Find the "Twitter Summary Community Update" frame.
-
Update the text to match the title of what you'd like to post.
-
Export the frame to PNG (at
1x
size). -
Place the PNG in the same folder as the relevant website page.
-
Rename the image so that it is "featured" for that page (see above)
-
Prevent the image from showing up on the page by adding the following to that page's YAML metadata:
image: preview_only: true
The image will now be used to generate a social media preview!
Our blog post feed is at https://2i2c.org/posts/, and contains a feed of posts from 2i2c team members.
This feed contains both internal and external blog posts. In general, when team members do work associated with other open source projects, we should write those posts in other spaces and cross-link them from the 2i2c blog.
The way to make a regular blog post is by following the standard Hugo documentation for internal blog posts. Check out the Hug Blox theme documentation for one way to do this.
To make an external blog post, follow these steps:
- Generate a blog post folder and include a markdown file similarly to how you'd generate an internal blog post.
- Add an
external_link
metadata parameter at the top of the file. The value of this parameter will be the external link the post should point to. - All other metadata can be the same, and will be used to share the post author, published order, etc.
Featured images are displayed to the right of each post in our post feed.
By default, you can add a featured image directly to the blog post's folder by adding an image called featured*
. For example, featured.jpg
, featured-image.png
, etc.
If you'd like to re-use another image on the site, you can create a symbolic link from the post folder to the image you'd like to re-use. This helps us save space and load time.
We have some custom Hugo templates created for posting new jobs and a summary of open jobs.
- The
content/jobs/
folder contains all content related to job postings and an overview of working at 2i2c. - The
/jobs/_index.md
file is a "landing page" for our jobs (what is at 2i2c.org/jobs).- It contains a custom Hugo shortcode defined at
layouts/shortcodes/open_jobs.html
that will list all jobs in thejobs/
folder that haveopen: true
in the page metadata.
- It contains a custom Hugo shortcode defined at
- Every other page in
/jobs/
is a job posting. The YAML metadata at the top contains several important pieces of information for the job, and is used to populate job posting cards.- Use previous job postings as a reference for the information that should be used.
- To mark a job as "open", make sure to put
open: true
in the posting metadata. - There's also a special shortcode to display relevant job metadata for a posting. This is at
layouts/shortcodes/job_details.html
.
We are using the latest version of the Hugo Blox theme (used to be the "Wowchemy Academic Theme"). See its documentation for information about customization and usage.
Optimizing images saves space in our repository and in traffic load times.
The oxipng
tool is one that we've used here.
These are brief instructions to get it working based on the oxipng
instructions.
It is written in Rust, so you'll need to install cargo
, install oxipng
, and then run it.
To Install Cargo, follow the Cargo installation steps.
This will install both Rust and Cargo.
On Windows and Mac, it should be something like:
curl https://sh.rustup.rs -sSf | sh
One you have done this, you can either run oxipng
manually or via pre-commit
.
Both are described below.
If you have pre-commit installed in this repository, it will run oxipng
on any .png
files that have been added automatically.
Simply cd
into this repository root, then run:
$ pip install pre-commit
$ pre-commit install
Now when you commit a .png
file, oxipng
will be run.
To run oxipng
manually, follow these steps:
-
Install
oxipng
. Usecargo
to installoxipng
.cargo install oxipng
-
Run the optimization on our images. This one uses several sensible options and will optimize any image in the repository.
oxipng -o 4 -i 1 --strip safe --recursive content *.png
Once the images are optimized, re-commit them to the repository and push the changes.