3 * Name: Forum Directory
4 * Description: Add a directory of forums hosted on your server, with verbose descriptions.
6 * Author: Thomas Willingham <https://beardyunixer.com/profile/beardyunixer>
10 use Friendica\Content\Nav;
11 use Friendica\Content\Pager;
12 use Friendica\Content\Widget;
13 use Friendica\Core\Hook;
14 use Friendica\Core\Renderer;
15 use Friendica\Database\DBA;
17 use Friendica\Model\Profile;
18 use Friendica\Util\Strings;
20 function forumdirectory_install()
22 Hook::register('app_menu', 'addon/forumdirectory/forumdirectory.php', 'forumdirectory_app_menu');
25 function forumdirectory_uninstall()
27 Hook::unregister('app_menu', 'addon/forumdirectory/forumdirectory.php', 'forumdirectory_app_menu');
30 function forumdirectory_module()
35 function forumdirectory_app_menu(App $a, array &$b)
37 $b['app_menu'][] = '<div class="app-title"><a href="forumdirectory">' . DI::l10n()->t('Forum Directory') . '</a></div>';
40 function forumdirectory_init(App $a)
43 DI::page()['aside'] .= Widget::findPeople();
47 function forumdirectory_post(App $a)
49 if (!empty($_POST['search'])) {
50 $a->data['search'] = $_POST['search'];
54 function forumdirectory_content(App $a)
56 if ((DI::config()->get('system', 'block_public')) && (!local_user()) && (!remote_user())) {
57 notice(DI::l10n()->t('Public access denied.') . EOL);
64 Nav::setSelected('directory');
66 if (!empty($a->data['search'])) {
67 $search = Strings::escapeTags(trim($a->data['search']));
69 $search = (!empty($_GET['search']) ? Strings::escapeTags(trim(rawurldecode($_GET['search']))) : '');
73 $dirurl = DI::config()->get('system', 'directory');
74 if (strlen($dirurl)) {
75 $gdirpath = Profile::zrl($dirurl, true);
79 if (strlen($search)) {
80 $search = DBA::escape($search);
82 $sql_extra = " AND ((`profile`.`name` LIKE '%$search%') OR
83 (`user`.`nickname` LIKE '%$search%') OR
84 (`profile`.`about` LIKE '%$search%') OR
85 (`profile`.`locality` LIKE '%$search%') OR
86 (`profile`.`region` LIKE '%$search%') OR
87 (`profile`.`country-name` LIKE '%$search%') OR
88 (`profile`.`pub_keywords` LIKE '%$search%') OR
89 (`profile`.`prv_keywords` LIKE '%$search%'))";
92 $publish = DI::config()->get('system', 'publish_all') ? '' : "`publish` = 1";
95 $cnt = DBA::fetchFirst("SELECT COUNT(*) AS `total` FROM `profile`
96 LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid`
97 WHERE $publish AND NOT `user`.`blocked` AND NOT `user`.`account_removed` `user`.`page-flags` = 2 $sql_extra");
98 if (DBA::isResult($cnt)) {
99 $total = $cnt['total'];
102 $pager = new Pager(DI::l10n(), DI::args()->getQueryString(), 60);
104 $order = " ORDER BY `name` ASC ";
106 $limit = $pager->getStart()."," . $pager->getItemsPerPage();
108 $r = DBA::p("SELECT `profile`.*, `user`.`nickname`, `user`.`timezone` , `user`.`page-flags`,
109 `contact`.`addr`, `contact`.`url` AS `profile_url` FROM `profile`
110 LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid`
111 LEFT JOIN `contact` ON `contact`.`uid` = `user`.`uid`
112 WHERE $publish AND NOT `user`.`blocked` AND NOT `user`.`account_removed` AND `user`.`page-flags` = 2 AND `contact`.`self`
113 $sql_extra $order LIMIT $limit"
116 if (DBA::isResult($r)) {
117 if (in_array('small', $a->argv)) {
123 while ($rr = DBA::fetch($r)) {
124 $entries[] = Friendica\Module\Directory::formatEntry($rr, $photo);
128 info(DI::l10n()->t("No entries \x28some entries may be hidden\x29.") . EOL);
131 $tpl = Renderer::getMarkupTemplate('directory_header.tpl');
132 $o .= Renderer::replaceMacros($tpl, [
133 '$search' => $search,
134 '$globaldir' => DI::l10n()->t('Global Directory'),
135 '$gdirpath' => $gdirpath,
136 '$desc' => DI::l10n()->t('Find on this site'),
137 '$contacts' => $entries,
138 '$finding' => DI::l10n()->t('Results for:'),
139 '$findterm' => (strlen($search) ? $search : ""),
140 '$title' => DI::l10n()->t('Forum Directory'),
141 '$search_mod' => 'forumdirectory',
142 '$submit' => DI::l10n()->t('Find'),
143 '$paginate' => $pager->renderFull($total),