]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - lib/noticesection.php
MessageCommand moved to DirectMessage plugin
[quix0rs-gnu-social.git] / lib / noticesection.php
index ceb0bb36f80aa36eecbf39529aacccbc9de89250..b7f38ba6655b5b583a6bebb8a481953a2c05c2b0 100644 (file)
@@ -50,6 +50,8 @@ define('NOTICES_PER_SECTION', 6);
 
 class NoticeSection extends Section
 {
+    protected $maxchars = 140;
+
     function showContent()
     {
         $notices = $this->getNotices();
@@ -68,7 +70,7 @@ class NoticeSection extends Section
         return null;
     }
 
-    function showNotice($notice)
+    function showNotice(Notice $notice)
     {
         $profile = $notice->getProfile();
         if (empty($profile)) {
@@ -76,33 +78,27 @@ class NoticeSection extends Section
                                             $notice->id));
             return;
         }
-        $this->out->elementStart('li', 'hentry notice');
-        $this->out->elementStart('div', 'entry-title');
-        $avatar = $profile->getAvatar(AVATAR_MINI_SIZE);
-        $this->out->elementStart('span', 'vcard author');
-        $this->out->elementStart('a', array('title' => ($profile->fullname) ?
-                                            $profile->fullname :
-                                            $profile->nickname,
+        $this->out->elementStart('li', 'h-entry notice');
+        $this->out->elementStart('div', 'h-card');
+        $this->out->elementStart('a', array('title' => $profile->getBestName(),
                                             'href' => $profile->profileurl,
-                                            'class' => 'url'));
-        $this->out->element('img', array('src' => (($avatar) ? $avatar->displayUrl() :  Avatar::defaultImage(AVATAR_MINI_SIZE)),
+                                            'class' => 'p-author u-url p-name'));
+        $avatarUrl = $profile->avatarUrl(AVATAR_MINI_SIZE);
+        $this->out->element('img', array('src' => $avatarUrl,
                                          'width' => AVATAR_MINI_SIZE,
                                          'height' => AVATAR_MINI_SIZE,
-                                         'class' => 'avatar photo',
-                                         'alt' =>  ($profile->fullname) ?
-                                         $profile->fullname :
-                                         $profile->nickname));
-        $this->out->text(' ');
-        $this->out->element('span', 'fn nickname', $profile->nickname);
+                                         'class' => 'avatar u-photo',
+                                         'alt' => $profile->getBestName()));
+        $this->out->text($profile->getBestName());
         $this->out->elementEnd('a');
-        $this->out->elementEnd('span');
 
-        $this->out->elementStart('p', 'entry-content');
-        $this->out->raw($notice->rendered);
+        $this->out->elementStart('p', 'e-content');
+        $this->out->text(mb_strlen($notice->content) > $this->maxchars
+            ? mb_substr($notice->content, 0, $this->maxchars) . '[…]'
+            : $notice->content);
         $this->out->elementEnd('p');
 
         $this->out->elementStart('div', 'entry_content');
-        get_class('NoticeList');
         $nli = new NoticeListItem($notice, $this->out);
         $nli->showNoticeLink();
         $this->out->elementEnd('div');