mirror of
https://github.com/friendica/friendica
synced 2025-01-03 19:22:18 +00:00
Merge pull request #14322 from annando/link-length
Configurable maximum link length
This commit is contained in:
commit
4f928b6fae
3 changed files with 21 additions and 10 deletions
|
@ -2090,7 +2090,7 @@ class BBCode
|
||||||
$text = preg_replace("/\[zrl\=(.*?)\](.*?)\[\/zrl\]/ism", '[url=$1]$2[/url]', $text);
|
$text = preg_replace("/\[zrl\=(.*?)\](.*?)\[\/zrl\]/ism", '[url=$1]$2[/url]', $text);
|
||||||
|
|
||||||
if (in_array($simple_html, [self::INTERNAL, self::EXTERNAL, self::DIASPORA, self::OSTATUS, self::MASTODON_API, self::TWITTER_API, self::ACTIVITYPUB])) {
|
if (in_array($simple_html, [self::INTERNAL, self::EXTERNAL, self::DIASPORA, self::OSTATUS, self::MASTODON_API, self::TWITTER_API, self::ACTIVITYPUB])) {
|
||||||
$text = self::shortenLinkDescription($text);
|
$text = self::shortenLinkDescription($text, $simple_html);
|
||||||
} else {
|
} else {
|
||||||
$text = self::unifyLinks($text);
|
$text = self::unifyLinks($text);
|
||||||
}
|
}
|
||||||
|
@ -2143,20 +2143,26 @@ class BBCode
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function shortenLinkDescription(string $text): string
|
private static function shortenLinkDescription(string $text, int $simple_html): string
|
||||||
{
|
{
|
||||||
|
if ($simple_html == self::INTERNAL) {
|
||||||
|
$max_length = DI::config()->get('system', 'display_link_length');
|
||||||
|
} else {
|
||||||
|
$max_length = 30;
|
||||||
|
}
|
||||||
|
|
||||||
$text = preg_replace_callback(
|
$text = preg_replace_callback(
|
||||||
"/\[url\](.*?)\[\/url\]/ism",
|
"/\[url\](.*?)\[\/url\]/ism",
|
||||||
function ($match) {
|
function ($match) use ($max_length) {
|
||||||
return "[url=" . self::escapeUrl($match[1]) . "]" . Strings::getStyledURL($match[1]) . "[/url]";
|
return "[url=" . self::escapeUrl($match[1]) . "]" . Strings::getStyledURL($match[1], $max_length) . "[/url]";
|
||||||
},
|
},
|
||||||
$text
|
$text
|
||||||
);
|
);
|
||||||
$text = preg_replace_callback(
|
$text = preg_replace_callback(
|
||||||
"/\[url\=(.*?)\](.*?)\[\/url\]/ism",
|
"/\[url\=(.*?)\](.*?)\[\/url\]/ism",
|
||||||
function ($match) {
|
function ($match) use ($max_length) {
|
||||||
if ($match[1] == $match[2]) {
|
if ($match[1] == $match[2]) {
|
||||||
return "[url=" . self::escapeUrl($match[1]) . "]" . Strings::getStyledURL($match[2]) . "[/url]";
|
return "[url=" . self::escapeUrl($match[1]) . "]" . Strings::getStyledURL($match[2], $max_length) . "[/url]";
|
||||||
} else {
|
} else {
|
||||||
return "[url=" . self::escapeUrl($match[1]) . "]" . $match[2] . "[/url]";
|
return "[url=" . self::escapeUrl($match[1]) . "]" . $match[2] . "[/url]";
|
||||||
}
|
}
|
||||||
|
|
|
@ -565,10 +565,11 @@ class Strings
|
||||||
/**
|
/**
|
||||||
* Converts an URL in a nicer format (without the scheme and possibly shortened)
|
* Converts an URL in a nicer format (without the scheme and possibly shortened)
|
||||||
*
|
*
|
||||||
* @param string $url URL that is about to be reformatted
|
* @param string $url URL that is about to be reformatted
|
||||||
|
* @param int $max_length Maximum length of an url before it is shortened
|
||||||
* @return string reformatted link
|
* @return string reformatted link
|
||||||
*/
|
*/
|
||||||
public static function getStyledURL(string $url): string
|
public static function getStyledURL(string $url, int $max_length = 30): string
|
||||||
{
|
{
|
||||||
$parts = parse_url($url);
|
$parts = parse_url($url);
|
||||||
if (empty($parts['scheme'])) {
|
if (empty($parts['scheme'])) {
|
||||||
|
@ -578,8 +579,8 @@ class Strings
|
||||||
$scheme = [$parts['scheme'] . '://www.', $parts['scheme'] . '://'];
|
$scheme = [$parts['scheme'] . '://www.', $parts['scheme'] . '://'];
|
||||||
$styled_url = str_replace($scheme, '', $url);
|
$styled_url = str_replace($scheme, '', $url);
|
||||||
|
|
||||||
if (strlen($styled_url) > 30) {
|
if (!empty($max_length) && strlen($styled_url) > $max_length) {
|
||||||
$styled_url = substr($styled_url, 0, 30) . "…";
|
$styled_url = substr($styled_url, 0, $max_length) . "…";
|
||||||
}
|
}
|
||||||
|
|
||||||
return $styled_url;
|
return $styled_url;
|
||||||
|
|
|
@ -259,6 +259,10 @@ return [
|
||||||
// Display the first resharer as icon and text on a reshared item.
|
// Display the first resharer as icon and text on a reshared item.
|
||||||
'display_resharer' => false,
|
'display_resharer' => false,
|
||||||
|
|
||||||
|
// display_link_length (integer)
|
||||||
|
// Maximum length of displayed links. Default value is 30, 0 deactivates the functionality.
|
||||||
|
'display_link_length' => 30,
|
||||||
|
|
||||||
// dlogfile (Path)
|
// dlogfile (Path)
|
||||||
// location of the developer log file.
|
// location of the developer log file.
|
||||||
'dlogfile' => '',
|
'dlogfile' => '',
|
||||||
|
|
Loading…
Reference in a new issue