friendica/mod/suggest.php

123 lines
3.3 KiB
PHP
Raw Normal View History

2011-11-01 23:29:55 -04:00
<?php
use Friendica\App;
2017-08-26 02:04:21 -04:00
use Friendica\Core\System;
2011-11-01 23:29:55 -04:00
require_once('include/socgraph.php');
2011-11-02 00:27:11 -04:00
require_once('include/contact_widgets.php');
2011-11-01 23:29:55 -04:00
function suggest_init(App $a) {
if (! local_user()) {
2011-11-03 19:00:52 -04:00
return;
}
2011-11-03 19:00:52 -04:00
if (x($_GET,'ignore') && intval($_GET['ignore'])) {
// Check if we should do HTML-based delete confirmation
if ($_REQUEST['confirm']) {
// <form> can't take arguments in its "action" parameter
// so add any arguments as hidden inputs
$query = explode_querystring($a->query_string);
$inputs = array();
foreach ($query['args'] as $arg) {
if (strpos($arg, 'confirm=') === false) {
$arg_parts = explode('=', $arg);
$inputs[] = array('name' => $arg_parts[0], 'value' => $arg_parts[1]);
}
}
$a->page['content'] = replace_macros(get_markup_template('confirm.tpl'), array(
'$method' => 'get',
'$message' => t('Do you really want to delete this suggestion?'),
'$extra_inputs' => $inputs,
'$confirm' => t('Yes'),
'$confirm_url' => $query['base'],
'$confirm_name' => 'confirmed',
'$cancel' => t('Cancel'),
));
$a->error = 1; // Set $a->error so the other module functions don't execute
return;
}
// Now check how the user responded to the confirmation query
if (!$_REQUEST['canceled']) {
q("INSERT INTO `gcign` ( `uid`, `gcid` ) VALUES ( %d, %d ) ",
intval(local_user()),
intval($_GET['ignore'])
);
}
2011-11-03 19:00:52 -04:00
}
2011-11-03 19:00:52 -04:00
}
2011-11-03 19:00:52 -04:00
function suggest_content(App $a) {
2011-11-01 23:29:55 -04:00
require_once("mod/proxy.php");
2011-11-01 23:29:55 -04:00
$o = '';
if (! local_user()) {
2011-11-01 23:29:55 -04:00
notice( t('Permission denied.') . EOL);
return;
}
$_SESSION['return_url'] = App::get_baseurl() . '/' . $a->cmd;
2011-11-02 00:27:11 -04:00
$a->page['aside'] .= findpeople_widget();
$a->page['aside'] .= follow_widget();
2011-11-02 00:27:11 -04:00
2011-11-01 23:29:55 -04:00
$r = suggestion_query(local_user());
if (! dbm::is_result($r)) {
2011-12-18 04:08:32 -05:00
$o .= t('No suggestions available. If this is a new site, please try again in 24 hours.');
2011-11-01 23:29:55 -04:00
return $o;
}
require_once 'include/contact_selectors.php';
foreach ($r as $rr) {
2011-12-18 04:08:32 -05:00
$connlnk = App::get_baseurl() . '/follow/?url=' . (($rr['connect']) ? $rr['connect'] : $rr['url']);
$ignlnk = App::get_baseurl() . '/suggest?ignore=' . $rr['id'];
$photo_menu = array(
'profile' => array(t("View Profile"), zrl($rr["url"])),
'follow' => array(t("Connect/Follow"), $connlnk),
'hide' => array(t('Ignore/Hide'), $ignlnk)
);
2016-06-05 07:57:11 -04:00
$contact_details = get_contact_details_by_url($rr["url"], local_user(), $rr);
2011-12-18 04:08:32 -05:00
2015-10-17 15:25:21 -04:00
$entry = array(
'url' => zrl($rr['url']),
'itemurl' => (($contact_details['addr'] != "") ? $contact_details['addr'] : $rr['url']),
'img_hover' => $rr['url'],
2016-06-05 07:57:11 -04:00
'name' => $contact_details['name'],
'thumb' => proxy_url($contact_details['thumb'], false, PROXY_SIZE_THUMB),
'details' => $contact_details['location'],
'tags' => $contact_details['keywords'],
'about' => $contact_details['about'],
'account_type' => account_type($contact_details),
'ignlnk' => $ignlnk,
2015-10-17 15:25:21 -04:00
'ignid' => $rr['id'],
'conntxt' => t('Connect'),
'connlnk' => $connlnk,
'photo_menu' => $photo_menu,
'ignore' => t('Ignore/Hide'),
'network' => network_to_name($rr['network'], $rr['url']),
'id' => ++$id,
2015-10-17 15:25:21 -04:00
);
$entries[] = $entry;
2011-11-01 23:29:55 -04:00
}
$tpl = get_markup_template('viewcontact_template.tpl');
2015-10-17 15:25:21 -04:00
$o .= replace_macros($tpl,array(
'$title' => t('Friend Suggestions'),
'$contacts' => $entries,
2015-10-17 15:25:21 -04:00
));
2011-11-01 23:29:55 -04:00
return $o;
}