Merge branch 'master' of evan@dev.controlyourself.ca:/var/www/trunk

This commit is contained in:
Evan Prodromou 2009-01-25 18:07:55 +01:00
commit f06d5eff10
2 changed files with 40 additions and 57 deletions

View File

@ -19,40 +19,37 @@
if (!defined('LACONICA')) { exit(1); } if (!defined('LACONICA')) { exit(1); }
require_once(INSTALLDIR.'/lib/profilelist.php'); require_once INSTALLDIR.'/lib/profilelist.php';
class PeopletagAction extends Action class PeopletagAction extends Action
{ {
var $tag = null;
var $page = null;
function handle($args) function handle($args)
{ {
parent::handle($args);
parent::handle($args);
$tag = $this->trimmed('tag');
if (!common_valid_profile_tag($tag)) { parent::prepare($args);
$this->clientError(sprintf(_('Not a valid people tag: %s'), $tag));
$this->tag = $this->trimmed('tag');
if (!common_valid_profile_tag($this->tag)) {
$this->clientError(sprintf(_('Not a valid people tag: %s'), $this->tag));
return; return;
} }
$page = $this->trimmed('page'); $this->page = $this->trimmed('page');
if (!$page) { if (!$this->page) {
$page = 1; $this->page = 1;
} }
# Looks like we're good; show the header $this->showPage();
common_show_header(sprintf(_('Users self-tagged with %s - page %d'), $tag, $page),
null, $tag, array($this, 'show_top'));
$this->show_people($tag, $page);
common_show_footer();
} }
function show_people($tag, $page) function showContent()
{ {
$profile = new Profile(); $profile = new Profile();
@ -68,42 +65,28 @@ class PeopletagAction extends Action
# XXX: memcached this # XXX: memcached this
$profile->query(sprintf('SELECT profile.* ' . $qry = 'SELECT profile.* ' .
'FROM profile JOIN profile_tag ' . 'FROM profile JOIN profile_tag ' .
'ON profile.id = profile_tag.tagger ' . 'ON profile.id = profile_tag.tagger ' .
'WHERE profile_tag.tagger = profile_tag.tagged ' . 'WHERE profile_tag.tagger = profile_tag.tagged ' .
'AND tag = "%s" ' . 'AND tag = "%s" ' .
'ORDER BY profile_tag.modified DESC ' . 'ORDER BY profile_tag.modified DESC';
$lim, $tag));
$pl = new ProfileList($profile);
$cnt = $pl->show_list();
common_pagination($page > 1, $profile->query(sprintf($qry, $this->tag, $lim));
$pl = new ProfileList($profile, null, $this);
$cnt = $pl->show();
$this->pagination($this->page > 1,
$cnt > PROFILES_PER_PAGE, $cnt > PROFILES_PER_PAGE,
$page, $this->page,
$this->trimmed('action'), $this->trimmed('action'),
array('tag' => $tag)); array('tag' => $this->tag));
} }
function show_top($tag) function title()
{ {
$instr = sprintf(_('These are users who have tagged themselves "%s" ' . return sprintf( _('Users self-tagged with %s - page %d'), $this->tag, $this->page);
'to show a common interest, characteristic, hobby or job.'), $tag);
$this->elementStart('div', 'instructions');
$this->elementStart('p');
$this->text($instr);
$this->elementEnd('p');
$this->elementEnd('div');
}
function get_title()
{
return null;
}
function show_header($arr)
{
return;
} }
} }

View File

@ -178,11 +178,11 @@ class Rss10Action extends Action
$image = $this->getImage(); $image = $this->getImage();
if ($image) { if ($image) {
$channel = $this->getChannel(); $channel = $this->getChannel();
common_element_start('image', array('rdf:about' => $image)); $this->elementStart('image', array('rdf:about' => $image));
common_element('title', null, $channel['title']); $this->element('title', null, $channel['title']);
common_element('link', null, $channel['link']); $this->element('link', null, $channel['link']);
common_element('url', null, $image); $this->element('url', null, $image);
common_element_end('image'); $this->elementEnd('image');
} }
} }