123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 |
- <?php
- /**
- * StatusNet, the distributed open-source microblogging tool
- *
- * List of featured users
- *
- * PHP version 5
- *
- * LICENCE: This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
- * @category Public
- * @package StatusNet
- * @author Zach Copley <zach@status.net>
- * @author Evan Prodromou <evan@status.net>
- * @copyright 2008-2009 StatusNet, Inc.
- * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
- * @link http://status.net/
- */
- if (!defined('STATUSNET') && !defined('LACONICA')) {
- exit(1);
- }
- require_once INSTALLDIR.'/lib/profilelist.php';
- require_once INSTALLDIR.'/lib/publicgroupnav.php';
- /**
- * List of featured users
- *
- * @category Public
- * @package StatusNet
- * @author Zach Copley <zach@status.net>
- * @author Evan Prodromou <evan@status.net>
- * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
- * @link http://status.net/
- */
- class FeaturedAction extends Action
- {
- var $page = null;
- function isReadOnly($args)
- {
- return true;
- }
- function prepare(array $args = array())
- {
- parent::prepare($args);
- $this->page = ($this->arg('page')) ? ($this->arg('page')+0) : 1;
- return true;
- }
- function title()
- {
- if ($this->page == 1) {
- // TRANS: Page title for first page of featured users.
- return _('Featured users');
- } else {
- // TRANS: Page title for all but first page of featured users.
- // TRANS: %d is the page number being displayed.
- return sprintf(_('Featured users, page %d'), $this->page);
- }
- }
- function handle()
- {
- parent::handle();
- $this->showPage();
- }
- function showPageNotice()
- {
- $instr = $this->getInstructions();
- $output = common_markup_to_html($instr);
- $this->elementStart('div', 'instructions');
- $this->raw($output);
- $this->elementEnd('div');
- }
- function getInstructions()
- {
- // TRANS: Description on page displaying featured users.
- return sprintf(_('A selection of some great users on %s.'),
- common_config('site', 'name'));
- }
- function showContent()
- {
- // XXX: Note I'm doing it this two-stage way because a raw query
- // with a JOIN was *not* working. --Zach
- $featured_nicks = common_config('nickname', 'featured');
- if (count($featured_nicks) > 0) {
- $quoted = array();
- foreach ($featured_nicks as $nick) {
- $quoted[] = "'$nick'";
- }
- $user = new User;
- $user->whereAdd(sprintf('nickname IN (%s)', implode(',', $quoted)));
- $user->limit(($this->page - 1) * PROFILES_PER_PAGE, PROFILES_PER_PAGE + 1);
- $user->orderBy(common_database_tablename('user') .'.nickname ASC');
- $user->find();
- $profile_ids = array();
- while ($user->fetch()) {
- $profile_ids[] = $user->id;
- }
- $profile = new Profile;
- $profile->whereAdd(sprintf('profile.id IN (%s)', implode(',', $profile_ids)));
- $profile->orderBy('nickname ASC');
- $cnt = $profile->find();
- if ($cnt > 0) {
- $featured = new ProfileList($profile, $this);
- $featured->show();
- }
- $profile->free();
- $this->pagination($this->page > 1, $cnt > PROFILES_PER_PAGE,
- $this->page, 'featured');
- }
- }
- }
|