]> git.mxchange.org Git - friendica.git/commitdiff
Create specific module to display HTML message when a conversation isn't found in...
authorHypolite Petovan <hypolite@mrpetovan.com>
Sun, 5 Feb 2023 00:18:05 +0000 (19:18 -0500)
committerHypolite Petovan <hypolite@mrpetovan.com>
Sun, 5 Feb 2023 01:28:04 +0000 (20:28 -0500)
src/App/BaseURL.php
src/Module/Item/Display.php
src/Module/Special/DisplayNotFound.php [new file with mode: 0644]
view/templates/special/displaynotfound.tpl [new file with mode: 0644]

index f02cb9ef9936a7b5a92495cbbbd7feadafd7c1eb..564527a652287f0327fc513c1df50c2d2b28ad4f 100644 (file)
@@ -341,7 +341,7 @@ class BaseURL
        public function redirect(string $toUrl = '', bool $ssl = false)
        {
                if (!empty(parse_url($toUrl, PHP_URL_SCHEME))) {
-                       throw new HTTPException\InternalServerErrorException("'$toUrl is not a relative path, please use System::externalRedirectTo");
+                       throw new HTTPException\InternalServerErrorException("$toUrl is not a relative path, please use System::externalRedirectTo");
                }
 
                $redirectTo = $this->get($ssl) . '/' . ltrim($toUrl, '/');
index a97c9db830f756903ed15ea389ddc81d6e693c20..b2ed43c5b51d707125818e8b68aadbada5c6958f 100644 (file)
@@ -37,6 +37,7 @@ use Friendica\Model\Post;
 use Friendica\Model\Profile;
 use Friendica\Model\User;
 use Friendica\Module\Response;
+use Friendica\Module\Special\DisplayNotFound;
 use Friendica\Navigation\Notifications\Repository\Notification;
 use Friendica\Navigation\Notifications\Repository\Notify;
 use Friendica\Protocol\ActivityPub;
@@ -246,14 +247,8 @@ class Display extends BaseModule
 
                if (empty($item)) {
                        $this->page['aside'] = '';
-                       throw new HTTPException\NotFoundException($this->t('Unfortunately, the requested conversation isn\'t available to you.</p>
-<p>Possible reasons include:</p>
-<ul>
-       <li>The top-level post isn\'t visible.</li>
-       <li>The top-level post was deleted.</li>
-       <li>The node has blocked the top-level author or the author of the shared post.</li>
-       <li>You have ignored or blocked the top-level author or the author of the shared post.</li>
-</ul><p>'));
+                       $displayNotFound = new DisplayNotFound($this->l10n, $this->baseUrl, $this->args, $this->logger, $this->profiler, $this->response, $this->server, $this->parameters);
+                       return $displayNotFound->content();
                }
 
                $item['uri-id'] = $item['parent-uri-id'];
diff --git a/src/Module/Special/DisplayNotFound.php b/src/Module/Special/DisplayNotFound.php
new file mode 100644 (file)
index 0000000..d66ecec
--- /dev/null
@@ -0,0 +1,49 @@
+<?php
+/**
+ * @copyright Copyright (C) 2010-2023, the Friendica project
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program.  If not, see <https://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace Friendica\Module\Special;
+
+use Friendica\Core\Renderer;
+
+/**
+ * This is a special case of the HTTPException module where the message is intended to be HTML.
+ * This module should be called directly from the Display module and shouldn't be routed to.
+ */
+class DisplayNotFound extends \Friendica\BaseModule
+{
+       protected function content(array $request = []): string
+       {
+               $tpl = Renderer::getMarkupTemplate('special/displaynotfound.tpl');
+               return Renderer::replaceMacros($tpl, [
+                       '$l10n' => [
+                               'title'   => $this->t('Not Found'),
+                               'message' => $this->t("<p>Unfortunately, the requested conversation isn't available to you.</p>
+<p>Possible reasons include:</p>
+<ul>
+       <li>The top-level post isn't visible.</li>
+       <li>The top-level post was deleted.</li>
+       <li>The node has blocked the top-level author or the author of the shared post.</li>
+       <li>You have ignored or blocked the top-level author or the author of the shared post.</li>
+</ul>"),
+                       ]
+               ]);
+       }
+}
diff --git a/view/templates/special/displaynotfound.tpl b/view/templates/special/displaynotfound.tpl
new file mode 100644 (file)
index 0000000..48e7b51
--- /dev/null
@@ -0,0 +1,5 @@
+<div id="exception" class="generic-page-wrapper">
+       <img class="hare" src="images/friendica-404_svg_flexy-o-hare.png"/>
+       <h1>{{$title}}</h1>
+       {{$message nofilter}}
+</div>