Add new contact/{id}/contacts[/{type}] route and module
- Rework contact pages tabs - Add constants for active contact page tab
This commit is contained in:
parent
383ddb10ed
commit
18cd4f7412
4 changed files with 169 additions and 55 deletions
|
@ -47,6 +47,12 @@ use Friendica\Util\Strings;
|
||||||
*/
|
*/
|
||||||
class Contact extends BaseModule
|
class Contact extends BaseModule
|
||||||
{
|
{
|
||||||
|
const TAB_CONVERSATIONS = 1;
|
||||||
|
const TAB_POSTS = 2;
|
||||||
|
const TAB_PROFILE = 3;
|
||||||
|
const TAB_CONTACTS = 4;
|
||||||
|
const TAB_ADVANCED = 5;
|
||||||
|
|
||||||
private static function batchActions()
|
private static function batchActions()
|
||||||
{
|
{
|
||||||
if (empty($_POST['contact_batch']) || !is_array($_POST['contact_batch'])) {
|
if (empty($_POST['contact_batch']) || !is_array($_POST['contact_batch'])) {
|
||||||
|
@ -531,7 +537,7 @@ class Contact extends BaseModule
|
||||||
$nettype = DI::l10n()->t('Network type: %s', ContactSelector::networkToName($contact['network'], $contact['url'], $contact['protocol']));
|
$nettype = DI::l10n()->t('Network type: %s', ContactSelector::networkToName($contact['network'], $contact['url'], $contact['protocol']));
|
||||||
|
|
||||||
// tabs
|
// tabs
|
||||||
$tab_str = self::getTabsHTML($contact, 3);
|
$tab_str = self::getTabsHTML($contact, self::TAB_PROFILE);
|
||||||
|
|
||||||
$lost_contact = (($contact['archive'] && $contact['term-date'] > DBA::NULL_DATETIME && $contact['term-date'] < DateTimeFormat::utcNow()) ? DI::l10n()->t('Communications lost with this contact!') : '');
|
$lost_contact = (($contact['archive'] && $contact['term-date'] > DBA::NULL_DATETIME && $contact['term-date'] < DateTimeFormat::utcNow()) ? DI::l10n()->t('Communications lost with this contact!') : '');
|
||||||
|
|
||||||
|
@ -576,7 +582,7 @@ class Contact extends BaseModule
|
||||||
'$lbl_info2' => DI::l10n()->t('Their personal note'),
|
'$lbl_info2' => DI::l10n()->t('Their personal note'),
|
||||||
'$reason' => trim(Strings::escapeTags($contact['reason'])),
|
'$reason' => trim(Strings::escapeTags($contact['reason'])),
|
||||||
'$infedit' => DI::l10n()->t('Edit contact notes'),
|
'$infedit' => DI::l10n()->t('Edit contact notes'),
|
||||||
'$common_link' => 'common/loc/' . local_user() . '/' . $contact['id'],
|
'$common_link' => 'contact/' . $contact['id'] . '/contacts/common',
|
||||||
'$relation_text' => $relation_text,
|
'$relation_text' => $relation_text,
|
||||||
'$visit' => DI::l10n()->t('Visit %s\'s profile [%s]', $contact['name'], $contact['url']),
|
'$visit' => DI::l10n()->t('Visit %s\'s profile [%s]', $contact['name'], $contact['url']),
|
||||||
'$blockunblock' => DI::l10n()->t('Block/Unblock contact'),
|
'$blockunblock' => DI::l10n()->t('Block/Unblock contact'),
|
||||||
|
@ -876,57 +882,41 @@ class Contact extends BaseModule
|
||||||
$tabs = [
|
$tabs = [
|
||||||
[
|
[
|
||||||
'label' => DI::l10n()->t('Status'),
|
'label' => DI::l10n()->t('Status'),
|
||||||
'url' => "contact/" . $pcid . "/conversations",
|
'url' => 'contact/' . $pcid . '/conversations',
|
||||||
'sel' => (($active_tab == 1) ? 'active' : ''),
|
'sel' => (($active_tab == self::TAB_CONVERSATIONS) ? 'active' : ''),
|
||||||
'title' => DI::l10n()->t('Conversations started by this contact'),
|
'title' => DI::l10n()->t('Conversations started by this contact'),
|
||||||
'id' => 'status-tab',
|
'id' => 'status-tab',
|
||||||
'accesskey' => 'm',
|
'accesskey' => 'm',
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
'label' => DI::l10n()->t('Posts and Comments'),
|
'label' => DI::l10n()->t('Posts and Comments'),
|
||||||
'url' => "contact/" . $pcid . "/posts",
|
'url' => 'contact/' . $pcid . '/posts',
|
||||||
'sel' => (($active_tab == 2) ? 'active' : ''),
|
'sel' => (($active_tab == self::TAB_POSTS) ? 'active' : ''),
|
||||||
'title' => DI::l10n()->t('Status Messages and Posts'),
|
'title' => DI::l10n()->t('Status Messages and Posts'),
|
||||||
'id' => 'posts-tab',
|
'id' => 'posts-tab',
|
||||||
'accesskey' => 'p',
|
'accesskey' => 'p',
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
'label' => DI::l10n()->t('Profile'),
|
'label' => DI::l10n()->t('Profile'),
|
||||||
'url' => "contact/" . $cid,
|
'url' => 'contact/' . $cid,
|
||||||
'sel' => (($active_tab == 3) ? 'active' : ''),
|
'sel' => (($active_tab == self::TAB_PROFILE) ? 'active' : ''),
|
||||||
'title' => DI::l10n()->t('Profile Details'),
|
'title' => DI::l10n()->t('Profile Details'),
|
||||||
'id' => 'profile-tab',
|
'id' => 'profile-tab',
|
||||||
'accesskey' => 'o',
|
'accesskey' => 'o',
|
||||||
]
|
],
|
||||||
|
['label' => DI::l10n()->t('Contacts'),
|
||||||
|
'url' => 'contact/' . $pcid . '/contacts',
|
||||||
|
'sel' => (($active_tab == self::TAB_CONTACTS) ? 'active' : ''),
|
||||||
|
'title' => DI::l10n()->t('View all known contacts'),
|
||||||
|
'id' => 'contacts-tab',
|
||||||
|
'accesskey' => 't'
|
||||||
|
],
|
||||||
];
|
];
|
||||||
|
|
||||||
// Show this tab only if there is visible friend list
|
|
||||||
$x = Model\Contact\Relation::countFollows($pcid);
|
|
||||||
if ($x) {
|
|
||||||
$tabs[] = ['label' => DI::l10n()->t('Contacts'),
|
|
||||||
'url' => "allfriends/" . $pcid,
|
|
||||||
'sel' => (($active_tab == 4) ? 'active' : ''),
|
|
||||||
'title' => DI::l10n()->t('View all contacts'),
|
|
||||||
'id' => 'allfriends-tab',
|
|
||||||
'accesskey' => 't'];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Show this tab only if there is visible common friend list
|
|
||||||
$common = Model\GContact::countCommonFriends(local_user(), $cid);
|
|
||||||
if ($common) {
|
|
||||||
$tabs[] = ['label' => DI::l10n()->t('Common Friends'),
|
|
||||||
'url' => "common/loc/" . local_user() . "/" . $cid,
|
|
||||||
'sel' => (($active_tab == 5) ? 'active' : ''),
|
|
||||||
'title' => DI::l10n()->t('View all common friends'),
|
|
||||||
'id' => 'common-loc-tab',
|
|
||||||
'accesskey' => 'd'
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($cid != $pcid) {
|
if ($cid != $pcid) {
|
||||||
$tabs[] = ['label' => DI::l10n()->t('Advanced'),
|
$tabs[] = ['label' => DI::l10n()->t('Advanced'),
|
||||||
'url' => 'contact/' . $cid . '/advanced/',
|
'url' => 'contact/' . $cid . '/advanced/',
|
||||||
'sel' => (($active_tab == 6) ? 'active' : ''),
|
'sel' => (($active_tab == self::TAB_ADVANCED) ? 'active' : ''),
|
||||||
'title' => DI::l10n()->t('Advanced Contact Settings'),
|
'title' => DI::l10n()->t('Advanced Contact Settings'),
|
||||||
'id' => 'advanced-tab',
|
'id' => 'advanced-tab',
|
||||||
'accesskey' => 'r'
|
'accesskey' => 'r'
|
||||||
|
@ -964,7 +954,7 @@ class Contact extends BaseModule
|
||||||
$contact = DBA::selectFirst('contact', ['uid', 'url', 'id'], ['id' => $contact_id, 'deleted' => false]);
|
$contact = DBA::selectFirst('contact', ['uid', 'url', 'id'], ['id' => $contact_id, 'deleted' => false]);
|
||||||
|
|
||||||
if (!$update) {
|
if (!$update) {
|
||||||
$o .= self::getTabsHTML($contact, 1);
|
$o .= self::getTabsHTML($contact, self::TAB_CONVERSATIONS);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (DBA::isResult($contact)) {
|
if (DBA::isResult($contact)) {
|
||||||
|
@ -988,7 +978,7 @@ class Contact extends BaseModule
|
||||||
{
|
{
|
||||||
$contact = DBA::selectFirst('contact', ['uid', 'url', 'id'], ['id' => $contact_id, 'deleted' => false]);
|
$contact = DBA::selectFirst('contact', ['uid', 'url', 'id'], ['id' => $contact_id, 'deleted' => false]);
|
||||||
|
|
||||||
$o = self::getTabsHTML($contact, 2);
|
$o = self::getTabsHTML($contact, self::TAB_POSTS);
|
||||||
|
|
||||||
if (DBA::isResult($contact)) {
|
if (DBA::isResult($contact)) {
|
||||||
DI::page()['aside'] = '';
|
DI::page()['aside'] = '';
|
||||||
|
|
|
@ -125,7 +125,7 @@ class Advanced extends BaseModule
|
||||||
$remote_self_options = ['0' => DI::l10n()->t('No mirroring'), '2' => DI::l10n()->t('Mirror as my own posting')];
|
$remote_self_options = ['0' => DI::l10n()->t('No mirroring'), '2' => DI::l10n()->t('Mirror as my own posting')];
|
||||||
}
|
}
|
||||||
|
|
||||||
$tab_str = Contact::getTabsHTML($contact, 6);
|
$tab_str = Contact::getTabsHTML($contact, Contact::TAB_ADVANCED);
|
||||||
|
|
||||||
$tpl = Renderer::getMarkupTemplate('contact/advanced.tpl');
|
$tpl = Renderer::getMarkupTemplate('contact/advanced.tpl');
|
||||||
return Renderer::replaceMacros($tpl, [
|
return Renderer::replaceMacros($tpl, [
|
||||||
|
|
123
src/Module/Contact/Contacts.php
Normal file
123
src/Module/Contact/Contacts.php
Normal file
|
@ -0,0 +1,123 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Friendica\Module\Contact;
|
||||||
|
|
||||||
|
use Friendica\BaseModule;
|
||||||
|
use Friendica\Content\Pager;
|
||||||
|
use Friendica\Core\Renderer;
|
||||||
|
use Friendica\Core\Session;
|
||||||
|
use Friendica\DI;
|
||||||
|
use Friendica\Model;
|
||||||
|
use Friendica\Module;
|
||||||
|
use Friendica\Network\HTTPException;
|
||||||
|
|
||||||
|
class Contacts extends BaseModule
|
||||||
|
{
|
||||||
|
public static function content(array $parameters = [])
|
||||||
|
{
|
||||||
|
$app = DI::app();
|
||||||
|
|
||||||
|
if (!local_user()) {
|
||||||
|
throw new HTTPException\ForbiddenException();
|
||||||
|
}
|
||||||
|
|
||||||
|
$cid = $parameters['id'];
|
||||||
|
$type = $parameters['type'] ?? 'all';
|
||||||
|
|
||||||
|
if (!$cid) {
|
||||||
|
throw new HTTPException\BadRequestException(DI::l10n()->t('Invalid contact.'));
|
||||||
|
}
|
||||||
|
|
||||||
|
$contact = Model\Contact::getById($cid, []);
|
||||||
|
if (empty($contact)) {
|
||||||
|
throw new HTTPException\NotFoundException(DI::l10n()->t('Contact not found.'));
|
||||||
|
}
|
||||||
|
|
||||||
|
$localContactId = Model\Contact::getPublicIdByUserId(local_user());
|
||||||
|
|
||||||
|
Model\Profile::load($app, '', $contact);
|
||||||
|
|
||||||
|
$condition = [
|
||||||
|
'blocked' => false,
|
||||||
|
'self' => false,
|
||||||
|
'hidden' => false,
|
||||||
|
];
|
||||||
|
|
||||||
|
$noresult_label = DI::l10n()->t('No known contacts.');
|
||||||
|
|
||||||
|
switch ($type) {
|
||||||
|
case 'followers':
|
||||||
|
$total = Model\Contact\Relation::countFollowers($cid, $condition);
|
||||||
|
break;
|
||||||
|
case 'following':
|
||||||
|
$total = Model\Contact\Relation::countFollows($cid, $condition);
|
||||||
|
break;
|
||||||
|
case 'mutuals':
|
||||||
|
$total = Model\Contact\Relation::countMutuals($cid, $condition);
|
||||||
|
break;
|
||||||
|
case 'common':
|
||||||
|
$condition = [
|
||||||
|
'NOT `self` AND NOT `blocked` AND NOT `hidden` AND `id` != ?',
|
||||||
|
$localContactId,
|
||||||
|
];
|
||||||
|
$total = Model\Contact\Relation::countCommon($localContactId, $cid, $condition);
|
||||||
|
$noresult_label = DI::l10n()->t('No common contacts.');
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
$total = Model\Contact\Relation::countAll($cid, $condition);
|
||||||
|
}
|
||||||
|
|
||||||
|
$pager = new Pager(DI::l10n(), DI::args()->getQueryString());
|
||||||
|
$desc = '';
|
||||||
|
|
||||||
|
switch ($type) {
|
||||||
|
case 'followers':
|
||||||
|
$friends = Model\Contact\Relation::listFollowers($cid, $condition, $pager->getItemsPerPage(), $pager->getStart());
|
||||||
|
$title = DI::l10n()->tt('Follower (%s)', 'Followers (%s)', $total);
|
||||||
|
break;
|
||||||
|
case 'following':
|
||||||
|
$friends = Model\Contact\Relation::listFollows($cid, $condition, $pager->getItemsPerPage(), $pager->getStart());
|
||||||
|
$title = DI::l10n()->tt('Following (%s)', 'Following (%s)', $total);
|
||||||
|
break;
|
||||||
|
case 'mutuals':
|
||||||
|
$friends = Model\Contact\Relation::listMutuals($cid, $condition, $pager->getItemsPerPage(), $pager->getStart());
|
||||||
|
$title = DI::l10n()->tt('Mutual friend (%s)', 'Mutual friends (%s)', $total);
|
||||||
|
$desc = DI::l10n()->t(
|
||||||
|
'These contacts both follow and are followed by <strong>%s</strong>.',
|
||||||
|
htmlentities($contact['name'], ENT_COMPAT, 'UTF-8')
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
case 'common':
|
||||||
|
$friends = Model\Contact\Relation::listCommon($localContactId, $cid, $condition, $pager->getItemsPerPage(), $pager->getStart());
|
||||||
|
$title = DI::l10n()->tt('Common contact (%s)', 'Common contacts (%s)', $total);
|
||||||
|
$desc = DI::l10n()->t(
|
||||||
|
'Both <strong>%s</strong> and yourself have publicly interacted with these contacts (follow, comment or likes on public posts).',
|
||||||
|
htmlentities($contact['name'], ENT_COMPAT, 'UTF-8')
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
$friends = Model\Contact\Relation::listAll($cid, $condition, $pager->getItemsPerPage(), $pager->getStart());
|
||||||
|
$title = DI::l10n()->tt('Contact (%s)', 'Contacts (%s)', $total);
|
||||||
|
}
|
||||||
|
|
||||||
|
$o = Module\Contact::getTabsHTML($contact, Module\Contact::TAB_CONTACTS);
|
||||||
|
|
||||||
|
$tabs = self::getContactFilterTabs('contact/' . $cid, $type, true);
|
||||||
|
|
||||||
|
$contacts = array_map([Module\Contact::class, 'getContactTemplateVars'], $friends);
|
||||||
|
|
||||||
|
$tpl = Renderer::getMarkupTemplate('profile/contacts.tpl');
|
||||||
|
$o .= Renderer::replaceMacros($tpl, [
|
||||||
|
'$title' => $title,
|
||||||
|
'$desc' => $desc,
|
||||||
|
'$tabs' => $tabs,
|
||||||
|
|
||||||
|
'$noresult_label' => $noresult_label,
|
||||||
|
|
||||||
|
'$contacts' => $contacts,
|
||||||
|
'$paginate' => $pager->renderFull($total),
|
||||||
|
]);
|
||||||
|
|
||||||
|
return $o;
|
||||||
|
}
|
||||||
|
}
|
|
@ -121,6 +121,7 @@ return [
|
||||||
'/{id:\d+}/advanced' => [Module\Contact\Advanced::class, [R::GET, R::POST]],
|
'/{id:\d+}/advanced' => [Module\Contact\Advanced::class, [R::GET, R::POST]],
|
||||||
'/{id:\d+}/block' => [Module\Contact::class, [R::GET]],
|
'/{id:\d+}/block' => [Module\Contact::class, [R::GET]],
|
||||||
'/{id:\d+}/conversations' => [Module\Contact::class, [R::GET]],
|
'/{id:\d+}/conversations' => [Module\Contact::class, [R::GET]],
|
||||||
|
'/{id:\d+}/contacts[/{type}]' => [Module\Contact\Contacts::class, [R::GET]],
|
||||||
'/{id:\d+}/drop' => [Module\Contact::class, [R::GET]],
|
'/{id:\d+}/drop' => [Module\Contact::class, [R::GET]],
|
||||||
'/{id:\d+}/ignore' => [Module\Contact::class, [R::GET]],
|
'/{id:\d+}/ignore' => [Module\Contact::class, [R::GET]],
|
||||||
'/{id:\d+}/poke' => [Module\Contact\Poke::class, [R::GET, R::POST]],
|
'/{id:\d+}/poke' => [Module\Contact\Poke::class, [R::GET, R::POST]],
|
||||||
|
|
Loading…
Reference in a new issue