X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=mod%2Fviewcontacts.php;h=af5ecd9d67011b5daaeace861600026cd7cd3975;hb=303aef34f0804f9becc10610ae85985835f9d9bf;hp=04520e0d9309cc163ffe86c165625ef0e96233cd;hpb=c00772204100a44267c38f7a2533268b5dff1248;p=friendica.git diff --git a/mod/viewcontacts.php b/mod/viewcontacts.php index 04520e0d93..af5ecd9d67 100644 --- a/mod/viewcontacts.php +++ b/mod/viewcontacts.php @@ -1,64 +1,79 @@ argc > 1) { + if ($a->argc > 1) { $nick = $a->argv[1]; $r = q("SELECT * FROM `user` WHERE `nickname` = '%s' AND `blocked` = 0 LIMIT 1", dbesc($nick) ); - if(! count($r)) + if (! DBM::is_result($r)) { return; + } $a->data['user'] = $r[0]; $a->profile_uid = $r[0]['uid']; $is_owner = (local_user() && (local_user() == $a->profile_uid)); - profile_load($a,$a->argv[1]); + Profile::load($a, $a->argv[1]); } } - -function viewcontacts_content(&$a) { +function viewcontacts_content(App $a) +{ require_once("mod/proxy.php"); - if((get_config('system','block_public')) && (! local_user()) && (! remote_user())) { - notice( t('Public access denied.') . EOL); + if ((Config::get('system', 'block_public')) && (! local_user()) && (! remote_user())) { + notice(L10n::t('Public access denied.') . EOL); return; } - if(((! count($a->profile)) || ($a->profile['hide-friends']))) { - notice( t('Permission denied.') . EOL); - return; - } + $is_owner = $a->profile['profile_uid'] == local_user(); $o = ""; // tabs - $o .= profile_tabs($a,$is_owner, $a->data['user']['nickname']); + $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; + } $r = q("SELECT COUNT(*) AS `total` FROM `contact` - WHERE `uid` = %d AND `blocked` = 0 AND `pending` = 0 AND `hidden` = 0 AND `archive` = 0 + WHERE `uid` = %d AND NOT `blocked` AND NOT `pending` + AND NOT `hidden` AND NOT `archive` AND `network` IN ('%s', '%s', '%s')", intval($a->profile['uid']), dbesc(NETWORK_DFRN), dbesc(NETWORK_DIASPORA), dbesc(NETWORK_OSTATUS) ); - if(count($r)) + if (DBM::is_result($r)) { $a->set_pager_total($r[0]['total']); + } $r = q("SELECT * FROM `contact` - WHERE `uid` = %d AND `blocked` = 0 AND `pending` = 0 AND `hidden` = 0 AND `archive` = 0 + WHERE `uid` = %d AND NOT `blocked` AND NOT `pending` + AND NOT `hidden` AND NOT `archive` AND `network` IN ('%s', '%s', '%s') ORDER BY `name` ASC LIMIT %d, %d", intval($a->profile['uid']), @@ -68,55 +83,46 @@ function viewcontacts_content(&$a) { intval($a->pager['start']), intval($a->pager['itemspage']) ); - if(!count($r)) { - info(t('No contacts.').EOL); + if (!DBM::is_result($r)) { + info(L10n::t('No contacts.').EOL); return $o; } - $contacts = array(); + $contacts = []; - foreach($r as $rr) { - if($rr['self']) + foreach ($r as $rr) { + /// @TODO This triggers an E_NOTICE if 'self' is not there + if ($rr['self']) { continue; + } - $url = $rr['url']; - - // route DFRN profiles through the redirect - - $is_owner = ((local_user() && ($a->profile['profile_uid'] == local_user())) ? true : false); + $contact_details = Contact::getDetailsByURL($rr['url'], $a->profile['uid'], $rr); - if($is_owner && ($rr['network'] === NETWORK_DFRN) && ($rr['rel'])) - $url = 'redir/' . $rr['id']; - else - $url = zrl($url); - - $contact_details = get_contact_details_by_url($rr['url'], $a->profile['uid']); - - $contacts[] = array( + $contacts[] = [ 'id' => $rr['id'], - 'img_hover' => sprintf( t('Visit %s\'s profile [%s]'), $rr['name'], $rr['url']), - 'photo_menu' => contact_photo_menu($rr), - 'thumb' => proxy_url($rr['thumb'], false, PROXY_SIZE_THUMB), - 'name' => htmlentities(substr($rr['name'],0,20)), - 'username' => htmlentities($rr['name']), + 'img_hover' => L10n::t('Visit %s\'s profile [%s]', $contact_details['name'], $rr['url']), + 'photo_menu' => Contact::photoMenu($rr), + 'thumb' => proxy_url($contact_details['thumb'], false, PROXY_SIZE_THUMB), + 'name' => htmlentities(substr($contact_details['name'], 0, 20)), + 'username' => htmlentities($contact_details['name']), 'details' => $contact_details['location'], 'tags' => $contact_details['keywords'], 'about' => $contact_details['about'], - 'account_type' => (($contact_details['community']) ? t('Forum') : ''), - 'url' => $url, + 'account_type' => Contact::getAccountType($contact_details), + 'url' => Contact::magicLink($rr['url']), 'sparkle' => '', 'itemurl' => (($contact_details['addr'] != "") ? $contact_details['addr'] : $rr['url']), - 'network' => network_to_name($rr['network'], $rr['url']), - ); + 'network' => ContactSelector::networkToName($rr['network'], $rr['url']), + ]; } $tpl = get_markup_template("viewcontact_template.tpl"); - $o .= replace_macros($tpl, array( - '$title' => t('Contacts'), + $o .= replace_macros($tpl, [ + '$title' => L10n::t('Contacts'), '$contacts' => $contacts, '$paginate' => paginate($a), - )); + ]); return $o;