Merge pull request #5923 from MrPetovan/task/improve-contact-module
Improve Contact module
This commit is contained in:
commit
0080d117ee
3 changed files with 193 additions and 210 deletions
|
@ -5,7 +5,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\L10n;
|
use Friendica\Core\L10n;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Module\Contacts;
|
use Friendica\Module\Contact;
|
||||||
|
|
||||||
function update_contacts_content(App $a)
|
function update_contacts_content(App $a)
|
||||||
{
|
{
|
||||||
|
|
|
@ -349,7 +349,7 @@ class Group extends BaseObject
|
||||||
* @param int $cid
|
* @param int $cid
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public static function sidebarWidget($every = 'contacts', $each = 'group', $editmode = 'standard', $group_id = '', $cid = 0)
|
public static function sidebarWidget($every = 'contact', $each = 'group', $editmode = 'standard', $group_id = '', $cid = 0)
|
||||||
{
|
{
|
||||||
$o = '';
|
$o = '';
|
||||||
|
|
||||||
|
@ -404,7 +404,7 @@ class Group extends BaseObject
|
||||||
'newgroup' => $editmode == 'extended' || $editmode == 'full' ? 1 : '',
|
'newgroup' => $editmode == 'extended' || $editmode == 'full' ? 1 : '',
|
||||||
'grouppage' => 'group/',
|
'grouppage' => 'group/',
|
||||||
'$edittext' => L10n::t('Edit group'),
|
'$edittext' => L10n::t('Edit group'),
|
||||||
'$ungrouped' => $every === 'contacts' ? L10n::t('Contacts not in any group') : '',
|
'$ungrouped' => $every === 'contact' ? L10n::t('Contacts not in any group') : '',
|
||||||
'$ungrouped_selected' => (($group_id === 'none') ? 'group-selected' : ''),
|
'$ungrouped_selected' => (($group_id === 'none') ? 'group-selected' : ''),
|
||||||
'$createtext' => L10n::t('Create a new group'),
|
'$createtext' => L10n::t('Create a new group'),
|
||||||
'$creategroup' => L10n::t('Group Name: '),
|
'$creategroup' => L10n::t('Group Name: '),
|
||||||
|
|
|
@ -37,8 +37,8 @@ class Contact extends BaseModule
|
||||||
}
|
}
|
||||||
|
|
||||||
$nets = defaults($_GET, 'nets', '');
|
$nets = defaults($_GET, 'nets', '');
|
||||||
if ($nets == "all") {
|
if ($nets == 'all') {
|
||||||
$nets = "";
|
$nets = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!x($a->page, 'aside')) {
|
if (!x($a->page, 'aside')) {
|
||||||
|
@ -47,7 +47,9 @@ class Contact extends BaseModule
|
||||||
|
|
||||||
$contact_id = null;
|
$contact_id = null;
|
||||||
$contact = null;
|
$contact = null;
|
||||||
if ((($a->argc == 2) && intval($a->argv[1])) || (($a->argc == 3) && intval($a->argv[1]) && in_array($a->argv[2], ['posts', 'conversations']))) {
|
if ($a->argc == 2 && intval($a->argv[1])
|
||||||
|
|| $a->argc == 3 && intval($a->argv[1]) && in_array($a->argv[2], ['posts', 'conversations'])
|
||||||
|
) {
|
||||||
$contact_id = intval($a->argv[1]);
|
$contact_id = intval($a->argv[1]);
|
||||||
$contact = DBA::selectFirst('contact', [], ['id' => $contact_id, 'uid' => local_user()]);
|
$contact = DBA::selectFirst('contact', [], ['id' => $contact_id, 'uid' => local_user()]);
|
||||||
|
|
||||||
|
@ -72,21 +74,21 @@ class Contact extends BaseModule
|
||||||
|
|
||||||
$a->data['contact'] = $contact;
|
$a->data['contact'] = $contact;
|
||||||
|
|
||||||
if (($a->data['contact']['network'] != "") && ($a->data['contact']['network'] != Protocol::DFRN)) {
|
if (($contact['network'] != '') && ($contact['network'] != Protocol::DFRN)) {
|
||||||
$networkname = format_network_name($a->data['contact']['network'], $a->data['contact']['url']);
|
$networkname = format_network_name($contact['network'], $contact['url']);
|
||||||
} else {
|
} else {
|
||||||
$networkname = '';
|
$networkname = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
/// @TODO Add nice spaces
|
/// @TODO Add nice spaces
|
||||||
$vcard_widget = replace_macros(get_markup_template("vcard-widget.tpl"), [
|
$vcard_widget = replace_macros(get_markup_template('vcard-widget.tpl'), [
|
||||||
'$name' => htmlentities($a->data['contact']['name']),
|
'$name' => htmlentities($contact['name']),
|
||||||
'$photo' => $a->data['contact']['photo'],
|
'$photo' => $contact['photo'],
|
||||||
'$url' => Model\Contact::MagicLink($a->data['contact']['url']),
|
'$url' => Model\Contact::MagicLink($contact['url']),
|
||||||
'$addr' => (($a->data['contact']['addr'] != "") ? ($a->data['contact']['addr']) : ""),
|
'$addr' => defaults($contact, 'addr', ''),
|
||||||
'$network_name' => $networkname,
|
'$network_name' => $networkname,
|
||||||
'$network' => L10n::t('Network:'),
|
'$network' => L10n::t('Network:'),
|
||||||
'$account_type' => Model\Contact::getAccountType($a->data['contact'])
|
'$account_type' => Model\Contact::getAccountType($contact)
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$findpeople_widget = '';
|
$findpeople_widget = '';
|
||||||
|
@ -94,7 +96,7 @@ class Contact extends BaseModule
|
||||||
$networks_widget = '';
|
$networks_widget = '';
|
||||||
} else {
|
} else {
|
||||||
$vcard_widget = '';
|
$vcard_widget = '';
|
||||||
$networks_widget = Widget::networks('contacts', $nets);
|
$networks_widget = Widget::networks('contact', $nets);
|
||||||
if (isset($_GET['add'])) {
|
if (isset($_GET['add'])) {
|
||||||
$follow_widget = Widget::follow($_GET['add']);
|
$follow_widget = Widget::follow($_GET['add']);
|
||||||
} else {
|
} else {
|
||||||
|
@ -105,12 +107,12 @@ class Contact extends BaseModule
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($contact['uid'] != 0) {
|
if ($contact['uid'] != 0) {
|
||||||
$groups_widget = Model\Group::sidebarWidget('contacts', 'group', 'full', 'everyone', $contact_id);
|
$groups_widget = Model\Group::sidebarWidget('contact', 'group', 'full', 'everyone', $contact_id);
|
||||||
} else {
|
} else {
|
||||||
$groups_widget = null;
|
$groups_widget = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
$a->page['aside'] .= replace_macros(get_markup_template("contacts-widget-sidebar.tpl"), [
|
$a->page['aside'] .= replace_macros(get_markup_template('contacts-widget-sidebar.tpl'), [
|
||||||
'$vcard_widget' => $vcard_widget,
|
'$vcard_widget' => $vcard_widget,
|
||||||
'$findpeople_widget' => $findpeople_widget,
|
'$findpeople_widget' => $findpeople_widget,
|
||||||
'$follow_widget' => $follow_widget,
|
'$follow_widget' => $follow_widget,
|
||||||
|
@ -119,7 +121,7 @@ class Contact extends BaseModule
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$base = $a->getBaseURL();
|
$base = $a->getBaseURL();
|
||||||
$tpl = get_markup_template("contacts-head.tpl");
|
$tpl = get_markup_template('contacts-head.tpl');
|
||||||
$a->page['htmlhead'] .= replace_macros($tpl, [
|
$a->page['htmlhead'] .= replace_macros($tpl, [
|
||||||
'$baseurl' => System::baseUrl(true),
|
'$baseurl' => System::baseUrl(true),
|
||||||
'$base' => $base
|
'$base' => $base
|
||||||
|
@ -140,31 +142,30 @@ class Contact extends BaseModule
|
||||||
$count_actions = 0;
|
$count_actions = 0;
|
||||||
foreach ($orig_records as $orig_record) {
|
foreach ($orig_records as $orig_record) {
|
||||||
$contact_id = $orig_record['id'];
|
$contact_id = $orig_record['id'];
|
||||||
if (defaults($_POST, 'contacts_batch_update', '')) {
|
if (!empty($_POST['contacts_batch_update'])) {
|
||||||
self::updateContactFromPoll($contact_id);
|
self::updateContactFromPoll($contact_id);
|
||||||
$count_actions++;
|
$count_actions++;
|
||||||
}
|
}
|
||||||
if (defaults($_POST, 'contacts_batch_block', '')) {
|
if (!empty($_POST['contacts_batch_block'])) {
|
||||||
self::blockContact($contact_id);
|
self::blockContact($contact_id);
|
||||||
$count_actions++;
|
$count_actions++;
|
||||||
}
|
}
|
||||||
if (defaults($_POST, 'contacts_batch_ignore', '')) {
|
if (!empty($_POST['contacts_batch_ignore'])) {
|
||||||
self::ignoreContact($contact_id);
|
self::ignoreContact($contact_id);
|
||||||
$count_actions++;
|
$count_actions++;
|
||||||
}
|
}
|
||||||
if (defaults($_POST, 'contacts_batch_archive', '')) {
|
if (!empty($_POST['contacts_batch_archive'])
|
||||||
$r = self::archiveContact($contact_id, $orig_record);
|
&& self::archiveContact($contact_id, $orig_record)
|
||||||
if ($r) {
|
) {
|
||||||
$count_actions++;
|
$count_actions++;
|
||||||
}
|
}
|
||||||
}
|
if (!empty($_POST['contacts_batch_drop'])) {
|
||||||
if (defaults($_POST, 'contacts_batch_drop', '')) {
|
|
||||||
self::dropContact($orig_record);
|
self::dropContact($orig_record);
|
||||||
$count_actions++;
|
$count_actions++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ($count_actions > 0) {
|
if ($count_actions > 0) {
|
||||||
info(L10n::tt("%d contact edited.", "%d contacts edited.", $count_actions));
|
info(L10n::tt('%d contact edited.', '%d contacts edited.', $count_actions));
|
||||||
}
|
}
|
||||||
|
|
||||||
goaway('contact');
|
goaway('contact');
|
||||||
|
@ -178,7 +179,7 @@ class Contact extends BaseModule
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($a->argv[1] === "batch") {
|
if ($a->argv[1] === 'batch') {
|
||||||
self::batchActions($a);
|
self::batchActions($a);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -204,9 +205,9 @@ class Contact extends BaseModule
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$hidden = defaults($_POST['hidden']);
|
$hidden = !empty($_POST['hidden']);
|
||||||
|
|
||||||
$notify = defaults($_POST['notify']);
|
$notify = !empty($_POST['notify']);
|
||||||
|
|
||||||
$fetch_further_information = intval(defaults($_POST, 'fetch_further_information', 0));
|
$fetch_further_information = intval(defaults($_POST, 'fetch_further_information', 0));
|
||||||
|
|
||||||
|
@ -219,15 +220,16 @@ class Contact extends BaseModule
|
||||||
|
|
||||||
$info = escape_tags(trim($_POST['info']));
|
$info = escape_tags(trim($_POST['info']));
|
||||||
|
|
||||||
$r = DBA::update('contact',
|
$r = DBA::update('contact', [
|
||||||
['profile-id' => $profile_id,
|
'profile-id' => $profile_id,
|
||||||
'priority' => $priority,
|
'priority' => $priority,
|
||||||
'info' => $info,
|
'info' => $info,
|
||||||
'hidden' => $hidden,
|
'hidden' => $hidden,
|
||||||
'notify_new_posts' => $notify,
|
'notify_new_posts' => $notify,
|
||||||
'fetch_further_information' => $fetch_further_information,
|
'fetch_further_information' => $fetch_further_information,
|
||||||
'ffi_keyword_blacklist' => $ffi_keyword_blacklist],
|
'ffi_keyword_blacklist' => $ffi_keyword_blacklist],
|
||||||
['id' => $contact_id, 'uid' => local_user()]);
|
['id' => $contact_id, 'uid' => local_user()]
|
||||||
|
);
|
||||||
|
|
||||||
if (DBA::isResult($r)) {
|
if (DBA::isResult($r)) {
|
||||||
info(L10n::t('Contact updated.') . EOL);
|
info(L10n::t('Contact updated.') . EOL);
|
||||||
|
@ -252,17 +254,17 @@ class Contact extends BaseModule
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$uid = $contact["uid"];
|
$uid = $contact['uid'];
|
||||||
|
|
||||||
if ($contact["network"] == Protocol::OSTATUS) {
|
if ($contact['network'] == Protocol::OSTATUS) {
|
||||||
$result = Model\Contact::createFromProbe($uid, $contact["url"], false, $contact["network"]);
|
$result = Model\Contact::createFromProbe($uid, $contact['url'], false, $contact['network']);
|
||||||
|
|
||||||
if ($result['success']) {
|
if ($result['success']) {
|
||||||
DBA::update('contact', ['subhub' => 1], ['id' => $contact_id]);
|
DBA::update('contact', ['subhub' => 1], ['id' => $contact_id]);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// pull feed and consume it, which should subscribe to the hub.
|
// pull feed and consume it, which should subscribe to the hub.
|
||||||
Worker::add(PRIORITY_HIGH, "OnePoll", $contact_id, "force");
|
Worker::add(PRIORITY_HIGH, 'OnePoll', $contact_id, 'force');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -273,60 +275,49 @@ class Contact extends BaseModule
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$uid = $contact["uid"];
|
$uid = $contact['uid'];
|
||||||
|
|
||||||
$data = Probe::uri($contact["url"], "", 0, false);
|
$data = Probe::uri($contact['url'], '', 0, false);
|
||||||
|
|
||||||
// "Feed" or "Unknown" is mostly a sign of communication problems
|
// 'Feed' or 'Unknown' is mostly a sign of communication problems
|
||||||
if ((in_array($data["network"], [Protocol::FEED, Protocol::PHANTOM])) && ($data["network"] != $contact["network"])) {
|
if ((in_array($data['network'], [Protocol::FEED, Protocol::PHANTOM])) && ($data['network'] != $contact['network'])) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$updatefields = ["name", "nick", "url", "addr", "batch", "notify", "poll", "request", "confirm",
|
$updatefields = ['name', 'nick', 'url', 'addr', 'batch', 'notify', 'poll', 'request', 'confirm', 'poco', 'network', 'alias'];
|
||||||
"poco", "network", "alias"];
|
$fields = [];
|
||||||
$update = [];
|
|
||||||
|
|
||||||
if ($data["network"] == Protocol::OSTATUS) {
|
if ($data['network'] == Protocol::OSTATUS) {
|
||||||
$result = Model\Contact::createFromProbe($uid, $data["url"], false);
|
$result = Model\Contact::createFromProbe($uid, $data['url'], false);
|
||||||
|
|
||||||
if ($result['success']) {
|
if ($result['success']) {
|
||||||
$update["subhub"] = true;
|
$fields['subhub'] = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($updatefields AS $field) {
|
foreach ($updatefields AS $field) {
|
||||||
if (isset($data[$field]) && ($data[$field] != "")) {
|
if (!empty($data[$field])) {
|
||||||
$update[$field] = $data[$field];
|
$fields[$field] = $data[$field];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$update["nurl"] = normalise_link($data["url"]);
|
$fields['nurl'] = normalise_link($data['url']);
|
||||||
|
|
||||||
$query = "";
|
if (!empty($data['priority'])) {
|
||||||
|
$fields['priority'] = intval($data['priority']);
|
||||||
if (isset($data["priority"]) && ($data["priority"] != 0)) {
|
|
||||||
$query = "'priority' => '" . intval($data["priority"]) . "'";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($update AS $key => $value) {
|
if (empty($fields)) {
|
||||||
if ($query != "") {
|
|
||||||
$query .= ", ";
|
|
||||||
}
|
|
||||||
|
|
||||||
$query .= "'" . $key . "' => '" . DBA::escape($value) . "'";
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($query == "") {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = DBA::update('contact', $query, ['id' => $contact_id, 'uid' => local_user()]);
|
$r = DBA::update('contact', $fields, ['id' => $contact_id, 'uid' => local_user()]);
|
||||||
|
|
||||||
// Update the entry in the contact table
|
// Update the entry in the contact table
|
||||||
Model\Contact::updateAvatar($data['photo'], local_user(), $contact_id, true);
|
Model\Contact::updateAvatar($data['photo'], local_user(), $contact_id, true);
|
||||||
|
|
||||||
// Update the entry in the gcontact table
|
// Update the entry in the gcontact table
|
||||||
Model\GContact::updateFromProbe($data["url"]);
|
Model\GContact::updateFromProbe($data['url']);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function blockContact($contact_id)
|
private static function blockContact($contact_id)
|
||||||
|
@ -351,17 +342,12 @@ class Contact extends BaseModule
|
||||||
|
|
||||||
private static function dropContact($orig_record)
|
private static function dropContact($orig_record)
|
||||||
{
|
{
|
||||||
$a = get_app();
|
$owner = Model\User::getOwnerDataById(local_user());
|
||||||
|
if (!DBA::isResult($owner)) {
|
||||||
$r = q("SELECT `contact`.*, `user`.* FROM `contact` INNER JOIN `user` ON `contact`.`uid` = `user`.`uid`
|
|
||||||
WHERE `user`.`uid` = %d AND `contact`.`self` LIMIT 1",
|
|
||||||
intval($a->user['uid'])
|
|
||||||
);
|
|
||||||
if (!DBA::isResult($r)) {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Model\Contact::terminateFriendship($r[0], $orig_record, true);
|
Model\Contact::terminateFriendship($owner, $orig_record, true);
|
||||||
Model\Contact::remove($orig_record['id']);
|
Model\Contact::remove($orig_record['id']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -437,8 +423,8 @@ class Contact extends BaseModule
|
||||||
|
|
||||||
if ($cmd === 'drop' && ($orig_record['uid'] != 0)) {
|
if ($cmd === 'drop' && ($orig_record['uid'] != 0)) {
|
||||||
// Check if we should do HTML-based delete confirmation
|
// Check if we should do HTML-based delete confirmation
|
||||||
if (defaults($_REQUEST, 'confirm')) {
|
if (!empty($_REQUEST['confirm'])) {
|
||||||
// <form> can't take arguments in its "action" parameter
|
// <form> can't take arguments in its 'action' parameter
|
||||||
// so add any arguments as hidden inputs
|
// so add any arguments as hidden inputs
|
||||||
$query = explode_querystring($a->query_string);
|
$query = explode_querystring($a->query_string);
|
||||||
$inputs = [];
|
$inputs = [];
|
||||||
|
@ -464,7 +450,7 @@ class Contact extends BaseModule
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
// Now check how the user responded to the confirmation query
|
// Now check how the user responded to the confirmation query
|
||||||
if (defaults($_REQUEST, 'canceled')) {
|
if (!empty($_REQUEST['canceled'])) {
|
||||||
goaway('contact');
|
goaway('contact');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -484,7 +470,7 @@ class Contact extends BaseModule
|
||||||
|
|
||||||
$_SESSION['return_url'] = $a->query_string;
|
$_SESSION['return_url'] = $a->query_string;
|
||||||
|
|
||||||
if ((defaults($a->data, 'contact')) && (is_array($a->data['contact']))) {
|
if (!empty($a->data['contact']) && is_array($a->data['contact'])) {
|
||||||
$contact_id = $a->data['contact']['id'];
|
$contact_id = $a->data['contact']['id'];
|
||||||
$contact = $a->data['contact'];
|
$contact = $a->data['contact'];
|
||||||
|
|
||||||
|
@ -522,7 +508,7 @@ class Contact extends BaseModule
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!in_array($contact['network'], [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::OSTATUS, Protocol::DIASPORA])) {
|
if (!in_array($contact['network'], [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::OSTATUS, Protocol::DIASPORA])) {
|
||||||
$relation_text = "";
|
$relation_text = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
$relation_text = sprintf($relation_text, htmlentities($contact['name']));
|
$relation_text = sprintf($relation_text, htmlentities($contact['name']));
|
||||||
|
@ -539,13 +525,13 @@ class Contact extends BaseModule
|
||||||
$last_update = (($contact['last-update'] <= NULL_DATE) ? L10n::t('Never') : DateTimeFormat::local($contact['last-update'], 'D, j M Y, g:i A'));
|
$last_update = (($contact['last-update'] <= NULL_DATE) ? L10n::t('Never') : DateTimeFormat::local($contact['last-update'], 'D, j M Y, g:i A'));
|
||||||
|
|
||||||
if ($contact['last-update'] > NULL_DATE) {
|
if ($contact['last-update'] > NULL_DATE) {
|
||||||
$last_update .= ' ' . (($contact['last-update'] <= $contact['success_update']) ? L10n::t("\x28Update was successful\x29") : L10n::t("\x28Update was not successful\x29"));
|
$last_update .= ' ' . (($contact['last-update'] <= $contact['success_update']) ? L10n::t('(Update was successful)') : L10n::t('(Update was not successful)'));
|
||||||
}
|
}
|
||||||
$lblsuggest = (($contact['network'] === Protocol::DFRN) ? L10n::t('Suggest friends') : '');
|
$lblsuggest = (($contact['network'] === Protocol::DFRN) ? L10n::t('Suggest friends') : '');
|
||||||
|
|
||||||
$poll_enabled = in_array($contact['network'], [Protocol::DFRN, Protocol::OSTATUS, Protocol::FEED, Protocol::MAIL]);
|
$poll_enabled = in_array($contact['network'], [Protocol::DFRN, Protocol::OSTATUS, Protocol::FEED, Protocol::MAIL]);
|
||||||
|
|
||||||
$nettype = L10n::t('Network type: %s', ContactSelector::networkToName($contact['network'], $contact["url"]));
|
$nettype = L10n::t('Network type: %s', ContactSelector::networkToName($contact['network'], $contact['url']));
|
||||||
|
|
||||||
// tabs
|
// tabs
|
||||||
$tab_str = self::getTabsHTML($a, $contact, 3);
|
$tab_str = self::getTabsHTML($a, $contact, 3);
|
||||||
|
@ -558,8 +544,9 @@ class Contact extends BaseModule
|
||||||
'fetch_further_information',
|
'fetch_further_information',
|
||||||
L10n::t('Fetch further information for feeds'),
|
L10n::t('Fetch further information for feeds'),
|
||||||
$contact['fetch_further_information'],
|
$contact['fetch_further_information'],
|
||||||
L10n::t("Fetch information like preview pictures, title and teaser from the feed item. You can activate this if the feed doesn't contain much text. Keywords are taken from the meta header in the feed item and are posted as hash tags."),
|
L10n::t('Fetch information like preview pictures, title and teaser from the feed item. You can activate this if the feed doesn\'t contain much text. Keywords are taken from the meta header in the feed item and are posted as hash tags.'),
|
||||||
['0' => L10n::t('Disabled'),
|
[
|
||||||
|
'0' => L10n::t('Disabled'),
|
||||||
'1' => L10n::t('Fetch information'),
|
'1' => L10n::t('Fetch information'),
|
||||||
'3' => L10n::t('Fetch keywords'),
|
'3' => L10n::t('Fetch keywords'),
|
||||||
'2' => L10n::t('Fetch information and keywords')
|
'2' => L10n::t('Fetch information and keywords')
|
||||||
|
@ -569,12 +556,12 @@ class Contact extends BaseModule
|
||||||
|
|
||||||
$poll_interval = null;
|
$poll_interval = null;
|
||||||
if (in_array($contact['network'], [Protocol::FEED, Protocol::MAIL])) {
|
if (in_array($contact['network'], [Protocol::FEED, Protocol::MAIL])) {
|
||||||
$poll_interval = ContactSelector::pollInterval($contact['priority'], (!$poll_enabled));
|
$poll_interval = ContactSelector::pollInterval($contact['priority'], !$poll_enabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
$profile_select = null;
|
$profile_select = null;
|
||||||
if ($contact['network'] == Protocol::DFRN) {
|
if ($contact['network'] == Protocol::DFRN) {
|
||||||
$profile_select = ContactSelector::profileAssign($contact['profile-id'], (($contact['network'] !== Protocol::DFRN) ? true : false));
|
$profile_select = ContactSelector::profileAssign($contact['profile-id'], $contact['network'] !== Protocol::DFRN);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// @todo Only show the following link with DFRN when the remote version supports it
|
/// @todo Only show the following link with DFRN when the remote version supports it
|
||||||
|
@ -582,12 +569,12 @@ class Contact extends BaseModule
|
||||||
$follow_text = '';
|
$follow_text = '';
|
||||||
if (in_array($contact['rel'], [Model\Contact::FRIEND, Model\Contact::SHARING])) {
|
if (in_array($contact['rel'], [Model\Contact::FRIEND, Model\Contact::SHARING])) {
|
||||||
if (in_array($contact['network'], Protocol::NATIVE_SUPPORT)) {
|
if (in_array($contact['network'], Protocol::NATIVE_SUPPORT)) {
|
||||||
$follow = $a->getBaseURL(true) . "/unfollow?url=" . urlencode($contact["url"]);
|
$follow = $a->getBaseURL(true) . '/unfollow?url=' . urlencode($contact['url']);
|
||||||
$follow_text = L10n::t("Disconnect/Unfollow");
|
$follow_text = L10n::t('Disconnect/Unfollow');
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$follow = $a->getBaseURL(true) . "/follow?url=" . urlencode($contact["url"]);
|
$follow = $a->getBaseURL(true) . '/follow?url=' . urlencode($contact['url']);
|
||||||
$follow_text = L10n::t("Connect/Follow");
|
$follow_text = L10n::t('Connect/Follow');
|
||||||
}
|
}
|
||||||
|
|
||||||
// Load contactact related actions like hide, suggest, delete and others
|
// Load contactact related actions like hide, suggest, delete and others
|
||||||
|
@ -603,9 +590,9 @@ class Contact extends BaseModule
|
||||||
$contact_settings_label = null;
|
$contact_settings_label = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
$tpl = get_markup_template("contact_edit.tpl");
|
$tpl = get_markup_template('contact_edit.tpl');
|
||||||
$o .= replace_macros($tpl, [
|
$o .= replace_macros($tpl, [
|
||||||
'$header' => L10n::t("Contact"),
|
'$header' => L10n::t('Contact'),
|
||||||
'$tab_str' => $tab_str,
|
'$tab_str' => $tab_str,
|
||||||
'$submit' => L10n::t('Submit'),
|
'$submit' => L10n::t('Submit'),
|
||||||
'$lbl_vis1' => $lbl_vis1,
|
'$lbl_vis1' => $lbl_vis1,
|
||||||
|
@ -619,7 +606,7 @@ class Contact extends BaseModule
|
||||||
'$visit' => L10n::t('Visit %s\'s profile [%s]', $contact['name'], $contact['url']),
|
'$visit' => L10n::t('Visit %s\'s profile [%s]', $contact['name'], $contact['url']),
|
||||||
'$blockunblock' => L10n::t('Block/Unblock contact'),
|
'$blockunblock' => L10n::t('Block/Unblock contact'),
|
||||||
'$ignorecont' => L10n::t('Ignore contact'),
|
'$ignorecont' => L10n::t('Ignore contact'),
|
||||||
'$lblcrepair' => L10n::t("Repair URL settings"),
|
'$lblcrepair' => L10n::t('Repair URL settings'),
|
||||||
'$lblrecent' => L10n::t('View conversations'),
|
'$lblrecent' => L10n::t('View conversations'),
|
||||||
'$lblsuggest' => $lblsuggest,
|
'$lblsuggest' => $lblsuggest,
|
||||||
'$nettype' => $nettype,
|
'$nettype' => $nettype,
|
||||||
|
@ -653,22 +640,22 @@ class Contact extends BaseModule
|
||||||
'$dir_icon' => $dir_icon,
|
'$dir_icon' => $dir_icon,
|
||||||
'$sparkle' => $sparkle,
|
'$sparkle' => $sparkle,
|
||||||
'$url' => $url,
|
'$url' => $url,
|
||||||
'$profileurllabel' => L10n::t('Profile URL'),
|
'$profileurllabel'=> L10n::t('Profile URL'),
|
||||||
'$profileurl' => $contact['url'],
|
'$profileurl' => $contact['url'],
|
||||||
'$account_type' => Model\Contact::getAccountType($contact),
|
'$account_type' => Model\Contact::getAccountType($contact),
|
||||||
'$location' => BBCode::convert($contact["location"]),
|
'$location' => BBCode::convert($contact['location']),
|
||||||
'$location_label' => L10n::t("Location:"),
|
'$location_label' => L10n::t('Location:'),
|
||||||
'$xmpp' => BBCode::convert($contact["xmpp"]),
|
'$xmpp' => BBCode::convert($contact['xmpp']),
|
||||||
'$xmpp_label' => L10n::t("XMPP:"),
|
'$xmpp_label' => L10n::t('XMPP:'),
|
||||||
'$about' => BBCode::convert($contact["about"], false),
|
'$about' => BBCode::convert($contact['about'], false),
|
||||||
'$about_label' => L10n::t("About:"),
|
'$about_label' => L10n::t('About:'),
|
||||||
'$keywords' => $contact["keywords"],
|
'$keywords' => $contact['keywords'],
|
||||||
'$keywords_label' => L10n::t("Tags:"),
|
'$keywords_label' => L10n::t('Tags:'),
|
||||||
'$contact_action_button' => L10n::t("Actions"),
|
'$contact_action_button' => L10n::t('Actions'),
|
||||||
'$contact_actions' => $contact_actions,
|
'$contact_actions'=> $contact_actions,
|
||||||
'$contact_status' => L10n::t("Status"),
|
'$contact_status' => L10n::t('Status'),
|
||||||
'$contact_settings_label' => $contact_settings_label,
|
'$contact_settings_label' => $contact_settings_label,
|
||||||
'$contact_profile_label' => L10n::t("Profile"),
|
'$contact_profile_label' => L10n::t('Profile'),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$arr = ['contact' => $contact, 'output' => $o];
|
$arr = ['contact' => $contact, 'output' => $o];
|
||||||
|
@ -705,8 +692,8 @@ class Contact extends BaseModule
|
||||||
|
|
||||||
$sql_extra .= sprintf(" AND `network` != '%s' ", Protocol::PHANTOM);
|
$sql_extra .= sprintf(" AND `network` != '%s' ", Protocol::PHANTOM);
|
||||||
|
|
||||||
$search = defaults($_GET, 'search') ? notags(trim($_GET['search'])) : '';
|
$search = notags(trim(defaults($_GET, 'search', '')));
|
||||||
$nets = defaults($_GET, 'nets' ) ? notags(trim($_GET['nets'])) : '';
|
$nets = notags(trim(defaults($_GET, 'nets' , '')));
|
||||||
|
|
||||||
$tabs = [
|
$tabs = [
|
||||||
[
|
[
|
||||||
|
@ -812,7 +799,7 @@ class Contact extends BaseModule
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$tpl = get_markup_template("contacts-template.tpl");
|
$tpl = get_markup_template('contacts-template.tpl');
|
||||||
$o .= replace_macros($tpl, [
|
$o .= replace_macros($tpl, [
|
||||||
'$baseurl' => System::baseUrl(),
|
'$baseurl' => System::baseUrl(),
|
||||||
'$header' => L10n::t('Contacts') . (($nets) ? ' - ' . ContactSelector::networkToName($nets) : ''),
|
'$header' => L10n::t('Contacts') . (($nets) ? ' - ' . ContactSelector::networkToName($nets) : ''),
|
||||||
|
@ -820,7 +807,7 @@ class Contact extends BaseModule
|
||||||
'$total' => $total,
|
'$total' => $total,
|
||||||
'$search' => $search_hdr,
|
'$search' => $search_hdr,
|
||||||
'$desc' => L10n::t('Search your contacts'),
|
'$desc' => L10n::t('Search your contacts'),
|
||||||
'$finding' => $searching ? L10n::t('Results for: %s', $search) : "",
|
'$finding' => $searching ? L10n::t('Results for: %s', $search) : '',
|
||||||
'$submit' => L10n::t('Find'),
|
'$submit' => L10n::t('Find'),
|
||||||
'$cmd' => $a->cmd,
|
'$cmd' => $a->cmd,
|
||||||
'$contacts' => $contacts,
|
'$contacts' => $contacts,
|
||||||
|
@ -828,10 +815,10 @@ class Contact extends BaseModule
|
||||||
'multiselect' => 1,
|
'multiselect' => 1,
|
||||||
'$batch_actions' => [
|
'$batch_actions' => [
|
||||||
'contacts_batch_update' => L10n::t('Update'),
|
'contacts_batch_update' => L10n::t('Update'),
|
||||||
'contacts_batch_block' => L10n::t('Block') . "/" . L10n::t("Unblock"),
|
'contacts_batch_block' => L10n::t('Block') . '/' . L10n::t('Unblock'),
|
||||||
"contacts_batch_ignore" => L10n::t('Ignore') . "/" . L10n::t("Unignore"),
|
'contacts_batch_ignore' => L10n::t('Ignore') . '/' . L10n::t('Unignore'),
|
||||||
"contacts_batch_archive" => L10n::t('Archive') . "/" . L10n::t("Unarchive"),
|
'contacts_batch_archive' => L10n::t('Archive') . '/' . L10n::t('Unarchive'),
|
||||||
"contacts_batch_drop" => L10n::t('Delete'),
|
'contacts_batch_drop' => L10n::t('Delete'),
|
||||||
],
|
],
|
||||||
'$h_batch_actions' => L10n::t('Batch Actions'),
|
'$h_batch_actions' => L10n::t('Batch Actions'),
|
||||||
'$paginate' => paginate($a),
|
'$paginate' => paginate($a),
|
||||||
|
@ -950,18 +937,16 @@ class Contact extends BaseModule
|
||||||
}
|
}
|
||||||
|
|
||||||
if (DBA::isResult($contact)) {
|
if (DBA::isResult($contact)) {
|
||||||
$a->page['aside'] = "";
|
$a->page['aside'] = '';
|
||||||
|
|
||||||
$profiledata = Model\Contact::getDetailsByURL($contact["url"]);
|
$profiledata = Model\Contact::getDetailsByURL($contact['url']);
|
||||||
|
|
||||||
if (local_user()) {
|
if (local_user() && in_array($profiledata['network'], [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS])) {
|
||||||
if (in_array($profiledata["network"], [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS])) {
|
$profiledata['remoteconnect'] = System::baseUrl() . '/follow?url=' . urlencode($profiledata['url']);
|
||||||
$profiledata["remoteconnect"] = System::baseUrl()."/follow?url=".urlencode($profiledata["url"]);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Model\Profile::load($a, "", 0, $profiledata, true);
|
Model\Profile::load($a, '', 0, $profiledata, true);
|
||||||
$o .= Model\Contact::getPostsFromUrl($contact["url"], true, $update);
|
$o .= Model\Contact::getPostsFromUrl($contact['url'], true, $update);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $o;
|
return $o;
|
||||||
|
@ -974,18 +959,16 @@ class Contact extends BaseModule
|
||||||
$o = self::getTabsHTML($a, $contact, 2);
|
$o = self::getTabsHTML($a, $contact, 2);
|
||||||
|
|
||||||
if (DBA::isResult($contact)) {
|
if (DBA::isResult($contact)) {
|
||||||
$a->page['aside'] = "";
|
$a->page['aside'] = '';
|
||||||
|
|
||||||
$profiledata = Model\Contact::getDetailsByURL($contact["url"]);
|
$profiledata = Model\Contact::getDetailsByURL($contact['url']);
|
||||||
|
|
||||||
if (local_user()) {
|
if (local_user() && in_array($profiledata['network'], [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS])) {
|
||||||
if (in_array($profiledata["network"], [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS])) {
|
$profiledata['remoteconnect'] = System::baseUrl() . '/follow?url=' . urlencode($profiledata['url']);
|
||||||
$profiledata["remoteconnect"] = System::baseUrl()."/follow?url=".urlencode($profiledata["url"]);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Model\Profile::load($a, "", 0, $profiledata, true);
|
Model\Profile::load($a, '', 0, $profiledata, true);
|
||||||
$o .= Model\Contact::getPostsFromUrl($contact["url"]);
|
$o .= Model\Contact::getPostsFromUrl($contact['url']);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $o;
|
return $o;
|
||||||
|
@ -1033,8 +1016,8 @@ class Contact extends BaseModule
|
||||||
|
|
||||||
return [
|
return [
|
||||||
'img_hover' => L10n::t('Visit %s\'s profile [%s]', $rr['name'], $rr['url']),
|
'img_hover' => L10n::t('Visit %s\'s profile [%s]', $rr['name'], $rr['url']),
|
||||||
'edit_hover' => L10n::t('Edit contact'),
|
'edit_hover'=> L10n::t('Edit contact'),
|
||||||
'photo_menu' => Model\Contact::photoMenu($rr),
|
'photo_menu'=> Model\Contact::photoMenu($rr),
|
||||||
'id' => $rr['id'],
|
'id' => $rr['id'],
|
||||||
'alt_text' => $alt_text,
|
'alt_text' => $alt_text,
|
||||||
'dir_icon' => $dir_icon,
|
'dir_icon' => $dir_icon,
|
||||||
|
@ -1043,7 +1026,7 @@ class Contact extends BaseModule
|
||||||
'username' => htmlentities($rr['name']),
|
'username' => htmlentities($rr['name']),
|
||||||
'account_type' => Model\Contact::getAccountType($rr),
|
'account_type' => Model\Contact::getAccountType($rr),
|
||||||
'sparkle' => $sparkle,
|
'sparkle' => $sparkle,
|
||||||
'itemurl' => (($rr['addr'] != "") ? $rr['addr'] : $rr['url']),
|
'itemurl' => defaults($rr, 'addr', $rr['url']),
|
||||||
'url' => $url,
|
'url' => $url,
|
||||||
'network' => ContactSelector::networkToName($rr['network'], $rr['url']),
|
'network' => ContactSelector::networkToName($rr['network'], $rr['url']),
|
||||||
'nick' => htmlentities($rr['nick']),
|
'nick' => htmlentities($rr['nick']),
|
||||||
|
|
Loading…
Reference in a new issue