]> git.mxchange.org Git - friendica.git/commitdiff
simplify the calendar download
authorMichael <heluecht@pirati.ca>
Sat, 29 May 2021 17:09:45 +0000 (17:09 +0000)
committerMichael <heluecht@pirati.ca>
Sat, 29 May 2021 17:09:45 +0000 (17:09 +0000)
mod/cal.php
mod/events.php
src/Content/Widget/CalendarExport.php

index aa38fa658203799dd018863144bd4c225ba3c8ad..c867582a7f96e6bcbbc12a677cb5334c6e4f63ff 100644 (file)
@@ -84,7 +84,7 @@ function cal_init(App $a)
                '$about' => BBCode::convert($a->profile['about']),
        ]);
 
-       $cal_widget = Widget\CalendarExport::getHTML();
+       $cal_widget = Widget\CalendarExport::getHTML($user['uid']);
 
        if (empty(DI::page()['aside'])) {
                DI::page()['aside'] = '';
index 85976f8f878a2130f60506e22b2d90c02cd3b1b3..2bbf4e6a3b10de0422645d97968429d2083ee25a 100644 (file)
@@ -59,7 +59,7 @@ function events_init(App $a)
                DI::page()['aside'] = '';
        }
 
-       $cal_widget = CalendarExport::getHTML();
+       $cal_widget = CalendarExport::getHTML(local_user());
 
        DI::page()['aside'] .= $cal_widget;
 
index 63d1d7af87a7251f5b5d5c7dba31c27c9a8dde37..1ea7d1e1809da1bd4a19b7f323ae839c35879e20 100644 (file)
@@ -21,9 +21,9 @@
 
 namespace Friendica\Content\Widget;
 
-use Friendica\Content\Feature;
 use Friendica\Core\Renderer;
 use Friendica\DI;
+use Friendica\Model\User;
 
 /**
  * TagCloud widget
@@ -34,36 +34,27 @@ class CalendarExport
 {
        /**
         * Get the events widget.
+        * @param int $uid
         *
         * @return string Formated HTML of the calendar widget.
         * @throws \Friendica\Network\HTTPException\InternalServerErrorException
         */
-       public static function getHTML() {
-               $a = DI::app();
-
-               if (empty($a->data['user'])) {
-                       return;
+       public static function getHTML(int $uid = 0) {
+               if (empty($uid)) {
+                       return '';
                }
 
-               $owner_uid = intval($a->data['user']['uid']);
-
-               // The permission testing is a little bit tricky because we have to respect many cases.
-
-               // It's not the private events page (we don't get the $owner_uid for /events).
-               if (!local_user() && !$owner_uid) {
-                       return;
+               $user = User::getById($uid, ['nickname']);
+               if (empty($user['nickname'])) {
+                       return '';
                }
 
-               // $a->data is only available if the profile page is visited. If the visited page is not part
-               // of the profile page it should be the personal /events page. So we can use $a->user.
-               $user = ($a->data['user']['nickname'] ?? '') ?: $a->user['nickname'];
-
                $tpl = Renderer::getMarkupTemplate("widget/events.tpl");
                $return = Renderer::replaceMacros($tpl, [
                        '$etitle'      => DI::l10n()->t("Export"),
                        '$export_ical' => DI::l10n()->t("Export calendar as ical"),
                        '$export_csv'  => DI::l10n()->t("Export calendar as csv"),
-                       '$user'        => $user
+                       '$user'        => $user['nickname']
                ]);
 
                return $return;