mirror of
https://gerrit.wikimedia.org/r/mediawiki/skins/Vector.git
synced 2024-11-24 23:55:53 +00:00
8db112ddb3
- Fixes TOC button being transparent (https://jmp.sh/jbuivqlM). FYI the fixed width toggle button has the same issue. - Add replace `html-vector-heading-icon` with Icon.mustache Bug: T320453 Depends-on: I9a990ea8de63fb336391bea11b4503d447fb9d4f Change-Id: I39397f8e98f79a2fdde9a8d785690133ea5a2619
86 lines
2.8 KiB
PHP
86 lines
2.8 KiB
PHP
<?php
|
|
namespace MediaWiki\Skins\Vector\Components;
|
|
|
|
use Title;
|
|
|
|
/**
|
|
* VectorComponentLanguageButton component
|
|
*/
|
|
class VectorComponentLanguageDropdown implements VectorComponent {
|
|
private const CLASS_PROGRESSIVE = 'mw-ui-progressive';
|
|
/** @var string */
|
|
private $label;
|
|
/** @var string */
|
|
private $ariaLabel;
|
|
/** @var string */
|
|
private $class;
|
|
/** @var int */
|
|
private $numLanguages;
|
|
/** @var array */
|
|
private $menuContentsData;
|
|
/** @var Title|null */
|
|
private $title;
|
|
|
|
/**
|
|
* @param string $label human readable
|
|
* @param string $ariaLabel label for accessibility
|
|
* @param string $class of the dropdown component
|
|
* @param int $numLanguages
|
|
* @param string $itemHTML the HTML of the list e.g. `<li>...</li>`
|
|
* @param string $beforePortlet no known usages. Perhaps can be removed in future
|
|
* @param string $afterPortlet used by Extension:ULS
|
|
* @param Title|null $title
|
|
*/
|
|
public function __construct(
|
|
string $label, string $ariaLabel, string $class, int $numLanguages,
|
|
// @todo: replace with >MenuContents class.
|
|
string $itemHTML, string $beforePortlet = '', string $afterPortlet = '', $title = null
|
|
) {
|
|
$this->label = $label;
|
|
$this->ariaLabel = $ariaLabel;
|
|
$this->class = $class;
|
|
$this->numLanguages = $numLanguages;
|
|
$this->menuContentsData = [
|
|
'html-items' => $itemHTML,
|
|
'html-before-portal' => $beforePortlet,
|
|
'html-after-portal' => $afterPortlet,
|
|
];
|
|
$this->title = $title;
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function getTemplateData(): array {
|
|
$title = $this->title;
|
|
$isSubjectPage = $title && $title->exists() && !$title->isTalkPage();
|
|
// If page doesn't exist or if it's in a talk namespace, we should
|
|
// display a less prominent "language" button, without a label, and
|
|
// quiet instead of progressive. For this reason some default values
|
|
// should be updated for this case. (T316559)
|
|
if ( !$isSubjectPage ) {
|
|
$icon = 'language';
|
|
$label = '';
|
|
$headingClass = 'mw-ui-button mw-ui-quiet mw-portlet-lang-heading-empty';
|
|
$checkboxClass = 'mw-interlanguage-selector-empty';
|
|
} else {
|
|
$icon = 'language-progressive';
|
|
$label = $this->label;
|
|
$headingClass = 'mw-ui-button mw-ui-quiet '
|
|
. self::CLASS_PROGRESSIVE . ' mw-portlet-lang-heading-' . strval( $this->numLanguages );
|
|
$checkboxClass = 'mw-interlanguage-selector';
|
|
}
|
|
$dropdown = new VectorComponentDropdown( 'p-lang-btn', $label, $this->class );
|
|
$dropdownData = $dropdown->getTemplateData();
|
|
// override default heading class.
|
|
$dropdownData['heading-class'] = $headingClass;
|
|
// ext.uls.interface attaches click handler to this selector.
|
|
$dropdownData['checkbox-class'] = $checkboxClass;
|
|
$dropdownData['icon'] = $icon;
|
|
$dropdownData['aria-label'] = $this->ariaLabel;
|
|
$dropdownData['is-language-selector-empty'] = !$isSubjectPage;
|
|
|
|
return $dropdownData + $this->menuContentsData;
|
|
}
|
|
}
|