Pass emojis in remote mastodon posts in mastodon api
This commit is contained in:
parent
e088bb722b
commit
2cb0027f56
3 changed files with 26 additions and 9 deletions
|
@ -1234,7 +1234,7 @@ class BBCode
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Expand Youtube and Vimeo links to
|
* Expand Youtube and Vimeo links to
|
||||||
*
|
*
|
||||||
* @param string $text
|
* @param string $text
|
||||||
* @return string
|
* @return string
|
||||||
|
@ -1387,7 +1387,7 @@ class BBCode
|
||||||
"\n[hr]", "[hr]\n", " [hr]", "[hr] ",
|
"\n[hr]", "[hr]\n", " [hr]", "[hr] ",
|
||||||
"\n[attachment ", " [attachment ", "\n[/attachment]", "[/attachment]\n", " [/attachment]", "[/attachment] ",
|
"\n[attachment ", " [attachment ", "\n[/attachment]", "[/attachment]\n", " [/attachment]", "[/attachment] ",
|
||||||
"[table]\n", "[table] ", " [table]", "\n[/table]", " [/table]", "[/table] ",
|
"[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 = [
|
$replace = [
|
||||||
"[th]", "[th]", "[th]", "[/th]", "[/th]", "[/th]",
|
"[th]", "[th]", "[th]", "[/th]", "[/th]", "[/th]",
|
||||||
|
@ -1480,14 +1480,14 @@ class BBCode
|
||||||
if ($simple_html == self::INTERNAL) {
|
if ($simple_html == self::INTERNAL) {
|
||||||
//Ensure to always start with <h4> if possible
|
//Ensure to always start with <h4> if possible
|
||||||
$heading_count = 0;
|
$heading_count = 0;
|
||||||
for ($level = 6; $level > 0; $level--) {
|
for ($level = 6; $level > 0; $level--) {
|
||||||
if (preg_match("(\[h$level\].*?\[\/h$level\])ism", $text)) {
|
if (preg_match("(\[h$level\].*?\[\/h$level\])ism", $text)) {
|
||||||
$heading_count++;
|
$heading_count++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ($heading_count > 0) {
|
if ($heading_count > 0) {
|
||||||
$heading = min($heading_count + 3, 6);
|
$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)) {
|
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);
|
$text = preg_replace("(\[h$level\](.*?)\[\/h$level\])ism", "</p><h$heading>$1</h$heading><p>", $text);
|
||||||
$heading--;
|
$heading--;
|
||||||
|
@ -1548,7 +1548,11 @@ class BBCode
|
||||||
$text = preg_replace("(\[style=(.*?)\](.*?)\[\/style\])ism", '<span style="$1">$2</span>', $text);
|
$text = preg_replace("(\[style=(.*?)\](.*?)\[\/style\])ism", '<span style="$1">$2</span>', $text);
|
||||||
|
|
||||||
// Mastodon Emoji (internal tag, do not document for users)
|
// 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
|
// Check for CSS classes
|
||||||
// @deprecated since 2021.12, left for backward-compatibility reasons
|
// @deprecated since 2021.12, left for backward-compatibility reasons
|
||||||
|
|
|
@ -34,19 +34,28 @@ class Emoji extends BaseFactory
|
||||||
/**
|
/**
|
||||||
* Creates an emoji collection from shortcode => image mappings.
|
* 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 array $smilies
|
||||||
|
* @param bool $extract_url
|
||||||
*
|
*
|
||||||
* @return Emojis
|
* @return Emojis
|
||||||
*/
|
*/
|
||||||
public function createCollectionFromArray(array $smilies): Emojis
|
public function createCollectionFromArray(array $smilies, bool $extract_url = true): Emojis
|
||||||
{
|
{
|
||||||
$prototype = null;
|
$prototype = null;
|
||||||
|
|
||||||
$emojis = [];
|
$emojis = [];
|
||||||
|
|
||||||
foreach ($smilies as $shortcode => $icon) {
|
foreach ($smilies as $shortcode => $url) {
|
||||||
if (preg_match('/src="(.+?)"/', $icon, $matches)) {
|
if (substr($shortcode, 0, 1) == ':' && substr($shortcode, -1) == ':') {
|
||||||
$url = $matches[1];
|
if ($extract_url) {
|
||||||
|
if (preg_match('/src="(.+?)"/', $url, $matches)) {
|
||||||
|
$url = $matches[1];
|
||||||
|
} else {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
$shortcode = trim($shortcode, ':');
|
$shortcode = trim($shortcode, ':');
|
||||||
|
|
||||||
if ($prototype === null) {
|
if ($prototype === null) {
|
||||||
|
|
|
@ -292,6 +292,10 @@ class Status extends BaseFactory
|
||||||
if (DI::baseUrl()->isLocalUrl($item['uri'])) {
|
if (DI::baseUrl()->isLocalUrl($item['uri'])) {
|
||||||
$used_smilies = Smilies::extractUsedSmilies($item['body'] ?: $item['raw-body']);
|
$used_smilies = Smilies::extractUsedSmilies($item['body'] ?: $item['raw-body']);
|
||||||
$emojis = $this->mstdnEmojiFactory->createCollectionFromArray($used_smilies)->getArrayCopy(true);
|
$emojis = $this->mstdnEmojiFactory->createCollectionFromArray($used_smilies)->getArrayCopy(true);
|
||||||
|
} else {
|
||||||
|
if (preg_match_all("(\[emoji=(.*?)](.*?)\[/emoji])ism", $item['body'] ?: $item['raw-body'], $matches)) {
|
||||||
|
$emojis = $this->mstdnEmojiFactory->createCollectionFromArray(array_combine($matches[2], $matches[1]), false)->getArrayCopy(true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($is_reshare) {
|
if ($is_reshare) {
|
||||||
|
|
Loading…
Reference in a new issue