X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=mod%2Fnotifications.php;h=e306f0c8a64d2cf86a41d6c719c6112fa6d560d8;hb=af88c2daa34e39cb6430abf64d0648665bfeb9cd;hp=ac642122c28af096661aa360ac861a3e0c24a68e;hpb=f185f6fd3dde9a63feb735dd6dd87aaf278a6415;p=friendica.git diff --git a/mod/notifications.php b/mod/notifications.php index ac642122c2..e306f0c8a6 100644 --- a/mod/notifications.php +++ b/mod/notifications.php @@ -1,7 +1,7 @@ internalRedirect(); + DI::baseUrl()->redirect(); } $request_id = (($a->argc > 1) ? $a->argv[1] : 0); @@ -31,39 +31,18 @@ function notifications_post(App $a) } if ($request_id) { - $intro = DBA::selectFirst('intro', ['id', 'contact-id', 'fid'], ['id' => $request_id, 'uid' => local_user()]); - - if (DBA::isResult($intro)) { - $intro_id = $intro['id']; - $contact_id = $intro['contact-id']; - } else { - notice(L10n::t('Invalid request identifier.') . EOL); - return; + $intro = DI::intro()->selectFirst(['id' => $request_id, 'uid' => local_user()]); + + switch ($_POST['submit']) { + case L10n::t('Discard'): + $intro->discard(); + break; + case L10n::t('Ignore'): + $intro->ignore(); + break; } - // If it is a friend suggestion, the contact is not a new friend but an existing friend - // that should not be deleted. - - $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' => Contact::FOLLOWER]; - if (DBA::exists('contact', $condition)) { - Contact::remove($contact_id); - } - } - $a->internalRedirect('notifications/intros'); - } - - if ($_POST['submit'] == L10n::t('Ignore')) { - DBA::update('intro', ['ignore' => true], ['id' => $intro_id]); - $a->internalRedirect('notifications/intros'); - } + DI::baseUrl()->redirect('notifications/intros'); } } @@ -74,14 +53,14 @@ function notifications_content(App $a) return Login::form(); } - $page = defaults($_REQUEST, 'page', 1); - $show = defaults($_REQUEST, 'show', 0); + $page = ($_REQUEST['page'] ?? 0) ?: 1; + $show = ($_REQUEST['show'] ?? '') === 'all'; Nav::setSelected('notifications'); $json = (($a->argc > 1 && $a->argv[$a->argc - 1] === 'json') ? true : false); - $nm = new NotificationsManager(); + $nm = DI::notify(); $o = ''; // Get the nav tabs for the notification pages @@ -108,34 +87,34 @@ function notifications_content(App $a) $all = (($a->argc > 2) && ($a->argv[2] == 'all')); - $notifs = $nm->introNotifs($all, $startrec, $perpage, $id); + $notifs = $nm->getIntroList($all, $startrec, $perpage, $id); // Get the network notifications } elseif (($a->argc > 1) && ($a->argv[1] == 'network')) { $notif_header = L10n::t('Network Notifications'); - $notifs = $nm->networkNotifs($show, $startrec, $perpage); + $notifs = $nm->getNetworkList($show, $startrec, $perpage); // Get the system notifications } elseif (($a->argc > 1) && ($a->argv[1] == 'system')) { $notif_header = L10n::t('System Notifications'); - $notifs = $nm->systemNotifs($show, $startrec, $perpage); + $notifs = $nm->getSystemList($show, $startrec, $perpage); // Get the personal notifications } elseif (($a->argc > 1) && ($a->argv[1] == 'personal')) { $notif_header = L10n::t('Personal Notifications'); - $notifs = $nm->personalNotifs($show, $startrec, $perpage); + $notifs = $nm->getPersonalList($show, $startrec, $perpage); // Get the home notifications } elseif (($a->argc > 1) && ($a->argv[1] == 'home')) { $notif_header = L10n::t('Home Notifications'); - $notifs = $nm->homeNotifs($show, $startrec, $perpage); + $notifs = $nm->getHomeList($show, $startrec, $perpage); // fallback - redirect to main page } else { - $a->internalRedirect('notifications'); + DI::baseUrl()->redirect('notifications'); } // Set the pager - $pager = new Pager($a->query_string, $perpage); + $pager = new Pager(DI::args()->getQueryString(), $perpage); // Add additional informations (needed for json output) $notifs['items_page'] = $pager->getItemsPerPage(); @@ -154,7 +133,7 @@ function notifications_content(App $a) ]; // Process the data for template creation - if (defaults($notifs, 'ident', '') === 'introductions') { + if (($notifs['ident'] ?? '') == 'introductions') { $sugg = Renderer::getMarkupTemplate('suggestions.tpl'); $tpl = Renderer::getMarkupTemplate('intros.tpl');