For a Jekyll-powered site that I'm building, I needed an image gallery. I browsed the "Sites built with Jekyll" list in Jekyll's GitHub wiki to see how others do galleries with Jekyll, but I didn't find a site that used any kind of "real" image gallery (besides stuff like just showing thumbnails from Flickr and then linking directly to Flickr to display the actual image, which is not what I wanted).
I guess Jekyll is mostly used by programmers to create blogs about programming, so most Jekyll users don't want/need a gallery. Without a ready-made example to borrow from, I had to create something by myself.
FancyBox or Lightbox2?
For a start, I needed an "image displaying" script.
The standard these days seems to be FancyBox (at least that's my impression), and I also evaluated Lightbox2.
With FancyBox, I had some problems with the relative paths to the "helper images" (stuff like left/right arrows) that I didn't have with Lightbox2. So I just took the path of least resistance and used Lightbox2.
The actual site for which I created this gallery is private (as well as its source code), so I can't show it here.
Instead, I built a small example site (with Jekyll's standard template and the example images that come with Lightbox2) and put the source code on Bitbucket.
You can view the source code here and the finished site here.
Creating a Data File
First, I created one data file to hold all images of all image galleries.
In my first draft, I had one data file per gallery, but in the end I went with one single file for everything, because that makes it easier to display a list of all available galleries.
My data file looks like this:
- id: gallery1
description: This is the first gallery
imagefolder: /img/demopage
images:
- name: image-1.jpg
thumb: thumb-1.jpg
text: The first image
- name: image-2.jpg
thumb: thumb-2.jpg
text: The second image
- name: image-3.jpg
thumb: thumb-3.jpg
text: The third image
- id: anothergallery
description: This is even another gallery!
imagefolder: /img/demopage
images:
- name: image-4.jpg
thumb: thumb-4.jpg
text: Another gallery, first image
- name: image-5.jpg
thumb: thumb-5.jpg
text: Another gallery, second image
- name: image-6.jpg
thumb: thumb-6.jpg
text: Another gallery, third image
Gallery Overview
Since all galleries are inside the same data file, creating the list of galleries on the "gallery index page" is very simple:
{% for gallery in site.data.galleries %}
- [{{ gallery.description }}]({{ gallery.id }})
{% endfor %}
This just loops through the list of galleries, displays the description
value and links to a sub-folder with the name of the id
value.
The file is a Markdown file, so creating the list of links in Markdown is sufficient.
Sub Pages and Lightbox Galleries
Next, I created the sub pages with the actual image galleries, the ones that are linked from the gallery index page.
According to the Lightbox docs, the following steps are required to display images with Lightbox:
- Load jQuery and two Lightbox files (JS and CSS)
-
Show each image on the page with the following HTML:
<a href="img/image-1.jpg" data-lightbox="image-1"
title="My caption">image #1</a>
This means that all sub pages will be identical (read from YAML data file and generate the HTML described above), so I put the actual creation of the gallery into a layout file.
It's still necessary to create a HTML or Markdown file for the actual URL of each gallery, but these files don't need to have any content, just minimal YAML front-matter:
---
title: the first gallery page
layout: gallery
galleryid: gallery1
---
- The line
layout: gallery
points to the layout file that I'll explain next, the one that does all the work. - The line
galleryid: gallery1
refers to the id
in the YAML data file, so the layout file knows that it needs to load the pictures of the gallery "gallery1
".
This is how the layout file looks like:
---
layout: default
---
<script src="http://christianspecht.de/js/jquery-1.10.2.min.js"></script>
<script src="http://christianspecht.de/js/lightbox-2.6.min.js"></script>
<link href="http://christianspecht.de/css/lightbox.css" rel="stylesheet" />
<p>default header for all gallery pages</p>
{% for gallery in site.data.galleries %}
{% if gallery.id == page.galleryid %}
<h1>{{ gallery.description }}</h1>
<ol>
{% for image in gallery.images %}
<li>
{{ image.text }}<br>
<a href="{{ gallery.imagefolder }}/{{ image.name }}"
data-lightbox="{{ gallery.id }}" title="{{ image.text }}">
<img src="{{ gallery.imagefolder }}/{{ image.thumb }}">
</a>
</li>
{% endfor %}
</ol>
{% endif %}
{% endfor %}
<p>default footer for all gallery pages</p>
To find the right gallery in the data file, the layout just loops through the data file until it finds a gallery where the id
property matches the galleryid
in the front matter of the page.
Then, it loops through the images in the gallery and creates the necessary "Lightbox HTML" for each one (with thumbnails and image descriptions).
The Result
In the end, this gallery (from the first part of the data file):
- id: gallery1
description: This is the first gallery
imagefolder: /img/demopage
images:
- name: image-1.jpg
thumb: thumb-1.jpg
text: The first image
- name: image-2.jpg
thumb: thumb-2.jpg
text: The second image
- name: image-3.jpg
thumb: thumb-3.jpg
text: The third image
...is transformed into this HTML:
<h1>This is the first gallery</h1>
<ol>
<li>
The first image<br>
<a href="http://christianspecht.de/img/demopage/image-1.jpg"
data-lightbox="gallery1" title="The first image">
<img src="http://christianspecht.de/img/demopage/thumb-1.jpg">
</a>
</li>
<li>
The second image<br>
<a href="http://christianspecht.de/img/demopage/image-2.jpg"
data-lightbox="gallery1" title="The second image">
<img src="http://christianspecht.de/img/demopage/thumb-2.jpg">
</a>
</li>
<li>
The third image<br>
<a href="http://christianspecht.de/img/demopage/image-3.jpg"
data-lightbox="gallery1" title="The third image">
<img src="http://christianspecht.de/img/demopage/thumb-3.jpg">
</a>
</li>
</ol>
Adding a New Gallery
Now that all the plumbing is done, adding a new gallery page is very simple:
That's already enough to add this gallery to the site.
There is also another blog post showing a different approach how to generate image galleries with Jekyll.