.
*
* @file
* @ingroup Skins
*/
declare( strict_types=1 );
namespace MediaWiki\Skins\Citizen\Partials;
use MediaWiki\MediaWikiServices;
use Skin;
use User;
/**
* Header partial of Skin Citizen
* Generates the following partials:
* - User Menu
* - Search
*/
final class Header extends Partial {
/**
* Decorate search box template data
*
* @param array $searchBoxData original data-search-box
* @return array
*/
public function decorateSearchBoxData( $searchBoxData ): array {
return $searchBoxData += [
'msg-citizen-search-toggle-shortcut' => '[/]',
'html-random-href' => Skin::makeSpecialUrl( 'Randompage' ),
];
}
/**
* Get the user info template data for user menu
*
* TODO: Consider dropping Menu.mustache since the DOM doesn't make much sense
*
* @param $userPageData data-portlets.data-user-page
* @return array
*/
public function getUserInfoData( $userPageData ): array {
$isRegistered = $this->user->isRegistered();
$html = $this->getUserPageHTML( $isRegistered, $userPageData );
if ( $isRegistered ) {
$html .= $this->getUserGroupsHTML();
$html .= $this->getUserContributionsHTML();
}
return [
'id' => 'p-user-info',
'html-items' => $html,
];
}
/**
* Get the user page HTML
*
* @param bool $isRegistered
* @param array $userPageData data-portlets.data-user-page
* @return string
*/
private function getUserPageHTML( $isRegistered, $userPageData ): ?string {
if ( $isRegistered ) {
$realname = $this->user->getRealName();
if ( !empty( $realname ) ) {
$username = $this->user->getName();
$innerHtml = <<$realname
$username
HTML;
// Dirty but it works
$html = str_replace(
">" . $username . "<",
">" . $innerHtml . "<",
$userPageData['html-items']
);
} else {
$html = $userPageData['html-items'];
}
} else {
// There must be a cleaner way to do this
$msg = $this->skin->msg( 'notloggedin' )->text();
$tooltip = $this->skin->msg( 'tooltip-pt-anonuserpage' )->text();
$html = <<
$msg
HTML;
}
return $html;
}
/**
* Get the user groups HTML
*
* @return string|null
*/
private function getUserGroupsHTML(): ?string {
// This does not return implicit groups
$groups = MediaWikiServices::getInstance()->getUserGroupManager()->getUserGroups( $this->user );
if ( empty( $groups ) ) {
return null;
}
$html = '';
$msgName = 'group-%s-member';
// There must be a cleaner way
foreach ( $groups as $group ) {
$id = sprintf( $msgName, $group );
$msg = $this->skin->msg( $id )->text();
$title = $this->title->newFromText(
$msg,
NS_PROJECT
);
if ( $msg ) {
// Member names are in lowercase
$msg = ucfirst( $msg );
}
if ( $title ) {
$href = $title->getLinkURL();
$html .= <<< HTML
$msg
HTML;
}
}
$html = sprintf( '', $html );
return $html;
}
/**
* Get the user contributions HTML
*
* @return string|null
*/
private function getUserContributionsHTML(): ?string {
// Return user edits
$edits = MediaWikiServices::getInstance()->getUserEditTracker()->getUserEditCount( $this->user );
if ( empty( $edits ) ) {
return null;
}
$editsText = $this->skin->msg( 'usereditcount' )
->numParams( sprintf( '%s', number_format( $edits, 0 ) ) );
// There must be a cleaner way
$html = '' . $editsText . '';
return $html;
}
}