2008-06-23 04:08:37 +01:00
< ? php
2009-01-17 23:17:57 +00:00
/**
2009-08-25 23:12:20 +01:00
* StatusNet , the distributed open - source microblogging tool
2008-06-23 04:08:37 +01:00
*
2009-01-17 23:17:57 +00:00
* List of replies
*
* PHP version 5
*
* LICENCE : This program is free software : you can redistribute it and / or modify
2008-06-23 04:08:37 +01:00
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation , either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU Affero General Public License for more details .
*
* You should have received a copy of the GNU Affero General Public License
* along with this program . If not , see < http :// www . gnu . org / licenses />.
2009-01-17 23:17:57 +00:00
*
* @ category Personal
2009-08-25 23:12:20 +01:00
* @ package StatusNet
2009-08-25 23:19:04 +01:00
* @ author Evan Prodromou < evan @ status . net >
2011-06-09 21:20:19 +01:00
* @ copyright 2008 - 2011 StatusNet , Inc .
2009-01-17 23:17:57 +00:00
* @ license http :// www . fsf . org / licensing / licenses / agpl - 3.0 . html GNU Affero General Public License version 3.0
2009-08-25 23:16:46 +01:00
* @ link http :// status . net /
2008-06-23 04:08:37 +01:00
*/
2009-08-26 15:41:36 +01:00
if ( ! defined ( 'STATUSNET' ) && ! defined ( 'LACONICA' )) {
2009-01-17 23:17:57 +00:00
exit ( 1 );
}
2008-06-23 04:08:37 +01:00
2009-01-17 23:17:57 +00:00
require_once INSTALLDIR . '/lib/personalgroupnav.php' ;
require_once INSTALLDIR . '/lib/noticelist.php' ;
require_once INSTALLDIR . '/lib/feedlist.php' ;
2008-06-23 04:08:37 +01:00
2009-01-17 23:17:57 +00:00
/**
* List of replies
*
* @ category Personal
2009-08-25 23:12:20 +01:00
* @ package StatusNet
2009-08-25 23:19:04 +01:00
* @ author Evan Prodromou < evan @ status . net >
2009-01-17 23:17:57 +00:00
* @ license http :// www . fsf . org / licensing / licenses / agpl - 3.0 . html GNU Affero General Public License version 3.0
2009-08-25 23:16:46 +01:00
* @ link http :// status . net /
2009-01-17 23:17:57 +00:00
*/
2011-06-09 21:20:19 +01:00
class RepliesAction extends Action
2009-01-17 23:17:57 +00:00
{
var $page = null ;
2009-08-16 15:37:15 +01:00
var $notice ;
2009-01-17 23:17:57 +00:00
/**
* Prepare the object
*
* Check the input values and initialize the object .
* Shows an error page on bad input .
*
* @ param array $args $_REQUEST data
*
* @ return boolean success flag
*/
function prepare ( $args )
2008-12-23 19:33:23 +00:00
{
2009-01-17 23:17:57 +00:00
parent :: prepare ( $args );
2008-06-23 04:08:37 +01:00
2008-12-23 19:19:07 +00:00
$nickname = common_canonical_nickname ( $this -> arg ( 'nickname' ));
2008-06-23 04:08:37 +01:00
2013-08-18 12:04:58 +01:00
$this -> user = User :: getKV ( 'nickname' , $nickname );
2009-01-17 23:17:57 +00:00
if ( ! $this -> user ) {
2011-03-18 19:37:04 +00:00
// TRANS: Client error displayed when trying to reply to a non-exsting user.
2009-01-17 23:17:57 +00:00
$this -> clientError ( _ ( 'No such user.' ));
2008-12-23 19:19:07 +00:00
}
2008-06-23 04:08:37 +01:00
2009-01-17 23:17:57 +00:00
$profile = $this -> user -> getProfile ();
2008-06-23 04:08:37 +01:00
2008-12-23 19:19:07 +00:00
if ( ! $profile ) {
2011-04-25 13:48:19 +01:00
// TRANS: Error message displayed when referring to a user without a profile.
2009-01-15 23:03:38 +00:00
$this -> serverError ( _ ( 'User has no profile.' ));
2008-12-23 19:19:07 +00:00
}
2008-06-23 04:08:37 +01:00
2009-01-17 23:17:57 +00:00
$this -> page = ( $this -> arg ( 'page' )) ? ( $this -> arg ( 'page' ) + 0 ) : 1 ;
2008-06-23 04:08:37 +01:00
2009-02-06 00:16:10 +00:00
common_set_returnto ( $this -> selfUrl ());
2009-02-11 16:37:50 +00:00
2011-05-30 16:22:36 +01:00
$stream = new ReplyNoticeStream ( $this -> user -> id ,
Profile :: current ());
$this -> notice = $stream -> getNotices (( $this -> page - 1 ) * NOTICES_PER_PAGE ,
NOTICES_PER_PAGE + 1 );
2009-08-16 15:37:15 +01:00
if ( $this -> page > 1 && $this -> notice -> N == 0 ){
2015-01-29 22:35:49 +00:00
// TRANS: Client error when page not found (404)
$this -> clientError ( _ ( 'No such page.' ), 404 );
2009-08-16 15:37:15 +01:00
}
2009-01-17 23:17:57 +00:00
return true ;
}
2008-07-08 10:45:31 +01:00
2009-01-17 23:17:57 +00:00
/**
* Handle a request
*
* Just show the page . All args already handled .
*
* @ param array $args $_REQUEST data
*
* @ return void
*/
function handle ( $args )
{
parent :: handle ( $args );
$this -> showPage ();
2008-12-23 19:19:07 +00:00
}
2008-07-08 10:45:31 +01:00
2009-01-17 23:17:57 +00:00
/**
* Title of the page
*
* Includes name of user and page number .
*
* @ return string title of page
*/
function title ()
2008-12-23 19:33:23 +00:00
{
2009-01-17 23:17:57 +00:00
if ( $this -> page == 1 ) {
2011-03-18 19:37:04 +00:00
// TRANS: Title for first page of replies for a user.
// TRANS: %s is a user nickname.
2009-01-17 23:17:57 +00:00
return sprintf ( _ ( " Replies to %s " ), $this -> user -> nickname );
} else {
2011-03-18 19:37:04 +00:00
// TRANS: Title for all but the first page of replies for a user.
// TRANS: %1$s is a user nickname, %2$d is a page number.
2010-01-25 03:52:03 +00:00
return sprintf ( _ ( 'Replies to %1$s, page %2$d' ),
2009-01-24 17:28:47 +00:00
$this -> user -> nickname ,
2009-01-17 23:17:57 +00:00
$this -> page );
}
2008-12-23 19:19:07 +00:00
}
2008-07-17 13:42:15 +01:00
2009-01-17 23:17:57 +00:00
/**
* Feeds for the < head > section
*
* @ return void
*/
2009-02-11 16:37:50 +00:00
function getFeeds ()
2008-12-23 19:33:23 +00:00
{
2011-06-22 22:19:46 +01:00
return array ( new Feed ( Feed :: JSON ,
common_local_url ( 'ApiTimelineMentions' ,
array (
'id' => $this -> user -> nickname ,
'format' => 'as' )),
// TRANS: Link for feed with replies for a user.
// TRANS: %s is a user nickname.
sprintf ( _ ( 'Replies feed for %s (Activity Streams JSON)' ),
$this -> user -> nickname )),
new Feed ( Feed :: RSS1 ,
2009-10-29 23:09:42 +00:00
common_local_url ( 'repliesrss' ,
array ( 'nickname' => $this -> user -> nickname )),
2011-03-18 19:37:04 +00:00
// TRANS: Link for feed with replies for a user.
// TRANS: %s is a user nickname.
2009-10-29 23:09:42 +00:00
sprintf ( _ ( 'Replies feed for %s (RSS 1.0)' ),
$this -> user -> nickname )),
new Feed ( Feed :: RSS2 ,
common_local_url ( 'ApiTimelineMentions' ,
array (
'id' => $this -> user -> nickname ,
'format' => 'rss' )),
2011-03-18 19:37:04 +00:00
// TRANS: Link for feed with replies for a user.
// TRANS: %s is a user nickname.
2009-10-29 23:09:42 +00:00
sprintf ( _ ( 'Replies feed for %s (RSS 2.0)' ),
$this -> user -> nickname )),
new Feed ( Feed :: ATOM ,
common_local_url ( 'ApiTimelineMentions' ,
array (
'id' => $this -> user -> nickname ,
'format' => 'atom' )),
2011-03-18 19:37:04 +00:00
// TRANS: Link for feed with replies for a user.
// TRANS: %s is a user nickname.
2009-10-29 23:09:42 +00:00
sprintf ( _ ( 'Replies feed for %s (Atom)' ),
$this -> user -> nickname )));
2008-12-23 19:19:07 +00:00
}
2008-06-23 04:08:37 +01:00
2009-01-17 23:17:57 +00:00
/**
* Show the content
*
* A list of notices that are replies to the user , plus pagination .
*
* @ return void
*/
function showContent ()
{
2015-01-08 19:29:09 +00:00
$nl = new PrimaryNoticeList ( $this -> notice , $this , array ( 'show_n' => NOTICES_PER_PAGE ));
2008-12-11 23:12:52 +00:00
2009-01-17 23:17:57 +00:00
$cnt = $nl -> show ();
2009-04-08 00:25:12 +01:00
if ( 0 === $cnt ) {
$this -> showEmptyListMessage ();
}
2008-07-08 10:45:31 +01:00
2009-01-17 23:17:57 +00:00
$this -> pagination ( $this -> page > 1 , $cnt > NOTICES_PER_PAGE ,
$this -> page , 'replies' ,
array ( 'nickname' => $this -> user -> nickname ));
2008-12-23 19:19:07 +00:00
}
2009-01-23 09:15:15 +00:00
2009-04-08 00:25:12 +01:00
function showEmptyListMessage ()
{
2011-03-18 19:37:04 +00:00
// TRANS: Empty list message for page with replies for a user.
// TRANS: %1$s and %s$s are the user nickname.
$message = sprintf ( _ ( 'This is the timeline showing replies to %1$s but %2$s hasn\'t received a notice to them yet.' ),
$this -> user -> nickname ,
$this -> user -> nickname ) . ' ' ;
2009-04-08 00:25:12 +01:00
if ( common_logged_in ()) {
$current_user = common_current_user ();
if ( $this -> user -> id === $current_user -> id ) {
2011-03-18 19:37:04 +00:00
// TRANS: Empty list message for page with replies for a user for the logged in user.
// TRANS: This message contains a Markdown link in the form [link text](link).
2009-04-08 00:25:12 +01:00
$message .= _ ( 'You can engage other users in a conversation, subscribe to more people or [join groups](%%action.groups%%).' );
} else {
2011-03-18 19:37:04 +00:00
// TRANS: Empty list message for page with replies for a user for all logged in users but the user themselves.
// TRANS: %1$s, %2$s and %3$s are a user nickname. This message contains a Markdown link in the form [link text](link).
2010-07-31 23:16:39 +01:00
$message .= sprintf ( _ ( 'You can try to [nudge %1$s](../%2$s) or [post something to them](%%%%action.newnotice%%%%?status_textarea=%3$s).' ), $this -> user -> nickname , $this -> user -> nickname , '@' . $this -> user -> nickname );
2009-04-08 00:25:12 +01:00
}
}
else {
2011-03-18 19:37:04 +00:00
// TRANS: Empty list message for page with replies for a user for not logged in users.
// TRANS: %1$s is a user nickname. This message contains a Markdown link in the form [link text](link).
2010-07-31 23:16:39 +01:00
$message .= sprintf ( _ ( 'Why not [register an account](%%%%action.register%%%%) and then nudge %s or post a notice to them.' ), $this -> user -> nickname );
2009-04-08 00:25:12 +01:00
}
$this -> elementStart ( 'div' , 'guide' );
$this -> raw ( common_markup_to_html ( $message ));
$this -> elementEnd ( 'div' );
}
2009-04-13 20:49:26 +01:00
function isReadOnly ( $args )
2009-01-23 09:15:15 +00:00
{
return true ;
}
2008-06-23 04:08:37 +01:00
}