2011-11-10 02:33:08 +00:00
|
|
|
<?php
|
2018-01-05 00:42:48 +00:00
|
|
|
|
2017-11-15 14:47:28 +00:00
|
|
|
/**
|
|
|
|
* @file mod/allfriends.php
|
|
|
|
*/
|
2017-04-30 04:07:00 +00:00
|
|
|
use Friendica\App;
|
2018-01-10 03:42:04 +00:00
|
|
|
use Friendica\Content\ContactSelector;
|
2017-08-26 06:04:21 +00:00
|
|
|
use Friendica\Core\System;
|
2017-11-08 03:57:46 +00:00
|
|
|
use Friendica\Database\DBM;
|
2017-12-07 14:04:24 +00:00
|
|
|
use Friendica\Model\Contact;
|
2017-12-07 14:09:28 +00:00
|
|
|
use Friendica\Model\GContact;
|
2017-04-30 04:07:00 +00:00
|
|
|
|
2017-11-15 14:47:28 +00:00
|
|
|
require_once 'mod/contacts.php';
|
2011-11-10 02:33:08 +00:00
|
|
|
|
2018-01-05 00:42:48 +00:00
|
|
|
function allfriends_content(App $a)
|
|
|
|
{
|
2011-11-10 02:33:08 +00:00
|
|
|
$o = '';
|
2018-01-05 00:42:48 +00:00
|
|
|
if (!local_user()) {
|
|
|
|
notice(t('Permission denied.') . EOL);
|
2011-11-10 02:33:08 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-01-05 00:42:48 +00:00
|
|
|
$cid = 0;
|
2016-12-20 10:56:34 +00:00
|
|
|
if ($a->argc > 1) {
|
2011-11-10 02:33:08 +00:00
|
|
|
$cid = intval($a->argv[1]);
|
2016-12-20 10:56:34 +00:00
|
|
|
}
|
2015-10-27 14:27:26 +00:00
|
|
|
|
2018-01-05 00:42:48 +00:00
|
|
|
if (!$cid) {
|
2011-11-10 02:33:08 +00:00
|
|
|
return;
|
2016-12-20 10:56:34 +00:00
|
|
|
}
|
2011-11-10 02:33:08 +00:00
|
|
|
|
2016-12-20 09:58:55 +00:00
|
|
|
$uid = $a->user['uid'];
|
2015-11-03 13:31:15 +00:00
|
|
|
|
2015-10-27 14:27:26 +00:00
|
|
|
$c = q("SELECT `name`, `url`, `photo` FROM `contact` WHERE `id` = %d AND `uid` = %d LIMIT 1",
|
2011-11-10 02:33:08 +00:00
|
|
|
intval($cid),
|
|
|
|
intval(local_user())
|
|
|
|
);
|
|
|
|
|
2018-01-05 00:42:48 +00:00
|
|
|
if (!DBM::is_result($c)) {
|
2011-11-10 02:33:08 +00:00
|
|
|
return;
|
2016-12-20 16:43:46 +00:00
|
|
|
}
|
2011-11-10 02:33:08 +00:00
|
|
|
|
2015-12-01 07:12:05 +00:00
|
|
|
$a->page['aside'] = "";
|
2017-11-19 22:03:39 +00:00
|
|
|
profile_load($a, "", 0, Contact::getDetailsByURL($c[0]["url"]));
|
2011-11-10 02:33:08 +00:00
|
|
|
|
2017-12-07 14:09:28 +00:00
|
|
|
$total = GContact::countAllFriends(local_user(), $cid);
|
2015-12-15 13:31:24 +00:00
|
|
|
|
2018-01-05 00:42:48 +00:00
|
|
|
$a->set_pager_total($total);
|
2015-12-15 13:31:24 +00:00
|
|
|
|
2017-12-07 14:09:28 +00:00
|
|
|
$r = GContact::allFriends(local_user(), $cid, $a->pager['start'], $a->pager['itemspage']);
|
2018-01-05 00:42:48 +00:00
|
|
|
if (!DBM::is_result($r)) {
|
2011-11-10 02:33:08 +00:00
|
|
|
$o .= t('No friends to display.');
|
|
|
|
return $o;
|
|
|
|
}
|
|
|
|
|
2015-10-27 14:27:26 +00:00
|
|
|
$id = 0;
|
2011-11-10 02:33:08 +00:00
|
|
|
|
2018-01-05 00:42:48 +00:00
|
|
|
$entries = [];
|
2016-12-20 20:15:53 +00:00
|
|
|
foreach ($r as $rr) {
|
2015-11-03 13:31:15 +00:00
|
|
|
//get further details of the contact
|
2017-11-19 22:03:39 +00:00
|
|
|
$contact_details = Contact::getDetailsByURL($rr['url'], $uid, $rr);
|
2015-11-03 13:31:15 +00:00
|
|
|
|
|
|
|
$photo_menu = '';
|
|
|
|
|
2018-01-05 00:42:48 +00:00
|
|
|
$connlnk = '';
|
2015-11-03 13:31:15 +00:00
|
|
|
// $rr[cid] is only available for common contacts. So if the contact is a common one, use contact_photo_menu to generate the photo_menu
|
|
|
|
// If the contact is not common to the user, Connect/Follow' will be added to the photo menu
|
2018-01-05 00:42:48 +00:00
|
|
|
if ($rr['cid']) {
|
|
|
|
$rr['id'] = $rr['cid'];
|
|
|
|
$photo_menu = Contact::photoMenu($rr);
|
|
|
|
} else {
|
2017-08-26 07:32:10 +00:00
|
|
|
$connlnk = System::baseUrl() . '/follow/?url=' . $rr['url'];
|
2016-06-06 14:54:29 +00:00
|
|
|
$photo_menu = array(
|
|
|
|
'profile' => array(t("View Profile"), zrl($rr['url'])),
|
|
|
|
'follow' => array(t("Connect/Follow"), $connlnk)
|
|
|
|
);
|
2015-11-03 13:31:15 +00:00
|
|
|
}
|
|
|
|
|
2015-10-27 14:27:26 +00:00
|
|
|
$entry = array(
|
2016-12-22 16:03:00 +00:00
|
|
|
'url' => $rr['url'],
|
2018-01-05 00:42:48 +00:00
|
|
|
'itemurl' => defaults($contact_details, 'addr', $rr['url']),
|
2016-12-22 16:03:00 +00:00
|
|
|
'name' => htmlentities($contact_details['name']),
|
|
|
|
'thumb' => proxy_url($contact_details['thumb'], false, PROXY_SIZE_THUMB),
|
|
|
|
'img_hover' => htmlentities($contact_details['name']),
|
|
|
|
'details' => $contact_details['location'],
|
|
|
|
'tags' => $contact_details['keywords'],
|
|
|
|
'about' => $contact_details['about'],
|
2017-11-19 22:03:39 +00:00
|
|
|
'account_type' => Contact::getAccountType($contact_details),
|
2018-01-10 03:42:04 +00:00
|
|
|
'network' => ContactSelector::networkToName($contact_details['network'], $contact_details['url']),
|
2016-12-22 16:03:00 +00:00
|
|
|
'photo_menu' => $photo_menu,
|
|
|
|
'conntxt' => t('Connect'),
|
|
|
|
'connlnk' => $connlnk,
|
|
|
|
'id' => ++$id,
|
2015-10-27 14:27:26 +00:00
|
|
|
);
|
|
|
|
$entries[] = $entry;
|
2011-11-10 02:33:08 +00:00
|
|
|
}
|
|
|
|
|
2015-12-01 07:12:05 +00:00
|
|
|
$tab_str = contacts_tab($a, $cid, 3);
|
|
|
|
|
2015-10-27 14:27:26 +00:00
|
|
|
$tpl = get_markup_template('viewcontact_template.tpl');
|
|
|
|
|
2018-01-05 00:42:48 +00:00
|
|
|
$o .= replace_macros($tpl, array(
|
2015-12-01 17:21:05 +00:00
|
|
|
//'$title' => sprintf( t('Friends of %s'), htmlentities($c[0]['name'])),
|
2015-12-01 07:12:05 +00:00
|
|
|
'$tab_str' => $tab_str,
|
2015-10-27 14:27:26 +00:00
|
|
|
'$contacts' => $entries,
|
2015-12-15 13:31:24 +00:00
|
|
|
'$paginate' => paginate($a),
|
2015-10-27 14:27:26 +00:00
|
|
|
));
|
|
|
|
|
2011-11-10 02:33:08 +00:00
|
|
|
return $o;
|
|
|
|
}
|