2008-06-23 12:08:37 +09:00
< ? php
2009-01-18 08:17:57 +09:00
/**
* Laconica , the distributed open - source microblogging tool
2008-06-23 12:08:37 +09:00
*
2009-01-18 08:17:57 +09:00
* List of replies
*
* PHP version 5
*
* LICENCE : This program is free software : you can redistribute it and / or modify
2008-06-23 12:08:37 +09: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-18 08:17:57 +09:00
*
* @ category Personal
* @ package Laconica
* @ author Evan Prodromou < evan @ controlyourself . ca >
* @ copyright 2008 - 2009 Control Yourself , Inc .
* @ license http :// www . fsf . org / licensing / licenses / agpl - 3.0 . html GNU Affero General Public License version 3.0
* @ link http :// laconi . ca /
2008-06-23 12:08:37 +09:00
*/
2009-01-18 08:17:57 +09:00
if ( ! defined ( 'LACONICA' )) {
exit ( 1 );
}
2008-06-23 12:08:37 +09:00
2009-01-18 08:17:57 +09:00
require_once INSTALLDIR . '/lib/personalgroupnav.php' ;
require_once INSTALLDIR . '/lib/noticelist.php' ;
require_once INSTALLDIR . '/lib/feedlist.php' ;
2008-06-23 12:08:37 +09:00
2009-01-18 08:17:57 +09:00
/**
* List of replies
*
* @ category Personal
* @ package Laconica
* @ author Evan Prodromou < evan @ controlyourself . ca >
* @ license http :// www . fsf . org / licensing / licenses / agpl - 3.0 . html GNU Affero General Public License version 3.0
* @ link http :// laconi . ca /
*/
2008-06-23 12:08:37 +09:00
2009-05-24 12:35:04 +09:00
class RepliesAction extends OwnerDesignAction
2009-01-18 08:17:57 +09:00
{
var $page = null ;
2009-08-16 23:37:15 +09:00
var $notice ;
2009-01-18 08:17:57 +09: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-24 04:33:23 +09:00
{
2009-01-18 08:17:57 +09:00
parent :: prepare ( $args );
2008-06-23 12:08:37 +09:00
2008-12-24 04:19:07 +09:00
$nickname = common_canonical_nickname ( $this -> arg ( 'nickname' ));
2008-06-23 12:08:37 +09:00
2009-01-18 08:17:57 +09:00
$this -> user = User :: staticGet ( 'nickname' , $nickname );
if ( ! $this -> user ) {
$this -> clientError ( _ ( 'No such user.' ));
return false ;
2008-12-24 04:19:07 +09:00
}
2008-06-23 12:08:37 +09:00
2009-01-18 08:17:57 +09:00
$profile = $this -> user -> getProfile ();
2008-06-23 12:08:37 +09:00
2008-12-24 04:19:07 +09:00
if ( ! $profile ) {
2009-01-16 08:03:38 +09:00
$this -> serverError ( _ ( 'User has no profile.' ));
2009-01-18 08:17:57 +09:00
return false ;
2008-12-24 04:19:07 +09:00
}
2008-06-23 12:08:37 +09:00
2009-01-18 08:17:57 +09:00
$this -> page = ( $this -> arg ( 'page' )) ? ( $this -> arg ( 'page' ) + 0 ) : 1 ;
2008-06-23 12:08:37 +09:00
2009-02-06 09:16:10 +09:00
common_set_returnto ( $this -> selfUrl ());
2009-02-12 01:37:50 +09:00
2009-08-16 23:37:15 +09:00
$this -> notice = $this -> user -> getReplies (( $this -> page - 1 ) * NOTICES_PER_PAGE ,
NOTICES_PER_PAGE + 1 );
if ( $this -> page > 1 && $this -> notice -> N == 0 ){
$this -> serverError ( _ ( 'No such page' ), $code = 404 );
}
2009-01-18 08:17:57 +09:00
return true ;
}
2008-07-08 18:45:31 +09:00
2009-01-18 08:17:57 +09:00
/**
* Handle a request
*
* Just show the page . All args already handled .
*
* @ param array $args $_REQUEST data
*
* @ return void
*/
2008-07-08 18:45:31 +09:00
2009-01-18 08:17:57 +09:00
function handle ( $args )
{
parent :: handle ( $args );
$this -> showPage ();
2008-12-24 04:19:07 +09:00
}
2008-07-08 18:45:31 +09:00
2009-01-18 08:17:57 +09:00
/**
* Title of the page
*
* Includes name of user and page number .
*
* @ return string title of page
*/
function title ()
2008-12-24 04:33:23 +09:00
{
2009-01-18 08:17:57 +09:00
if ( $this -> page == 1 ) {
return sprintf ( _ ( " Replies to %s " ), $this -> user -> nickname );
} else {
return sprintf ( _ ( " Replies to %s, page %d " ),
2009-01-25 02:28:47 +09:00
$this -> user -> nickname ,
2009-01-18 08:17:57 +09:00
$this -> page );
}
2008-12-24 04:19:07 +09:00
}
2008-07-17 21:42:15 +09:00
2009-01-18 08:17:57 +09:00
/**
* Feeds for the < head > section
*
* @ return void
*/
2009-02-12 01:37:50 +09:00
function getFeeds ()
2008-12-24 04:33:23 +09:00
{
2009-01-18 08:17:57 +09:00
$rssurl = common_local_url ( 'repliesrss' ,
array ( 'nickname' => $this -> user -> nickname ));
$rsstitle = sprintf ( _ ( 'Feed for replies to %s' ), $this -> user -> nickname );
2009-02-12 01:37:50 +09:00
return array ( new Feed ( Feed :: RSS1 , $rssurl , $rsstitle ));
2008-12-24 04:19:07 +09:00
}
2008-06-23 12:08:37 +09:00
2009-01-18 08:17:57 +09:00
/**
* show the personal group nav
*
* @ return void
*/
function showLocalNav ()
2008-12-24 04:33:23 +09:00
{
2009-01-18 08:17:57 +09:00
$nav = new PersonalGroupNav ( $this );
$nav -> show ();
}
2008-07-08 18:45:31 +09:00
2009-01-18 08:17:57 +09:00
/**
* Show the content
*
* A list of notices that are replies to the user , plus pagination .
*
* @ return void
*/
2008-07-07 16:05:45 +09:00
2009-01-18 08:17:57 +09:00
function showContent ()
{
2009-08-16 23:37:15 +09:00
$nl = new NoticeList ( $this -> notice , $this );
2008-12-12 08:12:52 +09:00
2009-01-18 08:17:57 +09:00
$cnt = $nl -> show ();
2009-04-08 08:25:12 +09:00
if ( 0 === $cnt ) {
$this -> showEmptyListMessage ();
}
2008-07-08 18:45:31 +09:00
2009-01-18 08:17:57 +09:00
$this -> pagination ( $this -> page > 1 , $cnt > NOTICES_PER_PAGE ,
$this -> page , 'replies' ,
array ( 'nickname' => $this -> user -> nickname ));
2008-12-24 04:19:07 +09:00
}
2009-01-23 18:15:15 +09:00
2009-04-08 08:25:12 +09:00
function showEmptyListMessage ()
{
$message = sprintf ( _ ( 'This is the timeline showing replies to %s but %s hasn\'t received a notice to his attention yet.' ), $this -> user -> nickname , $this -> user -> nickname ) . ' ' ;
if ( common_logged_in ()) {
$current_user = common_current_user ();
if ( $this -> user -> id === $current_user -> id ) {
$message .= _ ( 'You can engage other users in a conversation, subscribe to more people or [join groups](%%action.groups%%).' );
} else {
$message .= sprintf ( _ ( 'You can try to [nudge %s](../%s) or [post something to his or her attention](%%%%action.newnotice%%%%?status_textarea=%s).' ), $this -> user -> nickname , $this -> user -> nickname , '@' . $this -> user -> nickname );
}
}
else {
2009-08-09 20:12:59 +09:00
$message .= sprintf ( _ ( 'Why not [register an account](%%%%action.%s%%%%) and then nudge %s or post a notice to his or her attention.' ),
( ! common_config ( 'site' , 'openidonly' )) ? 'register' : 'openidlogin' ,
$this -> user -> nickname );
2009-04-08 08:25:12 +09:00
}
$this -> elementStart ( 'div' , 'guide' );
$this -> raw ( common_markup_to_html ( $message ));
$this -> elementEnd ( 'div' );
}
2009-04-14 04:49:26 +09:00
function isReadOnly ( $args )
2009-01-23 18:15:15 +09:00
{
return true ;
}
2008-06-23 12:08:37 +09:00
}