X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Fall.php;h=8c22e6f5f076337b5829a791129369beaef2b9db;hb=a21a17263956808e074fb62551300c5d6297387b;hp=526ac5f40881257217885ac0b99a68729a164e48;hpb=2d456a15e5652a0c0e2c0f9f50221eed2d16e109;p=quix0rs-gnu-social.git diff --git a/actions/all.php b/actions/all.php index 526ac5f408..8c22e6f5f0 100644 --- a/actions/all.php +++ b/actions/all.php @@ -1,7 +1,7 @@ . + * + * @category Actions + * @package Actions + * @author Evan Prodromou + * @author Mike Cochrane + * @author Robin Millette + * @author Adrian Lang + * @author Meitar Moscovitz + * @author Sarven Capadisli + * @author Craig Andrews + * @author Jeffery To + * @author Zach Copley + * @license GNU Affero General Public License http://www.gnu.org/licenses/ + * @link http://status.net */ -if (!defined('LACONICA')) { exit(1); } +if (!defined('STATUSNET') && !defined('LACONICA')) { + exit(1); +} -require_once(INSTALLDIR.'/actions/showstream.php'); +require_once INSTALLDIR.'/lib/personalgroupnav.php'; +require_once INSTALLDIR.'/lib/noticelist.php'; +require_once INSTALLDIR.'/lib/feedlist.php'; -class AllAction extends StreamAction +class AllAction extends ProfileAction { + var $notice; - function handle($args) + function isReadOnly($args) { + return true; + } - parent::handle($args); + function prepare($args) + { + parent::prepare($args); + $cur = common_current_user(); - $nickname = common_canonical_nickname($this->arg('nickname')); - $user = User::staticGet('nickname', $nickname); + if (!empty($cur) && $cur->id == $this->user->id) { + $this->notice = $this->user->noticeInbox(($this->page-1)*NOTICES_PER_PAGE, NOTICES_PER_PAGE + 1); + } else { + $this->notice = $this->user->noticesWithFriends(($this->page-1)*NOTICES_PER_PAGE, NOTICES_PER_PAGE + 1); + } - if (!$user) { - $this->client_error(_('No such user.')); - return; + if ($this->page > 1 && $this->notice->N == 0) { + // TRANS: Server error when page not found (404) + $this->serverError(_('No such page'), $code = 404); } - $profile = $user->getProfile(); + return true; + } - if (!$profile) { - common_server_error(_('User has no profile.')); + function handle($args) + { + parent::handle($args); + + if (!$this->user) { + $this->clientError(_('No such user.')); return; } - # Looks like we're good; show the header - - common_show_header(sprintf(_("%s and friends"), $profile->nickname), - array($this, 'show_header'), $user, - array($this, 'show_top')); - - $this->show_notices($user); + $this->showPage(); + } - common_show_footer(); + function title() + { + if ($this->page > 1) { + // TRANS: Page title. %1$s is user nickname, %2$d is page number + return sprintf(_('%1$s and friends, page %2$d'), $this->user->nickname, $this->page); + } else { + // TRANS: Page title. %1$s is user nickname + return sprintf(_("%s and friends"), $this->user->nickname); + } } - function show_header($user) + function getFeeds() { - common_element('link', array('rel' => 'alternate', - 'href' => common_local_url('allrss', array('nickname' => - $user->nickname)), - 'type' => 'application/rss+xml', - 'title' => sprintf(_('Feed for friends of %s'), $user->nickname))); + return array( + new Feed(Feed::RSS1, + common_local_url( + 'allrss', array( + 'nickname' => + $this->user->nickname) + ), + // TRANS: %1$s is user nickname + sprintf(_('Feed for friends of %s (RSS 1.0)'), $this->user->nickname)), + new Feed(Feed::RSS2, + common_local_url( + 'ApiTimelineFriends', array( + 'format' => 'rss', + 'id' => $this->user->nickname + ) + ), + // TRANS: %1$s is user nickname + sprintf(_('Feed for friends of %s (RSS 2.0)'), $this->user->nickname)), + new Feed(Feed::ATOM, + common_local_url( + 'ApiTimelineFriends', array( + 'format' => 'atom', + 'id' => $this->user->nickname + ) + ), + // TRANS: %1$s is user nickname + sprintf(_('Feed for friends of %s (Atom)'), $this->user->nickname)) + ); } - function show_top($user) + function showLocalNav() { - $cur = common_current_user(); + $nav = new PersonalGroupNav($this); + $nav->show(); + } - if ($cur && $cur->id == $user->id) { - common_notice_form('all'); + function showEmptyListMessage() + { + // TRANS: %1$s is user nickname + $message = sprintf(_('This is the timeline for %s and friends but no one has posted anything yet.'), $this->user->nickname) . ' '; + + if (common_logged_in()) { + $current_user = common_current_user(); + if ($this->user->id === $current_user->id) { + $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 "@" + $message .= sprintf(_('You can try to [nudge %1$s](../%2$s) from his profile or [post something to his or her attention](%%%%action.newnotice%%%%?status_textarea=%3$s).'), $this->user->nickname, $this->user->nickname, '@' . $this->user->nickname); + } + } else { + $message .= sprintf(_('Why not [register an account](%%%%action.register%%%%) and then nudge %s or post a notice to his or her attention.'), $this->user->nickname); } - $this->views_menu(); - - $this->show_feeds_list(array(0=>array('href'=>common_local_url('allrss', array('nickname' => $user->nickname)), - 'type' => 'rss', - 'version' => 'RSS 1.0', - 'item' => 'allrss'))); + $this->elementStart('div', 'guide'); + $this->raw(common_markup_to_html($message)); + $this->elementEnd('div'); } - function show_notices($user) + function showContent() { + if (Event::handle('StartShowAllContent', array($this))) { + $nl = new NoticeList($this->notice, $this); - $page = $this->trimmed('page'); - if (!$page) { - $page = 1; - } + $cnt = $nl->show(); - $notice = $user->noticesWithFriends(($page-1)*NOTICES_PER_PAGE, NOTICES_PER_PAGE + 1); + if (0 == $cnt) { + $this->showEmptyListMessage(); + } - $cnt = $this->show_notice_list($notice); + $this->pagination( + $this->page > 1, $cnt > NOTICES_PER_PAGE, + $this->page, 'all', array('nickname' => $this->user->nickname) + ); - common_pagination($page > 1, $cnt > NOTICES_PER_PAGE, - $page, 'all', array('nickname' => $user->nickname)); + Event::handle('EndShowAllContent', array($this)); + } + } + + function showPageTitle() + { + $user = common_current_user(); + if ($user && ($user->id == $this->user->id)) { + // TRANS: H1 text + $this->element('h1', null, _("You and friends")); + } else { + // TRANS: H1 text. %1$s is user nickname + $this->element('h1', null, sprintf(_('%s and friends'), $this->user->nickname)); + } } }