hazbo / simpletags
SimpleTags Library for parsing {various tags}
Installs: 22
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 1
pkg:composer/hazbo/simpletags
Requires
- php: >=5.3.0
This package is not auto-updated.
Last update: 2025-10-25 20:31:33 UTC
README
Description
Simpletags is exactly what it sounds like... a simple way to use tags in your PHP application. This allows you to have tags that look like this:
{something:other}
{date format="m/d/Y"}
{blog:entries count="5"}
Stuff here
{/blog:entries}
Installation
Add hazbo/simpletags to your composer.json file
{
    "require" : {
        "hazbo/simpletags"
    }
}
composer update
Usage
You can send a config array to the constructor with the following options (these are the defaults):
array( 'l_delim' => '{', 'r_delim' => '{', 'trigger' => '', );
You can also set the delimiters and triggers via the following functions:
$simpletags = new SimpleTag(); $simpletags->setDelimitiers('{', '}'); $simpletags->setTrigger('foo:');
To parse a string of text you simply call the parse() function. The parse function accepts 3 parameters:
- $content - The content to parse
- [optional] $data - a keyed array of data to replace tag vars with (more below)
- [optional] $callback - A callback that will be called for each tag.
Normal Return
If no callback is specified then the function will return an array. Consider this is the content you sent:
Hello there.
{rest:get url="http://example.com/api" type="json"}
Stuff here
{/rest:get}
Bye.
Parse would return this:
Array
(
    [content] => Hello there.
marker_0k0dj3j4nJHDj22j
Bye.
    [tags] => Array
        (
            [0] => Array
                (
                    [full_tag] => {rest:get url="http://example.com/api" type="json"}
Stuff here
{/rest:get}
                    [attributes] => Array
                        (
                            [url] => http://example.com/api
                            [type] => json
                        )
                    [segments] => Array
                        (
                            [0] => rest
                            [1] => get
                        )
                    [content] => 
Stuff here
                    [marker] => marker_0k0dj3j4nJHDj22j
                )
        )
)
Using the Data Array
The data array is a keyed array who's contents will replace tags with the same name. Example:
{foo:bar}
Would be replaced with "Hello World" when the following data array is sent to the parse function:
$data['foo']['bar'] = "Hello World"
You can use tag pairs to loop through data as well:
Tag:
{books}
{title} by {author}<br />
{/books}
Data
$data = array( 'books' => array( array( 'title' => 'PHP for Dummies', 'author' => 'John Doe' ), array( 'title' => 'CodeIgniter for Dummies', 'author' => 'Jane Doe' ) ) );
Resulting Output
PHP for Dummies by John Doe
CodeIgniter for Dummies by Jane Doe
Callbacks
The callback must be in a form that is_callable() accepts (typically array(object, method)). The callbac function should take 1 parameter (an array).
The callback will be sent the tag information in the form of an array. Consider the following
{rest:get url="http://example.com/api" type="json"}
Stuff here
{/rest:get}
Would send the callback function the following array:
Array
(
    [full_tag] => {rest:get url="http://example.com/api" type="json"}
Stuff here
{/rest:get}
    [attributes] => Array
        (
            [url] => http://example.com/api
            [type] => json
        )
    [segments] => Array
        (
            [0] => rest
            [1] => get
        )
    [content] => 
Stuff here
    [marker] => marker_0k0dj3j4nJHDj22j
)