X-Git-Url: https://scripts.mit.edu/gitweb/autoinstallsdev/mediawiki.git/blobdiff_plain/b311bee4b7600bfbf2500bfae0f994719c620a8e..036b27389fdc19af6784c101fb7e56319de98b4c:/includes/specials/SpecialSpecialpages.php diff --git a/includes/specials/SpecialSpecialpages.php b/includes/specials/SpecialSpecialpages.php index 4959f107..19bc6b00 100644 --- a/includes/specials/SpecialSpecialpages.php +++ b/includes/specials/SpecialSpecialpages.php @@ -1,83 +1,138 @@ loadAllMessages(); + function execute( $par ) { + global $wgOut; + $this->setHeaders(); + $this->outputHeader(); + $wgOut->allowClickjacking(); - $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( "

$1

\n", "specialpages-group-$group" ); - $wgOut->addHTML( "" ); - $wgOut->addHTML( "
    \n" ); - foreach( $sortedPages as $desc => $specialpage ) { - list( $title, $restricted ) = $specialpage; - $link = $sk->makeKnownLinkObj( $title , htmlspecialchars( $desc ) ); - if( $restricted ) { - $includesRestrictedPages = true; - $wgOut->addHTML( "
  • {$link}
  • \n" ); - } else { - $wgOut->addHTML( "
  • {$link}
  • \n" ); - } + private function outputPageList( $groups ) { + global $wgUser, $wgOut; - # Split up the larger groups - $count++; - if( $total > 3 && $count == $middle ) { - $wgOut->addHTML( "
    " ); + $sk = $wgUser->getSkin(); + $includesRestrictedPages = false; + + foreach ( $groups as $group => $sortedPages ) { + $middle = ceil( count( $sortedPages )/2 ); + $total = count( $sortedPages ); + $count = 0; + + $wgOut->wrapWikiMsg( "

    $1

    \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( "
\n" ); - } - if ( $includesRestrictedPages ) { - $wgOut->wrapWikiMsg( "
\n$1\n
", 'specialpages-note' ); + if ( $includesRestrictedPages ) { + $wgOut->wrapWikiMsg( "
\n$1\n
", 'specialpages-note' ); + } } }