aboutsummaryrefslogtreecommitdiffstats
path: root/mod/community.php
diff options
context:
space:
mode:
authorFriendika <info@friendika.com>2011-07-04 20:57:07 -0700
committerFriendika <info@friendika.com>2011-07-04 20:57:07 -0700
commit20d3aa2e77e4ba4c12d2a7332c7ac5f3a8f6b635 (patch)
tree4c321d73497d6a425c8835e69244ef87dc62962e /mod/community.php
parent308ffe500a7ea4a2e9c55565b0bc7510b4e8bb26 (diff)
downloadvolse-hubzilla-20d3aa2e77e4ba4c12d2a7332c7ac5f3a8f6b635.tar.gz
volse-hubzilla-20d3aa2e77e4ba4c12d2a7332c7ac5f3a8f6b635.tar.bz2
volse-hubzilla-20d3aa2e77e4ba4c12d2a7332c7ac5f3a8f6b635.zip
community page
Diffstat (limited to 'mod/community.php')
-rw-r--r--mod/community.php88
1 files changed, 88 insertions, 0 deletions
diff --git a/mod/community.php b/mod/community.php
new file mode 100644
index 000000000..aaa3ad9ed
--- /dev/null
+++ b/mod/community.php
@@ -0,0 +1,88 @@
+<?php
+
+
+function community_content(&$a, $update = 0) {
+
+ $o = '';
+
+ if((get_config('system','block_public')) && (! local_user()) && (! remote_user())) {
+ notice( t('Public access denied.') . EOL);
+ return;
+ }
+
+ if(! get_config('system','no_community_page')) {
+ notice( t('Not available.') . EOL);
+ return;
+ }
+
+ require_once("include/bbcode.php");
+ require_once('include/security.php');
+ require_once('include/conversation.php');
+
+ if(x($_SESSION,'theme'))
+ unset($_SESSION['theme']);
+
+
+ $o .= '<h3>' . t('Community') . '</h3>';
+ if(! $update) {
+ $o .= '<script> $(document).ready(function() { $(\'#nav-community-link\').addClass(\'nav-selected\'); });</script>';
+ $o .= '<div id="live-community"></div>' . "\r\n";
+ $o .= "<script> var profile_uid = -1; var netargs = ''; var profile_page = " . $a->pager['page'] . "; </script>\r\n";
+ }
+
+ if(x($a->data,'search'))
+ $search = notags(trim($a->data['search']));
+ else
+ $search = ((x($_GET,'search')) ? notags(trim(rawurldecode($_GET['search']))) : '');
+
+
+ // Here is the way permissions work in this module...
+ // Only public wall posts can be shown
+ // OR your own posts if you are a logged in member
+
+
+ $r = q("SELECT COUNT(*) AS `total`
+ FROM `item` LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id` LEFT JOIN `profile` ON `profile`.`uid` = `item`.`uid`
+ WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0
+ AND `wall` = 1 AND `item`.`allow_cid` = '' AND `item`.`allow_gid` = ''
+ AND `item`.`deny_cid` = '' AND `item`.`deny_gid` = '' AND `profile`.`hidewall` = 0
+ AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 AND `profile`.`is-default` = 1 "
+ );
+
+ if(count($r))
+ $a->set_pager_total($r[0]['total']);
+
+ if(! $r[0]['total']) {
+ info( t('No results.') . EOL);
+ return $o;
+ }
+
+ $r = q("SELECT `item`.*, `item`.`id` AS `item_id`,
+ `contact`.`name`, `contact`.`photo`, `contact`.`url`, `contact`.`rel`,
+ `contact`.`network`, `contact`.`thumb`, `contact`.`self`, `contact`.`writable`,
+ `contact`.`id` AS `cid`, `contact`.`uid` AS `contact-uid`,
+ `user`.`nickname`, `profile`.`hidewall`
+ FROM `item` LEFT JOIN `contact` ON `contact`.`id` = `item`.`contact-id`
+ LEFT JOIN `user` ON `user`.`uid` = `item`.`uid`
+ LEFT JOIN `profile` ON `profile`.`uid` = `item`.`uid`
+ WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0
+ AND `wall` = 1 AND `item`.`allow_cid` = '' AND `item`.`allow_gid` = ''
+ AND `item`.`deny_cid` = '' AND `item`.`deny_gid` = '' AND `profile`.`hidewall` = 0
+ AND `contact`.`blocked` = 0 AND `contact`.`pending` = 0 AND `profile`.`is-default` = 1
+ ORDER BY `received` DESC LIMIT %d, %d ",
+ intval($a->pager['start']),
+ intval($a->pager['itemspage'])
+
+ );
+
+ // we behave the same in message lists as the search module
+
+ $o .= conversation($a,$r,'search',false);
+
+ $o .= paginate($a);
+
+ $o .= '<div class="cc-license">' . t('Shared content is covered by the <a href="http://creativecommons.org/licenses/by/3.0/">Creative Commons Attribution 3.0</a> license.') . '</div>';
+
+ return $o;
+}
+