directory client mode
This commit is contained in:
parent
af5666b791
commit
a168c628a2
@ -38,90 +38,80 @@ function directory_content(&$a) {
|
||||
|
||||
$dirmode = intval(get_config('system','directory_mode'));
|
||||
|
||||
// if(($dirmode == DIRECTORY_MODE_PRIMARY) || ($dirmode == DIRECTORY_MODE_STANDALONE)) {
|
||||
// $localdir = true;
|
||||
// return;
|
||||
// }
|
||||
|
||||
// FIXME
|
||||
$localdir = true;
|
||||
|
||||
|
||||
if(! $localdir) {
|
||||
if(($dirmode == DIRECTORY_MODE_PRIMARY) || ($dirmode == DIRECTORY_MODE_STANDALONE)) {
|
||||
$url = z_root() . '/dirsearch';
|
||||
}
|
||||
if(! $url) {
|
||||
$directory = find_upstream_directory($dirmode);
|
||||
|
||||
if($directory) {
|
||||
$url = $directory['url'];
|
||||
}
|
||||
else {
|
||||
$url = DIRECTORY_FALLBACK_MASTER . '/post';
|
||||
$url = DIRECTORY_FALLBACK_MASTER . '/dirsearch';
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
if($localdir) {
|
||||
if($url) {
|
||||
$query = $url . ' ?f=' ;
|
||||
if($search)
|
||||
$search = dbesc($search);
|
||||
$sql_extra = ((strlen($search)) ? " AND MATCH ( xchan_name, xchan_addr, xprof_desc, xprof_locale, xprof_region, xprof_country, xprof_gender, xprof_marital ) AGAINST ('$search' IN BOOLEAN MODE) " : "");
|
||||
$query .= '$name=' . urlencode($search);
|
||||
|
||||
// group_concat(xtag_term separator ', ') as tags
|
||||
$r = q("SELECT COUNT(xchan_hash) AS `total` FROM xchan left join xprof on xchan_hash = xprof_hash $sql_extra");
|
||||
if($r)
|
||||
$a->set_pager_total($r[0]['total']);
|
||||
|
||||
$order = " ORDER BY `xchan_name` ASC ";
|
||||
}
|
||||
if($a->pager['page'] != 1)
|
||||
$query .= '&p=' . $a->pager['page'];
|
||||
|
||||
|
||||
$r = q("SELECT xchan.*, xprof.* from xchan left join xprof on xchan_hash = xprof_hash $sql_extra $order LIMIT %d , %d ",
|
||||
intval($a->pager['start']),
|
||||
intval($a->pager['itemspage'])
|
||||
);
|
||||
|
||||
|
||||
if($r) {
|
||||
$x = z_fetch_url($query);
|
||||
if($x['success']) {
|
||||
$t = 0;
|
||||
$j = json_decode($x['body'],true);
|
||||
if($j && $j['results']) {
|
||||
|
||||
$entries = array();
|
||||
|
||||
$photo = 'thumb';
|
||||
|
||||
foreach($r as $rr) {
|
||||
foreach($j['results'] as $rr) {
|
||||
|
||||
$profile_link = chanlink_hash($rr['xchan_hash']);
|
||||
|
||||
$pdesc = (($rr['xprof_desc']) ? $rr['xprof_desc'] . '<br />' : '');
|
||||
|
||||
|
||||
$profile_link = chanlink_url($rr['url']);
|
||||
|
||||
$pdesc = (($rr['description']) ? $rr['description'] . '<br />' : '');
|
||||
|
||||
$details = '';
|
||||
if(strlen($rr['xprof_locale']))
|
||||
$details .= $rr['xprof_locale'];
|
||||
if(strlen($rr['xprof_region'])) {
|
||||
if(strlen($rr['xprof_locale']))
|
||||
if(strlen($rr['locale']))
|
||||
$details .= $rr['locale'];
|
||||
if(strlen($rr['region'])) {
|
||||
if(strlen($rr['locale']))
|
||||
$details .= ', ';
|
||||
$details .= $rr['xprof_region'];
|
||||
$details .= $rr['region'];
|
||||
}
|
||||
if(strlen($rr['xprof_country'])) {
|
||||
if(strlen($rr['country'])) {
|
||||
if(strlen($details))
|
||||
$details .= ', ';
|
||||
$details .= $rr['xprof_country'];
|
||||
$details .= $rr['country'];
|
||||
}
|
||||
if(strlen($rr['xprof_dob'])) {
|
||||
if(($years = age($rr['xprof_dob'],'UTC','')) != 0)
|
||||
if(strlen($rr['birthday'])) {
|
||||
if(($years = age($rr['birthday'],'UTC','')) != 0)
|
||||
$details .= '<br />' . t('Age: ') . $years ;
|
||||
}
|
||||
if(strlen($rr['xprof_gender']))
|
||||
$details .= '<br />' . t('Gender: ') . $rr['xprof_gender'];
|
||||
if(strlen($rr['gender']))
|
||||
$details .= '<br />' . t('Gender: ') . $rr['gender'];
|
||||
|
||||
$page_type = '';
|
||||
|
||||
$profile = $rr;
|
||||
|
||||
if ((x($profile,'xprof_locale') == 1)
|
||||
|| (x($profile,'xprof_region') == 1)
|
||||
|| (x($profile,'xprof_postcode') == 1)
|
||||
|| (x($profile,'xprof_country') == 1))
|
||||
if ((x($profile,'locale') == 1)
|
||||
|| (x($profile,'region') == 1)
|
||||
|| (x($profile,'postcode') == 1)
|
||||
|| (x($profile,'country') == 1))
|
||||
$location = t('Location:');
|
||||
|
||||
$gender = ((x($profile,'xprof_gender') == 1) ? t('Gender:') : False);
|
||||
$gender = ((x($profile,'gender') == 1) ? t('Gender:') : False);
|
||||
|
||||
$marital = ((x($profile,'marital') == 1) ? t('Status:') : False);
|
||||
|
||||
@ -129,14 +119,13 @@ $localdir = true;
|
||||
|
||||
$about = ((x($profile,'about') == 1) ? t('About:') : False);
|
||||
|
||||
$t = 0;
|
||||
|
||||
$entry = array(
|
||||
'id' => ++$t,
|
||||
'profile_link' => $profile_link,
|
||||
'photo' => $rr[xchan_photo_m],
|
||||
'alttext' => $rr['xchan_name'],
|
||||
'name' => $rr['xchan_name'],
|
||||
'photo' => $rr['photo'],
|
||||
'alttext' => $rr['name'] . ' ' . $rr['address'],
|
||||
'name' => $rr['name'],
|
||||
'details' => $pdesc . $details,
|
||||
'profile' => $profile,
|
||||
'location' => $location,
|
||||
@ -152,10 +141,11 @@ $localdir = true;
|
||||
|
||||
call_hooks('directory_item', $arr);
|
||||
|
||||
$entries[] = $entry;
|
||||
|
||||
unset($profile);
|
||||
unset($location);
|
||||
|
||||
$entries[] = $entry;
|
||||
|
||||
}
|
||||
|
||||
@ -172,7 +162,7 @@ $localdir = true;
|
||||
));
|
||||
|
||||
|
||||
$o .= paginate($a);
|
||||
$o .= alt_pager($a,$j['records']);
|
||||
|
||||
}
|
||||
|
||||
@ -183,3 +173,4 @@ $localdir = true;
|
||||
|
||||
return $o;
|
||||
}
|
||||
|
||||
|
@ -36,7 +36,6 @@ function dirsearch_content(&$a) {
|
||||
$marital = ((x($_REQUEST,'marital')) ? $_REQUEST['marital'] : '');
|
||||
$keywords = ((x($_REQUEST,'keywords')) ? $_REQUEST['keywords'] : '');
|
||||
|
||||
|
||||
$sql_extra = '';
|
||||
|
||||
if($name)
|
||||
|
Reference in New Issue
Block a user