|
|
@ -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(
|
|
|
|
$catList .= $this->getCatList(
|
|
|
|
$hiddenCats,
|
|
|
|
$allCats['hidden'],
|
|
|
|
'catlist-hidden',
|
|
|
|
'hidden-catlinks',
|
|
|
|
[ 'hidden-categories', $hiddenCount ]
|
|
|
|
$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 ) {
|
|
|
|
$categoryItems = array_map( $makeLinkItem, $list );
|
|
|
|
continue;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
$categories[ htmlspecialchars( $category ) ] = [ 'links' => [ 0 => [
|
|
|
|
|
|
|
|
'href' => $title->getLinkURL(),
|
|
|
|
|
|
|
|
'text' => $title->getText()
|
|
|
|
|
|
|
|
] ] ];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$html .= $this->getPortlet( $id, $categories, $message );
|
|
|
|
$categoriesHtml = Html::rawElement( 'ul',
|
|
|
|
|
|
|
|
[],
|
|
|
|
|
|
|
|
implode( '', $categoryItems )
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$html .= $this->getPortlet( $id, $categoriesHtml, $message );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$html .= Html::closeElement( 'div' );
|
|
|
|
|
|
|
|
|
|
|
|
return $html;
|
|
|
|
return $html;
|
|
|
|
}
|
|
|
|
}
|
|
|
|