X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=lib%2Fnoticesection.php;h=4a4eac344a3b95e955e5bcd22fa26eeb19113a50;hb=d2104b89d93d40bf68884055196340465f3f6497;hp=7157feafc565bd81b30f1cba4d0cee5c4dc18442;hpb=5db40c440dcfa3f9d19f047c003bbcfaeb69dbc9;p=quix0rs-gnu-social.git diff --git a/lib/noticesection.php b/lib/noticesection.php index 7157feafc5..4a4eac344a 100644 --- a/lib/noticesection.php +++ b/lib/noticesection.php @@ -39,6 +39,8 @@ define('NOTICES_PER_SECTION', 6); * These are the widgets that show interesting data about a person * group, or site. * + * @todo migrate this to use a variant of NoticeList + * * @category Widget * @package StatusNet * @author Evan Prodromou @@ -48,6 +50,8 @@ define('NOTICES_PER_SECTION', 6); class NoticeSection extends Section { + protected $maxchars = 140; + function showContent() { $notices = $this->getNotices(); @@ -76,14 +80,14 @@ class NoticeSection extends Section } $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, 'href' => $profile->profileurl, 'class' => 'url')); - $this->out->element('img', array('src' => (($avatar) ? $avatar->displayUrl() : Avatar::defaultImage(AVATAR_MINI_SIZE)), + $avatarUrl = $profile->avatarUrl(AVATAR_MINI_SIZE); + $this->out->element('img', array('src' => $avatarUrl, 'width' => AVATAR_MINI_SIZE, 'height' => AVATAR_MINI_SIZE, 'class' => 'avatar photo', @@ -96,39 +100,16 @@ class NoticeSection extends Section $this->out->elementEnd('span'); $this->out->elementStart('p', 'entry-content'); - $this->out->raw($notice->rendered); - - $notice_link_cfg = common_config('site', 'notice_link'); - if ('direct' === $notice_link_cfg) { - $this->out->text(' ('); - $this->out->element('a', array('href' => $notice->uri), 'see'); - $this->out->text(')'); - } elseif ('attachment' === $notice_link_cfg) { - if ($count = $notice->hasAttachments()) { - // link to attachment(s) pages - if (1 === $count) { - $f2p = File_to_post::staticGet('post_id', $notice->id); - $href = common_local_url('attachment', array('attachment' => $f2p->file_id)); - $att_class = 'attachment'; - } else { - $href = common_local_url('attachments', array('notice' => $notice->id)); - $att_class = 'attachments'; - } + $this->out->text(mb_strlen($notice->content) > $this->maxchars + ? mb_substr($notice->content, 0, $this->maxchars) . '[…]' + : $notice->content); + $this->out->elementEnd('p'); - $clip = Theme::path('images/icons/clip.png', 'base'); - $this->out->elementStart('a', array('class' => $att_class, 'style' => "font-style: italic;", 'href' => $href, 'title' => "# of attachments: $count")); - $this->out->raw(" ($count "); - $this->out->element('img', array('style' => 'display: inline', 'align' => 'top', 'width' => 20, 'height' => 20, 'src' => $clip, 'alt' => 'alt')); - $this->out->text(')'); - $this->out->elementEnd('a'); - } else { - $this->out->text(' ('); - $this->out->element('a', array('href' => $notice->uri), 'see'); - $this->out->text(')'); - } - } + $this->out->elementStart('div', 'entry_content'); + $nli = new NoticeListItem($notice, $this->out); + $nli->showNoticeLink(); + $this->out->elementEnd('div'); - $this->out->elementEnd('p'); if (!empty($notice->value)) { $this->out->elementStart('p'); $this->out->text($notice->value);