2019-10-28 12:28:17 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* DiscussionTools data generators
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @ingroup Extensions
|
|
|
|
* @license MIT
|
|
|
|
*/
|
|
|
|
|
2020-05-14 22:44:49 +00:00
|
|
|
namespace MediaWiki\Extension\DiscussionTools;
|
|
|
|
|
|
|
|
use Config;
|
|
|
|
use ExtensionRegistry;
|
|
|
|
use Language;
|
2019-10-28 12:28:17 +00:00
|
|
|
use MediaWiki\MediaWikiServices;
|
2020-05-14 22:44:49 +00:00
|
|
|
use ResourceLoaderContext;
|
|
|
|
use ResourceLoaderFileModule;
|
2020-05-14 23:09:20 +00:00
|
|
|
use ResourceLoaderModule;
|
2019-10-28 12:28:17 +00:00
|
|
|
|
2020-05-14 22:44:49 +00:00
|
|
|
class Data {
|
2019-10-28 12:28:17 +00:00
|
|
|
/**
|
|
|
|
* Part of the 'ext.discussionTools.init' module.
|
|
|
|
*
|
|
|
|
* We need all of this data *in content language*. Some of it is already available in JS, but only
|
|
|
|
* in client language, so it's useless for us (e.g. digit transform table, month name messages).
|
|
|
|
*
|
2020-01-13 19:48:11 +00:00
|
|
|
* @param ResourceLoaderContext $context
|
|
|
|
* @param Config $config
|
|
|
|
* @param string|null $langCode
|
2019-10-28 12:28:17 +00:00
|
|
|
* @return array
|
|
|
|
*/
|
2020-01-13 19:48:11 +00:00
|
|
|
public static function getLocalData(
|
2020-05-16 15:46:25 +00:00
|
|
|
ResourceLoaderContext $context, Config $config, string $langCode = null
|
2020-05-14 23:09:20 +00:00
|
|
|
) : array {
|
2019-10-28 12:28:17 +00:00
|
|
|
if ( $langCode ) {
|
|
|
|
$lang = Language::factory( $langCode );
|
|
|
|
} else {
|
|
|
|
$lang = MediaWikiServices::getInstance()->getContentLanguage();
|
|
|
|
}
|
|
|
|
|
|
|
|
$data = [];
|
|
|
|
|
|
|
|
$data['dateFormat'] = $lang->getDateFormatString( 'both', $lang->dateFormat( false ) );
|
|
|
|
|
|
|
|
// TODO: We probably shouldn't assume that each digit can be represented by a single BMP
|
|
|
|
// codepoint in every language (although it seems to be true right now).
|
|
|
|
$data['digits'] = $lang->formatNum( '0123456789', true );
|
|
|
|
|
|
|
|
// ApiQuerySiteinfo
|
|
|
|
$data['localTimezone'] = $config->get( 'Localtimezone' );
|
|
|
|
|
2020-02-19 23:14:27 +00:00
|
|
|
$data['specialContributionsName'] = MediaWikiServices::getInstance()
|
|
|
|
->getSpecialPageFactory()->getLocalNameFor( 'Contributions' );
|
2019-10-28 12:28:17 +00:00
|
|
|
|
|
|
|
$localTimezone = $config->get( 'Localtimezone' );
|
|
|
|
// Return only timezone abbreviations for the local timezone (there will often be two, for
|
|
|
|
// non-DST and DST timestamps, and sometimes more due to historical data, but that's okay).
|
|
|
|
$timezoneAbbrs = array_keys( array_filter(
|
|
|
|
timezone_abbreviations_list(),
|
2020-05-16 15:46:25 +00:00
|
|
|
function ( array $timezones ) use ( $localTimezone ) {
|
2019-10-28 12:28:17 +00:00
|
|
|
foreach ( $timezones as $tz ) {
|
|
|
|
if ( $tz['timezone_id'] === $localTimezone ) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
) );
|
|
|
|
$data['timezones'] = array_combine(
|
2020-05-16 15:46:25 +00:00
|
|
|
array_map( function ( string $tzMsg ) use ( $lang ) {
|
2019-10-28 12:28:17 +00:00
|
|
|
// MWTimestamp::getTimezoneMessage()
|
|
|
|
// Parser::pstPass2()
|
|
|
|
// Messages used here: 'timezone-utc' and so on
|
|
|
|
$key = 'timezone-' . strtolower( trim( $tzMsg ) );
|
|
|
|
$msg = wfMessage( $key )->inLanguage( $lang );
|
|
|
|
// TODO: This probably causes a similar issue to https://phabricator.wikimedia.org/T221294,
|
|
|
|
// but we *must* check the message existence in the database, because the messages are not
|
|
|
|
// actually defined by MediaWiki core for any timezone other than UTC...
|
|
|
|
if ( $msg->exists() ) {
|
|
|
|
return $msg->text();
|
|
|
|
}
|
|
|
|
return strtoupper( $tzMsg );
|
|
|
|
}, $timezoneAbbrs ),
|
|
|
|
array_map( 'strtoupper', $timezoneAbbrs )
|
|
|
|
);
|
|
|
|
|
|
|
|
// Messages in content language
|
|
|
|
$messagesKeys = array_merge(
|
2020-02-28 08:18:16 +00:00
|
|
|
Language::WEEKDAY_MESSAGES,
|
|
|
|
Language::WEEKDAY_ABBREVIATED_MESSAGES,
|
|
|
|
Language::MONTH_MESSAGES,
|
|
|
|
Language::MONTH_GENITIVE_MESSAGES,
|
|
|
|
Language::MONTH_ABBREVIATED_MESSAGES
|
2019-10-28 12:28:17 +00:00
|
|
|
);
|
|
|
|
$data['contLangMessages'] = array_combine(
|
|
|
|
$messagesKeys,
|
|
|
|
array_map( function ( $key ) use ( $lang ) {
|
|
|
|
return wfMessage( $key )->inLanguage( $lang )->text();
|
|
|
|
}, $messagesKeys )
|
|
|
|
);
|
|
|
|
|
|
|
|
// How far backwards we look for a signature associated with a timestamp before giving up.
|
|
|
|
// Note that this is not a hard limit on the length of signatures we detect.
|
|
|
|
$data['signatureScanLimit'] = 100;
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
}
|
2020-03-10 13:03:45 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return messages in content language, for use in a ResourceLoader module.
|
|
|
|
*
|
|
|
|
* @param ResourceLoaderContext $context
|
|
|
|
* @param Config $config
|
|
|
|
* @param array $messagesKeys
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public static function getContentLanguageMessages(
|
2020-05-16 15:46:25 +00:00
|
|
|
ResourceLoaderContext $context, Config $config, array $messagesKeys = []
|
2020-05-14 23:09:20 +00:00
|
|
|
) : array {
|
2020-03-10 13:03:45 +00:00
|
|
|
return array_combine(
|
|
|
|
$messagesKeys,
|
|
|
|
array_map( function ( $key ) {
|
|
|
|
return wfMessage( $key )->inContentLanguage()->text();
|
|
|
|
}, $messagesKeys )
|
|
|
|
);
|
|
|
|
}
|
2020-03-23 22:50:03 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Add optional dependencies to a ResourceLoader module definition depending on loaded extensions.
|
|
|
|
*
|
|
|
|
* @param array $info
|
|
|
|
* @return ResourceLoaderModule
|
|
|
|
*/
|
2020-05-14 23:09:20 +00:00
|
|
|
public static function addOptionalDependencies( array $info ) : ResourceLoaderModule {
|
2020-03-23 22:50:03 +00:00
|
|
|
$extensionRegistry = ExtensionRegistry::getInstance();
|
|
|
|
|
|
|
|
foreach ( $info['optionalDependencies'] as $ext => $deps ) {
|
|
|
|
if ( $extensionRegistry->isLoaded( $ext ) ) {
|
|
|
|
$info['dependencies'] = array_merge( $info['dependencies'], (array)$deps );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$class = $info['class'] ?? ResourceLoaderFileModule::class;
|
|
|
|
return new $class( $info );
|
|
|
|
}
|
2019-10-28 12:28:17 +00:00
|
|
|
}
|