2010-07-01 19:48:07 -04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
function notifications_post(&$a) {
|
|
|
|
|
2010-08-16 00:49:29 -04:00
|
|
|
if(! local_user()) {
|
2010-07-01 19:48:07 -04:00
|
|
|
goaway($a->get_baseurl());
|
|
|
|
}
|
|
|
|
|
2010-08-16 00:49:29 -04:00
|
|
|
$request_id = (($a->argc > 1) ? $a->argv[1] : 0);
|
2010-07-01 19:48:07 -04:00
|
|
|
|
2010-09-26 22:44:03 -04:00
|
|
|
if($request_id === "all")
|
2010-07-01 19:48:07 -04:00
|
|
|
return;
|
|
|
|
|
|
|
|
if($request_id) {
|
|
|
|
|
2010-11-06 20:01:57 -04:00
|
|
|
$r = q("SELECT * FROM `intro`
|
2010-11-06 19:54:21 -04:00
|
|
|
WHERE `id` = %d
|
2010-07-01 19:48:07 -04:00
|
|
|
AND `uid` = %d LIMIT 1",
|
|
|
|
intval($request_id),
|
2010-10-18 17:34:59 -04:00
|
|
|
intval(local_user())
|
2010-07-01 19:48:07 -04:00
|
|
|
);
|
|
|
|
|
|
|
|
if(count($r)) {
|
|
|
|
$intro_id = $r[0]['id'];
|
2010-11-06 20:01:57 -04:00
|
|
|
$contact_id = $r[0]['contact-id'];
|
2010-07-01 19:48:07 -04:00
|
|
|
}
|
|
|
|
else {
|
2010-08-16 00:49:29 -04:00
|
|
|
notice( t('Invalid request identifier.') . EOL);
|
2010-07-01 19:48:07 -04:00
|
|
|
return;
|
|
|
|
}
|
2010-08-16 01:43:42 -04:00
|
|
|
if($_POST['submit'] == t('Discard')) {
|
2010-09-08 23:14:17 -04:00
|
|
|
$r = q("DELETE FROM `intro` WHERE `id` = %d LIMIT 1",
|
|
|
|
intval($intro_id)
|
|
|
|
);
|
2010-11-06 20:01:57 -04:00
|
|
|
$r = q("DELETE FROM `contact` WHERE `id` = %d AND `uid` = %d AND `self` = 0 LIMIT 1",
|
|
|
|
intval($contact_id),
|
2010-10-18 17:34:59 -04:00
|
|
|
intval(local_user())
|
2010-09-08 23:14:17 -04:00
|
|
|
);
|
2010-07-01 19:48:07 -04:00
|
|
|
return;
|
|
|
|
}
|
2010-08-16 00:49:29 -04:00
|
|
|
if($_POST['submit'] == t('Ignore')) {
|
2010-07-01 19:48:07 -04:00
|
|
|
$r = q("UPDATE `intro` SET `ignore` = 1 WHERE `id` = %d LIMIT 1",
|
|
|
|
intval($intro_id));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function notifications_content(&$a) {
|
|
|
|
|
2010-08-16 00:49:29 -04:00
|
|
|
if(! local_user()) {
|
|
|
|
notice( t('Permission denied.') . EOL);
|
2010-07-01 19:48:07 -04:00
|
|
|
goaway($a->get_baseurl());
|
|
|
|
}
|
|
|
|
|
2010-08-16 00:49:29 -04:00
|
|
|
$o = '';
|
2010-09-19 00:11:18 -04:00
|
|
|
$o .= '<script> $(document).ready(function() { $(\'#nav-notify-link\').addClass(\'nav-selected\'); });</script>';
|
2010-08-16 00:49:29 -04:00
|
|
|
|
2010-07-01 19:48:07 -04:00
|
|
|
if(($a->argc > 1) && ($a->argv[1] == 'all'))
|
|
|
|
$sql_extra = '';
|
|
|
|
else
|
|
|
|
$sql_extra = " AND `ignore` = 0 ";
|
|
|
|
|
2011-03-29 20:19:12 -04:00
|
|
|
$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";
|
2010-07-12 19:43:59 -04:00
|
|
|
|
2011-01-13 05:01:00 -05:00
|
|
|
|
|
|
|
$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);
|
|
|
|
}
|
|
|
|
|
2010-10-24 23:39:24 -04:00
|
|
|
$r = q("SELECT `intro`.`id` AS `intro_id`, `intro`.*, `contact`.*
|
2010-07-01 19:48:07 -04:00
|
|
|
FROM `intro` LEFT JOIN `contact` ON `intro`.`contact-id` = `contact`.`id`
|
|
|
|
WHERE `intro`.`uid` = %d $sql_extra AND `intro`.`blocked` = 0 ",
|
|
|
|
intval($_SESSION['uid']));
|
2010-07-12 19:43:59 -04:00
|
|
|
|
2010-07-01 19:48:07 -04:00
|
|
|
if(($r !== false) && (count($r))) {
|
|
|
|
|
|
|
|
|
2010-09-22 21:00:19 -04:00
|
|
|
$tpl = load_view_file("view/intros.tpl");
|
2010-07-01 19:48:07 -04:00
|
|
|
|
|
|
|
foreach($r as $rr) {
|
|
|
|
|
2010-11-18 23:28:41 -05:00
|
|
|
$friend_selected = (($rr['network'] !== 'stat') ? ' checked="checked" ' : ' disabled ');
|
2010-10-24 23:39:24 -04:00
|
|
|
$fan_selected = (($rr['network'] === 'stat') ? ' checked="checked" disabled ' : '');
|
|
|
|
$dfrn_tpl = load_view_file('view/netfriend.tpl');
|
|
|
|
|
|
|
|
$knowyou = '';
|
|
|
|
$dfrn_text = '';
|
|
|
|
|
2010-11-18 23:28:41 -05:00
|
|
|
if($rr['network'] !== 'stat') {
|
2010-10-24 23:39:24 -04:00
|
|
|
$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,
|
2011-02-22 18:35:33 -05:00
|
|
|
'$approve_as' => t('Approve as: '),
|
|
|
|
'$as_friend' => t('Friend'),
|
|
|
|
'$as_fan' => t('Fan/Admirer')
|
2010-10-24 23:39:24 -04:00
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2010-07-01 19:48:07 -04:00
|
|
|
$o .= replace_macros($tpl,array(
|
2010-11-16 02:27:12 -05:00
|
|
|
'$str_notifytype' => t('Notification type: '),
|
2010-11-18 23:28:41 -05:00
|
|
|
'$notify_type' => (($rr['network'] !== 'stat') ? t('Friend/Connect Request') : t('New Follower')),
|
2010-10-24 23:39:24 -04:00
|
|
|
'$dfrn_text' => $dfrn_text,
|
|
|
|
'$dfrn_id' => $rr['issued-id'],
|
2010-07-01 19:48:07 -04:00
|
|
|
'$uid' => $_SESSION['uid'],
|
2010-10-24 23:39:24 -04:00
|
|
|
'$intro_id' => $rr['intro_id'],
|
|
|
|
'$contact_id' => $rr['contact-id'],
|
2010-07-01 19:48:07 -04:00
|
|
|
'$photo' => ((x($rr,'photo')) ? $rr['photo'] : "images/default-profile.jpg"),
|
|
|
|
'$fullname' => $rr['name'],
|
|
|
|
'$url' => $rr['url'],
|
2010-10-24 23:39:24 -04:00
|
|
|
'$knowyou' => $knowyou,
|
2010-11-16 02:27:12 -05:00
|
|
|
'$approve' => t('Approve'),
|
2010-12-01 23:37:42 -05:00
|
|
|
'$note' => $rr['note'],
|
|
|
|
'$ignore' => t('Ignore'),
|
|
|
|
'$discard' => t('Discard')
|
|
|
|
|
2010-07-01 19:48:07 -04:00
|
|
|
));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
2010-08-16 00:49:29 -04:00
|
|
|
notice( t('No notifications.') . EOL);
|
2010-07-01 19:48:07 -04:00
|
|
|
|
2011-01-05 02:31:51 -05:00
|
|
|
if ($a->config['register_policy'] == REGISTER_APPROVE &&
|
2011-01-05 01:17:58 -05:00
|
|
|
$a->config['admin_email'] === $a->user['email']){
|
2011-03-29 20:19:12 -04:00
|
|
|
$o .= '<h1>' . t('User registrations waiting for confirm') . '</h1>' . "\r\n";
|
2011-01-04 08:46:08 -05:00
|
|
|
|
|
|
|
$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);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2011-01-13 05:01:00 -05:00
|
|
|
$o .= paginate($a);
|
2010-07-01 19:48:07 -04:00
|
|
|
return $o;
|
2011-01-04 08:46:08 -05:00
|
|
|
}
|