This plugin introduces shortcodes to be used as simple snippets inside a document to be rendered by Grav.
Shortcodes is a plugin for Grav used to extend Markdown's ability to do nifty things with very little effort.
Shortcodes are shortcuts. Using a simple content format shortcodes can embed files or create objects that would normally require lots of complicated, ugly code in just one line.
Installing or updating the Shortcodes plugin can be done in one of two ways. Using the GPM (Grav Package Manager) installation update method or (i.e. bin/gpm install shortcodes) manual install by downloading this plugin and extracting all plugin files to
user/plugins/shortcodes
For more informations, please check the Installation and update guide.
The Shortcodes plugin comes with some sensible default configuration, that are pretty self explanatory:
# Global plugin configurations
enabled: true               # Set to false to disable this plugin completely
# Default configurations for special shortcodes
shortcodes:
  assets:
    enabled: true
    options:
      type: "css"           # Assets type (either "css" or "js")
      inline: false         # Include assets as block or inline argument
      priority: 10          # Priority to add CSS or JS to Grav pipeline, bigger comes first
      pipeline: false       # Pipeline assets or not
      load: ""              # Load asset either asynchronously "async" or deferred "defer"
  comment:
    enabled: true
  embed:
    enabled: true
    options:
      template: ""          # Default template to render a page
  markdown:
    enabled: true
    options:
      extra: true           # Enable support for Markdown Extra
  summary:
    enabled: true
   twig:
    enabled: trueIf you need to change any value, then the best process is to copy the shortcodes.yaml file into your users/config/plugins/ folder (create it if it doesn't exist), and then modify there. This will override the default settings.
If you want to alter the settings for one or a few pages only, you can do so by adding page specific configurations into your page headers, e.g.
shortcodes: falseto disable the Shortcodes plugin just for this page.
In your content files, a shortcode can be called by using {{% myshortcode %}}
respectively. Shortcodes are space delimited (parameters with spaces can be quoted).
The first word is always the name of the shortcode. Parameters follow the name.The format for named parameters models that of HTML with the format name="value".
Some shortcodes use or require closing shortcodes. Closing shortcodes either match the name of the shortcode with prepended end like {{% endmyshortcode %}} or just {{% end %}} e.g.,
{{% summary %}}
  My summary
{{% end %}}
Shortcodes can be nested and may require parameters to work. Parameters to shortcodes can either be passed in two ways
{{% myshortcode param1 name="value" %}}
OR
{{% myshortcode(param1, name="value") %}}
Sometimes you may want to print the shortcode without processing it. To archive this you have two options. Either you disable the Shortcodes plugin per page using shortcodes: false or enclose the (whole) shortcode with the special {{% raw %}}...{{% endraw %}} shortcode like this:
{{% raw %}}
  {{% My ignored tag %}}
{{% endraw %}}
You can further comment out blocks of text or code using the {# ... #} tag as already known from Twig.
Shortcodes provides a Twig function to render shortcodes for any text. To use it, place the following line of code in the theme file:
{{ shortcodes("A text and shortcodes") }}The Shortcodes plugin offers some of the shortcodes by default and plugins can add their own as well via the Shortcode API. The already supported shortcodes are listed in the following:
- {{% assets %}}adds CSS and JS assets directly to the site. » Full instructions
- {{% embed %}}embeds a page or the contents of a page. » Full instructions
- {{% markdown %}}is a shortcut to parse texts using Markdown syntax in a document. » Full instructions
- {{% twig %}}renders custom texts using the Twig templating engine. » Full instructions
- {{% comment %}}allows you to use comments and annotations in a Markdown document without being outputted to the user. » Full instructions
- {{% raw %}}marks sections as being raw text that should not be parsed. » Full instructions
- {{% summary %}}sets the summary of page. » Full instructions
Useful shortcodes for adding a blog archive index, contact form, polls, and more.
The Shortcodes plugin offers developers to register their own shortcodes (here: myblockshortcode and myinlineshortcode). To do this Shortcodes provides an event onShortcodesInitialized, which could be used to register new shortcodes via the provided Grav\Plugin\Shortcodes\Shortcodes::register method. For example in your custom plugin use
namespace Grav\Plugin;
use Grav\Plugin\Shortcodes;
class MyPlugin extends Plugin
{
  public static function getSubscribedEvents()
  {
    return [
      'onShortcodesInitialized' => ['onShortcodesInitialized', 0]
    ];
  }
  public function onShortcodesInitialized(Event $event)
  {
    // Initialize custom shortcode
    $shortcode = new MyShortcodes();
    // Create block shortcode
    $block = new Shortcodes\BlockShortcode('myblockshortcode', [$shortcode, 'block']);
    // Create inline shortcode
    $inline = new Shortcodes\InlineShortcode('myinlineshortcode', [$shortcode, 'inline']);
    // Register shortcodes
    $event['shortcodes']->register($block);
    $event['shortcodes']->register($inline);
    // Or register shortcodes from class (calls getShortcodes internally)
    $event['shortcodes']->register($shortcode);
  }
}The MyShortcodes class has basically the format
namespace Grav\Plugin;
use Grav\Plugin\Shortcodes;
use RocketTheme\Toolbox\Event\Event;
class MyShortcodes
{
  public function getShortcodes()
  {
    $options = [];
    return [
      new Shortcodes\BlockShortcode('myblockshortcode', [$this, 'block'], $options).
      new Shortcodes\InlineShortcode('myinlineshortcode', [$this, 'inline'], $options)
    ];
  }
  public function block(Event $event)
  {
    // do something and return string
  }
  public function inline(Event $event)
  {
    // do something and return string
  }
}where myblockshortcode and myinlineshortcode are placeholders for your block and inline shortcode names respectively. When {{% myblockshortcode %}}...{{% end %}} is found in the text the method block is called and inline when {{% myinlineshortcode %}} is found. The event argument is an array of
- the body text ("body")
- the options passed to the shortcode ("options")
- the grav instance ("grav")
- the shortcodes instance ("shortcodes")
- the current page ("page")
which can be used in your custom functions.
For further examples, please study the already available shortcodes in the provided shortcodes classes.
You can contribute at any time! Before opening any issue, please search for existing issues and review the guidelines for contributing.
After that please note:
- If you find a bug, would like to make a feature request or suggest an improvement, please open a new issue. If you have any interesting ideas for additions to the syntax please do suggest them as well!
- Feature requests are more likely to get attention if you include a clearly described use case.
- If you wish to submit a pull request, please make again sure that your request match the guidelines for contributing and that you keep track of adding unit tests for any new or changed functionality.
If you like my project, feel free to support me via 
Thanks!
Copyright (c) 2015 Benjamin Regler. See also the list of contributors who participated in this project.
Dual-licensed for use under the terms of the MIT or GPLv3 licenses.



