thunderer/Shortcode

View on GitHub
src/Shortcode/ShortcodeInterface.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php
namespace Thunder\Shortcode\Shortcode;

/**
 * @author Tomasz Kowalczyk <tomasz@kowalczyk.cc>
 */
interface ShortcodeInterface
{
    /**
     * Returns new instance of given shortcode with changed content
     *
     * @param string $content
     *
     * @return self
     */
    public function withContent($content);

    /**
     * Returns shortcode name
     *
     * @return string
     */
    public function getName();

    /**
     * Returns associative array(name => value) of shortcode parameters
     *
     * @return array
     * @psalm-return array<string,string|null>
     */
    public function getParameters();

    /**
     * Returns parameter value using its name, will return null for parameter
     * without value
     *
     * @param string $name Parameter name
     * @param string|null $default Value returned if there is no parameter with given name
     *
     * @return string|null
     */
    public function getParameter($name, $default = null);

    /**
     * Returns shortcode content (data between opening and closing tag). Null
     * means that shortcode had no content (was self closing), do not confuse
     * that with empty string (hint: use strict comparison operator ===).
     *
     * @return string|null
     */
    public function getContent();

    /**
     * Returns the so-called "BBCode" fragment when shortcode name is treated
     * like a parameter, eg.: [name="value" /]
     *
     * @return string|null
     */
    public function getBbCode();
}