mediawiki-extensions-Catego.../CategoryPageSubclass.php

141 lines
3.8 KiB
PHP
Raw Normal View History

<?php
class CategoryTreeCategoryPage extends CategoryPage {
function closeShowCategory() {
global $wgOut, $wgRequest;
$from = $wgRequest->getVal( 'from' );
$until = $wgRequest->getVal( 'until' );
$viewer = new CategoryTreeCategoryViewer( $this->mTitle, $from, $until );
$wgOut->addHTML( $viewer->getHTML() );
}
}
class CategoryTreeCategoryViewer extends CategoryViewer {
var $child_titles;
2008-02-04 09:22:12 +00:00
function getCategoryTree() {
global $wgOut, $wgCategoryTreeCategoryPageOptions;
if ( ! isset($this->categorytree) ) {
CategoryTree::setHeaders( $wgOut );
$this->categorytree = new CategoryTree( $wgCategoryTreeCategoryPageOptions );
}
return $this->categorytree;
}
/**
* Add a subcategory to the internal lists
*/
function addSubcategory( $title, $sortkey, $pageLength ) {
global $wgContLang, $wgOut, $wgRequest;
2008-02-04 09:22:12 +00:00
if ( $wgRequest->getCheck( 'notree' ) ) {
return parent::addSubcategory( $title, $sortkey, $pageLength );
}
2008-02-04 09:22:12 +00:00
if ( ! $GLOBALS['wgCategoryTreeUnifiedView'] ) {
$this->child_titles[] = $title;
return parent::addSubcategory( $title, $sortkey, $pageLength );
}
2008-02-04 09:22:12 +00:00
$tree = $this->getCategoryTree();
2008-02-04 09:22:12 +00:00
$this->children[] = $tree->renderNode( $title );
$this->children_start_char[] = $this->getSubcategorySortChar( $title, $sortkey );
}
2008-02-04 09:22:12 +00:00
function getSubcategorySection() {
global $wgOut, $wgRequest, $wgCookiePrefix;
if ( $wgRequest->getCheck( 'notree' ) ) {
return parent::getSubcategorySection();
}
2008-02-04 09:22:12 +00:00
if ( $GLOBALS['wgCategoryTreeUnifiedView'] ) {
return parent::getSubcategorySection();
}
2008-02-04 09:22:12 +00:00
if( count( $this->children ) == 0 ) {
return '';
}
2008-02-04 09:22:12 +00:00
$r = '<h2>' . wfMsg( 'subcategories' ) . "</h2>\n" .
wfMsgExt( 'subcategorycount', array( 'parse' ), count( $this->children) );
# Use a cookie to save the user's last selection, so that AJAX doesn't
# keep coming back to haunt them.
#
2008-02-04 09:22:12 +00:00
# FIXME: This doesn't work very well with IMS handling in
# OutputPage::checkLastModified, because when the cookie changes, the
# category pages are not, at present, invalidated.
$cookieName = $wgCookiePrefix.'ShowSubcatAs';
$cookieVal = @$_COOKIE[$cookieName];
2006-09-01 17:33:14 +00:00
$reqShowAs = $wgRequest->getVal( 'showas' );
if ( $reqShowAs == 'list' ) {
$showAs = 'list';
2006-09-01 17:33:14 +00:00
} elseif ( $reqShowAs == 'tree' ) {
$showAs = 'tree';
} elseif ( $cookieVal == 'list' || $cookieVal == 'tree' ) {
$showAs = $cookieVal;
} else {
$showAs = 'tree';
}
2006-09-01 17:33:14 +00:00
if ( !is_null( $reqShowAs ) ) {
global $wgCookieExpiration, $wgCookiePath, $wgCookieDomain, $wgCookieSecure;
$exp = time() + $wgCookieExpiration;
2006-09-01 17:33:14 +00:00
setcookie( $cookieName, $showAs, $exp, $wgCookiePath, $wgCookieDomain, $wgCookieSecure );
}
2008-02-04 09:22:12 +00:00
if ( $showAs == 'tree' && count( $this->children ) > $this->limit ) {
2008-02-04 09:22:12 +00:00
# Tree doesn't page properly
$showAs = 'list';
$r .= self::msg( 'too-many-subcats' );
} else {
$sk = $this->getSkin();
$r .= '<p>' .
$this->makeShowAsLink( 'tree', $showAs ) .
' | ' .
$this->makeShowAsLink( 'list', $showAs ) .
'</p>';
}
2008-02-04 09:22:12 +00:00
if ( $showAs == 'list' ) {
$r .= $this->formatList( $this->children, $this->children_start_char );
} else {
$ct = getCategoryTree();
foreach ( $this->child_titles as $title ) {
$r .= $ct->renderNode( $title );
}
}
return $r;
}
2008-02-04 09:22:12 +00:00
function makeShowAsLink( $targetValue, $currentValue ) {
$msg = htmlspecialchars( CategoryTree::msg( "show-$targetValue" ) );
if ( $targetValue == $currentValue ) {
return "<strong>$msg</strong>";
} else {
return $this->getSkin()->makeKnownLinkObj( $this->title, $msg, "showas=$targetValue" );
}
}
function clearCategoryState() {
$this->child_titles = array();
parent::clearCategoryState();
}
2008-02-04 09:22:12 +00:00
function finaliseCategoryState() {
if( $this->flip ) {
$this->child_titles = array_reverse( $this->child_titles );
}
parent::finaliseCategoryState();
}
}