Skip to content

A jekyll plugin to build a progressive image gallery using pig.js

License

Notifications You must be signed in to change notification settings

clnhlzmn/jekyll-pig

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

jekyll-pig

This is a plugin that makes it easy to include progressive image galleries in your Jekyll site. Jekyll-pig is made possible with minimagick and pig.js.

How to use

1. install ImageMagick

2. add - jekyll-pig to the plugins list in your site's _config.yml

3. install jekyll-pig

Either add gem jekyll-pig to your site's Gemfile and run bundle install or run gem install jekyll-pig

4. add a section called galleries to your site's _config.yml

It should look like this:

galleries:
    -
        path: <path relative to site root>
        name: <gallery-name>
    -
        <another gallery>

These lines tell jekyll-pig where to find your images and how to organize the generated output. <gallery-name> shouldn't have any spaces.

5. add images to your gallery folders

6. add gallery folder paths to exclude list in _config.yml and to your .gitignore

use {% include <gallery-name>.html %} in your pages and posts to include a the gallery identified by gallery-name

7. run jekyll build

What happens

jekyll-pig generates a bunch of content

<site root>
├── _data
│   ├── <gallery-name>.json             #data for a specific gallery (one for each gallery)
│   └── ...
├── _includes
│   ├── <gallery-name>.html             #gallery include file (one for each gallery)
│   └── ...
├── assets
│   ├── html
│   │   ├── <gallery-name>
│   │   │   └── <filename>.html         #an html page using layout: page for each image
│   │   └── ...
│   ├── img
│   │   ├── <gallery-name>
│   │   │   ├── 20
│   │   │   │   ├── <filename>.<ext>    #each image resized into various size thumbnails
│   │   │   │   └── ...
│   │   │   ├── 100
│   │   │   │   └── ...
│   │   │   ├── 250
│   │   │   │   └── ...
│   │   │   ├── 500
│   │   │   │   └── ...
│   │   │   └── 1024
│   │   │       └── ...
│   │   └── ...
│   ├── js
│   │   ├── pig.min.js                  #js required for the gallery
│   │   └── ...
│   └── ...
└── ...

What you will see

Wherever you {% include <gallery-name>.html %} you will see a progressive image gallery.

Check out mine.

Notes

Each image in a gallery is linked to generated page for that image. The default jekyll theme lists all pages at the top of every page. To keep all your image pages from cluttering your page listing the generate pages include exclude: true front matter. You can modify your header.html include file like this:

{%- if my_page.title and my_page.exclude != true -%}
<a class="page-link" href="{{ my_page.url | relative_url }}">{{ my_page.title | escape }}</a>
{%- endif -%}

The above just prevents the page link from appearing if my_page.exclude is true.

About

A jekyll plugin to build a progressive image gallery using pig.js

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages