if ($this->notice->scope != 0 && $this->notice->scope != 1) {
$class .= ' limited-scope';
}
+ if (!empty($this->notice->source)) {
+ $class .= ' notice-source-'.$this->notice->source;
+ }
$this->out->elementStart('li', array('class' => $class,
'id' => 'notice-' . $id));
Event::handle('EndOpenNoticeListItemElement', array($this));
$this->out->elementStart('a', $attrs);
$this->showAvatar();
$this->out->text(' ');
- $this->out->element('span',array('class' => 'nickname fn'),
+ $this->out->element('span',array('class' => 'fn'),
$this->profile->getBestName());
$this->out->elementEnd('a');
function showAddressees()
{
- $this->out->elementStart('span', 'addressees');
-
- $cnt = $this->showGroupAddressees(true);
- $cnt = $this->showProfileAddressees($cnt == 0);
-
- $this->out->elementEnd('span', 'addressees');
+ $ga = $this->getGroupAddressees();
+ $pa = $this->getProfileAddressees();
+
+ $a = array_merge($ga, $pa);
+
+ if (!empty($a)) {
+ $this->out->elementStart('span', 'addressees');
+ $first = true;
+ foreach ($a as $addr) {
+ if (!$first) {
+ // TRANS: Separator in profile addressees list.
+ $this->out->text(_m('SEPARATOR',', '));
+ } else {
+ // Start of profile addressees list.
+ $first = false;
+ }
+ $text = $addr['text'];
+ unset($addr['text']);
+ $this->out->element('a', $addr, $text);
+ }
+ $this->out->elementEnd('span', 'addressees');
+ }
}
- function showGroupAddressees($first)
+ function getGroupAddressees()
{
+ $ga = array();
+
$groups = $this->getGroups();
foreach ($groups as $group) {
- if (!$first) {
- $this->out->text(', ');
- } else {
- $this->out->text(' ▶ ');
- $first = false;
- }
- $this->out->element('a', array('href' => $group->homeUrl(),
- 'title' => $group->nickname,
- 'class' => 'addressee group'),
- $group->getBestName());
+ $ga[] = array('href' => $group->homeUrl(),
+ 'title' => $group->nickname,
+ 'class' => 'addressee group',
+ 'text' => $group->getBestName());
}
- return count($groups);
+ return $ga;
}
function getGroups()
return $this->notice->getGroups();
}
- function showProfileAddressees($first)
+ function getProfileAddressees()
{
+ $pa = array();
+
$replies = $this->getReplyProfiles();
foreach ($replies as $reply) {
- if (!$first) {
- $this->out->text(', ');
- } else {
- $this->out->text(' ▶ ');
- $first = false;
- }
- $this->out->element('a', array('href' => $reply->profileurl,
- 'title' => $reply->nickname,
- 'class' => 'addressee account'),
- $reply->getBestName());
+ $pa[] = array('href' => $reply->profileurl,
+ 'title' => $reply->nickname,
+ 'class' => 'addressee account',
+ 'text' => $reply->getBestName());
}
- return count($replies);
+ return $pa;
}
function getReplyProfiles()
$source_name = (empty($ns->name)) ? ($ns->code ? _($ns->code) : _m('SOURCE','web')) : _($ns->name);
$this->out->text(' ');
$this->out->elementStart('span', 'source');
- // FIXME: probably i18n issue. If "from" is followed by text, that should be a parameter to "from" (from %s).
+ // @todo FIXME: probably i18n issue. If "from" is followed by text, that should be a parameter to "from" (from %s).
// TRANS: Followed by notice source.
$this->out->text(_('from'));
$this->out->text(' ');
// TRANS: Addition in notice list item if notice was repeated. Followed by a span with a nickname.
$this->out->raw(_('Repeated by'));
+ $this->out->raw(_(' '));
$this->out->elementStart('a', $attrs);
$this->out->element('span', 'fn nickname', $repeater->nickname);
$this->out->elementStart('a', array('href' => $reply_url,
'class' => 'notice_reply',
// TRANS: Link title in notice list item to reply to a notice.
- 'title' => _('Reply to this notice')));
+ 'title' => _('Reply to this notice.')));
// TRANS: Link text in notice list item to reply to a notice.
$this->out->text(_('Reply'));
$this->out->text(' ');
$this->out->element('a', array('href' => $deleteurl,
'class' => 'notice_delete',
// TRANS: Link title in notice list item to delete a notice.
- 'title' => _('Delete this notice')),
+ 'title' => _('Delete this notice from the timeline.')),
// TRANS: Link text in notice list item to delete a notice.
_('Delete'));
}