aboutsummaryrefslogblamecommitdiffstats
path: root/mod/notifications.php
blob: 0c695d0b4799245c4715d522e7de2b9bcb87a796 (plain) (tree)
1
2
3
4
5
6
7
8
9



                                  
                            


                                          
                                                         
        
                                 



                         
                                              
                                        

                                                    
                                                    



                                                
                                                          

                      
                                                                        

                               
                                                      


                                                                              

                                                                                                              
                                                    
                          

                               
                                                     












                                                                                         

                                                       


                                          
                
                                                                                                                         
 




                                                    




                                                                                                                                     
 









                                                                                
                                                                          


                                                                                         
 


                                           
                                                            


                                    
                                                                                                                
                                                                                                            
                                                                            



                                                
                                                       





                                                                                                                      


                                                                           




                                                
                                                        
                                                                              
                                                                                                                                  

                                                                
                                                           

                                                                   

                                                                                                             
                                                     
                                                       
                                                           



                                                          



                           
                                                      
 
                                                                        
                                                                 
                                                                                              





                                                                                          
                                     
                                            


                                                                                                                               
                         
                                      





                                                              
                           
                  
 
<?php

function notifications_post(&$a) {

	if(! local_user()) {
		goaway($a->get_baseurl());
	}
	
	$request_id = (($a->argc > 1) ? $a->argv[1] : 0);
	
	if($request_id === "all")
		return;

	if($request_id) {

		$r = q("SELECT * FROM `intro` 
			WHERE `id` = %d 
			AND `uid` = %d LIMIT 1",
				intval($request_id),
				intval(local_user())
		);
	
		if(count($r)) {
			$intro_id = $r[0]['id'];
			$contact_id = $r[0]['contact-id'];
		}
		else {
			notice( t('Invalid request identifier.') . EOL);
			return;
		}
		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())
			);
			return;
		}
		if($_POST['submit'] == t('Ignore')) {
			$r = q("UPDATE `intro` SET `ignore` = 1 WHERE `id` = %d LIMIT 1",
				intval($intro_id));
			return;
		}
	}
}





function notifications_content(&$a) {

	if(! local_user()) {
		notice( t('Permission denied.') . EOL);
		goaway($a->get_baseurl());
	}

	$o = '';
	$o .= '<script>	$(document).ready(function() { $(\'#nav-notify-link\').addClass(\'nav-selected\'); });</script>';

	if(($a->argc > 1) && ($a->argv[1] == 'all'))
		$sql_extra = '';
	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";


	$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`.* 
		FROM `intro` LEFT JOIN `contact` ON `intro`.`contact-id` = `contact`.`id`
		WHERE `intro`.`uid` = %d $sql_extra AND `intro`.`blocked` = 0 ",
			intval($_SESSION['uid']));

	if(($r !== false) && (count($r))) {


		$tpl = file_get_contents("view/intros.tpl");

		foreach($r as $rr) {

			$friend_selected = (($rr['network'] !== 'stat') ? ' checked="checked" ' : ' disabled ');
			$fan_selected = (($rr['network'] === 'stat') ? ' checked="checked" disabled ' : '');
			$dfrn_tpl = file_get_contents('view/netfriend.tpl');

			$knowyou   = '';
			$dfrn_text = '';
						
			if($rr['network'] !== 'stat') {
				$knowyou = t('Claims to be known to you: ') . (($rr['knowyou']) ? t('yes') : t('no'));

				$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' => t('Fan/Admirer')
				));
			}			



			$o .= replace_macros($tpl,array(
				'$str_notifytype' => t('Notification type: '),
				'$notify_type' => (($rr['network'] !== 'stat') ? t('Friend/Connect Request') : t('New Follower')),
				'$dfrn_text' => $dfrn_text,	
				'$dfrn_id' => $rr['issued-id'],
				'$uid' => $_SESSION['uid'],
				'$intro_id' => $rr['intro_id'],
				'$contact_id' => $rr['contact-id'],
				'$photo' => ((x($rr,'photo')) ? $rr['photo'] : "images/default-profile.jpg"),
				'$fullname' => $rr['name'],
				'$url' => $rr['url'],
				'$knowyou' => $knowyou,
				'$approve' => t('Approve'),
				'$note' => $rr['note'],
				'$ignore' => t('Ignore'),
				'$discard' => t('Discard')

			));
		}
	}
	else
		notice( t('No notifications.') . EOL);

	if ($a->config['register_policy'] == REGISTER_APPROVE &&	
		$a->config['admin_email'] === $a->user['email']){
		$o .= '<h1>' . t('User registrations waiting for confirm') . '</h1>' . "\r\n";
		
		$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))) {
			$o .= '<ul>';
			foreach($r as $rr) {
				$o .= '<li>' . sprintf('%s (%s) : ', $rr['name'],$rr['email']) 
					. '<a href="regmod/allow/' . $rr['hash'] .'">' . t('Approve') 
					. '</a> - <href="regmod/deny/' . $rr['hash'] . '">' . t('Deny') . '</a></li>' . "\r\n";
			}
			$o .= "</ul>";
		}
		else
			notice( t('No registrations.') . EOL);

	}

	$o .= paginate($a);
	return $o;
}