X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=lib%2Fgalleryaction.php;h=4fdd97d468331b0bbf942ad31fc3297cc2c49031;hb=dd61ae8fbeee64c85f8186672292335592be1ff5;hp=51bb9e3e1a17d17e2af83c2eda6ccea0f6f38cef;hpb=d594c83a5a9a9d42fce917b544c28591fcadb1aa;p=quix0rs-gnu-social.git diff --git a/lib/galleryaction.php b/lib/galleryaction.php index 51bb9e3e1a..4fdd97d468 100644 --- a/lib/galleryaction.php +++ b/lib/galleryaction.php @@ -30,71 +30,14 @@ define('AVATARS_PER_PAGE', 80); // @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) { - // TRANS: Client error displayed when trying to perform a gallery action with an unknown user. - $this->clientError(_('No such user.'), 404); - return false; - } - - $this->profile = $this->user->getProfile(); - - if (!$this->profile) { - // TRANS: Error message displayed when referring to a user without a profile. - $this->serverError(_('User has no profile.')); - return false; + // Post from the tag dropdown; redirect to a GET + if ($this->isPost()) { + common_redirect($this->selfUrl(), 303); } - $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(); + parent::handle(); } function showContent() @@ -124,14 +67,14 @@ class GalleryAction extends ProfileAction array('href' => common_local_url($this->trimmed('action'), array('nickname' => - $this->user->nickname))), + $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. @@ -140,7 +83,7 @@ class GalleryAction extends ProfileAction $this->dropdown('tag', _('Tag'), $content, // 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->user->nickname); + $this->hidden('nickname', $this->target->getNickname()); // TRANS: Submit button text on gallery action page. $this->submit('submit', _m('BUTTON','Go')); $this->elementEnd('fieldset'); @@ -158,8 +101,8 @@ class GalleryAction extends ProfileAction $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(); @@ -177,7 +120,7 @@ class GalleryAction extends ProfileAction function showProfileBlock() { - $block = new AccountProfileBlock($this, $this->profile); + $block = new AccountProfileBlock($this, $this->target); $block->show(); } }