addHTML( wfMsgExt( 'categoriespagetext', array( 'parse' ) ) . $cap->getNavigationBar() . '' . $cap->getNavigationBar() ); } /** * TODO: Allow sorting by count. We need to have a unique index to do this * properly. * * @addtogroup SpecialPage * @addtogroup Pager */ class CategoryPager extends AlphabeticPager { function getQueryInfo() { global $wgRequest; return array( 'tables' => array( 'category' ), 'fields' => array( 'cat_title','cat_pages' ), 'conds' => array( 'cat_pages > 0' ) ); } function getIndexField() { # return array( 'abc' => 'cat_title', 'count' => 'cat_pages' ); return 'cat_title'; } # protected function getOrderTypeMessages() { # return array( 'abc' => 'special-categories-sort-abc', # 'count' => 'special-categories-sort-count' ); # } protected function getDefaultDirections() { # return array( 'abc' => false, 'count' => true ); return false; } /* Override getBody to apply LinksBatch on resultset before actually outputting anything. */ public function getBody() { if (!$this->mQueryDone) { $this->doQuery(); } $batch = new LinkBatch; $this->mResult->rewind(); while ( $row = $this->mResult->fetchObject() ) { $batch->addObj( Title::makeTitleSafe( NS_CATEGORY, $row->cat_title ) ); } $batch->execute(); $this->mResult->rewind(); return parent::getBody(); } function formatRow($result) { global $wgLang; $title = Title::makeTitle( NS_CATEGORY, $result->cat_title ); $titleText = $this->getSkin()->makeLinkObj( $title, htmlspecialchars( $title->getText() ) ); $count = wfMsgExt( 'nmembers', array( 'parsemag', 'escape' ), $wgLang->formatNum( $result->cat_pages ) ); return Xml::tags('li', null, "$titleText ($count)" ) . "\n"; } }