Add support for allocated height for inline images
This commit is contained in:
parent
86141eb363
commit
c4657c4661
2 changed files with 32 additions and 8 deletions
|
@ -33,6 +33,7 @@ use Friendica\Core\Worker;
|
||||||
use Friendica\Database\DBA;
|
use Friendica\Database\DBA;
|
||||||
use Friendica\DI;
|
use Friendica\DI;
|
||||||
use Friendica\Model\Post\Category;
|
use Friendica\Model\Post\Category;
|
||||||
|
use Friendica\Model\Post\Media;
|
||||||
use Friendica\Network\HTTPException\InternalServerErrorException;
|
use Friendica\Network\HTTPException\InternalServerErrorException;
|
||||||
use Friendica\Protocol\Activity;
|
use Friendica\Protocol\Activity;
|
||||||
use Friendica\Protocol\ActivityPub;
|
use Friendica\Protocol\ActivityPub;
|
||||||
|
@ -3344,7 +3345,19 @@ class Item
|
||||||
if (empty($attachment['preview']) || ($attachment['type'] != Post\Media::IMAGE)) {
|
if (empty($attachment['preview']) || ($attachment['type'] != Post\Media::IMAGE)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
$s = str_replace('<a href="' . $attachment['url'] . '"', '<a data-fancybox="' . $uri_id . '" href="' . $attachment['url'] . '"', $s);
|
|
||||||
|
$pattern = '#<a href="' . preg_quote($attachment['url']) . '">(.*?)"></a>#';
|
||||||
|
|
||||||
|
$s = preg_replace_callback($pattern, function () use ($attachment, $uri_id) {
|
||||||
|
return Renderer::replaceMacros(Renderer::getMarkupTemplate('content/image.tpl'), [
|
||||||
|
'$image' => [
|
||||||
|
'src' => $attachment['url'],
|
||||||
|
'uri_id' => $uri_id,
|
||||||
|
'attachment' => $attachment,
|
||||||
|
],
|
||||||
|
'$allocated_height' => Media::getAllocatedHeightByMedia($attachment),
|
||||||
|
]);
|
||||||
|
}, $s);
|
||||||
}
|
}
|
||||||
return $s;
|
return $s;
|
||||||
}
|
}
|
||||||
|
@ -3513,15 +3526,9 @@ class Item
|
||||||
if (count($images) > 1) {
|
if (count($images) > 1) {
|
||||||
$media = self::makeImageGrid($images);
|
$media = self::makeImageGrid($images);
|
||||||
} elseif (count($images) == 1) {
|
} elseif (count($images) == 1) {
|
||||||
if (!empty($images[0]['attachment']['preview-height'])) {
|
|
||||||
$allocated_height = (100 * $images[0]['attachment']['preview-height'] / $images[0]['attachment']['preview-width']) . '%';
|
|
||||||
} else {
|
|
||||||
$allocated_height = (100 * $images[0]['attachment']['height'] / $images[0]['attachment']['width']) . '%';
|
|
||||||
}
|
|
||||||
|
|
||||||
$media = Renderer::replaceMacros(Renderer::getMarkupTemplate('content/image.tpl'), [
|
$media = Renderer::replaceMacros(Renderer::getMarkupTemplate('content/image.tpl'), [
|
||||||
'$image' => $images[0],
|
'$image' => $images[0],
|
||||||
'$allocated_height' => $allocated_height,
|
'$allocated_height' => Media::getAllocatedHeightByMedia($images[0]['attachment']),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1164,4 +1164,21 @@ class Media
|
||||||
}
|
}
|
||||||
return $url . $id;
|
return $url . $id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Computes the allocated height value used in the content/image.tpl template based on a post-media record
|
||||||
|
*
|
||||||
|
* @param array $media A post-media record array
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function getAllocatedHeightByMedia(array $media): string
|
||||||
|
{
|
||||||
|
if (!empty($media['preview-height'])) {
|
||||||
|
$allocated_height = (100 * $media['preview-height'] / $media['preview-width']) . '%';
|
||||||
|
} else {
|
||||||
|
$allocated_height = (100 * $media['height'] / $media['width']) . '%';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $allocated_height;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue