mediawiki-skins-MinervaNeue/includes/LanguagesHelper.php
Piotr Miazga d7f60a26db Extract language/variants check to a service
The $hasLangauges and $hasVariants checks were used in couple places,
which lead to the same code used in many places.
Following the DRY rule, let's implement a Service that can do that
check, and use that service everywhere in code.

Bug: T224735
Change-Id: I46d58758356e870c408a74b2c087a42d6ad0ddea
2019-07-16 19:53:57 +00:00

52 lines
1.5 KiB
PHP

<?php
/**
* This program 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 2 of the License, or
* (at your option) any later version.
*
* This program 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 this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
* http://www.gnu.org/copyleft/gpl.html
*
* @file
*/
namespace MediaWiki\Minerva;
use OutputPage;
use Title;
/**
* Helper class to encapsulate logic responsible for checking languages and variants for given title
* @package MediaWiki\Minerva
*/
class LanguagesHelper {
/**
* @var bool
*/
private $hasLanguages;
/**
* @param OutputPage $out Output page to fetch language links
*/
public function __construct( OutputPage $out ) {
$this->hasLanguages = !empty( $out->getLanguageLinks() );
}
/**
* Whether the Title is also available in other languages or variants
* @param Title $title
* @return bool
*/
public function doesTitleHasLanguagesOrVariants( Title $title ) {
return $this->hasLanguages || $title->getPageLanguage()->hasVariants();
}
}