2021-01-28 11:19:50 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Citizen - A responsive skin developed for the Star Citizen Wiki
|
|
|
|
*
|
|
|
|
* This file is part of Citizen.
|
|
|
|
*
|
|
|
|
* Citizen is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* Citizen is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with Citizen. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @ingroup Skins
|
|
|
|
*/
|
|
|
|
|
2021-01-28 11:21:58 +00:00
|
|
|
declare( strict_types=1 );
|
2021-01-28 11:19:50 +00:00
|
|
|
|
|
|
|
namespace Citizen\Partials;
|
|
|
|
|
|
|
|
use Exception;
|
2021-01-28 20:45:37 +00:00
|
|
|
use ExtensionRegistry;
|
|
|
|
use MWException;
|
2021-01-28 11:19:50 +00:00
|
|
|
use Skin;
|
2021-01-28 20:45:37 +00:00
|
|
|
use SpecialPage;
|
2021-01-28 11:19:50 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Drawer partial of Skin Citizen
|
|
|
|
* Generates the following partials:
|
|
|
|
* - Logo
|
|
|
|
* - Drawer
|
|
|
|
* + Special Pages Link
|
|
|
|
* + Upload Link
|
|
|
|
*/
|
2021-01-28 19:34:46 +00:00
|
|
|
final class Drawer extends Partial {
|
2021-01-28 11:21:58 +00:00
|
|
|
/**
|
|
|
|
* Render the navigation drawer
|
|
|
|
* Based on buildSidebar()
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
* @throws Exception
|
|
|
|
*/
|
|
|
|
public function buildDrawer() {
|
|
|
|
$portals = $this->skin->buildSidebar();
|
|
|
|
$props = [];
|
|
|
|
$languages = null;
|
|
|
|
|
|
|
|
// Render portals
|
|
|
|
foreach ( $portals as $name => $content ) {
|
|
|
|
if ( $content === false ) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Numeric strings gets an integer when set as key, cast back - T73639
|
|
|
|
$name = (string)$name;
|
|
|
|
|
|
|
|
switch ( $name ) {
|
|
|
|
case 'SEARCH':
|
|
|
|
case 'TOOLBOX':
|
|
|
|
break;
|
|
|
|
case 'LANGUAGES':
|
|
|
|
$languages = $this->skin->getLanguages();
|
|
|
|
$portal = $this->skin->getMenuData( 'lang', $content );
|
|
|
|
// The language portal will be added provided either
|
|
|
|
// languages exist or there is a value in html-after-portal
|
|
|
|
// for example to show the add language wikidata link (T252800)
|
|
|
|
if ( count( $content ) || $portal['html-after-portal'] ) {
|
|
|
|
$languages = $portal;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
// Historically some portals have been defined using HTML rather than arrays.
|
|
|
|
// Let's move away from that to a uniform definition.
|
|
|
|
if ( !is_array( $content ) ) {
|
|
|
|
$html = $content;
|
|
|
|
$content = [];
|
|
|
|
wfDeprecated(
|
|
|
|
"`content` field in portal $name must be array."
|
|
|
|
. "Previously it could be a string but this is no longer supported.",
|
|
|
|
'1.35.0'
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
$html = false;
|
|
|
|
}
|
|
|
|
$portal = $this->skin->getMenuData( $name, $content );
|
|
|
|
if ( $html ) {
|
|
|
|
$portal['html-items'] .= $html;
|
|
|
|
}
|
|
|
|
$props[] = $portal;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-29 20:49:01 +00:00
|
|
|
$portalLabel = $this->getConfigValue( 'CitizenPortalAttach' ) ?? 'first';
|
2021-01-28 11:21:58 +00:00
|
|
|
|
2021-01-29 20:49:01 +00:00
|
|
|
$firstPortal = array_shift( $props );
|
|
|
|
|
|
|
|
if ( $portalLabel === 'first' && $firstPortal !== null && isset( $firstPortal['html-items'] ) ) {
|
|
|
|
$this->addToolboxLinksToDrawer( $firstPortal['html-items'] );
|
|
|
|
} else {
|
|
|
|
for ( $i = 0, $portalCount = count( $props ); $i < $portalCount; $i++ ) {
|
|
|
|
if ( isset( $props[$i]['label'] ) && $props[$i]['label'] === $portalLabel ) {
|
|
|
|
$this->addToolboxLinksToDrawer( $props[$i]['html-items'] );
|
|
|
|
break;
|
|
|
|
}
|
2021-01-28 11:21:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-03 20:00:43 +00:00
|
|
|
$portals = [
|
2021-01-28 11:21:58 +00:00
|
|
|
'msg-citizen-drawer-toggle' => $this->skin->msg( 'citizen-drawer-toggle' )->text(),
|
2021-02-03 20:47:32 +00:00
|
|
|
'msg-citizen-drawer-search' => $this->skin->msg( 'citizen-drawer-search' )->text(),
|
2021-01-28 11:21:58 +00:00
|
|
|
'data-portals-first' => $firstPortal,
|
2021-01-29 20:49:01 +00:00
|
|
|
'array-portals-rest' => $props,
|
2021-01-28 11:21:58 +00:00
|
|
|
'data-portals-languages' => $languages,
|
2021-03-22 21:01:08 +00:00
|
|
|
'data-drawer-sitestats' => $this->getSiteStats(),
|
2021-02-03 20:00:43 +00:00
|
|
|
'data-drawer-subsearch' => false,
|
2021-01-28 11:21:58 +00:00
|
|
|
];
|
2021-02-03 20:00:43 +00:00
|
|
|
|
2021-03-22 21:01:08 +00:00
|
|
|
// Drawer subsearch
|
2021-02-03 20:00:43 +00:00
|
|
|
if ( $this->getConfigValue( 'CitizenEnableDrawerSubSearch' ) ) {
|
|
|
|
$portals['data-drawer-subsearch'] = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $portals;
|
2021-01-28 11:21:58 +00:00
|
|
|
}
|
|
|
|
|
2021-03-22 21:01:08 +00:00
|
|
|
/**
|
|
|
|
* Get messages used for site stats in the drawer
|
|
|
|
*
|
|
|
|
* @return array for use in Mustache template.
|
|
|
|
*/
|
|
|
|
private function getSiteStats() {
|
|
|
|
$props = [];
|
|
|
|
|
|
|
|
if ( $this->getConfigValue( 'CitizenEnableDrawerSiteStats' ) ) {
|
|
|
|
$stats = [ 'articles', 'images', 'users', 'edits' ];
|
|
|
|
$items = [];
|
2022-04-23 05:06:07 +00:00
|
|
|
$fmt = new \NumberFormatter('en_US', \NumberFormatter::PADDING_POSITION);
|
|
|
|
$fmt->setAttribute(\NumberFormatter::ROUNDING_MODE, \NumberFormatter::ROUND_DOWN);
|
|
|
|
$fmt->setAttribute(\NumberFormatter::MAX_FRACTION_DIGITS, 1);
|
2021-03-22 21:01:08 +00:00
|
|
|
|
|
|
|
foreach ( $stats as &$stat ) {
|
|
|
|
$items[] = [
|
|
|
|
'id' => $stat,
|
2022-04-23 05:06:07 +00:00
|
|
|
'value' => $fmt->format( call_user_func( 'SiteStats::' . $stat ) ),
|
2021-03-22 21:01:08 +00:00
|
|
|
'label' => $this->skin->msg( "citizen-sitestats-$stat-label" )->text(),
|
|
|
|
];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$props['array-drawer-sitestats-item'] = $items;
|
|
|
|
return $props;
|
|
|
|
}
|
|
|
|
|
2021-01-28 11:21:58 +00:00
|
|
|
/**
|
|
|
|
* Add a link to special pages and the upload form to the first portal in the drawer
|
|
|
|
*
|
|
|
|
* @param string &$htmlItems
|
|
|
|
*
|
|
|
|
* @return void
|
2021-01-28 20:45:37 +00:00
|
|
|
* @throws MWException
|
2021-01-28 11:21:58 +00:00
|
|
|
*/
|
|
|
|
private function addToolboxLinksToDrawer( &$htmlItems ) {
|
|
|
|
// First add a link to special pages
|
|
|
|
$htmlItems .= $this->skin->makeListItem( 'specialpages', [
|
2021-01-28 19:53:07 +00:00
|
|
|
'href' => Skin::makeSpecialUrl( 'Specialpages' ),
|
2021-01-28 11:21:58 +00:00
|
|
|
'id' => 't-specialpages'
|
|
|
|
] );
|
|
|
|
|
2021-01-28 20:45:37 +00:00
|
|
|
$uploadHref = Skin::makeSpecialUrl( 'Upload' );
|
|
|
|
|
|
|
|
if ( ExtensionRegistry::getInstance()->isLoaded( 'Upload Wizard' ) ) {
|
|
|
|
$uploadHref = SpecialPage::getTitleFor( 'UploadWizard' )->getLocalURL();
|
|
|
|
}
|
|
|
|
|
2021-01-28 11:21:58 +00:00
|
|
|
// Then add a link to the upload form
|
|
|
|
$htmlItems .= $this->skin->makeListItem( 'upload', [
|
2021-01-28 20:45:37 +00:00
|
|
|
'href' => $uploadHref,
|
2021-01-28 11:21:58 +00:00
|
|
|
'id' => 't-upload'
|
|
|
|
] );
|
|
|
|
}
|
2021-01-28 11:19:50 +00:00
|
|
|
}
|