samwilson/commonmark-shortcodes 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

samwilson/commonmark-shortcodes

最新稳定版本:0.6.1

Composer 安装命令:

composer require samwilson/commonmark-shortcodes

包简介

Adds shortcodes to Markdown, for the CommonMark package.

README 文档

README

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/

统计信息

  • 总下载量: 1.59k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 3
  • 点击次数: 1
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 3
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: gpl-3.0-or-later
  • 更新时间: 2023-04-16