Merge pull request #7156 from MrPetovan/task/add-relationship-filter
Add contact relationship filter
This commit is contained in:
commit
bd0c536736
19 changed files with 276 additions and 168 deletions
|
@ -147,7 +147,7 @@ function cal_content(App $a)
|
||||||
$sql_extra = " AND `event`.`cid` = 0 " . $sql_perms;
|
$sql_extra = " AND `event`.`cid` = 0 " . $sql_perms;
|
||||||
|
|
||||||
// get the tab navigation bar
|
// get the tab navigation bar
|
||||||
$tabs = Profile::getTabs($a, false, $a->data['user']['nickname']);
|
$tabs = Profile::getTabs($a, 'cal', false, $a->data['user']['nickname']);
|
||||||
|
|
||||||
// The view mode part is similiar to /mod/events.php
|
// The view mode part is similiar to /mod/events.php
|
||||||
if ($mode == 'view') {
|
if ($mode == 'view') {
|
||||||
|
|
|
@ -246,7 +246,7 @@ function events_content(App $a)
|
||||||
$tabs = '';
|
$tabs = '';
|
||||||
// tabs
|
// tabs
|
||||||
if ($a->theme_events_in_profile) {
|
if ($a->theme_events_in_profile) {
|
||||||
$tabs = Profile::getTabs($a, true);
|
$tabs = Profile::getTabs($a, 'events', true);
|
||||||
}
|
}
|
||||||
|
|
||||||
$mode = 'view';
|
$mode = 'view';
|
||||||
|
|
|
@ -28,7 +28,7 @@ function notes_content(App $a, $update = false)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$o = Profile::getTabs($a, true);
|
$o = Profile::getTabs($a, 'notes', true);
|
||||||
|
|
||||||
if (!$update) {
|
if (!$update) {
|
||||||
$o .= '<h3>' . L10n::t('Personal Notes') . '</h3>';
|
$o .= '<h3>' . L10n::t('Personal Notes') . '</h3>';
|
||||||
|
|
|
@ -950,7 +950,7 @@ function photos_content(App $a)
|
||||||
|
|
||||||
// tabs
|
// tabs
|
||||||
$is_owner = (local_user() && (local_user() == $owner_uid));
|
$is_owner = (local_user() && (local_user() == $owner_uid));
|
||||||
$o .= Profile::getTabs($a, $is_owner, $a->data['user']['nickname']);
|
$o .= Profile::getTabs($a, 'photos', $is_owner, $a->data['user']['nickname']);
|
||||||
|
|
||||||
// Display upload form
|
// Display upload form
|
||||||
if ($datatype === 'upload') {
|
if ($datatype === 'upload') {
|
||||||
|
|
|
@ -217,7 +217,7 @@ function videos_content(App $a)
|
||||||
|
|
||||||
// tabs
|
// tabs
|
||||||
$_is_owner = (local_user() && (local_user() == $owner_uid));
|
$_is_owner = (local_user() && (local_user() == $owner_uid));
|
||||||
$o .= Profile::getTabs($a, $_is_owner, $a->data['user']['nickname']);
|
$o .= Profile::getTabs($a, 'videos', $_is_owner, $a->data['user']['nickname']);
|
||||||
|
|
||||||
//
|
//
|
||||||
// dispatch request
|
// dispatch request
|
||||||
|
|
|
@ -1,120 +0,0 @@
|
||||||
<?php
|
|
||||||
/**
|
|
||||||
* @file mod/viewcontacts.php
|
|
||||||
*/
|
|
||||||
|
|
||||||
use Friendica\App;
|
|
||||||
use Friendica\Content\ContactSelector;
|
|
||||||
use Friendica\Content\Nav;
|
|
||||||
use Friendica\Content\Pager;
|
|
||||||
use Friendica\Core\Config;
|
|
||||||
use Friendica\Core\L10n;
|
|
||||||
use Friendica\Core\Protocol;
|
|
||||||
use Friendica\Core\Renderer;
|
|
||||||
use Friendica\Core\System;
|
|
||||||
use Friendica\Database\DBA;
|
|
||||||
use Friendica\Model\Contact;
|
|
||||||
use Friendica\Model\Profile;
|
|
||||||
use Friendica\Util\Proxy as ProxyUtils;
|
|
||||||
|
|
||||||
function viewcontacts_init(App $a)
|
|
||||||
{
|
|
||||||
if (Config::get('system', 'block_public') && !local_user() && !remote_user()) {
|
|
||||||
throw new \Friendica\Network\HTTPException\ForbiddenException(L10n::t('Access denied.'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($a->argc < 2) {
|
|
||||||
throw new \Friendica\Network\HTTPException\ForbiddenException(L10n::t('Access denied.'));
|
|
||||||
}
|
|
||||||
|
|
||||||
Nav::setSelected('home');
|
|
||||||
|
|
||||||
$user = DBA::selectFirst('user', [], ['nickname' => $a->argv[1], 'blocked' => false]);
|
|
||||||
if (!DBA::isResult($user)) {
|
|
||||||
throw new \Friendica\Network\HTTPException\NotFoundException();
|
|
||||||
}
|
|
||||||
|
|
||||||
$a->data['user'] = $user;
|
|
||||||
$a->profile_uid = $user['uid'];
|
|
||||||
|
|
||||||
Profile::load($a, $a->argv[1]);
|
|
||||||
}
|
|
||||||
|
|
||||||
function viewcontacts_content(App $a)
|
|
||||||
{
|
|
||||||
if (Config::get('system', 'block_public') && !local_user() && !remote_user()) {
|
|
||||||
notice(L10n::t('Public access denied.') . EOL);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$is_owner = $a->profile['profile_uid'] == local_user();
|
|
||||||
|
|
||||||
// tabs
|
|
||||||
$o = Profile::getTabs($a, $is_owner, $a->data['user']['nickname']);
|
|
||||||
|
|
||||||
if (!count($a->profile) || $a->profile['hide-friends']) {
|
|
||||||
notice(L10n::t('Permission denied.') . EOL);
|
|
||||||
return $o;
|
|
||||||
}
|
|
||||||
|
|
||||||
$condition = [
|
|
||||||
'uid' => $a->profile['uid'],
|
|
||||||
'blocked' => false,
|
|
||||||
'pending' => false,
|
|
||||||
'hidden' => false,
|
|
||||||
'archive' => false,
|
|
||||||
'network' => [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS]
|
|
||||||
];
|
|
||||||
|
|
||||||
$total = DBA::count('contact', $condition);
|
|
||||||
|
|
||||||
$pager = new Pager($a->query_string);
|
|
||||||
|
|
||||||
$params = ['order' => ['name' => false], 'limit' => [$pager->getStart(), $pager->getItemsPerPage()]];
|
|
||||||
|
|
||||||
$contacts_stmt = DBA::select('contact', [], $condition, $params);
|
|
||||||
|
|
||||||
if (!DBA::isResult($contacts_stmt)) {
|
|
||||||
info(L10n::t('No contacts.') . EOL);
|
|
||||||
return $o;
|
|
||||||
}
|
|
||||||
|
|
||||||
$contacts = [];
|
|
||||||
|
|
||||||
while ($contact = DBA::fetch($contacts_stmt)) {
|
|
||||||
/// @TODO This triggers an E_NOTICE if 'self' is not there
|
|
||||||
if ($contact['self']) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
$contact_details = Contact::getDetailsByURL($contact['url'], $a->profile['uid'], $contact);
|
|
||||||
|
|
||||||
$contacts[] = [
|
|
||||||
'id' => $contact['id'],
|
|
||||||
'img_hover' => L10n::t('Visit %s\'s profile [%s]', $contact_details['name'], $contact['url']),
|
|
||||||
'photo_menu' => Contact::photoMenu($contact),
|
|
||||||
'thumb' => ProxyUtils::proxifyUrl($contact_details['thumb'], false, ProxyUtils::SIZE_THUMB),
|
|
||||||
'name' => substr($contact_details['name'], 0, 20),
|
|
||||||
'username' => $contact_details['name'],
|
|
||||||
'details' => $contact_details['location'],
|
|
||||||
'tags' => $contact_details['keywords'],
|
|
||||||
'about' => $contact_details['about'],
|
|
||||||
'account_type' => Contact::getAccountType($contact_details),
|
|
||||||
'url' => Contact::magicLink($contact['url']),
|
|
||||||
'sparkle' => '',
|
|
||||||
'itemurl' => (($contact_details['addr'] != "") ? $contact_details['addr'] : $contact['url']),
|
|
||||||
'network' => ContactSelector::networkToName($contact['network'], $contact['url']),
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
DBA::close($contacts_stmt);
|
|
||||||
|
|
||||||
$tpl = Renderer::getMarkupTemplate("viewcontact_template.tpl");
|
|
||||||
$o .= Renderer::replaceMacros($tpl, [
|
|
||||||
'$title' => L10n::t('Contacts'),
|
|
||||||
'$contacts' => $contacts,
|
|
||||||
'$paginate' => $pager->renderFull($total),
|
|
||||||
]);
|
|
||||||
|
|
||||||
return $o;
|
|
||||||
}
|
|
|
@ -187,6 +187,7 @@ class Router
|
||||||
$this->routeCollector->addRoute(['GET'], '/probe', Module\Debug\Probe::class);
|
$this->routeCollector->addRoute(['GET'], '/probe', Module\Debug\Probe::class);
|
||||||
$this->routeCollector->addGroup('/profile', function (RouteCollector $collector) {
|
$this->routeCollector->addGroup('/profile', function (RouteCollector $collector) {
|
||||||
$collector->addRoute(['GET'], '/{nickname}', Module\Profile::class);
|
$collector->addRoute(['GET'], '/{nickname}', Module\Profile::class);
|
||||||
|
$collector->addRoute(['GET'], '/{nickname}/contacts[/{type}]', Module\Profile\Contacts::class);
|
||||||
$collector->addRoute(['GET'], '/{profile:\d+}/view', Module\Profile::class);
|
$collector->addRoute(['GET'], '/{profile:\d+}/view', Module\Profile::class);
|
||||||
});
|
});
|
||||||
$this->routeCollector->addGroup('/proxy', function (RouteCollector $collector) {
|
$this->routeCollector->addGroup('/proxy', function (RouteCollector $collector) {
|
||||||
|
|
|
@ -121,17 +121,28 @@ class Widget
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $type
|
* Display a generic filter widget based on a list of options
|
||||||
|
*
|
||||||
|
* The options array must be the following format:
|
||||||
|
* [
|
||||||
|
* [
|
||||||
|
* 'ref' => {filter value},
|
||||||
|
* 'name' => {option name}
|
||||||
|
* ],
|
||||||
|
* ...
|
||||||
|
* ]
|
||||||
|
*
|
||||||
|
* @param string $type The filter query string key
|
||||||
* @param string $title
|
* @param string $title
|
||||||
* @param string $desc
|
* @param string $desc
|
||||||
* @param string $all
|
* @param string $all The no filter label
|
||||||
* @param string $baseUrl
|
* @param string $baseUrl The full page request URI
|
||||||
* @param array $options
|
* @param array $options
|
||||||
* @param string $selected
|
* @param string $selected The currently selected filter option value
|
||||||
* @return string
|
* @return string
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public static function filter($type, $title, $desc, $all, $baseUrl, array $options, $selected = null)
|
private static function filter($type, $title, $desc, $all, $baseUrl, array $options, $selected = null)
|
||||||
{
|
{
|
||||||
$queryString = parse_url($baseUrl, PHP_URL_QUERY);
|
$queryString = parse_url($baseUrl, PHP_URL_QUERY);
|
||||||
$queryArray = [];
|
$queryArray = [];
|
||||||
|
@ -160,6 +171,37 @@ class Widget
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return networks widget
|
||||||
|
*
|
||||||
|
* @param string $baseurl baseurl
|
||||||
|
* @param string $selected optional, default empty
|
||||||
|
* @return string
|
||||||
|
* @throws \Exception
|
||||||
|
*/
|
||||||
|
public static function contactRels($baseurl, $selected = '')
|
||||||
|
{
|
||||||
|
if (!local_user()) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$options = [
|
||||||
|
['ref' => 'followers', 'name' => L10n::t('Followers')],
|
||||||
|
['ref' => 'following', 'name' => L10n::t('Following')],
|
||||||
|
['ref' => 'mutuals', 'name' => L10n::t('Mutual friends')],
|
||||||
|
];
|
||||||
|
|
||||||
|
return self::filter(
|
||||||
|
'rel',
|
||||||
|
L10n::t('Relationships'),
|
||||||
|
'',
|
||||||
|
L10n::t('All Contacts'),
|
||||||
|
$baseurl,
|
||||||
|
$options,
|
||||||
|
$selected
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return networks widget
|
* Return networks widget
|
||||||
*
|
*
|
||||||
|
|
|
@ -52,7 +52,7 @@ class ContactBlock
|
||||||
'pending' => false,
|
'pending' => false,
|
||||||
'hidden' => false,
|
'hidden' => false,
|
||||||
'archive' => false,
|
'archive' => false,
|
||||||
'network' => [Protocol::DFRN, Protocol::ACTIVITYPUB, Protocol::OSTATUS, Protocol::DIASPORA],
|
'network' => [Protocol::DFRN, Protocol::ACTIVITYPUB, Protocol::OSTATUS, Protocol::DIASPORA, Protocol::FEED],
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$contacts_title = L10n::t('No contacts');
|
$contacts_title = L10n::t('No contacts');
|
||||||
|
|
|
@ -877,32 +877,35 @@ class Profile
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function getTabs($a, $is_owner = false, $nickname = null)
|
/**
|
||||||
|
* @param App $a
|
||||||
|
* @param string $current
|
||||||
|
* @param bool $is_owner
|
||||||
|
* @param string $nickname
|
||||||
|
* @return string
|
||||||
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
|
*/
|
||||||
|
public static function getTabs(App $a, string $current, bool $is_owner, string $nickname = null)
|
||||||
{
|
{
|
||||||
if (is_null($nickname)) {
|
if (is_null($nickname)) {
|
||||||
$nickname = $a->user['nickname'];
|
$nickname = $a->user['nickname'];
|
||||||
}
|
}
|
||||||
|
|
||||||
$tab = false;
|
$baseProfileUrl = System::baseUrl() . '/profile/' . $nickname;
|
||||||
if (!empty($_GET['tab'])) {
|
|
||||||
$tab = Strings::escapeTags(trim($_GET['tab']));
|
|
||||||
}
|
|
||||||
|
|
||||||
$url = System::baseUrl() . '/profile/' . $nickname;
|
|
||||||
|
|
||||||
$tabs = [
|
$tabs = [
|
||||||
[
|
[
|
||||||
'label' => L10n::t('Status'),
|
'label' => L10n::t('Status'),
|
||||||
'url' => $url,
|
'url' => $baseProfileUrl,
|
||||||
'sel' => !$tab && $a->argv[0] == 'profile' ? 'active' : '',
|
'sel' => !$current ? 'active' : '',
|
||||||
'title' => L10n::t('Status Messages and Posts'),
|
'title' => L10n::t('Status Messages and Posts'),
|
||||||
'id' => 'status-tab',
|
'id' => 'status-tab',
|
||||||
'accesskey' => 'm',
|
'accesskey' => 'm',
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
'label' => L10n::t('Profile'),
|
'label' => L10n::t('Profile'),
|
||||||
'url' => $url . '/?tab=profile',
|
'url' => $baseProfileUrl . '/?tab=profile',
|
||||||
'sel' => $tab == 'profile' ? 'active' : '',
|
'sel' => $current == 'profile' ? 'active' : '',
|
||||||
'title' => L10n::t('Profile Details'),
|
'title' => L10n::t('Profile Details'),
|
||||||
'id' => 'profile-tab',
|
'id' => 'profile-tab',
|
||||||
'accesskey' => 'r',
|
'accesskey' => 'r',
|
||||||
|
@ -910,7 +913,7 @@ class Profile
|
||||||
[
|
[
|
||||||
'label' => L10n::t('Photos'),
|
'label' => L10n::t('Photos'),
|
||||||
'url' => System::baseUrl() . '/photos/' . $nickname,
|
'url' => System::baseUrl() . '/photos/' . $nickname,
|
||||||
'sel' => !$tab && $a->argv[0] == 'photos' ? 'active' : '',
|
'sel' => $current == 'photos' ? 'active' : '',
|
||||||
'title' => L10n::t('Photo Albums'),
|
'title' => L10n::t('Photo Albums'),
|
||||||
'id' => 'photo-tab',
|
'id' => 'photo-tab',
|
||||||
'accesskey' => 'h',
|
'accesskey' => 'h',
|
||||||
|
@ -918,7 +921,7 @@ class Profile
|
||||||
[
|
[
|
||||||
'label' => L10n::t('Videos'),
|
'label' => L10n::t('Videos'),
|
||||||
'url' => System::baseUrl() . '/videos/' . $nickname,
|
'url' => System::baseUrl() . '/videos/' . $nickname,
|
||||||
'sel' => !$tab && $a->argv[0] == 'videos' ? 'active' : '',
|
'sel' => $current == 'videos' ? 'active' : '',
|
||||||
'title' => L10n::t('Videos'),
|
'title' => L10n::t('Videos'),
|
||||||
'id' => 'video-tab',
|
'id' => 'video-tab',
|
||||||
'accesskey' => 'v',
|
'accesskey' => 'v',
|
||||||
|
@ -930,7 +933,7 @@ class Profile
|
||||||
$tabs[] = [
|
$tabs[] = [
|
||||||
'label' => L10n::t('Events'),
|
'label' => L10n::t('Events'),
|
||||||
'url' => System::baseUrl() . '/events',
|
'url' => System::baseUrl() . '/events',
|
||||||
'sel' => !$tab && $a->argv[0] == 'events' ? 'active' : '',
|
'sel' => $current == 'events' ? 'active' : '',
|
||||||
'title' => L10n::t('Events and Calendar'),
|
'title' => L10n::t('Events and Calendar'),
|
||||||
'id' => 'events-tab',
|
'id' => 'events-tab',
|
||||||
'accesskey' => 'e',
|
'accesskey' => 'e',
|
||||||
|
@ -941,7 +944,7 @@ class Profile
|
||||||
$tabs[] = [
|
$tabs[] = [
|
||||||
'label' => L10n::t('Events'),
|
'label' => L10n::t('Events'),
|
||||||
'url' => System::baseUrl() . '/cal/' . $nickname,
|
'url' => System::baseUrl() . '/cal/' . $nickname,
|
||||||
'sel' => !$tab && $a->argv[0] == 'cal' ? 'active' : '',
|
'sel' => $current == 'cal' ? 'active' : '',
|
||||||
'title' => L10n::t('Events and Calendar'),
|
'title' => L10n::t('Events and Calendar'),
|
||||||
'id' => 'events-tab',
|
'id' => 'events-tab',
|
||||||
'accesskey' => 'e',
|
'accesskey' => 'e',
|
||||||
|
@ -952,7 +955,7 @@ class Profile
|
||||||
$tabs[] = [
|
$tabs[] = [
|
||||||
'label' => L10n::t('Personal Notes'),
|
'label' => L10n::t('Personal Notes'),
|
||||||
'url' => System::baseUrl() . '/notes',
|
'url' => System::baseUrl() . '/notes',
|
||||||
'sel' => !$tab && $a->argv[0] == 'notes' ? 'active' : '',
|
'sel' => $current == 'notes' ? 'active' : '',
|
||||||
'title' => L10n::t('Only You Can See This'),
|
'title' => L10n::t('Only You Can See This'),
|
||||||
'id' => 'notes-tab',
|
'id' => 'notes-tab',
|
||||||
'accesskey' => 't',
|
'accesskey' => 't',
|
||||||
|
@ -969,18 +972,18 @@ class Profile
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$is_owner && empty($a->profile['hide-friends'])) {
|
if ($is_owner || empty($a->profile['hide-friends'])) {
|
||||||
$tabs[] = [
|
$tabs[] = [
|
||||||
'label' => L10n::t('Contacts'),
|
'label' => L10n::t('Contacts'),
|
||||||
'url' => System::baseUrl() . '/viewcontacts/' . $nickname,
|
'url' => $baseProfileUrl . '/contacts',
|
||||||
'sel' => !$tab && $a->argv[0] == 'viewcontacts' ? 'active' : '',
|
'sel' => $current == 'contacts' ? 'active' : '',
|
||||||
'title' => L10n::t('Contacts'),
|
'title' => L10n::t('Contacts'),
|
||||||
'id' => 'viewcontacts-tab',
|
'id' => 'viewcontacts-tab',
|
||||||
'accesskey' => 'k',
|
'accesskey' => 'k',
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
$arr = ['is_owner' => $is_owner, 'nickname' => $nickname, 'tab' => $tab, 'tabs' => $tabs];
|
$arr = ['is_owner' => $is_owner, 'nickname' => $nickname, 'tab' => $current, 'tabs' => $tabs];
|
||||||
Hook::callAll('profile_tabs', $arr);
|
Hook::callAll('profile_tabs', $arr);
|
||||||
|
|
||||||
$tpl = Renderer::getMarkupTemplate('common_tabs.tpl');
|
$tpl = Renderer::getMarkupTemplate('common_tabs.tpl');
|
||||||
|
|
|
@ -266,6 +266,7 @@ class Contact extends BaseModule
|
||||||
$a = self::getApp();
|
$a = self::getApp();
|
||||||
|
|
||||||
$nets = defaults($_GET, 'nets', '');
|
$nets = defaults($_GET, 'nets', '');
|
||||||
|
$rel = defaults($_GET, 'rel' , '');
|
||||||
|
|
||||||
if (empty($a->page['aside'])) {
|
if (empty($a->page['aside'])) {
|
||||||
$a->page['aside'] = '';
|
$a->page['aside'] = '';
|
||||||
|
@ -321,6 +322,7 @@ class Contact extends BaseModule
|
||||||
$findpeople_widget = '';
|
$findpeople_widget = '';
|
||||||
$follow_widget = '';
|
$follow_widget = '';
|
||||||
$networks_widget = '';
|
$networks_widget = '';
|
||||||
|
$rel_widget = '';
|
||||||
} else {
|
} else {
|
||||||
$vcard_widget = '';
|
$vcard_widget = '';
|
||||||
$findpeople_widget = Widget::findPeople();
|
$findpeople_widget = Widget::findPeople();
|
||||||
|
@ -331,6 +333,7 @@ class Contact extends BaseModule
|
||||||
}
|
}
|
||||||
|
|
||||||
$networks_widget = Widget::networks($_SERVER['REQUEST_URI'], $nets);
|
$networks_widget = Widget::networks($_SERVER['REQUEST_URI'], $nets);
|
||||||
|
$rel_widget = Widget::contactRels($_SERVER['REQUEST_URI'], $rel);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($contact['uid'] != 0) {
|
if ($contact['uid'] != 0) {
|
||||||
|
@ -339,7 +342,7 @@ class Contact extends BaseModule
|
||||||
$groups_widget = null;
|
$groups_widget = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
$a->page['aside'] .= $vcard_widget . $findpeople_widget . $follow_widget . $groups_widget . $networks_widget;
|
$a->page['aside'] .= $vcard_widget . $findpeople_widget . $follow_widget . $groups_widget . $networks_widget . $rel_widget;
|
||||||
|
|
||||||
$tpl = Renderer::getMarkupTemplate('contacts-head.tpl');
|
$tpl = Renderer::getMarkupTemplate('contacts-head.tpl');
|
||||||
$a->page['htmlhead'] .= Renderer::replaceMacros($tpl, [
|
$a->page['htmlhead'] .= Renderer::replaceMacros($tpl, [
|
||||||
|
@ -678,6 +681,7 @@ class Contact extends BaseModule
|
||||||
|
|
||||||
$search = Strings::escapeTags(trim(defaults($_GET, 'search', '')));
|
$search = Strings::escapeTags(trim(defaults($_GET, 'search', '')));
|
||||||
$nets = Strings::escapeTags(trim(defaults($_GET, 'nets' , '')));
|
$nets = Strings::escapeTags(trim(defaults($_GET, 'nets' , '')));
|
||||||
|
$rel = Strings::escapeTags(trim(defaults($_GET, 'rel' , '')));
|
||||||
|
|
||||||
$tabs = [
|
$tabs = [
|
||||||
[
|
[
|
||||||
|
@ -747,6 +751,12 @@ class Contact extends BaseModule
|
||||||
$sql_extra .= sprintf(" AND network = '%s' ", DBA::escape($nets));
|
$sql_extra .= sprintf(" AND network = '%s' ", DBA::escape($nets));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
switch ($rel) {
|
||||||
|
case 'followers': $sql_extra .= " AND `rel` IN (1, 3)"; break;
|
||||||
|
case 'following': $sql_extra .= " AND `rel` IN (2, 3)"; break;
|
||||||
|
case 'mutuals': $sql_extra .= " AND `rel` = 3"; break;
|
||||||
|
}
|
||||||
|
|
||||||
$sql_extra .= " AND NOT `deleted` ";
|
$sql_extra .= " AND NOT `deleted` ";
|
||||||
|
|
||||||
$sql_extra2 = ((($sort_type > 0) && ($sort_type <= Model\Contact::FRIEND)) ? sprintf(" AND `rel` = %d ", intval($sort_type)) : '');
|
$sql_extra2 = ((($sort_type > 0) && ($sort_type <= Model\Contact::FRIEND)) ? sprintf(" AND `rel` = %d ", intval($sort_type)) : '');
|
||||||
|
@ -777,6 +787,13 @@ class Contact extends BaseModule
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
switch ($rel) {
|
||||||
|
case 'followers': $header = L10n::t('Followers'); break;
|
||||||
|
case 'following': $header = L10n::t('Following'); break;
|
||||||
|
case 'mutuals': $header = L10n::t('Mutual friends'); break;
|
||||||
|
default: $header = L10n::t('Contacts');
|
||||||
|
}
|
||||||
|
|
||||||
switch ($type) {
|
switch ($type) {
|
||||||
case 'blocked': $header .= ' - ' . L10n::t('Blocked'); break;
|
case 'blocked': $header .= ' - ' . L10n::t('Blocked'); break;
|
||||||
case 'hidden': $header .= ' - ' . L10n::t('Hidden'); break;
|
case 'hidden': $header .= ' - ' . L10n::t('Hidden'); break;
|
||||||
|
|
|
@ -178,12 +178,9 @@ class Profile extends BaseModule
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$update) {
|
if (!$update) {
|
||||||
$tab = false;
|
$tab = Strings::escapeTags(trim(defaults($_GET, 'tab', '')));
|
||||||
if (!empty($_GET['tab'])) {
|
|
||||||
$tab = Strings::escapeTags(trim($_GET['tab']));
|
|
||||||
}
|
|
||||||
|
|
||||||
$o .= ProfileModel::getTabs($a, $is_owner, $a->profile['nickname']);
|
$o .= ProfileModel::getTabs($a, $tab, $is_owner, $a->profile['nickname']);
|
||||||
|
|
||||||
if ($tab === 'profile') {
|
if ($tab === 'profile') {
|
||||||
$o .= ProfileModel::getAdvanced($a);
|
$o .= ProfileModel::getAdvanced($a);
|
||||||
|
|
136
src/Module/Profile/Contacts.php
Normal file
136
src/Module/Profile/Contacts.php
Normal file
|
@ -0,0 +1,136 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Friendica\Module\Profile;
|
||||||
|
|
||||||
|
use Friendica\BaseModule;
|
||||||
|
use Friendica\Content\ContactSelector;
|
||||||
|
use Friendica\Content\Nav;
|
||||||
|
use Friendica\Content\Pager;
|
||||||
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Core\L10n;
|
||||||
|
use Friendica\Core\Protocol;
|
||||||
|
use Friendica\Core\Renderer;
|
||||||
|
use Friendica\Database\DBA;
|
||||||
|
use Friendica\Model\Contact;
|
||||||
|
use Friendica\Model\Profile;
|
||||||
|
use Friendica\Util\Proxy as ProxyUtils;
|
||||||
|
|
||||||
|
class Contacts extends BaseModule
|
||||||
|
{
|
||||||
|
public static function content()
|
||||||
|
{
|
||||||
|
if (Config::get('system', 'block_public') && !local_user() && !remote_user()) {
|
||||||
|
throw new \Friendica\Network\HTTPException\NotFoundException(L10n::t('User not found.'));
|
||||||
|
}
|
||||||
|
|
||||||
|
$a = self::getApp();
|
||||||
|
|
||||||
|
//@TODO: Get value from router parameters
|
||||||
|
$nickname = $a->argv[1];
|
||||||
|
$type = defaults($a->argv, 3, 'all');
|
||||||
|
|
||||||
|
Nav::setSelected('home');
|
||||||
|
|
||||||
|
$user = DBA::selectFirst('user', [], ['nickname' => $nickname, 'blocked' => false]);
|
||||||
|
if (!DBA::isResult($user)) {
|
||||||
|
throw new \Friendica\Network\HTTPException\NotFoundException(L10n::t('User not found.'));
|
||||||
|
}
|
||||||
|
|
||||||
|
$a->data['user'] = $user;
|
||||||
|
$a->profile_uid = $user['uid'];
|
||||||
|
|
||||||
|
Profile::load($a, $nickname);
|
||||||
|
|
||||||
|
$is_owner = $a->profile['profile_uid'] == local_user();
|
||||||
|
|
||||||
|
// tabs
|
||||||
|
$o = Profile::getTabs($a, 'contacts', $is_owner, $nickname);
|
||||||
|
|
||||||
|
if (!count($a->profile) || $a->profile['hide-friends']) {
|
||||||
|
notice(L10n::t('Permission denied.') . EOL);
|
||||||
|
return $o;
|
||||||
|
}
|
||||||
|
|
||||||
|
$condition = [
|
||||||
|
'uid' => $a->profile['uid'],
|
||||||
|
'blocked' => false,
|
||||||
|
'pending' => false,
|
||||||
|
'hidden' => false,
|
||||||
|
'archive' => false,
|
||||||
|
'network' => [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS, Protocol::FEED]
|
||||||
|
];
|
||||||
|
|
||||||
|
switch ($type) {
|
||||||
|
case 'followers': $condition['rel'] = [1, 3]; break;
|
||||||
|
case 'following': $condition['rel'] = [2, 3]; break;
|
||||||
|
case 'mutuals': $condition['rel'] = 3; break;
|
||||||
|
}
|
||||||
|
|
||||||
|
$total = DBA::count('contact', $condition);
|
||||||
|
|
||||||
|
$pager = new Pager($a->query_string);
|
||||||
|
|
||||||
|
$params = ['order' => ['name' => false], 'limit' => [$pager->getStart(), $pager->getItemsPerPage()]];
|
||||||
|
|
||||||
|
$contacts_stmt = DBA::select('contact', [], $condition, $params);
|
||||||
|
|
||||||
|
if (!DBA::isResult($contacts_stmt)) {
|
||||||
|
info(L10n::t('No contacts.') . EOL);
|
||||||
|
return $o;
|
||||||
|
}
|
||||||
|
|
||||||
|
$contacts = [];
|
||||||
|
|
||||||
|
while ($contact = DBA::fetch($contacts_stmt)) {
|
||||||
|
if ($contact['self']) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$contact_details = Contact::getDetailsByURL($contact['url'], $a->profile['uid'], $contact);
|
||||||
|
|
||||||
|
$contacts[] = [
|
||||||
|
'id' => $contact['id'],
|
||||||
|
'img_hover' => L10n::t('Visit %s\'s profile [%s]', $contact_details['name'], $contact['url']),
|
||||||
|
'photo_menu' => Contact::photoMenu($contact),
|
||||||
|
'thumb' => ProxyUtils::proxifyUrl($contact_details['thumb'], false, ProxyUtils::SIZE_THUMB),
|
||||||
|
'name' => substr($contact_details['name'], 0, 20),
|
||||||
|
'username' => $contact_details['name'],
|
||||||
|
'details' => $contact_details['location'],
|
||||||
|
'tags' => $contact_details['keywords'],
|
||||||
|
'about' => $contact_details['about'],
|
||||||
|
'account_type' => Contact::getAccountType($contact_details),
|
||||||
|
'url' => Contact::magicLink($contact['url']),
|
||||||
|
'sparkle' => '',
|
||||||
|
'itemurl' => $contact_details['addr'] ? : $contact['url'],
|
||||||
|
'network' => ContactSelector::networkToName($contact['network'], $contact['url']),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
DBA::close($contacts_stmt);
|
||||||
|
|
||||||
|
switch ($type) {
|
||||||
|
case 'followers': $title = L10n::tt('Follower (%s)', 'Followers (%s)', $total); break;
|
||||||
|
case 'following': $title = L10n::tt('Following (%s)', 'Following (%s)', $total); break;
|
||||||
|
case 'mutuals': $title = L10n::tt('Mutual friend (%s)', 'Mutual friends (%s)', $total); break;
|
||||||
|
|
||||||
|
case 'all': default: $title = L10n::tt('Contact (%s)', 'Contacts (%s)', $total); break;
|
||||||
|
}
|
||||||
|
|
||||||
|
$tpl = Renderer::getMarkupTemplate('profile/contacts.tpl');
|
||||||
|
$o .= Renderer::replaceMacros($tpl, [
|
||||||
|
'$title' => $title,
|
||||||
|
'$nickname' => $nickname,
|
||||||
|
'$type' => $type,
|
||||||
|
|
||||||
|
'$all_label' => L10n::t('All contacts'),
|
||||||
|
'$followers_label' => L10n::t('Followers'),
|
||||||
|
'$following_label' => L10n::t('Following'),
|
||||||
|
'$mutuals_label' => L10n::t('Mutual friends'),
|
||||||
|
|
||||||
|
'$contacts' => $contacts,
|
||||||
|
'$paginate' => $pager->renderFull($total),
|
||||||
|
]);
|
||||||
|
|
||||||
|
return $o;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1515,7 +1515,7 @@ class OStatus
|
||||||
$author->appendChild($urls);
|
$author->appendChild($urls);
|
||||||
}
|
}
|
||||||
|
|
||||||
XML::addElement($doc, $author, "followers", "", ["url" => System::baseUrl()."/viewcontacts/".$owner["nick"]]);
|
XML::addElement($doc, $author, "followers", "", ["url" => System::baseUrl() . "/profile/" . $owner["nick"] . "/contacts/followers"]);
|
||||||
XML::addElement($doc, $author, "statusnet:profile_info", "", ["local_id" => $owner["uid"]]);
|
XML::addElement($doc, $author, "statusnet:profile_info", "", ["local_id" => $owner["uid"]]);
|
||||||
|
|
||||||
if ($profile["publish"]) {
|
if ($profile["publish"]) {
|
||||||
|
|
20
view/templates/profile/contacts.tpl
Normal file
20
view/templates/profile/contacts.tpl
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
<div class="generic-page-wrapper">
|
||||||
|
{{include file="section_title.tpl"}}
|
||||||
|
|
||||||
|
<ul role="menubar" class="tabs">
|
||||||
|
<li role="menuitem"><a href="profile/{{$nickname}}/contacts" class="tab button{{if !$type || $type == 'all'}} active{{/if}}">{{$all_label}}</a></li>
|
||||||
|
<li role="menuitem"><a href="profile/{{$nickname}}/contacts/followers" class="tab button{{if $type == 'followers'}} active{{/if}}">{{$followers_label}}</a></li>
|
||||||
|
<li role="menuitem"><a href="profile/{{$nickname}}/contacts/following" class="tab button{{if $type == 'following'}} active{{/if}}">{{$following_label}}</a></li>
|
||||||
|
<li role="menuitem"><a href="profile/{{$nickname}}/contacts/mutuals" class="tab button{{if $type == 'mutuals'}} active{{/if}}">{{$mutuals_label}}</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<div id="viewcontact_wrapper-{{$id}}">
|
||||||
|
{{foreach $contacts as $contact}}
|
||||||
|
{{include file="contact_template.tpl"}}
|
||||||
|
{{/foreach}}
|
||||||
|
</div>
|
||||||
|
<div class="clear"></div>
|
||||||
|
<div id="view-contact-end"></div>
|
||||||
|
|
||||||
|
{{$paginate nofilter}}
|
||||||
|
</div>
|
|
@ -680,10 +680,6 @@ input#dfrn-url {
|
||||||
clear: both;
|
clear: both;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#viewcontacts {
|
|
||||||
margin-top: 15px;
|
|
||||||
}
|
|
||||||
#profile-edit-default-desc {
|
#profile-edit-default-desc {
|
||||||
color: #FF0000;
|
color: #FF0000;
|
||||||
border: 1px solid #FF8888;
|
border: 1px solid #FF8888;
|
||||||
|
|
|
@ -2317,7 +2317,7 @@ ul.dropdown-menu li:hover {
|
||||||
.manage-content-wrapper, .notes-content-wrapper,
|
.manage-content-wrapper, .notes-content-wrapper,
|
||||||
.message-content-wrapper, .apps-content-wrapper,
|
.message-content-wrapper, .apps-content-wrapper,
|
||||||
#adminpage, .delegate-content-wrapper, .uexport-content-wrapper,
|
#adminpage, .delegate-content-wrapper, .uexport-content-wrapper,
|
||||||
.viewcontacts-content-wrapper, .dfrn_request-content-wrapper,
|
.dfrn_request-content-wrapper,
|
||||||
.friendica-content-wrapper, .credits-content-wrapper, .nogroup-content-wrapper,
|
.friendica-content-wrapper, .credits-content-wrapper, .nogroup-content-wrapper,
|
||||||
.profperm-content-wrapper, .invite-content-wrapper, .tos-content-wrapper,
|
.profperm-content-wrapper, .invite-content-wrapper, .tos-content-wrapper,
|
||||||
.fsuggest-content-wrapper {
|
.fsuggest-content-wrapper {
|
||||||
|
@ -3547,7 +3547,7 @@ section .profile-match-wrapper {
|
||||||
right: 10px;
|
right: 10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.generic-page-wrapper, .profile_photo-content-wrapper, .videos-content-wrapper, .suggest-content-wrapper, .common-content-wrapper, .help-content-wrapper, .allfriends-content-wrapper, .match-content-wrapper, .dirfind-content-wrapper, .directory-content-wrapper, .manage-content-wrapper, .notes-content-wrapper, .message-content-wrapper, .apps-content-wrapper, #adminpage, .delegate-content-wrapper, .uexport-content-wrapper, .viewcontacts-content-wrapper, .dfrn_request-content-wrapper, .friendica-content-wrapper, .credits-content-wrapper, .nogroup-content-wrapper, .profperm-content-wrapper, .invite-content-wrapper, .tos-content-wrapper, .fsuggest-content-wrapper {
|
.generic-page-wrapper, .profile_photo-content-wrapper, .videos-content-wrapper, .suggest-content-wrapper, .common-content-wrapper, .help-content-wrapper, .allfriends-content-wrapper, .match-content-wrapper, .dirfind-content-wrapper, .directory-content-wrapper, .manage-content-wrapper, .notes-content-wrapper, .message-content-wrapper, .apps-content-wrapper, #adminpage, .delegate-content-wrapper, .uexport-content-wrapper, .dfrn_request-content-wrapper, .friendica-content-wrapper, .credits-content-wrapper, .nogroup-content-wrapper, .profperm-content-wrapper, .invite-content-wrapper, .tos-content-wrapper, .fsuggest-content-wrapper {
|
||||||
border-radius: 0;
|
border-radius: 0;
|
||||||
padding: 10px;
|
padding: 10px;
|
||||||
}
|
}
|
||||||
|
|
20
view/theme/frio/templates/profile/contacts.tpl
Normal file
20
view/theme/frio/templates/profile/contacts.tpl
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
<div class="generic-page-wrapper">
|
||||||
|
{{include file="section_title.tpl"}}
|
||||||
|
|
||||||
|
<ul class="nav nav-tabs">
|
||||||
|
<li role="presentation"{{if !$type || $type == 'all'}} class="active"{{/if}}><a href="profile/{{$nickname}}/contacts">{{$all_label}}</a></li>
|
||||||
|
<li role="presentation"{{if $type == 'followers'}} class="active"{{/if}}><a href="profile/{{$nickname}}/contacts/followers">{{$followers_label}}</a></li>
|
||||||
|
<li role="presentation"{{if $type == 'following'}} class="active"{{/if}}><a href="profile/{{$nickname}}/contacts/following">{{$following_label}}</a></li>
|
||||||
|
<li role="presentation"{{if $type == 'mutuals'}} class="active"{{/if}}><a href="profile/{{$nickname}}/contacts/mutuals">{{$mutuals_label}}</a></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
<ul id="viewcontact_wrapper{{if $id}}-{{$id}}{{/if}}" class="viewcontact_wrapper media-list">
|
||||||
|
{{foreach $contacts as $contact}}
|
||||||
|
<li>{{include file="contact_template.tpl"}}</li>
|
||||||
|
{{/foreach}}
|
||||||
|
</ul>
|
||||||
|
<div class="clear"></div>
|
||||||
|
<div id="view-contact-end"></div>
|
||||||
|
|
||||||
|
{{$paginate nofilter}}
|
||||||
|
</div>
|
|
@ -2834,10 +2834,6 @@ margin-left: 0px;
|
||||||
clear: both;
|
clear: both;
|
||||||
}
|
}
|
||||||
|
|
||||||
#viewcontacts {
|
|
||||||
margin-top: 15px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.contact-entry-wrapper .contact-entry-photo-wrapper {
|
.contact-entry-wrapper .contact-entry-photo-wrapper {
|
||||||
float: left;
|
float: left;
|
||||||
margin-right: 10px;
|
margin-right: 10px;
|
||||||
|
|
Loading…
Reference in a new issue