mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Popups
synced 2024-11-23 23:24:39 +00:00
1ce8b38f9f
The function PopupsContext::getLogger is not needed anymore. Change-Id: Ib538372f1480d282857d827fedbe0ebe9abc0685
293 lines
9.6 KiB
PHP
293 lines
9.6 KiB
PHP
<?php
|
|
/*
|
|
* This file is part of the MediaWiki extension Popups.
|
|
*
|
|
* Popups 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.
|
|
*
|
|
* Popups 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 Popups. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* @file
|
|
* @ingroup extensions
|
|
*/
|
|
namespace Popups;
|
|
|
|
use ExtensionRegistry;
|
|
use MediaWiki\Auth\Hook\LocalUserCreatedHook;
|
|
use MediaWiki\Config\Config;
|
|
use MediaWiki\Hook\BeforePageDisplayHook;
|
|
use MediaWiki\Hook\MakeGlobalVariablesScriptHook;
|
|
use MediaWiki\MediaWikiServices;
|
|
use MediaWiki\Output\OutputPage;
|
|
use MediaWiki\Preferences\Hook\GetPreferencesHook;
|
|
use MediaWiki\ResourceLoader\Hook\ResourceLoaderGetConfigVarsHook;
|
|
use MediaWiki\User\Hook\UserGetDefaultOptionsHook;
|
|
use MediaWiki\User\Options\UserOptionsManager;
|
|
use MediaWiki\User\User;
|
|
use Psr\Log\LoggerInterface;
|
|
use Skin;
|
|
|
|
/**
|
|
* Hooks definitions for Popups extension
|
|
*
|
|
* @package Popups
|
|
*/
|
|
class PopupsHooks implements
|
|
GetPreferencesHook,
|
|
BeforePageDisplayHook,
|
|
ResourceLoaderGetConfigVarsHook,
|
|
MakeGlobalVariablesScriptHook,
|
|
UserGetDefaultOptionsHook,
|
|
LocalUserCreatedHook
|
|
{
|
|
|
|
private const PREVIEWS_PREFERENCES_SECTION = 'rendering/reading';
|
|
|
|
/** @var Config */
|
|
private $config;
|
|
|
|
/** @var PopupsContext */
|
|
private $popupsContext;
|
|
|
|
/** @var LoggerInterface */
|
|
private $logger;
|
|
|
|
/** @var UserOptionsManager */
|
|
private $userOptionsManager;
|
|
|
|
/**
|
|
* @param Config $config
|
|
* @param PopupsContext $popupsContext
|
|
* @param LoggerInterface $logger
|
|
* @param UserOptionsManager $userOptionsManager
|
|
*/
|
|
public function __construct(
|
|
Config $config,
|
|
PopupsContext $popupsContext,
|
|
LoggerInterface $logger,
|
|
UserOptionsManager $userOptionsManager
|
|
) {
|
|
$this->config = $config;
|
|
$this->popupsContext = $popupsContext;
|
|
$this->logger = $logger;
|
|
$this->userOptionsManager = $userOptionsManager;
|
|
}
|
|
|
|
/**
|
|
* Get custom Popups types registered by extensions
|
|
* @return array
|
|
*/
|
|
public static function getCustomPopupTypes(): array {
|
|
$rl = MediaWikiServices::getInstance()->getService( 'ResourceLoader' );
|
|
// FIXME: If the module ext.cite.referencePreviews does not exist register reference previews.
|
|
// This code can be removed once T355194 is complete.
|
|
$others = $rl->getModule( 'ext.cite.referencePreviews' ) ?
|
|
[] : [ 'ext.popups.referencePreviews' ];
|
|
|
|
return array_merge( ExtensionRegistry::getInstance()->getAttribute(
|
|
'PopupsPluginModules'
|
|
), $others );
|
|
}
|
|
|
|
/**
|
|
* Add options to user Preferences page
|
|
*
|
|
* @param User $user User whose preferences are being modified
|
|
* @param array[] &$prefs Preferences description array, to be fed to a HTMLForm object
|
|
*/
|
|
public function onGetPreferences( $user, &$prefs ) {
|
|
if ( !$this->popupsContext->showPreviewsOptInOnPreferencesPage() ) {
|
|
return;
|
|
}
|
|
|
|
$skinPosition = array_search( 'skin', array_keys( $prefs ) );
|
|
$readingOptions = self::getPagePreviewPrefToggle( $user, $this->popupsContext );
|
|
|
|
if ( $this->config->get( 'PopupsReferencePreviews' ) ) {
|
|
$readingOptions = array_merge(
|
|
$readingOptions,
|
|
self::getReferencePreviewPrefToggle( $user, $this->popupsContext )
|
|
);
|
|
}
|
|
|
|
if ( $skinPosition !== false ) {
|
|
$injectIntoIndex = $skinPosition + 1;
|
|
$prefs = array_slice( $prefs, 0, $injectIntoIndex, true )
|
|
+ $readingOptions
|
|
+ array_slice( $prefs, $injectIntoIndex, null, true );
|
|
} else {
|
|
$prefs += $readingOptions;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get Page Preview option
|
|
*
|
|
* @param User $user User whose preferences are being modified
|
|
* @param PopupsContext $context
|
|
* @return array[]
|
|
*/
|
|
private static function getPagePreviewPrefToggle( User $user, PopupsContext $context ) {
|
|
$option = [
|
|
'type' => 'toggle',
|
|
'label-message' => 'popups-prefs-optin',
|
|
'help-message' => 'popups-prefs-conflicting-gadgets-info',
|
|
'section' => self::PREVIEWS_PREFERENCES_SECTION
|
|
];
|
|
|
|
if ( $context->conflictsWithNavPopupsGadget( $user ) ) {
|
|
$option[ 'disabled' ] = true;
|
|
$option[ 'help-message' ] = [ 'popups-prefs-disable-nav-gadgets-info',
|
|
'Special:Preferences#mw-prefsection-gadgets' ];
|
|
}
|
|
|
|
return [
|
|
PopupsContext::PREVIEWS_OPTIN_PREFERENCE_NAME => $option
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Get Reference Preview option
|
|
*
|
|
* @param User $user User whose preferences are being modified
|
|
* @param PopupsContext $context
|
|
* @return array[]
|
|
*/
|
|
private static function getReferencePreviewPrefToggle( User $user, PopupsContext $context ) {
|
|
$option = [
|
|
'type' => 'toggle',
|
|
'label-message' => 'popups-refpreview-user-preference-label',
|
|
'help-message' => 'popups-prefs-conflicting-gadgets-info',
|
|
'section' => self::PREVIEWS_PREFERENCES_SECTION
|
|
];
|
|
|
|
$isNavPopupsGadgetEnabled = $context->conflictsWithNavPopupsGadget( $user );
|
|
$isRefTooltipsGadgetEnabled = $context->conflictsWithRefTooltipsGadget( $user );
|
|
|
|
if ( $isNavPopupsGadgetEnabled && $isRefTooltipsGadgetEnabled ) {
|
|
$option[ 'disabled' ] = true;
|
|
$option[ 'help-message' ] = [ 'popups-prefs-reftooltips-and-navpopups-gadget-conflict-info',
|
|
'Special:Preferences#mw-prefsection-gadgets' ];
|
|
} elseif ( $isNavPopupsGadgetEnabled ) {
|
|
$option[ 'disabled' ] = true;
|
|
$option[ 'help-message' ] = [ 'popups-prefs-navpopups-gadget-conflict-info',
|
|
'Special:Preferences#mw-prefsection-gadgets' ];
|
|
} elseif ( $isRefTooltipsGadgetEnabled ) {
|
|
$option[ 'disabled' ] = true;
|
|
$option[ 'help-message' ] = [ 'popups-prefs-reftooltips-gadget-conflict-info',
|
|
'Special:Preferences#mw-prefsection-gadgets' ];
|
|
}
|
|
|
|
return [
|
|
PopupsContext::REFERENCE_PREVIEWS_PREFERENCE_NAME => $option
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Allows last minute changes to the output page, e.g. adding of CSS or JavaScript by extensions.
|
|
*
|
|
* @param OutputPage $out The Output page object
|
|
* @param Skin $skin Skin object that will be used to generate the page
|
|
*/
|
|
public function onBeforePageDisplay( $out, $skin ): void {
|
|
if ( $this->popupsContext->isTitleExcluded( $out->getTitle() ) ) {
|
|
return;
|
|
}
|
|
|
|
if ( !$this->popupsContext->areDependenciesMet() ) {
|
|
$this->logger->error( 'Popups requires the PageImages extensions.
|
|
TextExtracts extension is required when using mwApiPlain gateway.' );
|
|
return;
|
|
}
|
|
|
|
$user = $out->getUser();
|
|
if ( $this->popupsContext->shouldSendModuleToUser( $user ) ) {
|
|
$out->addModules( [ 'ext.popups' ] );
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Hook handler for the ResourceLoaderStartUpModule that makes static configuration visible to
|
|
* the frontend. These variables end in the only "startup" ResourceLoader module that is loaded
|
|
* before all others.
|
|
*
|
|
* Dynamic configuration that depends on the context needs to be published via the
|
|
* MakeGlobalVariablesScript hook.
|
|
*
|
|
* @param array &$vars Array of variables to be added into the output of the startup module
|
|
* @param string $skin
|
|
* @param Config $config
|
|
*/
|
|
public function onResourceLoaderGetConfigVars( array &$vars, $skin, Config $config ): void {
|
|
$vars['wgPopupsVirtualPageViews'] = $this->config->get( 'PopupsVirtualPageViews' );
|
|
$vars['wgPopupsGateway'] = $this->config->get( 'PopupsGateway' );
|
|
$vars['wgPopupsRestGatewayEndpoint'] = $this->config->get( 'PopupsRestGatewayEndpoint' );
|
|
$vars['wgPopupsStatsvSamplingRate'] = $this->config->get( 'PopupsStatsvSamplingRate' );
|
|
$vars['wgPopupsTextExtractsIntroOnly'] = $this->config->get( 'PopupsTextExtractsIntroOnly' );
|
|
}
|
|
|
|
/**
|
|
* Hook handler publishing dynamic configuration that depends on the context, e.g. the page or
|
|
* the users settings. These variables end in an inline <script> in the documents head.
|
|
*
|
|
* Variables added:
|
|
* * `wgPopupsReferencePreviews' - The server's notion of whether or not the reference
|
|
* previews should be enabled. Depending on the general setting done on the wiki.
|
|
* * `wgPopupsConflictsWithNavPopupGadget' - The server's notion of whether or not the
|
|
* user has enabled conflicting Navigational Popups Gadget.
|
|
* * `wgPopupsConflictsWithRefTooltipsGadget' - The server's notion of whether or not the
|
|
* user has enabled conflicting Reference Tooltips Gadget.
|
|
*
|
|
* @param array &$vars variables to be added into the output of OutputPage::headElement
|
|
* @param \IContextSource $out OutputPage instance calling the hook
|
|
*/
|
|
public function onMakeGlobalVariablesScript( &$vars, $out ): void {
|
|
$vars['wgPopupsFlags'] = $this->popupsContext->getConfigBitmaskFromUser( $out->getUser() );
|
|
}
|
|
|
|
/**
|
|
* Called whenever a user wants to reset their preferences.
|
|
*
|
|
* @param array &$defaultOptions
|
|
*/
|
|
public function onUserGetDefaultOptions( &$defaultOptions ) {
|
|
$default = $this->config->get( 'PopupsOptInDefaultState' );
|
|
$defaultOptions[PopupsContext::PREVIEWS_OPTIN_PREFERENCE_NAME] = $default;
|
|
|
|
if ( $this->config->get( 'PopupsReferencePreviews' ) ) {
|
|
$defaultOptions[PopupsContext::REFERENCE_PREVIEWS_PREFERENCE_NAME] = '1';
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Called one time when initializing a users preferences for a newly created account.
|
|
*
|
|
* @param User $user Newly created user object
|
|
* @param bool $isAutoCreated
|
|
*/
|
|
public function onLocalUserCreated( $user, $isAutoCreated ) {
|
|
$default = $this->config->get( 'PopupsOptInStateForNewAccounts' );
|
|
$this->userOptionsManager->setOption(
|
|
$user,
|
|
PopupsContext::PREVIEWS_OPTIN_PREFERENCE_NAME,
|
|
$default
|
|
);
|
|
|
|
if ( $this->config->get( 'PopupsReferencePreviews' ) ) {
|
|
$this->userOptionsManager->setOption(
|
|
$user,
|
|
PopupsContext::REFERENCE_PREVIEWS_PREFERENCE_NAME,
|
|
$default
|
|
);
|
|
}
|
|
}
|
|
}
|