]> git.mxchange.org Git - friendica.git/blobdiff - mod/notify.php
Merge pull request #4905 from MrPetovan/task/content-filter-one-liner
[friendica.git] / mod / notify.php
index 229020f4a715df876d44c1b44cc44734009e3bc3..f22c1cf5b1d11342b5c92b861ed7714397e40186 100644 (file)
@@ -1,39 +1,87 @@
 <?php
+/**
+ * @file mod/notify.php
+ */
 
+use Friendica\App;
+use Friendica\Content\Text\BBCode;
+use Friendica\Core\L10n;
+use Friendica\Core\NotificationsManager;
+use Friendica\Core\System;
+use Friendica\Database\DBM;
+use Friendica\Model\Item;
+use Friendica\Module\Login;
+use Friendica\Util\Temporal;
 
-function notify_init(&$a) {
-       if(! local_user())
+function notify_init(App $a)
+{
+       if (! local_user()) {
                return;
+       }
+
+       $nm = new NotificationsManager();
+
+       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()) {
+                               require_once("include/items.php");
+                               $urldata = parse_url($note['link']);
+                               $guid = basename($urldata["path"]);
+                               $itemdata = Item::getIdAndNickByGuid($guid, local_user());
+                               if ($itemdata["id"] != 0) {
+                                       $note['link'] = System::baseUrl().'/display/'.$itemdata["nick"].'/'.$itemdata["id"];
+                               }
+                       }
 
-       if($a->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']);
+                       goaway($note['link']);
                }
 
-               goaway($a->get_baseurl());
+               goaway(System::baseUrl(true));
        }
 
-       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();
        }
-
 }
 
+function notify_content(App $a)
+{
+       if (! local_user()) {
+               return Login::form();
+       }
+
+       $nm = new NotificationsManager();
 
-function notify_content(&$a) {
-       if(! local_user())
-               return login();
-}
\ No newline at end of file
+       $notif_tpl = get_markup_template('notifications.tpl');
+
+       $not_tpl = get_markup_template('notify.tpl');
+
+       $r = $nm->getAll(['seen'=>0]);
+       if (DBM::is_result($r) > 0) {
+               foreach ($r as $it) {
+                       $notif_content .= replace_macros($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, [
+               '$notif_header' => L10n::t('System Notifications'),
+               '$tabs' => false, // $tabs,
+               '$notif_content' => $notif_content,
+       ]);
+
+       return $o;
+}