]> git.mxchange.org Git - friendica.git/commitdiff
Add support for Hubzilla forum mentions (starting with !)
authorHypolite Petovan <hypolite@mrpetovan.com>
Wed, 9 Jan 2019 01:55:36 +0000 (20:55 -0500)
committerHypolite Petovan <hypolite@mrpetovan.com>
Wed, 9 Jan 2019 01:56:01 +0000 (20:56 -0500)
src/Content/Text/BBCode.php
src/Content/Text/Markdown.php

index 6d2b152ee8de490c8013f3364023b2ac63aaeb8a..1ddae09eaca8a451fae36f514f50106b9858f58d 100644 (file)
@@ -1809,6 +1809,9 @@ class BBCode extends BaseObject
         * @brief Callback function to replace a Friendica style mention in a mention for Diaspora
         *
         * @param array $match Matching values for the callback
+        *                     [1] = Mention type (! or @)
+        *                     [2] = Name
+        *                     [3] = Address
         * @return string Replaced mention
         */
        private static function bbCodeMention2DiasporaCallback($match)
@@ -1823,7 +1826,7 @@ class BBCode extends BaseObject
                        return $match[0];
                }
 
-               $mention = '@{' . $match[2] . '; ' . $contact['addr'] . '}';
+               $mention = $match[1] . '{' . $match[2] . '; ' . $contact['addr'] . '}';
                return $mention;
        }
 
@@ -1908,7 +1911,7 @@ class BBCode extends BaseObject
                if ($for_diaspora) {
                        $url_search_string = "^\[\]";
                        $text = preg_replace_callback(
-                               "/([@]\[(.*?)\])\(([$url_search_string]*?)\)/ism",
+                               "/([@!])\[(.*?)\]\(([$url_search_string]*?)\)/ism",
                                ['self', 'bbCodeMention2DiasporaCallback'],
                                $text
                        );
index 2289bee869ee5ca42b885eea7b0defb903ab974d..994d9683349928f9213a25cd49865559684a273e 100644 (file)
@@ -44,27 +44,30 @@ class Markdown extends BaseObject
         * @brief Callback function to replace a Diaspora style mention in a mention for Friendica
         *
         * @param array $match Matching values for the callback
+        *                     [1] = mention type (@ or !)
+        *                     [2] = name (optional)
+        *                     [3] = address
         * @return string Replaced mention
         */
        private static function diasporaMention2BBCodeCallback($match)
        {
-               if ($match[2] == '') {
+               if ($match[3] == '') {
                        return;
                }
 
-               $data = Contact::getDetailsByAddr($match[2]);
+               $data = Contact::getDetailsByAddr($match[3]);
 
                if (empty($data)) {
                        return;
                }
 
-               $name = $match[1];
+               $name = $match[2];
 
                if ($name == '') {
                        $name = $data['name'];
                }
 
-               return '@[url=' . $data['url'] . ']' . $name . '[/url]';
+               return $match[1] . '[url=' . $data['url'] . ']' . $name . '[/url]';
        }
 
        /*
@@ -93,7 +96,7 @@ class Markdown extends BaseObject
 
                $s = self::convert($s);
 
-               $regexp = "/@\{(?:([^\}]+?); )?([^\} ]+)\}/";
+               $regexp = "/([@!])\{(?:([^\}]+?); ?)?([^\} ]+)\}/";
                $s = preg_replace_callback($regexp, ['self', 'diasporaMention2BBCodeCallback'], $s);
 
                $s = str_replace('&#35;', '#', $s);