Skip to content

samwilson/commonmark-shortcodes

Repository files navigation

Samwilson/CommonMarkShortcodes

An extension to League/CommonMark for adding 'shortcodes' to Markdown.

Packagist Version Packagist License GitHub Workflow Status

Shortcodes are bits of text in a Markdown document that are delimited with one or three braces and are replaced with whatever content is needed. There are two types of shortcode, inline and block (the same name cannot be used for both an inline and block shortcode; i.e. you must decide when designing the shortcodes how each is to be used).

Inline shortcodes have one brace, {name|attr=val}, and appear within a paragraph or list item etc. For example, here cite is the name of the shortcode and it's got one attribute:

There are over 300 distinct breeds{cite|Kris2008} of goat.

Block shortcodes have three braces, {{{name|attr=val}}}, and an optional body; their attributes are the same as for inline shortcodes. Here quotation is the shortcode, it's got one attribute, and a two-line body:

{{{quotation|source=Q2934
The goat is a member of the animal family Bovidae and the tribe Caprini,
meaning it is closely related to the sheep.
}}}

Shortcodes can have zero or more attributes. Attributes are separated by pipes | and can be given a name by adding the equals sign (without a name, they're numbered from 1).

When compiled, the shortcodes are replaced by the HTML (or other content) that is specified in the shortcode handlers. See #Usage below for more information about how to set up the CommonMark environment.

Installation

Install with Composer:

$ composer require samwilson/commonmark-shortcodes

Usage

Set up your CommonMark Environment object with a shortcodes configuration key:

$environment = new Environment([
    'shortcodes' => [
        'shortcodes' => [
            'myshortcode' => /* callback one */
            'myshortcode2' => /* callback two */
        ],
    ],
]);
$environment->addExtension(new CommonMarkCoreExtension());

Then add the ShortcodeExtension, and start converting Markdown:

$environment->addExtension(new ShortcodeExtension());
$converter = new MarkdownConverter($environment);
echo $converter->convert('Markdown *goes here*.')->getContent();

The callbacks are where you define your shortcodes' output. Each takes a single parameter (a Shortcode object) and returns a string that will be inserted into the output in place of the shortcode.

For example, Markdown like this:

Lorem {smallcaps|ipsum}.

could be paired with the following shortcode configuration:

[
    'smallcaps' => function (Shortcode $shortcode) {
        return '<span style="font-variant:small-caps">'
            . $shortcode->getAttr(1)
            . '</span>';
    },
]

to produce this output:

<p>Lorem <span style="font-variant:small-caps">ipsum</span></p>

See the examples/ directory for functioning examples, and if you have any issues please do report them.

License

Copyright © 2023 Sam Wilson https://samwilson.id.au/

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see https://www.gnu.org/licenses/