sforkowany z mirror/friendica
209 wiersze
5.5 KiB
PHP
209 wiersze
5.5 KiB
PHP
<?php
|
|
|
|
function directory_init(&$a) {
|
|
$a->set_pager_itemspage(60);
|
|
|
|
if(local_user()) {
|
|
require_once('include/contact_widgets.php');
|
|
|
|
$a->page['aside'] .= findpeople_widget();
|
|
|
|
}
|
|
else {
|
|
unset($_SESSION['theme']);
|
|
unset($_SESSION['mobile-theme']);
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
function directory_post(&$a) {
|
|
if(x($_POST,'search'))
|
|
$a->data['search'] = $_POST['search'];
|
|
}
|
|
|
|
|
|
|
|
function directory_content(&$a) {
|
|
global $db;
|
|
|
|
require_once("mod/proxy.php");
|
|
|
|
if((get_config('system','block_public')) && (! local_user()) && (! remote_user()) ||
|
|
(get_config('system','block_local_dir')) && (! local_user()) && (! remote_user())) {
|
|
notice( t('Public access denied.') . EOL);
|
|
return;
|
|
}
|
|
|
|
$o = '';
|
|
nav_set_selected('directory');
|
|
|
|
if(x($a->data,'search'))
|
|
$search = notags(trim($a->data['search']));
|
|
else
|
|
$search = ((x($_GET,'search')) ? notags(trim(rawurldecode($_GET['search']))) : '');
|
|
|
|
$tpl = get_markup_template('directory_header.tpl');
|
|
|
|
$globaldir = '';
|
|
$gdirpath = get_config('system','directory');
|
|
if(strlen($gdirpath)) {
|
|
$globaldir = '<ul><li><div id="global-directory-link"><a href="'
|
|
. zrl($gdirpath,true) . '">' . t('Global Directory') . '</a></div></li></ul>';
|
|
}
|
|
|
|
$admin = '';
|
|
|
|
$o .= replace_macros($tpl, array(
|
|
'$search' => $search,
|
|
'$globaldir' => $globaldir,
|
|
'$desc' => t('Find on this site'),
|
|
'$admin' => $admin,
|
|
'$finding' => (strlen($search) ? '<h4>' . t('Finding: ') . "'" . $search . "'" . '</h4>' : ""),
|
|
'$sitedir' => t('Site Directory'),
|
|
'$submit' => t('Find')
|
|
));
|
|
|
|
if($search) {
|
|
$search = dbesc($search);
|
|
|
|
$sql_extra = " AND ((`profile`.`name` LIKE '%$search%') OR
|
|
(`user`.`nickname` LIKE '%$search%') OR
|
|
(`pdesc` LIKE '%$search%') OR
|
|
(`locality` LIKE '%$search%') OR
|
|
(`region` LIKE '%$search%') OR
|
|
(`country-name` LIKE '%$search%') OR
|
|
(`gender` LIKE '%$search%') OR
|
|
(`marital` LIKE '%$search%') OR
|
|
(`sexual` LIKE '%$search%') OR
|
|
(`about` LIKE '%$search%') OR
|
|
(`romance` LIKE '%$search%') OR
|
|
(`work` LIKE '%$search%') OR
|
|
(`education` LIKE '%$search%') OR
|
|
(`pub_keywords` LIKE '%$search%') OR
|
|
(`prv_keywords` LIKE '%$search%'))";
|
|
}
|
|
|
|
$publish = ((get_config('system','publish_all')) ? '' : " AND `publish` = 1 " );
|
|
|
|
|
|
$r = $db->q("SELECT COUNT(*) AS `total` FROM `profile` LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid` WHERE `is-default` = 1 $publish AND `user`.`blocked` = 0 $sql_extra ");
|
|
if(count($r))
|
|
$a->set_pager_total($r[0]['total']);
|
|
|
|
$order = " ORDER BY `name` ASC ";
|
|
|
|
$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` LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid` WHERE `is-default` = 1 $publish AND `user`.`blocked` = 0 $sql_extra $order LIMIT ".$limit);
|
|
if(count($r)) {
|
|
|
|
if(in_array('small', $a->argv))
|
|
$photo = 'thumb';
|
|
else
|
|
$photo = 'photo';
|
|
|
|
foreach($r as $rr) {
|
|
|
|
|
|
$profile_link = $a->get_baseurl() . '/profile/' . ((strlen($rr['nickname'])) ? $rr['nickname'] : $rr['profile_uid']);
|
|
|
|
$pdesc = (($rr['pdesc']) ? $rr['pdesc'] . '<br />' : '');
|
|
|
|
$details = '';
|
|
if(strlen($rr['locality']))
|
|
$details .= $rr['locality'];
|
|
if(strlen($rr['region'])) {
|
|
if(strlen($rr['locality']))
|
|
$details .= ', ';
|
|
$details .= $rr['region'];
|
|
}
|
|
if(strlen($rr['country-name'])) {
|
|
if(strlen($details))
|
|
$details .= ', ';
|
|
$details .= $rr['country-name'];
|
|
}
|
|
if(strlen($rr['dob'])) {
|
|
if(($years = age($rr['dob'],$rr['timezone'],'')) != 0)
|
|
$details .= '<br />' . t('Age: ') . $years ;
|
|
}
|
|
if(strlen($rr['gender']))
|
|
$details .= '<br />' . t('Gender: ') . $rr['gender'];
|
|
|
|
if($rr['page-flags'] == PAGE_NORMAL)
|
|
$page_type = "Personal Profile";
|
|
if($rr['page-flags'] == PAGE_SOAPBOX)
|
|
$page_type = "Fan Page";
|
|
if($rr['page-flags'] == PAGE_COMMUNITY)
|
|
$page_type = "Community Forum";
|
|
if($rr['page-flags'] == PAGE_FREELOVE)
|
|
$page_type = "Open Forum";
|
|
if($rr['page-flags'] == PAGE_PRVGROUP)
|
|
$page_type = "Private Group";
|
|
|
|
$profile = $rr;
|
|
|
|
if((x($profile,'address') == 1)
|
|
|| (x($profile,'locality') == 1)
|
|
|| (x($profile,'region') == 1)
|
|
|| (x($profile,'postal-code') == 1)
|
|
|| (x($profile,'country-name') == 1))
|
|
$location = t('Location:');
|
|
|
|
$gender = ((x($profile,'gender') == 1) ? t('Gender:') : False);
|
|
|
|
$marital = ((x($profile,'marital') == 1) ? t('Status:') : False);
|
|
|
|
$homepage = ((x($profile,'homepage') == 1) ? t('Homepage:') : False);
|
|
|
|
$about = ((x($profile,'about') == 1) ? t('About:') : False);
|
|
|
|
$tpl = get_markup_template('directory_item.tpl');
|
|
|
|
if($a->theme['template_engine'] === 'internal') {
|
|
$location_e = template_escape($location);
|
|
}
|
|
else {
|
|
$location_e = $location;
|
|
}
|
|
|
|
$entry = replace_macros($tpl,array(
|
|
'$id' => $rr['id'],
|
|
'$profile_link' => $profile_link,
|
|
'$photo' => proxy_url($a->get_cached_avatar_image($rr[$photo])),
|
|
'$alt_text' => $rr['name'],
|
|
'$name' => $rr['name'],
|
|
'$details' => $pdesc . $details,
|
|
'$page_type' => $page_type,
|
|
'$profile' => $profile,
|
|
'$location' => $location_e,
|
|
'$gender' => $gender,
|
|
'$pdesc' => $pdesc,
|
|
'$marital' => $marital,
|
|
'$homepage' => $homepage,
|
|
'$about' => $about,
|
|
|
|
));
|
|
|
|
$arr = array('contact' => $rr, 'entry' => $entry);
|
|
|
|
call_hooks('directory_item', $arr);
|
|
|
|
unset($profile);
|
|
unset($location);
|
|
|
|
$o .= $entry;
|
|
|
|
}
|
|
|
|
$o .= "<div class=\"directory-end\" ></div>\r\n";
|
|
$o .= paginate($a);
|
|
|
|
}
|
|
else
|
|
info( t("No entries \x28some entries may be hidden\x29.") . EOL);
|
|
|
|
return $o;
|
|
}
|