X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fall.php;h=a0e0b9a08b71a59ff2c4e7a7ba19f6cd922361b3;hb=418b3c3c53194040022c4b56bd0c0b04fd6fd4d7;hp=8ee3ec3fa697dcb42890b38e285846f9d5f66d68;hpb=c4aef15a153e961a3a5341d3b3864fdb9b664bb8;p=quix0rs-gnu-social.git diff --git a/actions/all.php b/actions/all.php index 8ee3ec3fa6..a0e0b9a08b 100644 --- a/actions/all.php +++ b/actions/all.php @@ -1,7 +1,7 @@ * @author Siebrand Mazeland * @author Zach Copley - * @copyright 2009 Free Software Foundation, Inc http://www.fsf.org + * @copyright 2009-2014 Free Software Foundation, Inc http://www.fsf.org * @license GNU Affero General Public License http://www.gnu.org/licenses/ * @link http://status.net */ -if (!defined('STATUSNET') && !defined('LACONICA')) { - exit(1); -} - -require_once INSTALLDIR.'/lib/personalgroupnav.php'; -require_once INSTALLDIR.'/lib/noticelist.php'; -require_once INSTALLDIR.'/lib/feedlist.php'; +if (!defined('GNUSOCIAL') && !defined('STATUSNET')) { exit(1); } class AllAction extends ProfileAction { @@ -52,11 +46,17 @@ class AllAction extends ProfileAction return true; } - function prepare($args) + protected function prepare(array $args=array()) { parent::prepare($args); - $stream = new ThreadingInboxNoticeStream($this->user, Profile::current()); + $user = common_current_user(); + + if (!empty($user) && $user->streamModeOnly()) { + $stream = new InboxNoticeStream($this->target, $this->scoped); + } else { + $stream = new ThreadingInboxNoticeStream($this->target, $this->scoped); + } $this->notice = $stream->getNotices(($this->page-1)*NOTICES_PER_PAGE, NOTICES_PER_PAGE + 1); @@ -69,14 +69,13 @@ class AllAction extends ProfileAction return true; } - function handle($args) + protected function handle() { - parent::handle($args); + parent::handle(); - if (!$this->user) { + if (!$this->target instanceof Profile) { // TRANS: Client error when user not found for an action. $this->clientError(_('No such user.')); - return; } $this->showPage(); @@ -84,67 +83,76 @@ class AllAction extends ProfileAction function title() { - $user = common_current_user(); - if ($user->id == $this->user->id) { + if (!empty($this->scoped) && $this->scoped->id == $this->target->id) { + // TRANS: Title of a user's own start page. return _('Home timeline'); } else { - $profile = $this->user->getProfile(); - return sprintf(_("%s's home timeline"), $profile->getBestName()); + // TRANS: Title of another user's start page. + // TRANS: %s is the other user's name. + return sprintf(_("%s's home timeline"), $this->target->getBestName()); } } function getFeeds() { return array( + new Feed(Feed::JSON, + common_local_url( + 'ApiTimelineFriends', array( + 'format' => 'as', + 'id' => $this->target->nickname + ) + ), + // TRANS: %s is user nickname. + sprintf(_('Feed for friends of %s (Activity Streams JSON)'), $this->target->nickname)), new Feed(Feed::RSS1, common_local_url( 'allrss', array( 'nickname' => - $this->user->nickname) + $this->target->nickname) ), // TRANS: %s is user nickname. - sprintf(_('Feed for friends of %s (RSS 1.0)'), $this->user->nickname)), + sprintf(_('Feed for friends of %s (RSS 1.0)'), $this->target->nickname)), new Feed(Feed::RSS2, common_local_url( 'ApiTimelineFriends', array( 'format' => 'rss', - 'id' => $this->user->nickname + 'id' => $this->target->nickname ) ), // TRANS: %s is user nickname. - sprintf(_('Feed for friends of %s (RSS 2.0)'), $this->user->nickname)), + sprintf(_('Feed for friends of %s (RSS 2.0)'), $this->target->nickname)), new Feed(Feed::ATOM, common_local_url( 'ApiTimelineFriends', array( 'format' => 'atom', - 'id' => $this->user->nickname + 'id' => $this->target->nickname ) ), // TRANS: %s is user nickname. - sprintf(_('Feed for friends of %s (Atom)'), $this->user->nickname)) + sprintf(_('Feed for friends of %s (Atom)'), $this->target->nickname)) ); } function showEmptyListMessage() { // TRANS: Empty list message. %s is a user nickname. - $message = sprintf(_('This is the timeline for %s and friends but no one has posted anything yet.'), $this->user->nickname) . ' '; + $message = sprintf(_('This is the timeline for %s and friends but no one has posted anything yet.'), $this->target->nickname) . ' '; if (common_logged_in()) { - $current_user = common_current_user(); - if ($this->user->id === $current_user->id) { + if ($this->target->id === $this->scoped->id) { // TRANS: Encouragement displayed on logged in user's empty timeline. // TRANS: This message contains Markdown links. Keep "](" together. $message .= _('Try subscribing to more people, [join a group](%%action.groups%%) or post something yourself.'); } else { // TRANS: %1$s is user nickname, %2$s is user nickname, %2$s is user nickname prefixed with "@". // TRANS: This message contains Markdown links. Keep "](" together. - $message .= sprintf(_('You can try to [nudge %1$s](../%2$s) from their profile or [post something to them](%%%%action.newnotice%%%%?status_textarea=%3$s).'), $this->user->nickname, $this->user->nickname, '@' . $this->user->nickname); + $message .= sprintf(_('You can try to [nudge %1$s](../%2$s) from their profile or [post something to them](%%%%action.newnotice%%%%?status_textarea=%3$s).'), $this->target->nickname, $this->target->nickname, '@' . $this->target->nickname); } } else { - // TRANS: Encoutagement displayed on empty timeline user pages for anonymous users. + // TRANS: Encouragement displayed on empty timeline user pages for anonymous users. // TRANS: %s is a user nickname. This message contains Markdown links. Keep "](" together. - $message .= sprintf(_('Why not [register an account](%%%%action.register%%%%) and then nudge %s or post a notice to them.'), $this->user->nickname); + $message .= sprintf(_('Why not [register an account](%%%%action.register%%%%) and then nudge %s or post a notice to them.'), $this->target->nickname); } $this->elementStart('div', 'guide'); @@ -164,7 +172,11 @@ class AllAction extends ProfileAction $profile = $current_user->getProfile(); } - $nl = new ThreadedNoticeList($this->notice, $this, $profile); + if (!empty($current_user) && $current_user->streamModeOnly()) { + $nl = new NoticeList($this->notice, $this); + } else { + $nl = new ThreadedNoticeList($this->notice, $this, $profile); + } $cnt = $nl->show(); @@ -174,7 +186,7 @@ class AllAction extends ProfileAction $this->pagination( $this->page > 1, $cnt > NOTICES_PER_PAGE, - $this->page, 'all', array('nickname' => $this->user->nickname) + $this->page, 'all', array('nickname' => $this->target->nickname) ); Event::handle('EndShowAllContent', array($this)); @@ -183,19 +195,36 @@ class AllAction extends ProfileAction function showSections() { - $ibs = new InviteButtonSection($this); - $ibs->show(); - $pop = new PopularNoticeSection($this); - $pop->show(); - // $pop = new InboxTagCloudSection($this, $this->user); - // $pop->show(); + // Show invite button, as long as site isn't closed, and + // we have a logged in user. + if (common_config('invite', 'enabled') && !common_config('site', 'closed') && common_logged_in()) { + if (!common_config('site', 'private')) { + $ibs = new InviteButtonSection( + $this, + // TRANS: Button text for inviting more users to the StatusNet instance. + // TRANS: Less business/enterprise-oriented language for public sites. + _m('BUTTON', 'Send invite') + ); + } else { + $ibs = new InviteButtonSection($this); + } + $ibs->show(); + } + // XXX: make this a little more convenient + + if (!common_config('performance', 'high')) { + $pop = new PopularNoticeSection($this, $this->scoped); + $pop->show(); + $pop = new InboxTagCloudSection($this, $this->target); + $pop->show(); + } } } class ThreadingInboxNoticeStream extends ThreadingNoticeStream { - function __construct($user, $profile) + function __construct(Profile $target, Profile $scoped=null) { - parent::__construct(new InboxNoticeStream($user, $profile)); + parent::__construct(new InboxNoticeStream($target, $scoped)); } }