X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fsubscribers.php;h=81ab70e21e87acd8079969a973c7637e65bebe97;hb=1f02dc639ec3dfa44df87c4fa031b3f298ffee7e;hp=9e1fb4cf73c30b318115bbd8833f0e4fa77f3350;hpb=87d46e1ae5e5effcc985021ff5af3f10815f3d3c;p=quix0rs-gnu-social.git diff --git a/actions/subscribers.php b/actions/subscribers.php index 9e1fb4cf73..81ab70e21e 100644 --- a/actions/subscribers.php +++ b/actions/subscribers.php @@ -48,20 +48,19 @@ class SubscribersAction extends GalleryAction if ($this->page == 1) { // TRANS: Header for list of subscribers for a user (first page). // TRANS: %s is the user's nickname. - return sprintf(_('%s subscribers'), $this->user->nickname); + return sprintf(_('%s subscribers'), $this->target->getNickname()); } else { // TRANS: Header for list of subscribers for a user (not first page). // TRANS: %1$s is the user's nickname, $2$d is the page number. return sprintf(_('%1$s subscribers, page %2$d'), - $this->user->nickname, + $this->target->getNickname(), $this->page); } } function showPageNotice() { - $user = common_current_user(); - if ($user && ($user->id == $this->profile->id)) { + if ($this->scoped instanceof Profile && $this->scoped->id === $this->target->id) { $this->element('p', null, // TRANS: Page notice for page with an overview of all subscribers // TRANS: of the logged in user's own profile. @@ -73,7 +72,7 @@ class SubscribersAction extends GalleryAction // TRANS: than the logged in user. %s is the user nickname. sprintf(_('These are the people who '. 'listen to %s\'s notices.'), - $this->profile->nickname)); + $this->target->getNickname())); } } @@ -87,13 +86,13 @@ class SubscribersAction extends GalleryAction $cnt = 0; if ($this->tag) { - $subscribers = $this->user->getTaggedSubscribers($this->tag, $offset, $limit); + $subscribers = $this->target->getTaggedSubscribers($this->tag, $offset, $limit); } else { - $subscribers = $this->user->getSubscribers($offset, $limit); + $subscribers = $this->target->getSubscribers($offset, $limit); } if ($subscribers) { - $subscribers_list = new SubscribersList($subscribers, $this->user, $this); + $subscribers_list = new SubscribersList($subscribers, $this->target, $this); $cnt = $subscribers_list->show(); if (0 == $cnt) { $this->showEmptyListMessage(); @@ -102,29 +101,25 @@ class SubscribersAction extends GalleryAction $this->pagination($this->page > 1, $cnt > PROFILES_PER_PAGE, $this->page, 'subscribers', - array('nickname' => $this->user->nickname)); + array('nickname' => $this->target->getNickname())); } function showEmptyListMessage() { - if (common_logged_in()) { - $current_user = common_current_user(); - if ($this->user->id === $current_user->id) { - // TRANS: Subscriber list text when the logged in user has no subscribers. - $message = _('You have no subscribers. Try subscribing to people you know and they might return the favor.'); - } else { - // TRANS: Subscriber list text when looking at the subscribers for a of a user other - // TRANS: than the logged in user that has no subscribers. %s is the user nickname. - $message = sprintf(_('%s has no subscribers. Want to be the first?'), $this->user->nickname); - } - } - else { + if ($this->scoped instanceof Profile && $this->target->id === $this->scoped->id) { + // TRANS: Subscriber list text when the logged in user has no subscribers. + $message = _('You have no subscribers. Try subscribing to people you know and they might return the favor.'); + } elseif ($this->scoped instanceof Profile) { + // TRANS: Subscriber list text when looking at the subscribers for a of a user other + // TRANS: than the logged in user that has no subscribers. %s is the user nickname. + $message = sprintf(_('%s has no subscribers. Want to be the first?'), $this->target->getNickname()); + } else { // TRANS: Subscriber list text when looking at the subscribers for a of a user that has none // TRANS: as an anonymous user. %s is the user nickname. // TRANS: This message contains a Markdown URL. The link description is between // TRANS: square brackets, and the link between parentheses. Do not separate "](" // TRANS: and do not change the URL part. - $message = sprintf(_('%s has no subscribers. Why not [register an account](%%%%action.register%%%%) and be the first?'), $this->user->nickname); + $message = sprintf(_('%s has no subscribers. Why not [register an account](%%%%action.register%%%%) and be the first?'), $this->target->getNickname()); } $this->elementStart('div', 'guide'); @@ -137,64 +132,3 @@ class SubscribersAction extends GalleryAction parent::showSections(); } } - -class SubscribersList extends SubscriptionList -{ - function newListItem($profile) - { - return new SubscribersListItem($profile, $this->owner, $this->action); - } -} - -class SubscribersListItem extends SubscriptionListItem -{ - function showActions() - { - $this->startActions(); - if (Event::handle('StartProfileListItemActionElements', array($this))) { - $this->showSubscribeButton(); - // Relevant code! - $this->showBlockForm(); - Event::handle('EndProfileListItemActionElements', array($this)); - } - $this->endActions(); - } - - function showBlockForm() - { - $user = common_current_user(); - - if (!empty($user) && $this->owner->id == $user->id) { - $returnto = array('action' => 'subscribers', - 'nickname' => $this->owner->nickname); - $page = $this->out->arg('page'); - if ($page) { - $returnto['param-page'] = $page; - } - $bf = new BlockForm($this->out, $this->profile, $returnto); - $bf->show(); - } - } - - function linkAttributes() - { - $aAttrs = parent::linkAttributes(); - - if (common_config('nofollow', 'subscribers')) { - $aAttrs['rel'] .= ' nofollow'; - } - - return $aAttrs; - } - - function homepageAttributes() - { - $aAttrs = parent::linkAttributes(); - - if (common_config('nofollow', 'subscribers')) { - $aAttrs['rel'] = 'nofollow'; - } - - return $aAttrs; - } -}