Skip to main content

Automatic photo album generation and thumbnailing for Pelican.

Project description

Pelican-Albums

Pelican-Albums is a plugin for Pelican that helps you to easily manage your photo albums (or galleries).

Features

  • Easily reference an image in your album path using {image}album/image.jpg.

  • Automatically create a thumbnail for an image in your album path using {thumbnail}album/image.jpg or {thumbnail:NxN@Q}album/image.jpg.

  • Automatically create album pages by adding a page to an album directory.

Installation

To install pelican-albums to your pelican installation use:

$ pip install pelican-albums

Then, add ‘pelican_albums’ to the plugin list in your publishconf.py:

PLUGINS = ['pelican_albums']

Settings

Pelican-albums provides a couple of settings:

  • ALBUM_PATH (images): What directory inside content contains your albums.

  • THUMBNAIL_OUTPUT_PATH (images/thumbnails): What directory inside the output directory will be used to store thumbnails.

  • THUMBNAIL_OUTPUT_FORMAT (JPEG): As what format the thumbnails should be created (JPEG or PNG).

  • THUMBNAIL_DEFAULT_SIZE (192x192): What the default size of a thumbnail should be.

  • THUMBNAIL_DEFAULT_QUALITY (80): What the default quality of a JPEG thumbnail should be.

  • ALBUM_SAVE_AS (albums/{slug}.html): Where to store album indexes.

  • ALBUM_URL (albums/{slug}.html): The URL scheme to reference an album.

Albums

To create a new album, just create a new directory in the ALBUM_PATH (the default is content/images) and place the images inside it. Please note that pelican-albums does not offer facilities to rotate or resize the images for you (except for creating thumbnails) at this moment.

Thumbnails

Pelican-albums will automatically generate the requested thumbnails at the requested sizes. It will check the mtime of the original file to that of the thumbnail to check if the thumbnail should be refreshed.

You can specify the size and quality of a thumbnail on different places:

  • Inside the {thumbnail} tag: {thumbnail:128x128@80}album/image.jpg

  • In the metadata of the content: Thumbnail-Size: 128x128@80

  • As a parameter to the album.thumbnail(spec=None) in your templates.

  • In the global pelican settings.

A thumbnail size specifier can have a number of different forms:

  • WIDTHxHEIGHT – Crop and resize an image until a thumbnail of these exact dimensions is the result (f.e. 192x192).

  • DIMENSION – Shorthand for DIMENSIONxDIMENSION (f.e. 192).

  • WIDTHx – Create a thumbnail with the given width but keep the original aspect ratio so the height might vary (f.e. 192x).

  • xHEIGHT – Create a thumbnail with the given height but keep the original aspect ratio so the width might vary (f.e. x192).

You can optionally add an @nn suffix to the size to indicate the thumbnail quality that should be used (f.e. 192@80 for a 192x192 thumbnail at 80% quality). This specifies the JPEG file quality and does not apply to PNG thumbnails.

Album pages

By creating a page inside an album folder, a page will be generated using the album.html template. Both the album and the page will be available inside the template. The page object works exactly as the regular pelican page objects.

The album object has several properties:

  • images – The images contained in this album.

  • albums – A list of sub-albums (if any).

  • pages – The album pages for this album (you can create multiple pages for each album if you want).

The image objects returned by album.images have the following properties:

  • album – The album this image belongs to.

  • filename – The filename of this image.

  • url – The URL of this image relative to the site URL.

  • thumbnail(spec=None) – A method that returns the URL of a thumbnail of the given (or default) size and quality relative to the site URL.

album.html

An example template for album pages (save this as album.html inside your templates directory):

{% extends "base.html" %}
{% block title %}{{ page.title }}{%endblock%}
{% block content %}
<article class="page">
    <header>
        <div class="title">
            {{ page.title }}
        </div>
    </header>

    <div class="entry-content">
        {{ page.content }}
    </div>

    <div class="album">
        {% for image in album.images %}
            <a href="{{ SITEURL }}/{{ image.url }}">
                <img src="{{ SITEURL }}/{{ image.thumbnail(page.metadata.get('thumbnail-size')) }}"
                     title="{{ image.filename }}" />
            </a>
        {% endfor %}
    </div>
</article>
{% endblock %}

Release history

0.6.1 (2019-02-23)

  • Add support for pelican 4.0.0.

0.6.0 (2015-04-28)

  • Allow using PNG files as thumbnails instead of JPEG.

  • Allow specifying the thumbnail quality.

  • Increase default quality to 80%.

0.5.1 (2015-04-13)

  • Automatically exclude the album path from the article and page generators.

  • Documentation improvements.

0.5.0 (2015-04-12)

  • Initial release.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pelican-albums-0.6.1.tar.gz (6.4 kB view details)

Uploaded Source

Built Distribution

pelican_albums-0.6.1-py3-none-any.whl (7.2 kB view details)

Uploaded Python 3

File details

Details for the file pelican-albums-0.6.1.tar.gz.

File metadata

  • Download URL: pelican-albums-0.6.1.tar.gz
  • Upload date:
  • Size: 6.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.2

File hashes

Hashes for pelican-albums-0.6.1.tar.gz
Algorithm Hash digest
SHA256 3c8fb3bfb587221d8a99744b58a794940d87c8e56d02e8aa608eba7b09a02451
MD5 4c803cd042f3f0a7b7e2cd922589069f
BLAKE2b-256 bc319aef64a7aa22a625a268426c061c8bc016f7f3fdbb187579e6056f3f8817

See more details on using hashes here.

File details

Details for the file pelican_albums-0.6.1-py3-none-any.whl.

File metadata

  • Download URL: pelican_albums-0.6.1-py3-none-any.whl
  • Upload date:
  • Size: 7.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.2

File hashes

Hashes for pelican_albums-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 372065129b86a8d100ecd5b6276ca330d8b859f0c37a983da9d8cf0134a82de5
MD5 5b2e75dcf178cd67b1160e18b0b0e3a3
BLAKE2b-256 8a8720e4345626bff85146bdea41af7cfecdf8e4007c5bf721f01025f3838331

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page