Merge "Fix display of categories in the sidebar"

isekai
jenkins-bot 7 years ago committed by Gerrit Code Review
commit 279ded1b51

@ -702,95 +702,49 @@ class TimelessTemplate extends BaseTemplate {
/** /**
* Categories for the sidebar * Categories for the sidebar
* *
* Assemble an array of categories, regardless of view mode. Just using Skin or * Assemble an array of categories. This doesn't show any categories for the
* OutputPage functions doesn't respect view modes (preview, history, whatever) * action=history view, but that behaviour is consistent with other skins.
* But why? I have no idea what the purpose of this is.
* *
* @return string html * @return string html
*/ */
protected function getCategories() { protected function getCategories() {
global $wgContLang;
$skin = $this->getSkin(); $skin = $this->getSkin();
$title = $skin->getTitle(); $catList = '';
$catList = false;
$html = ''; $html = '';
// Get list from outputpage if in preview; otherwise get list from title $allCats = $skin->getOutput()->getCategoryLinks();
if ( in_array( $skin->getRequest()->getVal( 'action' ), [ 'submit', 'edit' ] ) ) { if ( !empty( $allCats ) ) {
$allCats = []; if ( !empty( $allCats['normal'] ) ) {
// Can't just use getCategoryLinks because there's no equivalent for Title $catHeader = 'categories';
$allCats2 = $skin->getOutput()->getCategories(); $catList .= $this->getCatList(
foreach ( $allCats2 as $displayName ) { $allCats['normal'],
$catTitle = Title::makeTitleSafe( NS_CATEGORY, $displayName ); 'normal-catlinks',
$allCats[] = $catTitle->getDBkey(); 'mw-normal-catlinks',
} 'categories'
} else { );
// This is probably to trim out some excessive stuff. Unless I was just high on cough syrup.
$allCats = array_keys( $title->getParentCategories() );
$len = strlen( $wgContLang->getNsText( NS_CATEGORY ) . ':' );
foreach ( $allCats as $i => $catName ) {
$allCats[$i] = substr( $catName, $len );
}
}
if ( $allCats !== [] ) {
$dbr = wfGetDB( DB_REPLICA );
$res = $dbr->select(
[ 'page', 'page_props' ],
[ 'page_id', 'page_title' ],
[
'page_title' => $allCats,
'page_namespace' => NS_CATEGORY,
'pp_propname' => 'hiddencat'
],
__METHOD__,
[],
[ 'page_props' => [ 'JOIN', 'pp_page = page_id' ] ]
);
$hiddenCats = [];
foreach ( $res as $row ) {
$hiddenCats[] = $row->page_title;
}
$normalCats = array_diff( $allCats, $hiddenCats );
$normalCount = count( $normalCats );
$hiddenCount = count( $hiddenCats );
$count = $normalCount;
// Mostly consistent with how Skin does it.
// Doesn't have the classes. Either way can't be good for caching.
if (
$skin->getUser()->getBoolOption( 'showhiddencats' ) ||
$title->getNamespace() == NS_CATEGORY
) {
$count += $hiddenCount;
} else { } else {
/* We don't care if there are hidden ones. */ $catHeader = 'hidden-categories';
$hiddenCount = 0;
} }
// Assemble the html... if ( isset( $allCats['hidden'] ) ) {
if ( $count ) { $hiddenCatClass = [ 'mw-hidden-catlinks' ];
if ( $normalCount ) { if ( $skin->getUser()->getBoolOption( 'showhiddencats' ) ) {
$catHeader = 'categories'; $hiddenCatClass[] = 'mw-hidden-cats-user-shown';
} elseif ( $skin->getTitle()->getNamespace() == NS_CATEGORY ) {
$hiddenCatClass[] = 'mw-hidden-cats-ns-shown';
} else { } else {
$catHeader = 'hidden-categories'; $hiddenCatClass[] = 'mw-hidden-cats-hidden';
}
$catList = '';
if ( $normalCount ) {
$catList .= $this->getCatList( $normalCats, 'catlist-normal', 'categories' );
}
if ( $hiddenCount ) {
$catList .= $this->getCatList(
$hiddenCats,
'catlist-hidden',
[ 'hidden-categories', $hiddenCount ]
);
} }
$catList .= $this->getCatList(
$allCats['hidden'],
'hidden-catlinks',
$hiddenCatClass,
[ 'hidden-categories', count( $allCats['hidden'] ) ]
);
} }
} }
if ( $catList ) {
if ( $catList !== '' ) {
$html = $this->getSidebarChunk( 'catlinks-sidebar', $catHeader, $catList ); $html = $this->getSidebarChunk( 'catlinks-sidebar', $catHeader, $catList );
} }
@ -802,27 +756,28 @@ class TimelessTemplate extends BaseTemplate {
* *
* @param array $list * @param array $list
* @param string $id * @param string $id
* @param string|array $class
* @param string|array $message i18n message name or an array of [ message name, params ] * @param string|array $message i18n message name or an array of [ message name, params ]
* *
* @return string html * @return string html
*/ */
protected function getCatList( $list, $id, $message ) { protected function getCatList( $list, $id, $class, $message ) {
$html = ''; $html = Html::openElement( 'div', [ 'id' => "sidebar-{$id}", 'class' => $class ] );
$categories = []; $makeLinkItem = function ( $linkHtml ) {
// Generate portlet content return Html::rawElement( 'li', [], $linkHtml );
foreach ( $list as $category ) { };
$title = Title::makeTitleSafe( NS_CATEGORY, $category );
if ( !$title ) {
continue;
}
$categories[ htmlspecialchars( $category ) ] = [ 'links' => [ 0 => [
'href' => $title->getLinkURL(),
'text' => $title->getText()
] ] ];
}
$html .= $this->getPortlet( $id, $categories, $message ); $categoryItems = array_map( $makeLinkItem, $list );
$categoriesHtml = Html::rawElement( 'ul',
[],
implode( '', $categoryItems )
);
$html .= $this->getPortlet( $id, $categoriesHtml, $message );
$html .= Html::closeElement( 'div' );
return $html; return $html;
} }

Loading…
Cancel
Save