X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fsubscribers.php;h=2724927878c586d640c0a827317dd61e59993f3a;hb=792b62874e13214dc12480acd2cf4a40b3292d79;hp=cd3e2ee5bedd136190ddea88971c526345c98b73;hpb=26b03240271d061177a258dbae46bc384dbc9d6a;p=quix0rs-gnu-social.git diff --git a/actions/subscribers.php b/actions/subscribers.php index cd3e2ee5be..2724927878 100644 --- a/actions/subscribers.php +++ b/actions/subscribers.php @@ -41,32 +41,38 @@ if (!defined('STATUSNET') && !defined('LACONICA')) { * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 * @link http://status.net/ */ - class SubscribersAction extends GalleryAction { function title() { if ($this->page == 1) { - return sprintf(_('%s subscribers'), $this->user->nickname); + // TRANS: Header for list of subscribers for a user (first page). + // TRANS: %s is the user's 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. _('These are the people who listen to '. 'your notices.')); } else { $this->element('p', null, + // TRANS: Page notice for page with an overview of all subscribers of a user other + // 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())); } } @@ -80,38 +86,40 @@ 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(); } } - $subscribers->free(); - $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) { - $message = _('You have no subscribers. Try subscribing to people you know and they might return the favor'); - } else { - $message = sprintf(_('%s has no subscribers. Want to be the first?'), $this->user->nickname); - } - } - else { - $message = sprintf(_('%s has no subscribers. Why not [register an account](%%%%action.register%%%%) and be the first?'), $this->user->nickname); + 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->target->getNickname()); } $this->elementStart('div', 'guide'); @@ -122,11 +130,6 @@ class SubscribersAction extends GalleryAction function showSections() { parent::showSections(); - $cloud = new SubscribersPeopleTagCloudSection($this); - $cloud->show(); - - $cloud2 = new SubscribersPeopleSelfTagCloudSection($this); - $cloud2->show(); } } @@ -143,9 +146,12 @@ class SubscribersListItem extends SubscriptionListItem function showActions() { $this->startActions(); - $this->showSubscribeButton(); - // Relevant code! - $this->showBlockForm(); + if (Event::handle('StartProfileListItemActionElements', array($this))) { + $this->showSubscribeButton(); + // Relevant code! + $this->showBlockForm(); + Event::handle('EndProfileListItemActionElements', array($this)); + } $this->endActions(); } @@ -154,10 +160,36 @@ class SubscribersListItem extends SubscriptionListItem $user = common_current_user(); if (!empty($user) && $this->owner->id == $user->id) { - $bf = new BlockForm($this->out, $this->profile, - array('action' => 'subscribers', - 'nickname' => $this->owner->nickname)); + $returnto = array('action' => 'subscribers', + 'nickname' => $this->owner->getNickname()); + $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; + } }