artygrand / shortcode
Really simple shortcode parser without regex
v1.0.0
2017-02-12 13:18 UTC
Requires
- php: >=5.3.0
This package is not auto-updated.
Last update: 2025-01-04 20:04:16 UTC
README
Really simple shortcode parser without regex
- without regex
- nested shortcodes with unlimited level
- with aliases
- with the ability to show shortcode instead of compile it
- with predefined arguments
Install
To install with composer:
composer require artygrand/shortcode
Requires PHP 5.3 or newer.
Usage
Here's a basic usage example:
<?php require __DIR__.'/vendor/autoload.php'; // or // include 'path/to/Shortcode.php'; $sample = ' [shortcode] [short argument="value"] [shortcode active other="complex value"] [short]content[/short] [shortcode argument="value"]content[/shortcode] [span6] [span6] [span6 ]Lorem[/span6] [span4] [/span6] [span4] [span6 class="first" ]dolor[/span6] [col6 class="last" ]cudere[/col6] [/span4] [/span6] [span6] @[span6] [span6]Lorem[/span6] [/span6] [/span6] '; $sc = artygrand\Shortcode::getInstance(); $sc ->add('shortcode', 'func_shortcode') ->withAlias('short') ->add('span4', array( 'grid', array('cols' => 4) )) ->add('span6', array( 'grid', array('cols' => 6) )) ->withAlias('col6'); echo $sc->compile($sample); // functions function func_shortcode($args, $content = null){ if (is_null($content)){ return print_r($args, true); } $args['content'] = $content; return print_r($args, true); } function grid($args, $content = null){ $args = array_merge(array( 'cols' => 1, 'class' => '', ), $args); $class = $args['class'] ? ' class="' . $args['class'] . '"' : ''; if (is_null($content)){ return '<div style="width:' . ($args['cols']/0.12) .'%;"' . $class . '>NoContent</div>'; } return '<div style="width:' . ($args['cols']/0.12) .'%;"' . $class . '>' . $content . '</div>'; }
End result will be like
Array
(
)
Array
(
[argument] => value
)
Array
(
[active] => 1
[other] => complex value
)
Array
(
[content] => content
)
Array
(
[argument] => value
[content] => content
)
<div style="width:50%;">
<div style="width:50%;">
<div style="width:50%;">Lorem</div>
<div style="width:33.333333333333%;">NoContent</div>
</div>
<div style="width:33.333333333333%;">
<div style="width:50%;" class="first">dolor</div>
<div style="width:50%;" class="last">cudere</div>
</div>
</div>
<div style="width:50%;">
[span6]
<div style="width:50%;">Lorem</div>
[/span6]
</div>
License
Released under the MIT license.