X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FModel%2FItem.php;h=33ba8ee7a4d1b849631bec1e245d17c4f91f8fc9;hb=8397ccf37c2733ae74a997dab31ac55c1762a402;hp=f24771375d890c94fa199d26d4cfbb36b83e7709;hpb=c554af9c303a62a2f93c131f8f3c5ccaa97d8d6d;p=friendica.git diff --git a/src/Model/Item.php b/src/Model/Item.php index f24771375d..33ba8ee7a4 100644 --- a/src/Model/Item.php +++ b/src/Model/Item.php @@ -3016,7 +3016,11 @@ class Item $item['hashtags'] = $tags['hashtags']; $item['mentions'] = $tags['mentions']; - $body = $item['body'] = Post\Media::removeFromEndOfBody($item['body'] ?? ''); + if (!$is_preview) { + $item['body'] = Post\Media::removeFromEndOfBody($item['body'] ?? ''); + } + + $body = $item['body']; $fields = ['uri-id', 'uri', 'body', 'title', 'author-name', 'author-link', 'author-avatar', 'guid', 'created', 'plink', 'network', 'has-media', 'quote-uri-id', 'post-type']; @@ -3096,7 +3100,7 @@ class Item ]; Hook::callAll('prepare_body', $hook_data); $s = $hook_data['html']; - + unset($hook_data); if (!$attach) { @@ -3144,113 +3148,14 @@ class Item * @return string * @throws \Friendica\Network\HTTPException\ServiceUnavailableException */ - public static function makeImageGrid(array $images): string + private static function makeImageGrid(array $images): string { - $landscapeimages = array(); - $portraitimages = array(); - - foreach ($images as $image) { - ($image['attachment']['width'] > $image['attachment']['height']) ? ($landscapeimages[] = $image) : ($portraitimages[] = $image); - } - // Image for first column (fc) and second column (sc) - $images_fc = array(); - $images_sc = array(); - $lcount = count($landscapeimages); - $pcount = count($portraitimages); - if ($lcount == 0 || $pcount == 0) { - if ($lcount == 0) { - // only portrait - for ($i = 0; $i < $pcount; $i++) { - ($i % 2 == 0) ? ($images_fc[] = $portraitimages[$i]) : ($images_sc[] = $portraitimages[$i]); - } - } - if ($pcount == 0) { - // ony landscapes - for ($i = 0; $i < $lcount; $i++) { - ($i % 2 == 0) ? ($images_fc[] = $landscapeimages[$i]) : ($images_sc[] = $landscapeimages[$i]); - } - } - } else { - // Mix of landscape and portrait images. - if ($lcount == $pcount) { - // equal amount of landscapes and portraits - for ($l = 0; $l < $lcount; $l++) { - if ($l % 2 == 0) { - $images_fc[] = $landscapeimages[$l]; - $images_fc[] = $portraitimages[$l]; - } else { - $images_sc[] = $portraitimages[$l]; - $images_sc[] = $landscapeimages[$l]; - } - } - } - if ($lcount > $pcount) { - // More landscapes than portraits - $p = 0; - $l = 0; - while ($l < $lcount) { - if (($lcount > $l + 1) && ($pcount > $l)) { - // we have one more landscape that can be used for the l-th portrait - $images_fc[] = $landscapeimages[$l++]; - } - $images_fc[] = $landscapeimages[$l++]; - if ($pcount > $p) { - $images_sc[] = $portraitimages[$p++]; - } - - } - } - if ($lcount < $pcount) { - // More portraits than landscapes - if ($lcount % 2 == 0 && $pcount % 2 == 0) { - /* - * even number of landscapes and portraits, but fewer landscapes than portraits. Iterate to the end - * of landscapes array - */ - $i = 0; - while ($i < $lcount) { - if ($i % 2 == 0) { - $images_fc[] = $landscapeimages[$i]; - $images_fc[] = $portraitimages[$i]; - } else { - $images_sc[] = $portraitimages[$i]; - $images_sc[] = $landscapeimages[$i]; - } - $i++; - } - // Rest portraits - while ($i < $pcount) { - if ($i % 2 == 0) { - $images_fc[] = $portraitimages[$i]; - } else { - $images_sc[] = $portraitimages[$i]; - } - $i++; - } + $images_fc = []; + $images_sc = []; - } - if ($lcount % 2 != 0 && $pcount % 2 == 0) { - // uneven landscapes count even portraits count. - for ($p = 0; $p < $pcount; $p++) { - // --> First all portraits until - if ($p % 2 == 0) { - $images_fc[] = $portraitimages[$p]; - } else { - $images_sc[] = $portraitimages[$p]; - } - } - // and now the (uneven) landscapes - for ($l = 0; $l < $lcount; $l++) { - // --> First all portraits until - if ($l % 2 == 0) { - $images_fc[] = $landscapeimages[$l]; - } else { - $images_sc[] = $landscapeimages[$l]; - } - } - } - } + for ($i = 0; $i < count($images); $i++) { + ($i % 2 == 0) ? ($images_fc[] = $images[$i]) : ($images_sc[] = $images[$i]); } return Renderer::replaceMacros(Renderer::getMarkupTemplate('content/image_grid.tpl'), [ @@ -3260,6 +3165,7 @@ class Item ], ]); } + /** * Check if the body contains a link @@ -3415,9 +3321,8 @@ class Item $media = ''; if (count($images) > 1) { $media = self::makeImageGrid($images); - } - elseif (count($images) == 1) { - $media = $media = Renderer::replaceMacros(Renderer::getMarkupTemplate('content/image.tpl'), [ + } elseif (count($images) == 1) { + $media = Renderer::replaceMacros(Renderer::getMarkupTemplate('content/image.tpl'), [ '$image' => $images[0], ]); } @@ -3430,15 +3335,15 @@ class Item } if ($shared) { - $content = str_replace(BBCode::TOP_ANCHOR, '
' . $leading . '
' . BBCode::TOP_ANCHOR, $content); - $content = str_replace(BBCode::BOTTOM_ANCHOR, '
' . $trailing . '
' . BBCode::BOTTOM_ANCHOR, $content); + $content = str_replace(BBCode::TOP_ANCHOR, '
' . $leading . '
' . BBCode::TOP_ANCHOR, $content); + $content = str_replace(BBCode::BOTTOM_ANCHOR, '
' . $trailing . '
' . BBCode::BOTTOM_ANCHOR, $content); } else { if ($leading != '') { - $content = '
' . $leading . '
' . $content; + $content = '
' . $leading . '
' . $content; } if ($trailing != '') { - $content .= '
' . $trailing . '
'; + $content .= '
' . $trailing . '
'; } } @@ -3598,7 +3503,7 @@ class Item } if ($trailing != '') { - $content .= '
' . $trailing . '
'; + $content .= '
' . $trailing . '
'; } DI::profiler()->stopRecording();