*
* @ingroup SpecialPage
*/
-class ActiveUsersPager extends UsersPager {
+class SpecialActiveUsers extends QueryPage {
/**
* @var FormOptions
$this->setupOptions();
- parent::__construct();
+ parent::__construct( 'Activeusers' );
}
public function setupOptions() {
$this->opts->add( 'hidebots', false, FormOptions::BOOL );
$this->opts->add( 'hidesysops', false, FormOptions::BOOL );
+ $this->opts->add( 'limit', 0, FormOptions::INT );
+ $this->opts->add( 'offset', 0, FormOptions::INT );
$this->opts->fetchValuesFromRequest( $wgRequest );
}
}
- function getIndexField() {
- return 'rc_user_text';
+ function getOrderFields() {
+ return array( 'rc_user_text', 'user_id' );
}
function getQueryInfo() {
return $query;
}
- function formatRow( $row ) {
+ function formatResult( $skin, $row ) {
global $wgLang;
$userName = $row->user_name;
- $ulinks = $this->getSkin()->userLink( $row->user_id, $userName );
- $ulinks .= $this->getSkin()->userToolLinks( $row->user_id, $userName );
+ $ulinks = $skin->userLink( $row->user_id, $userName );
+ $ulinks .= $skin->userToolLinks( $row->user_id, $userName );
$list = array();
- foreach( self::getGroups( $row->user_id ) as $group ) {
+ $user = User::newFromId( $row->user_id );
+ foreach( $user->getEffectiveGroups() as $group ) {
if ( isset( $this->groups[$group] ) ) {
- return;
+ return false;
+ }
+ if( in_array( $group, array( '*', 'user' ) ) ){
+ continue;
}
- $list[] = self::buildGroupLink( $group );
+ $list[] = SpecialListUsers::buildGroupLink( $group );
}
$groups = $wgLang->commaList( $list );
);
$blocked = $row->blocked ? ' ' . wfMsgExt( 'listusers-blocked', array( 'parsemag' ), $userName ) : '';
- return Html::rawElement( 'li', array(), "{$item} [{$count}]{$blocked}" );
+ return "{$item} [{$count}]{$blocked}";
+ }
+
+ function linkParameters() {
+ return array(
+ 'hidebots' => isset( $this->groups['bot'] ),
+ 'hidesysops' => isset( $this->groups['sysop'] ),
+ 'username' => $this->requestedUser,
+ );
}
function getPageHeader() {
- global $wgScript;
+ global $wgScript, $wgActiveUserDays, $wgLang;
$self = $this->getTitle();
- $limit = $this->mLimit ? Html::hidden( 'limit', $this->mLimit ) : '';
+ $limit = $this->opts->getValue( 'limit' )
+ ? Html::hidden( 'limit', $this->opts->getValue( 'limit' ) )
+ : '';
+ $offset = $this->opts->getValue( 'offset' )
+ ? Html::hidden( 'offset', $this->opts->getValue( 'offset' ) )
+ : '';
+
+ $out = Html::rawElement( 'div', array( 'class' => 'mw-activeusers-intro' ),
+ wfMsgExt( 'activeusers-intro', array( 'parsemag', 'escape' ), $wgLang->formatNum( $wgActiveUserDays ) )
+ );
- $out = Xml::openElement( 'form', array( 'method' => 'get', 'action' => $wgScript ) ); # Form tag
+ $out .= Xml::openElement( 'form', array( 'method' => 'get', 'action' => $wgScript ) ); # Form tag
$out .= Xml::fieldset( wfMsg( 'activeusers' ) ) . "\n";
- $out .= Html::hidden( 'title', $self->getPrefixedDBkey() ) . $limit . "\n";
+ $out .= Html::hidden( 'title', $self->getPrefixedDBkey() ) . $limit . $offset . "\n";
$out .= Xml::inputLabel( wfMsg( 'activeusers-from' ), 'username', 'offset', 20, $this->requestedUser ) . '<br />';# Username field
return $out;
}
-}
-
-/**
- * @ingroup SpecialPage
- */
-class SpecialActiveUsers extends SpecialPage {
-
- /**
- * Constructor
- */
- public function __construct() {
- parent::__construct( 'Activeusers' );
- }
-
- /**
- * Show the special page
- *
- * @param $par Mixed: parameter passed to the page or null
- */
- public function execute( $par ) {
- global $wgOut, $wgLang, $wgActiveUserDays;
-
- $this->setHeaders();
- $this->outputHeader();
-
- $up = new ActiveUsersPager();
-
- # getBody() first to check, if empty
- $usersbody = $up->getBody();
-
- $s = Html::rawElement( 'div', array( 'class' => 'mw-activeusers-intro' ),
- wfMsgExt( 'activeusers-intro', array( 'parsemag', 'escape' ), $wgLang->formatNum( $wgActiveUserDays ) )
- );
-
- $s .= $up->getPageHeader();
- if( $usersbody ) {
- $s .= $up->getNavigationBar();
- $s .= Html::rawElement( 'ul', array(), $usersbody );
- $s .= $up->getNavigationBar();
- } else {
- $s .= Html::element( 'p', array(), wfMsg( 'activeusers-noresult' ) );
- }
-
- $wgOut->addHTML( $s );
- }
-
-}
+}
\ No newline at end of file