X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=mod%2Fnotify.php;h=959b581d59a25942b19cb824ec4b11cd1e479a8a;hb=735cb7c6c1619662925df913360c7eb0ec3c3b9d;hp=7acac1084af94805d692ddb8a0f2771a01939bcb;hpb=db949bb802448184bfe5164d8d3dd86ddf51b187;p=friendica.git diff --git a/mod/notify.php b/mod/notify.php index 7acac1084a..959b581d59 100644 --- a/mod/notify.php +++ b/mod/notify.php @@ -1,84 +1,88 @@ argc > 2 && $a->argv[1] === 'view' && intval($a->argv[2])) { - $r = q("select * from notify where id = %d and uid = %d limit 1", - intval($a->argv[2]), - intval(local_user()) - ); - if(count($r)) { - q("update notify set seen = 1 where ( link = '%s' or ( parent != 0 and parent = %d and otype = '%s' )) and uid = %d", - dbesc($r[0]['link']), - intval($r[0]['parent']), - dbesc($r[0]['otype']), - intval(local_user()) - ); + if ($a->argc > 2 && $a->argv[1] === 'view' && intval($a->argv[2])) { + $note = $nm->getByID($a->argv[2]); + if ($note) { + $nm->setSeen($note); // The friendica client has problems with the GUID. this is some workaround - if ($a->is_friendica_app()) { + if ($a->isFriendicaApp()) { require_once("include/items.php"); - $urldata = parse_url($r[0]['link']); + $urldata = parse_url($note['link']); $guid = basename($urldata["path"]); - $itemdata = get_item_id($guid, local_user()); - if ($itemdata["id"] != 0) - $r[0]['link'] = $a->get_baseurl().'/display/'.$itemdata["nick"].'/'.$itemdata["id"]; + $itemdata = Item::getIdAndNickByGuid($guid, local_user()); + if ($itemdata["id"] != 0) { + $note['link'] = System::baseUrl().'/display/'.$itemdata["nick"].'/'.$itemdata["id"]; + } } - goaway($r[0]['link']); + System::externalRedirect($note['link']); } - goaway($a->get_baseurl(true)); + $a->internalRedirect(); } - if($a->argc > 2 && $a->argv[1] === 'mark' && $a->argv[2] === 'all' ) { - $r = q("update notify set seen = 1 where uid = %d", - intval(local_user()) - ); - $j = json_encode(array('result' => ($r) ? 'success' : 'fail')); + if ($a->argc > 2 && $a->argv[1] === 'mark' && $a->argv[2] === 'all') { + $r = $nm->setAllSeen(); + $j = json_encode(['result' => ($r) ? 'success' : 'fail']); echo $j; killme(); } } -} -if(! function_exists('notify_content')) { -function notify_content(&$a) { - if(! local_user()) - return login(); +function notify_content(App $a) +{ + if (! local_user()) { + return Login::form(); + } - $notif_tpl = get_markup_template('notifications.tpl'); + $nm = new NotificationsManager(); - $not_tpl = get_markup_template('notify.tpl'); - require_once('include/bbcode.php'); + $notif_tpl = Renderer::getMarkupTemplate('notifications.tpl'); - $r = q("SELECT * from notify where uid = %d and seen = 0 order by date desc", - intval(local_user()) - ); + $not_tpl = Renderer::getMarkupTemplate('notify.tpl'); - if (count($r) > 0) { - foreach ($r as $it) { - $notif_content .= replace_macros($not_tpl,array( - '$item_link' => $a->get_baseurl(true).'/notify/view/'. $it['id'], - '$item_image' => $it['photo'], - '$item_text' => strip_tags(bbcode($it['msg'])), - '$item_when' => relative_date($it['date']) - )); - } - } else { - $notif_content .= t('No more system notifications.'); + $r = $nm->getAll(['seen'=>0]); + if (DBA::isResult($r) > 0) { + foreach ($r as $it) { + $notif_content .= Renderer::replaceMacros($not_tpl, [ + '$item_link' => System::baseUrl(true).'/notify/view/'. $it['id'], + '$item_image' => $it['photo'], + '$item_text' => strip_tags(BBCode::convert($it['msg'])), + '$item_when' => Temporal::getRelativeDate($it['date']) + ]); } + } else { + $notif_content .= L10n::t('No more system notifications.'); + } - $o .= replace_macros($notif_tpl, array( - '$notif_header' => t('System Notifications'), - '$tabs' => '', // $tabs, - '$notif_content' => $notif_content, - )); + $o = Renderer::replaceMacros($notif_tpl, [ + '$notif_header' => L10n::t('System Notifications'), + '$tabs' => false, // $tabs, + '$notif_content' => $notif_content, + ]); return $o; - -} }