]> git.mxchange.org Git - friendica.git/blobdiff - mod/notifications.php
Merge pull request #7605 from annando/pending-2
[friendica.git] / mod / notifications.php
index 8cd1b29ea426edc9b98413096f4465b948c074da..3276e65491dc9060541c2dd3e5ca7c46569b0862 100644 (file)
@@ -1,81 +1,83 @@
 <?php
-
 /**
  * @file mod/notifications.php
  * @brief The notifications module
  */
 
-require_once("include/NotificationsManager.php");
-require_once("include/contact_selectors.php");
-require_once("include/network.php");
-
-function notifications_post(App $a) {
-
-       if (! local_user()) {
-               goaway(z_root());
+use Friendica\App;
+use Friendica\Content\ContactSelector;
+use Friendica\Content\Nav;
+use Friendica\Content\Pager;
+use Friendica\Core\L10n;
+use Friendica\Core\NotificationsManager;
+use Friendica\Core\Protocol;
+use Friendica\Core\Renderer;
+use Friendica\Core\Logger;
+use Friendica\Core\System;
+use Friendica\Database\DBA;
+use Friendica\Module\Login;
+use Friendica\Model\Contact;
+
+function notifications_post(App $a)
+{
+       if (!local_user()) {
+               $a->internalRedirect();
        }
 
        $request_id = (($a->argc > 1) ? $a->argv[1] : 0);
 
-       if($request_id === "all")
+       if ($request_id === 'all') {
                return;
+       }
 
-       if($request_id) {
-
-               $r = q("SELECT * FROM `intro` WHERE `id` = %d  AND `uid` = %d LIMIT 1",
-                       intval($request_id),
-                       intval(local_user())
-               );
+       if ($request_id) {
+               $intro = DBA::selectFirst('intro', ['id', 'contact-id', 'fid'], ['id' => $request_id, 'uid' => local_user()]);
 
-               if (dbm::is_result($r)) {
-                       $intro_id = $r[0]['id'];
-                       $contact_id = $r[0]['contact-id'];
-               }
-               else {
-                       notice( t('Invalid request identifier.') . EOL);
+               if (DBA::isResult($intro)) {
+                       $intro_id = $intro['id'];
+                       $contact_id = $intro['contact-id'];
+               } else {
+                       notice(L10n::t('Invalid request identifier.') . EOL);
                        return;
                }
 
                // If it is a friend suggestion, the contact is not a new friend but an existing friend
                // that should not be deleted.
 
-               $fid = $r[0]['fid'];
-
-               if($_POST['submit'] == t('Discard')) {
-                       $r = q("DELETE FROM `intro` WHERE `id` = %d",
-                               intval($intro_id)
-                       );
-                       if(! $fid) {
-
-                               // The check for blocked and pending is in case the friendship was already approved
-                               // and we just want to get rid of the now pointless notification
-
-                               $r = q("DELETE FROM `contact` WHERE `id` = %d AND `uid` = %d AND `self` = 0 AND `blocked` = 1 AND `pending` = 1",
-                                       intval($contact_id),
-                                       intval(local_user())
-                               );
+               $fid = $intro['fid'];
+
+               if ($_POST['submit'] == L10n::t('Discard')) {
+                       DBA::delete('intro', ['id' => $intro_id]);
+                       if (!$fid) {
+                               // The check for pending is in case the friendship was already approved
+                               // and we just want to get rid of the pending contact
+                               $condition = ['id' => $contact_id, 'uid' => local_user(),
+                                       'self' => false, 'pending' => true, 'rel' => [0, Contact::FOLLOWER]];
+                               if (DBA::exists('contact', $condition)) {
+                                       Contact::remove($contact_id);
+                               }
                        }
-                       goaway('notifications/intros');
+                       $a->internalRedirect('notifications/intros');
                }
-               if($_POST['submit'] == t('Ignore')) {
-                       $r = q("UPDATE `intro` SET `ignore` = 1 WHERE `id` = %d",
-                               intval($intro_id));
-                       goaway('notifications/intros');
+
+               if ($_POST['submit'] == L10n::t('Ignore')) {
+                       DBA::update('intro', ['ignore' => true], ['id' => $intro_id]);
+                       $a->internalRedirect('notifications/intros');
                }
        }
 }
 
-function notifications_content(App $a) {
-
-       if (! local_user()) {
-               notice( t('Permission denied.') . EOL);
-               return;
+function notifications_content(App $a)
+{
+       if (!local_user()) {
+               notice(L10n::t('Permission denied.') . EOL);
+               return Login::form();
        }
 
-       $page   =       (x($_REQUEST,'page')            ? $_REQUEST['page']             : 1);
-       $show   =       (x($_REQUEST,'show')            ? $_REQUEST['show']             : 0);
+       $page = defaults($_REQUEST, 'page', 1);
+       $show = defaults($_REQUEST, 'show', 0);
 
-       nav_set_selected('notifications');
+       Nav::setSelected('notifications');
 
        $json = (($a->argc > 1 && $a->argv[$a->argc - 1] === 'json') ? true : false);
 
@@ -84,237 +86,261 @@ function notifications_content(App $a) {
        $o = '';
        // Get the nav tabs for the notification pages
        $tabs = $nm->getTabs();
-       $notif_content = array();
+       $notif_content = [];
+       $notif_nocontent = '';
 
        // Notification results per page
        $perpage = 20;
        $startrec = ($page * $perpage) - $perpage;
 
+       $notif_header = L10n::t('Notifications');
+
+       $all = false;
+
        // Get introductions
-       if( (($a->argc > 1) && ($a->argv[1] == 'intros')) || (($a->argc == 1))) {
-               nav_set_selected('introductions');
-               $notif_header = t('Notifications');
+       if ((($a->argc > 1) && ($a->argv[1] == 'intros')) || (($a->argc == 1))) {
+               Nav::setSelected('introductions');
+
+               $id = 0;
+               if (!empty($a->argv[2]) && intval($a->argv[2]) != 0) {
+                       $id = (int)$a->argv[2];
+               }
 
                $all = (($a->argc > 2) && ($a->argv[2] == 'all'));
 
-               $notifs = $nm->introNotifs($all, $startrec, $perpage);
+               $notifs = $nm->introNotifs($all, $startrec, $perpage, $id);
 
        // Get the network notifications
-       } else if (($a->argc > 1) && ($a->argv[1] == 'network')) {
-
-               $notif_header = t('Network Notifications');
+       } elseif (($a->argc > 1) && ($a->argv[1] == 'network')) {
+               $notif_header = L10n::t('Network Notifications');
                $notifs = $nm->networkNotifs($show, $startrec, $perpage);
 
        // Get the system notifications
-       } else if (($a->argc > 1) && ($a->argv[1] == 'system')) {
-
-               $notif_header = t('System Notifications');
+       } elseif (($a->argc > 1) && ($a->argv[1] == 'system')) {
+               $notif_header = L10n::t('System Notifications');
                $notifs = $nm->systemNotifs($show, $startrec, $perpage);
 
        // Get the personal notifications
-       } else if (($a->argc > 1) && ($a->argv[1] == 'personal')) {
-
-               $notif_header = t('Personal Notifications');
+       } elseif (($a->argc > 1) && ($a->argv[1] == 'personal')) {
+               $notif_header = L10n::t('Personal Notifications');
                $notifs = $nm->personalNotifs($show, $startrec, $perpage);
 
        // Get the home notifications
-       } else if (($a->argc > 1) && ($a->argv[1] == 'home')) {
-
-               $notif_header = t('Home Notifications');
+       } elseif (($a->argc > 1) && ($a->argv[1] == 'home')) {
+               $notif_header = L10n::t('Home Notifications');
                $notifs = $nm->homeNotifs($show, $startrec, $perpage);
-
+       // fallback - redirect to main page
+       } else {
+               $a->internalRedirect('notifications');
        }
 
-
        // Set the pager
-       $a->set_pager_total($notifs['total']);
-       $a->set_pager_itemspage($perpage);
+       $pager = new Pager($a->query_string, $perpage);
 
        // Add additional informations (needed for json output)
-       $notifs['items_page'] = $a->pager['itemspage'];
-       $notifs['page'] = $a->pager['page'];
+       $notifs['items_page'] = $pager->getItemsPerPage();
+       $notifs['page'] = $pager->getPage();
 
        // Json output
-       if(intval($json) === 1)
-               json_return_and_die($notifs);
+       if (intval($json) === 1) {
+               System::jsonExit($notifs);
+       }
 
-       $notif_tpl = get_markup_template('notifications.tpl');
+       $notif_tpl = Renderer::getMarkupTemplate('notifications.tpl');
 
-       // Process the data for template creation
-       if($notifs['ident'] === 'introductions') {
+       $notif_show_lnk = [
+               'href' => ($show ? 'notifications/' . $notifs['ident'] : 'notifications/' . $notifs['ident'] . '?show=all' ),
+               'text' => ($show ? L10n::t('Show unread') : L10n::t('Show all')),
+       ];
 
-               $sugg = get_markup_template('suggestions.tpl');
-               $tpl = get_markup_template("intros.tpl");
+       // Process the data for template creation
+       if (defaults($notifs, 'ident', '') === 'introductions') {
+               $sugg = Renderer::getMarkupTemplate('suggestions.tpl');
+               $tpl = Renderer::getMarkupTemplate('intros.tpl');
 
                // The link to switch between ignored and normal connection requests
-               $notif_show_lnk = array(
+               $notif_show_lnk = [
                        'href' => (!$all ? 'notifications/intros/all' : 'notifications/intros' ),
-                       'text' => (!$all ? t('Show Ignored Requests') : t('Hide Ignored Requests'))
-               );
+                       'text' => (!$all ? L10n::t('Show Ignored Requests') : L10n::t('Hide Ignored Requests'))
+               ];
 
                // Loop through all introduction notifications.This creates an array with the output html for each
                // introduction
-               foreach ($notifs['notifications'] as $it) {
+               foreach ($notifs['notifications'] as $notif) {
 
                        // There are two kind of introduction. Contacts suggested by other contacts and normal connection requests.
                        // We have to distinguish between these two because they use different data.
-                       switch ($it['label']) {
+                       switch ($notif['label']) {
                                case 'friend_suggestion':
-                                       $notif_content[] = replace_macros($sugg, array(
-                                               '$str_notifytype' => t('Notification type: '),
-                                               '$notify_type' => $it['notify_type'],
-                                               '$intro_id' => $it['intro_id'],
-                                               '$madeby' => sprintf( t('suggested by %s'),$it['madeby']),
-                                               '$contact_id' => $it['contact-id'],
-                                               '$photo' => $it['photo'],
-                                               '$fullname' => $it['name'],
-                                               '$url' => $it['url'],
-                                               '$hidden' => array('hidden', t('Hide this contact from others'), ($it['hidden'] == 1), ''),
-                                               '$activity' => array('activity', t('Post a new friend activity'), $it['post_newfriend'], t('if applicable')),
-
-                                               '$knowyou' => $it['knowyou'],
-                                               '$approve' => t('Approve'),
-                                               '$note' => $it['note'],
-                                               '$request' => $it['request'],
-                                               '$ignore' => t('Ignore'),
-                                               '$discard' => t('Discard'),
-                                       ));
+                                       $notif_content[] = Renderer::replaceMacros($sugg, [
+                                               '$type'       => $notif['label'],
+                                               '$str_notifytype' => L10n::t('Notification type:'),
+                                               '$notify_type'=> $notif['notify_type'],
+                                               '$intro_id'   => $notif['intro_id'],
+                                               '$lbl_madeby' => L10n::t('Suggested by:'),
+                                               '$madeby'     => $notif['madeby'],
+                                               '$madeby_url' => $notif['madeby_url'],
+                                               '$madeby_zrl' => $notif['madeby_zrl'],
+                                               '$madeby_addr'=> $notif['madeby_addr'],
+                                               '$contact_id' => $notif['contact_id'],
+                                               '$photo'      => $notif['photo'],
+                                               '$fullname'   => $notif['name'],
+                                               '$url'        => $notif['url'],
+                                               '$zrl'        => $notif['zrl'],
+                                               '$lbl_url'    => L10n::t('Profile URL'),
+                                               '$addr'       => $notif['addr'],
+                                               '$hidden'     => ['hidden', L10n::t('Hide this contact from others'), ($notif['hidden'] == 1), ''],
+                                               '$knowyou'    => $notif['knowyou'],
+                                               '$approve'    => L10n::t('Approve'),
+                                               '$note'       => $notif['note'],
+                                               '$request'    => $notif['request'],
+                                               '$ignore'     => L10n::t('Ignore'),
+                                               '$discard'    => L10n::t('Discard'),
+                                       ]);
                                        break;
 
                                // Normal connection requests
                                default:
-                                       $friend_selected = (($it['network'] !== NETWORK_OSTATUS) ? ' checked="checked" ' : ' disabled ');
-                                       $fan_selected = (($it['network'] === NETWORK_OSTATUS) ? ' checked="checked" disabled ' : '');
-                                       $dfrn_tpl = get_markup_template('netfriend.tpl');
-
-                                       $knowyou   = '';
-                                       $dfrn_text = '';
-
-                                       if($it['network'] === NETWORK_DFRN || $it['network'] === NETWORK_DIASPORA) {
-                                               if($it['network'] === NETWORK_DFRN) {
-                                                       $lbl_knowyou = t('Claims to be known to you: ');
-                                                       $knowyou = (($it['knowyou']) ? t('yes') : t('no'));
-                                                       $helptext = t('Shall your connection be bidirectional or not? "Friend" implies that you allow to read and you subscribe to their posts. "Fan/Admirer" means that you allow to read but you do not want to read theirs. Approve as: ');
-                                               } else {
-                                                       $knowyou = '';
-                                                       $helptext = t('Shall your connection be bidirectional or not? "Friend" implies that you allow to read and you subscribe to their posts. "Sharer" means that you allow to read but you do not want to read theirs. Approve as: ');
-                                               }
+                                       $friend_selected = (($notif['network'] !== Protocol::OSTATUS) ? ' checked="checked" ' : ' disabled ');
+                                       $fan_selected = (($notif['network'] === Protocol::OSTATUS) ? ' checked="checked" disabled ' : '');
+
+                                       $lbl_knowyou = '';
+                                       $knowyou     = '';
+                                       $helptext    = '';
+                                       $helptext2   = '';
+                                       $helptext3   = '';
+
+                                       if ($notif['network'] === Protocol::DFRN) {
+                                               $lbl_knowyou = L10n::t('Claims to be known to you: ');
+                                               $knowyou   = (($notif['knowyou']) ? L10n::t('yes') : L10n::t('no'));
+                                               $helptext  = L10n::t('Shall your connection be bidirectional or not?');
+                                               $helptext2 = L10n::t('Accepting %s as a friend allows %s to subscribe to your posts, and you will also receive updates from them in your news feed.', $notif['name'], $notif['name']);
+                                               $helptext3 = L10n::t('Accepting %s as a subscriber allows them to subscribe to your posts, but you will not receive updates from them in your news feed.', $notif['name']);
+                                       } elseif ($notif['network'] === Protocol::DIASPORA) {
+                                               $helptext  = L10n::t('Shall your connection be bidirectional or not?');
+                                               $helptext2 = L10n::t('Accepting %s as a friend allows %s to subscribe to your posts, and you will also receive updates from them in your news feed.', $notif['name'], $notif['name']);
+                                               $helptext3 = L10n::t('Accepting %s as a sharer allows them to subscribe to your posts, but you will not receive updates from them in your news feed.', $notif['name']);
                                        }
 
-                                       $dfrn_text = replace_macros($dfrn_tpl,array(
-                                               '$intro_id' => $it['intro_id'],
+                                       $dfrn_tpl = Renderer::getMarkupTemplate('netfriend.tpl');
+                                       $dfrn_text = Renderer::replaceMacros($dfrn_tpl, [
+                                               '$intro_id'    => $notif['intro_id'],
                                                '$friend_selected' => $friend_selected,
-                                               '$fan_selected' => $fan_selected,
-                                               '$approve_as' => $helptext,
-                                               '$as_friend' => t('Friend'),
-                                               '$as_fan' => (($it['network'] == NETWORK_DIASPORA) ? t('Sharer') : t('Fan/Admirer'))
-                                       ));
-
-                                       $header = $it["name"];
-
-                                       if ($it["addr"] != "")
-                                               $header .= " <".$it["addr"].">";
-
-                                       $header .= " (".network_to_name($it['network'], $it['url']).")";
-
-                                       $notif_content[] = replace_macros($tpl, array(
-                                               '$header' => htmlentities($header),
-                                               '$str_notifytype' => t('Notification type: '),
-                                               '$notify_type' => $it['notify_type'],
-                                               '$dfrn_text' => $dfrn_text,
-                                               '$dfrn_id' => $it['dfrn_id'],
-                                               '$uid' => $it['uid'],
-                                               '$intro_id' => $it['intro_id'],
-                                               '$contact_id' => $it['contact_id'],
-                                               '$photo' => $it['photo'],
-                                               '$fullname' => $it['name'],
-                                               '$location' => $it['location'],
-                                               '$lbl_location' => t('Location:'),
-                                               '$about' => $it['about'],
-                                               '$lbl_about' => t('About:'),
-                                               '$keywords' => $it['keywords'],
-                                               '$lbl_keywords' => t('Tags:'),
-                                               '$gender' => $it['gender'],
-                                               '$lbl_gender' => t('Gender:'),
-                                               '$hidden' => array('hidden', t('Hide this contact from others'), ($it['hidden'] == 1), ''),
-                                               '$activity' => array('activity', t('Post a new friend activity'), $it['post_newfriend'], t('if applicable')),
-                                               '$url' => $it['url'],
-                                               '$zrl' => $it['zrl'],
-                                               '$lbl_url' => t('Profile URL'),
-                                               '$addr' => $it['addr'],
+                                               '$fan_selected'=> $fan_selected,
+                                               '$approve_as1' => $helptext,
+                                               '$approve_as2' => $helptext2,
+                                               '$approve_as3' => $helptext3,
+                                               '$as_friend'   => L10n::t('Friend'),
+                                               '$as_fan'      => (($notif['network'] == Protocol::DIASPORA) ? L10n::t('Sharer') : L10n::t('Subscriber'))
+                                       ]);
+
+                                       $contact = DBA::selectFirst('contact', ['network', 'protocol'], ['id' => $notif['contact_id']]);
+
+                                       if (($contact['network'] != Protocol::DFRN) || ($contact['protocol'] == Protocol::ACTIVITYPUB)) {
+                                               $action = 'follow_confirm';
+                                       } else {
+                                               $action = 'dfrn_confirm';
+                                       }
+
+                                       $header = $notif['name'];
+
+                                       if ($notif['addr'] != '') {
+                                               $header .= ' <' . $notif['addr'] . '>';
+                                       }
+
+                                       $header .= ' (' . ContactSelector::networkToName($notif['network'], $notif['url']) . ')';
+
+                                       if ($notif['network'] != Protocol::DIASPORA) {
+                                               $discard = L10n::t('Discard');
+                                       } else {
+                                               $discard = '';
+                                       }
+
+                                       $notif_content[] = Renderer::replaceMacros($tpl, [
+                                               '$type'        => $notif['label'],
+                                               '$header'      => $header,
+                                               '$str_notifytype' => L10n::t('Notification type:'),
+                                               '$notify_type' => $notif['notify_type'],
+                                               '$dfrn_text'   => $dfrn_text,
+                                               '$dfrn_id'     => $notif['dfrn_id'],
+                                               '$uid'         => $notif['uid'],
+                                               '$intro_id'    => $notif['intro_id'],
+                                               '$contact_id'  => $notif['contact_id'],
+                                               '$photo'       => $notif['photo'],
+                                               '$fullname'    => $notif['name'],
+                                               '$location'    => $notif['location'],
+                                               '$lbl_location'=> L10n::t('Location:'),
+                                               '$about'       => $notif['about'],
+                                               '$lbl_about'   => L10n::t('About:'),
+                                               '$keywords'    => $notif['keywords'],
+                                               '$lbl_keywords'=> L10n::t('Tags:'),
+                                               '$gender'      => $notif['gender'],
+                                               '$lbl_gender'  => L10n::t('Gender:'),
+                                               '$hidden'      => ['hidden', L10n::t('Hide this contact from others'), ($notif['hidden'] == 1), ''],
+                                               '$url'         => $notif['url'],
+                                               '$zrl'         => $notif['zrl'],
+                                               '$lbl_url'     => L10n::t('Profile URL'),
+                                               '$addr'        => $notif['addr'],
                                                '$lbl_knowyou' => $lbl_knowyou,
-                                               '$lbl_network' => t('Network:'),
-                                               '$network' => network_to_name($it['network'], $it['url']),
-                                               '$knowyou' => $knowyou,
-                                               '$approve' => t('Approve'),
-                                               '$note' => $it['note'],
-                                               '$ignore' => t('Ignore'),
-                                               '$discard' => t('Discard'),
-
-                                       ));
+                                               '$lbl_network' => L10n::t('Network:'),
+                                               '$network'     => ContactSelector::networkToName($notif['network'], $notif['url']),
+                                               '$knowyou'     => $knowyou,
+                                               '$approve'     => L10n::t('Approve'),
+                                               '$note'        => $notif['note'],
+                                               '$ignore'      => L10n::t('Ignore'),
+                                               '$discard'     => $discard,
+                                               '$action'      => $action,
+                                       ]);
                                        break;
                        }
                }
 
-               if($notifs['total'] == 0)
-                       info( t('No introductions.') . EOL);
-
-       // Normal notifications (no introductions)
-       } else {
-
-               // The template files we need in different cases for formatting the content
-               $tpl_item_like = 'notifications_likes_item.tpl';
-               $tpl_item_dislike = 'notifications_dislikes_item.tpl';
-               $tpl_item_attend = 'notifications_attend_item.tpl';
-               $tpl_item_attendno = 'notifications_attend_item.tpl';
-               $tpl_item_attendmaybe = 'notifications_attend_item.tpl';
-               $tpl_item_friend = 'notifications_friends_item.tpl';
-               $tpl_item_comment = 'notifications_comments_item.tpl';
-               $tpl_item_post = 'notifications_posts_item.tpl';
-               $tpl_item_notify = 'notify.tpl';
+               if (count($notifs['notifications']) == 0) {
+                       info(L10n::t('No introductions.') . EOL);
+               }
 
+               // Normal notifications (no introductions)
+       } elseif (!empty($notifs['notifications'])) {
                // Loop trough ever notification This creates an array with the output html for each
                // notification and apply the correct template according to the notificationtype (label).
-               foreach ($notifs['notifications'] as $it) {
-
-                       // We use the notification label to get the correct template file
-                       $tpl_var_name = 'tpl_item_'.$it['label'];
-                       $tpl_notif = get_markup_template($$tpl_var_name);
-
-                       $notif_content[] = replace_macros($tpl_notif,array(
-                               '$item_label' => $it['label'],
-                               '$item_link' => $it['link'],
-                               '$item_image' => $it['image'],
-                               '$item_url' => $it['url'],
-                               '$item_text' => htmlentities($it['text']),
-                               '$item_when' => $it['when'],
-                               '$item_ago' => $it['ago'],
-                               '$item_seen' => $it['seen'],
-                       ));
-               }
-
-               // It doesn't make sense to show the Show unread / Show all link visible if the user is on the
-               // "Show all" page and there are no notifications. So we will hide it.
-               if($show == 0 || intval($show) && $notifs['total'] > 0) {
-                       $notif_show_lnk = array(
-                               'href' => ($show ? 'notifications/'.$notifs['ident'] : 'notifications/'.$notifs['ident'].'?show=all' ),
-                               'text' => ($show ? t('Show unread') : t('Show all')),
-                       );
+               foreach ($notifs['notifications'] as $notif) {
+                       $notification_templates = [
+                               'like'        => 'notifications_likes_item.tpl',
+                               'dislike'     => 'notifications_dislikes_item.tpl',
+                               'attend'      => 'notifications_attend_item.tpl',
+                               'attendno'    => 'notifications_attend_item.tpl',
+                               'attendmaybe' => 'notifications_attend_item.tpl',
+                               'friend'      => 'notifications_friends_item.tpl',
+                               'comment'     => 'notifications_comments_item.tpl',
+                               'post'        => 'notifications_posts_item.tpl',
+                               'notify'      => 'notify.tpl',
+                       ];
+
+                       $tpl_notif = Renderer::getMarkupTemplate($notification_templates[$notif['label']]);
+
+                       $notif_content[] = Renderer::replaceMacros($tpl_notif, [
+                               '$item_label' => $notif['label'],
+                               '$item_link'  => $notif['link'],
+                               '$item_image' => $notif['image'],
+                               '$item_url'   => $notif['url'],
+                               '$item_text'  => $notif['text'],
+                               '$item_when'  => $notif['when'],
+                               '$item_ago'   => $notif['ago'],
+                               '$item_seen'  => $notif['seen'],
+                       ]);
                }
-
-               // Output if there aren't any notifications available
-               if($notifs['total'] == 0)
-                       $notif_nocontent = sprintf( t('No more %s notifications.'), $notifs['ident']);
+       } else {
+               $notif_nocontent = L10n::t('No more %s notifications.', $notifs['ident']);
        }
 
-       $o .= replace_macros($notif_tpl, array(
-               '$notif_header' => $notif_header,
-               '$tabs' => $tabs,
-               '$notif_content' => $notif_content,
+       $o .= Renderer::replaceMacros($notif_tpl, [
+               '$notif_header'    => $notif_header,
+               '$tabs'            => $tabs,
+               '$notif_content'   => $notif_content,
                '$notif_nocontent' => $notif_nocontent,
-               '$notif_show_lnk' => $notif_show_lnk,
-               '$notif_paginate' => paginate($a)
-       ));
+               '$notif_show_lnk'  => $notif_show_lnk,
+               '$notif_paginate'  => $pager->renderMinimal(count($notif_content))
+       ]);
 
        return $o;
 }