}
$o = '';
+ $entries = [];
+
Nav::setSelected('directory');
if (!empty($a->data['search'])) {
$limit = $pager->getStart()."," . $pager->getItemsPerPage();
$r = DBA::p("SELECT `profile`.*, `profile`.`uid` AS `profile_uid`, `user`.`nickname`, `user`.`timezone` , `user`.`page-flags`,
- `contact`.`addr`, `contact`.`url` AS profile_url FROM `profile`
+ `contact`.`addr`, `contact`.`url` AS `profile_url` FROM `profile`
LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid`
LEFT JOIN `contact` ON `contact`.`uid` = `user`.`uid`
WHERE `is-default` $publish AND NOT `user`.`blocked` AND NOT `user`.`account_removed` AND `contact`.`self`
$photo = 'photo';
}
- $entries = [];
-
while ($rr = DBA::fetch($r)) {
- $itemurl = (($rr['addr'] != "") ? $rr['addr'] : $rr['profile_url']);
+ $entries[] = format_directory_entry($rr, $photo);
+ }
+ DBA::close($r);
+ } else {
+ info(L10n::t("No entries \x28some entries may be hidden\x29.") . EOL);
+ }
+
+ $tpl = Renderer::getMarkupTemplate('directory_header.tpl');
+
+ $o .= Renderer::replaceMacros($tpl, [
+ '$search' => $search,
+ '$globaldir' => L10n::t('Global Directory'),
+ '$gdirpath' => $gdirpath,
+ '$desc' => L10n::t('Find on this site'),
+ '$contacts' => $entries,
+ '$finding' => L10n::t('Results for:'),
+ '$findterm' => (strlen($search) ? $search : ""),
+ '$title' => L10n::t('Site Directory'),
+ '$search_mod' => 'directory',
+ '$submit' => L10n::t('Find'),
+ '$paginate' => $pager->renderFull($total),
+ ]);
+
+ return $o;
+}
+
+/**
+ * Format contact/profile/user data from the database into an usable
+ * array for displaying directory entries.
+ *
+ * @param type $r The directory entry from the database.
+ * @param string $photo_size Avatar size (thumb, photo or micro).
+ *
+ * @return array
+ */
+function format_directory_entry($arr, $photo_size = 'photo')
+{
+ $itemurl = (($arr['addr'] != "") ? $arr['addr'] : $arr['profile_url']);
- $profile_link = $rr['profile_url'];
+ $profile_link = $arr['profile_url'];
- $pdesc = (($rr['pdesc']) ? $rr['pdesc'] . '<br />' : '');
+ $pdesc = (($arr['pdesc']) ? $arr['pdesc'] . '<br />' : '');
$details = '';
- if (strlen($rr['locality'])) {
- $details .= $rr['locality'];
+ if (strlen($arr['locality'])) {
+ $details .= $arr['locality'];
}
- if (strlen($rr['region'])) {
- if (strlen($rr['locality'])) {
+ if (strlen($arr['region'])) {
+ if (strlen($arr['locality'])) {
$details .= ', ';
}
- $details .= $rr['region'];
+ $details .= $arr['region'];
}
- if (strlen($rr['country-name'])) {
+ if (strlen($arr['country-name'])) {
if (strlen($details)) {
$details .= ', ';
}
- $details .= $rr['country-name'];
+ $details .= $arr['country-name'];
}
-// if(strlen($rr['dob'])) {
-// if(($years = age($rr['dob'],$rr['timezone'],'')) != 0)
-// $details .= '<br />' . L10n::t('Age: ') . $years;
-// }
-// if(strlen($rr['gender']))
-// $details .= '<br />' . L10n::t('Gender: ') . $rr['gender'];
- $profile = $rr;
+ $profile = $arr;
if (!empty($profile['address'])
|| !empty($profile['locality'])
$location = '';
}
- $gender = (!empty($profile['gender']) ? L10n::t('Gender:') : false);
- $marital = (!empty($profile['marital']) ? L10n::t('Status:') : false);
+ $gender = (!empty($profile['gender']) ? L10n::t('Gender:') : false);
+ $marital = (!empty($profile['marital']) ? L10n::t('Status:') : false);
$homepage = (!empty($profile['homepage']) ? L10n::t('Homepage:') : false);
- $about = (!empty($profile['about']) ? L10n::t('About:') : false);
+ $about = (!empty($profile['about']) ? L10n::t('About:') : false);
$location_e = $location;
];
$entry = [
- 'id' => $rr['id'],
+ 'id' => $arr['id'],
'url' => Contact::magicLInk($profile_link),
'itemurl' => $itemurl,
- 'thumb' => ProxyUtils::proxifyUrl($rr[$photo], false, ProxyUtils::SIZE_THUMB),
- 'img_hover' => $rr['name'],
- 'name' => $rr['name'],
+ 'thumb' => ProxyUtils::proxifyUrl($arr[$photo_size], false, ProxyUtils::SIZE_THUMB),
+ 'img_hover' => $arr['name'],
+ 'name' => $arr['name'],
'details' => $details,
- 'account_type' => Contact::getAccountType($rr),
+ 'account_type' => Contact::getAccountType($arr),
'profile' => $profile,
'location' => $location_e,
- 'tags' => $rr['pub_keywords'],
+ 'tags' => $arr['pub_keywords'],
'gender' => $gender,
'pdesc' => $pdesc,
'marital' => $marital,
];
- $arr = ['contact' => $rr, 'entry' => $entry];
+ $hook = ['contact' => $arr, 'entry' => $entry];
- Hook::callAll('directory_item', $arr);
+ Hook::callAll('directory_item', $hook);
unset($profile);
unset($location);
- if (!$arr['entry']) {
- continue;
- }
-
- $entries[] = $arr['entry'];
- }
- DBA::close($r);
-
- $tpl = Renderer::getMarkupTemplate('directory_header.tpl');
-
- $o .= Renderer::replaceMacros($tpl, [
- '$search' => $search,
- '$globaldir' => L10n::t('Global Directory'),
- '$gdirpath' => $gdirpath,
- '$desc' => L10n::t('Find on this site'),
- '$contacts' => $entries,
- '$finding' => L10n::t('Results for:'),
- '$findterm' => (strlen($search) ? $search : ""),
- '$title' => L10n::t('Site Directory'),
- '$submit' => L10n::t('Find'),
- '$paginate' => $pager->renderFull($total),
- ]);
- } else {
- info(L10n::t("No entries \x28some entries may be hidden\x29.") . EOL);
- }
-
- return $o;
-}
+ return $hook['entry'];
+}
\ No newline at end of file
-{{if $gdirpath}}
-<ul class="list-unstyled pull-right">
- <li><div id="global-directory-link"><a href="{{$gdirpath}}">{{$globaldir}}</a></div></li>
-</ul>
-{{/if}}
-
-{{include file="section_title.tpl"}}
-
-
-{{* The search input field to search for contacts *}}
-<div id="directory-search-wrapper">
- <form id="directory-search-form" class="navbar-form" role="search" action="directory" method="get" >
- <div class="row">
- <div class="col-md-2"></div>
- <div class="col-md-8 ">
- <div class="form-group form-group-search">
- <input type="text" name="search" id="directory-search" class="search-input form-control form-search" onfocus="this.select();" value="{{$search}}" placeholder="{{$desc nofilter}}"/>
- <button class="btn btn-default btn-sm form-button-search" type="submit" id="directory-search-submit">{{$submit}}</button>
+<div class="generic-page-wrapper">
+ {{if $gdirpath}}
+ <ul class="list-unstyled pull-right">
+ <li><div id="global-directory-link"><a href="{{$gdirpath}}">{{$globaldir}}</a></div></li>
+ </ul>
+ {{/if}}
+
+ {{include file="section_title.tpl"}}
+
+
+ {{* The search input field to search for contacts *}}
+ <div id="directory-search-wrapper">
+ <form id="directory-search-form" class="navbar-form" role="search" action="{{$search_mod}}" method="get" >
+ <div class="row">
+ <div class="col-md-2"></div>
+ <div class="col-md-8 ">
+ <div class="form-group form-group-search">
+ <input type="text" name="search" id="directory-search" class="search-input form-control form-search" onfocus="this.select();" value="{{$search}}" placeholder="{{$desc nofilter}}"/>
+ <button class="btn btn-default btn-sm form-button-search" type="submit" id="directory-search-submit">{{$submit}}</button>
+ </div>
</div>
+ <div class="col-md-2"></div>
</div>
- <div class="col-md-2"></div>
- </div>
- </form>
-</div>
+ </form>
+ </div>
-<hr>
+ <hr>
-<div id="directory-search-end" class="clear"></div>
+ <div id="directory-search-end" class="clear"></div>
-{{* format each contact with the contact_template.tpl *}}
-<ul id="viewcontact_wrapper" class="viewcontact_wrapper media-list">
-{{foreach $contacts as $contact}}
- <li>{{include file="contact_template.tpl"}}</li>
-{{/foreach}}
-</ul>
+ {{* format each contact with the contact_template.tpl *}}
+ <ul id="viewcontact_wrapper" class="viewcontact_wrapper media-list">
+ {{foreach $contacts as $contact}}
+ <li>{{include file="contact_template.tpl"}}</li>
+ {{/foreach}}
+ </ul>
-<div class="directory-end" ></div>
+ <div class="directory-end" ></div>
-{{$paginate nofilter}}
+ {{$paginate nofilter}}
+</div>
\ No newline at end of file