Skip to main content

Allows the setting of the class attribute of `<a>` elements according to whether the link is external or internal to the Pelican-generated site.

Project description

travis_build_status

Link Class for Pelican

Description

This plugin allows the setting of the class attribute of <a> elements (generated in Markdown by [ext](link)) according to whether the link is external (i.e. starts with http:// or https://) or internal to the Pelican-generated site.

For now, this plugin only works with Markdown. It was tested with version 3.0.1 of the Python Markdown module. It may not work with previous versions.

Usage

User Settings

In order to avoid clashes with already-defined classes in the user CSS style sheets, it is possible to specify the name of the classes that will be used. They can be specified in the Pelican setting files with the LINKCLASS variable, which must be defined as a list of tuples, like this:

'LINKCLASS' = (('EXTERNAL_CLASS', 'name-of-the-class-for-external-links')
                'INTERNAL_CLASS', 'name-of-the-class-for-internal-links'))

The default values for EXTERNAL_CLASS and INTERNAL_CLASS are, respectively, 'external' and 'internal'.

Styling the hyperlinks

One of the possible uses of this plugins is for styling. Suppose that we have the following in your article written with Markdown:

This is an [internal](internal) link and this is an
[external](http://external.com) link.

If the default values of the configuration variables are used, then a possible CSS setting would be:

a.external:before {
    content: url('../images/external-link.png');
    margin-right: 0.2em;
}

(The file external-link.png is also distributed with this plugin. Just copy it to the appropriate place in your website source tree, for instance in theme/static/images/.)

Then, the result will look like the following:

figure

Note that this plugin also works with reference-style links, as in the following example:

This is an [internal][internal] link and this is an
[external][external] link.

 [internal]: internal
 [external]: http://external.com

Acknowledgments

Many thanks to Yuliya Bagriy for setting up the package for PyPI and Lucas Cimon for fixing the issues with pytest and the smooth integration into the Pelican repository as a sub-module.

Author

Copyright (C) 2015, 2017, 2019 Rafael Laboissiere (rafael@laboissiere.net)

Released under the GNU Affero Public License, version 3 or later. No warranties.

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-linkclass-1.0.0.tar.gz (5.6 kB view hashes)

Uploaded Source

Built Distribution

pelican_linkclass-1.0.0-py3-none-any.whl (19.4 kB view hashes)

Uploaded Python 3

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