friendica-github/mod/notifications.php

103 lines
2.3 KiB
PHP
Raw Normal View History

2010-07-01 23:48:07 +00:00
<?php
function notifications_post(&$a) {
2010-08-16 04:49:29 +00:00
if(! local_user()) {
2010-07-01 23:48:07 +00:00
goaway($a->get_baseurl());
}
2010-08-16 04:49:29 +00:00
$request_id = (($a->argc > 1) ? $a->argv[1] : 0);
2010-07-01 23:48:07 +00:00
if($request_id === "all")
2010-07-01 23:48:07 +00:00
return;
if($request_id) {
$r = q("SELECT `id` FROM `intro`
WHERE `request-id` = %d
AND `uid` = %d LIMIT 1",
intval($request_id),
2010-10-18 21:34:59 +00:00
intval(local_user())
2010-07-01 23:48:07 +00:00
);
if(count($r)) {
$intro_id = $r[0]['id'];
}
else {
2010-08-16 04:49:29 +00:00
notice( t('Invalid request identifier.') . EOL);
2010-07-01 23:48:07 +00:00
return;
}
2010-08-16 05:43:42 +00:00
if($_POST['submit'] == t('Discard')) {
2010-09-09 03:14:17 +00:00
$r = q("DELETE FROM `intro` WHERE `id` = %d LIMIT 1",
intval($intro_id)
);
$r = q("DELETE FROM `contact` WHERE `id` = %d AND `uid` = %d LIMIT 1",
2010-07-01 23:48:07 +00:00
intval($request_id),
2010-10-18 21:34:59 +00:00
intval(local_user())
2010-09-09 03:14:17 +00:00
);
2010-07-01 23:48:07 +00:00
return;
}
2010-08-16 04:49:29 +00:00
if($_POST['submit'] == t('Ignore')) {
2010-07-01 23:48:07 +00:00
$r = q("UPDATE `intro` SET `ignore` = 1 WHERE `id` = %d LIMIT 1",
intval($intro_id));
return;
}
}
}
function notifications_content(&$a) {
2010-08-16 04:49:29 +00:00
if(! local_user()) {
notice( t('Permission denied.') . EOL);
2010-07-01 23:48:07 +00:00
goaway($a->get_baseurl());
}
2010-08-16 04:49:29 +00:00
$o = '';
2010-09-19 04:11:18 +00:00
$o .= '<script> $(document).ready(function() { $(\'#nav-notify-link\').addClass(\'nav-selected\'); });</script>';
2010-08-16 04:49:29 +00:00
2010-07-01 23:48:07 +00:00
if(($a->argc > 1) && ($a->argv[1] == 'all'))
$sql_extra = '';
else
$sql_extra = " AND `ignore` = 0 ";
$tpl = load_view_file('view/intros-top.tpl');
2010-07-01 23:48:07 +00:00
$o .= replace_macros($tpl,array(
'$hide_url' => ((strlen($sql_extra)) ? 'notifications/all' : 'notifications' ),
2010-08-16 04:49:29 +00:00
'$hide_text' => ((strlen($sql_extra)) ? t('Show Ignored Requests') : t('Hide Ignored Requests'))
2010-07-01 23:48:07 +00:00
));
2010-07-12 23:43:59 +00:00
2010-07-01 23:48:07 +00:00
$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']));
2010-07-12 23:43:59 +00:00
2010-07-01 23:48:07 +00:00
if(($r !== false) && (count($r))) {
$tpl = load_view_file("view/intros.tpl");
2010-07-01 23:48:07 +00:00
foreach($r as $rr) {
$o .= replace_macros($tpl,array(
'$intro_id' => $rr['intro-id'],
'$dfrn-id' => $rr['issued-id'],
'$uid' => $_SESSION['uid'],
'$contact-id' => $rr['contact-id'],
'$photo' => ((x($rr,'photo')) ? $rr['photo'] : "images/default-profile.jpg"),
'$fullname' => $rr['name'],
2010-08-16 04:49:29 +00:00
'$knowyou' => (($rr['knowyou']) ? t('yes') : t('no')),
2010-07-01 23:48:07 +00:00
'$url' => $rr['url'],
'$note' => $rr['note']
));
}
}
else
2010-08-16 04:49:29 +00:00
notice( t('No notifications.') . EOL);
2010-07-01 23:48:07 +00:00
return $o;
}