$cap->getNavigationBar()
. '<ul>' . $cap->getBody() . '</ul>' .
$cap->getNavigationBar()
- );
+ );
}
/**
+ * TODO: Allow sorting by count. We need to have a unique index to do this
+ * properly.
+ *
* @addtogroup SpecialPage
* @addtogroup Pager
*/
function getQueryInfo() {
global $wgRequest;
return array(
- 'tables' => array('categorylinks'),
- 'fields' => array('cl_to','count(*) AS count'),
- 'options' => array('GROUP BY' => 'cl_to')
- );
+ 'tables' => array( 'category' ),
+ 'fields' => array( 'cat_title','cat_pages' ),
+ 'conds' => array( 'cat_pages > 0' )
+ );
}
function getIndexField() {
- return "cl_to";
+# 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. */
- function getBody() {
+ public function getBody() {
if (!$this->mQueryDone) {
$this->doQuery();
}
$this->mResult->rewind();
while ( $row = $this->mResult->fetchObject() ) {
- $batch->addObj( Title::makeTitleSafe( NS_CATEGORY, $row->cl_to ) );
+ $batch->addObj( Title::makeTitleSafe( NS_CATEGORY, $row->cat_title ) );
}
$batch->execute();
$this->mResult->rewind();
function formatRow($result) {
global $wgLang;
- $title = Title::makeTitle( NS_CATEGORY, $result->cl_to );
+ $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->count ) );
+ $wgLang->formatNum( $result->cat_pages ) );
return Xml::tags('li', null, "$titleText ($count)" ) . "\n";
}
}