* Modified Special:Specialpages to subclass UnlistedSpecialPage instead of using...
authorAlexandre Emsenhuber <ialex@users.mediawiki.org>
Sat, 10 Jul 2010 20:13:06 +0000 (20:13 +0000)
committerAlexandre Emsenhuber <ialex@users.mediawiki.org>
Sat, 10 Jul 2010 20:13:06 +0000 (20:13 +0000)
* Use Html:: methods

includes/AutoLoader.php
includes/SpecialPage.php
includes/specials/SpecialSpecialpages.php

index 64f57e8..f75d285 100644 (file)
@@ -598,6 +598,7 @@ $wgAutoloadLocalClasses = array(
        'SpecialRecentchangeslinked' => 'includes/specials/SpecialRecentchangeslinked.php',
        'SpecialSearch' => 'includes/specials/SpecialSearch.php',
        'SpecialSelenium' => 'includes/specials/SpecialSelenium.php',
+       'SpecialSpecialpages' => 'includes/specials/SpecialSpecialpages.php',
        'SpecialStatistics' => 'includes/specials/SpecialStatistics.php',
        'SpecialTags' => 'includes/specials/SpecialTags.php',
        'SpecialUnlockdb' => 'includes/specials/SpecialUnlockdb.php',
index b88969f..fec32b7 100644 (file)
@@ -191,7 +191,7 @@ class SpecialPage {
                'Mytalk'                    => 'SpecialMytalk',
                'Revisiondelete'            => 'SpecialRevisionDelete',
                'RevisionMove'              => 'SpecialRevisionMove',
-               'Specialpages'              => array( 'UnlistedSpecialPage', 'Specialpages' ),
+               'Specialpages'              => 'SpecialSpecialpages',
                'Userlogout'                => array( 'UnlistedSpecialPage', 'Userlogout' ),
        );
 
index 05cd9cc..25134bd 100644 (file)
  * @file
  * @ingroup SpecialPage
  */
+class SpecialSpecialpages extends UnlistedSpecialPage {
 
-function wfSpecialSpecialpages() {
-       global $wgOut, $wgUser, $wgMessageCache, $wgSortSpecialPages;
+       function __construct() {
+               parent::__construct( 'Specialpages' );
+       }
 
-       $wgMessageCache->loadAllMessages();
+       function execute( $par ) {
+               $this->setHeaders();
+               $this->outputHeader();
 
-       $wgOut->setRobotPolicy( 'noindex,nofollow' );  # Is this really needed?
-       $sk = $wgUser->getSkin();
+               $groups = $this->getPageGroups();
 
-       $pages = SpecialPage::getUsablePages();
+               if ( $groups === false ) {
+                       return;
+               }
 
-       if( count( $pages ) == 0 ) {
-               # Yeah, that was pointless. Thanks for coming.
-               return;
+               $this->outputPageList( $groups );
        }
 
-       /** Put them into a sortable array */
-       $groups = array();
-       foreach ( $pages as $page ) {
-               if ( $page->isListed() ) {
-                       $group = SpecialPage::getGroup( $page );
-                       if( !isset($groups[$group]) ) {
-                               $groups[$group] = array();
+       private function getPageGroups() {
+               global $wgSortSpecialPages;
+
+               $pages = SpecialPage::getUsablePages();
+
+               if( !count( $pages ) ) {
+                       # Yeah, that was pointless. Thanks for coming.
+                       return false;
+               }
+
+               /** Put them into a sortable array */
+               $groups = array();
+               foreach ( $pages as $page ) {
+                       if ( $page->isListed() ) {
+                               $group = SpecialPage::getGroup( $page );
+                               if( !isset( $groups[$group] ) ) {
+                                       $groups[$group] = array();
+                               }
+                               $groups[$group][$page->getDescription()] = array( $page->getTitle(), $page->isRestricted() );
                        }
-                       $groups[$group][$page->getDescription()] = array( $page->getTitle(), $page->isRestricted() );
                }
-       }
 
-       /** Sort */
-       if ( $wgSortSpecialPages ) {
-               foreach( $groups as $group => $sortedPages ) {
-                       ksort( $groups[$group] );
+               /** Sort */
+               if ( $wgSortSpecialPages ) {
+                       foreach( $groups as $group => $sortedPages ) {
+                               ksort( $groups[$group] );
+                       }
                }
-       }
 
-       /** Always move "other" to end */
-       if( array_key_exists('other',$groups) ) {
-               $other = $groups['other'];
-               unset( $groups['other'] );
-               $groups['other'] = $other;
+               /** Always move "other" to end */
+               if( array_key_exists( 'other', $groups ) ) {
+                       $other = $groups['other'];
+                       unset( $groups['other'] );
+                       $groups['other'] = $other;
+               }
+
+               return $groups;
        }
 
-       $includesRestrictedPages = false;
-       /** Now output the HTML */
-       foreach ( $groups as $group => $sortedPages ) {
-               $middle = ceil( count($sortedPages)/2 );
-               $total = count($sortedPages);
-               $count = 0;
-
-               $wgOut->wrapWikiMsg( "<h4 class=\"mw-specialpagesgroup\" id=\"mw-specialpagesgroup-$group\">$1</h4>\n", "specialpages-group-$group" );
-               $wgOut->addHTML( "<table style='width: 100%;' class='mw-specialpages-table'><tr>" );
-               $wgOut->addHTML( "<td width='30%' valign='top'><ul>\n" );
-               foreach( $sortedPages as $desc => $specialpage ) {
-                       list( $title, $restricted ) = $specialpage;
-                       $link = $sk->linkKnown( $title , htmlspecialchars( $desc ) );
-                       if( $restricted ) {
-                               $includesRestrictedPages = true;
-                               $wgOut->addHTML( "<li class='mw-specialpages-page mw-specialpagerestricted'><strong>{$link}</strong></li>\n" );
-                       } else {
-                               $wgOut->addHTML( "<li>{$link}</li>\n" );
-                       }
+       private function outputPageList( $groups ) {
+               global $wgUser, $wgOut;
+
+               $sk = $wgUser->getSkin();
+               $includesRestrictedPages = false;
 
-                       # Split up the larger groups
-                       $count++;
-                       if( $total > 3 && $count == $middle ) {
-                               $wgOut->addHTML( "</ul></td><td width='10%'></td><td width='30%' valign='top'><ul>" );
+               foreach ( $groups as $group => $sortedPages ) {
+                       $middle = ceil( count( $sortedPages )/2 );
+                       $total = count( $sortedPages );
+                       $count = 0;
+
+                       $wgOut->wrapWikiMsg( "<h4 class=\"mw-specialpagesgroup\" id=\"mw-specialpagesgroup-$group\">$1</h4>\n", "specialpages-group-$group" );
+                       $wgOut->addHTML(
+                               Html::openElement( 'table', array( 'style' => 'width:100%;', 'class' => 'mw-specialpages-table' ) ) ."\n" .
+                               Html::openElement( 'tr' ) . "\n" .
+                               Html::openElement( 'td', array( 'style' => 'width:30%;vertical-align:top' ) ) . "\n" .
+                               Html::openElement( 'ul' ) . "\n"
+                       );
+                       foreach( $sortedPages as $desc => $specialpage ) {
+                               list( $title, $restricted ) = $specialpage;
+                               $link = $sk->linkKnown( $title , htmlspecialchars( $desc ) );
+                               if( $restricted ) {
+                                       $includesRestrictedPages = true;
+                                       $wgOut->addHTML( Html::rawElement( 'li', array( 'class' => 'mw-specialpages-page mw-specialpagerestricted' ), Html::rawElement( 'strong', array(), $link ) ) . "\n" );
+                               } else {
+                                       $wgOut->addHTML( Html::rawElement( 'li', array(), $link ) . "\n" );
+                               }
+
+                               # Split up the larger groups
+                               $count++;
+                               if( $total > 3 && $count == $middle ) {
+                                       $wgOut->addHTML(
+                                               Html::closeElement( 'ul' ) . Html::closeElement( 'td' ) .
+                                               Html::element( 'td', array( 'style' => 'width:10%' ), '' ) .
+                                               Html::openElement( 'td', array( 'style' => 'width:30%' ) ) . Html::openElement( 'ul' ) . "\n"
+                                       );
+                               }
                        }
+                       $wgOut->addHTML(
+                               Html::closeElement( 'ul' ) . Html::closeElement( 'td' ) .
+                               Html::element( 'td', array( 'style' => 'width:30%' ), '' ) .
+                               Html::closeElement( 'tr' ) . Html::closeElement( 'table' ) . "\n"
+                       );
                }
-               $wgOut->addHTML( "</ul></td><td width='30%' valign='top'></td></tr></table>\n" );
-       }
 
-       if ( $includesRestrictedPages ) {
-               $wgOut->wrapWikiMsg( "<div class=\"mw-specialpages-notes\">\n$1\n</div>", 'specialpages-note' );
+               if ( $includesRestrictedPages ) {
+                       $wgOut->wrapWikiMsg( "<div class=\"mw-specialpages-notes\">\n$1\n</div>", 'specialpages-note' );
+               }
        }
 }