X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Freplies.php;h=84fd894ff0a072e7d2197a4816993df895587a03;hb=2f99a257a0d8bd773ea96249b13b134fcfbc99cd;hp=463d9e338c60009229c7049e40c19e666c3cb922;hpb=7b50acbc524159ed13c56dd28706f5c359c0073d;p=quix0rs-gnu-social.git diff --git a/actions/replies.php b/actions/replies.php index 463d9e338c..84fd894ff0 100644 --- a/actions/replies.php +++ b/actions/replies.php @@ -21,84 +21,80 @@ if (!defined('LACONICA')) { exit(1); } require_once(INSTALLDIR.'/actions/showstream.php'); -class RepliesAction extends StreamAction { - - function handle($args) { - - parent::handle($args); - - $nickname = common_canonical_nickname($this->arg('nickname')); - $user = User::staticGet('nickname', $nickname); - - if (!$user) { - $this->no_such_user(); - return; - } - - $profile = $user->getProfile(); - - if (!$profile) { - common_server_error(_t('User record exists without profile.')); - return; - } - - # Looks like we're good; show the header - - common_show_header(_t("Replies to ") . $profile->nickname, - array($this, 'show_header'), $user, - array($this, 'show_top')); - - $this->show_replies($profile); - - common_show_footer(); - } - - function show_header($user) { - common_element('link', array('rel' => 'alternate', - 'href' => common_local_url('repliesrss', array('nickname' => - $user->nickname)), - 'type' => 'application/rss+xml', - 'title' => _t('Feed for replies to ') . $user->nickname)); - } - - function show_top($user) { - $this->views_menu(); - } - - function show_replies($profile) { - - $reply = new Reply(); - - $reply->profile_id = $profile->id; - - $reply->orderBy('modified DESC'); - - $page = ($this->arg('page')) ? ($this->arg('page')+0) : 1; - - $reply->limit((($page-1)*NOTICES_PER_PAGE), NOTICES_PER_PAGE + 1); - - $cnt = $reply->find(); - - if ($cnt > 0) { - common_element_start('ul', array('id' => 'notices')); - for ($i = 0; $i < min($cnt, NOTICES_PER_PAGE); $i++) { - if ($reply->fetch()) { - $notice = new Notice(); - $notice->id = $reply->notice_id; - $result = $notice->find(true); - if (!$result) { - continue; - } - $this->show_notice($notice, $reply->replied_id); - } else { - // shouldn't happen! - break; - } - } - common_element_end('ul'); - } - - common_pagination($page > 1, $cnt > NOTICES_PER_PAGE, - $page, 'all', array('nickname' => $profile->nickname)); - } +class RepliesAction extends StreamAction +{ + + function handle($args) + { + + parent::handle($args); + + $nickname = common_canonical_nickname($this->arg('nickname')); + $user = User::staticGet('nickname', $nickname); + + if (!$user) { + $this->no_such_user(); + return; + } + + $profile = $user->getProfile(); + + if (!$profile) { + $this->serverError(_('User has no profile.')); + return; + } + + # Looks like we're good; show the header + + common_show_header(sprintf(_("Replies to %s"), $profile->nickname), + array($this, 'show_header'), $user, + array($this, 'show_top')); + + $this->show_replies($user); + + common_show_footer(); + } + + function no_such_user() + { + $this->clientError(_('No such user.')); + } + + function show_header($user) + { + $this->element('link', array('rel' => 'alternate', + 'href' => common_local_url('repliesrss', array('nickname' => + $user->nickname)), + 'type' => 'application/rss+xml', + 'title' => sprintf(_('Feed for replies to %s'), $user->nickname))); + } + + function show_top($user) + { + $cur = common_current_user(); + + if ($cur && $cur->id == $user->id) { + common_notice_form('replies'); + } + + $this->views_menu(); + + $this->show_feeds_list(array(0=>array('href'=>common_local_url('repliesrss', array('nickname' => $user->nickname)), + 'type' => 'rss', + 'version' => 'RSS 1.0', + 'item' => 'repliesrss'))); + } + + function show_replies($user) + { + + $page = ($this->arg('page')) ? ($this->arg('page')+0) : 1; + + $notice = $user->getReplies(($page-1) * NOTICES_PER_PAGE, NOTICES_PER_PAGE + 1); + + $cnt = $this->show_notice_list($notice); + + common_pagination($page > 1, $cnt > NOTICES_PER_PAGE, + $page, 'replies', array('nickname' => $user->nickname)); + } }