directory - reduce the number of queries
This commit is contained in:
parent
9189971cb8
commit
aa047e16d7
2 changed files with 10 additions and 10 deletions
|
@ -830,6 +830,9 @@ function contacts_content(&$a) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function _contact_detail_for_template($rr){
|
function _contact_detail_for_template($rr){
|
||||||
|
|
||||||
|
$community = '';
|
||||||
|
|
||||||
switch($rr['rel']) {
|
switch($rr['rel']) {
|
||||||
case CONTACT_IS_FRIEND:
|
case CONTACT_IS_FRIEND:
|
||||||
$dir_icon = 'images/lrarrow.gif';
|
$dir_icon = 'images/lrarrow.gif';
|
||||||
|
|
|
@ -85,9 +85,11 @@ function directory_content(&$a) {
|
||||||
|
|
||||||
$limit = intval($a->pager['start']).",".intval($a->pager['itemspage']);
|
$limit = intval($a->pager['start']).",".intval($a->pager['itemspage']);
|
||||||
|
|
||||||
$r = $db->q("SELECT `profile`.*, `profile`.`uid` AS `profile_uid`, `user`.`nickname`, `user`.`timezone` , `user`.`page-flags` FROM `profile`
|
$r = $db->q("SELECT `profile`.*, `profile`.`uid` AS `profile_uid`, `user`.`nickname`, `user`.`timezone` , `user`.`page-flags`,
|
||||||
|
`contact`.`addr` AS faddr, `contact`.`url` AS profile_url FROM `profile`
|
||||||
LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid`
|
LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid`
|
||||||
WHERE `is-default` = 1 $publish AND `user`.`blocked` = 0 $sql_extra $order LIMIT ".$limit);
|
INNER JOIN `contact` ON `contact`.`uid` = `user`.`uid`
|
||||||
|
WHERE `is-default` = 1 $publish AND `user`.`blocked` = 0 AND `contact`.`self` $sql_extra $order LIMIT ".$limit);
|
||||||
if(count($r)) {
|
if(count($r)) {
|
||||||
|
|
||||||
if(in_array('small', $a->argv))
|
if(in_array('small', $a->argv))
|
||||||
|
@ -98,14 +100,9 @@ function directory_content(&$a) {
|
||||||
foreach($r as $rr) {
|
foreach($r as $rr) {
|
||||||
|
|
||||||
$community = '';
|
$community = '';
|
||||||
|
$itemurl= '';
|
||||||
|
|
||||||
// get the friendica address and the profile url of the user
|
$itemurl = (($rr['faddr'] != "") ? $rr['faddr'] : $rr['profile_url']);
|
||||||
$p = q("SELECT `addr` AS faddr, `url` AS profile_url FROM `contact` WHERE `uid` = %d AND `self`",
|
|
||||||
intval($rr['uid'])
|
|
||||||
);
|
|
||||||
|
|
||||||
if(count($p))
|
|
||||||
$itemurl = (($p['0']['faddr'] != "") ? $p['0']['faddr'] : $p['0']['profile_url']);
|
|
||||||
|
|
||||||
$profile_link = z_root() . '/profile/' . ((strlen($rr['nickname'])) ? $rr['nickname'] : $rr['profile_uid']);
|
$profile_link = z_root() . '/profile/' . ((strlen($rr['nickname'])) ? $rr['nickname'] : $rr['profile_uid']);
|
||||||
|
|
||||||
|
@ -135,7 +132,7 @@ function directory_content(&$a) {
|
||||||
// show if account is a community account
|
// show if account is a community account
|
||||||
// ToDo the other should be also respected, but first we need a good translatiion
|
// ToDo the other should be also respected, but first we need a good translatiion
|
||||||
// and systemwide consistency for displaying the page type
|
// and systemwide consistency for displaying the page type
|
||||||
if(intval($rr['page-flags']) == PAGE_COMMUNITY OR intval($rr['page-flags']) == PAGE_PRVGROUP)
|
if((intval($rr['page-flags']) == PAGE_COMMUNITY) OR (intval($rr['page-flags']) == PAGE_PRVGROUP))
|
||||||
$community = true;
|
$community = true;
|
||||||
|
|
||||||
$profile = $rr;
|
$profile = $rr;
|
||||||
|
|
Loading…
Reference in a new issue