mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Gadgets
synced 2024-11-30 18:14:21 +00:00
c807a86d0f
Implicitly marking parameter $... as nullable is deprecated in PHP 8.4. The explicit nullable type must be used instead. Bug: T376276 Change-Id: Ic2deb698668bb6f5833a3c6b6b8cbc6be6e2cf09
146 lines
3.5 KiB
PHP
146 lines
3.5 KiB
PHP
<?php
|
|
|
|
namespace MediaWiki\Extension\Gadgets;
|
|
|
|
use InvalidArgumentException;
|
|
use MediaWiki\MediaWikiServices;
|
|
use MediaWiki\ResourceLoader as RL;
|
|
|
|
/**
|
|
* Class representing a list of resources for one gadget, basically a wrapper
|
|
* around the Gadget class.
|
|
*/
|
|
class GadgetResourceLoaderModule extends RL\WikiModule {
|
|
/**
|
|
* @var string
|
|
*/
|
|
private $id;
|
|
|
|
/**
|
|
* @var Gadget
|
|
*/
|
|
private $gadget;
|
|
|
|
/**
|
|
* @param array $options
|
|
*/
|
|
public function __construct( array $options ) {
|
|
$this->id = $options['id'];
|
|
}
|
|
|
|
/**
|
|
* @return Gadget instance this module is about
|
|
*/
|
|
private function getGadget() {
|
|
if ( !$this->gadget ) {
|
|
/** @var GadgetRepo $repo */
|
|
$repo = MediaWikiServices::getInstance()->getService( 'GadgetsRepo' );
|
|
try {
|
|
$this->gadget = $repo->getGadget( $this->id );
|
|
} catch ( InvalidArgumentException $e ) {
|
|
// Fallback to a placeholder object...
|
|
$this->gadget = Gadget::newEmptyGadget( $this->id );
|
|
}
|
|
}
|
|
|
|
return $this->gadget;
|
|
}
|
|
|
|
/**
|
|
* Overrides the function from RL\WikiModule class
|
|
* @param RL\Context $context
|
|
* @return array
|
|
*/
|
|
protected function getPages( RL\Context $context ) {
|
|
$gadget = $this->getGadget();
|
|
$pages = [];
|
|
|
|
foreach ( $gadget->getStyles() as $style ) {
|
|
$pages[$style] = [ 'type' => 'style' ];
|
|
}
|
|
|
|
if ( $gadget->supportsResourceLoader() ) {
|
|
foreach ( $gadget->getScripts() as $script ) {
|
|
$pages[$script] = [ 'type' => 'script' ];
|
|
}
|
|
if ( $gadget->isPackaged() ) {
|
|
foreach ( $gadget->getJSONs() as $json ) {
|
|
$pages[$json] = [ 'type' => 'data' ];
|
|
}
|
|
}
|
|
}
|
|
|
|
return $pages;
|
|
}
|
|
|
|
/**
|
|
* Overrides RL\WikiModule::getRequireKey()
|
|
* @param string $titleText
|
|
* @return string
|
|
*/
|
|
public function getRequireKey( $titleText ): string {
|
|
/** @var GadgetRepo $repo */
|
|
$repo = MediaWikiServices::getInstance()->getService( 'GadgetsRepo' );
|
|
return $repo->titleWithoutPrefix( $titleText, $this->id );
|
|
}
|
|
|
|
/**
|
|
* @param string $fileName
|
|
* @param string $contents
|
|
* @return string
|
|
*/
|
|
protected function validateScriptFile( $fileName, $contents ) {
|
|
// Temporary solution to support gadgets in ES6 by disabling validation
|
|
// for them and putting them in a separate resource group to avoid a syntax error in them
|
|
// from corrupting core/extension-loaded scripts or other non-ES6 gadgets.
|
|
if ( $this->requiresES6() ) {
|
|
return $contents;
|
|
}
|
|
return parent::validateScriptFile( $fileName, $contents );
|
|
}
|
|
|
|
/**
|
|
* Overrides RL\WikiModule::isPackaged()
|
|
* Returns whether this gadget is packaged.
|
|
* @return bool
|
|
*/
|
|
public function isPackaged(): bool {
|
|
return $this->getGadget()->isPackaged();
|
|
}
|
|
|
|
/**
|
|
* Overrides RL\Module::getDependencies()
|
|
* @param RL\Context|null $context
|
|
* @return string[] Names of resources this module depends on
|
|
*/
|
|
public function getDependencies( ?RL\Context $context = null ) {
|
|
return $this->getGadget()->getDependencies();
|
|
}
|
|
|
|
/**
|
|
* Overrides RL\WikiModule::getType()
|
|
* @return string RL\Module::LOAD_STYLES or RL\Module::LOAD_GENERAL
|
|
*/
|
|
public function getType() {
|
|
return $this->getGadget()->getType() === 'styles'
|
|
? RL\Module::LOAD_STYLES
|
|
: RL\Module::LOAD_GENERAL;
|
|
}
|
|
|
|
public function getMessages() {
|
|
return $this->getGadget()->getMessages();
|
|
}
|
|
|
|
public function getSkins(): ?array {
|
|
return $this->getGadget()->getRequiredSkins() ?: null;
|
|
}
|
|
|
|
public function requiresES6(): bool {
|
|
return $this->getGadget()->requiresES6();
|
|
}
|
|
|
|
public function getGroup() {
|
|
return $this->requiresES6() ? 'es6-gadget' : self::GROUP_SITE;
|
|
}
|
|
}
|