]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - actions/replies.php
Make the OpenID settings work with new framework
[quix0rs-gnu-social.git] / actions / replies.php
index 463d9e338c60009229c7049e40c19e666c3cb922..84fd894ff0a072e7d2197a4816993df895587a03 100644 (file)
@@ -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));
+    }
 }