Baguette Box JS
So my second Javascript lightbox or gallery is Baguette Box JS. I was looking for:
- a vanilla JS library that didn’t need another library
- Did a nice job of displaying images, ran smoothly and was easy to install.
- Was customizable for different uses.
- Was responsive and mobile (touch) friendly.
I think Baguette Box ticks the boxes. It has bunch of custom settings that are easy to add, the documentation is fairly simple but it doesn’t need any more. Compared to Photoswipe there is no full screen button but full screen can be made the default in the code, so developer set rather than set by the user, so that’s a minor downside compared to Photoswipe.
However there are several upsides.
- You don’t need to add the image size for every image which is great. If you have a lot of different sized images that’s pain. In my Photoswipe gallery I made the images the same size.
- There is a lot less code to deal with (see below).
- Customization is easy
Customization comes in two forms. Firstly you can edit the CSS. Secondly you can cut’n’paste some code snippets between some JS brackets. Easy.
How to integrate Baguette Box with Hugo
The two things necessary for Baguette Box are:
- JS and CSS files for the Baguette Box to work. Using a CDN these are simply links the
<head>
of the document. - Some HTML code for your web page below to your page.
Here are the CDN links for the <head>
section. I got them both from CDNJS.
(You can of course always get the latest files from BaguetteBox GitHub page and link to those if you prefer.)
1<script src="https://cdnjs.cloudflare.com/ajax/libs/baguettebox.js/1.11.1/baguetteBox.js" integrity="sha512-FbW9...HE9cknTrg==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
2<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/baguettebox.js/1.11.1/baguetteBox.css" integrity="sha512-3eoKq...wDVwg==" crossorigin="anonymous" referrerpolicy="no-referrer" />
- The basic HTML suggested by Baguette Box is:
1<div class="gallery">
2 <a href="img/2-1.jpg" data-caption="Image caption">
3 <img src="img/thumbnails/2-1.jpg" alt="First image">
4 </a>
5 <a href="img/2-2.jpg" data-caption="Image caption">
6 <img src="img/thumbnails/2-2.jpg" alt="Second image">
7 </a>
8 ...
9</div>
Hugo code
Although the above code is simple enough if you’ve 30 images you don’t want to be writing that out over and over again. This is where Hugo comes in.
On the Hugo side we need the images kept somewhere to use and some code to place the images in our HTML code above.
The two possible places to store the images are either:
- in a leaf-bundle (simply a folder with an
index.md
file for the page) - or subfolder of the top level
/assets
folder.
I went for the leaf bundle method because I like the fact you can just dump a bunch of images in there, turn on Baguette Box with two words in the frontmatter, and let Hugo do the rest.
Here is my code. The .gallery
could be anything you want (no space though). It’s just the class name of the <div>
that contains the gallery.
1<script>
2 baguetteBox.run('.gallery');
3</script>
4
5
6<div class="gallery">
7 <ul>
8 {{- with .Page.Resources.ByType "image" }}
9 {{ range . }}
10 {{ $thumbs := .Fill "200x200" }}
11 <li>
12 <a href="{{ .Name }}" data-caption="{{ with .Exif }}{{ .Date.Format "Jan 2006" }} {{ .Tags.Caption }} - {{ end }}{{ replace (replace .Name ".jpg" "" ) "-" " " | title }}">
13 <img src="{{ $thumbs.RelPermalink }}" alt="{{ replace .Name "-" " " }}">
14 </a>
15 </li>
16 {{ end }}
17 {{ else }}
18 <p>No images for this page.</p>
19 {{- end -}}
20 </ul>
21</div>
22
23
24<script>
25window.addEventListener('load', function() {
26 baguetteBox.run('.gallery');
27});
28
29</script>
So where does this code go in a Hugo site? I put it in a shortcode so I could drop into any page. If you intend to have two or more galleries per page that would require some thought. You could add a parameter to the shortcode that is the class name of your <div>
so you could use the shortcode more than once. But then you need to decide how to split your images up, otherwise done this way you’ll end up with two identical galleries. If you’re sticking with a leaf bundle (images and resources in the same folder as the index.md
page file) you can create subfolders for each gallery and add another parameter to
Options
The various options for Baguette Box go curlies the bottom <script>
tag code:
1baguetteBox.run('.gallery', {
2 // Custom options
3});
Like this:
1<script>
2 window.addEventListener('load', function() {
3 baguetteBox.run('.gallery', {
4 fullScreen: true, // default is false
5 captions: false, // default is true
6 animation: fadeIn, // default is slideIn, false is the other option
7 overlayBackgroundColor: 'rgba(245, 245, 245, .9)' // default is 'rgba(0,0,0,0.8)'
8 });
9 });
10</script>
See the full list of options.