X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Ffeatured.php;h=394cfe6a8b9ef456325179533a3e5c00dbb48cc5;hb=cfaaf3c13cd97b73c4a7033f7714e36e294e3d9b;hp=2bf8b0b815cf2c8f1e909260b7694fd0ff79cbeb;hpb=02877224b20f87af304553f739b69544d7ac4cfa;p=quix0rs-gnu-social.git diff --git a/actions/featured.php b/actions/featured.php index 2bf8b0b815..394cfe6a8b 100644 --- a/actions/featured.php +++ b/actions/featured.php @@ -1,67 +1,104 @@ . + * along with this program. If not, see . + * + * @category Public + * @package StatusNet + * @author Zach Copley + * @author Evan Prodromou + * @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('LACONICA')) { exit(1); } +if (!defined('STATUSNET') && !defined('LACONICA')) { + exit(1); +} -require_once(INSTALLDIR.'/lib/stream.php'); -require_once(INSTALLDIR.'/lib/profilelist.php'); +require_once INSTALLDIR.'/lib/profilelist.php'; +require_once INSTALLDIR.'/lib/publicgroupnav.php'; -class FeaturedAction extends StreamAction +/** + * List of featured users + * + * @category Public + * @package StatusNet + * @author Zach Copley + * @author Evan Prodromou + * @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 handle($args) + function isReadOnly($args) { - parent::handle($args); - - $page = ($this->arg('page')) ? ($this->arg('page')+0) : 1; - - common_show_header(_('Featured users'), - array($this, 'show_header'), null, - array($this, 'show_top')); + return true; + } - $this->show_notices($page); + function prepare($args) + { + parent::prepare($args); + $this->page = ($this->arg('page')) ? ($this->arg('page')+0) : 1; - common_show_footer(); + return true; } - function show_top() + function title() { - $instr = $this->get_instructions(); - $output = common_markup_to_html($instr); - common_element_start('div', 'instructions'); - common_raw($output); - common_element_end('div'); - $this->public_views_menu(); + 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 show_header() + function handle($args) { + parent::handle($args); + + $this->showPage(); } - function get_instructions() + function showPageNotice() { - return _('Featured users'); + $instr = $this->getInstructions(); + $output = common_markup_to_html($instr); + $this->elementStart('div', 'instructions'); + $this->raw($output); + $this->elementEnd('div'); } - function show_notices($page) + 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 @@ -77,8 +114,8 @@ class FeaturedAction extends StreamAction $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'); + $user->limit(($this->page - 1) * PROFILES_PER_PAGE, PROFILES_PER_PAGE + 1); + $user->orderBy(common_database_tablename('user') .'.nickname ASC'); $user->find(); @@ -95,14 +132,14 @@ class FeaturedAction extends StreamAction $cnt = $profile->find(); if ($cnt > 0) { - $featured = new ProfileList($profile); - $featured->show_list(); + $featured = new ProfileList($profile, $this); + $featured->show(); } $profile->free(); - common_pagination($page > 1, $cnt > PROFILES_PER_PAGE, $page, 'featured'); + $this->pagination($this->page > 1, $cnt > PROFILES_PER_PAGE, + $this->page, 'featured'); } } - -} \ No newline at end of file +}