X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=lib%2Fgalleryaction.php;h=4fdd97d468331b0bbf942ad31fc3297cc2c49031;hb=dd61ae8fbeee64c85f8186672292335592be1ff5;hp=31e36803a731f1677a5f84550b92ada1ddd97ed0;hpb=8399e4c2e6aef80f9c3c24f62f2b37c19e5bab81;p=quix0rs-gnu-social.git diff --git a/lib/galleryaction.php b/lib/galleryaction.php index 31e36803a7..4fdd97d468 100644 --- a/lib/galleryaction.php +++ b/lib/galleryaction.php @@ -27,77 +27,17 @@ require_once INSTALLDIR.'/lib/profilelist.php'; define('AVATARS_PER_PAGE', 80); -class GalleryAction extends OwnerDesignAction +// @todo FIXME: Class documentation missing. +class GalleryAction extends ProfileAction { - var $profile = null; - var $page = null; - var $tag = null; - - function prepare($args) + protected function handle() { - parent::prepare($args); - - // FIXME very similar code below - - $nickname_arg = $this->arg('nickname'); - $nickname = common_canonical_nickname($nickname_arg); - - // Permanent redirect on non-canonical nickname - - if ($nickname_arg != $nickname) { - $args = array('nickname' => $nickname); - if ($this->arg('page') && $this->arg('page') != 1) { - $args['page'] = $this->arg['page']; - } - common_redirect(common_local_url($this->trimmed('action'), $args), 301); - return false; - } - - $this->user = User::staticGet('nickname', $nickname); - - if (!$this->user) { - $this->clientError(_('No such user.'), 404); - return false; + // Post from the tag dropdown; redirect to a GET + if ($this->isPost()) { + common_redirect($this->selfUrl(), 303); } - $this->profile = $this->user->getProfile(); - - if (!$this->profile) { - $this->serverError(_('User has no profile.')); - return false; - } - - $this->page = ($this->arg('page')) ? ($this->arg('page')+0) : 1; - - $this->tag = $this->trimmed('tag'); - $this->q = $this->trimmed('q'); - - return true; - } - - function isReadOnly($args) - { - return true; - } - - function handle($args) - { - parent::handle($args); - - # Post from the tag dropdown; redirect to a GET - - if ($_SERVER['REQUEST_METHOD'] == 'POST') { - common_redirect($this->selfUrl(), 303); - return; - } - - $this->showPage(); - } - - function showLocalNav() - { - $nav = new SubGroupNav($this, $this->user); - $nav->show(); + parent::handle(); } function showContent() @@ -117,8 +57,8 @@ class GalleryAction extends OwnerDesignAction $content[$t] = $t; } if ($tags) { - $this->elementStart('dl', array('id'=>'filter_tags')); - $this->element('dt', null, _('Filter tags')); + $this->elementStart('dl', array('id' => 'filter_tags')); + $this->element('dt', null, _('Tags')); $this->elementStart('dd'); $this->elementStart('ul'); $this->elementStart('li', array('id' => 'filter_tags_all', @@ -127,20 +67,25 @@ class GalleryAction extends OwnerDesignAction array('href' => common_local_url($this->trimmed('action'), array('nickname' => - $this->user->nickname))), - _('All')); + $this->target->getNickname()))), + // TRANS: List element on gallery action page to show all tags. + _m('TAGS','All')); $this->elementEnd('li'); $this->elementStart('li', array('id'=>'filter_tags_item')); $this->elementStart('form', array('name' => 'bytag', 'id' => 'form_filter_bytag', - 'action' => common_path('?action=' . $this->trimmed('action')), + 'action' => common_path('?action=' . $this->getActionName()), 'method' => 'post')); $this->elementStart('fieldset'); + // TRANS: Fieldset legend on gallery action page. $this->element('legend', null, _('Select tag to filter')); + // TRANS: Dropdown field label on gallery action page for a list containing tags. $this->dropdown('tag', _('Tag'), $content, - _('Choose a tag to narrow list'), false, $tag); - $this->hidden('nickname', $this->user->nickname); - $this->submit('submit', _('Go')); + // TRANS: Dropdown field title on gallery action page for a list containing tags. + _('Choose a tag to narrow list.'), false, $tag); + $this->hidden('nickname', $this->target->getNickname()); + // TRANS: Submit button text on gallery action page. + $this->submit('submit', _m('BUTTON','Go')); $this->elementEnd('fieldset'); $this->elementEnd('form'); $this->elementEnd('li'); @@ -151,14 +96,13 @@ class GalleryAction extends OwnerDesignAction } // Get list of tags we tagged other users with - function getTags($lst, $usr) { $profile_tag = new Notice_tag(); $profile_tag->query('SELECT DISTINCT(tag) ' . 'FROM profile_tag, subscription ' . - 'WHERE tagger = ' . $this->profile->id . ' ' . - 'AND ' . $usr . ' = ' . $this->profile->id . ' ' . + 'WHERE tagger = ' . $this->target->id . ' ' . + 'AND ' . $usr . ' = ' . $this->target->id . ' ' . 'AND ' . $lst . ' = tagged ' . 'AND tagger != tagged'); $tags = array(); @@ -173,4 +117,10 @@ class GalleryAction extends OwnerDesignAction { return array(); } + + function showProfileBlock() + { + $block = new AccountProfileBlock($this, $this->target); + $block->show(); + } }