Adding Navigation Links
Navigation inside a blog site is essential to discover related content.
Existing inspiration
It consists mostly of 3 things :
- tag navigation
- previous/next navigation
- related posts navigation
Tag navigation
I found some nice tag handling snippet for jekyll but it was a little too complex for my small needs. While it was nice since it had a tag page per tag as I wanted, it needed manual steps that I didn’t want.
Therefore, I hacked it away to make it much more simple. The resulting code is very different, as I finally used it more as a learning tool than to copy/paste from it.
It now produces a single page that has all the tags, and redirects to it from
the posts with div id="" anchors.
The code is comprised of
- the tags.md page
- the tags-cloud.md include file
- an {% assign ctags = ... %}Liquid directive to setup the correct tag list
Previous/Next navigation
Same as the tag navigation, I found a prev/next handling snippet and I adapted it, with some CSS tricks.
The code much simpler, as Jekyll does most of the work for us. It is comprised of
- the prev-next.html include file
- Adding the {% include prev-next.html -%}into_layout/post.html
Related Post navigation
For that, I got some inspiration from the same site as prev/next. They had an article that found the same deficiencies as the built-in mechanism in jekyll.
I edited the code to conform to my tag cloud navigation and i cleaned it a bit. As i did not like the way it mixes rendering and tag fetching.
It is a rather simple but clever algorithm:
- iterate on all the site posts
- see if there is at least a certain number of common tags between the current post and the iterated one
- limit the number of related posts
I totally injected the code in the _layouts/post.html file. With some
display: none; CSS if there are no related pages.