]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - actions/shownotice.php
Merge branch 'uiredesign' of /var/www/trunk into uiredesign
[quix0rs-gnu-social.git] / actions / shownotice.php
index b189fdb87fed43f629381c87563b687d466171ed..82d4bd27014f25fac5094167681c1413ebc823c9 100644 (file)
 
 if (!defined('LACONICA')) { exit(1); }
 
-class ShownoticeAction extends Action {
-
-       function handle($args) {
-               parent::handle($args);
-               $id = $this->arg('notice');
-               $notice = Notice::staticGet($id);
-
-               if (!$notice) {
-                       $this->no_such_notice();
-               }
-
-               if (!$notice->getProfile()) {
-                       $this->no_such_notice();
-               }
-
-               # Looks like we're good; show the header
-
-               common_show_header($profile->nickname." status on ".$notice->created);
-
-               $this->show_notice($notice);
-
-               common_show_footer();
-       }
-
-       function no_such_notice() {
-               common_user_error('No such notice.');
-       }
-
-       function show_notice($notice) {
-               $profile = $notice->getProfile();
-               # XXX: RDFa
-               common_element_start('div', array('class' => 'notice greenBg'));
-               $avatar = $profile->getAvatar(AVATAR_PROFILE_SIZE);
-               if ($avatar) {
-                       common_element('img', array('src' => $avatar->url,
-                                                                               'class' => 'avatar profile',
-                                                                               'width' => AVATAR_PROFILE_SIZE,
-                                                                               'height' => AVATAR_PROFILE_SIZE,
-                                                                               'alt' =>
-                                                                               ($profile->fullname) ? $profile->fullname :
-                                                                                                      $profile->nickname));
-               }
-               common_element('a', array('href' => $profile->profileurl,
-                                                                 'class' => 'nickname',
-                                                                 'title' =>
-                                                                 ($profile->fullname) ? $profile->fullname :
-                                                                 $profile->nickname),
-                                          $profile->nickname);
-               # FIXME: URL, image, video, audio
-               common_element_start('span', array('class' => 'content'));
-               common_raw(common_render_content($notice->content));
-               common_element_end('span');
-               common_element('span', array('class' => 'date'),
-                                          common_date_string($notice->created));
-               common_element_end('div');
-       }
+require_once(INSTALLDIR.'/lib/stream.php');
+
+class ShownoticeAction extends StreamAction
+{
+
+    var $notice = null;
+    var $profile = null;
+    var $avatar = null;
+
+    function prepare($args)
+    {
+
+        parent::prepare($args);
+
+        $id = $this->arg('notice');
+        $this->notice = Notice::staticGet($id);
+
+        if (!$this->notice) {
+            $this->clientError(_('No such notice.'), 404);
+            return false;
+        }
+
+        $this->profile = $this->notice->getProfile();
+
+        if (!$this->profile) {
+            $this->serverError(_('Notice has no profile'), 500);
+            return false;
+        }
+
+        $this->avatar = $this->profile->getAvatar(AVATAR_STREAM_SIZE);
+
+        return true;
+    }
+
+    function last_modified()
+    {
+        return max(strtotime($this->notice->created),
+                   strtotime($this->profile->modified),
+                   ($this->avatar) ? strtotime($this->avatar->modified) : 0);
+    }
+
+    function etag()
+    {
+        return 'W/"' . implode(':', array($this->arg('action'),
+                                          common_language(),
+                                          $this->notice->id,
+                                          strtotime($this->notice->created),
+                                          strtotime($this->profile->modified),
+                                          ($this->avatar) ? strtotime($this->avatar->modified) : 0)) . '"';
+    }
+
+    function handle($args)
+    {
+
+        parent::handle($args);
+
+        common_show_header(sprintf(_('%1$s\'s status on %2$s'),
+                                   $this->profile->nickname,
+                                   common_exact_date($this->notice->created)),
+                           array($this, 'show_header'), null,
+                           array($this, 'show_top'));
+
+        $this->elementStart('ul', array('id' => 'notices'));
+        $nli = new NoticeListItem($this->notice);
+        $nli->show();
+        $this->elementEnd('ul');
+
+        common_show_footer();
+    }
+
+    function show_header()
+    {
+
+        $user = User::staticGet($this->profile->id);
+
+        if (!$user) {
+            return;
+        }
+
+        if ($user->emailmicroid && $user->email && $this->notice->uri) {
+            $this->element('meta', array('name' => 'microid',
+                                         'content' => "mailto+http:sha1:" . sha1(sha1('mailto:' . $user->email) . sha1($this->notice->uri))));
+        }
+
+        if ($user->jabbermicroid && $user->jabber && $this->notice->uri) {
+            $this->element('meta', array('name' => 'microid',
+                                         'content' => "xmpp+http:sha1:" . sha1(sha1('xmpp:' . $user->jabber) . sha1($this->notice->uri))));
+        }
+    }
+
+    function show_top()
+    {
+        $cur = common_current_user();
+        if ($cur && $cur->id == $this->profile->id) {
+            common_notice_form();
+        }
+    }
+
+    function no_such_notice()
+    {
+        $this->clientError(_('No such notice.'));
+    }
 }