1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
|
<?php
/**
* @file
* @ingroup SpecialPage
*/
function wfSpecialCategories( $par=null ) {
global $wgOut, $wgRequest;
if( $par == '' ) {
$from = $wgRequest->getText( 'from' );
} else {
$from = $par;
}
$wgOut->allowClickjacking();
$cap = new CategoryPager( $from );
$cap->doQuery();
$wgOut->addHTML(
XML::openElement( 'div', array('class' => 'mw-spcontent') ) .
wfMsgExt( 'categoriespagetext', array( 'parse' ), $cap->getNumRows() ) .
$cap->getStartForm( $from ) .
$cap->getNavigationBar() .
'<ul>' . $cap->getBody() . '</ul>' .
$cap->getNavigationBar() .
XML::closeElement( 'div' )
);
}
/**
* TODO: Allow sorting by count. We need to have a unique index to do this
* properly.
*
* @ingroup SpecialPage Pager
*/
class CategoryPager extends AlphabeticPager {
function __construct( $from ) {
parent::__construct();
$from = str_replace( ' ', '_', $from );
if( $from !== '' ) {
$from = Title::capitalize( $from, NS_CATEGORY );
$this->mOffset = $from;
}
}
function getQueryInfo() {
return array(
'tables' => array( 'category' ),
'fields' => array( 'cat_title','cat_pages' ),
'conds' => array( 'cat_pages > 0' ),
'options' => array( 'USE INDEX' => 'cat_title' ),
);
}
function getIndexField() {
# return array( 'abc' => 'cat_title', 'count' => 'cat_pages' );
return 'cat_title';
}
function getDefaultQuery() {
parent::getDefaultQuery();
unset( $this->mDefaultQuery['from'] );
return $this->mDefaultQuery;
}
# 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() {
$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()->link( $title, htmlspecialchars( $title->getText() ) );
$count = wfMsgExt( 'nmembers', array( 'parsemag', 'escape' ),
$wgLang->formatNum( $result->cat_pages ) );
return Xml::tags('li', null, "$titleText ($count)" ) . "\n";
}
public function getStartForm( $from ) {
global $wgScript;
$t = SpecialPage::getTitleFor( 'Categories' );
return
Xml::tags( 'form', array( 'method' => 'get', 'action' => $wgScript ),
Xml::hidden( 'title', $t->getPrefixedText() ) .
Xml::fieldset( wfMsg( 'categories' ),
Xml::inputLabel( wfMsg( 'categoriesfrom' ),
'from', 'from', 20, $from ) .
' ' .
Xml::submitButton( wfMsg( 'allpagessubmit' ) ) ) );
}
}
|