Skip to main content

Series is a Pelican plugin that joins multiple posts into a series

Project description

Series: A Plugin for Pelican

Build Status PyPI Version License

Series is a Pelican plugin that joins multiple posts into a series. Globally, it provides a list of all the series, and for each article it provides a list of all articles in the same series and links to the next and previous articles in the series.

Installation

This plugin can be installed via:

python -m pip install pelican-series

As long as you have not explicitly added a PLUGINS setting to your Pelican settings file, then the newly-installed plugin should be automatically detected and enabled. Otherwise, you must add series to your existing PLUGINS list. For more information, please see the How to Use Plugins documentation.

Usage

In order to mark reStructuredText-formatted posts as part of a series, use the :series: metadata:

:series:  NAME_OF_THIS_SERIES

Or, for Markdown-formatted content:

Series: NAME_OF_THIS_SERIES

The plugin collects all articles or pages belonging to the same series and provides series-related variables that you can use in your template.

Articles and pages

This plugin works both with articles and pages. As Pelican uses the specific variable article for article templates and page for page templates it is complicated to give examples that work for both cases. In the following documentation all example will mention article. (e.g. article.series, article.title) but the code works in the same way with page (e.g. page.series, page.title).

Article series and page series are created separately, so even if an article and a page have the same series they won't appear together.

Indexing

By default, articles in a series are ordered by date and then automatically numbered. Pages in a series are ordered by title and automatically numbered.

If you want to force a given order, specify :series_index: (reST) or series_index: (Markdown) in the article metadata, starting from 1. All articles with this enforced index are put at the beginning of the series and ordered according to the index itself. All the remaining articles come after them, ordered with the default ordering (date for articles and title for pages).

The plugin provides the following variables to your templates:

  • article.series.name is the name of the series as specified in the article metadata
  • article.series.index is the index of the current article inside the series
  • article.series.all is an ordered list of all articles in the series (including the current one)
  • article.series.all_previous is an ordered list of the articles published before the current one
  • article.series.all_next is an ordered list of the articles published after the current one
  • article.series.previous is the previous article in the series (a shortcut to article.series.all_previous[-1]) or None for the first article
  • article.series.next is the next article in the series (a shortcut to article.series.all_next[0]) or None for the last one

For example:

{% if article.series %}
    <p>This post is part {{ article.series.index }} of the "{{ article.series.name }}" series:</p>
    <ol class="parts">
        {% for part_article in article.series.all %}
            <li {% if part_article == article %}class="active"{% endif %}>
                <a href='{{ SITEURL }}/{{ part_article.url }}'>{{ part_article.title }}</a>
            </li>
        {% endfor %}
    </ol>
{% endif %}

Global Context

Warning: in version 3 the global key series has been renamed to article_series to differentiate it from the new global key page_series.

The plugin also adds the keys article_series and page_series to the global context. They are dictionaries of all series names (as keys) and items (as values). You can use that to list all the series in your site, for example

{% for series_name, series_articles in series.items() %}
{% set article = series_articles[0] %}
<article class="card">
	<a href="{{ article.url }}" class="image">
		<img src="/images/{{ article.image }}.jpg" alt="{{ article.image }}" />
	</a>
	<div class="card-body">
    	<a href="{{ article.url }}"><h3 class="card-title">{{ series_name }}</h3></a>
     	<ul class="actions">
     		<li><a href="{{ article.url }}" class="button">Start</a></li>
     	</ul>
	</div>
</article>
{% endfor %}

As it is not possible to create pages from plugins you can leverage it to create a page for a specific series, even though you have to hard code the name of the series in the template.

Contributing

Contributions are welcome and much appreciated. Every little bit helps. You can contribute by improving the documentation, adding missing features, and fixing bugs. You can also help out by reviewing and commenting on existing issues.

To start contributing to this plugin, review the Contributing to Pelican documentation, beginning with the Contributing Code section.

License

This project is licensed under the AGPL 3.0 license.

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_series-3.0.0.tar.gz (8.2 kB view details)

Uploaded Source

Built Distribution

pelican_series-3.0.0-py3-none-any.whl (10.8 kB view details)

Uploaded Python 3

File details

Details for the file pelican_series-3.0.0.tar.gz.

File metadata

  • Download URL: pelican_series-3.0.0.tar.gz
  • Upload date:
  • Size: 8.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.9.19 Linux/6.5.0-1018-azure

File hashes

Hashes for pelican_series-3.0.0.tar.gz
Algorithm Hash digest
SHA256 e44ced55b8f1459b02392a55c77f19d3e449f75cf120d5b1de6705819781e3f3
MD5 d51e2484050c5d56e2d263fde5cee746
BLAKE2b-256 4413bc65ef34fbb921a8a0c56f4fc77b33fd0ebf1e8e989ef2fa24ce42e9453b

See more details on using hashes here.

File details

Details for the file pelican_series-3.0.0-py3-none-any.whl.

File metadata

  • Download URL: pelican_series-3.0.0-py3-none-any.whl
  • Upload date:
  • Size: 10.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.9.19 Linux/6.5.0-1018-azure

File hashes

Hashes for pelican_series-3.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 dc6cd93690afeb5336d867e702070396ca0a465fba1976083281e01a346ed882
MD5 dbd08e62fcc6b8082b4dd57013fb5581
BLAKE2b-256 73d107daf1c643cc090f15641e8160bd7e5a8687cb6f71b121f789069829b154

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