X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Ftag.php;h=9159e7c043b9509c28787bfb0a109c50facae7f4;hb=d6b28c64830f632bb2f4b6f3c9369b9e56ad217a;hp=944cda1f4a16c3dceaa532b036266c952384b42a;hpb=325cb4833db7e3fd396720f12a27b880b63f4173;p=quix0rs-gnu-social.git diff --git a/actions/tag.php b/actions/tag.php index 944cda1f4a..9159e7c043 100644 --- a/actions/tag.php +++ b/actions/tag.php @@ -17,50 +17,46 @@ * along with this program. If not, see . */ -if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); } +if (!defined('GNUSOCIAL')) { exit(1); } -class TagAction extends Action +// @todo FIXME: documentation missing. +class TagAction extends ManagedAction { - var $notice; + var $tag; + var $page; - function prepare($args) + protected function prepare(array $args=array()) { parent::prepare($args); + $taginput = $this->trimmed('tag'); $this->tag = common_canonical_tag($taginput); - if (!$this->tag) { + if (empty($this->tag)) { common_redirect(common_local_url('publictagcloud'), 301); - return false; } - if ($this->tag != $taginput) { - common_redirect(common_local_url('tag', array('tag' => $this->tag)), - 301); - return false; + // after common_canonical_tag we have a lowercase, no-specials tag string + if ($this->tag !== $taginput) { + common_redirect(common_local_url('tag', array('tag' => $this->tag)), 301); } $this->page = ($this->arg('page')) ? ($this->arg('page')+0) : 1; common_set_returnto($this->selfUrl()); - $this->notice = Notice_tag::getStream($this->tag, (($this->page-1)*NOTICES_PER_PAGE), NOTICES_PER_PAGE + 1); + $this->notice = Notice_tag::getStream($this->tag)->getNotices(($this->page-1)*NOTICES_PER_PAGE, + NOTICES_PER_PAGE + 1); if($this->page > 1 && $this->notice->N == 0){ - // TRANS: Server error when page not found (404) - $this->serverError(_('No such page.'),$code=404); + // TRANS: Client error when page not found (404). + $this->clientError(_('No such page.'), 404); } return true; } - function showSections() - { - $pop = new PopularNoticeSection($this); - $pop->show(); - } - function title() { if ($this->page == 1) { @@ -76,39 +72,46 @@ class TagAction extends Action } } - function handle($args) - { - parent::handle($args); - - $this->showPage(); - } - function getFeeds() { - return array(new Feed(Feed::RSS1, + return array(new Feed(Feed::JSON, + common_local_url('ApiTimelineTag', + array('format' => 'as', + 'tag' => $this->tag)), + // TRANS: Link label for feed on "notices with tag" page. + // TRANS: %s is the tag the feed is for. + sprintf(_('Notice feed for tag %s (Activity Streams JSON)'), + $this->tag)), + new Feed(Feed::RSS1, common_local_url('tagrss', array('tag' => $this->tag)), + // TRANS: Link label for feed on "notices with tag" page. + // TRANS: %s is the tag the feed is for. sprintf(_('Notice feed for tag %s (RSS 1.0)'), $this->tag)), new Feed(Feed::RSS2, common_local_url('ApiTimelineTag', array('format' => 'rss', 'tag' => $this->tag)), + // TRANS: Link label for feed on "notices with tag" page. + // TRANS: %s is the tag the feed is for. sprintf(_('Notice feed for tag %s (RSS 2.0)'), $this->tag)), new Feed(Feed::ATOM, common_local_url('ApiTimelineTag', array('format' => 'atom', 'tag' => $this->tag)), + // TRANS: Link label for feed on "notices with tag" page. + // TRANS: %s is the tag the feed is for. sprintf(_('Notice feed for tag %s (Atom)'), $this->tag))); } - function showContent() + protected function showContent() { if(Event::handle('StartTagShowContent', array($this))) { - - $nl = new NoticeList($this->notice, $this); + + $nl = new PrimaryNoticeList($this->notice, $this, array('show_n'=>NOTICES_PER_PAGE)); $cnt = $nl->show(); @@ -119,7 +122,7 @@ class TagAction extends Action } } - function isReadOnly($args) + function isReadOnly(array $args=array()) { return true; }