summaryrefslogtreecommitdiff
path: root/actions/featured.php
diff options
context:
space:
mode:
authorZach Copley <zach@controlyourself.ca>2008-11-20 19:53:38 -0500
committerZach Copley <zach@controlyourself.ca>2008-11-20 19:53:38 -0500
commitdac0314e0a36923c3be8f0a8c22d0d9c36d331e8 (patch)
treebc14f5d28f55dd9e2e992f6bdf7c26edc3eaa2e1 /actions/featured.php
parente69f16d4b609bc510e018e9710ababdace260f9b (diff)
Public 'Featured' tab now shows profiles instead of notices!
darcs-hash:20081121005338-7b5ce-1e2b30a5f7de6900cdc865246c1ed65d0dfe29f6.gz
Diffstat (limited to 'actions/featured.php')
-rw-r--r--actions/featured.php68
1 files changed, 33 insertions, 35 deletions
diff --git a/actions/featured.php b/actions/featured.php
index d5cfd06f5..63ba8a071 100644
--- a/actions/featured.php
+++ b/actions/featured.php
@@ -20,6 +20,7 @@
if (!defined('LACONICA')) { exit(1); }
require_once(INSTALLDIR.'/lib/stream.php');
+require_once(INSTALLDIR.'/lib/profilelist.php');
class FeaturedAction extends StreamAction {
@@ -46,61 +47,58 @@ class FeaturedAction extends StreamAction {
$this->public_views_menu();
}
+ function show_header() {
+ }
+
function get_instructions() {
return _('Featured users');
}
- function show_header() {
+ function show_notices($page) {
- // XXX need to make the RSS feed for this
+ // XXX: Note I'm doing it this two-stage way because a raw query
+ // with a JOIN was *not* working. --Zach
- //common_element('link', array('rel' => 'alternate',
- // 'href' => common_local_url('featuredrss'),
- // 'type' => 'application/rss+xml',
- // 'title' => _('Featured Stream Feed')));
+ $featured_nicks = common_config('nickname', 'featured');
- }
+ if (count($featured_nicks) > 0) {
- function show_notices($page) {
+ $quoted = array();
- $featured = common_config('nickname', 'featured');
+ foreach ($featured_nicks as $nick) {
+ $quoted[] = "'$nick'";
+ }
- if (count($featured) > 0) {
+ $user = new User;
+ $user->whereAdd(sprintf('nickname IN (%s)', implode(',', $quoted)));
+ $user->limit(($page - 1) * PROFILES_PER_PAGE, PROFILES_PER_PAGE + 1);
+ $user->orderBy('user.nickname ASC');
- $id_list = array();
+ $user->find();
- foreach($featured as $featuree) {
- $profile = Profile::staticGet('nickname', trim($featuree));
- array_push($id_list, $profile->id);
- }
+ $profile_ids = array();
- // XXX: Show a list of users (people list) instead of shit crap
+ while ($user->fetch()) {
+ $profile_ids[] = $user->id;
+ common_debug("id = $user->id");
+ }
- $qry =
- 'SELECT * ' .
- 'FROM notice ' .
- 'WHERE profile_id IN (%s) ';
+ $profile = new Profile;
+ $profile->whereAdd(sprintf('profile.id IN (%s)', implode(',', $profile_ids)));
+ $profile->orderBy('nickname ASC');
- $cnt = 0;
+ $cnt = $profile->find();
- $notice = Notice::getStream(sprintf($qry, implode($id_list, ',')),
- 'featured_stream', ($page-1)*NOTICES_PER_PAGE, NOTICES_PER_PAGE + 1);
+ common_debug("count = $cnt");
- if ($notice) {
- common_element_start('ul', array('id' => 'notices'));
- while ($notice->fetch()) {
- $cnt++;
- if ($cnt > NOTICES_PER_PAGE) {
- break;
- }
- $this->show_notice($notice);
- }
- common_element_end('ul');
+ if ($cnt > 0) {
+ $featured = new ProfileList($profile);
+ $featured->show_list();
}
- common_pagination($page > 1, $cnt > NOTICES_PER_PAGE,
- $page, 'featured');
+ $profile->free();
+ common_pagination($page > 1, $cnt > PROFILES_PER_PAGE, $page, 'featured');
}
}