-<?
+<?php
+/**
+ *
+ * @addtogroup SpecialPage
+ */
-function wfSpecialCategories()
-{
- global $wgUser, $wgOut , $wgLang ;
- global $article , $category ;
- $sk = $wgUser->getSkin() ;
- $sc = "Special:Categories" ;
- $r = "" ;
- $r .= "<OL>\n" ;
- $cat = ucfirst ( wfMsg ( "category" ) ) ;
- $sql = "SELECT cur_title FROM cur WHERE cur_title LIKE \"{$cat}:%\"" ;
- $res = wfQuery ( $sql ) ;
- while ( $x = wfFetchObject ( $res ) )
- {
- $t = explode ( ":" , $x->cur_title , 2 ) ;
- $t = $t[1] ;
- $r .= "<li>" ;
- $r .= $sk->makeKnownLink ( $x->cur_title , $t ) ;
- $r .= "</li>\n" ;
- }
- wfFreeResult ( $res ) ;
- $r .= "</OL>\n" ;
+function wfSpecialCategories() {
+ global $wgOut;
- $r .= "<hr>\n" ;
- $sql = "SELECT DISTINCT bl_to FROM brokenlinks WHERE bl_to LIKE \"{$cat}:%\"" ;
- $res = wfQuery ( $sql ) ;
- $r .= "<OL>\n" ;
- while ( $x = wfFetchObject ( $res ) )
- {
- $t = explode ( ":" , $x->bl_to , 2 ) ;
- $t = $t[1] ;
- $r .= "<li>" ;
- $r .= $sk->makeBrokenLink ( $x->bl_to , $t ) ;
- $r .= "</li>\n" ;
- }
- wfFreeResult ( $res ) ;
- $r .= "</OL>\n" ;
+ $cap = new CategoryPager();
+ $wgOut->addHTML(
+ wfMsgExt( 'categoriespagetext', array( 'parse' ) ) .
+ $cap->getNavigationBar()
+ . '<ul>' . $cap->getBody() . '</ul>' .
+ $cap->getNavigationBar()
+ );
+}
+
+/**
+ * @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' );
+ }
- $wgOut->addHTML ( $r ) ;
+ protected function getOrderTypeMessages() {
+ return array( 'abc' => 'special-categories-sort-abc',
+ 'count' => 'special-categories-sort-count' );
+ }
+
+ protected function getDefaultDirection() {
+ return array( 'abc' => false, 'count' => true );
+ }
+
+ /* 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";
+ }
}
-?>
+