]> git.mxchange.org Git - friendica.git/blobdiff - mod/notifications.php
missing salmon key? report it.
[friendica.git] / mod / notifications.php
index ef72023636d78577e34c8b868c7ad6c6b427f303..8c32ee8628bbe5250a9dd163e6cb4d09c2f245d3 100644 (file)
@@ -3,7 +3,7 @@
 function notifications_post(&$a) {
 
        if(! local_user()) {
-               goaway($a->get_baseurl());
+               goaway(z_root());
        }
        
        $request_id = (($a->argc > 1) ? $a->argv[1] : 0);
@@ -13,11 +13,9 @@ function notifications_post(&$a) {
 
        if($request_id) {
 
-               $r = q("SELECT * FROM `intro` 
-                       WHERE `id` = %d 
-                       AND `uid` = %d LIMIT 1",
-                               intval($request_id),
-                               intval(local_user())
+               $r = q("SELECT * FROM `intro` WHERE `id` = %d  AND `uid` = %d LIMIT 1",
+                       intval($request_id),
+                       intval(local_user())
                );
        
                if(count($r)) {
@@ -28,14 +26,22 @@ function notifications_post(&$a) {
                        notice( 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 LIMIT 1", 
                                intval($intro_id)
                        );      
-                       $r = q("DELETE FROM `contact` WHERE `id` = %d AND `uid` = %d AND `self` = 0 LIMIT 1", 
-                               intval($contact_id),
-                               intval(local_user())
-                       );
+                       if(! $fid) {
+                               $r = q("DELETE FROM `contact` WHERE `id` = %d AND `uid` = %d AND `self` = 0 LIMIT 1", 
+                                       intval($contact_id),
+                                       intval(local_user())
+                               );
+                       }
                        return;
                }
                if($_POST['submit'] == t('Ignore')) {
@@ -54,7 +60,7 @@ function notifications_content(&$a) {
 
        if(! local_user()) {
                notice( t('Permission denied.') . EOL);
-               goaway($a->get_baseurl());
+               return;
        }
 
        $o = '';
@@ -65,39 +71,76 @@ function notifications_content(&$a) {
        else
                $sql_extra = " AND `ignore` = 0 ";
 
+       $o .= '<h1>' . t('Pending Friend/Connect Notifications') . '</h1>' . "\r\n";
+       
+       $o .= '<div id="notification-show-hide-wrapper" >';
+       $o .= '<a href="' . ((strlen($sql_extra)) ? 'notifications/all' : 'notifications' ) . '" id="notifications-show-hide-link" >'
+               . ((strlen($sql_extra)) ? t('Show Ignored Requests') : t('Hide Ignored Requests')) . '</a></div>' . "\r\n";
 
-       $tpl = load_view_file('view/intros-top.tpl');
-       $o .= replace_macros($tpl,array(
-               '$hide_url' => ((strlen($sql_extra)) ? 'notifications/all' : 'notifications' ),
-               '$hide_text' => ((strlen($sql_extra)) ? t('Show Ignored Requests') : t('Hide Ignored Requests'))
-       )); 
 
-       $r = q("SELECT `intro`.`id` AS `intro_id`, `intro`.*, `contact`.* 
-               FROM `intro` LEFT JOIN `contact` ON `intro`.`contact-id` = `contact`.`id`
+       $r = q("SELECT COUNT(*) AS `total` FROM `intro` 
+               WHERE `intro`.`uid` = %d $sql_extra AND `intro`.`blocked` = 0 ",
+                       intval($_SESSION['uid'])
+       );
+       if($r && count($r)) {
+               $a->set_pager_total($r[0]['total']);
+               $a->set_pager_itemspage(20);
+       }
+
+       $r = q("SELECT `intro`.`id` AS `intro_id`, `intro`.*, `contact`.*, `fcontact`.`name` AS `fname`,`fcontact`.`url` AS `furl`,`fcontact`.`photo` AS `fphoto`,`fcontact`.`request` AS `frequest`
+               FROM `intro` LEFT JOIN `contact` ON `contact`.`id` = `intro`.`contact-id` LEFT JOIN `fcontact` ON `intro`.`fid` = `fcontact`.`id`
                WHERE `intro`.`uid` = %d $sql_extra AND `intro`.`blocked` = 0 ",
                        intval($_SESSION['uid']));
 
        if(($r !== false) && (count($r))) {
 
-
-               $tpl = load_view_file("view/intros.tpl");
+               $sugg = get_markup_template('suggestions.tpl');
+               $tpl = get_markup_template("intros.tpl");
 
                foreach($r as $rr) {
+                       if($rr['fid']) {
+
+                               $return_addr = bin2hex($a->user['nickname'] . '@' . $a->get_hostname() . (($a->path) ? '/' . $a->path : ''));
+                               $o .= replace_macros($sugg,array(
+                                       '$str_notifytype' => t('Notification type: '),
+                                       '$notify_type' => t('Friend Suggestion'),
+                                       '$intro_id' => $rr['intro_id'],
+                                       '$madeby' => sprintf( t('suggested by %s'),$rr['name']),
+                                       '$contact_id' => $rr['contact-id'],
+                                       '$photo' => ((x($rr,'fphoto')) ? $rr['fphoto'] : "images/default-profile.jpg"),
+                                       '$fullname' => $rr['fname'],
+                                       '$url' => $rr['furl'],
+                                       '$knowyou' => $knowyou,
+                                       '$approve' => t('Approve'),
+                                       '$note' => $rr['note'],
+                                       '$request' => $rr['frequest'] . '?addr=' . $return_addr,
+                                       '$ignore' => t('Ignore'),
+                                       '$discard' => t('Discard')
+
+                               ));
 
-                       $friend_selected = (($rr['network'] !== 'stat') ? ' checked="checked" ' : ' disabled ');
-                       $fan_selected = (($rr['network'] === 'stat') ? ' checked="checked" disabled ' : '');
-                       $dfrn_tpl = load_view_file('view/netfriend.tpl');
+                               continue;
+
+                       }
+                       $friend_selected = (($rr['network'] !== NETWORK_OSTATUS) ? ' checked="checked" ' : ' disabled ');
+                       $fan_selected = (($rr['network'] === NETWORK_OSTATUS) ? ' checked="checked" disabled ' : '');
+                       $dfrn_tpl = get_markup_template('netfriend.tpl');
 
                        $knowyou   = '';
                        $dfrn_text = '';
                                                
-                       if($rr['network'] !== 'stat') {
-                               $knowyou = t('Claims to be known to you: ') . (($rr['knowyou']) ? t('yes') : t('no'));
-
+                       if($rr['network'] === NETWORK_DFRN || $rr['network'] === NETWORK_DIASPORA) {
+                               if($rr['network'] === NETWORK_DFRN)
+                                       $knowyou = t('Claims to be known to you: ') . (($rr['knowyou']) ? t('yes') : t('no'));
+                               else
+                                       $knowyou = '';
                                $dfrn_text = replace_macros($dfrn_tpl,array(
                                        '$intro_id' => $rr['intro_id'],
                                        '$friend_selected' => $friend_selected,
                                        '$fan_selected' => $fan_selected,
+                                       '$approve_as' => t('Approve as: '),
+                                       '$as_friend' => t('Friend'),
+                                       '$as_fan' => (($rr['network'] == NETWORK_DIASPORA) ? t('Sharer') : t('Fan/Admirer'))
                                ));
                        }                       
 
@@ -105,7 +148,7 @@ function notifications_content(&$a) {
 
                        $o .= replace_macros($tpl,array(
                                '$str_notifytype' => t('Notification type: '),
-                               '$notify_type' => (($rr['network'] !== 'stat') ? t('Friend/Connect Request') : t('New Follower')),
+                               '$notify_type' => (($rr['network'] !== NETWORK_OSTATUS) ? t('Friend/Connect Request') : t('New Follower')),
                                '$dfrn_text' => $dfrn_text,     
                                '$dfrn_id' => $rr['issued-id'],
                                '$uid' => $_SESSION['uid'],
@@ -124,33 +167,8 @@ function notifications_content(&$a) {
                }
        }
        else
-               notice( t('No notifications.') . EOL);
-
-       if ($a->config['register_policy'] == REGISTER_APPROVE &&        
-               $a->config['admin_email'] === $a->user['email']){
-               $o .= load_view_file('view/registrations-top.tpl');
-               
-               $r = q("SELECT `register`.*, `contact`.`name`, `user`.`email`
-                                FROM `register`
-                                LEFT JOIN `contact` ON `register`.`uid` = `contact`.`uid`
-                                LEFT JOIN `user` ON `register`.`uid` = `user`.`uid`;");
-               if(($r !== false) && (count($r))) {
-                       $tpl = load_view_file("view/registrations.tpl");
-                       foreach($r as $rr) {
-                               $o .= "<ul>";
-                               $o .= replace_macros($tpl, array(
-                                       '$fullname'     => $rr['name'],
-                                       '$email'                => $rr['email'],
-                                       '$approvelink'  => "regmod/allow/".$rr['hash'],
-                                       '$denylink'     => "regmod/deny/".$rr['hash'],
-                               ));
-                               $o .= "</ul>";
-                       }
-               }
-               else
-                       notice( t('No registrations.') . EOL);
-
-       }
+               info( t('No notifications.') . EOL);
 
+       $o .= paginate($a);
        return $o;
 }