]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - plugins/QnA/actions/qnashowanswer.php
Merge branch 'statusnetworkapi' into 1.0.x
[quix0rs-gnu-social.git] / plugins / QnA / actions / qnashowanswer.php
index d90b5c7ac68ee0be9ea5719cc97db77ac96c71f4..30ce406739238f430da9c077be78698df996d668 100644 (file)
@@ -44,7 +44,6 @@ if (!defined('STATUSNET')) {
  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
  * @link      http://status.net/
  */
-
 class QnashowanswerAction extends ShownoticeAction
 {
     protected $answer = null;
@@ -56,7 +55,6 @@ class QnashowanswerAction extends ShownoticeAction
      *
      * @return boolean true
      */
-
     function prepare($argarray)
     {
         OwnerDesignAction::prepare($argarray);
@@ -66,26 +64,36 @@ class QnashowanswerAction extends ShownoticeAction
         $this->answer = QnA_Answer::staticGet('id', $this->id);
 
         if (empty($this->answer)) {
-            throw new ClientException(_('No such answer.'), 404);
+            // TRANS: Client exception thrown when requesting a non-existing answer.
+            throw new ClientException(_m('No such answer.'), 404);
+        }
+
+        $this->question = $this->answer->getQuestion();
+
+        if (empty($this->question)) {
+            // TRANS: Client exception thrown when requesting an answer that has no connected question.
+            throw new ClientException(_m('No question for this answer.'), 404);
         }
 
         $this->notice = Notice::staticGet('uri', $this->answer->uri);
 
         if (empty($this->notice)) {
-            // Did we used to have it, and it got deleted?
-            throw new ClientException(_('No such answer.'), 404);
+            // TRANS: Did we used to have it, and it got deleted?
+            throw new ClientException(_m('No such answer.'), 404);
         }
 
         $this->user = User::staticGet('id', $this->answer->profile_id);
 
         if (empty($this->user)) {
-            throw new ClientException(_('No such user.'), 404);
+            // TRANS: Client exception thrown when requesting answer data for a non-existing user.
+            throw new ClientException(_m('No such user.'), 404);
         }
 
         $this->profile = $this->user->getProfile();
 
         if (empty($this->profile)) {
-            throw new ServerException(_('User without a profile.'));
+            // TRANS: Client exception thrown when requesting answer data for a user without a profile.
+            throw new ServerException(_m('User without a profile.'));
         }
 
         $this->avatar = $this->profile->getAvatar(AVATAR_PROFILE_SIZE);
@@ -100,14 +108,17 @@ class QnashowanswerAction extends ShownoticeAction
      *
      * @return string page tile
      */
-
     function title()
     {
         $question = $this->answer->getQuestion();
 
-        return sprintf(_('%s\'s answer to "%s"'),
-                       $this->user->nickname,
-                       $question->title);
+        return sprintf(
+            // TRANS: Page title.
+            // TRANS: %1$s is the user who answered a question, %2$s is the question.
+            _m('%1$s\'s answer to "%2$s"'),
+            $this->user->nickname,
+            $question->title
+        );
     }
 
     /**
@@ -115,15 +126,19 @@ class QnashowanswerAction extends ShownoticeAction
      *
      * @return void
      */
-
     function showPageTitle()
     {
         $this->elementStart('h1');
         $this->element(
             'a',
-            array('href' => $this->answer->url),
-            $this->answer->title
+            array('href' => $this->answer->uri),
+            $this->question->title
         );
         $this->elementEnd('h1');
     }
+
+    function showContent()
+    {
+        $this->raw($this->answer->asHTML());
+    }
 }