* @see PublicrssAction
* @see PublicxrdsAction
*/
-class PublicAction extends Action
+class PublicAction extends ManagedAction
{
/**
* page of the stream we're on; default = 1
var $page = null;
var $notice;
- var $userProfile = null;
- function isReadOnly($args)
+ protected $stream = null;
+
+ function isReadOnly(array $args=array())
{
return true;
}
*
* @return boolean success value
*/
- function prepare($args)
+ protected function doPreparation()
{
- parent::prepare($args);
$this->page = ($this->arg('page')) ? ($this->arg('page')+0) : 1;
if ($this->page > MAX_PUBLIC_PAGE) {
common_set_returnto($this->selfUrl());
- $this->userProfile = Profile::current();
-
- $user = common_current_user();
+ $this->streamPrepare();
- if (!empty($user) && $user->streamModeOnly()) {
- $stream = new PublicNoticeStream($this->userProfile);
- } else {
- $stream = new ThreadingPublicNoticeStream($this->userProfile);
- }
-
- $this->notice = $stream->getNotices(($this->page-1)*NOTICES_PER_PAGE,
+ $this->notice = $this->stream->getNotices(($this->page-1)*NOTICES_PER_PAGE,
NOTICES_PER_PAGE + 1);
if (!$this->notice) {
$this->serverError(_('Could not retrieve public timeline.'));
}
- if($this->page > 1 && $this->notice->N == 0){
- // TRANS: Server error when page not found (404).
- $this->serverError(_('No such page.'),$code=404);
+ if ($this->page > 1 && $this->notice->N == 0){
+ // TRANS: Client error when page not found (404).
+ $this->clientError(_('No such page.'), 404);
}
return true;
*
* @return void
*/
- function handle($args)
+ protected function streamPrepare()
{
- parent::handle($args);
-
- $this->showPage();
+ if ($this->scoped instanceof Profile && $this->scoped->isLocal() && $this->scoped->getUser()->streamModeOnly()) {
+ $this->stream = new PublicNoticeStream($this->scoped);
+ } else {
+ $this->stream = new ThreadingPublicNoticeStream($this->scoped);
+ }
}
/**
*/
function showContent()
{
- $user = common_current_user();
-
- if (!empty($user) && $user->streamModeOnly()) {
- $nl = new NoticeList($this->notice, $this);
+ if ($this->scoped instanceof Profile && $this->scoped->isLocal() && $this->scoped->getUser()->streamModeOnly()) {
+ $nl = new PrimaryNoticeList($this->notice, $this, array('show_n'=>NOTICES_PER_PAGE));
} else {
- $nl = new ThreadedNoticeList($this->notice, $this, $this->userProfile);
+ $nl = new ThreadedNoticeList($this->notice, $this, $this->scoped);
}
$cnt = $nl->show();
}
$this->pagination($this->page > 1, $cnt > NOTICES_PER_PAGE,
- $this->page, 'public');
+ $this->page, $this->action);
}
function showSections()
$this->elementEnd('div');
}
}
-
-class ThreadingPublicNoticeStream extends ThreadingNoticeStream
-{
- function __construct($profile)
- {
- parent::__construct(new PublicNoticeStream($profile));
- }
-}