X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=mod%2Fnotify.php;h=938e2ffbe35a908a79162b2a4c692a1d9a0d228c;hb=09931b71247c2261371a5a40b38a2127f79f344d;hp=d1e5022bcb59f386b06a9e6783444fec91837505;hpb=b821399f001cd4082707ba9fb6df9c419e0b8e5e;p=friendica.git diff --git a/mod/notify.php b/mod/notify.php index d1e5022bcb..938e2ffbe3 100644 --- a/mod/notify.php +++ b/mod/notify.php @@ -1,29 +1,72 @@ 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 id = %d and uid = %d limit 1", - intval($a->argv[2]), - intval(local_user()) - ); - goaway($r[0]['link']); + $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()) { + require_once("include/items.php"); + $urldata = parse_url($note['link']); + $guid = basename($urldata["path"]); + $itemdata = get_item_id($guid, local_user()); + if ($itemdata["id"] != 0) + $note['link'] = $a->get_baseurl().'/display/'.$itemdata["nick"].'/'.$itemdata["id"]; + } + + goaway($note['link']); } - goaway($a->get_baseurl()); + goaway($a->get_baseurl(true)); + } + + if($a->argc > 2 && $a->argv[1] === 'mark' && $a->argv[2] === 'all' ) { + $r = $nm->setAllSeen(); + $j = json_encode(array('result' => ($r) ? 'success' : 'fail')); + echo $j; + killme(); } -} +} function notify_content(&$a) { - if(! local_user()) - return login(); -} \ No newline at end of file + if(! local_user()) return login(); + + $nm = new NotificationsManager(); + + $notif_tpl = get_markup_template('notifications.tpl'); + + $not_tpl = get_markup_template('notify.tpl'); + require_once('include/bbcode.php'); + + $r = $nm->getAll(array('seen'=>0)); + if ($r!==false && 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.'); + } + + $o .= replace_macros($notif_tpl, array( + '$notif_header' => t('System Notifications'), + '$tabs' => false, // $tabs, + '$notif_content' => $notif_content, + )); + + return $o; + + +}