}
/**
- * Expand Youtube and Vimeo links to
+ * Expand Youtube and Vimeo links to
*
* @param string $text
* @return string
"\n[hr]", "[hr]\n", " [hr]", "[hr] ",
"\n[attachment ", " [attachment ", "\n[/attachment]", "[/attachment]\n", " [/attachment]", "[/attachment] ",
"[table]\n", "[table] ", " [table]", "\n[/table]", " [/table]", "[/table] ",
- " \n", "\t\n", "[/li]\n", "\n[li]", "\n[*]",
+ " \n", "\t\n", "[/li]\n", "\n[li]", "\n[*]",
];
$replace = [
"[th]", "[th]", "[th]", "[/th]", "[/th]", "[/th]",
if ($simple_html == self::INTERNAL) {
//Ensure to always start with <h4> if possible
$heading_count = 0;
- for ($level = 6; $level > 0; $level--) {
+ for ($level = 6; $level > 0; $level--) {
if (preg_match("(\[h$level\].*?\[\/h$level\])ism", $text)) {
$heading_count++;
}
}
if ($heading_count > 0) {
$heading = min($heading_count + 3, 6);
- for ($level = 6; $level > 0; $level--) {
+ for ($level = 6; $level > 0; $level--) {
if (preg_match("(\[h$level\].*?\[\/h$level\])ism", $text)) {
$text = preg_replace("(\[h$level\](.*?)\[\/h$level\])ism", "</p><h$heading>$1</h$heading><p>", $text);
$heading--;
$text = preg_replace("(\[style=(.*?)\](.*?)\[\/style\])ism", '<span style="$1">$2</span>', $text);
// Mastodon Emoji (internal tag, do not document for users)
- $text = preg_replace("(\[emoji=(.*?)](.*?)\[/emoji])ism", '<span class="mastodon emoji"><img src="$1" alt="$2" title="$2"/></span>', $text);
+ if ($simple_html == self::MASTODON_API) {
+ $text = preg_replace("(\[emoji=(.*?)](.*?)\[/emoji])ism", '$2', $text);
+ } else {
+ $text = preg_replace("(\[emoji=(.*?)](.*?)\[/emoji])ism", '<span class="mastodon emoji"><img src="$1" alt="$2" title="$2"/></span>', $text);
+ }
// Check for CSS classes
// @deprecated since 2021.12, left for backward-compatibility reasons
/**
* Creates an emoji collection from shortcode => image mappings.
*
+ * Only emojis with shortcodes of the form of ':shortcode:' are passed in the collection.
+ *
* @param array $smilies
+ * @param bool $extract_url
*
* @return Emojis
*/
- public function createCollectionFromArray(array $smilies): Emojis
+ public function createCollectionFromArray(array $smilies, bool $extract_url = true): Emojis
{
$prototype = null;
$emojis = [];
- foreach ($smilies as $shortcode => $icon) {
- if (preg_match('/src="(.+?)"/', $icon, $matches)) {
- $url = $matches[1];
+ foreach ($smilies as $shortcode => $url) {
+ if (substr($shortcode, 0, 1) == ':' && substr($shortcode, -1) == ':') {
+ if ($extract_url) {
+ if (preg_match('/src="(.+?)"/', $url, $matches)) {
+ $url = $matches[1];
+ } else {
+ continue;
+ }
+ }
$shortcode = trim($shortcode, ':');
if ($prototype === null) {