* The UserCryptPassword and UserComparePassword hooks are no longer called. Any extensions
using them must be updated to use the Password Hashing API.
* $wgCompiledFiles has been removed.
+* $wgSortSpecialPages was removed, the listing on Special:SpecialPages is
+ now always sorted.
=== New features in 1.24 ===
* Added a new hook, "WhatLinksHereProps", to allow extensions to annotate
the $wgResourceModuleSkinStyles global. See the Vector skin for examples.
* (bug 4488) There is now a preference to watch pages where the user has
rollbacked an edit by default.
+* (bug 15484) Users will now be redirected to the login page when they need to
+ log in, rather than being shown a page asking them to log in and having to click
+ another link to actually get to the login page.
=== Bug fixes in 1.24 ===
* (bug 49116) Footer copyright notice is now always displayed in user language
* (bug 60734) Actions that use ApiPageSet (e.g. purge, watch,
setnotificationtimestamp) will now include continuation information when
using a generator.
+* $wgAPIModules (and the related $wgAPIFormatModules, $wgAPIMetaModules,
+ $wgAPIPropModules, and $wgAPIListModules settings) now allow API modules
+ to be specified using a "module spec" array instead of a plain class name.
+ A "module spec" is an associative array containing at least the 'class' key
+ for the module's class, and optionally a 'factory' key for the factory function
+ to use for the module. This is intended for extensions that want control over
+ the instantiation of their API modules, to allow for proper dependency
+ injection.
=== Languages updated in 1.24 ===
setPreloadedText() from EditPage.php. (deprecated since 1.21)
* Removed global functions wfArrayLookup(), wfArrayMerge(), wfDebugDieBacktrace()
and wfTime(). (deprecated since 1.22)
+* Microsoft Internet Explorer 6 is now a "grade C" browser, meaning that
+ JavaScript is no longer executed in this browser. The IEFixes script, which
+ existed purely to provide support for MSIE versions below 7 and which was
+ conditionally loaded for those browsers, was also removed.
==== Renamed classes ====
* CLDRPluralRuleConverter_Expression to CLDRPluralRuleConverterExpression
returning false. May also be an array, where the first element is the message
key and the remaining elements are used as parameters to the message.
-'UploadVerifyFile': extra file verification, based on mime type, etc. Preferred
+'UploadVerifyFile': extra file verification, based on MIME type, etc. Preferred
in most cases over UploadVerification.
object $upload: an instance of UploadBase, with all info about the upload
-string $mime: The uploaded file's mime type, as detected by MediaWiki. Handlers
- will typically only apply for specific mime types.
+string $mime: The uploaded file's MIME type, as detected by MediaWiki. Handlers
+ will typically only apply for specific MIME types.
object &$error: output: true if the file is valid. Otherwise, an indexed array
representing the problem with the file, where the first element is the message
key and the remaining elements are used as parameters to the message.
MEDIAWIKI_LOAD_URL ?= http://localhost/w/load.php
-kss: nodecheck
-# FIXME: Use more up-to-date Ruby version
-
+kss: kssnodecheck
# Generates CSS of mediawiki.ui and mediawiki.ui.button using ResourceLoader, then applies it to the
# KSS style guide
$(eval KSS_RL_TMP := $(shell mktemp /tmp/tmp.XXXXXXXXXX))
@command -v xdg-open >/dev/null 2>&1 || { open ${PWD}/static/index.html; exit 0; }
@xdg-open ${PWD}/static/index.html
-nodecheck:
- @scripts/nodecheck.sh
+kssnodecheck:
+ @scripts/kss-node-check.sh
--- /dev/null
+#!/usr/bin/env bash
+
+if command -v npm > /dev/null ; then
+ npm install
+else
+ # If npm isn't installed, but kss-node is, exit normally.
+ # This allows setting it up on one machine, and running it on
+ # another (e.g. Tools Labs execution nodes) that doesn't have npm
+ # installed. However, "npm install" still needs to be run
+ # occasionally to keep kss updated.
+
+ KSS_NODE="${BASH_SOURCE%/*}/../node_modules/.bin/kss-node"
+ if ! [ -x "$KSS_NODE" ] ; then
+ echo "Neither kss-node nor npm are installed."
+ echo "To install npm, see http://nodejs.org/"
+ echo "When npm is installed, the Makefile can automatically"
+ echo "install kss-node."
+ exit 1
+ fi
+fi
+++ /dev/null
-#!/usr/bin/env bash
-if command -v npm > /dev/null ; then
- npm install
-else
- echo "You need to install Node.JS!"
- echo "See http://nodejs.org/"
- exit 1
-fi
--- /dev/null
+<!DOCTYPE html>
+<html lang="en" dir="ltr">
+<head>
+ <meta charset="utf-8">
+ <!--
+ The jquery.confirmable module uses some additional modules and files
+ for internationalization support. These are omitted here for simplicity.
+ -->
+ <script type="text/javascript" src="../../resources/lib/jquery/jquery.js"></script>
+ <link rel="stylesheet" href="../../resources/src/jquery/jquery.confirmable.css">
+ <script type="text/javascript" src="../../resources/src/jquery/jquery.confirmable.js"></script>
+ <style>
+ body {
+ font: small sans-serif;
+ }
+ .mw-rollback-link a,
+ .mw-unwatch-link a,
+ .mw-thanks-thank-link a {
+ background: #ccf;
+ }
+ </style>
+</head>
+<body>
+ <h2>Introduction</h2>
+
+ <p>The jquery.confirmable module provides a simple inline confirmation script for potentially destructive or uncancellable actions.</p>
+
+ <p>Possible uses include confirmable "rollback" links in histories, confirmable "unwatch" links on watchlists, or confirmable "thanks" links (provided by the Echo extension).</p>
+
+ <p>Shown below is a demo of how each of those could work on history and watchlist entries, in an LTR and RTL language. The enhanced links are highlighted in blue.</p>
+
+ <h2>Examples</h2>
+
+ <h3>LTR (English)</h3>
+
+ <p>Watchlist:</p>
+
+ <ul lang="en" dir="ltr">
+ <li class="mw-line-even mw-changeslist-line-not-watched">
+ (<a href="#">diff</a> | <a href="#">hist</a>)
+ <span class="mw-changeslist-separator">. .</span>
+ <span class="mw-title"><a href="#" class="mw-changeslist-title">Example page</a></span>; <span class="mw-changeslist-date">13:38</span>
+ <span class="mw-changeslist-separator">. .</span>
+ <span class="mw-plusminus-neg">(-130)</span>
+ <span class="mw-changeslist-separator">. .</span>
+ <a href="#" class="mw-userlink">Example user</a>
+ <span class="mw-usertoollinks">(<a href="#">Talk</a> | <a href="#">contribs</a> | <a href="#">block</a>)</span>
+ <span class="comment">(example edit)</span>
+ <span class="mw-rollback-link">[<a href="https://www.mediawiki.org/wiki/Random_ideas_for_rollback_to_be_shelved_and_forgotten_about">rollback</a>]</span>
+ (<span class="mw-unwatch-link"><a href="#">unwatch</a></span>)
+ </li>
+ </ul>
+
+ <p>History:</p>
+
+ <ul lang="en" dir="ltr">
+ <li>
+ <span class="mw-history-histlinks">(cur | <a href="#">prev</a>)</span>
+ <input type="radio" style="visibility: hidden;" /><input type="radio" checked />
+ <a href="#" class="mw-changeslist-date">13:38, 28 October 2013</a>
+ <span class='history-user'>
+ <a href="#" class="mw-userlink">Example user</a>
+ <span class="mw-usertoollinks">(<a href="#">Talk</a> | <a href="#">contribs</a> | <a href="#">block</a>)</span>
+ </span>
+ <span class="mw-changeslist-separator">. .</span>
+ <span class="history-size">(1,654 bytes)</span>
+ <span class="mw-plusminus-neg">(-130)</span>
+ <span class="mw-changeslist-separator">. .</span>
+ <span class="comment">(example edit)</span>
+ (<span class="mw-rollback-link"><a href="https://www.mediawiki.org/wiki/Random_ideas_for_rollback_to_be_shelved_and_forgotten_about">rollback 1 edit</a></span> | <span class="mw-history-undo"><a href="#">undo</a></span> | <span class="mw-thanks-thank-link"><a href="#">thank</a></span>)
+ </li>
+ </ul>
+
+ <script type="text/javascript">
+ $( 'ul[lang="en"] .mw-rollback-link a' )
+ .confirmable({ i18n: { confirm: 'Are you sure you want to rollback?' } });
+ $( 'ul[lang="en"] .mw-unwatch-link a' )
+ .confirmable({ handler: function(){ alert('Unwatched!') } });
+ $( 'ul[lang="en"] .mw-thanks-thank-link a' )
+ .confirmable({ handler: function(){ alert('Thanked!') } });
+ </script>
+
+ <h3>RTL (Hebrew)</h3>
+ <!-- All of the Hebrew text below has been basically pulled out of my hat. -->
+
+ <p>Watchlist:</p>
+
+ <ul lang="he" dir="rtl">
+ <li class="mw-line-even mw-changeslist-line-not-watched">
+ (<a href="#">הבדל</a> | <a href="#">היסטוריה</a>)
+ <span class="mw-changeslist-separator">. .</span>
+ <span class="mw-title"><a href="#" class="mw-changeslist-title">דף דוגמה</a></span>; <span class="mw-changeslist-date">13:38</span>
+ <span class="mw-changeslist-separator">. .</span>
+ <span class="mw-plusminus-neg">(-57)</span>
+ <span class="mw-changeslist-separator">. .</span>
+ <a href="#" class="mw-userlink">דוגמא אדם</a>
+ <span class="mw-usertoollinks">(<a href="#">שיחה</a> | <a href="#">תרומות</a> | <a href="#">חסימה</a>)</span>
+ <span class="comment">(עריכה לדוגמה)</span>
+ <span class="mw-rollback-link">[<a href="https://www.mediawiki.org/wiki/Random_ideas_for_rollback_to_be_shelved_and_forgotten_about">שחזור</a>]</span>
+ (<span class="mw-unwatch-link"><a href="#">הפסקת מעקב</a></span>)
+ </li>
+ </ul>
+
+ <p>History:</p>
+
+ <ul lang="he" dir="rtl">
+ <li>
+ <span class="mw-history-histlinks">(נוכחית | <a href="#">קודמת</a>)</span>
+ <input type="radio" style="visibility: hidden;" /><input type="radio" checked />
+ <a href="#" class="mw-changeslist-date">23:41, 12 במאי 2012</a>
+ <span class='history-user'>
+ <a href="#" class="mw-userlink">דוגמא אדם</a>
+ <span class="mw-usertoollinks">(<a href="#">שיחה</a> | <a href="#">תרומות</a> | <a href="#">חסימה</a>)</span>
+ </span>
+ <span class="mw-changeslist-separator">. .</span>
+ <span class="history-size">(1,762 בתים)</span>
+ <span class="mw-plusminus-neg">(-57)</span>
+ <span class="mw-changeslist-separator">. .</span>
+ <span class="comment">(עריכה לדוגמה)</span>
+ (<span class="mw-rollback-link"><a href="https://www.mediawiki.org/wiki/Random_ideas_for_rollback_to_be_shelved_and_forgotten_about">שחזור עריכה אחת</a></span> | <span class="mw-history-undo"><a href="#">ביטול</a></span> | <span class="mw-thanks-thank-link"><a href="#">תודה</a></span>)
+ </li>
+ </ul>
+
+ <script type="text/javascript">
+ var hebrewI18n = {
+ confirm: 'האם ברצונך להמשיך?',
+ yes: 'כן',
+ no: 'לא',
+ }
+
+ $( 'ul[lang="he"] .mw-rollback-link a' )
+ .confirmable({ i18n: $.extend( {}, hebrewI18n, { confirm: 'האם ברצונך לשחזר?' } ) });
+ $( 'ul[lang="he"] .mw-unwatch-link a' )
+ .confirmable({ i18n: hebrewI18n, handler: function(){ alert('Unwatched!') } });
+ $( 'ul[lang="he"] .mw-thanks-thank-link a' )
+ .confirmable({ i18n: hebrewI18n, handler: function(){ alert('Thanked!') } });
+ </script>
+ <style type="text/css">
+ /* This is normally handled by CSSJanus. */
+ ul[dir=rtl] .jquery-confirmable-button {
+ margin-left: 0;
+ margin-right: 1ex;
+ }
+ </style>
+</body>
+</html>
+
If uploads are enabled in the wiki, files will be put in subdirectories
under here.
-
-Note to upgraders: as of MediaWiki 1.5, the images used in the user
-interface have been moved to skins/common/images.
'SiteStatsInit' => 'includes/SiteStats.php',
'Skin' => 'includes/Skin.php',
'SkinTemplate' => 'includes/SkinTemplate.php',
+ 'SkinFallback' => 'includes/SkinFallback.php',
+ 'SkinFallbackTemplate' => 'includes/SkinFallback.php',
'SquidPurgeClient' => 'includes/SquidPurgeClient.php',
'SquidPurgeClientPool' => 'includes/SquidPurgeClient.php',
'StatCounter' => 'includes/StatCounter.php',
'RevisiondeleteAction' => 'includes/actions/RevisiondeleteAction.php',
'RollbackAction' => 'includes/actions/RollbackAction.php',
'SubmitAction' => 'includes/actions/EditAction.php',
- 'UnprotectAction' => 'includes/actions/ProtectAction.php',
- 'UnwatchAction' => 'includes/actions/WatchAction.php',
+ 'UnprotectAction' => 'includes/actions/UnprotectAction.php',
+ 'UnwatchAction' => 'includes/actions/UnwatchAction.php',
'ViewAction' => 'includes/actions/ViewAction.php',
'WatchAction' => 'includes/actions/WatchAction.php',
'ResourceLoaderWikiModule' => 'includes/resourceloader/ResourceLoaderWikiModule.php',
# includes/revisiondelete
- 'RevDelArchivedFileItem' => 'includes/revisiondelete/RevisionDelete.php',
- 'RevDelArchivedFileList' => 'includes/revisiondelete/RevisionDelete.php',
- 'RevDelArchivedRevisionItem' => 'includes/revisiondelete/RevisionDelete.php',
- 'RevDelArchiveItem' => 'includes/revisiondelete/RevisionDelete.php',
- 'RevDelArchiveList' => 'includes/revisiondelete/RevisionDelete.php',
- 'RevDelFileItem' => 'includes/revisiondelete/RevisionDelete.php',
- 'RevDelFileList' => 'includes/revisiondelete/RevisionDelete.php',
+ 'RevDelArchivedFileItem' => 'includes/revisiondelete/RevDelArchivedFileItem.php',
+ 'RevDelArchivedFileList' => 'includes/revisiondelete/RevDelArchivedFileList.php',
+ 'RevDelArchivedRevisionItem' => 'includes/revisiondelete/RevDelArchivedRevisionItem.php',
+ 'RevDelArchiveItem' => 'includes/revisiondelete/RevDelArchiveItem.php',
+ 'RevDelArchiveList' => 'includes/revisiondelete/RevDelArchiveList.php',
+ 'RevDelFileItem' => 'includes/revisiondelete/RevDelFileItem.php',
+ 'RevDelFileList' => 'includes/revisiondelete/RevDelFileList.php',
'RevDelItem' => 'includes/revisiondelete/RevisionDeleteAbstracts.php',
'RevDelList' => 'includes/revisiondelete/RevisionDeleteAbstracts.php',
- 'RevDelLogItem' => 'includes/revisiondelete/RevisionDelete.php',
- 'RevDelLogList' => 'includes/revisiondelete/RevisionDelete.php',
- 'RevDelRevisionItem' => 'includes/revisiondelete/RevisionDelete.php',
- 'RevDelRevisionList' => 'includes/revisiondelete/RevisionDelete.php',
+ 'RevDelLogItem' => 'includes/revisiondelete/RevDelLogItem.php',
+ 'RevDelLogList' => 'includes/revisiondelete/RevDelLogList.php',
+ 'RevDelRevisionItem' => 'includes/revisiondelete/RevDelRevisionItem.php',
+ 'RevDelRevisionList' => 'includes/revisiondelete/RevDelRevisionList.php',
'RevisionDeleter' => 'includes/revisiondelete/RevisionDeleter.php',
'RevisionDeleteUser' => 'includes/revisiondelete/RevisionDeleteUser.php',
# includes/search
- 'PostgresSearchResult' => 'includes/search/SearchPostgres.php',
- 'PostgresSearchResultSet' => 'includes/search/SearchPostgres.php',
'SearchDatabase' => 'includes/search/SearchDatabase.php',
'SearchEngine' => 'includes/search/SearchEngine.php',
'SearchEngineDummy' => 'includes/search/SearchEngine.php',
'exe', 'scr', 'dll', 'msi', 'vbs', 'bat', 'com', 'pif', 'cmd', 'vxd', 'cpl' );
/**
- * Files with these mime types will never be allowed as uploads
+ * Files with these MIME types will never be allowed as uploads
* if $wgVerifyMimeType is enabled.
*/
$wgMimeTypeBlacklist = array(
$wgUploadSizeWarning = false;
/**
- * list of trusted media-types and mime types.
+ * list of trusted media-types and MIME types.
* Use the MEDIATYPE_xxx constants to represent media types.
* This list is used by File::isSafeFile
*
$wgAntivirusRequired = true;
/**
- * Determines if the mime type of uploaded files should be checked
+ * Determines if the MIME type of uploaded files should be checked
*/
$wgVerifyMimeType = true;
/**
- * Sets the mime type definition file to use by MimeMagic.php.
+ * Sets the MIME type definition file to use by MimeMagic.php.
* Set to null, to use built-in defaults only.
* example: $wgMimeTypeFile = '/etc/mime.types';
*/
$wgMimeTypeFile = 'includes/mime.types';
/**
- * Sets the mime type info file to use by MimeMagic.php.
+ * Sets the MIME type info file to use by MimeMagic.php.
* Set to null, to use built-in defaults only.
*/
$wgMimeInfoFile = 'includes/mime.info';
/**
- * Sets an external mime detector program. The command must print only
- * the mime type to standard output.
+ * Sets an external MIME detector program. The command must print only
+ * the MIME type to standard output.
* The name of the file to process will be appended to the command given here.
* If not set or NULL, mime_content_type will be used if available.
*
* @par Example:
* @code
- * #$wgMimeDetectorCommand = "file -bi"; # use external mime detector (Linux)
+ * #$wgMimeDetectorCommand = "file -bi"; # use external MIME detector (Linux)
* @endcode
*/
$wgMimeDetectorCommand = null;
/**
- * Switch for trivial mime detection. Used by thumb.php to disable all fancy
+ * Switch for trivial MIME detection. Used by thumb.php to disable all fancy
* things, because only a few types of images are needed and file extensions
* can be trusted.
*/
$wgTrivialMimeDetection = false;
/**
- * Additional XML types we can allow via mime-detection.
+ * Additional XML types we can allow via MIME-detection.
* array = ( 'rootElement' => 'associatedMimeType' )
*/
$wgXMLMimeTypes = array(
* Normally we wouldn't have to define this in the root "<html>"
* element, but IE needs it there in some circumstances.
*
- * This is ignored if $wgMimeType is set to a non-XML mimetype.
+ * This is ignored if $wgMimeType is set to a non-XML MIME type.
*/
$wgXhtmlNamespaces = array();
*
* @since 1.24
*/
-$wgFallbackSkin = 'vector';
+$wgFallbackSkin = 'fallback';
/**
* Specify the names of skins that should not be presented in the list of
*/
$wgUseCombinedLoginLink = false;
-/**
- * Search form look for Vector skin only.
- * - true = use an icon search button
- * - false = use Go & Search buttons
- */
-$wgVectorUseSimpleSearch = true;
-
-/**
- * Watch and unwatch as an icon rather than a link for Vector skin only.
- * - true = use an icon watch/unwatch button
- * - false = use watch/unwatch text link
- */
-$wgVectorUseIconWatch = true;
-
/**
* Display user edit counts in various prominent places.
*/
'protect/modify' => 'modifiedarticleprotection',
'protect/unprotect' => 'unprotectedarticle',
'protect/move_prot' => 'movedarticleprotection',
- 'upload/upload' => 'uploadedimage',
- 'upload/overwrite' => 'overwroteimage',
- 'upload/revert' => 'uploadedimage',
'import/upload' => 'import-logentry-upload',
'import/interwiki' => 'import-logentry-interwiki',
'merge/merge' => 'pagemerge-logentry',
'patrol/patrol' => 'PatrolLogFormatter',
'rights/rights' => 'RightsLogFormatter',
'rights/autopromote' => 'RightsLogFormatter',
+ 'upload/upload' => 'LogFormatter',
+ 'upload/overwrite' => 'LogFormatter',
+ 'upload/revert' => 'LogFormatter',
);
/**
*/
$wgSpecialPageGroups = array();
-/**
- * Whether or not to sort special pages in Special:Specialpages
- */
-$wgSortSpecialPages = true;
-
/**
* On Special:Unusedimages, consider images "used", if they are put
* into a category. Default (false) is not to count those as used.
/**
* API module extensions.
- * Associative array mapping module name to class name.
- * Extension modules may override the core modules.
*
+ * Associative array mapping module name to modules specs;
+ * Each module spec is an associative array containing at least
+ * the 'class' key for the module's class, and optionally a
+ * 'factory' key for the factory function to use for the module.
+ *
+ * That factory function will be called with two parameters,
+ * the parent module (an instance of ApiBase, usually ApiMain)
+ * and the name the module was registered under. The return
+ * value must be an instance of the class given in the 'class'
+ * field.
+ *
+ * For backward compatibility, the module spec may also be a
+ * simple string containing the module's class name. In that
+ * case, the class' constructor will be called with the parent
+ * module and module name as parameters, as described above.
+ *
+ * Examples for registering API modules:
+ *
+ * @code
+ * $wgAPIModules['foo'] = 'ApiFoo';
+ * $wgAPIModules['bar'] = array(
+ * 'class' => 'ApiBar',
+ * 'factory' => function( $main, $name ) { ... }
+ * );
+ * $wgAPIModules['xyzzy'] = array(
+ * 'class' => 'ApiXyzzy',
+ * 'factory' => array( 'XyzzyFactory', 'newApiModule' )
+ * );
+ * @endcode
+ *
+ * Extension modules may override the core modules.
* See ApiMain::$Modules for a list of the core modules.
*/
$wgAPIModules = array();
/**
* API format module extensions.
- * Associative array mapping format module name to class name.
+ * Associative array mapping format module name to module specs (see $wgAPIModules).
* Extension modules may override the core modules.
*
* See ApiMain::$Formats for a list of the core format modules.
/**
* API Query meta module extensions.
- * Associative array mapping meta module name to class name.
+ * Associative array mapping meta module name to module specs (see $wgAPIModules).
* Extension modules may override the core modules.
*
* See ApiQuery::$QueryMetaModules for a list of the core meta modules.
/**
* API Query prop module extensions.
- * Associative array mapping properties module name to class name.
+ * Associative array mapping prop module name to module specs (see $wgAPIModules).
* Extension modules may override the core modules.
*
* See ApiQuery::$QueryPropModules for a list of the core prop modules.
/**
* API Query list module extensions.
- * Associative array mapping list module name to class name.
+ * Associative array mapping list module name to module specs (see $wgAPIModules).
* Extension modules may override the core modules.
*
* See ApiQuery::$QueryListModules for a list of the core list modules.
/**
* Shows a bulletin board style toolbar for common editing functions.
* It can be disabled in the user preferences.
- * The necessary JavaScript code can be found in skins/common/edit.js.
*
* @return string
*/
*
* There are two important configuration options this class uses:
*
- * $wgMimeType: If this is set to an xml mimetype then output should be
+ * $wgMimeType: If this is set to an xml MIME type then output should be
* valid XHTML5.
* $wgWellFormedXml: If this is set to true, then all output should be
* well-formed XML (quotes on attributes, self-closing tags, etc.).
$isXHTML = self::isXmlMimeType( $wgMimeType );
if ( $isXHTML ) { // XHTML5
- // XML mimetyped markup should have an xml header.
+ // XML MIME-typed markup should have an xml header.
// However a DOCTYPE is not needed.
$ret .= "<?xml version=\"1.0\" encoding=\"UTF-8\" ?" . ">\n";
}
/**
- * Determines if the given mime type is xml.
+ * Determines if the given MIME type is xml.
*
- * @param string $mimetype MimeType
+ * @param string $mimetype MIME type
* @return bool
*/
public static function isXmlMimeType( $mimetype ) {
# http://www.whatwg.org/html/infrastructure.html#xml-mime-type
# * text/xml
# * application/xml
- # * Any mimetype with a subtype ending in +xml (this implicitly includes application/xhtml+xml)
+ # * Any MIME type with a subtype ending in +xml (this implicitly includes application/xhtml+xml)
return (bool)preg_match( '!^(text|application)/xml$|^.+/.+\+xml$!', $mimetype );
}
*/
private $context;
+ /**
+ * @var Config
+ */
+ private $config;
+
/**
* @param null|WebRequest $x
* @return WebRequest
}
$this->context = $context;
+ $this->config = $context->getConfig();
}
/**
* @return void
*/
private function performRequest() {
- global $wgServer, $wgUsePathInfo, $wgTitle;
+ global $wgTitle;
wfProfileIn( __METHOD__ );
$url = $title->getFullURL( $query );
}
// Check for a redirect loop
- if ( !preg_match( '/^' . preg_quote( $wgServer, '/' ) . '/', $url )
+ if ( !preg_match( '/^' . preg_quote( $this->config->get( 'Server' ), '/' ) . '/', $url )
&& $title->isLocal()
) {
// 301 so google et al report the target as the actual url.
"requested; this sometimes happens when moving a wiki " .
"to a new server or changing the server configuration.\n\n";
- if ( $wgUsePathInfo ) {
+ if ( $this->config->get( 'UsePathInfo' ) ) {
$message .= "The wiki is trying to interpret the page " .
"title from the URL path portion (PATH_INFO), which " .
"sometimes fails depending on the web server. Try " .
* @return mixed An Article, or a string to redirect to another URL
*/
private function initializeArticle() {
- global $wgDisableHardRedirects;
-
wfProfileIn( __METHOD__ );
$title = $this->context->getTitle();
// Is the target already set by an extension?
$target = $target ? $target : $article->followRedirect();
if ( is_string( $target ) ) {
- if ( !$wgDisableHardRedirects ) {
+ if ( !$this->config->get( 'DisableHardRedirects' ) ) {
// we'll need to redirect
wfProfileOut( __METHOD__ );
return $target;
* @param Title $requestTitle The original title, before any redirects were applied
*/
private function performAction( Page $page, Title $requestTitle ) {
- global $wgUseSquid, $wgSquidMaxage;
-
wfProfileIn( __METHOD__ );
$request = $this->context->getRequest();
if ( $action instanceof Action ) {
# Let Squid cache things if we can purge them.
- if ( $wgUseSquid &&
+ if ( $this->config->get( 'UseSquid' ) &&
in_array( $request->getFullRequestURL(), $requestTitle->getSquidURLs() )
) {
- $output->setSquidMaxage( $wgSquidMaxage );
+ $output->setSquidMaxage( $this->config->get( 'SquidMaxage' ) );
}
$action->show();
* @return bool
*/
private function checkMaxLag() {
- global $wgShowHostnames;
-
wfProfileIn( __METHOD__ );
$maxLag = $this->context->getRequest()->getVal( 'maxlag' );
if ( !is_null( $maxLag ) ) {
$resp->header( 'Retry-After: ' . max( intval( $maxLag ), 5 ) );
$resp->header( 'X-Database-Lag: ' . intval( $lag ) );
$resp->header( 'Content-Type: text/plain' );
- if ( $wgShowHostnames ) {
+ if ( $this->config->get( 'ShowHostnames' ) ) {
echo "Waiting for $host: $lag seconds lagged\n";
} else {
echo "Waiting for a database server: $lag seconds lagged\n";
}
private function main() {
- global $wgUseFileCache, $wgTitle, $wgUseAjax;
+ global $wgTitle;
wfProfileIn( __METHOD__ );
$request = $this->context->getRequest();
// Send Ajax requests to the Ajax dispatcher.
- if ( $wgUseAjax && $request->getVal( 'action', 'view' ) == 'ajax' ) {
+ if ( $this->config->get( 'UseAjax' ) && $request->getVal( 'action', 'view' ) == 'ajax' ) {
// Set a dummy title, because $wgTitle == null might break things
$title = Title::makeTitle( NS_MAIN, 'AJAX' );
}
}
- if ( $wgUseFileCache && $title->getNamespace() >= 0 ) {
+ if ( $this->config->get( 'UseFileCache' ) && $title->getNamespace() >= 0 ) {
wfProfileIn( 'main-try-filecache' );
if ( HTMLFileCache::useFileCache( $this->context ) ) {
// Try low-level file cache hit
* the socket once it's done.
*/
protected function triggerJobs() {
- global $wgJobRunRate, $wgServer, $wgRunJobsAsync;
-
- if ( $wgJobRunRate <= 0 || wfReadOnly() ) {
+ $jobRunRate = $this->config->get( 'JobRunRate' );
+ if ( $jobRunRate <= 0 || wfReadOnly() ) {
return;
} elseif ( $this->getTitle()->isSpecial( 'RunJobs' ) ) {
return; // recursion guard
$section = new ProfileSection( __METHOD__ );
- if ( $wgJobRunRate < 1 ) {
+ if ( $jobRunRate < 1 ) {
$max = mt_getrandmax();
- if ( mt_rand( 0, $max ) > $max * $wgJobRunRate ) {
- return; // the higher $wgJobRunRate, the less likely we return here
+ if ( mt_rand( 0, $max ) > $max * $jobRunRate ) {
+ return; // the higher the job run rate, the less likely we return here
}
$n = 1;
} else {
- $n = intval( $wgJobRunRate );
+ $n = intval( $jobRunRate );
}
- if ( !$wgRunJobsAsync ) {
+ if ( !$this->config->get( 'RunJobsAsync' ) ) {
// Fall back to running the job here while the user waits
$runner = new JobRunner();
$runner->run( array( 'maxJobs' => $n ) );
$query['signature'] = SpecialRunJobs::getQuerySignature( $query );
$errno = $errstr = null;
- $info = wfParseUrl( $wgServer );
+ $info = wfParseUrl( $this->config->get( 'Server' ) );
wfSuppressWarnings();
$sock = fsockopen(
$info['host'],
protected $language = null;
/**
- * @var string|string[] The message key or array of keys.
+ * @var string The message key. If $keysToTry has more than one element,
+ * this may change to one of the keys to try when fetching the message text.
*/
protected $key;
+ /**
+ * @var string[] List of keys to try when fetching the message.
+ */
+ protected $keysToTry;
+
/**
* @var array List of parameters which will be substituted into the message.
*/
* non-empty message for.
* @param array $params Message parameters.
* @param Language $language Optional language of the message, defaults to $wgLang.
+ *
+ * @throws InvalidArgumentException
*/
public function __construct( $key, $params = array(), Language $language = null ) {
global $wgLang;
- $this->key = $key;
+ if ( !is_string( $key ) && !is_array( $key ) ) {
+ throw new InvalidArgumentException( '$key must be a string or an array' );
+ }
+
+ $this->keysToTry = (array)$key;
+
+ if ( empty( $this->keysToTry ) ) {
+ throw new InvalidArgumentException( '$key must not be an empty list' );
+ }
+
+ $this->key = reset( $this->keysToTry );
+
$this->parameters = array_values( $params );
$this->language = $language ? $language : $wgLang;
}
/**
- * Returns the message key or the first from an array of message keys.
+ * @since 1.24
+ *
+ * @return bool True if this is a multi-key message, that is, if the key provided to the
+ * constructor was a fallback list of keys to try.
+ */
+ public function isMultiKey() {
+ return count( $this->keysToTry ) > 1;
+ }
+
+ /**
+ * @since 1.24
+ *
+ * @return string[] The list of keys to try when fetching the message text,
+ * in order of preference.
+ */
+ public function getKeysToTry() {
+ return $this->keysToTry;
+ }
+
+ /**
+ * Returns the message key.
+ *
+ * If a list of multiple possible keys was supplied to the constructor, this method may
+ * return any of these keys. After the message ahs been fetched, this method will return
+ * the key that was actually used to fetch the message.
*
* @since 1.21
*
* @return string
*/
public function getKey() {
- if ( is_array( $this->key ) ) {
- // May happen if some kind of fallback is applied.
- // For now, just use the first key. We really need a better solution.
- return $this->key[0];
- } else {
- return $this->key;
- }
+ return $this->key;
}
/**
$string = $this->fetchMessage();
if ( $string === false ) {
- $key = htmlspecialchars( is_array( $this->key ) ? $this->key[0] : $this->key );
+ $key = htmlspecialchars( $this->key );
if ( $this->format === 'plain' ) {
return '<' . $key . '>';
}
protected function fetchMessage() {
if ( $this->message === null ) {
$cache = MessageCache::singleton();
- if ( is_array( $this->key ) ) {
- if ( !count( $this->key ) ) {
- throw new MWException( "Given empty message key array." );
- }
- foreach ( $this->key as $key ) {
- $message = $cache->get( $key, $this->useDatabase, $this->language );
- if ( $message !== false && $message !== '' ) {
- break;
- }
+
+ foreach ( $this->keysToTry as $key ) {
+ $message = $cache->get( $key, $this->useDatabase, $this->language );
+ if ( $message !== false && $message !== '' ) {
+ break;
}
- $this->message = $message;
- } else {
- $this->message = $cache->get( $this->key, $this->useDatabase, $this->language );
}
+
+ // NOTE: The constructor makes sure keysToTry isn't empty,
+ // so we know that $key and $message are initialized.
+ $this->key = $key;
+ $this->message = $message;
}
return $this->message;
}
*
* @see Message::__construct
*
- * @param string|string[] $key Message to use.
+ * @param string $text Message to use.
* @param array $params Parameters for the message.
+ *
+ * @throws InvalidArgumentException
*/
- public function __construct( $key, $params = array() ) {
- parent::__construct( $key, $params );
+ public function __construct( $text, $params = array() ) {
+ if ( !is_string( $text ) ) {
+ throw new InvalidArgumentException( '$text must be a string' );
+ }
+
+ parent::__construct( $text, $params );
+
// The key is the message.
- $this->message = $key;
+ $this->message = $text;
}
/**
if ( $this->message === null ) {
$this->message = $this->key;
}
+
return $this->message;
}
<?php
/**
- * Module defining helper functions for detecting and dealing with mime types.
+ * Module defining helper functions for detecting and dealing with MIME types.
*
* 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
*/
/**
- * Defines a set of well known mime types
+ * Defines a set of well known MIME types
* This is used as a fallback to mime.types files.
- * An extensive list of well known mime types is provided by
+ * An extensive list of well known MIME types is provided by
* the file mime.types in the includes directory.
*
- * This list concatenated with mime.types is used to create a mime <-> ext
- * map. Each line contains a mime type followed by a space separated list of
- * extensions. If multiple extensions for a single mime type exist or if
- * multiple mime types exist for a single extension then in most cases
- * MediaWiki assumes that the first extension following the mime type is the
- * canonical extension, and the first time a mime type appears for a certain
- * extension is considered the canonical mime type.
+ * This list concatenated with mime.types is used to create a MIME <-> ext
+ * map. Each line contains a MIME type followed by a space separated list of
+ * extensions. If multiple extensions for a single MIME type exist or if
+ * multiple MIME types exist for a single extension then in most cases
+ * MediaWiki assumes that the first extension following the MIME type is the
+ * canonical extension, and the first time a MIME type appears for a certain
+ * extension is considered the canonical MIME type.
*
* (Note that appending $wgMimeTypeFile to the end of MM_WELL_KNOWN_MIME_TYPES
* sucks because you can't redefine canonical types. This could be fixed by
);
/**
- * Defines a set of well known mime info entries
+ * Defines a set of well known MIME info entries
* This is used as a fallback to mime.info files.
- * An extensive list of well known mime types is provided by
+ * An extensive list of well known MIME types is provided by
* the file mime.info in the includes directory.
*/
define( 'MM_WELL_KNOWN_MIME_INFO', <<<END_STRING
);
/**
- * Implements functions related to mime types such as detection and mapping to
+ * Implements functions related to MIME types such as detection and mapping to
* file extension.
*
* Instances of this class are stateless, there only needs to be one global instance
*/
class MimeMagic {
/**
- * @var array Mapping of media types to arrays of mime types.
+ * @var array Mapping of media types to arrays of MIME types.
* This is used by findMediaType and getMediaType, respectively
*/
protected $mMediaTypes = null;
- /** @var array Map of mime type aliases
+ /** @var array Map of MIME type aliases
*/
protected $mMimeTypeAliases = null;
- /** @var array Map of mime types to file extensions (as a space separated list)
+ /** @var array Map of MIME types to file extensions (as a space separated list)
*/
protected $mMimeToExt = null;
- /** @var array Map of file extensions types to mime types (as a space separated list)
+ /** @var array Map of file extensions types to MIME types (as a space separated list)
*/
public $mExtToMime = null;
}
/**
- * Returns a list of file extensions for a given mime type as a space
- * separated string or null if the mime type was unrecognized. Resolves
- * mime type aliases.
+ * Returns a list of file extensions for a given MIME type as a space
+ * separated string or null if the MIME type was unrecognized. Resolves
+ * MIME type aliases.
*
* @param string $mime
* @return string|null
return $this->mMimeToExt[$mime];
}
- // Resolve the mime type to the canonical type
+ // Resolve the MIME type to the canonical type
if ( isset( $this->mMimeTypeAliases[$mime] ) ) {
$mime = $this->mMimeTypeAliases[$mime];
if ( isset( $this->mMimeToExt[$mime] ) ) {
}
/**
- * Returns a list of mime types for a given file extension as a space
+ * Returns a list of MIME types for a given file extension as a space
* separated string or null if the extension was unrecognized.
*
* @param string $ext
}
/**
- * Returns a single mime type for a given file extension or null if unknown.
+ * Returns a single MIME type for a given file extension or null if unknown.
* This is always the first type from the list returned by getTypesForExtension($ext).
*
* @param string $ext
}
/**
- * Tests if the extension matches the given mime type. Returns true if a
- * match was found, null if the mime type is unknown, and false if the
- * mime type is known but no matches where found.
+ * Tests if the extension matches the given MIME type. Returns true if a
+ * match was found, null if the MIME type is unknown, and false if the
+ * MIME type is known but no matches where found.
*
* @param string $extension
* @param string $mime
$ext = $this->getExtensionsForType( $mime );
if ( !$ext ) {
- return null; // Unknown mime type
+ return null; // Unknown MIME type
}
$ext = explode( ' ', $ext );
}
/**
- * Returns true if the mime type is known to represent an image format
+ * Returns true if the MIME type is known to represent an image format
* supported by the PHP GD library.
*
* @param string $mime
* invalid uploads; if we can't identify the type we won't
* be able to say if it's invalid.
*
- * @todo Be more accurate when using fancy mime detector plugins;
+ * @todo Be more accurate when using fancy MIME detector plugins;
* right now this is the bare minimum getimagesize() list.
* @param string $extension
* @return bool
}
/**
- * Improves a mime type using the file extension. Some file formats are very generic,
- * so their mime type is not very meaningful. A more useful mime type can be derived
+ * Improves a MIME type using the file extension. Some file formats are very generic,
+ * so their MIME type is not very meaningful. A more useful MIME type can be derived
* by looking at the file extension. Typically, this method would be called on the
* result of guessMimeType().
*
- * @param string $mime The mime type, typically guessed from a file's content.
+ * @param string $mime The MIME type, typically guessed from a file's content.
* @param string $ext The file extension, as taken from the file name
*
- * @return string The mime type
+ * @return string The MIME type
*/
public function improveTypeFromExtension( $mime, $ext ) {
if ( $mime === 'unknown/unknown' ) {
} elseif ( $mime === 'application/x-opc+zip' ) {
if ( $this->isMatchingExtension( $ext, $mime ) ) {
// A known file extension for an OPC file,
- // find the proper mime type for that file extension
+ // find the proper MIME type for that file extension
$mime = $this->guessTypesForExtension( $ext );
} else {
wfDebug( __METHOD__ . ": refusing to guess better type for $mime file, " .
}
/**
- * Mime type detection. This uses detectMimeType to detect the mime type
+ * MIME type detection. This uses detectMimeType to detect the MIME type
* of the file, but applies additional checks to determine some well known
- * file formats that may be missed or misinterpreted by the default mime
+ * file formats that may be missed or misinterpreted by the default MIME
* detection (namely XML based formats like XHTML or SVG, as well as ZIP
* based formats like OPC/ODF files).
*
* @param string $file The file to check
* @param string|bool $ext The file extension, or true (default) to extract it from the filename.
* Set it to false to ignore the extension. DEPRECATED! Set to false, use
- * improveTypeFromExtension($mime, $ext) later to improve mime type.
+ * improveTypeFromExtension($mime, $ext) later to improve MIME type.
*
- * @return string The mime type of $file
+ * @return string The MIME type of $file
*/
public function guessMimeType( $file, $ext = true ) {
if ( $ext ) { // TODO: make $ext default to false. Or better, remove it.
}
/**
- * Guess the mime type from the file contents.
+ * Guess the MIME type from the file contents.
*
* @param string $file
* @param mixed $ext
* @param string|null $tail The tail of the file
* @param string|bool $ext The file extension, or true to extract it from the filename.
* Set it to false (default) to ignore the extension. DEPRECATED! Set to false,
- * use improveTypeFromExtension($mime, $ext) later to improve mime type.
+ * use improveTypeFromExtension($mime, $ext) later to improve MIME type.
*
* @return string
*/
# TODO: remove the block below, as soon as improveTypeFromExtension is used everywhere
if ( $ext !== true && $ext !== false ) {
/** This is the mode used by getPropsFromPath
- * These mime's are stored in the database, where we don't really want
+ * These MIME's are stored in the database, where we don't really want
* x-opc+zip, because we use it only for internal purposes
*/
if ( $this->isMatchingExtension( $ext, $mime ) ) {
}
/**
- * Internal mime type detection. Detection is done using an external
+ * Internal MIME type detection. Detection is done using an external
* program, if $wgMimeDetectorCommand is set. Otherwise, the fileinfo
* extension and mime_content_type are tried (in this order), if they
- * are available. If the detections fails and $ext is not false, the mime
+ * are available. If the detections fails and $ext is not false, the MIME
* type is guessed from the file extension, using guessTypesForExtension.
*
- * If the mime type is still unknown, getimagesize is used to detect the
- * mime type if the file is an image. If no mime type can be determined,
+ * If the MIME type is still unknown, getimagesize is used to detect the
+ * MIME type if the file is an image. If no MIME type can be determined,
* this function returns 'unknown/unknown'.
*
* @param string $file The file to check
* @param string|bool $ext The file extension, or true (default) to extract it from the filename.
* Set it to false to ignore the extension. DEPRECATED! Set to false, use
- * improveTypeFromExtension($mime, $ext) later to improve mime type.
+ * improveTypeFromExtension($mime, $ext) later to improve MIME type.
*
- * @return string The mime type of $file
+ * @return string The MIME type of $file
*/
private function detectMimeType( $file, $ext = true ) {
global $wgMimeDetectorCommand;
# If you may need to load the fileinfo extension at runtime, set
# $wgLoadFileinfoExtension in LocalSettings.php
- $mime_magic_resource = finfo_open( FILEINFO_MIME ); /* return mime type ala mimetype extension */
+ $mime_magic_resource = finfo_open( FILEINFO_MIME ); /* return MIME type ala mimetype extension */
if ( $mime_magic_resource ) {
$m = finfo_file( $mime_magic_resource, $file );
}
/**
- * Determine the media type code for a file, using its mime type, name and
+ * Determine the media type code for a file, using its MIME type, name and
* possibly its contents.
*
- * This function relies on the findMediaType(), mapping extensions and mime
+ * This function relies on the findMediaType(), mapping extensions and MIME
* types to media types.
*
* @todo analyse file if need be
* @todo look at multiple extension, separately and together.
*
* @param string $path Full path to the image file, in case we have to look at the contents
- * (if null, only the mime type is used to determine the media type code).
- * @param string $mime Mime type. If null it will be guessed using guessMimeType.
+ * (if null, only the MIME type is used to determine the media type code).
+ * @param string $mime MIME type. If null it will be guessed using guessMimeType.
*
* @return string A value to be used with the MEDIATYPE_xxx constants.
*/
return MEDIATYPE_UNKNOWN;
}
- // If mime type is unknown, guess it
+ // If MIME type is unknown, guess it
if ( !$mime ) {
$mime = $this->guessMimeType( $path, false );
}
}
}
- // Check for entry for full mime type
+ // Check for entry for full MIME type
if ( $mime ) {
$type = $this->findMediaType( $mime );
if ( $type !== MEDIATYPE_UNKNOWN ) {
}
}
- // Check major mime type
+ // Check major MIME type
if ( $mime ) {
$i = strpos( $mime, '/' );
if ( $i !== false ) {
}
/**
- * Returns a media code matching the given mime type or file extension.
+ * Returns a media code matching the given MIME type or file extension.
* File extensions are represented by a string starting with a dot (.) to
- * distinguish them from mime types.
+ * distinguish them from MIME types.
*
* This function relies on the mapping defined by $this->mMediaTypes
* @access private
*/
function findMediaType( $extMime ) {
if ( strpos( $extMime, '.' ) === 0 ) {
- // If it's an extension, look up the mime types
+ // If it's an extension, look up the MIME types
$m = $this->getTypesForExtension( substr( $extMime, 1 ) );
if ( !$m ) {
return MEDIATYPE_UNKNOWN;
$m = explode( ' ', $m );
} else {
- // Normalize mime type
+ // Normalize MIME type
if ( isset( $this->mMimeTypeAliases[$extMime] ) ) {
$extMime = $this->mMimeTypeAliases[$extMime];
}
$wgExtensionAssetsPath = "$wgScriptPath/extensions";
}
-// Enable default skins. Temporary, to be removed before 1.24 release.
-// This is hacky and bad, the require_once calls should eventually be generated by the installer
-// and placed in LocalSettings.php.
-// While this is in Setup.php, it needs to be done as soon as possible, as some of the setup code
-// depends on all extensions and skins being already required (bug 67318).
-require_once "$wgStyleDirectory/MonoBook/MonoBook.php";
-require_once "$wgStyleDirectory/Vector/Vector.php";
-
if ( $wgLogo === false ) {
$wgLogo = "$wgStylePath/common/images/wiki.png";
}
$wgSkipSkins[] = $wgSkipSkin;
}
+// Register a hidden "fallback" skin
+$wgValidSkinNames['fallback'] = 'Fallback'; // SkinFallback
+$wgSkipSkins[] = 'fallback';
+
if ( $wgLocalInterwiki ) {
array_unshift( $wgLocalInterwikis, $wgLocalInterwiki );
}
--- /dev/null
+<?php
+/**
+ * Skin file for the fallback skin.
+ *
+ * The structure is copied from the example skin (mediawiki/skins/Example).
+ *
+ * @since 1.24
+ * @file
+ */
+
+/**
+ * SkinTemplate class for the fallback skin
+ */
+class SkinFallback extends SkinTemplate {
+ var $skinname = 'fallback', $template = 'SkinFallbackTemplate';
+
+ /**
+ * Add CSS via ResourceLoader
+ *
+ * @param $out OutputPage
+ */
+ function setupSkinUserCss( OutputPage $out ) {
+ parent::setupSkinUserCss( $out );
+ $out->addModuleStyles( 'mediawiki.skinning.interface' );
+ }
+}
+
+/**
+ * BaseTemplate class for the fallback skin
+ */
+class SkinFallbackTemplate extends BaseTemplate {
+ /**
+ * @return array
+ */
+ private function findInstalledSkins() {
+ global $wgStyleDirectory;
+
+ // Get all subdirectories which might contains skins
+ $possibleSkins = scandir( $wgStyleDirectory );
+ $possibleSkins = array_filter( $possibleSkins, function ( $maybeDir ) {
+ global $wgStyleDirectory;
+ return $maybeDir !== '.' && $maybeDir !== '..' && is_dir( "$wgStyleDirectory/$maybeDir" );
+ } );
+
+ // Only keep the ones that contain a .php file with the same name inside
+ $possibleSkins = array_filter( $possibleSkins, function ( $skinDir ) {
+ global $wgStyleDirectory;
+ return is_file( "$wgStyleDirectory/$skinDir/$skinDir.php" );
+ } );
+
+ return $possibleSkins;
+ }
+
+ /**
+ * Inform the user why they are seeing this skin.
+ *
+ * @return string
+ */
+ private function buildHelpfulInformationMessage() {
+ global $wgDefaultSkin, $wgValidSkinNames;
+
+ $installedSkins = $this->findInstalledSkins();
+ $enabledSkins = $wgValidSkinNames;
+ $enabledSkins = array_change_key_case( $enabledSkins, CASE_LOWER );
+
+ if ( $installedSkins ) {
+ $skinsInstalledText = array();
+ $skinsInstalledSnippet = array();
+
+ foreach ( $installedSkins as $skin ) {
+ $normalizedKey = strtolower( $skin );
+ $isEnabled = array_key_exists( $normalizedKey, $enabledSkins );
+ if ( $isEnabled ) {
+ $skinsInstalledText[] = $this->getMsg( 'default-skin-not-found-row-enabled' )
+ ->params( $normalizedKey, $skin )->plain();
+ } else {
+ $skinsInstalledText[] = $this->getMsg( 'default-skin-not-found-row-disabled' )
+ ->params( $normalizedKey, $skin )->plain();
+ $skinsInstalledSnippet[] = "require_once \"\$IP/skins/$skin/$skin.php\";";
+ }
+ }
+
+ return $this->getMsg( 'default-skin-not-found' )->params(
+ $wgDefaultSkin,
+ implode( "\n", $skinsInstalledText ),
+ implode( "\n", $skinsInstalledSnippet )
+ )->parseAsBlock();
+ } else {
+ return $this->getMsg( 'default-skin-not-found-no-skins' )->params(
+ $wgDefaultSkin
+ )->parseAsBlock();
+ }
+ }
+
+ /**
+ * Outputs the entire contents of the page. No navigation (other than search box), just the big
+ * warning message and page content.
+ */
+ public function execute() {
+ $this->html( 'headelement' ) ?>
+
+ <div class="warningbox">
+ <?php echo $this->buildHelpfulInformationMessage() ?>
+ </div>
+
+ <form action="<?php $this->text( 'wgScript' ) ?>">
+ <input type="hidden" name="title" value="<?php $this->text( 'searchtitle' ) ?>" />
+ <h3><label for="searchInput"><?php $this->msg( 'search' ) ?></label></h3>
+ <?php echo $this->makeSearchInput( array( "id" => "searchInput" ) ) ?>
+ <?php echo $this->makeSearchButton( 'go' ) ?>
+ </form>
+
+ <div class="mw-body" role="main">
+ <h1 class="firstHeading">
+ <span dir="auto"><?php $this->html( 'title' ) ?></span>
+ </h1>
+
+ <div class="mw-body-content">
+ <?php $this->html( 'bodytext' ) ?>
+ <?php $this->html( 'catlinks' ) ?>
+ </div>
+ </div>
+
+ <?php $this->printTrail() ?>
+ </body></html>
+
+ <?php
+ }
+}
}
}
-/**
- * Handle page unprotection
- *
- * This is a wrapper that will call Article::unprotect().
- *
- * @ingroup Actions
- */
-class UnprotectAction extends ProtectAction {
-
- public function getName() {
- return 'unprotect';
- }
-
- public function show() {
-
- $this->page->unprotect();
- }
-}
--- /dev/null
+<?php
+/**
+ * action=unprotect handler
+ *
+ * Copyright © 2012 Timo Tijhof
+ *
+ * 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
+ *
+ * @file
+ * @ingroup Actions
+ * @author Timo Tijhof
+ */
+
+/**
+ * Handle page unprotection
+ *
+ * This is a wrapper that will call Article::unprotect().
+ *
+ * @ingroup Actions
+ */
+class UnprotectAction extends ProtectAction {
+
+ public function getName() {
+ return 'unprotect';
+ }
+
+ public function show() {
+
+ $this->page->unprotect();
+ }
+}
\ No newline at end of file
--- /dev/null
+<?php
+/**
+ * Performs the unwatch actions on a page
+ *
+ * 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
+ *
+ * @file
+ * @ingroup Actions
+ */
+
+/**
+ * Page removal from a user's watchlist
+ *
+ * @ingroup Actions
+ */
+class UnwatchAction extends WatchAction {
+
+ public function getName() {
+ return 'unwatch';
+ }
+
+ protected function getDescription() {
+ return $this->msg( 'removewatch' )->escaped();
+ }
+
+ public function onSubmit( $data ) {
+ wfProfileIn( __METHOD__ );
+ self::doUnwatch( $this->getTitle(), $this->getUser() );
+ wfProfileOut( __METHOD__ );
+
+ return true;
+ }
+
+ protected function alterForm( HTMLForm $form ) {
+ $form->setSubmitTextMsg( 'confirm-unwatch-button' );
+ }
+
+ protected function preText() {
+ return $this->msg( 'confirm-unwatch-top' )->parse();
+ }
+
+ public function onSuccess() {
+ $this->getOutput()->addWikiMsg( 'removedwatchtext', $this->getTitle()->getPrefixedText() );
+ }
+}
<?php
/**
- * Performs the watch and unwatch actions on a page
+ * Performs the watch actions on a page
*
* 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
protected function checkCanExecute( User $user ) {
// Must be logged in
if ( $user->isAnon() ) {
- $loginreqlink = Linker::linkKnown(
- SpecialPage::getTitleFor( 'Userlogin' ),
- $this->msg( 'loginreqlink' )->escaped(),
- array(),
- array( 'returnto' => $this->getPageTitle(), 'returntoquery' => 'action=' . $this->getName() )
- );
- $reasonMsg = $this->msg( 'watchlistanontext' )->rawParams( $loginreqlink );
- throw new UserNotLoggedIn( $reasonMsg, 'watchnologin' );
+ throw new UserNotLoggedIn( 'watchlistanontext', 'watchnologin' );
}
return parent::checkCanExecute( $user );
$this->getOutput()->addWikiMsg( 'addedwatchtext', $this->getTitle()->getPrefixedText() );
}
}
-
-/**
- * Page removal from a user's watchlist
- *
- * @ingroup Actions
- */
-class UnwatchAction extends WatchAction {
-
- public function getName() {
- return 'unwatch';
- }
-
- protected function getDescription() {
- return $this->msg( 'removewatch' )->escaped();
- }
-
- public function onSubmit( $data ) {
- wfProfileIn( __METHOD__ );
- self::doUnwatch( $this->getTitle(), $this->getUser() );
- wfProfileOut( __METHOD__ );
-
- return true;
- }
-
- protected function alterForm( HTMLForm $form ) {
- $form->setSubmitTextMsg( 'confirm-unwatch-button' );
- }
-
- protected function preText() {
- return $this->msg( 'confirm-unwatch-top' )->parse();
- }
-
- public function onSuccess() {
- $this->getOutput()->addWikiMsg( 'removedwatchtext', $this->getTitle()->getPrefixedText() );
- }
-}
}
/**
- * Overriding class returns the mime type that should be sent to the client.
+ * Overriding class returns the MIME type that should be sent to the client.
* This method is not called if getIsHtml() returns true.
* @return string
*/
}
/**
- * Add a list of modules to the manager
- * @param array $modules A map of ModuleName => ModuleClass
+ * Add a list of modules to the manager. Each module is described
+ * by a module spec.
+ *
+ * Each module spec is an associative array containing at least
+ * the 'class' key for the module's class, and optionally a
+ * 'factory' key for the factory function to use for the module.
+ *
+ * That factory function will be called with two parameters,
+ * the parent module (an instance of ApiBase, usually ApiMain)
+ * and the name the module was registered under. The return
+ * value must be an instance of the class given in the 'class'
+ * field.
+ *
+ * For backward compatibility, the module spec may also be a
+ * simple string containing the module's class name. In that
+ * case, the class' constructor will be called with the parent
+ * module and module name as parameters, as described above.
+ *
+ * Examples for defining module specs:
+ *
+ * @code
+ * $modules['foo'] = 'ApiFoo';
+ * $modules['bar'] = array(
+ * 'class' => 'ApiBar',
+ * 'factory' => function( $main, $name ) { ... }
+ * );
+ * $modules['xyzzy'] = array(
+ * 'class' => 'ApiXyzzy',
+ * 'factory' => array( 'XyzzyFactory', 'newApiModule' )
+ * );
+ * @endcode
+ *
+ * @param array $modules A map of ModuleName => ModuleSpec; The ModuleSpec
+ * is either a string containing the module's class name, or an associative
+ * array (see above for details).
* @param string $group Which group modules belong to (action,format,...)
*/
public function addModules( array $modules, $group ) {
- foreach ( $modules as $name => $class ) {
- $this->addModule( $name, $group, $class );
+
+ foreach ( $modules as $name => $moduleSpec ) {
+ if ( is_array( $moduleSpec ) ) {
+ $class = $moduleSpec['class'];
+ $factory = ( isset( $moduleSpec['factory'] ) ? $moduleSpec['factory'] : null );
+ } else {
+ $class = $moduleSpec;
+ $factory = null;
+ }
+
+ $this->addModule( $name, $group, $class, $factory );
}
}
* classes who wish to add their own modules to their lexicon or override the
* behavior of inherent ones.
*
- * @param string $group Name of the module group
* @param string $name The identifier for this module.
+ * @param string $group Name of the module group
* @param string $class The class where this module is implemented.
+ * @param callable|null $factory Callback for instantiating the module.
+ *
+ * @throws InvalidArgumentException
*/
- public function addModule( $name, $group, $class ) {
+ public function addModule( $name, $group, $class, $factory = null ) {
+ if ( !is_string( $name ) ) {
+ throw new InvalidArgumentException( '$name must be a string' );
+ }
+
+ if ( !is_string( $group ) ) {
+ throw new InvalidArgumentException( '$group must be a string' );
+ }
+
+ if ( !is_string( $class ) ) {
+ throw new InvalidArgumentException( '$class must be a string' );
+ }
+
+ if ( $factory !== null && !is_callable( $factory ) ) {
+ throw new InvalidArgumentException( '$factory must be a callable (or null)' );
+ }
+
$this->mGroups[$group] = null;
- $this->mModules[$name] = array( $group, $class );
+ $this->mModules[$name] = array( $group, $class, $factory );
}
/**
* Get module instance by name, or instantiate it if it does not exist
+ *
* @param string $moduleName Module name
* @param string $group Optionally validate that the module is in a specific group
* @param bool $ignoreCache If true, force-creates a new instance and does not cache it
- * @return mixed The new module instance, or null if failed
+ *
+ * @return ApiBase|null The new module instance, or null if failed
*/
public function getModule( $moduleName, $group = null, $ignoreCache = false ) {
if ( !isset( $this->mModules[$moduleName] ) ) {
return null;
}
- $grpCls = $this->mModules[$moduleName];
- if ( $group !== null && $grpCls[0] !== $group ) {
+
+ list( $moduleGroup, $moduleClass, $moduleFactory ) = $this->mModules[$moduleName];
+
+ if ( $group !== null && $moduleGroup !== $group ) {
return null;
}
+
if ( !$ignoreCache && isset( $this->mInstances[$moduleName] ) ) {
// already exists
return $this->mInstances[$moduleName];
} else {
// new instance
- $class = $grpCls[1];
- $instance = new $class ( $this->mParent, $moduleName );
+ $instance = $this->instantiateModule( $moduleName, $moduleClass, $moduleFactory );
+
if ( !$ignoreCache ) {
// cache this instance in case it is needed later
$this->mInstances[$moduleName] = $instance;
}
}
+ /**
+ * Instantiate the module using the given class or factory function.
+ *
+ * @param string $name The identifier for this module.
+ * @param string $class The class where this module is implemented.
+ * @param callable|null $factory Callback for instantiating the module.
+ *
+ * @throws MWException
+ * @return ApiBase
+ */
+ private function instantiateModule( $name, $class, $factory = null ) {
+ if ( $factory !== null ) {
+ // create instance from factory
+ $instance = call_user_func( $factory, $this->mParent, $name );
+
+ if ( ! $instance instanceof $class ) {
+ throw new MWException( "The factory function for module $name did not return an instance of $class!" );
+ }
+ } else {
+ // create instance from class name
+ $instance = new $class( $this->mParent, $name );
+ }
+
+ return $instance;
+ }
+
/**
* Get an array of modules in a specific group or all if no group is set.
* @param string $group Optional group filter
public function execute() {
$params = $this->extractRequestParams();
+ $activeUserDays = $this->getConfig()->get( 'ActiveUserDays' );
if ( $params['activeusers'] ) {
// Update active user cache
- SpecialActiveUsers::mergeActiveUsers( 600 );
+ SpecialActiveUsers::mergeActiveUsers( 600, $activeUserDays );
}
$db = $this->getDB();
}
if ( $params['activeusers'] ) {
- $activeUserSeconds = $this->getConfig()->get( 'ActiveUserDays' ) * 86400;
+ $activeUserSeconds = $activeUserDays * 86400;
// Filter query to only include users in the active users cache
$this->addTables( 'querycachetwo' );
if ( isset( $prop['timestamp'] ) ) {
$vals['timestamp'] = wfTimestamp( TS_ISO_8601, $result->getTimestamp() );
}
- if ( !is_null( $result->getScore() ) && isset( $prop['score'] ) ) {
- $vals['score'] = $result->getScore();
- }
if ( isset( $prop['titlesnippet'] ) ) {
$vals['titlesnippet'] = $result->getTitleSnippet( $terms );
}
$params['timestamps'][$i] = wfTimestamp( TS_MW, $ts );
}
- $pa = new PageArchive( $titleObj );
+ $pa = new PageArchive( $titleObj, $this->getConfig() );
$retval = $pa->undelete(
( isset( $params['timestamps'] ) ? $params['timestamps'] : array() ),
$params['reason'],
* @file
*/
-define( 'MW_LC_VERSION', 2 );
-
/**
* Class for caching the contents of localisation files, Messages*.php
* and *.i18n.php.
* as grammatical transformation, is done by the caller.
*/
class LocalisationCache {
+ const VERSION = 2;
+
/** Configuration associative array */
private $conf;
# Add cache dependencies for any referenced globals
$deps['wgExtensionMessagesFiles'] = new GlobalDependency( 'wgExtensionMessagesFiles' );
$deps['wgMessagesDirs'] = new GlobalDependency( 'wgMessagesDirs' );
- $deps['version'] = new ConstantDependency( 'MW_LC_VERSION' );
+ $deps['version'] = new ConstantDependency( 'LocalisationCache::VERSION' );
# Add dependencies to the cache entry
$allData['deps'] = $deps;
*/
/**
- * Shows a generic "user is not logged in" error page.
+ * Redirect a user to the login page
*
* This is essentially an ErrorPageError exception which by default uses the
* 'exception-nologin' as a title and 'exception-nologin-text' for the message.
- * @see bug 37627
- * @since 1.20
+ *
+ * @note In order for this exception to redirect, the error message passed to the
+ * constructor has to be explicitly added to LoginForm::validErrorMessages. Otherwise,
+ * the user will just be shown the message rather than redirected.
*
* @par Example:
* @code
* }
* @endcode
*
+ * @see bug 37627
+ * @since 1.20
* @ingroup Exception
*/
class UserNotLoggedIn extends ErrorPageError {
/**
+ * @note The value of the $reasonMsg parameter must be put into LoginForm::validErrorMessages
+ * if you want the user to be automatically redirected to the login form.
+ *
* @param string $reasonMsg A message key containing the reason for the error.
* Optional, default: 'exception-nologin-text'
* @param string $titleMsg A message key to set the page title.
) {
parent::__construct( $titleMsg, $reasonMsg, $params );
}
+
+ /**
+ * Redirect to Special:Userlogin if the specified message is compatible. Otherwise,
+ * show an error page as usual.
+ */
+ public function report() {
+ // If an unsupported message is used, don't try redirecting to Special:Userlogin,
+ // since the message may not be compatible.
+ if ( !in_array( $this->msg, LoginForm::$validErrorMessages ) ) {
+ parent::report();
+ }
+
+ // Message is valid. Redirec to Special:Userlogin
+
+ $context = RequestContext::getMain();
+
+ $output = $context->getOutput();
+ $query = $context->getRequest()->getValues();
+ // Title will be overridden by returnto
+ unset( $query['title'] );
+ // Redirect to Special:Userlogin
+ $output->redirect( SpecialPage::getTitleFor( 'Userlogin' )->getFullURL( array(
+ // Return to this page when the user logs in
+ 'returnto' => $context->getTitle()->getFullText(),
+ 'returntoquery' => wfArrayToCgi( $query ),
+ 'warning' => $this->msg,
+ ) ) );
+
+ $output->output();
+ }
}
$ext = self::extensionFromPath( $this->path );
}
- # mime type according to file contents
+ # MIME type according to file contents
$info['file-mime'] = $this->getMimeType();
- # logical mime type
+ # logical MIME type
$info['mime'] = $magic->improveTypeFromExtension( $info['file-mime'], $ext );
list( $info['major_mime'], $info['minor_mime'] ) = File::splitMime( $info['mime'] );
* read a file into a string or several files into a map of path names to strings
* download a file or set of files to a temporary file (on a mounted file system)
* get the SHA1 hash of a file
-* get various properties of a file (stat information, content time, mime information, ...)
+* get various properties of a file (stat information, content time, MIME information, ...)
On directories:
* get a list of files directly under a directory
}
/**
- * Returns the mime type of the file.
+ * Returns the MIME type of the file.
* @return string
*/
public function getMimeType() {
}
/**
- * Returns the mime type of the file.
+ * Returns the MIME type of the file.
* Overridden by LocalFile, UnregisteredLocalFile
* STUB
*
/** @var int Result of the query for the file's history (nextHistoryLine) */
private $historyRes;
- /** @var string Major mime type */
+ /** @var string Major MIME type */
private $major_mime;
- /** @var string Minor mime type */
+ /** @var string Minor MIME type */
private $minor_mime;
/** @var string Upload timestamp */
}
/**
- * Returns the mime type of the file.
+ * Returns the MIME type of the file.
* @return string
*/
function getMimeType() {
"config-extensions-help": "Пашырэньні пададзеныя вышэй, былі знойдзеныя ў Вашай дырэкторыі <code>./extensions</code>.\n\nЯны могуць патрабаваць дадатковых наладаў, але іх можна ўключыць зараз",
"config-skins": "Тэмы афармленьня",
"config-skins-help": "Пералічаныя вышэй тэмы афармленьня знойдзеныя ў вашай тэчцы <code>./skins</code>. Вы мусіце ўключыць як мінімум адну, а таксама абраць тэму па змоўчаньні.",
+ "config-skins-use-as-default": "Выкарыстоўваць па змоўчаньні гэтую тэму афармленьня",
"config-install-alreadydone": "'''Папярэджаньне:''' здаецца, што Вы ўжо ўсталёўвалі MediaWiki і спрабуеце зрабіць гэтай зноў.\nКалі ласка, перайдзіце на наступную старонку.",
"config-install-begin": "Пасьля націску кнопкі «{{int:config-continue}}» пачнецца ўсталяваньне MediaWiki.\nКалі Вы жадаеце што-небудзь зьмяніць, націсьніце кнопку «{{int:config-back}}».",
"config-install-step-done": "зроблена",
"Filipinayzd"
]
},
+ "config-title": "Pabutang ka MediaWiki $1",
"config-information": "Impormasyon",
"config-your-language": "A kanimong sarita:",
"config-wiki-language": "Sarita ka Wiki:",
"config-db-host-oracle": "Database ka TNS:",
"config-db-wiki-settings": "Mibdiron adin wiki",
"config-db-name": "Ngaran ka database:",
+ "config-charset-mysql5-binary": "MySQL 4.1/5.0 binary",
"config-charset-mysql5": "MySQL 4.1/5.0 UTF-8",
+ "config-charset-mysql4": "MySQL 4.0 backwards-compatible UTF-8",
"config-db-port": "Port ka database:",
"config-db-schema": "Skema para sa MediaWiki:",
"config-sqlite-dir": "Direktoryo ka data sa SQLite:",
"config-oracle-def-ts": "Dating tablescape:",
"config-oracle-temp-ts": "Temporaryong tablescape:",
+ "config-type-mysql": "MySQL (o compatible)",
"config-type-mssql": "Microsoft SQL Server",
"config-header-mysql": "MySQL settings",
"config-header-postgres": "PostgreSQL settings",
"config-header-mssql": "Microsoft SQL Server settings",
"config-mysql-innodb": "InnoDB",
"config-mysql-myisam": "MyISAM",
+ "config-mysql-binary": "Binary",
"config-mysql-utf8": "UTF-8",
+ "config-site-name": "Ngaran ka wiki",
+ "config-site-name-blank": "Ibutang a ngaran ka site.",
+ "config-project-namespace": "Bibutangan ka proyekto:",
+ "config-ns-generic": "Proyekto",
"config-ns-other-default": "MyWiki",
"config-admin-password": "Password:",
"config-admin-password-confirm": "Password ulit:",
"config-admin-email": "Email address:",
"config-profile-wiki": "Bukas na wiki",
"config-profile-private": "Pribadong wiki",
+ "config-license-pd": "Pampublikong Domain",
+ "config-email-sender": "Pabalik na email adres:",
"config-logo": "URL ko logo:",
"config-cc-again": "Pumili dayday...",
"config-install-step-done": "tapus na",
+ "config-install-user-alreadyexists": "Agko na ka user na \"$1\"",
+ "config-install-user-create-failed": "Sala a ginigibong user na \"$1\": $2",
"config-help": "tabang"
}
"authors": [
"Peter Alberti",
"Christian List",
- "Tjernobyl"
+ "Tjernobyl",
+ "Thomsen"
]
},
"config-page-language": "Sprog",
"config-page-name": "Navn",
"config-page-options": "Indstillinger",
"config-page-install": "Installer",
+ "config-page-complete": "Færdig",
+ "config-page-restart": "Genstarte installation",
+ "config-page-readme": "Læs mig",
+ "config-page-copying": "Kopiering",
+ "config-page-upgradedoc": "Opgradering",
+ "config-page-existingwiki": "Eksisterende wiki",
+ "config-help-restart": "Vil du rydde alle gemte data, du har indtastet og genstarte installationen?",
+ "config-restart": "Ja, genstarte den",
+ "config-env-php": "PHP $1 er installeret.",
+ "config-db-type": "Databasetype:",
+ "config-db-host": "Database vært:",
+ "config-db-name": "Databasenavn:",
+ "config-mysql-old": "MySQL $1 eller nyere kræves. Du har $2.",
"config-header-mysql": "MySQL-indstillinger",
"config-header-postgres": "PostgreSQL-indstillinger",
"config-header-sqlite": "SQLite-indstillinger",
/* Protected Static Members */
- /** @var array List of common image files extensions and mime-types */
+ /** @var array List of common image files extensions and MIME-types */
protected static $mimeTypes = array(
'gif' => 'image/gif',
'jpe' => 'image/jpeg',
*/
public static function getMimeType( $file ) {
$realpath = realpath( $file );
- // Try a couple of different ways to get the mime-type of a file, in order of
+ // Try a couple of different ways to get the MIME-type of a file, in order of
// preference
if (
$realpath
&& function_exists( 'finfo_open' )
&& defined( 'FILEINFO_MIME_TYPE' )
) {
- // As of PHP 5.3, this is how you get the mime-type of a file; it uses the Fileinfo
+ // As of PHP 5.3, this is how you get the MIME-type of a file; it uses the Fileinfo
// PECL extension
return finfo_file( finfo_open( FILEINFO_MIME_TYPE ), $realpath );
} elseif ( function_exists( 'mime_content_type' ) ) {
- // Before this was deprecated in PHP 5.3, this was how you got the mime-type of a file
+ // Before this was deprecated in PHP 5.3, this was how you got the MIME-type of a file
return mime_content_type( $file );
} else {
- // Worst-case scenario has happened, use the file extension to infer the mime-type
+ // Worst-case scenario has happened, use the file extension to infer the MIME-type
$ext = strtolower( pathinfo( $file, PATHINFO_EXTENSION ) );
if ( isset( self::$mimeTypes[$ext] ) ) {
return self::$mimeTypes[$ext];
* @param string $chunk the first 256 bytes of the file
* @param string $proposed the MIME type proposed by the server
*
- * @return Array: map of IE version to detected mime type
+ * @return Array: map of IE version to detected MIME type
*/
public function getRealMimesFromData( $fileName, $chunk, $proposed ) {
$types = $this->getMimesFromData( $fileName, $chunk, $proposed );
* @param string $chunk the first 256 bytes of the file
* @param string $proposed the MIME type proposed by the server
*
- * @return Array: map of IE version to detected mime type
+ * @return Array: map of IE version to detected MIME type
*/
public function getMimesFromData( $fileName, $chunk, $proposed ) {
$types = array();
}
}
- if(!is_null($mime)) // fallback if the mime type is still unknown
+ if(!is_null($mime)) // fallback if the MIME type is still unknown
$url = sprintf('data:%s;base64,%s', $mime, base64_encode(file_get_contents($fullpath)));
}
}
function getThumbType( $ext, $mime, $params = null ) {
$magic = MimeMagic::singleton();
if ( !$ext || $magic->isMatchingExtension( $ext, $mime ) === false ) {
- // The extension is not valid for this mime type and we do
- // recognize the mime type
+ // The extension is not valid for this MIME type and we do
+ // recognize the MIME type
$extensions = $magic->getExtensionsForType( $mime );
if ( $extensions ) {
return array( strtok( $extensions, ' ' ), $mime );
}
}
- // The extension is correct (true) or the mime type is unknown to
+ // The extension is correct (true) or the MIME type is unknown to
// MediaWiki (null)
return array( $ext, $mime );
}
'mode' => XMPReader::MODE_SEQ,
'validate' => 'validateDate',
),
- /* Do not extract dc:format, as we've got better ways to determine mimetype */
+ /* Do not extract dc:format, as we've got better ways to determine MIME type */
'identifier' => array(
'map_group' => 'deprecated',
'map_name' => 'Identifier',
-# Mime type info file.
-# the first mime type in each line is the "main" mime type,
+# MIME type info file.
+# the first MIME type in each line is the "main" MIME type,
# the others are aliases for this type
# the media type is given in upper case and square brackets,
# like [BITMAP], and must indicate a media type as defined by
Xml::closeElement( 'form' );
if ( $user->isAllowed( 'editinterface' ) ) {
- $title = Title::makeTitle( NS_MEDIAWIKI, 'Deletereason-dropdown' );
+ $dropdownTitle = Title::makeTitle( NS_MEDIAWIKI, 'Deletereason-dropdown' );
$link = Linker::link(
- $title,
+ $dropdownTitle,
wfMessage( 'delete-edit-reasonlist' )->escaped(),
array(),
array( 'action' => 'edit' )
// but were preserved for backwards-compatibility just in case. Tread lightly.
$localBasePath = $localBasePath === null ? $IP : $localBasePath;
- if ( $remoteBasePath !== null ) {
- $remoteBasePath = $remoteBasePath;
- } else {
+ if ( $remoteBasePath === null ) {
$remoteBasePath = $wgResourceBasePath === null ? $wgScriptPath : $wgResourceBasePath;
}
--- /dev/null
+<?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
+ * @ingroup RevisionDelete
+ */
+
+/**
+ * Item class for a archive table row
+ */
+class RevDelArchiveItem extends RevDelRevisionItem {
+ public function __construct( $list, $row ) {
+ RevDelItem::__construct( $list, $row );
+ $this->revision = Revision::newFromArchiveRow( $row, array( 'page' => $this->list->title->getArticleID() ) );
+ }
+
+ public function getIdField() {
+ return 'ar_timestamp';
+ }
+
+ public function getTimestampField() {
+ return 'ar_timestamp';
+ }
+
+ public function getAuthorIdField() {
+ return 'ar_user';
+ }
+
+ public function getAuthorNameField() {
+ return 'ar_user_text';
+ }
+
+ public function getId() {
+ # Convert DB timestamp to MW timestamp
+ return $this->revision->getTimestamp();
+ }
+
+ public function setBits( $bits ) {
+ $dbw = wfGetDB( DB_MASTER );
+ $dbw->update( 'archive', array( 'ar_deleted' => $bits ), array( 'ar_namespace' => $this->list->title->getNamespace(), 'ar_title' => $this->list->title->getDBkey(), // use timestamp for index
+ 'ar_timestamp' => $this->row->ar_timestamp, 'ar_rev_id' => $this->row->ar_rev_id, 'ar_deleted' => $this->getBits() ), __METHOD__ );
+
+ return (bool) $dbw->affectedRows();
+ }
+
+ protected function getRevisionLink() {
+ $date = htmlspecialchars( $this->list->getLanguage()->userTimeAndDate( $this->revision->getTimestamp(), $this->list->getUser() ) );
+
+ if ( $this->isDeleted() && !$this->canViewContent() ) {
+ return $date;
+ }
+
+ return Linker::link( SpecialPage::getTitleFor( 'Undelete' ), $date, array(), array( 'target' => $this->list->title->getPrefixedText(), 'timestamp' => $this->revision->getTimestamp() ) );
+ }
+
+ protected function getDiffLink() {
+ if ( $this->isDeleted() && !$this->canViewContent() ) {
+ return $this->list->msg( 'diff' )->escaped();
+ }
+
+ return Linker::link( SpecialPage::getTitleFor( 'Undelete' ), $this->list->msg( 'diff' )->escaped(), array(), array( 'target' => $this->list->title->getPrefixedText(), 'diff' => 'prev', 'timestamp' => $this->revision->getTimestamp() ) );
+ }
+}
\ No newline at end of file
--- /dev/null
+<?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
+ * @ingroup RevisionDelete
+ */
+
+/**
+ * List for archive table items, i.e. revisions deleted via action=delete
+ */
+class RevDelArchiveList extends RevDelRevisionList {
+ public function getType() {
+ return 'archive';
+ }
+
+ public static function getRelationType() {
+ return 'ar_timestamp';
+ }
+
+ /**
+ * @param DatabaseBase $db
+ * @return mixed
+ */
+ public function doQuery( $db ) {
+ $timestamps = array();
+ foreach ( $this->ids as $id ) {
+ $timestamps[] = $db->timestamp( $id );
+ }
+
+ return $db->select( 'archive', Revision::selectArchiveFields(), array( 'ar_namespace' => $this->title->getNamespace(), 'ar_title' => $this->title->getDBkey(), 'ar_timestamp' => $timestamps ), __METHOD__, array( 'ORDER BY' => 'ar_timestamp DESC' ) );
+ }
+
+ public function newItem( $row ) {
+ return new RevDelArchiveItem( $this, $row );
+ }
+
+ public function doPreCommitUpdates() {
+ return Status::newGood();
+ }
+
+ public function doPostCommitUpdates() {
+ return Status::newGood();
+ }
+}
\ No newline at end of file
--- /dev/null
+<?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
+ * @ingroup RevisionDelete
+ */
+
+/**
+ * Item class for a filearchive table row
+ */
+class RevDelArchivedFileItem extends RevDelFileItem {
+ public function __construct( $list, $row ) {
+ RevDelItem::__construct( $list, $row );
+ $this->file = ArchivedFile::newFromRow( $row );
+ }
+
+ public function getIdField() {
+ return 'fa_id';
+ }
+
+ public function getTimestampField() {
+ return 'fa_timestamp';
+ }
+
+ public function getAuthorIdField() {
+ return 'fa_user';
+ }
+
+ public function getAuthorNameField() {
+ return 'fa_user_text';
+ }
+
+ public function getId() {
+ return $this->row->fa_id;
+ }
+
+ public function setBits( $bits ) {
+ $dbw = wfGetDB( DB_MASTER );
+ $dbw->update( 'filearchive', array( 'fa_deleted' => $bits ), array( 'fa_id' => $this->row->fa_id, 'fa_deleted' => $this->getBits(), ), __METHOD__ );
+
+ return (bool) $dbw->affectedRows();
+ }
+
+ protected function getLink() {
+ $date = htmlspecialchars( $this->list->getLanguage()->userTimeAndDate( $this->file->getTimestamp(), $this->list->getUser() ) );
+
+ # Hidden files...
+ if ( !$this->canViewContent() ) {
+ $link = $date;
+ } else {
+ $undelete = SpecialPage::getTitleFor( 'Undelete' );
+ $key = $this->file->getKey();
+ $link = Linker::link( $undelete, $date, array(), array( 'target' => $this->list->title->getPrefixedText(), 'file' => $key, 'token' => $this->list->getUser()->getEditToken( $key ) ) );
+ }
+ if ( $this->isDeleted() ) {
+ $link = '<span class="history-deleted">' . $link . '</span>';
+ }
+
+ return $link;
+ }
+
+ public function getApiData( ApiResult $result ) {
+ $file = $this->file;
+ $user = $this->list->getUser();
+ $ret = array( 'title' => $this->list->title->getPrefixedText(), 'timestamp' => wfTimestamp( TS_ISO_8601, $file->getTimestamp() ), 'width' => $file->getWidth(), 'height' => $file->getHeight(), 'size' => $file->getSize(), );
+ $ret += $file->isDeleted( Revision::DELETED_USER ) ? array( 'userhidden' => '' ) : array();
+ $ret += $file->isDeleted( Revision::DELETED_COMMENT ) ? array( 'commenthidden' => '' ) : array();
+ $ret += $this->isDeleted() ? array( 'contenthidden' => '' ) : array();
+ if ( $this->canViewContent() ) {
+ $ret += array( 'url' => SpecialPage::getTitleFor( 'Revisiondelete' )->getLinkURL( array( 'target' => $this->list->title->getPrefixedText(), 'file' => $file->getKey(), 'token' => $user->getEditToken( $file->getKey() ) ), false, PROTO_RELATIVE ), );
+ }
+ if ( $file->userCan( Revision::DELETED_USER, $user ) ) {
+ $ret += array( 'userid' => $file->getUser( 'id' ), 'user' => $file->getUser( 'text' ), );
+ }
+ if ( $file->userCan( Revision::DELETED_COMMENT, $user ) ) {
+ $ret += array( 'comment' => $file->getRawDescription(), );
+ }
+
+ return $ret;
+ }
+}
\ No newline at end of file
--- /dev/null
+<?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
+ * @ingroup RevisionDelete
+ */
+
+/**
+ * List for filearchive table items
+ */
+class RevDelArchivedFileList extends RevDelFileList {
+ public function getType() {
+ return 'filearchive';
+ }
+
+ public static function getRelationType() {
+ return 'fa_id';
+ }
+
+ /**
+ * @param DatabaseBase $db
+ * @return mixed
+ */
+ public function doQuery( $db ) {
+ $ids = array_map( 'intval', $this->ids );
+
+ return $db->select( 'filearchive', ArchivedFile::selectFields(), array( 'fa_name' => $this->title->getDBkey(), 'fa_id' => $ids ), __METHOD__, array( 'ORDER BY' => 'fa_id DESC' ) );
+ }
+
+ public function newItem( $row ) {
+ return new RevDelArchivedFileItem( $this, $row );
+ }
+}
\ No newline at end of file
--- /dev/null
+<?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
+ * @ingroup RevisionDelete
+ */
+
+/**
+ * Item class for a archive table row by ar_rev_id -- actually
+ * used via RevDelRevisionList.
+ */
+class RevDelArchivedRevisionItem extends RevDelArchiveItem {
+ public function __construct( $list, $row ) {
+ RevDelItem::__construct( $list, $row );
+
+ $this->revision = Revision::newFromArchiveRow( $row, array( 'page' => $this->list->title->getArticleID() ) );
+ }
+
+ public function getIdField() {
+ return 'ar_rev_id';
+ }
+
+ public function getId() {
+ return $this->revision->getId();
+ }
+
+ public function setBits( $bits ) {
+ $dbw = wfGetDB( DB_MASTER );
+ $dbw->update( 'archive', array( 'ar_deleted' => $bits ), array( 'ar_rev_id' => $this->row->ar_rev_id, 'ar_deleted' => $this->getBits() ), __METHOD__ );
+
+ return (bool) $dbw->affectedRows();
+ }
+}
\ No newline at end of file
--- /dev/null
+<?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
+ * @ingroup RevisionDelete
+ */
+
+/**
+ * Item class for an oldimage table row
+ */
+class RevDelFileItem extends RevDelItem {
+ /** @var File */
+ var $file;
+
+ public function __construct( $list, $row ) {
+ parent::__construct( $list, $row );
+ $this->file = RepoGroup::singleton()->getLocalRepo()->newFileFromRow( $row );
+ }
+
+ public function getIdField() {
+ return 'oi_archive_name';
+ }
+
+ public function getTimestampField() {
+ return 'oi_timestamp';
+ }
+
+ public function getAuthorIdField() {
+ return 'oi_user';
+ }
+
+ public function getAuthorNameField() {
+ return 'oi_user_text';
+ }
+
+ public function getId() {
+ $parts = explode( '!', $this->row->oi_archive_name );
+
+ return $parts[0];
+ }
+
+ public function canView() {
+ return $this->file->userCan( File::DELETED_RESTRICTED, $this->list->getUser() );
+ }
+
+ public function canViewContent() {
+ return $this->file->userCan( File::DELETED_FILE, $this->list->getUser() );
+ }
+
+ public function getBits() {
+ return $this->file->getVisibility();
+ }
+
+ public function setBits( $bits ) {
+ # Queue the file op
+ # @todo FIXME: Move to LocalFile.php
+ if ( $this->isDeleted() ) {
+ if ( $bits & File::DELETED_FILE ) {
+ # Still deleted
+ } else {
+ # Newly undeleted
+ $key = $this->file->getStorageKey();
+ $srcRel = $this->file->repo->getDeletedHashPath( $key ) . $key;
+ $this->list->storeBatch[] = array( $this->file->repo->getVirtualUrl( 'deleted' ) . '/' . $srcRel, 'public', $this->file->getRel() );
+ $this->list->cleanupBatch[] = $key;
+ }
+ } elseif ( $bits & File::DELETED_FILE ) {
+ # Newly deleted
+ $key = $this->file->getStorageKey();
+ $dstRel = $this->file->repo->getDeletedHashPath( $key ) . $key;
+ $this->list->deleteBatch[] = array( $this->file->getRel(), $dstRel );
+ }
+
+ # Do the database operations
+ $dbw = wfGetDB( DB_MASTER );
+ $dbw->update( 'oldimage', array( 'oi_deleted' => $bits ), array( 'oi_name' => $this->row->oi_name, 'oi_timestamp' => $this->row->oi_timestamp, 'oi_deleted' => $this->getBits() ), __METHOD__ );
+
+ return (bool) $dbw->affectedRows();
+ }
+
+ public function isDeleted() {
+ return $this->file->isDeleted( File::DELETED_FILE );
+ }
+
+ /**
+ * Get the link to the file.
+ * Overridden by RevDelArchivedFileItem.
+ * @return string
+ */
+ protected function getLink() {
+ $date = htmlspecialchars( $this->list->getLanguage()->userTimeAndDate( $this->file->getTimestamp(), $this->list->getUser() ) );
+
+ if ( !$this->isDeleted() ) {
+ # Regular files...
+ return Html::rawElement( 'a', array( 'href' => $this->file->getUrl() ), $date );
+ }
+
+ # Hidden files...
+ if ( !$this->canViewContent() ) {
+ $link = $date;
+ } else {
+ $link = Linker::link( SpecialPage::getTitleFor( 'Revisiondelete' ), $date, array(), array( 'target' => $this->list->title->getPrefixedText(), 'file' => $this->file->getArchiveName(), 'token' => $this->list->getUser()->getEditToken( $this->file->getArchiveName() ) ) );
+ }
+
+ return '<span class="history-deleted">' . $link . '</span>';
+ }
+
+ /**
+ * Generate a user tool link cluster if the current user is allowed to view it
+ * @return string HTML
+ */
+ protected function getUserTools() {
+ if ( $this->file->userCan( Revision::DELETED_USER, $this->list->getUser() ) ) {
+ $uid = $this->file->getUser( 'id' );
+ $name = $this->file->getUser( 'text' );
+ $link = Linker::userLink( $uid, $name ) . Linker::userToolLinks( $uid, $name );
+ } else {
+ $link = $this->list->msg( 'rev-deleted-user' )->escaped();
+ }
+ if ( $this->file->isDeleted( Revision::DELETED_USER ) ) {
+ return '<span class="history-deleted">' . $link . '</span>';
+ }
+
+ return $link;
+ }
+
+ /**
+ * Wrap and format the file's comment block, if the current
+ * user is allowed to view it.
+ *
+ * @return string HTML
+ */
+ protected function getComment() {
+ if ( $this->file->userCan( File::DELETED_COMMENT, $this->list->getUser() ) ) {
+ $block = Linker::commentBlock( $this->file->getDescription() );
+ } else {
+ $block = ' ' . $this->list->msg( 'rev-deleted-comment' )->escaped();
+ }
+ if ( $this->file->isDeleted( File::DELETED_COMMENT ) ) {
+ return "<span class=\"history-deleted\">$block</span>";
+ }
+
+ return $block;
+ }
+
+ public function getHTML() {
+ $data = $this->list->msg( 'widthheight' )->numParams( $this->file->getWidth(), $this->file->getHeight() )->text() . ' (' . $this->list->msg( 'nbytes' )->numParams( $this->file->getSize() )->text() . ')';
+
+ return '<li>' . $this->getLink() . ' ' . $this->getUserTools() . ' ' . $data . ' ' . $this->getComment() . '</li>';
+ }
+
+ public function getApiData( ApiResult $result ) {
+ $file = $this->file;
+ $user = $this->list->getUser();
+ $ret = array( 'title' => $this->list->title->getPrefixedText(), 'archivename' => $file->getArchiveName(), 'timestamp' => wfTimestamp( TS_ISO_8601, $file->getTimestamp() ), 'width' => $file->getWidth(), 'height' => $file->getHeight(), 'size' => $file->getSize(), );
+ $ret += $file->isDeleted( Revision::DELETED_USER ) ? array( 'userhidden' => '' ) : array();
+ $ret += $file->isDeleted( Revision::DELETED_COMMENT ) ? array( 'commenthidden' => '' ) : array();
+ $ret += $this->isDeleted() ? array( 'contenthidden' => '' ) : array();
+ if ( !$this->isDeleted() ) {
+ $ret += array( 'url' => $file->getUrl(), );
+ } elseif ( $this->canViewContent() ) {
+ $ret += array( 'url' => SpecialPage::getTitleFor( 'Revisiondelete' )->getLinkURL( array( 'target' => $this->list->title->getPrefixedText(), 'file' => $file->getArchiveName(), 'token' => $user->getEditToken( $file->getArchiveName() ) ), false, PROTO_RELATIVE ), );
+ }
+ if ( $file->userCan( Revision::DELETED_USER, $user ) ) {
+ $ret += array( 'userid' => $file->user, 'user' => $file->user_text, );
+ }
+ if ( $file->userCan( Revision::DELETED_COMMENT, $user ) ) {
+ $ret += array( 'comment' => $file->description, );
+ }
+
+ return $ret;
+ }
+}
\ No newline at end of file
--- /dev/null
+<?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
+ * @ingroup RevisionDelete
+ */
+
+/**
+ * List for oldimage table items
+ */
+class RevDelFileList extends RevDelList {
+ /** @var array */
+ var $storeBatch;
+
+ /** @var array */
+ var $deleteBatch;
+
+ /** @var array */
+ var $cleanupBatch;
+
+ public function getType() {
+ return 'oldimage';
+ }
+
+ public static function getRelationType() {
+ return 'oi_archive_name';
+ }
+
+ public static function getRestriction() {
+ return 'deleterevision';
+ }
+
+ public static function getRevdelConstant() {
+ return File::DELETED_FILE;
+ }
+
+ /**
+ * @param DatabaseBase $db
+ * @return mixed
+ */
+ public function doQuery( $db ) {
+ $archiveNames = array();
+ foreach ( $this->ids as $timestamp ) {
+ $archiveNames[] = $timestamp . '!' . $this->title->getDBkey();
+ }
+
+ return $db->select( 'oldimage', OldLocalFile::selectFields(), array( 'oi_name' => $this->title->getDBkey(), 'oi_archive_name' => $archiveNames ), __METHOD__, array( 'ORDER BY' => 'oi_timestamp DESC' ) );
+ }
+
+ public function newItem( $row ) {
+ return new RevDelFileItem( $this, $row );
+ }
+
+ public function clearFileOps() {
+ $this->deleteBatch = array();
+ $this->storeBatch = array();
+ $this->cleanupBatch = array();
+ }
+
+ public function doPreCommitUpdates() {
+ $status = Status::newGood();
+ $repo = RepoGroup::singleton()->getLocalRepo();
+ if ( $this->storeBatch ) {
+ $status->merge( $repo->storeBatch( $this->storeBatch, FileRepo::OVERWRITE_SAME ) );
+ }
+ if ( !$status->isOK() ) {
+ return $status;
+ }
+ if ( $this->deleteBatch ) {
+ $status->merge( $repo->deleteBatch( $this->deleteBatch ) );
+ }
+ if ( !$status->isOK() ) {
+ // Running cleanupDeletedBatch() after a failed storeBatch() with the DB already
+ // modified (but destined for rollback) causes data loss
+ return $status;
+ }
+ if ( $this->cleanupBatch ) {
+ $status->merge( $repo->cleanupDeletedBatch( $this->cleanupBatch ) );
+ }
+
+ return $status;
+ }
+
+ public function doPostCommitUpdates() {
+ $file = wfLocalFile( $this->title );
+ $file->purgeCache();
+ $file->purgeDescription();
+ $purgeUrls = array();
+ foreach ( $this->ids as $timestamp ) {
+ $archiveName = $timestamp . '!' . $this->title->getDBkey();
+ $file->purgeOldThumbnails( $archiveName );
+ $purgeUrls[] = $file->getArchiveUrl( $archiveName );
+ }
+ if ( $this->getConfig()->get( 'UseSquid' ) ) {
+ // purge full images from cache
+ SquidUpdate::purge( $purgeUrls );
+ }
+
+ return Status::newGood();
+ }
+
+ public function getSuppressBit() {
+ return File::DELETED_RESTRICTED;
+ }
+}
\ No newline at end of file
--- /dev/null
+<?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
+ * @ingroup RevisionDelete
+ */
+
+/**
+ * Item class for a logging table row
+ */
+class RevDelLogItem extends RevDelItem {
+ public function getIdField() {
+ return 'log_id';
+ }
+
+ public function getTimestampField() {
+ return 'log_timestamp';
+ }
+
+ public function getAuthorIdField() {
+ return 'log_user';
+ }
+
+ public function getAuthorNameField() {
+ return 'log_user_text';
+ }
+
+ public function canView() {
+ return LogEventsList::userCan( $this->row, Revision::DELETED_RESTRICTED, $this->list->getUser() );
+ }
+
+ public function canViewContent() {
+ return true; // none
+ }
+
+ public function getBits() {
+ return $this->row->log_deleted;
+ }
+
+ public function setBits( $bits ) {
+ $dbw = wfGetDB( DB_MASTER );
+ $dbw->update( 'recentchanges', array( 'rc_deleted' => $bits, 'rc_patrolled' => 1 ), array( 'rc_logid' => $this->row->log_id, 'rc_timestamp' => $this->row->log_timestamp // index
+ ), __METHOD__ );
+ $dbw->update( 'logging', array( 'log_deleted' => $bits ), array( 'log_id' => $this->row->log_id, 'log_deleted' => $this->getBits() ), __METHOD__ );
+
+ return (bool) $dbw->affectedRows();
+ }
+
+ public function getHTML() {
+ $date = htmlspecialchars( $this->list->getLanguage()->userTimeAndDate( $this->row->log_timestamp, $this->list->getUser() ) );
+ $title = Title::makeTitle( $this->row->log_namespace, $this->row->log_title );
+ $formatter = LogFormatter::newFromRow( $this->row );
+ $formatter->setContext( $this->list->getContext() );
+ $formatter->setAudience( LogFormatter::FOR_THIS_USER );
+
+ // Log link for this page
+ $loglink = Linker::link( SpecialPage::getTitleFor( 'Log' ), $this->list->msg( 'log' )->escaped(), array(), array( 'page' => $title->getPrefixedText() ) );
+ $loglink = $this->list->msg( 'parentheses' )->rawParams( $loglink )->escaped();
+ // User links and action text
+ $action = $formatter->getActionText();
+ // Comment
+ $comment = $this->list->getLanguage()->getDirMark() . Linker::commentBlock( $this->row->log_comment );
+
+ if ( LogEventsList::isDeleted( $this->row, LogPage::DELETED_COMMENT ) ) {
+ $comment = '<span class="history-deleted">' . $comment . '</span>';
+ }
+
+ return "<li>$loglink $date $action $comment</li>";
+ }
+
+ public function getApiData( ApiResult $result ) {
+ $logEntry = DatabaseLogEntry::newFromRow( $this->row );
+ $user = $this->list->getUser();
+ $ret = array( 'id' => $logEntry->getId(), 'type' => $logEntry->getType(), 'action' => $logEntry->getSubtype(), );
+ $ret += $logEntry->isDeleted( LogPage::DELETED_USER ) ? array( 'userhidden' => '' ) : array();
+ $ret += $logEntry->isDeleted( LogPage::DELETED_COMMENT ) ? array( 'commenthidden' => '' ) : array();
+ $ret += $logEntry->isDeleted( LogPage::DELETED_ACTION ) ? array( 'actionhidden' => '' ) : array();
+
+ if ( LogEventsList::userCan( $this->row, LogPage::DELETED_ACTION, $user ) ) {
+ ApiQueryLogEvents::addLogParams( $result, $ret, $logEntry->getParameters(), $logEntry->getType(), $logEntry->getSubtype(), $logEntry->getTimestamp(), $logEntry->isLegacy() );
+ }
+ if ( LogEventsList::userCan( $this->row, LogPage::DELETED_USER, $user ) ) {
+ $ret += array( 'userid' => $this->row->log_user, 'user' => $this->row->log_user_text, );
+ }
+ if ( LogEventsList::userCan( $this->row, LogPage::DELETED_COMMENT, $user ) ) {
+ $ret += array( 'comment' => $this->row->log_comment, );
+ }
+
+ return $ret;
+ }
+}
\ No newline at end of file
--- /dev/null
+<?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
+ * @ingroup RevisionDelete
+ */
+
+/**
+ * List for logging table items
+ */
+class RevDelLogList extends RevDelList {
+ public function getType() {
+ return 'logging';
+ }
+
+ public static function getRelationType() {
+ return 'log_id';
+ }
+
+ public static function getRestriction() {
+ return 'deletelogentry';
+ }
+
+ public static function getRevdelConstant() {
+ return LogPage::DELETED_ACTION;
+ }
+
+ public static function suggestTarget( $target, array $ids ) {
+ $result = wfGetDB( DB_SLAVE )->select( 'logging', 'log_type', array( 'log_id' => $ids ), __METHOD__, array( 'DISTINCT' ) );
+ if ( $result->numRows() == 1 ) {
+ // If there's only one type, the target can be set to include it.
+ return SpecialPage::getTitleFor( 'Log', $result->current()->log_type );
+ }
+
+ return SpecialPage::getTitleFor( 'Log' );
+ }
+
+ /**
+ * @param DatabaseBase $db
+ * @return mixed
+ */
+ public function doQuery( $db ) {
+ $ids = array_map( 'intval', $this->ids );
+
+ return $db->select( 'logging', array( 'log_id', 'log_type', 'log_action', 'log_timestamp', 'log_user', 'log_user_text', 'log_namespace', 'log_title', 'log_page', 'log_comment', 'log_params', 'log_deleted' ), array( 'log_id' => $ids ), __METHOD__, array( 'ORDER BY' => 'log_id DESC' ) );
+ }
+
+ public function newItem( $row ) {
+ return new RevDelLogItem( $this, $row );
+ }
+
+ public function getSuppressBit() {
+ return Revision::DELETED_RESTRICTED;
+ }
+
+ public function getLogAction() {
+ return 'event';
+ }
+
+ public function getLogParams( $params ) {
+ return array( implode( ',', $params['ids'] ), "ofield={$params['oldBits']}", "nfield={$params['newBits']}" );
+ }
+}
\ No newline at end of file
--- /dev/null
+<?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
+ * @ingroup RevisionDelete
+ */
+
+/**
+ * Item class for a live revision table row
+ */
+class RevDelRevisionItem extends RevDelItem {
+ /** @var Revision */
+ var $revision;
+
+ public function __construct( $list, $row ) {
+ parent::__construct( $list, $row );
+ $this->revision = new Revision( $row );
+ }
+
+ public function getIdField() {
+ return 'rev_id';
+ }
+
+ public function getTimestampField() {
+ return 'rev_timestamp';
+ }
+
+ public function getAuthorIdField() {
+ return 'rev_user';
+ }
+
+ public function getAuthorNameField() {
+ return 'rev_user_text';
+ }
+
+ public function canView() {
+ return $this->revision->userCan( Revision::DELETED_RESTRICTED, $this->list->getUser() );
+ }
+
+ public function canViewContent() {
+ return $this->revision->userCan( Revision::DELETED_TEXT, $this->list->getUser() );
+ }
+
+ public function getBits() {
+ return $this->revision->getVisibility();
+ }
+
+ public function setBits( $bits ) {
+ $dbw = wfGetDB( DB_MASTER );
+ // Update revision table
+ $dbw->update( 'revision', array( 'rev_deleted' => $bits ), array( 'rev_id' => $this->revision->getId(), 'rev_page' => $this->revision->getPage(), 'rev_deleted' => $this->getBits() ), __METHOD__ );
+ if ( !$dbw->affectedRows() ) {
+ // Concurrent fail!
+ return false;
+ }
+ // Update recentchanges table
+ $dbw->update( 'recentchanges', array( 'rc_deleted' => $bits, 'rc_patrolled' => 1 ), array( 'rc_this_oldid' => $this->revision->getId(), // condition
+ // non-unique timestamp index
+ 'rc_timestamp' => $dbw->timestamp( $this->revision->getTimestamp() ), ), __METHOD__ );
+
+ return true;
+ }
+
+ public function isDeleted() {
+ return $this->revision->isDeleted( Revision::DELETED_TEXT );
+ }
+
+ public function isHideCurrentOp( $newBits ) {
+ return ( $newBits & Revision::DELETED_TEXT ) && $this->list->getCurrent() == $this->getId();
+ }
+
+ /**
+ * Get the HTML link to the revision text.
+ * Overridden by RevDelArchiveItem.
+ * @return string
+ */
+ protected function getRevisionLink() {
+ $date = htmlspecialchars( $this->list->getLanguage()->userTimeAndDate( $this->revision->getTimestamp(), $this->list->getUser() ) );
+
+ if ( $this->isDeleted() && !$this->canViewContent() ) {
+ return $date;
+ }
+
+ return Linker::linkKnown( $this->list->title, $date, array(), array( 'oldid' => $this->revision->getId(), 'unhide' => 1 ) );
+ }
+
+ /**
+ * Get the HTML link to the diff.
+ * Overridden by RevDelArchiveItem
+ * @return string
+ */
+ protected function getDiffLink() {
+ if ( $this->isDeleted() && !$this->canViewContent() ) {
+ return $this->list->msg( 'diff' )->escaped();
+ } else {
+ return Linker::linkKnown( $this->list->title, $this->list->msg( 'diff' )->escaped(), array(), array( 'diff' => $this->revision->getId(), 'oldid' => 'prev', 'unhide' => 1 ) );
+ }
+ }
+
+ public function getHTML() {
+ $difflink = $this->list->msg( 'parentheses' )
+ ->rawParams( $this->getDiffLink() )->escaped();
+ $revlink = $this->getRevisionLink();
+ $userlink = Linker::revUserLink( $this->revision );
+ $comment = Linker::revComment( $this->revision );
+ if ( $this->isDeleted() ) {
+ $revlink = "<span class=\"history-deleted\">$revlink</span>";
+ }
+
+ return "<li>$difflink $revlink $userlink $comment</li>";
+ }
+
+ public function getApiData( ApiResult $result ) {
+ $rev = $this->revision;
+ $user = $this->list->getUser();
+ $ret = array( 'id' => $rev->getId(), 'timestamp' => wfTimestamp( TS_ISO_8601, $rev->getTimestamp() ), );
+ $ret += $rev->isDeleted( Revision::DELETED_USER ) ? array( 'userhidden' => '' ) : array();
+ $ret += $rev->isDeleted( Revision::DELETED_COMMENT ) ? array( 'commenthidden' => '' ) : array();
+ $ret += $rev->isDeleted( Revision::DELETED_TEXT ) ? array( 'texthidden' => '' ) : array();
+ if ( $rev->userCan( Revision::DELETED_USER, $user ) ) {
+ $ret += array( 'userid' => $rev->getUser( Revision::FOR_THIS_USER ), 'user' => $rev->getUserText( Revision::FOR_THIS_USER ), );
+ }
+ if ( $rev->userCan( Revision::DELETED_COMMENT, $user ) ) {
+ $ret += array( 'comment' => $rev->getComment( Revision::FOR_THIS_USER ), );
+ }
+
+ return $ret;
+ }
+}
\ No newline at end of file
--- /dev/null
+<?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
+ * @ingroup RevisionDelete
+ */
+
+/**
+ * List for revision table items
+ *
+ * This will check both the 'revision' table for live revisions and the
+ * 'archive' table for traditionally-deleted revisions that have an
+ * ar_rev_id saved.
+ *
+ * See RevDelRevisionItem and RevDelArchivedRevisionItem for items.
+ */
+class RevDelRevisionList extends RevDelList {
+ /** @var int */
+ var $currentRevId;
+
+ public function getType() {
+ return 'revision';
+ }
+
+ public static function getRelationType() {
+ return 'rev_id';
+ }
+
+ public static function getRestriction() {
+ return 'deleterevision';
+ }
+
+ public static function getRevdelConstant() {
+ return Revision::DELETED_TEXT;
+ }
+
+ public static function suggestTarget( $target, array $ids ) {
+ $rev = Revision::newFromId( $ids[0] );
+ return $rev ? $rev->getTitle() : $target;
+ }
+
+ /**
+ * @param DatabaseBase $db
+ * @return mixed
+ */
+ public function doQuery( $db ) {
+ $ids = array_map( 'intval', $this->ids );
+ $live = $db->select(
+ array( 'revision', 'page', 'user' ),
+ array_merge( Revision::selectFields(), Revision::selectUserFields() ),
+ array(
+ 'rev_page' => $this->title->getArticleID(),
+ 'rev_id' => $ids,
+ ),
+ __METHOD__,
+ array( 'ORDER BY' => 'rev_id DESC' ),
+ array(
+ 'page' => Revision::pageJoinCond(),
+ 'user' => Revision::userJoinCond() )
+ );
+
+ if ( $live->numRows() >= count( $ids ) ) {
+ // All requested revisions are live, keeps things simple!
+ return $live;
+ }
+
+ // Check if any requested revisions are available fully deleted.
+ $archived = $db->select( array( 'archive' ), Revision::selectArchiveFields(),
+ array(
+ 'ar_rev_id' => $ids
+ ),
+ __METHOD__,
+ array( 'ORDER BY' => 'ar_rev_id DESC' )
+ );
+
+ if ( $archived->numRows() == 0 ) {
+ return $live;
+ } elseif ( $live->numRows() == 0 ) {
+ return $archived;
+ } else {
+ // Combine the two! Whee
+ $rows = array();
+ foreach ( $live as $row ) {
+ $rows[$row->rev_id] = $row;
+ }
+ foreach ( $archived as $row ) {
+ $rows[$row->ar_rev_id] = $row;
+ }
+ krsort( $rows );
+ return new FakeResultWrapper( array_values( $rows ) );
+ }
+ }
+
+ public function newItem( $row ) {
+ if ( isset( $row->rev_id ) ) {
+ return new RevDelRevisionItem( $this, $row );
+ } elseif ( isset( $row->ar_rev_id ) ) {
+ return new RevDelArchivedRevisionItem( $this, $row );
+ } else {
+ // This shouldn't happen. :)
+ throw new MWException( 'Invalid row type in RevDelRevisionList' );
+ }
+ }
+
+ public function getCurrent() {
+ if ( is_null( $this->currentRevId ) ) {
+ $dbw = wfGetDB( DB_MASTER );
+ $this->currentRevId = $dbw->selectField(
+ 'page', 'page_latest', $this->title->pageCond(), __METHOD__ );
+ }
+ return $this->currentRevId;
+ }
+
+ public function getSuppressBit() {
+ return Revision::DELETED_RESTRICTED;
+ }
+
+ public function doPreCommitUpdates() {
+ $this->title->invalidateCache();
+ return Status::newGood();
+ }
+
+ public function doPostCommitUpdates() {
+ $this->title->purgeSquid();
+ // Extensions that require referencing previous revisions may need this
+ wfRunHooks( 'ArticleRevisionVisibilitySet', array( &$this->title ) );
+ return Status::newGood();
+ }
+}
+++ /dev/null
-<?php
-/**
- * Base implementations for deletable items.
- *
- * 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
- * @ingroup RevisionDelete
- */
-
-/**
- * List for revision table items
- *
- * This will check both the 'revision' table for live revisions and the
- * 'archive' table for traditionally-deleted revisions that have an
- * ar_rev_id saved.
- *
- * See RevDelRevisionItem and RevDelArchivedRevisionItem for items.
- */
-class RevDelRevisionList extends RevDelList {
- /** @var int */
- var $currentRevId;
-
- public function getType() {
- return 'revision';
- }
-
- public static function getRelationType() {
- return 'rev_id';
- }
-
- public static function getRestriction() {
- return 'deleterevision';
- }
-
- public static function getRevdelConstant() {
- return Revision::DELETED_TEXT;
- }
-
- public static function suggestTarget( $target, array $ids ) {
- $rev = Revision::newFromId( $ids[0] );
- return $rev ? $rev->getTitle() : $target;
- }
-
- /**
- * @param DatabaseBase $db
- * @return mixed
- */
- public function doQuery( $db ) {
- $ids = array_map( 'intval', $this->ids );
- $live = $db->select(
- array( 'revision', 'page', 'user' ),
- array_merge( Revision::selectFields(), Revision::selectUserFields() ),
- array(
- 'rev_page' => $this->title->getArticleID(),
- 'rev_id' => $ids,
- ),
- __METHOD__,
- array( 'ORDER BY' => 'rev_id DESC' ),
- array(
- 'page' => Revision::pageJoinCond(),
- 'user' => Revision::userJoinCond() )
- );
-
- if ( $live->numRows() >= count( $ids ) ) {
- // All requested revisions are live, keeps things simple!
- return $live;
- }
-
- // Check if any requested revisions are available fully deleted.
- $archived = $db->select( array( 'archive' ), Revision::selectArchiveFields(),
- array(
- 'ar_rev_id' => $ids
- ),
- __METHOD__,
- array( 'ORDER BY' => 'ar_rev_id DESC' )
- );
-
- if ( $archived->numRows() == 0 ) {
- return $live;
- } elseif ( $live->numRows() == 0 ) {
- return $archived;
- } else {
- // Combine the two! Whee
- $rows = array();
- foreach ( $live as $row ) {
- $rows[$row->rev_id] = $row;
- }
- foreach ( $archived as $row ) {
- $rows[$row->ar_rev_id] = $row;
- }
- krsort( $rows );
- return new FakeResultWrapper( array_values( $rows ) );
- }
- }
-
- public function newItem( $row ) {
- if ( isset( $row->rev_id ) ) {
- return new RevDelRevisionItem( $this, $row );
- } elseif ( isset( $row->ar_rev_id ) ) {
- return new RevDelArchivedRevisionItem( $this, $row );
- } else {
- // This shouldn't happen. :)
- throw new MWException( 'Invalid row type in RevDelRevisionList' );
- }
- }
-
- public function getCurrent() {
- if ( is_null( $this->currentRevId ) ) {
- $dbw = wfGetDB( DB_MASTER );
- $this->currentRevId = $dbw->selectField(
- 'page', 'page_latest', $this->title->pageCond(), __METHOD__ );
- }
- return $this->currentRevId;
- }
-
- public function getSuppressBit() {
- return Revision::DELETED_RESTRICTED;
- }
-
- public function doPreCommitUpdates() {
- $this->title->invalidateCache();
- return Status::newGood();
- }
-
- public function doPostCommitUpdates() {
- $this->title->purgeSquid();
- // Extensions that require referencing previous revisions may need this
- wfRunHooks( 'ArticleRevisionVisibilitySet', array( &$this->title ) );
- return Status::newGood();
- }
-}
-
-/**
- * Item class for a live revision table row
- */
-class RevDelRevisionItem extends RevDelItem {
- /** @var Revision */
- var $revision;
-
- public function __construct( $list, $row ) {
- parent::__construct( $list, $row );
- $this->revision = new Revision( $row );
- }
-
- public function getIdField() {
- return 'rev_id';
- }
-
- public function getTimestampField() {
- return 'rev_timestamp';
- }
-
- public function getAuthorIdField() {
- return 'rev_user';
- }
-
- public function getAuthorNameField() {
- return 'rev_user_text';
- }
-
- public function canView() {
- return $this->revision->userCan( Revision::DELETED_RESTRICTED, $this->list->getUser() );
- }
-
- public function canViewContent() {
- return $this->revision->userCan( Revision::DELETED_TEXT, $this->list->getUser() );
- }
-
- public function getBits() {
- return $this->revision->getVisibility();
- }
-
- public function setBits( $bits ) {
- $dbw = wfGetDB( DB_MASTER );
- // Update revision table
- $dbw->update( 'revision',
- array( 'rev_deleted' => $bits ),
- array(
- 'rev_id' => $this->revision->getId(),
- 'rev_page' => $this->revision->getPage(),
- 'rev_deleted' => $this->getBits()
- ),
- __METHOD__
- );
- if ( !$dbw->affectedRows() ) {
- // Concurrent fail!
- return false;
- }
- // Update recentchanges table
- $dbw->update( 'recentchanges',
- array(
- 'rc_deleted' => $bits,
- 'rc_patrolled' => 1
- ),
- array(
- 'rc_this_oldid' => $this->revision->getId(), // condition
- // non-unique timestamp index
- 'rc_timestamp' => $dbw->timestamp( $this->revision->getTimestamp() ),
- ),
- __METHOD__
- );
- return true;
- }
-
- public function isDeleted() {
- return $this->revision->isDeleted( Revision::DELETED_TEXT );
- }
-
- public function isHideCurrentOp( $newBits ) {
- return ( $newBits & Revision::DELETED_TEXT )
- && $this->list->getCurrent() == $this->getId();
- }
-
- /**
- * Get the HTML link to the revision text.
- * Overridden by RevDelArchiveItem.
- * @return string
- */
- protected function getRevisionLink() {
- $date = htmlspecialchars( $this->list->getLanguage()->userTimeAndDate(
- $this->revision->getTimestamp(), $this->list->getUser() ) );
-
- if ( $this->isDeleted() && !$this->canViewContent() ) {
- return $date;
- }
- return Linker::linkKnown(
- $this->list->title,
- $date,
- array(),
- array(
- 'oldid' => $this->revision->getId(),
- 'unhide' => 1
- )
- );
- }
-
- /**
- * Get the HTML link to the diff.
- * Overridden by RevDelArchiveItem
- * @return string
- */
- protected function getDiffLink() {
- if ( $this->isDeleted() && !$this->canViewContent() ) {
- return $this->list->msg( 'diff' )->escaped();
- } else {
- return Linker::linkKnown(
- $this->list->title,
- $this->list->msg( 'diff' )->escaped(),
- array(),
- array(
- 'diff' => $this->revision->getId(),
- 'oldid' => 'prev',
- 'unhide' => 1
- )
- );
- }
- }
-
- public function getHTML() {
- $difflink = $this->list->msg( 'parentheses' )
- ->rawParams( $this->getDiffLink() )->escaped();
- $revlink = $this->getRevisionLink();
- $userlink = Linker::revUserLink( $this->revision );
- $comment = Linker::revComment( $this->revision );
- if ( $this->isDeleted() ) {
- $revlink = "<span class=\"history-deleted\">$revlink</span>";
- }
- return "<li>$difflink $revlink $userlink $comment</li>";
- }
-
- public function getApiData( ApiResult $result ) {
- $rev = $this->revision;
- $user = $this->list->getUser();
- $ret = array(
- 'id' => $rev->getId(),
- 'timestamp' => wfTimestamp( TS_ISO_8601, $rev->getTimestamp() ),
- );
- $ret += $rev->isDeleted( Revision::DELETED_USER ) ? array( 'userhidden' => '' ) : array();
- $ret += $rev->isDeleted( Revision::DELETED_COMMENT ) ? array( 'commenthidden' => '' ) : array();
- $ret += $rev->isDeleted( Revision::DELETED_TEXT ) ? array( 'texthidden' => '' ) : array();
- if ( $rev->userCan( Revision::DELETED_USER, $user ) ) {
- $ret += array(
- 'userid' => $rev->getUser( Revision::FOR_THIS_USER ),
- 'user' => $rev->getUserText( Revision::FOR_THIS_USER ),
- );
- }
- if ( $rev->userCan( Revision::DELETED_COMMENT, $user ) ) {
- $ret += array(
- 'comment' => $rev->getComment( Revision::FOR_THIS_USER ),
- );
- }
- return $ret;
- }
-}
-
-/**
- * List for archive table items, i.e. revisions deleted via action=delete
- */
-class RevDelArchiveList extends RevDelRevisionList {
- public function getType() {
- return 'archive';
- }
-
- public static function getRelationType() {
- return 'ar_timestamp';
- }
-
- /**
- * @param DatabaseBase $db
- * @return mixed
- */
- public function doQuery( $db ) {
- $timestamps = array();
- foreach ( $this->ids as $id ) {
- $timestamps[] = $db->timestamp( $id );
- }
- return $db->select( 'archive', Revision::selectArchiveFields(),
- array(
- 'ar_namespace' => $this->title->getNamespace(),
- 'ar_title' => $this->title->getDBkey(),
- 'ar_timestamp' => $timestamps
- ),
- __METHOD__,
- array( 'ORDER BY' => 'ar_timestamp DESC' )
- );
- }
-
- public function newItem( $row ) {
- return new RevDelArchiveItem( $this, $row );
- }
-
- public function doPreCommitUpdates() {
- return Status::newGood();
- }
-
- public function doPostCommitUpdates() {
- return Status::newGood();
- }
-}
-
-/**
- * Item class for a archive table row
- */
-class RevDelArchiveItem extends RevDelRevisionItem {
- public function __construct( $list, $row ) {
- RevDelItem::__construct( $list, $row );
- $this->revision = Revision::newFromArchiveRow( $row,
- array( 'page' => $this->list->title->getArticleID() ) );
- }
-
- public function getIdField() {
- return 'ar_timestamp';
- }
-
- public function getTimestampField() {
- return 'ar_timestamp';
- }
-
- public function getAuthorIdField() {
- return 'ar_user';
- }
-
- public function getAuthorNameField() {
- return 'ar_user_text';
- }
-
- public function getId() {
- # Convert DB timestamp to MW timestamp
- return $this->revision->getTimestamp();
- }
-
- public function setBits( $bits ) {
- $dbw = wfGetDB( DB_MASTER );
- $dbw->update( 'archive',
- array( 'ar_deleted' => $bits ),
- array(
- 'ar_namespace' => $this->list->title->getNamespace(),
- 'ar_title' => $this->list->title->getDBkey(),
- // use timestamp for index
- 'ar_timestamp' => $this->row->ar_timestamp,
- 'ar_rev_id' => $this->row->ar_rev_id,
- 'ar_deleted' => $this->getBits()
- ),
- __METHOD__ );
- return (bool)$dbw->affectedRows();
- }
-
- protected function getRevisionLink() {
- $date = htmlspecialchars( $this->list->getLanguage()->userTimeAndDate(
- $this->revision->getTimestamp(), $this->list->getUser() ) );
-
- if ( $this->isDeleted() && !$this->canViewContent() ) {
- return $date;
- }
-
- return Linker::link(
- SpecialPage::getTitleFor( 'Undelete' ),
- $date,
- array(),
- array(
- 'target' => $this->list->title->getPrefixedText(),
- 'timestamp' => $this->revision->getTimestamp()
- )
- );
- }
-
- protected function getDiffLink() {
- if ( $this->isDeleted() && !$this->canViewContent() ) {
- return $this->list->msg( 'diff' )->escaped();
- }
-
- return Linker::link(
- SpecialPage::getTitleFor( 'Undelete' ),
- $this->list->msg( 'diff' )->escaped(),
- array(),
- array(
- 'target' => $this->list->title->getPrefixedText(),
- 'diff' => 'prev',
- 'timestamp' => $this->revision->getTimestamp()
- )
- );
- }
-}
-
-/**
- * Item class for a archive table row by ar_rev_id -- actually
- * used via RevDelRevisionList.
- */
-class RevDelArchivedRevisionItem extends RevDelArchiveItem {
- public function __construct( $list, $row ) {
- RevDelItem::__construct( $list, $row );
-
- $this->revision = Revision::newFromArchiveRow( $row,
- array( 'page' => $this->list->title->getArticleID() ) );
- }
-
- public function getIdField() {
- return 'ar_rev_id';
- }
-
- public function getId() {
- return $this->revision->getId();
- }
-
- public function setBits( $bits ) {
- $dbw = wfGetDB( DB_MASTER );
- $dbw->update( 'archive',
- array( 'ar_deleted' => $bits ),
- array( 'ar_rev_id' => $this->row->ar_rev_id,
- 'ar_deleted' => $this->getBits()
- ),
- __METHOD__ );
- return (bool)$dbw->affectedRows();
- }
-}
-
-/**
- * List for oldimage table items
- */
-class RevDelFileList extends RevDelList {
- /** @var array */
- var $storeBatch;
-
- /** @var array */
- var $deleteBatch;
-
- /** @var array */
- var $cleanupBatch;
-
- public function getType() {
- return 'oldimage';
- }
-
- public static function getRelationType() {
- return 'oi_archive_name';
- }
-
- public static function getRestriction() {
- return 'deleterevision';
- }
-
- public static function getRevdelConstant() {
- return File::DELETED_FILE;
- }
-
- /**
- * @param DatabaseBase $db
- * @return mixed
- */
- public function doQuery( $db ) {
- $archiveNames = array();
- foreach ( $this->ids as $timestamp ) {
- $archiveNames[] = $timestamp . '!' . $this->title->getDBkey();
- }
- return $db->select(
- 'oldimage',
- OldLocalFile::selectFields(),
- array(
- 'oi_name' => $this->title->getDBkey(),
- 'oi_archive_name' => $archiveNames
- ),
- __METHOD__,
- array( 'ORDER BY' => 'oi_timestamp DESC' )
- );
- }
-
- public function newItem( $row ) {
- return new RevDelFileItem( $this, $row );
- }
-
- public function clearFileOps() {
- $this->deleteBatch = array();
- $this->storeBatch = array();
- $this->cleanupBatch = array();
- }
-
- public function doPreCommitUpdates() {
- $status = Status::newGood();
- $repo = RepoGroup::singleton()->getLocalRepo();
- if ( $this->storeBatch ) {
- $status->merge( $repo->storeBatch( $this->storeBatch, FileRepo::OVERWRITE_SAME ) );
- }
- if ( !$status->isOK() ) {
- return $status;
- }
- if ( $this->deleteBatch ) {
- $status->merge( $repo->deleteBatch( $this->deleteBatch ) );
- }
- if ( !$status->isOK() ) {
- // Running cleanupDeletedBatch() after a failed storeBatch() with the DB already
- // modified (but destined for rollback) causes data loss
- return $status;
- }
- if ( $this->cleanupBatch ) {
- $status->merge( $repo->cleanupDeletedBatch( $this->cleanupBatch ) );
- }
- return $status;
- }
-
- public function doPostCommitUpdates() {
- global $wgUseSquid;
- $file = wfLocalFile( $this->title );
- $file->purgeCache();
- $file->purgeDescription();
- $purgeUrls = array();
- foreach ( $this->ids as $timestamp ) {
- $archiveName = $timestamp . '!' . $this->title->getDBkey();
- $file->purgeOldThumbnails( $archiveName );
- $purgeUrls[] = $file->getArchiveUrl( $archiveName );
- }
- if ( $wgUseSquid ) {
- // purge full images from cache
- SquidUpdate::purge( $purgeUrls );
- }
- return Status::newGood();
- }
-
- public function getSuppressBit() {
- return File::DELETED_RESTRICTED;
- }
-}
-
-/**
- * Item class for an oldimage table row
- */
-class RevDelFileItem extends RevDelItem {
- /** @var File */
- var $file;
-
- public function __construct( $list, $row ) {
- parent::__construct( $list, $row );
- $this->file = RepoGroup::singleton()->getLocalRepo()->newFileFromRow( $row );
- }
-
- public function getIdField() {
- return 'oi_archive_name';
- }
-
- public function getTimestampField() {
- return 'oi_timestamp';
- }
-
- public function getAuthorIdField() {
- return 'oi_user';
- }
-
- public function getAuthorNameField() {
- return 'oi_user_text';
- }
-
- public function getId() {
- $parts = explode( '!', $this->row->oi_archive_name );
- return $parts[0];
- }
-
- public function canView() {
- return $this->file->userCan( File::DELETED_RESTRICTED, $this->list->getUser() );
- }
-
- public function canViewContent() {
- return $this->file->userCan( File::DELETED_FILE, $this->list->getUser() );
- }
-
- public function getBits() {
- return $this->file->getVisibility();
- }
-
- public function setBits( $bits ) {
- # Queue the file op
- # @todo FIXME: Move to LocalFile.php
- if ( $this->isDeleted() ) {
- if ( $bits & File::DELETED_FILE ) {
- # Still deleted
- } else {
- # Newly undeleted
- $key = $this->file->getStorageKey();
- $srcRel = $this->file->repo->getDeletedHashPath( $key ) . $key;
- $this->list->storeBatch[] = array(
- $this->file->repo->getVirtualUrl( 'deleted' ) . '/' . $srcRel,
- 'public',
- $this->file->getRel()
- );
- $this->list->cleanupBatch[] = $key;
- }
- } elseif ( $bits & File::DELETED_FILE ) {
- # Newly deleted
- $key = $this->file->getStorageKey();
- $dstRel = $this->file->repo->getDeletedHashPath( $key ) . $key;
- $this->list->deleteBatch[] = array( $this->file->getRel(), $dstRel );
- }
-
- # Do the database operations
- $dbw = wfGetDB( DB_MASTER );
- $dbw->update( 'oldimage',
- array( 'oi_deleted' => $bits ),
- array(
- 'oi_name' => $this->row->oi_name,
- 'oi_timestamp' => $this->row->oi_timestamp,
- 'oi_deleted' => $this->getBits()
- ),
- __METHOD__
- );
- return (bool)$dbw->affectedRows();
- }
-
- public function isDeleted() {
- return $this->file->isDeleted( File::DELETED_FILE );
- }
-
- /**
- * Get the link to the file.
- * Overridden by RevDelArchivedFileItem.
- * @return string
- */
- protected function getLink() {
- $date = htmlspecialchars( $this->list->getLanguage()->userTimeAndDate(
- $this->file->getTimestamp(), $this->list->getUser() ) );
-
- if ( !$this->isDeleted() ) {
- # Regular files...
- return Html::rawElement( 'a', array( 'href' => $this->file->getUrl() ), $date );
- }
-
- # Hidden files...
- if ( !$this->canViewContent() ) {
- $link = $date;
- } else {
- $link = Linker::link(
- SpecialPage::getTitleFor( 'Revisiondelete' ),
- $date,
- array(),
- array(
- 'target' => $this->list->title->getPrefixedText(),
- 'file' => $this->file->getArchiveName(),
- 'token' => $this->list->getUser()->getEditToken(
- $this->file->getArchiveName() )
- )
- );
- }
- return '<span class="history-deleted">' . $link . '</span>';
- }
-
- /**
- * Generate a user tool link cluster if the current user is allowed to view it
- * @return string HTML
- */
- protected function getUserTools() {
- if ( $this->file->userCan( Revision::DELETED_USER, $this->list->getUser() ) ) {
- $uid = $this->file->getUser( 'id' );
- $name = $this->file->getUser( 'text' );
- $link = Linker::userLink( $uid, $name ) . Linker::userToolLinks( $uid, $name );
- } else {
- $link = $this->list->msg( 'rev-deleted-user' )->escaped();
- }
- if ( $this->file->isDeleted( Revision::DELETED_USER ) ) {
- return '<span class="history-deleted">' . $link . '</span>';
- }
- return $link;
- }
-
- /**
- * Wrap and format the file's comment block, if the current
- * user is allowed to view it.
- *
- * @return string HTML
- */
- protected function getComment() {
- if ( $this->file->userCan( File::DELETED_COMMENT, $this->list->getUser() ) ) {
- $block = Linker::commentBlock( $this->file->getDescription() );
- } else {
- $block = ' ' . $this->list->msg( 'rev-deleted-comment' )->escaped();
- }
- if ( $this->file->isDeleted( File::DELETED_COMMENT ) ) {
- return "<span class=\"history-deleted\">$block</span>";
- }
- return $block;
- }
-
- public function getHTML() {
- $data =
- $this->list->msg( 'widthheight' )->numParams(
- $this->file->getWidth(), $this->file->getHeight() )->text() .
- ' (' . $this->list->msg( 'nbytes' )->numParams( $this->file->getSize() )->text() . ')';
-
- return '<li>' . $this->getLink() . ' ' . $this->getUserTools() . ' ' .
- $data . ' ' . $this->getComment() . '</li>';
- }
-
- public function getApiData( ApiResult $result ) {
- $file = $this->file;
- $user = $this->list->getUser();
- $ret = array(
- 'title' => $this->list->title->getPrefixedText(),
- 'archivename' => $file->getArchiveName(),
- 'timestamp' => wfTimestamp( TS_ISO_8601, $file->getTimestamp() ),
- 'width' => $file->getWidth(),
- 'height' => $file->getHeight(),
- 'size' => $file->getSize(),
- );
- $ret += $file->isDeleted( Revision::DELETED_USER ) ? array( 'userhidden' => '' ) : array();
- $ret += $file->isDeleted( Revision::DELETED_COMMENT ) ? array( 'commenthidden' => '' ) : array();
- $ret += $this->isDeleted() ? array( 'contenthidden' => '' ) : array();
- if ( !$this->isDeleted() ) {
- $ret += array(
- 'url' => $file->getUrl(),
- );
- } elseif ( $this->canViewContent() ) {
- $ret += array(
- 'url' => SpecialPage::getTitleFor( 'Revisiondelete' )->getLinkURL(
- array(
- 'target' => $this->list->title->getPrefixedText(),
- 'file' => $file->getArchiveName(),
- 'token' => $user->getEditToken( $file->getArchiveName() )
- ),
- false, PROTO_RELATIVE
- ),
- );
- }
- if ( $file->userCan( Revision::DELETED_USER, $user ) ) {
- $ret += array(
- 'userid' => $file->user,
- 'user' => $file->user_text,
- );
- }
- if ( $file->userCan( Revision::DELETED_COMMENT, $user ) ) {
- $ret += array(
- 'comment' => $file->description,
- );
- }
- return $ret;
- }
-}
-
-/**
- * List for filearchive table items
- */
-class RevDelArchivedFileList extends RevDelFileList {
- public function getType() {
- return 'filearchive';
- }
-
- public static function getRelationType() {
- return 'fa_id';
- }
-
- /**
- * @param DatabaseBase $db
- * @return mixed
- */
- public function doQuery( $db ) {
- $ids = array_map( 'intval', $this->ids );
- return $db->select(
- 'filearchive',
- ArchivedFile::selectFields(),
- array(
- 'fa_name' => $this->title->getDBkey(),
- 'fa_id' => $ids
- ),
- __METHOD__,
- array( 'ORDER BY' => 'fa_id DESC' )
- );
- }
-
- public function newItem( $row ) {
- return new RevDelArchivedFileItem( $this, $row );
- }
-}
-
-/**
- * Item class for a filearchive table row
- */
-class RevDelArchivedFileItem extends RevDelFileItem {
- public function __construct( $list, $row ) {
- RevDelItem::__construct( $list, $row );
- $this->file = ArchivedFile::newFromRow( $row );
- }
-
- public function getIdField() {
- return 'fa_id';
- }
-
- public function getTimestampField() {
- return 'fa_timestamp';
- }
-
- public function getAuthorIdField() {
- return 'fa_user';
- }
-
- public function getAuthorNameField() {
- return 'fa_user_text';
- }
-
- public function getId() {
- return $this->row->fa_id;
- }
-
- public function setBits( $bits ) {
- $dbw = wfGetDB( DB_MASTER );
- $dbw->update( 'filearchive',
- array( 'fa_deleted' => $bits ),
- array(
- 'fa_id' => $this->row->fa_id,
- 'fa_deleted' => $this->getBits(),
- ),
- __METHOD__
- );
- return (bool)$dbw->affectedRows();
- }
-
- protected function getLink() {
- $date = htmlspecialchars( $this->list->getLanguage()->userTimeAndDate(
- $this->file->getTimestamp(), $this->list->getUser() ) );
-
- # Hidden files...
- if ( !$this->canViewContent() ) {
- $link = $date;
- } else {
- $undelete = SpecialPage::getTitleFor( 'Undelete' );
- $key = $this->file->getKey();
- $link = Linker::link( $undelete, $date, array(),
- array(
- 'target' => $this->list->title->getPrefixedText(),
- 'file' => $key,
- 'token' => $this->list->getUser()->getEditToken( $key )
- )
- );
- }
- if ( $this->isDeleted() ) {
- $link = '<span class="history-deleted">' . $link . '</span>';
- }
- return $link;
- }
-
- public function getApiData( ApiResult $result ) {
- $file = $this->file;
- $user = $this->list->getUser();
- $ret = array(
- 'title' => $this->list->title->getPrefixedText(),
- 'timestamp' => wfTimestamp( TS_ISO_8601, $file->getTimestamp() ),
- 'width' => $file->getWidth(),
- 'height' => $file->getHeight(),
- 'size' => $file->getSize(),
- );
- $ret += $file->isDeleted( Revision::DELETED_USER ) ? array( 'userhidden' => '' ) : array();
- $ret += $file->isDeleted( Revision::DELETED_COMMENT ) ? array( 'commenthidden' => '' ) : array();
- $ret += $this->isDeleted() ? array( 'contenthidden' => '' ) : array();
- if ( $this->canViewContent() ) {
- $ret += array(
- 'url' => SpecialPage::getTitleFor( 'Revisiondelete' )->getLinkURL(
- array(
- 'target' => $this->list->title->getPrefixedText(),
- 'file' => $file->getKey(),
- 'token' => $user->getEditToken( $file->getKey() )
- ),
- false, PROTO_RELATIVE
- ),
- );
- }
- if ( $file->userCan( Revision::DELETED_USER, $user ) ) {
- $ret += array(
- 'userid' => $file->getUser( 'id' ),
- 'user' => $file->getUser( 'text' ),
- );
- }
- if ( $file->userCan( Revision::DELETED_COMMENT, $user ) ) {
- $ret += array(
- 'comment' => $file->getRawDescription(),
- );
- }
- return $ret;
- }
-}
-
-/**
- * List for logging table items
- */
-class RevDelLogList extends RevDelList {
- public function getType() {
- return 'logging';
- }
-
- public static function getRelationType() {
- return 'log_id';
- }
-
- public static function getRestriction() {
- return 'deletelogentry';
- }
-
- public static function getRevdelConstant() {
- return LogPage::DELETED_ACTION;
- }
-
- public static function suggestTarget( $target, array $ids ) {
- $result = wfGetDB( DB_SLAVE )->select( 'logging',
- 'log_type',
- array( 'log_id' => $ids ),
- __METHOD__,
- array( 'DISTINCT' )
- );
- if ( $result->numRows() == 1 ) {
- // If there's only one type, the target can be set to include it.
- return SpecialPage::getTitleFor( 'Log', $result->current()->log_type );
- }
- return SpecialPage::getTitleFor( 'Log' );
- }
-
- /**
- * @param DatabaseBase $db
- * @return mixed
- */
- public function doQuery( $db ) {
- $ids = array_map( 'intval', $this->ids );
- return $db->select( 'logging', array(
- 'log_id',
- 'log_type',
- 'log_action',
- 'log_timestamp',
- 'log_user',
- 'log_user_text',
- 'log_namespace',
- 'log_title',
- 'log_page',
- 'log_comment',
- 'log_params',
- 'log_deleted'
- ),
- array( 'log_id' => $ids ),
- __METHOD__,
- array( 'ORDER BY' => 'log_id DESC' )
- );
- }
-
- public function newItem( $row ) {
- return new RevDelLogItem( $this, $row );
- }
-
- public function getSuppressBit() {
- return Revision::DELETED_RESTRICTED;
- }
-
- public function getLogAction() {
- return 'event';
- }
-
- public function getLogParams( $params ) {
- return array(
- implode( ',', $params['ids'] ),
- "ofield={$params['oldBits']}",
- "nfield={$params['newBits']}"
- );
- }
-}
-
-/**
- * Item class for a logging table row
- */
-class RevDelLogItem extends RevDelItem {
- public function getIdField() {
- return 'log_id';
- }
-
- public function getTimestampField() {
- return 'log_timestamp';
- }
-
- public function getAuthorIdField() {
- return 'log_user';
- }
-
- public function getAuthorNameField() {
- return 'log_user_text';
- }
-
- public function canView() {
- return LogEventsList::userCan( $this->row, Revision::DELETED_RESTRICTED, $this->list->getUser() );
- }
-
- public function canViewContent() {
- return true; // none
- }
-
- public function getBits() {
- return $this->row->log_deleted;
- }
-
- public function setBits( $bits ) {
- $dbw = wfGetDB( DB_MASTER );
- $dbw->update( 'recentchanges',
- array(
- 'rc_deleted' => $bits,
- 'rc_patrolled' => 1
- ),
- array(
- 'rc_logid' => $this->row->log_id,
- 'rc_timestamp' => $this->row->log_timestamp // index
- ),
- __METHOD__
- );
- $dbw->update( 'logging',
- array( 'log_deleted' => $bits ),
- array(
- 'log_id' => $this->row->log_id,
- 'log_deleted' => $this->getBits()
- ),
- __METHOD__
- );
- return (bool)$dbw->affectedRows();
- }
-
- public function getHTML() {
- $date = htmlspecialchars( $this->list->getLanguage()->userTimeAndDate(
- $this->row->log_timestamp, $this->list->getUser() ) );
- $title = Title::makeTitle( $this->row->log_namespace, $this->row->log_title );
- $formatter = LogFormatter::newFromRow( $this->row );
- $formatter->setContext( $this->list->getContext() );
- $formatter->setAudience( LogFormatter::FOR_THIS_USER );
-
- // Log link for this page
- $loglink = Linker::link(
- SpecialPage::getTitleFor( 'Log' ),
- $this->list->msg( 'log' )->escaped(),
- array(),
- array( 'page' => $title->getPrefixedText() )
- );
- $loglink = $this->list->msg( 'parentheses' )->rawParams( $loglink )->escaped();
- // User links and action text
- $action = $formatter->getActionText();
- // Comment
- $comment = $this->list->getLanguage()->getDirMark()
- . Linker::commentBlock( $this->row->log_comment );
-
- if ( LogEventsList::isDeleted( $this->row, LogPage::DELETED_COMMENT ) ) {
- $comment = '<span class="history-deleted">' . $comment . '</span>';
- }
-
- return "<li>$loglink $date $action $comment</li>";
- }
-
- public function getApiData( ApiResult $result ) {
- $logEntry = DatabaseLogEntry::newFromRow( $this->row );
- $user = $this->list->getUser();
- $ret = array(
- 'id' => $logEntry->getId(),
- 'type' => $logEntry->getType(),
- 'action' => $logEntry->getSubtype(),
- );
- $ret += $logEntry->isDeleted( LogPage::DELETED_USER )
- ? array( 'userhidden' => '' )
- : array();
- $ret += $logEntry->isDeleted( LogPage::DELETED_COMMENT )
- ? array( 'commenthidden' => '' )
- : array();
- $ret += $logEntry->isDeleted( LogPage::DELETED_ACTION )
- ? array( 'actionhidden' => '' )
- : array();
-
- if ( LogEventsList::userCan( $this->row, LogPage::DELETED_ACTION, $user ) ) {
- ApiQueryLogEvents::addLogParams(
- $result,
- $ret,
- $logEntry->getParameters(),
- $logEntry->getType(),
- $logEntry->getSubtype(),
- $logEntry->getTimestamp(),
- $logEntry->isLegacy()
- );
- }
- if ( LogEventsList::userCan( $this->row, LogPage::DELETED_USER, $user ) ) {
- $ret += array(
- 'userid' => $this->row->log_user,
- 'user' => $this->row->log_user_text,
- );
- }
- if ( LogEventsList::userCan( $this->row, LogPage::DELETED_COMMENT, $user ) ) {
- $ret += array(
- 'comment' => $this->row->log_comment,
- );
- }
- return $ret;
- }
-}
* latest revision article text (pagecontent.old_text)
*
* @param string $term Raw search term
- * @return PostgresSearchResultSet
+ * @return SqlSearchResultSet
*/
function searchTitle( $term ) {
$q = $this->searchQuery( $term, 'titlevector', 'page_title' );
$olderror = error_reporting( E_ERROR );
$resultSet = $this->db->resultObject( $this->db->query( $q, 'SearchPostgres', true ) );
error_reporting( $olderror );
- return new PostgresSearchResultSet( $resultSet, $this->searchTerms );
+ return new SqlSearchResultSet( $resultSet, $this->searchTerms );
}
function searchText( $term ) {
$olderror = error_reporting( E_ERROR );
$resultSet = $this->db->resultObject( $this->db->query( $q, 'SearchPostgres', true ) );
error_reporting( $olderror );
- return new PostgresSearchResultSet( $resultSet, $this->searchTerms );
+ return new SqlSearchResultSet( $resultSet, $this->searchTerms );
}
/**
return true;
}
-} ## end of the SearchPostgres class
-
-/**
- * @ingroup Search
- */
-class PostgresSearchResult extends SearchResult {
- function __construct( $row ) {
- parent::__construct( $row );
- $this->score = $row->score;
- }
-
- function getScore() {
- return $this->score;
- }
-}
-
-/**
- * @ingroup Search
- */
-class PostgresSearchResultSet extends SqlSearchResultSet {
- function next() {
- $row = $this->resultSet->fetchObject();
- if ( $row === false ) {
- return false;
- } else {
- return new PostgresSearchResult( $row );
- }
- }
}
return $this->mImage;
}
- /**
- * @return float|null If not supported
- */
- function getScore() {
- return null;
- }
-
/**
* Lazy initialization of article text from DB
*/
* @return string
*/
public static function makeLegend( IContextSource $context ) {
- global $wgRecentChangesFlags;
$user = $context->getUser();
# The legend showing what the letters and stuff mean
$legend = Html::openElement( 'dl' ) . "\n";
# Iterates through them and gets the messages for both letter and tooltip
- $legendItems = $wgRecentChangesFlags;
+ $legendItems = $context->getConfig()->get( 'RecentChangesFlags' );
if ( !( $user->useRCPatrol() || $user->useNPPatrol() ) ) {
unset( $legendItems['unpatrolled'] );
}
* @return bool
*/
function isExpensive() {
- global $wgDisableQueryPages;
- return $wgDisableQueryPages;
+ return $this->getConfig()->get( 'DisableQueryPages' );
}
/**
* @return bool
*/
function isCached() {
- global $wgMiserMode;
-
- return $this->isExpensive() && $wgMiserMode;
+ return $this->isExpensive() && $this->getConfig()->get( 'MiserMode' );
}
/**
* @param string $par
*/
function execute( $par ) {
- global $wgQueryCacheLimit, $wgDisableQueryPageUpdate;
-
$user = $this->getUser();
if ( !$this->userCanExecute( $user ) ) {
$this->displayRestrictionError();
# Fetch the timestamp of this update
$ts = $this->getCachedTimestamp();
$lang = $this->getLanguage();
- $maxResults = $lang->formatNum( $wgQueryCacheLimit );
+ $maxResults = $lang->formatNum( $this->getConfig()->get( 'QueryCacheLimit' ) );
if ( $ts ) {
$updated = $lang->userTimeAndDate( $ts, $user );
# If updates on this page have been disabled, let the user know
# that the data set won't be refreshed for now
- if ( is_array( $wgDisableQueryPageUpdate )
- && in_array( $this->getName(), $wgDisableQueryPageUpdate )
+ if ( is_array( $this->getConfig()->get( 'DisableQueryPageUpdate' ) )
+ && in_array( $this->getName(), $this->getConfig()->get( 'DisableQueryPageUpdate' ) )
) {
$out->wrapWikiMsg(
"<div class=\"mw-querypage-no-updates\">\n$1\n</div>",
* @return bool
*/
function doFeed( $class = '', $limit = 50 ) {
- global $wgFeed, $wgFeedClasses, $wgFeedLimit;
-
- if ( !$wgFeed ) {
+ if ( !$this->getConfig()->get( 'Feed' ) ) {
$this->getOutput()->addWikiMsg( 'feed-unavailable' );
return false;
}
- $limit = min( $limit, $wgFeedLimit );
+ $limit = min( $limit, $this->getConfig()->get( 'FeedLimit' ) );
- if ( isset( $wgFeedClasses[$class] ) ) {
+ $feedClasses = $this->getConfig()->get( 'FeedClasses' );
+ if ( isset( $feedClasses[$class] ) ) {
/** @var RSSFeed|AtomFeed $feed */
- $feed = new $wgFeedClasses[$class](
+ $feed = new $feedClasses[$class](
$this->feedTitle(),
$this->feedDesc(),
$this->feedUrl() );
}
function feedTitle() {
- global $wgLanguageCode, $wgSitename;
$desc = $this->getDescription();
- return "$wgSitename - $desc [$wgLanguageCode]";
+ $code = $this->getConfig()->get( 'LanguageCode' );
+ $sitename = $this->getConfig()->get( 'Sitename' );
+ return "$sitename - $desc [$code]";
}
function feedDesc() {
}
/**
- * If the user is not logged in, throws UserNotLoggedIn error.
+ * If the user is not logged in, throws UserNotLoggedIn error
*
- * Default error message includes a link to Special:Userlogin with properly set 'returnto' query
- * parameter.
+ * The user will be redirected to Special:Userlogin with the given message as an error on
+ * the form.
*
* @since 1.23
- * @param string|Message $reasonMsg [optional] Passed on to UserNotLoggedIn constructor. Strings
- * will be used as message keys. If a string is given, the message will also receive a
- * formatted login link (generated using the 'loginreqlink' message) as first parameter. If a
- * Message is given, it will be passed on verbatim.
- * @param string|Message $titleMsg [optional] Passed on to UserNotLoggedIn constructor. Strings
- * will be used as message keys.
+ * @param string $reasonMsg [optional] Message key to be displayed on login page
+ * @param string $titleMsg [optional] Passed on to UserNotLoggedIn constructor
* @throws UserNotLoggedIn
*/
- public function requireLogin( $reasonMsg = null, $titleMsg = null ) {
+ public function requireLogin(
+ $reasonMsg = 'exception-nologin-text', $titleMsg = 'exception-nologin'
+ ) {
if ( $this->getUser()->isAnon() ) {
- // Use default messages if not given or explicit null passed
- if ( !$reasonMsg ) {
- $reasonMsg = 'exception-nologin-text-manual';
- }
- if ( !$titleMsg ) {
- $titleMsg = 'exception-nologin';
- }
-
- // Convert to Messages with current context
- if ( is_string( $reasonMsg ) ) {
- $loginreqlink = Linker::linkKnown(
- SpecialPage::getTitleFor( 'Userlogin' ),
- $this->msg( 'loginreqlink' )->escaped(),
- array(),
- array( 'returnto' => $this->getPageTitle()->getPrefixedText() )
- );
- $reasonMsg = $this->msg( $reasonMsg )->rawParams( $loginreqlink );
- }
- if ( is_string( $titleMsg ) ) {
- $titleMsg = $this->msg( $titleMsg );
- }
-
throw new UserNotLoggedIn( $reasonMsg, $titleMsg );
}
}
* @param array $params
*/
protected function addFeedLinks( $params ) {
- global $wgFeedClasses;
-
$feedTemplate = wfScript( 'api' );
- foreach ( $wgFeedClasses as $format => $class ) {
+ foreach ( $this->getConfig()->get( 'FeedClasses' ) as $format => $class ) {
$theseParams = $params + array( 'feedformat' => $format );
$url = wfAppendQuery( $feedTemplate, $theseParams );
$this->getOutput()->addFeedLink( $format, $url );
* @since 1.21
*/
public function getFinalGroupName() {
- global $wgSpecialPageGroups;
$name = $this->getName();
+ $specialPageGroups = $this->getConfig()->get( 'SpecialPageGroups' );
// Allow overbidding the group from the wiki side
$msg = $this->msg( 'specialpages-specialpagegroup-' . strtolower( $name ) )->inContentLanguage();
// Group '-' is used as default to have the chance to determine,
// if the special pages overrides this method,
// if not overridden, $wgSpecialPageGroups is checked for b/c
- if ( $group === '-' && isset( $wgSpecialPageGroups[$name] ) ) {
- $group = $wgSpecialPageGroups[$name];
+ if ( $group === '-' && isset( $specialPageGroups[$name] ) ) {
+ $group = $specialPageGroups[$name];
}
}
* @param string $par Parameter passed to the page
*/
function __construct( IContextSource $context = null, $group = null, $par = null ) {
- global $wgActiveUserDays;
-
parent::__construct( $context );
- $this->RCMaxAge = $wgActiveUserDays;
+ $this->RCMaxAge = $this->getConfig()->get( 'ActiveUserDays' );
$un = $this->getRequest()->getText( 'username', $par );
$this->requestedUser = '';
if ( $un != '' ) {
}
function getPageHeader() {
- global $wgScript;
-
$self = $this->getTitle();
$limit = $this->mLimit ? Html::hidden( 'limit', $this->mLimit ) : '';
# Form tag
- $out = Xml::openElement( 'form', array( 'method' => 'get', 'action' => $wgScript ) );
+ $out = Xml::openElement( 'form', array( 'method' => 'get', 'action' => wfScript() ) );
$out .= Xml::fieldset( $this->msg( 'activeusers' )->text() ) . "\n";
$out .= Html::hidden( 'title', $self->getPrefixedDBkey() ) . $limit . "\n";
* @param string $par Parameter passed to the page or null
*/
public function execute( $par ) {
- global $wgActiveUserDays;
+ $days = $this->getConfig()->get( 'ActiveUserDays' );
$this->setHeaders();
$this->outputHeader();
$out = $this->getOutput();
$out->wrapWikiMsg( "<div class='mw-activeusers-intro'>\n$1\n</div>",
- array( 'activeusers-intro', $this->getLanguage()->formatNum( $wgActiveUserDays ) ) );
+ array( 'activeusers-intro', $this->getLanguage()->formatNum( $days ) ) );
// Occasionally merge in new updates
- $seconds = min( self::mergeActiveUsers( 600 ), $wgActiveUserDays * 86400 );
+ $seconds = min( self::mergeActiveUsers( 600, $days ), $days * 86400 );
// Mention the level of staleness
$out->addWikiMsg( 'cachedspecial-viewing-cached-ttl',
$this->getLanguage()->formatDuration( $seconds ) );
}
/**
- * @param intr $period Seconds (do updates no more often than this)
+ * @param int $period Seconds (do updates no more often than this)
+ * @param int $days How many days user must be idle before he is considered inactive
* @return int How many seconds old the cache is
*/
- public static function mergeActiveUsers( $period ) {
- global $wgActiveUserDays;
-
+ public static function mergeActiveUsers( $period, $days ) {
$dbr = wfGetDB( DB_SLAVE );
$cTime = $dbr->selectField( 'querycache_info',
'qci_timestamp',
if ( !$cTime || ( time() - wfTimestamp( TS_UNIX, $cTime ) ) > $period ) {
$dbw = wfGetDB( DB_MASTER );
if ( $dbw->estimateRowCount( 'recentchanges' ) <= 10000 ) {
- $window = $wgActiveUserDays * 86400; // small wiki
+ $window = $days * 86400; // small wiki
} else {
$window = $period * 2;
}
- $cTime = self::doQueryCacheUpdate( $dbw, $window ) ?: $cTime;
+ $cTime = self::doQueryCacheUpdate( $dbw, $days, $window ) ?: $cTime;
}
}
return ( time() -
- ( $cTime ? wfTimestamp( TS_UNIX, $cTime ) : $wgActiveUserDays * 86400 ) );
+ ( $cTime ? wfTimestamp( TS_UNIX, $cTime ) : $days * 86400 ) );
}
/**
public static function cacheUpdate( DatabaseBase $dbw ) {
global $wgActiveUserDays;
- self::doQueryCacheUpdate( $dbw, $wgActiveUserDays * 86400 );
+ self::doQueryCacheUpdate( $dbw, $wgActiveUserDays, $wgActiveUserDays * 86400 );
}
/**
* Update the query cache as needed
*
* @param DatabaseBase $dbw
+ * @param int $days How many days user must be idle before he is considered inactive
* @param int $window Maximum time range of new data to scan (in seconds)
* @return int|bool UNIX timestamp the cache is now up-to-date as of (false on error)
*/
- protected static function doQueryCacheUpdate( DatabaseBase $dbw, $window ) {
- global $wgActiveUserDays;
-
+ protected static function doQueryCacheUpdate( DatabaseBase $dbw, $days, $window ) {
$lockKey = wfWikiID() . '-activeusers';
if ( !$dbw->lock( $lockKey, __METHOD__, 1 ) ) {
return false; // exclusive update (avoids duplicate entries)
// Pick the date range to fetch from. This is normally from the last
// update to till the present time, but has a limited window for sanity.
// If the window is limited, multiple runs are need to fully populate it.
- $sTimestamp = max( $cTimeUnix, $now - $wgActiveUserDays * 86400 );
+ $sTimestamp = max( $cTimeUnix, $now - $days * 86400 );
$eTimestamp = min( $sTimestamp + $window, $now );
// Get all the users active since the last update
$dbw->delete( 'querycachetwo',
array(
'qcc_type' => 'activeusers',
- 'qcc_value < ' . $dbw->addQuotes( $now - $wgActiveUserDays * 86400 ) // TS_UNIX
+ 'qcc_value < ' . $dbw->addQuotes( $now - $days * 86400 ) // TS_UNIX
),
__METHOD__
);
$size = $request->getIntOrNull( 'size' );
$NS = $request->getIntOrNull( 'namespace' );
- $pager = new ProtectedTitlesPager( $this, array(), $type, $level, $NS, $sizetype, $size );
+ $pager = new ProtectedTitlesPager( $this->getContext(), array(), $type, $level, $NS, $sizetype, $size );
$this->getOutput()->addHTML( $this->showOptions( $NS, $type, $level ) );
* @private
*/
function showOptions( $namespace, $type = 'edit', $level ) {
- global $wgScript;
- $action = htmlspecialchars( $wgScript );
+ $action = htmlspecialchars( wfScript() );
$title = $this->getPageTitle();
$special = htmlspecialchars( $title->getPrefixedDBkey() );
* @private
*/
function getLevelMenu( $pr_level ) {
- global $wgRestrictionLevels;
-
// Temporary array
$m = array( $this->msg( 'restriction-level-all' )->text() => 0 );
$options = array();
// First pass to load the log names
- foreach ( $wgRestrictionLevels as $type ) {
+ foreach ( $this->getConfig()->get( 'RestrictionLevels' ) as $type ) {
if ( $type != '' && $type != '*' ) {
// Messages: restriction-level-sysop, restriction-level-autoconfirmed
$text = $this->msg( "restriction-level-$type" )->text();
}
public function execute( $par ) {
- global $wgScript;
-
$cat = false;
$categoryStr = $this->getRequest()->getText( 'category', $par );
$submit = Html::input( '', $submitText, 'submit' );
$msg = $this->msg( 'randomincategory-selectcategory' );
- $form = Html::rawElement( 'form', array( 'action' => $wgScript ),
+ $form = Html::rawElement( 'form', array( 'action' => wfScript() ),
Html::hidden( 'title', $this->getPageTitle()->getPrefixedText() ) .
$msg->rawParams( $input, $submit )->parse()
);
* @return bool|ResultWrapper Result or false (for Recentchangeslinked only)
*/
public function doMainQuery( $conds, $opts ) {
- global $wgAllowCategorizedRecentChanges;
-
$dbr = $this->getDB();
$user = $this->getUser();
);
// Build the final data
- if ( $wgAllowCategorizedRecentChanges ) {
+ if ( $this->getConfig()->get( 'AllowCategorizedRecentChanges' ) ) {
$this->filterByCategories( $rows, $opts );
}
* @return array
*/
private function getFeedQuery() {
- global $wgFeedLimit;
$query = array_filter( $this->getOptions()->getAllValues(), function ( $value ) {
// API handles empty parameters in a different way
return $value !== '';
} );
$query['action'] = 'feedrecentchanges';
- if ( $query['limit'] > $wgFeedLimit ) {
- $query['limit'] = $wgFeedLimit;
+ $feedLimit = $this->getConfig()->get( 'FeedLimit' );
+ if ( $query['limit'] > $feedLimit ) {
+ $query['limit'] = $feedLimit;
}
return $query;
* @param FormOptions $opts
*/
public function outputChangesList( $rows, $opts ) {
- global $wgRCShowWatchingUsers, $wgShowUpdatedMarker;
-
$limit = $opts['limit'];
- $showWatcherCount = $wgRCShowWatchingUsers
+ $showWatcherCount = $this->getConfig()->get( 'RCShowWatchingUsers' )
&& $this->getUser()->getOption( 'shownumberswatching' );
$watcherCache = array();
$rc = RecentChange::newFromRow( $obj );
$rc->counter = $counter++;
# Check if the page has been updated since the last visit
- if ( $wgShowUpdatedMarker && !empty( $obj->wl_notificationtimestamp ) ) {
+ if ( $this->getConfig()->get( 'ShowUpdatedMarker' ) && !empty( $obj->wl_notificationtimestamp ) ) {
$rc->notificationtimestamp = ( $obj->rc_timestamp >= $obj->wl_notificationtimestamp );
} else {
$rc->notificationtimestamp = false; // Default
* @param int $numRows Number of rows in the result to show after this header
*/
public function doHeader( $opts, $numRows ) {
- global $wgScript;
-
$this->setTopText( $opts );
$defaults = $opts->getAllValues();
$t = $this->getPageTitle();
$out .= Html::hidden( 'title', $t->getPrefixedText() );
- $form = Xml::tags( 'form', array( 'action' => $wgScript ), $out );
+ $form = Xml::tags( 'form', array( 'action' => wfScript() ), $out );
$panel[] = $form;
$panelString = implode( "\n", $panel );
$extraOpts = array();
$extraOpts['namespace'] = $this->namespaceFilterForm( $opts );
- global $wgAllowCategorizedRecentChanges;
- if ( $wgAllowCategorizedRecentChanges ) {
+ if ( $this->getConfig()->get( 'AllowCategorizedRecentChanges' ) ) {
$extraOpts['category'] = $this->categoryFilterForm( $opts );
}
* @return string
*/
function optionsPanel( $defaults, $nondefaults, $numRows ) {
- global $wgRCLinkLimits, $wgRCLinkDays;
-
$options = $nondefaults + $defaults;
$note = '';
}
# Sort data for display and make sure it's unique after we've added user data.
- $linkLimits = $wgRCLinkLimits;
+ $linkLimits = $this->getConfig()->get( 'RCLinkLimits' );
$linkLimits[] = $options['limit'];
sort( $linkLimits );
$linkLimits = array_unique( $linkLimits );
- $linkDays = $wgRCLinkDays;
+ $linkDays = $this->getConfig()->get( 'RCLinkDays' );
$linkDays[] = $options['days'];
sort( $linkDays );
$linkDays = array_unique( $linkDays );
# No match, generate an edit URL
$title = Title::newFromText( $term );
if ( !is_null( $title ) ) {
- global $wgGoToEdit;
wfRunHooks( 'SpecialSearchNogomatch', array( &$title ) );
wfDebugLog( 'nogomatch', $title->getFullText(), 'private' );
# If the feature is enabled, go straight to the edit page
- if ( $wgGoToEdit ) {
+ if ( $this->getConfig()->get( 'GoToEdit' ) ) {
$this->getOutput()->redirect( $title->getFullURL( array( 'action' => 'edit' ) ) );
return;
* @param string $term
*/
public function showResults( $term ) {
- global $wgDisableTextSearch, $wgSearchForwardUrl, $wgContLang, $wgScript;
+ global $wgContLang;
$profile = new ProfileSection( __METHOD__ );
$search = $this->getSearchEngine();
$out = $this->getOutput();
- if ( $wgDisableTextSearch ) {
- if ( $wgSearchForwardUrl ) {
- $url = str_replace( '$1', urlencode( $term ), $wgSearchForwardUrl );
+ if ( $this->getConfig()->get( 'DisableTextSearch' ) ) {
+ $searchFowardUrl = $this->getConfig()->get( 'SearchForwardUrl' );
+ if ( $searchFowardUrl ) {
+ $url = str_replace( '$1', urlencode( $term ), $searchFowardUrl );
$out->redirect( $url );
} else {
$out->addHTML(
array(
'id' => ( $this->profile === 'advanced' ? 'powersearch' : 'search' ),
'method' => 'get',
- 'action' => $wgScript
+ 'action' => wfScript(),
)
)
);
$lang = $this->getLanguage();
- // format score
- if ( is_null( $result->getScore() ) ) {
- // Search engine doesn't report scoring info
- $score = '';
- } else {
- $percent = sprintf( '%2.1f', $result->getScore() * 100 );
- $score = $this->msg( 'search-result-score' )->numParams( $percent )->text()
- . ' - ';
- }
-
// format description
$byteSize = $result->getByteSize();
$wordCount = $result->getWordCount();
'<td style="vertical-align: top;">' .
"{$link} {$redirect} {$section} {$fileMatch}" .
$extract .
- "<div class='mw-search-result-data'>{$score}{$desc} - {$date}{$related}</div>" .
+ "<div class='mw-search-result-data'>{$desc} - {$date}{$related}</div>" .
'</td>' .
'</tr>' .
'</table>' .
$html = null;
+ $score = '';
if ( wfRunHooks( 'ShowSearchHit', array(
$this, $result, $terms,
&$link, &$redirect, &$section, &$extract,
) ) ) {
$html = "<li><div class='mw-search-result-heading'>" .
"{$link} {$redirect} {$section} {$fileMatch}</div> {$extract}\n" .
- "<div class='mw-search-result-data'>{$score}{$size} - {$date}{$related}</div>" .
+ "<div class='mw-search-result-data'>{$size} - {$date}{$related}</div>" .
"</li>\n";
}
}
private function getPageGroups() {
- global $wgSortSpecialPages;
-
$pages = SpecialPageFactory::getUsablePages( $this->getUser() );
if ( !count( $pages ) ) {
}
/** Sort */
- if ( $wgSortSpecialPages ) {
- foreach ( $groups as $group => $sortedPages ) {
- ksort( $groups[$group] );
- }
+ foreach ( $groups as $group => $sortedPages ) {
+ ksort( $groups[$group] );
}
/** Always move "other" to end */
}
public function execute( $par ) {
- global $wgMemc, $wgDisableCounters, $wgMiserMode;
+ global $wgMemc;
+
+ $disableCounters = $this->getConfig()->get( 'DisableCounters' );
+ $miserMode = $this->getConfig()->get( 'MiserMode' );
$this->setHeaders();
$this->getOutput()->addModuleStyles( 'mediawiki.special' );
# Staticic - views
$viewsStats = '';
- if ( !$wgDisableCounters ) {
+ if ( !$disableCounters ) {
$viewsStats = $this->getViewsStats();
}
# Set active user count
- if ( !$wgMiserMode ) {
+ if ( !$miserMode ) {
$key = wfMemcKey( 'sitestats', 'activeusers-updated' );
// Re-calculate the count if the last tally is old...
if ( !$wgMemc->get( $key ) ) {
$text .= $viewsStats;
# Statistic - popular pages
- if ( !$wgDisableCounters && !$wgMiserMode ) {
+ if ( !$disableCounters && !$miserMode ) {
$text .= $this->getMostViewedPages();
}
}
private function getUserStats() {
- global $wgActiveUserDays;
-
return Xml::openElement( 'tr' ) .
Xml::tags( 'th', array( 'colspan' => '2' ), $this->msg( 'statistics-header-users' )->parse() ) .
Xml::closeElement( 'tr' ) .
$this->getLanguage()->formatNum( $this->activeUsers ),
array( 'class' => 'mw-statistics-users-active' ),
'statistics-users-active-desc',
- $this->getLanguage()->formatNum( $wgActiveUserDays )
+ $this->getLanguage()->formatNum( $this->getConfig()->get( 'ActiveUserDays' ) )
);
}
private function getGroupStats() {
- global $wgGroupPermissions, $wgImplicitGroups;
$text = '';
- foreach ( $wgGroupPermissions as $group => $permissions ) {
+ foreach ( $this->getConfig()->get( 'GroupPermissions' ) as $group => $permissions ) {
# Skip generic * and implicit groups
- if ( in_array( $group, $wgImplicitGroups ) || $group == '*' ) {
+ if ( in_array( $group, $this->getConfig()->get( 'ImplicitGroups' ) ) || $group == '*' ) {
continue;
}
$groupname = htmlspecialchars( $group );
}
function execute( $par ) {
- // Global array containing names of tracking categories
- global $wgTrackingCategories;
-
$this->setHeaders();
$this->outputHeader();
$this->getOutput()->allowClickjacking();
</tr></thead>"
);
- foreach ( $wgTrackingCategories as $catMsg ) {
+ foreach ( $this->getConfig()->get( 'TrackingCategories' ) as $catMsg ) {
/*
* Check if the tracking category varies by namespace
* Otherwise only pages in the current namespace will be displayed
/** @var Status */
protected $revisionStatus;
- function __construct( $title ) {
+ /** @var Config */
+ protected $config;
+
+ function __construct( $title, Config $config = null ) {
if ( is_null( $title ) ) {
throw new MWException( __METHOD__ . ' given a null title.' );
}
$this->title = $title;
+ if ( $config === null ) {
+ wfDebug( __METHOD__ . ' did not have a Config object passed to it' );
+ $config = ConfigFactory::getDefaultInstance()->makeConfig( 'main' );
+ }
+ $this->config = $config;
}
/**
* @return ResultWrapper
*/
function listRevisions() {
- global $wgContentHandlerUseDB;
-
$dbr = wfGetDB( DB_SLAVE );
$tables = array( 'archive' );
'ar_comment', 'ar_len', 'ar_deleted', 'ar_rev_id', 'ar_sha1',
);
- if ( $wgContentHandlerUseDB ) {
+ if ( $this->config->get( 'ContentHandlerUseDB' ) ) {
$fields[] = 'ar_content_format';
$fields[] = 'ar_content_model';
}
* @return Revision|null
*/
function getRevision( $timestamp ) {
- global $wgContentHandlerUseDB;
-
$dbr = wfGetDB( DB_SLAVE );
$fields = array(
'ar_sha1',
);
- if ( $wgContentHandlerUseDB ) {
+ if ( $this->config->get( 'ContentHandlerUseDB' ) ) {
$fields[] = 'ar_content_format';
$fields[] = 'ar_content_model';
}
* @return Status Status object containing the number of revisions restored on success
*/
private function undeleteRevisions( $timestamps, $unsuppress = false, $comment = '' ) {
- global $wgContentHandlerUseDB;
-
if ( wfReadOnly() ) {
throw new ReadOnlyError();
}
'ar_sha1'
);
- if ( $wgContentHandlerUseDB ) {
+ if ( $this->config->get( 'ContentHandlerUseDB' ) ) {
$fields[] = 'ar_content_format';
$fields[] = 'ar_content_model';
}
}
function showSearchForm() {
- global $wgScript;
-
$out = $this->getOutput();
$out->setPageTitle( $this->msg( 'undelete-search-title' ) );
$out->addHTML(
- Xml::openElement( 'form', array( 'method' => 'get', 'action' => $wgScript ) ) .
+ Xml::openElement( 'form', array( 'method' => 'get', 'action' => wfScript() ) ) .
Xml::fieldset( $this->msg( 'undelete-search-box' )->text() ) .
Html::hidden( 'title', $this->getPageTitle()->getPrefixedDBkey() ) .
Html::rawElement(
return;
}
- $archive = new PageArchive( $this->mTargetObj );
+ $archive = new PageArchive( $this->mTargetObj, $this->getConfig() );
if ( !wfRunHooks( 'UndeleteForm::showRevision', array( &$archive, $this->mTargetObj ) ) ) {
return;
}
array( 'undeletepagetitle', wfEscapeWikiText( $this->mTargetObj->getPrefixedText() ) )
);
- $archive = new PageArchive( $this->mTargetObj );
+ $archive = new PageArchive( $this->mTargetObj, $this->getConfig() );
wfRunHooks( 'UndeleteForm::showHistory', array( &$archive, $this->mTargetObj ) );
/*
$text = $archive->getLastRevisionText();
}
function undelete() {
- global $wgUploadMaintenance;
-
- if ( $wgUploadMaintenance && $this->mTargetObj->getNamespace() == NS_FILE ) {
+ if ( $this->getConfig()->get( 'UploadMaintenance' ) && $this->mTargetObj->getNamespace() == NS_FILE ) {
throw new ErrorPageError( 'undelete-error', 'filedelete-maintenance' );
}
}
$out = $this->getOutput();
- $archive = new PageArchive( $this->mTargetObj );
+ $archive = new PageArchive( $this->mTargetObj, $this->getConfig() );
wfRunHooks( 'UndeleteForm::undelete', array( &$archive, $this->mTargetObj ) );
$ok = $archive->undelete(
$this->mTargetTimestamp,
}
public function checkExecutePermissions( User $user ) {
- global $wgReadOnlyFile;
-
parent::checkExecutePermissions( $user );
# If the lock file isn't writable, we can do sweet bugger all
- if ( !file_exists( $wgReadOnlyFile ) ) {
+ if ( !file_exists( $this->getConfig()->get( 'ReadOnlyFile' ) ) ) {
throw new ErrorPageError( 'lockdb', 'databasenotlocked' );
}
}
}
public function onSubmit( array $data ) {
- global $wgReadOnlyFile;
-
if ( !$data['Confirm'] ) {
return Status::newFatal( 'locknoconfirm' );
}
+ $readOnlyFile = $this->getConfig()->get( 'ReadOnlyFile' );
wfSuppressWarnings();
- $res = unlink( $wgReadOnlyFile );
+ $res = unlink( $readOnlyFile );
wfRestoreWarnings();
if ( $res ) {
return Status::newGood();
} else {
- return Status::newFatal( 'filedeleteerror', $wgReadOnlyFile );
+ return Status::newFatal( 'filedeleteerror', $readOnlyFile );
}
}
}
function getQueryInfo() {
- global $wgCountCategorizedImagesAsUsed;
$retval = array(
'tables' => array( 'image', 'imagelinks' ),
'fields' => array(
'join_conds' => array( 'imagelinks' => array( 'LEFT JOIN', 'il_to = img_name' ) )
);
- if ( $wgCountCategorizedImagesAsUsed ) {
+ if ( $this->getConfig()->get( 'CountCategorizedImagesAsUsed' ) ) {
// Order is significant
$retval['tables'] = array( 'image', 'page', 'categorylinks',
'imagelinks' );
* @return bool Success
*/
private function outputThumbFromStash( $file, $params ) {
- // this global, if it exists, points to a "scaler", as you might find in
+ $flags = 0;
+ // this config option, if it exists, points to a "scaler", as you might find in
// the Wikimedia Foundation cluster. See outputRemoteScaledThumb(). This
// is part of our horrible NFS-based system, we create a file on a mount
// point here, but fetch the scaled file from somewhere else that
// happens to share it over NFS.
- global $wgUploadStashScalerBaseUrl;
-
- $flags = 0;
- if ( $wgUploadStashScalerBaseUrl ) {
+ if ( $this->getConfig()->get( 'UploadStashScalerBaseUrl' ) ) {
$this->outputRemoteScaledThumb( $file, $params, $flags );
} else {
$this->outputLocallyScaledThumb( $file, $params, $flags );
throw new UploadStashFileNotFoundException( "no local path for scaled item" );
}
- // now we should construct a File, so we can get mime and other such info in a standard way
- // n.b. mimetype may be different from original (ogx original -> jpeg thumb)
+ // now we should construct a File, so we can get MIME and other such info in a standard way
+ // n.b. MIME type may be different from original (ogx original -> jpeg thumb)
$thumbFile = new UnregisteredLocalFile( false,
$this->stash->repo, $thumbnailImage->getStoragePath(), false );
if ( !$thumbFile ) {
* @return bool Success
*/
private function outputRemoteScaledThumb( $file, $params, $flags ) {
- // This global probably looks something like
+ // This option probably looks something like
// 'http://upload.wikimedia.org/wikipedia/test/thumb/temp'. Do not use
// trailing slash.
- global $wgUploadStashScalerBaseUrl;
- $scalerBaseUrl = $wgUploadStashScalerBaseUrl;
+ $scalerBaseUrl = $this->getConfig()->get( 'UploadStashScalerBaseUrl' );
if ( preg_match( '/^\/\//', $scalerBaseUrl ) ) {
// this is apparently a protocol-relative URL, which makes no sense in this context,
* Output HTTP response of raw content
* Side effect: writes HTTP response to STDOUT.
* @param string $content Content
- * @param string $contentType Mime type
+ * @param string $contentType MIME type
* @throws SpecialUploadStashTooLargeException
* @return bool
*/
/**
* Output headers for streaming
* @todo Unsure about encoding as binary; if we received from HTTP perhaps
- * we should use that encoding, concatted with semicolon to mimeType as it
+ * we should use that encoding, concatenated with semicolon to `$contentType` as it
* usually is.
* Side effect: preps PHP to write headers to STDOUT.
* @param string $contentType String suitable for content-type header
const NEED_TOKEN = 12;
const WRONG_TOKEN = 13;
+ /**
+ * Valid error and warning messages
+ *
+ * Special:Userlogin can show an error or warning message on the form when
+ * coming from another page. This is done via the ?error= or ?warning= GET
+ * parameters.
+ *
+ * This array is the list of valid message keys. All other values will be
+ * ignored.
+ *
+ * @since 1.24
+ * @var string[]
+ */
+ public static $validErrorMessages = array(
+ 'exception-nologin-text',
+ 'watchlistanontext',
+ 'changeemail-no-info',
+ 'resetpass-no-info',
+ 'confirmemail_needlogin',
+ 'prefsnologintext2',
+ );
+
public $mAbortLoginErrorMsg = null;
protected $mUsername;
protected $mType;
protected $mReason;
protected $mRealName;
+ protected $mEntryError = '';
+ protected $mEntryErrorType = 'error';
private $mTempPasswordUsed;
private $mLoaded = false;
$this->mReturnTo = $request->getVal( 'returnto', '' );
$this->mReturnToQuery = $request->getVal( 'returntoquery', '' );
+ // Show an error or warning passed on from a previous page
+ $entryError = $this->msg( $request->getVal( 'error', '' ) );
+ $entryWarning = $this->msg( $request->getVal( 'warning', '' ) );
+ // bc: provide login link as a parameter for messages where the translation
+ // was not updated
+ $loginreqlink = Linker::linkKnown(
+ $this->getPageTitle(),
+ $this->msg( 'loginreqlink' )->escaped(),
+ array(),
+ array(
+ 'returnto' => $this->mReturnTo,
+ 'returntoquery' => $this->mReturnToQuery,
+ 'uselang' => $this->mLanguage,
+ 'fromhttp' => $this->mFromHTTP ? '1' : '0',
+ )
+ );
+
+ // Only show valid error or warning messages.
+ if ( $entryError->exists()
+ && in_array( $entryError->getKey(), self::$validErrorMessages )
+ ) {
+ $this->mEntryErrorType = 'error';
+ $this->mEntryError = $entryError->rawParams( $loginreqlink )->escaped();
+
+ } elseif ( $entryWarning->exists()
+ && in_array( $entryWarning->getKey(), self::$validErrorMessages )
+ ) {
+ $this->mEntryErrorType = 'warning';
+ $this->mEntryError = $entryWarning->rawParams( $loginreqlink )->escaped();
+ }
+
if ( $wgEnableEmail ) {
$this->mEmail = $request->getText( 'wpEmail' );
} else {
}
$this->setHeaders();
+ // In the case where the user is already logged in, do not show the login page.
+ // The use case scenario for this is when a user opens a large number of tabs, is
+ // redirected to the login page on all of them, and then logs in on one, expecting
+ // all the others to work properly.
+ if ( $this->mType !== 'signup' && !$this->mPosted && $this->getUser()->isLoggedIn() ) {
+ $this->successfulLogin();
+ }
+
// If logging in and not on HTTPS, either redirect to it or offer a link.
global $wgSecureLogin;
if ( $this->mRequest->getProtocol() !== 'https' ) {
'returntoquery' => $this->mReturnToQuery !== '' ?
$this->mReturnToQuery : null,
'title' => null,
+ ( $this->mEntryErrorType === 'error' ? 'error' : 'warning' ) => $this->mEntryError,
) + $this->mRequest->getQueryValues();
$url = $title->getFullURL( $query, false, PROTO_HTTPS );
if ( $wgSecureLogin
return;
}
}
- $this->mainLoginForm( '' );
+ $this->mainLoginForm( $this->mEntryError, $this->mEntryErrorType );
}
/**
* @return Status
*/
public function fetchUser( $username ) {
- global $wgUserrightsInterwikiDelimiter;
-
- $parts = explode( $wgUserrightsInterwikiDelimiter, $username );
+ $parts = explode( $this->getConfig()->get( 'UserrightsInterwikiDelimiter' ), $username );
if ( count( $parts ) < 2 ) {
$name = trim( $username );
$database = '';
* Output a form to allow searching for a user
*/
function switchForm() {
- global $wgScript;
$this->getOutput()->addHTML(
Html::openElement(
'form',
array(
'method' => 'get',
- 'action' => $wgScript,
+ 'action' => wfScript(),
'name' => 'uluser',
'id' => 'mw-userrights-form1'
)
$software = array();
$software['[https://www.mediawiki.org/ MediaWiki]'] = self::getVersionLinked();
$phpKey = wfIsHHVM() ? '[http://hhvm.com/ HHVM]' :
- '[http://www.php.net/ PHP]';
+ '[https://php.net/ PHP]';
$software[$phpKey] = PHP_VERSION . " (" . PHP_SAPI . ")";
$software[$dbr->getSoftwareLink()] = $dbr->getServerInfo();
}
function getQueryInfo() {
- global $wgWantedPagesThreshold;
- $count = $wgWantedPagesThreshold - 1;
+ $count = $this->getConfig()->get( 'WantedPagesThreshold' ) - 1;
$query = array(
'tables' => array(
'pagelinks',
* @param string $subpage
*/
function execute( $subpage ) {
- global $wgEnotifWatchlist, $wgShowUpdatedMarker;
-
// Anons don't get a watchlist
$this->requireLogin( 'watchlistanontext' );
$user = $this->getUser();
$opts = $this->getOptions();
- if ( ( $wgEnotifWatchlist || $wgShowUpdatedMarker )
+ $config = $this->getConfig();
+ if ( ( $config->get( 'EnotifWatchlist' ) || $config->get( 'ShowUpdatedMarker' ) )
&& $request->getVal( 'reset' )
&& $request->wasPosted()
) {
* @return bool|ResultWrapper Result or false (for Recentchangeslinked only)
*/
public function doMainQuery( $conds, $opts ) {
- global $wgShowUpdatedMarker;
-
$dbr = $this->getDB();
$user = $this->getUser();
),
);
- if ( $wgShowUpdatedMarker ) {
+ if ( $this->getConfig()->get( 'ShowUpdatedMarker' ) ) {
$fields[] = 'wl_notificationtimestamp';
}
if ( $limitWatchlist ) {
* @param FormOptions $opts
*/
public function outputChangesList( $rows, $opts ) {
- global $wgShowUpdatedMarker, $wgRCShowWatchingUsers;
-
$dbr = $this->getDB();
$user = $this->getUser();
$output = $this->getOutput();
$rc = RecentChange::newFromRow( $obj );
$rc->counter = $counter++;
- if ( $wgShowUpdatedMarker ) {
+ if ( $this->getConfig()->get( 'ShowUpdatedMarker' ) ) {
$updated = $obj->wl_notificationtimestamp;
} else {
$updated = false;
}
- if ( $wgRCShowWatchingUsers && $user->getOption( 'shownumberswatching' ) ) {
+ if ( $this->getConfig()->get( 'RCShowWatchingUsers' ) && $user->getOption( 'shownumberswatching' ) ) {
$rc->numberofWatchingusers = $dbr->selectField( 'watchlist',
'COUNT(*)',
array(
}
function setTopText( FormOptions $opts ) {
- global $wgEnotifWatchlist, $wgShowUpdatedMarker;
-
$nondefaults = $opts->getChangedValues();
$form = "";
$user = $this->getUser();
$dbr = $this->getDB();
$numItems = $this->countItems( $dbr );
+ $showUpdatedMarker = $this->getConfig()->get( 'ShowUpdatedMarker' );
// Show watchlist header
$form .= "<p>";
$form .= $this->msg( 'nowatchlist' )->parse() . "\n";
} else {
$form .= $this->msg( 'watchlist-details' )->numParams( $numItems )->parse() . "\n";
- if ( $wgEnotifWatchlist && $user->getOption( 'enotifwatchlistpages' ) ) {
+ if ( $this->getConfig()->get( 'EnotifWatchlist' ) && $user->getOption( 'enotifwatchlistpages' ) ) {
$form .= $this->msg( 'wlheader-enotif' )->parse() . "\n";
}
- if ( $wgShowUpdatedMarker ) {
+ if ( $showUpdatedMarker ) {
$form .= $this->msg( 'wlheader-showupdated' )->parse() . "\n";
}
}
$form .= "</p>";
- if ( $numItems > 0 && $wgShowUpdatedMarker ) {
+ if ( $numItems > 0 && $showUpdatedMarker ) {
$form .= Xml::openElement( 'form', array( 'method' => 'post',
'action' => $this->getPageTitle()->getLocalURL(),
'id' => 'mw-watchlist-resetbutton' ) ) . "\n" .
}
function execute( $par ) {
- global $wgQueryPageDefaultLimit;
$out = $this->getOutput();
$this->setHeaders();
$opts->add( 'target', '' );
$opts->add( 'namespace', '', FormOptions::INTNULL );
- $opts->add( 'limit', $wgQueryPageDefaultLimit );
+ $opts->add( 'limit', $this->getConfig()->get( 'QueryPageDefaultLimit' ) );
$opts->add( 'from', 0 );
$opts->add( 'back', 0 );
$opts->add( 'hideredirs', false );
* @param int $back Display from this article ID at backwards scrolling (default: 0)
*/
function showIndirectLinks( $level, $target, $limit, $from = 0, $back = 0 ) {
- global $wgMaxRedirectLinksRetrieved, $wgUseLinkNamespaceDBFields;
-
$out = $this->getOutput();
$dbr = wfGetDB( DB_SLAVE );
'il_to' => $target->getDBkey(),
);
+ $useLinkNamespaceDBFields = $this->getConfig()->get( 'UseLinkNamespaceDBFields' );
$namespace = $this->opts->getValue( 'namespace' );
if ( is_int( $namespace ) ) {
- if ( $wgUseLinkNamespaceDBFields ) {
+ if ( $useLinkNamespaceDBFields ) {
$conds['pagelinks']['pl_from_namespace'] = $namespace;
$conds['templatelinks']['tl_from_namespace'] = $namespace;
$conds['imagelinks']['il_from_namespace'] = $namespace;
$conds['pagelinks'][] = 'rd_from is NOT NULL';
}
- $queryFunc = function ( $dbr, $table, $fromCol ) use ( $conds, $target, $limit ) {
- global $wgUseLinkNamespaceDBFields;
+ $queryFunc = function ( $dbr, $table, $fromCol ) use ( $conds, $target, $limit, $useLinkNamespaceDBFields ) {
// Read an extra row as an at-end check
$queryLimit = $limit + 1;
$on = array(
'rd_title' => $target->getDBkey(),
'rd_interwiki = ' . $dbr->addQuotes( '' ) . ' OR rd_interwiki IS NULL'
);
- if ( $wgUseLinkNamespaceDBFields ) { // migration check
+ if ( $useLinkNamespaceDBFields ) { // migration check
$on['rd_namespace'] = $target->getNamespace();
}
// Inner LIMIT is 2X in case of stale backlinks with wrong namespaces
if ( $row->rd_from && $level < 2 ) {
$out->addHTML( $this->listItem( $row, $nt, $target, true ) );
- $this->showIndirectLinks( $level + 1, $nt, $wgMaxRedirectLinksRetrieved );
+ $this->showIndirectLinks( $level + 1, $nt, $this->getConfig()->get( 'MaxRedirectLinksRetrieved' ) );
$out->addHTML( Xml::closeElement( 'li' ) );
} else {
$out->addHTML( $this->listItem( $row, $nt, $target ) );
}
function whatlinkshereForm() {
- global $wgScript;
-
// We get nicer value from the title object
$this->opts->consumeValue( 'target' );
// Reset these for new requests
$namespace = $this->opts->consumeValue( 'namespace' );
# Build up the form
- $f = Xml::openElement( 'form', array( 'action' => $wgScript ) );
+ $f = Xml::openElement( 'form', array( 'action' => wfScript() ) );
# Values that should not be forgotten
$f .= Html::hidden( 'title', $this->getPageTitle()->getPrefixedText() );
}
function getPageHeader() {
- global $wgScript;
-
# Do not show useless input form if special page is cached
if ( $this->isCached() ) {
return '';
$prefix = $this->prefix;
$t = $this->getPageTitle();
- return Html::openElement( 'form', array( 'method' => 'get', 'action' => $wgScript ) ) . "\n" .
+ return Html::openElement( 'form', array( 'method' => 'get', 'action' => wfScript() ) ) . "\n" .
Html::openElement( 'fieldset' ) . "\n" .
Html::element( 'legend', null, $this->msg( 'withoutinterwiki-legend' )->text() ) . "\n" .
Html::hidden( 'title', $t->getPrefixedText() ) . "\n" .
}
/**
- * Verify the mime type.
+ * Verify the MIME type.
*
- * @note Only checks that it is not an evil mime. The "does it have
- * correct extension given its mime type?" check is in verifyFile.
- * @param string $mime Representing the mime
+ * @note Only checks that it is not an evil MIME. The "does it have
+ * correct extension given its MIME type?" check is in verifyFile.
+ * in `verifyFile()` that MIME type and file extension correlate.
+ * @param string $mime Representing the MIME
* @return mixed True if the file is verified, an array otherwise
*/
protected function verifyMimeType( $mime ) {
return array( 'filetype-badmime', $mime );
}
- # Check IE type
+ # Check what Internet Explorer would detect
$fp = fopen( $this->mTempPath, 'rb' );
$chunk = fread( $fp, 256 );
fclose( $fp );
$this->mFileProps = FSFile::getPropsFromPath( $this->mTempPath, $this->mFinalExtension );
- # check mime type, if desired
+ # check MIME type, if desired
$mime = $this->mFileProps['file-mime'];
$status = $this->verifyMimeType( $mime );
if ( $status !== true ) {
}
/**
- * Checks if the mime type of the uploaded file matches the file extension.
+ * Checks if the MIME type of the uploaded file matches the file extension.
*
- * @param string $mime The mime type of the uploaded file
+ * @param string $mime The MIME type of the uploaded file
* @param string $extension The filename extension that the file is to be served with
* @return bool
*/
* positives in some situations.
*
* @param string $file Pathname to the temporary upload file
- * @param string $mime The mime type of the file
+ * @param string $mime The MIME type of the file
* @param string $extension The extension of the file
* @return bool True if the file contains something looking like embedded scripts
*/
}
/**
- * Find or guess extension -- ensuring that our extension matches our mime type.
+ * Find or guess extension -- ensuring that our extension matches our MIME type.
* Since these files are constructed from php tempnames they may not start off
* with an extension.
* XXX this is somewhat redundant with the checks that ApiUpload.php does with incoming
if ( $n !== false ) {
$extension = $n ? substr( $path, $n + 1 ) : '';
} else {
- // If not, assume that it should be related to the mime type of the original file.
+ // If not, assume that it should be related to the MIME type of the original file.
$magic = MimeMagic::singleton();
$mimeType = $magic->guessMimeType( $path );
$extensions = explode( ' ', MimeMagic::singleton()->getExtensionsForType( $mimeType ) );
'ar' => 'العربية', # Arabic
'arc' => 'ܐܪܡܝܐ', # Aramaic
'arn' => 'mapudungun', # Mapuche, Mapudungu, Araucanian (Araucano)
- 'arq' => 'جزائرÙ\8a', # Algerian Spoken Arabic
+ 'arq' => 'جازاÙ\8aرÙ\8aØ©', # Algerian Spoken Arabic
'ary' => 'Maġribi', # Moroccan Spoken Arabic
'arz' => 'مصرى', # Egyptian Spoken Arabic
'as' => 'অসমীয়া', # Assamese
"uploadwarning": "تحذير الرفع",
"uploadwarning-text": "من فضلك عدل وصف الملف أدناه وحاول مرة أخرى.",
"savefile": "احفظ الملف",
- "uploadedimage": "رفع \"[[$1]]\"",
- "overwroteimage": "رفع نسخة جديدة من \"[[$1]]\"",
"uploaddisabled": "تم تعطيل الرفع",
"copyuploaddisabled": "الرفع من مسار معطل.",
"uploaddisabledtext": "رفع الملفات معطل.",
"uploadwarning": "Avisu de xubíes de ficheros",
"uploadwarning-text": "Por favor, camuda más abaxo la descripción del ficheru y vuelve a tentalo.",
"savefile": "Guardar ficheru",
- "uploadedimage": "xubió \"[[$1]]\"",
- "overwroteimage": "xubió una versión nueva de \"[[$1]]\"",
"uploaddisabled": "Deshabilitaes les xubíes",
"copyuploaddisabled": "Xubir por URL ta desactivao.",
"uploaddisabledtext": "Les xubíes de ficheros tán desactivaes.",
"uploadwarning": "Папярэджаньне",
"uploadwarning-text": "Калі ласка, зьмяніце апісаньне файла ніжэй і паспрабуйце ізноў.",
"savefile": "Захаваць файл",
- "uploadedimage": "загружаная «[[$1]]»",
- "overwroteimage": "загружаная новая вэрсія «[[$1]]»",
"uploaddisabled": "Загрузка файлаў забароненая",
"copyuploaddisabled": "Загрузка праз URL-адрас адключаная.",
"uploaddisabledtext": "Загрузка файлаў забароненая.",
"logentry-rights-rights": "$1 {{GENDER:$1|зьмяніў|зьмяніла}} прыналежнасьць $3 да групы з $4 на $5",
"logentry-rights-rights-legacy": "$1 {{GENDER:$1|зьмяніў|зьмяніла}} прыналежнасьць $3 да групаў",
"logentry-rights-autopromote": "$1 {{GENDER:$1|быў аўтаматычна пераведзены|была аўтаматычна пераведзеная}} з групы $4 ў $5",
+ "logentry-upload-upload": "$1 {{GENDER:$2|загрузіў|загрузіла}} $3",
+ "logentry-upload-overwrite": "$1 {{GENDER:$2|загрузіў|загрузіла}} новую вэрсію $3",
"rightsnone": "(няма)",
"feedback-bugornote": "Калі Вы гатовы падрабязна апісаць тэхнічную праблему, калі ласка [$1 паведаміце пра памылку]. \nУ адваротным выпадку, Вы можаце выкарыстоўваць простую форму пададзеную ніжэй. Ваш камэнтар будзе дададзены на старонку «[$3 $2]», разам з Вашым іменем удзельніка і выкарыстоўваемым браўзэрам.",
"feedback-subject": "Тэма:",
"uploadwarning": "Папярэджанне пра ўкладанне",
"uploadwarning-text": "Калі ласка, змяніце апісанне файла ніжэй і паўтарыце спробу.",
"savefile": "Запісаць файл",
- "uploadedimage": "укладзена \"[[$1]]\"",
- "overwroteimage": "укладзена новая версія \"[[$1]]\"",
"uploaddisabled": "Укладанні не дазваляюцца",
"copyuploaddisabled": "Даданне па URL адключана.",
"uploaddisabledtext": "Не дазваляюцца ўкладанні файлаў.",
"uploadwarning": "Предупреждение при качване",
"uploadwarning-text": "Необходимо е да промените описанието на файла по-долу и да опитате отново.",
"savefile": "Съхраняване на файл",
- "uploadedimage": "качи „[[$1]]“",
- "overwroteimage": "качи нова версия на „[[$1]]“",
"uploaddisabled": "Качванията са забранени.",
"copyuploaddisabled": "Спряно е качването на файлове чрез URL.",
"uploaddisabledtext": "Качването на файлове е забранено.",
"uploadwarning": "আপলোড সতর্কবাণী",
"uploadwarning-text": "অনুগ্রহ করে নিচে ফাইলের বর্ণনা পরিবর্তন করে আবার চেষ্টা করুন।",
"savefile": "সংরক্ষণ",
- "uploadedimage": "\"[[$1]]\" আপলোড করা হয়েছে।",
- "overwroteimage": "\"[[$1]]\"-এর একটি নতুন সংস্করণ আপলোড করা হয়েছে",
"uploaddisabled": "আপলোড নিষ্ক্রিয় আছে",
"copyuploaddisabled": "ইউআরএল এর মাধ্যমে আপলোড নিস্ক্রিয় রয়েছে।",
"uploaddisabledtext": "ফাইল আপলোড নিষ্ক্রিয়।",
"uploadwarning": "Kemenn diwall en ur ezporzhiañ",
"uploadwarning-text": "Cheñchit deskrivadur ar restr a-is ha klaskit en-dro.",
"savefile": "Enrollañ ar restr",
- "uploadedimage": "\"[[$1]]\" enporzhiet",
- "overwroteimage": "enporzhiet ur stumm nevez eus \"[[$1]]\"",
"uploaddisabled": "Ho tigarez, diweredekaet eo bet kas ar restr-mañ.",
"copyuploaddisabled": "Diweredekaet eo bet ar pellgargañ dre URL.",
"uploaddisabledtext": "Diweredekaet eo an enporzhiañ restroù.",
"uploadwarning": "Avís de càrrega",
"uploadwarning-text": "Modifiqueu la descripció de la imatge i torneu a intentar-ho.",
"savefile": "Desa el fitxer",
- "uploadedimage": "ha carregat [[$1]]",
- "overwroteimage": "ha carregat una nova versió de «[[$1]]»",
"uploaddisabled": "S'ha inhabilitat la càrrega",
"copyuploaddisabled": "Càrrega per URL deshabilitada.",
"uploaddisabledtext": "S'ha inhabilitat la càrrega de fitxers.",
"아라",
"Mywood",
"Impersonator 1",
- "LNDDYL"
+ "LNDDYL",
+ "唐吉訶德的侍從"
]
},
"tog-underline": "下劃綫鏈接",
"editfont-monospace": "蜀様寬其字體",
"editfont-sansserif": "無襯線其字體",
"editfont-serif": "有襯線其字體",
- "sunday": "禮拜",
- "monday": "拜一",
- "tuesday": "拜二",
- "wednesday": "拜三",
- "thursday": "拜四",
- "friday": "拜五",
- "saturday": "拜六",
- "sun": "禮拜",
- "mon": "拜一",
- "tue": "拜二",
- "wed": "拜三",
- "thu": "拜四",
- "fri": "拜五",
- "sat": "拜六",
+ "sunday": "Lā̤ buái/禮拜",
+ "monday": "Buái ék/拜一",
+ "tuesday": "Buái nê/拜二",
+ "wednesday": "Buái săng / 拜三",
+ "thursday": "Buái sé/拜四",
+ "friday": "Buái ngô/拜五",
+ "saturday": "Buái lĕ̤k/拜六",
+ "sun": "Lā̤ buái/禮拜",
+ "mon": "Buái ék/拜一",
+ "tue": "Buái nê/拜二",
+ "wed": "Buái săng/拜三",
+ "thu": "Buái sé/拜四",
+ "fri": "Buái ngô/拜五",
+ "sat": "Buái lĕ̤k/拜六",
"january": "一月",
"february": "二月",
"march": "三月",
"fileexists": "名字蜀樣其文件已經存在去了。如果汝𣍐確定汝是伓是卜想刪掉伊,起動檢查蜀下<strong>[[:$1]]</strong>。\n[[$1|thumb]]",
"uploadwarning": "上傳警告",
"savefile": "保存文件",
- "uploadedimage": "已經上傳其「[[$1]]」",
"uploadvirus": "茲文件有病毒!\n細底:$1",
"sourcefilename": "源文件名:",
"destfilename": "目標文件名:",
"changeemail-password": "Хьан пароль «{{SITENAME}}» проектан:",
"changeemail-submit": "Хийца email",
"changeemail-cancel": "Цаоьшу",
+ "changeemail-throttled": "Хьо дукха гӀиртира.\nДехар до, собар де $1 юха гӀортале.",
"resettokens": "Токенаш кхоссар",
"resettokens-text": "Хьан йиш ю токенаш кхосса, цара йиш хуьлуьйту цхьаболу долара хаамашна тӀекхача, уьш ю хьан дӀаяздар ца вовшахтесна. \n\nХьона иза оьшу, ахьа хьай токенаш цхьам гучу яьхна елахь я хьан аккаунт йохийна елахь.",
"resettokens-no-tokens": "Кхосса токенаш яц.",
"blankarticle": "<strong>ДӀахьедар:</strong> Ахьа кхуллуш йолу агӀо еса ю.\nЮху кнопка «{{int:savearticle}}» тӀетаӀаяхь, агӀо цхьа чулацам боцуш кхуллур ю.",
"anoneditwarning": "'''Тергам бе''': Ахьа хьай цӀарца тадарш деш дац. Хьан IP-адрес дӀаяздина хира ду хӀокху агӀон истори чу.",
"anonpreviewwarning": "''Системин чу цагӀахь хьан IP-адрес агӀона истори чу дӀаяз лур ду.''",
+ "missingsummary": "'''Дагадаийтар.''' Ахьа хийцамаш лаьцна доца яздина дац. Кнопка «{{int:savearticle}}» юху тӀетаӀича хийцамах лаьцна хӀума доцуш Ӏалашбира бу.",
"missingcommenttext": "Дехар до дӀаязбе хайн хаам лахахь.",
+ "missingcommentheader": "'''Дагадаийтар.''' Ахьа хӀокху къамелан дӀахьедар/корта билгал бина бац. Кнопка «{{int:savearticle}}» юху тӀетаӀича хийцамах лаьцна хӀума доцуш Ӏалашбира бу.",
"summary-preview": "Цуьнах лаьцна хирду:",
"subject-preview": "Коьрта могӀа хира бу:",
"blockedtitle": "Декъашхочун блоктоьхана",
"uploadwarning": "Дlахьедар",
"uploadwarning-text": "Дехар до, лахара файлах лаьцнарг хийца а дай юху а гӀорта файл чуяккха.",
"savefile": "ДӀаязе йе файл",
- "uploadedimage": "чуяьккхина «[[$1]]»",
- "overwroteimage": "Чуяьккхина файлан керла верси «[[$1]]»",
"uploaddisabled": "Чуяккхар магийна дац",
"copyuploaddisabled": "URL тӀера чуяккхар дӀадайина ду.",
"uploaddisabledtext": "Файлаш чуяхар дӀадайина ду.",
"logentry-rights-rights": "$1 {{GENDER:$2|хийцина}} $3 бакъо $4 → $5",
"logentry-rights-rights-legacy": "$1 {{GENDER:$2|хийцина}} хӏокхуна $3 бакъо",
"logentry-rights-autopromote": "$1 {{GENDER:$2|вара|яра}} автоматически {{GENDER:$2|сихьа ваьлла|сихьа яьлла}} $4 $5 чу",
+ "logentry-upload-revert": "$1 {{GENDER:$2|чуяьккхина}} $3",
"rightsnone": "(яц)",
"feedback-bugornote": "Хьайн техникин халонах лаьцна яздан хӀума делахь, дехар до, [$1 хаам бе тхоьга].\nДацахь хьан йиш ю хӀокху атта кепаца «[$3 $2]» агӀонг къамел тӀетоха хьан декъашхочун цӀарца, кхин лелош йолу браузер билгал еш.",
"feedback-subject": "Къамел:",
"uploadwarning": "Upozornění k načítání",
"uploadwarning-text": "Prosíme, upravte popis souboru níže a zkuste to znovu.",
"savefile": "Uložit soubor",
- "uploadedimage": "načítá „[[$1]]“",
- "overwroteimage": "načtena nová verze \"[[$1]]\"",
"uploaddisabled": "Načítání souborů vypnuto.",
"copyuploaddisabled": "Načítání souborů prostřednictvím URL je vypnuto.",
"uploaddisabledtext": "Načítání souborů je vypnuto.",
"Søren Løvborg",
"Tjernobyl",
"Urhixidur",
- "아라"
+ "아라",
+ "Thomsen"
]
},
"tog-underline": "Understreg henvisninger:",
"uploadwarning": "Advarsel",
"uploadwarning-text": "Vær venlig at ændre filbeskrivelsen nedenfor og prøv igen.",
"savefile": "Gem fil",
- "uploadedimage": "lagde \"[[$1]]\" op",
- "overwroteimage": "lagde en ny version af \"[[$1]]\" op",
"uploaddisabled": "Desværre er funktionen til at lægge filer op afbrudt på denne server.",
"copyuploaddisabled": "Upload via URL er slået fra.",
"uploaddisabledtext": "Oplægning af filer er deaktiveret.",
"watchlist-details": "Du har $1 {{PLURAL:$1|side|sider}} på din overvågningsliste (ekskl. diskussionssider).",
"wlheader-enotif": "E-mail-underretning er slået til.",
"wlheader-showupdated": "Sider, der er ændret siden dit sidste besøg, er vist med '''fed skrift'''.",
- "wlnote2": "Nedenfor ses ændringerne i {{PLURAL:$1|den sidste time|de sidste <strong>$1</strong> timer}} op til den $2 kl. $3.",
+ "wlnote": "Nedenfor ses {{PLURAL:$1|den seneste ændring|de seneste '''$1''' ændringer}} i {{PLURAL:$2|den sidste time|de sidste '''$2''' timer}} op til den $3 kl. $4.",
"wlshowlast": "Vis de seneste $1 timer $2 dage $3",
"watchlist-options": "Indstillinger for overvågningslisten",
"watching": "Tilføjer overvågning …",
"uploadwarning": "Warnung",
"uploadwarning-text": "Bitte ändere unten die Dateibeschreibung und versuche es erneut.",
"savefile": "Datei speichern",
- "uploadedimage": "lud „[[$1]]“ hoch",
- "overwroteimage": "lud eine neue Version von „[[$1]]“ hoch",
"uploaddisabled": "Hochladen deaktiviert",
"copyuploaddisabled": "Das Hochladen von URLs ist deaktiviert",
"uploaddisabledtext": "Das Hochladen von Dateien ist deaktiviert.",
"logentry-rights-rights": "$1 {{GENDER:$2|änderte}} die Gruppenzugehörigkeit für $3 von $4 zu $5",
"logentry-rights-rights-legacy": "$1 {{GENDER:$2|änderte}} die Gruppenzugehörigkeit für $3",
"logentry-rights-autopromote": "$1 wurde automatisch von $4 zu $5 {{GENDER:$2|zugeordnet}}",
+ "logentry-upload-upload": "$1 {{GENDER:$2|lud}} $3 hoch",
+ "logentry-upload-overwrite": "$1 {{GENDER:$2|lud}} eine neue Version von $3 hoch",
+ "logentry-upload-revert": "$1 {{GENDER:$2|lud}} $3 hoch",
"rightsnone": "(–)",
"feedback-bugornote": "Sofern du detailliert ein technisches Problem beschreiben möchtest, melde bitte [$1 einen Fehler].\nAnderenfalls kannst du auch das untenstehende einfache Formular nutzen. Dein Kommentar wird, zusammen mit deinem Benutzernamen und der Version des von dir verwendeten Webbrowsers sowie Betriebssystems, auf der Seite „[$3 $2]“ hinzugefügt.",
"feedback-subject": "Betreff:",
"uploadwarning": "Îkazê bar kerdişî",
"uploadwarning-text": "Bînê de deskripyonê dosyayî bivurne u reyna qeyd bike.",
"savefile": "Dosya qeyd ke",
- "uploadedimage": "\"[[$1]]\" bar bi",
- "overwroteimage": "yew versiyonê \"$1\" newe bar bi",
"uploaddisabled": "bar kerdişî iptal biyo",
"copyuploaddisabled": "URL bar kerdiş kefiliyeyo.",
"uploaddisabledtext": "Barkerdışê dosya dewre ra veta.",
"tog-watchdefault": "Zûnta al pàgini e i file mudifichê int i tgnû 'd ôc specêl.",
"tog-watchmoves": "Zûnta al pàgini e i file spustê int i tgnû 'd ôc specêl.",
"tog-watchdeletion": "Zûnta al pàgini e i file scanşlê int i tgnû 'd ôc specêl.",
+ "tog-watchrollback": "Zûta al pàgini in dóv' ó fât al ritōren a la pàgina 'd préma a i tgnû 'd ôc specêl",
"tog-minordefault": "Sògna ògni mudéfica cme céca (sōl cme pre-stabilî)",
"tog-previewontop": "Fà vèder còl ch' ò fât sōver la caşèla ed mudéfica e mìa sòta.",
"tog-previewonfirst": "Fà vèder còl ch' ò fât almēno 'na vôlta préma 'd salvêr",
"preview": "Guêrda préma",
"showpreview": "Guêrda préma 'd salvêr",
"showdiff": "Guêrda i cambiamèint",
+ "blankarticle": "<strong>Atèinti:</strong>la pàgina che t'é drē fêr la gh'à gnînto dèinter. S' ét tōren a schisêr in sém a \"{{int:savearticle}}\", la pàgina la srà fât sèinsa gnînto dèinter.",
"anoneditwarning": "'''Atensiòun:''' Ingrès mìa fât. Al tó indirés IP al srà sgnê int la stòria ed cla pàgina chè.",
"anonpreviewwarning": "\"An n'é mìa stê fât l'ingrès. Mèinter es sêlva la pàgina, l'indirés IP al srà sgnê int la stòria 'd la pàgina.\"",
"missingsummary": "'''Atensiòun:''' an n'é mìa stê precişê al mutîv de sté mudéfica. S'es tōrna a clichêr insém a \"{{int:savearticle}}\" la mudéfica la gnirà salvêda cun al mutîv vōd.",
"rev-deleted-event": "(asiòun dal log armôsa)",
"rev-deleted-user-contribs": "(nòm utèint o indirés IP armôs - mudéfica lughêda da la stòria)",
"rev-deleted-text-permission": "Cla versiòun ché 'd la pàgina l'é stêda <strong> scanşlêda </strong>. \nConsultêr al [{{fullurl:{{#Special:Log}}/delete|page={{PAGENAMEE}}}} log dal canşladûri] per nōv particulêr.",
+ "rev-suppressed-text-permission": "Cla versiòun ché 'd la pàgina l'é stêda <strong> scanşlêda </strong>. Consultêr al [{{fullurl:{{#Special:Log}}/ suppress |page={{ FULLPAGENAMEE }}}} log dal canşladûri] per nōv particulêr.",
"rev-deleted-text-unhide": "Cla versiòun ché 'd la pàgina l'é stêda <strong> scanşlêda </strong>. Consultêr al [{{fullurl:{{#Special:Log}}/delete|page={{PAGENAMEE}}}} log dal canşladûri] per nōv particulêr.\nS' l' é necesâri a j aministradōr a gh'é incòra permés [$1 ed guardêr cla versiòun ché].",
"rev-suppressed-text-unhide": "Cla versiòun ché 'd la pàgina l'é stêda <strong> scanşlêda </strong>. Consultêr al [{{fullurl:{{#Special:Log}}/delete|page={{PAGENAMEE}}}} log dal canşladûri] per nōv particulêr.\nS' l' é necesâri a j aministradōr a gh'é incòra permés [$1 ed guardêr cla versiòun ché].",
"rev-deleted-text-view": "Cla versiòun ché 'd la pàgina l'é stêda <strong> scanşlêda </strong>. J aministradōr a pōlen incòra guardêrla; \nconsultêr al [{{fullurl:{{#Special:Log}}/delete|page={{PAGENAMEE}}}} log dal canşladûri] per nōv particulêr.",
"powersearch-togglenone": "Nisûn",
"powersearch-remember": "Arcôrda la siēlta per êtri sèirchi ch'é vō fêr",
"search-external": "Sèirca fâta fōra",
+ "searchdisabled": "La sèirca intêrna ed {{SITENAME}} l'a funsiòuna mìa; int al mèinter a s' pōl pruvêr a druvêr un mutōr ed sèirca d'ed fōra cme Google. (A gh' è da nutêr però che còl che gh'é dèinter in {{SITENAME}} che es câten in chi mutōr a prém èser mìa arnuvê.)",
+ "search-error": "É sucès un erōr mèinter a's fêva la sèirca:$1",
"preferences": "Preferèinsa",
"mypreferences": "Preferèinsi",
"prefs-edits": "Mudéfichi fâti:",
+ "prefsnologintext2": "Es prèiga ed $1 per impustêr al preferèinsi 'd l'utèint.",
"prefs-skin": "Aspèt grâfich (skin)",
"skin-preview": "Guêrda préma",
"datedefault": "Nisóna preferèinsa",
+ "prefs-labs": "Funsiòun adâti in sperimèint",
+ "prefs-user-pages": "Pàgini utèint",
+ "prefs-personal": "Prufîl utèint",
+ "prefs-rc": "Ûltmi mudéfichi",
+ "prefs-watchlist": "Tgnîr sòt ôc",
+ "prefs-watchlist-days": "Nómer ed dé da fêr vèder int i tgnû 'd ôc specêl:",
+ "prefs-watchlist-days-max": "Mâsim $1 {{PLURAL:$1|dé}}",
"saveprefs": "Sêlva",
"prefs-editing": "Caşèla 'd mudéfica",
"rows": "Rîghi",
"upload": "Cârga un 'file'",
"uploadlogpage": "Fil carghê",
"filedesc": "Sûnt.",
- "uploadedimage": "l'à carghê \"[[$1]]\"",
"license": "Licèinsa:",
"license-header": "Licèinsa",
"nolicense": "Nisóna licèinsa sgnêda",
"hidetoc": "hide",
"collapsible-collapse": "Collapse",
"collapsible-expand": "Expand",
+ "confirmable-confirm": "Are {{GENDER:$1|you}} sure?",
+ "confirmable-yes": "Yes",
+ "confirmable-no": "No",
"thisisdeleted": "View or restore $1?",
"viewdeleted": "View $1?",
"restorelink": "{{PLURAL:$1|one deleted edit|$1 deleted edits}}",
"invalidtitle-knownnamespace": "Invalid title with namespace \"$2\" and text \"$3\"",
"invalidtitle-unknownnamespace": "Invalid title with unknown namespace number $1 and text \"$2\"",
"exception-nologin": "Not logged in",
- "exception-nologin-text": "Please [[Special:Userlogin|log in]] to be able to access this page or action.",
+ "exception-nologin-text": "Please log in to be able to access this page or action.",
"exception-nologin-text-manual": "Please $1 to be able to access this page or action.",
"virus-badscanner": "Bad configuration: Unknown virus scanner: <em>$1</em>",
"virus-scanfailed": "scan failed (code $1)",
"parser-template-loop-warning": "Template loop detected: [[$1]]",
"parser-template-recursion-depth-warning": "Template recursion depth limit exceeded ($1)",
"language-converter-depth-warning": "Language converter depth limit exceeded ($1)",
- "node-count-exceeded-category": "Pages where node-count is exceeded",
- "node-count-exceeded-category-desc": "A category for pages where the node-count is exceeded.",
- "node-count-exceeded-warning": "Page exceeded the node-count",
+ "node-count-exceeded-category": "Pages where node count is exceeded",
+ "node-count-exceeded-category-desc": "The page exceeds the maximum node count.",
+ "node-count-exceeded-warning": "Page exceeded the node count",
"expansion-depth-exceeded-category": "Pages where expansion depth is exceeded",
- "expansion-depth-exceeded-category-desc": "This is a category for pages where the expansion depth is exceeded.",
+ "expansion-depth-exceeded-category-desc": "The page exceeds the maximum expansion depth.",
"expansion-depth-exceeded-warning": "Page exceeded the expansion depth",
"parser-unstrip-loop-warning": "Unstrip loop detected",
"parser-unstrip-recursion-limit": "Unstrip recursion limit exceeded ($1)",
"searchprofile-advanced-tooltip": "Search in custom namespaces",
"search-result-size": "$1 ({{PLURAL:$2|1 word|$2 words}})",
"search-result-category-size": "{{PLURAL:$1|1 member|$1 members}} ({{PLURAL:$2|1 subcategory|$2 subcategories}}, {{PLURAL:$3|1 file|$3 files}})",
- "search-result-score": "Relevance: $1%",
"search-redirect": "(redirect $1)",
"search-section": "(section $1)",
"search-file-match": "(matches file content)",
"preferences-summary": "",
"mypreferences": "Preferences",
"prefs-edits": "Number of edits:",
- "prefsnologintext2": "Please $1 to change your preferences.",
+ "prefsnologintext2": "Please login to change your preferences.",
"prefs-skin": "Skin",
"skin-preview": "Preview",
"datedefault": "No preference",
"trackingcategories-desc": "Category inclusion criteria",
"noindex-category-desc": "The page is not indexed by robots because it has the magic word <code><nowiki>__NOINDEX__</nowiki></code> on it and is in a namespace where that flag is allowed.",
"index-category-desc": "The page has a <code><nowiki>__INDEX__</nowiki></code> on it (and is in a namespace where that flag is allowed), and hence is indexed by robots where it normally wouldn't be.",
- "post-expand-template-inclusion-category-desc": "After expanding all the templates, the page size is bigger than <code>$wgMaxArticleSize</code>, so some templates weren't expanded.",
- "post-expand-template-argument-category-desc": "After expanding a template argument (something in triple braces, like <code>{{{Foo}}}</code>), the page is bigger than <code>$wgMaxArticleSize</code>.",
- "expensive-parserfunction-category-desc": "Too many expensive parser functions (like <code>#ifexist</code>) included on a page. See [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:$wgExpensiveParserFunctionLimit Manual:$wgExpensiveParserFunctionLimit].",
- "broken-file-category-desc": "Category added if the page contains a broken file link (a link to embed a file when the file does not exist).",
- "hidden-category-category-desc": "This is a category with <code><nowiki>__HIDDENCAT__</nowiki></code> on it, which prevents it from showing up in the category links box on pages, by default.",
+ "post-expand-template-inclusion-category-desc": "The page size is bigger than <code>$wgMaxArticleSize</code> after expanding all the templates, so some templates were not expanded.",
+ "post-expand-template-argument-category-desc": "The page is bigger than <code>$wgMaxArticleSize</code> after expanding a template argument (something in triple braces, like <code>{{{Foo}}}</code>).",
+ "expensive-parserfunction-category-desc": "The page uses too many expensive parser functions (like <code>#ifexist</code>). See [https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:$wgExpensiveParserFunctionLimit Manual:$wgExpensiveParserFunctionLimit].",
+ "broken-file-category-desc": "The page contains a broken file link (a link to embed a file when the file does not exist).",
+ "hidden-category-category-desc": "The category contains <code><nowiki>__HIDDENCAT__</nowiki></code> in its page content, which prevents it from showing up in the category links box on pages by default.",
"trackingcategories-nodesc": "No description available.",
"trackingcategories-disabled": "Category is disabled",
"mailnologin": "No send address",
"mywatchlist": "Watchlist",
"watchlistfor2": "For $1 $2",
"nowatchlist": "You have no items on your watchlist.",
- "watchlistanontext": "Please $1 to view or edit items on your watchlist.",
+ "watchlistanontext": "Please login to view or edit items on your watchlist.",
"watchnologin": "Not logged in",
"addwatch": "Add to watchlist",
"addedwatchtext": "The page \"[[:$1]]\" has been added to your [[Special:Watchlist|watchlist]].\nFuture changes to this page and its associated talk page will be listed there.",
"version-software": "Installed software",
"version-software-product": "Product",
"version-software-version": "Version",
- "version-db-mysql-url": "http://www.mysql.com/",
- "version-db-mariadb-url": "http://mariadb.org/",
+ "version-db-mysql-url": "https://www.mysql.com/",
+ "version-db-mariadb-url": "https://mariadb.org/",
"version-db-percona-url": "http://www.percona.com/software/percona-server",
"version-db-postgres-url": "http://www.postgresql.org/",
"version-db-oracle-url": "http://www.oracle.com/database/",
- "version-db-sqlite-url": "http://www.sqlite.org/",
- "version-db-mssql-url": "http://www.microsoft.com/sql/",
+ "version-db-sqlite-url": "https://www.sqlite.org/",
+ "version-db-mssql-url": "https://www.microsoft.com/sql/",
"version-entrypoints": "Entry point URLs",
"version-entrypoints-header-entrypoint": "Entry point",
"version-entrypoints-header-url": "URL",
"logentry-rights-rights": "$1 {{GENDER:$2|changed}} group membership for $3 from $4 to $5",
"logentry-rights-rights-legacy": "$1 {{GENDER:$2|changed}} group membership for $3",
"logentry-rights-autopromote": "$1 was automatically {{GENDER:$2|promoted}} from $4 to $5",
+ "logentry-upload-upload": "$1 {{GENDER:$2|uploaded}} $3",
+ "logentry-upload-overwrite": "$1 {{GENDER:$2|uploaded}} a new version of $3",
+ "logentry-upload-revert": "$1 {{GENDER:$2|uploaded}} $3",
"rightsnone": "(none)",
"revdelete-logentry": "changed revision visibility of \"[[$1]]\"",
"logdelete-logentry": "changed event visibility of \"[[$1]]\"",
"action-pagelang": "change the page language",
"log-name-pagelang": "Change language log",
"log-description-pagelang": "This is a log of changes in page languages.",
- "logentry-pagelang-pagelang": "$1 {{GENDER:$2|changed}} page language for $3 from $4 to $5."
+ "logentry-pagelang-pagelang": "$1 {{GENDER:$2|changed}} page language for $3 from $4 to $5.",
+ "default-skin-not-found": "Whoops! The default skin for your wiki (<code>$wgDefaultSkin</code>), <code>$1</code>, is not available.\n\nYour installation seems to include the following skins. See [https://www.mediawiki.org/wiki/Manual:Skin_configuration Manual: Skin configuration] for information how to enable them and choose the default.\n\n$2\n\n; If you have just installed MediaWiki:\n: You probably installed from git, or directly from the source code using some other method. This is expected. Try installing some skins from [https://www.mediawiki.org/wiki/Category:All_skins mediawiki.org's skin directory], by:\n:* Downloading the [https://www.mediawiki.org/wiki/Download tarball installer], which comes with several skins and extensions. You can copy and paste the <code>skins/</code> directory from it.\n:* Cloning one of the <code>mediawiki/skins/*</code> repositories via git into the <code>skins/</code> directory of your MediaWiki installation.\n: Doing this should not interfere with your git repository if you're a MediaWiki developer.\n\n; If you have just upgraded MediaWiki:\n: MediaWiki 1.24 and newer no longer automatically enables installed skins (see [https://www.mediawiki.org/wiki/Manual:Skin_autodiscovery Manual: Skin autodiscovery]). You can paste the following lines into <code>LocalSettings.php</code> to enable all currently installed skins:\n\n<pre>$3</pre>\n\n; If you have just modified <code>LocalSettings.php</code>:\n: Double-check the skin names for typos.",
+ "default-skin-not-found-no-skins": "Whoops! The default skin for your wiki (<code>$wgDefaultSkin</code>), <code>$1</code>, is not available.\n\nYou have no installed skins.\n\n; If you have just installed or upgraded MediaWiki:\n: You probably installed from git, or directly from the source code using some other method. This is expected. MediaWiki 1.24 and newer doesn't include any skins in the main repository. Try installing some skins from [https://www.mediawiki.org/wiki/Category:All_skins mediawiki.org's skin directory], by:\n:* Downloading the [https://www.mediawiki.org/wiki/Download tarball installer], which comes with several skins and extensions. You can copy and paste the <code>skins/</code> directory from it.\n:* Cloning one of the <code>mediawiki/skins/*</code> repositories via git into the <code>skins/</code> directory of your MediaWiki installation.\n: Doing this should not interfere with your git repository if you're a MediaWiki developer. See [https://www.mediawiki.org/wiki/Manual:Skin_configuration Manual: Skin configuration] for information how to enable skins and choose the default.\n",
+ "default-skin-not-found-row-enabled": "* <code>$1</code> / $2 (enabled)",
+ "default-skin-not-found-row-disabled": "* <code>$1</code> / $2 ('''disabled''')"
}
"hidetoc": "ocultar",
"collapsible-collapse": "Contraer",
"collapsible-expand": "Expandir",
+ "confirmable-confirm": "¿Estás {{GENDER:$1|seguro|segura}}?",
+ "confirmable-yes": "Sí",
+ "confirmable-no": "No",
"thisisdeleted": "¿Ver o restaurar $1?",
"viewdeleted": "¿Quieres ver $1?",
"restorelink": "{{PLURAL:$1|una edición borrada|$1 ediciones borradas}}",
"uploadwarning": "Advertencia de subida de archivo",
"uploadwarning-text": "Por favor, modifique la descripción del archivo abajo indicada e inténtelo de nuevo.",
"savefile": "Guardar archivo",
- "uploadedimage": "subió «[[$1]]»",
- "overwroteimage": "subió una nueva versión de «[[$1]]»",
"uploaddisabled": "Se desactivó la carga de archivos.",
"copyuploaddisabled": "Carga por URL deshabilitada.",
"uploaddisabledtext": "Se desactivó la carga de archivos.",
"blocklist-userblocks": "Ocultar bloqueos de cuenta",
"blocklist-tempblocks": "Ocultar bloqueos temporales",
"blocklist-addressblocks": "Ocultar bloqueos de una sola dirección IP",
- "blocklist-rangeblocks": "Ocultar bloqueos de rango",
+ "blocklist-rangeblocks": "Ocultar bloqueos por intervalo",
"blocklist-timestamp": "Fecha y hora",
"blocklist-target": "Destino",
"blocklist-expiry": "Caduca",
"logentry-rights-rights": "$1 modificó los grupos a los que pertenece $3: de $4 a $5",
"logentry-rights-rights-legacy": "$1 modificó los grupos a los que pertenece $3",
"logentry-rights-autopromote": "$1 ha sido {{GENDER:$2|promocionado|promocionada}} automáticamente de $4 a $5",
+ "logentry-upload-upload": "$1 {{GENDER:$2|subió}} $3",
+ "logentry-upload-overwrite": "$1 {{GENDER:$2|subió}} una nueva versión de $3",
+ "logentry-upload-revert": "$1 {{GENDER:$2|subió}} $3",
"rightsnone": "(ninguno)",
"feedback-bugornote": "Si estás preparado para describir en detalle un problema técnico, [$1 informa de un bug] por favor.\n\nEn otro caso, puedes usar el siguiente formulario. Tu comentario será añadido a la página [$3 $2], junto con tu nombre de usuario y el navegador que usas.",
"feedback-subject": "Asunto:",
"uploadwarning": "Üleslaadimise hoiatus",
"uploadwarning-text": "Muuda allpool olevat faili kirjeldust ning proovi uuesti.",
"savefile": "Salvesta fail",
- "uploadedimage": "laadis üles faili \"[[$1]]\"",
- "overwroteimage": "laadis üles faili \"[[$1]]\" uue versiooni",
"uploaddisabled": "Üleslaadimine hetkel keelatud",
"copyuploaddisabled": "Internetiaadressilt üleslaadimine on keelatud.",
"uploaddisabledtext": "Faili üleslaadimine on keelatud.",
"tog-watchdefault": "صفحهها و پروندههایی که ویرایش میکنم به فهرست پیگیریهایم افزوده شود",
"tog-watchmoves": "صفحهها و پروندههایی که منتقل میکنم به فهرست پیگیریهایم افزوده شود",
"tog-watchdeletion": "صفحهها و پروندههایی که حذف میکنم به فهرست پیگیریهایم افزوده شود",
+ "tog-watchrollback": "افزودن صفحاتی که واگردانی کردم برای فهرست پیگیریهایم",
"tog-minordefault": "همهٔ ویرایشها به طور پیشفرض به عنوان «جزئی» علامت بخورد",
"tog-previewontop": "پیشنمایش قبل از جعبهٔ ویرایش نمایش یابد",
"tog-previewonfirst": "پیشنمایش هنگام اولین ویرایش نمایش یابد",
"uploadwarning": "هشدار بارگذاری",
"uploadwarning-text": "لطفاً توضیحات پرونده را در زیر تغییر دهید و دوباره تلاش کنید.",
"savefile": "ذخیرهٔ پرونده",
- "uploadedimage": "«[[$1]]» را بارگذاری کرد",
- "overwroteimage": "نسخه جدیدی از «[[$1]]» را بارگذاری کرد",
"uploaddisabled": "بارگذاری غیرفعال است.",
"copyuploaddisabled": "بارگذاری از طریق نشانی اینترنتی غیرفعال است.",
"uploaddisabledtext": "امکان بارگذاری پرونده غیرفعال است.",
"nolicense": "هیچ کدام انتخاب نشدهاست",
"licenses-edit": "گزینههای مجوز ویرایش",
"license-nopreview": "(پیشنمایش وجود ندارد)",
- "upload_source_url": "(یک نشانی اینترنتی معتبر و قابل دسترسی برای عموم)",
- "upload_source_file": "(پرÙ\88Ù\86دÙ\87â\80\8cاÛ\8c در راÛ\8cاÙ\86Ù\87Ù\94 Ø´Ù\85ا)",
+ "upload_source_url": "(شما یک پرونده انتخاب از یک URL معتبر و دسترس عموم انتخاب کردید)",
+ "upload_source_file": "(پرÙ\88Ù\86دÙ\87â\80\8cاÛ\8c از راÛ\8cاÙ\86Ù\87Ù\94 Ø´Ù\85ا اÙ\86تخاب شدÙ\87â\80\8cاست)",
"listfiles-delete": "حذف",
"listfiles-summary": "این صفحهٔ ویژه تمام پروندههای بارگذاریشده را نمایش میدهد.",
"listfiles_search_for": "جستجو به دنبال نام پرونده چندرسانهای:",
"watchlist-details": "بدون احتساب صفحههای جداگانهٔ بحث، {{PLURAL:$1|$1 صفحه|$1 صفحه}} در فهرست پیگیریهای شما قرار {{PLURAL:$1|دارد|دارند}}.",
"wlheader-enotif": "آگاهسازی رایانامهای فعال است.",
"wlheader-showupdated": "صفحههایی که پس از آخرین بازدید شما تغییر کردهاند '''پررنگ''' نمایش داده شدهاند.",
- "wlnote": "در زیر {{PLURAL:$1|تغییری|$1 تغییری}} که در {{PLURAL:$2|ساعت|$2 ساعت}} گذشته انجام شده موجود است، تاریخ آخرین بازیابی: $3، $4",
+ "wlnote": "در زیر {{PLURAL:$1|تغییری|<strong>$1</strong> تغییری}} که در {{PLURAL:$2|ساعت|<strong>$2</strong> ساعت}} گذشته انجام شده موجود است، تاریخ آخرین بازیابی: $3، $4",
"wlshowlast": "نمایش آخرین $1 ساعت $2 روز $3",
"watchlist-options": "گزینههای پیگیری",
"watching": "پیگیری...",
"logentry-rights-rights": "$1 عضویت $3 را از گروه $4 به $5 {{GENDER:$2|تغییر داد}}",
"logentry-rights-rights-legacy": "$1 گروه عضویت $3 را {{GENDER:$2|تغییر داد}}",
"logentry-rights-autopromote": "$1 به طور خودکار از $4 به $5 {{GENDER:$2|ارتقاء داد}}",
+ "logentry-upload-upload": "$1 {{GENDER:$2|بارگذاری کرد}} $3",
+ "logentry-upload-overwrite": "$1 یک نسخهٔ جدید {{GENDER:$2|بارگذاریکرد}} $3",
+ "logentry-upload-revert": "$1 {{GENDER:$2|بارگذاری کرد}} $3",
"rightsnone": "(هیچ)",
"feedback-bugornote": "اگر آمادهاید تا مشکلی فنی را با جزئیاتش شرح دهید لطفاً [$1 یک ایراد گزارش دهید]. در غیر این صورت میتوانید از فرم سادهٔ زیر استفاده کنید. نظر شما به همراه نام کاربری و مرورگرتان به صفحهٔ «[$3 $2]» افزوده خواهد شد.",
"feedback-subject": "موضوع:",
"underline-never": "Ei koskaan",
"underline-default": "Ulkoasun tai selaimen oletustapa",
"editfont-style": "Muokkauskentän kirjasintyyppi",
- "editfont-default": "Selaimen oletus",
+ "editfont-default": "Selaimen vakioasetus",
"editfont-monospace": "Tasalevyinen kirjasin",
"editfont-sansserif": "Sans-serif-kirjasin",
"editfont-serif": "Serif-kirjasin",
"suppressionlog": "Häivytysloki",
"suppressionlogtext": "Alla on luettelo poistoista ja muokkausestoista, jotka sisältävät ylläpitäjiltä piilotettua materiaalia.\n[[Special:BlockList|Estolistassa]] on lueteltu voimassa olevat muokkauskiellot ja muokkausestot.",
"mergehistory": "Yhdistä sivujen muutoshistoriat",
- "mergehistory-header": "Tämä sivu mahdollistaa sivun muutoshistorian yhdistämisen uudemman sivun muutoshistoriaan.\nUuden ja vanhan sivun muutoksien pitää muodostaa jatkumo – ne eivät saa mennä ristikkäin.",
- "mergehistory-box": "Yhdistä kahden sivun muutoshistoria",
- "mergehistory-from": "Lähdesivu",
- "mergehistory-into": "Kohdesivu",
+ "mergehistory-header": "Tällä sivulla voit yhdistää lähdesivun sivuhistorian versioita uudemman sivun historiaan.\nVarmista, että sivujen yhtenäinen muokkaushistoria säilyy eikä mene ristikkäin sekaisin!",
+ "mergehistory-box": "Yhdistä kahden sivun versioita:",
+ "mergehistory-from": "Lähdesivu:",
+ "mergehistory-into": "Kohdesivu:",
"mergehistory-list": "Sivuhistoria, joka voidaan yhdistää",
- "mergehistory-merge": "Seuraavat sivun [[:$1]] muutokset voidaan liittää sivun [[:$2]] muutoshistoriaan. Voit valita version, jota myöhempiä muutoksia ei liitetä. Selainlinkkien käyttäminen kadottaa tämän valinnan.",
- "mergehistory-go": "Etsi muutokset",
+ "mergehistory-merge": "Seuraavat versiot sivusta [[:$1]] voidaan yhdistää sivuun [[:$2]]. \n\nValintamerkin sijoituksella voit yhdistää vain ne versiot, jotka on luotu valittuna ajankohtana tai sitä ennen (listassa alaspäin). \nOta huomioon, että jos käytät navigaatiolinkkejä, tekemäsi valinta poistuu.",
+ "mergehistory-go": "Etsi muokkaukset, jotka voidaan yhdistää",
"mergehistory-submit": "Yhdistä versiot",
- "mergehistory-empty": "Ei liitettäviä muutoksia.",
- "mergehistory-success": "{{PLURAL:$3|Yksi versio|$3 versiota}} sivusta [[:$1]] liitettiin sivuun [[:$2]].",
- "mergehistory-fail": "Muutoshistorian liittäminen epäonnistui. Tarkista määritellyt sivut ja versiot.",
+ "mergehistory-empty": "Mitään versioita ei voida yhdistää.",
+ "mergehistory-success": "$3 {{PLURAL:$3|versio|versiota}} sivusta [[:$1]] yhdistettiin onnistuneesti sivuun [[:$2]].",
+ "mergehistory-fail": "Sivuhistorioiden yhdistämistä ei voida suorittaa. Tarkista lähde- ja kohdesivujen nimet sekä versioiden aikamääritys.",
"mergehistory-fail-toobig": "Sivuhistorian yhdistämistä ei voi tehdä, koska enemmän kuin sallittu määrä $1 {{PLURAL:$1|versio|versiota}} siirrettäisiin.",
"mergehistory-no-source": "Lähdesivua $1 ei ole olemassa.",
"mergehistory-no-destination": "Kohdesivua $1 ei ole olemassa.",
- "mergehistory-invalid-source": "Lähdesivulla pitää olla kelvollinen nimi.",
- "mergehistory-invalid-destination": "Kohdesivulla pitää olla kelvollinen nimi.",
- "mergehistory-autocomment": "Yhdisti sivun [[:$1]] sivuun [[:$2]]",
+ "mergehistory-invalid-source": "Lähdesivun nimen pitää olla kelvollinen.",
+ "mergehistory-invalid-destination": "Kohdesivun nimen pitää olla kelvollinen.",
+ "mergehistory-autocomment": "Ak: Yhdisti sivun [[:$1]] sivuun [[:$2]]",
"mergehistory-comment": "Yhdisti sivun [[:$1]] sivuun [[:$2]]: $3",
"mergehistory-same-destination": "Lähde- ja kohdesivut eivät voi olla samat",
"mergehistory-reason": "Syy:",
"mergelog": "Yhdistämisloki",
- "pagemerge-logentry": "liitti sivun [[$1]] sivuun [[$2]] (muokkaukseen $3 asti)",
- "revertmerge": "Kumoa yhdistäminen",
+ "pagemerge-logentry": "yhdisti kohteen [[$1]] kohteeseen [[$2]] (muokkaukseen $3 saakka)",
+ "revertmerge": "Peru yhdistäminen",
"mergelogpagetext": "Alla on loki viimeisimmistä muutoshistorioiden yhdistämisistä.",
"history-title": "Sivun ”$1” muutoshistoria",
"difference-title": "Ero sivun ”$1” versioiden välillä",
"group-bot": "botit",
"group-sysop": "ylläpitäjät",
"group-bureaucrat": "byrokraatit",
- "group-suppress": "häivytysoikeuden käyttäjät",
+ "group-suppress": "häivyttäjät",
"group-all": "(kaikki)",
"group-user-member": "{{GENDER:$1|käyttäjä}}",
"group-autoconfirmed-member": "{{GENDER:$1|automaattisesti hyväksytty käyttäjä}}",
"group-bot-member": "{{GENDER:$1|botti}}",
"group-sysop-member": "{{GENDER:$1|ylläpitäjä}}",
"group-bureaucrat-member": "{{GENDER:$1|byrokraatti}}",
- "group-suppress-member": "{{GENDER:$1|häivytysoikeuden käyttäjä}}",
+ "group-suppress-member": "{{GENDER:$1|häivyttäjä}}",
"grouppage-user": "{{ns:project}}:Käyttäjät",
"grouppage-autoconfirmed": "{{ns:project}}:Automaattisesti hyväksytyt käyttäjät",
"grouppage-bot": "{{ns:project}}:Botit",
"uploadwarning": "Tallennusvaroitus",
"uploadwarning-text": "Muuta alla olevaa tiedostokuvausta ja yritä uudelleen.",
"savefile": "Tallenna",
- "uploadedimage": "tallensi tiedoston [[$1]]",
- "overwroteimage": "tallensi uuden version [[$1]]",
"uploaddisabled": "Tiedostojen tallennus ei ole käytössä.",
"copyuploaddisabled": "Tallennus URL:n kautta on poistettu käytöstä.",
"uploaddisabledtext": "Tiedostojen tallennus on poistettu käytöstä.",
"upload_source_file": "(valitsemasi tiedosto omasta tietokoneestasi)",
"listfiles-delete": "poista",
"listfiles-summary": "Tämä toimintosivu näyttää kaikki tallennetut tiedostot.",
- "listfiles_search_for": "Nimihaku",
+ "listfiles_search_for": "Etsi tiedoston nimellä:",
"imgfile": "tiedosto",
"listfiles": "Tiedostoluettelo",
"listfiles_thumb": "Pienoiskuva",
"filerevert-success": "'''[[Media:$1|$1]]''' on palautettu takaisin [$4 versioon, joka luotiin $2 kello $3].",
"filerevert-badversion": "Tiedostosta ei ole luotu versiota kyseisellä ajan hetkellä.",
"filedelete": "Poistetaan tiedosto $1",
- "filedelete-legend": "Tiedoston poisto",
- "filedelete-intro": "Olet poistamassa tiedoston '''[[Media:$1|$1]]''' ja kaiken sen historian.",
+ "filedelete-legend": "Poista tiedosto",
+ "filedelete-intro": "Olet poistamassa tiedoston '''[[Media:$1|$1]]''' ja lisäksi koko sen muokkaushistorian.",
"filedelete-intro-old": "<span class=\"plainlinks\">Olet poistamassa tiedoston '''[[Media:$1|$1]]''' [$4 päivämäärällä $2 kello $3 luotua versiota].</span>",
"filedelete-comment": "Syy:",
"filedelete-submit": "Poista",
"movetalk": "Siirrä myös keskustelusivu",
"move-subpages": "Siirrä kaikki alasivut (enintään $1)",
"move-talk-subpages": "Siirrä kaikki keskustelusivun alasivut (enintään $1)",
- "movepage-page-exists": "Sivu $1 on jo olemassa ja sitä ei voi automaattisesti korvata.",
+ "movepage-page-exists": "Sivu $1 on jo olemassa ja sen päälle ei voida automaattisesti siirtää.",
"movepage-page-moved": "Sivu $1 on siirretty nimelle $2.",
"movepage-page-unmoved": "Sivua $1 ei voitu siirtää nimelle $2.",
"movepage-max-pages": "Enimmäismäärä sivuja on siirretty, eikä enempää siirretä enää automaattisesti.\n$1 {{PLURAL:$1|sivu|sivua}} siirrettiin.",
"export-pagelinks": "Sisällytä linkkien kohteina olevat sivut syvyydelle:",
"allmessages": "Järjestelmäviestit",
"allmessagesname": "Nimi",
- "allmessagesdefault": "Oletusarvo",
- "allmessagescurrent": "Nykyinen arvo",
+ "allmessagesdefault": "Viestin tekstin perusmuoto",
+ "allmessagescurrent": "Viestin teksti tällä hetkellä",
"allmessagestext": "Tämä on luettelo järjestelmäviesteistä, jotka ovat saatavilla MediaWiki-nimiavaruudessa.\nJos haluat muokata MediaWikin yleistä kotoistusta, käy [https://www.mediawiki.org/wiki/Special:MyLanguage/Localisation MediaWikin kotoistussivuilla] ja sivustolla [//translatewiki.net translatewiki.net].",
"allmessagesnotsupportedDB": "Tämä sivu ei ole käytössä, koska <tt>$wgUseDatabaseMessages</tt>-asetus on pois päältä.",
"allmessages-filter-legend": "Suodata",
"logentry-newusers-autocreate": "Käyttäjätunnus $1 {{GENDER:$2|luotiin}} automaattisesti",
"logentry-rights-rights": "$1 {{GENDER:$2|muutti}} käyttäjän $3 oikeudet ryhmistä $4 ryhmiin $5",
"logentry-rights-rights-legacy": "$1 {{GENDER:$2|muutti}} käyttäjän $3 jäsenyyttä ryhmässä",
- "logentry-rights-autopromote": "$1 {{GENDER:$2|muutettiin}} automaattisesti ryhmistä $4 ryhmiin $5",
+ "logentry-rights-autopromote": "Käyttäjän $1 oikeudet {{GENDER:$2|muuttuivat}} automaattisesti ryhmistä $4 ryhmiin $5",
+ "logentry-upload-upload": "$1 {{GENDER:$2|tallensi}} tiedoston $3",
+ "logentry-upload-overwrite": "$1 {{GENDER:$2|tallensi}} uuden version tiedostosta $3",
+ "logentry-upload-revert": "$1 {{GENDER:$2|tallensi}} tiedoston $3",
"rightsnone": "(ei oikeuksia)",
"feedback-bugornote": "Jos voit kuvailla teknisen ongelman tarkasti – [$1 ilmoita ohjelmointivirheestä].\nMuussa tapauksessa voit käyttää alla olevaa helpompaa lomaketta. Kommenttisi lisätään sivulle [$3 $2], ja siinä on mukana käyttäjätunnuksesi.",
"feedback-subject": "Otsikko",
"api-error-illegal-filename": "Tiedoston nimi ei kelpaa.",
"api-error-internal-error": "Sisäinen virhe: jotain meni vikaan tallennuksesi käsittelyssä.",
"api-error-invalid-file-key": "Sisäinen virhe: tiedostoa ei löytynyt välikaisvarastosta.",
- "api-error-missingparam": "Sisäinen virhe: pyynnöstä puutuu parametrejä.",
+ "api-error-missingparam": "Sisäinen virhe: pyynnöstä puutuu parametreja.",
"api-error-missingresult": "Sisäinen virhe: ei voitu varmistaa, että tallennus onnistui.",
"api-error-mustbeloggedin": "Sinun pitää olla kirjautunut sisään, jotta voisit tallentaa tiedostoja.",
"api-error-mustbeposted": "Sisäinen virhe: HTTP POST-pyyntö edellytetty.",
"uploadwarning": "Attention !",
"uploadwarning-text": "Modifiez la description du fichier et essayez de nouveau.",
"savefile": "Sauvegarder le fichier",
- "uploadedimage": "a importé « [[$1]] »",
- "overwroteimage": "a importé une nouvelle version de « [[$1]] »",
"uploaddisabled": "Désolé, l’import de fichiers est désactivé.",
"copyuploaddisabled": "Import de fichier par URL désactivé.",
"uploaddisabledtext": "L’import de fichiers est désactivé sur ce wiki.",
"logentry-rights-rights": "$1 {{GENDER:$2|a modifié}} l'appartenance au groupe pour $3 de $4 à $5",
"logentry-rights-rights-legacy": "$1 {{GENDER:$2|a modifié}} l'appartenance au groupe pour $3",
"logentry-rights-autopromote": "$1 {{GENDER:$2|a été promu}} automatiquement de $4 à $5",
+ "logentry-upload-upload": "$1 {{GENDER:$2|a téléchargé}} $3",
+ "logentry-upload-overwrite": "$1 {{GENDER:$2|a téléchargé}} une nouvelle version de $3",
+ "logentry-upload-revert": "$1 {{GENDER:$2|a téléchargé}} $3",
"rightsnone": "(aucun)",
"feedback-bugornote": "Si vous êtes prêt à décrire un problème technique en détail, veuillez [$1 signaler un bogue].\nSinon, vous pouvez utiliser le formulaire simplifié ci-dessous. Votre commentaire sera ajouté à la page « [$3 $2] », avec votre nom d'utilisateur.",
"feedback-subject": "Objet :",
"uploadwarning": "Advertencia ao cargar o ficheiro",
"uploadwarning-text": "Por favor, modifique a descrición do ficheiro e inténteo de novo.",
"savefile": "Gardar o ficheiro",
- "uploadedimage": "cargou \"[[$1]]\"",
- "overwroteimage": "enviou unha nova versión de \"[[$1]]\"",
"uploaddisabled": "Sentímolo, a subida de ficheiros está desactivada.",
"copyuploaddisabled": "A carga mediante URL está desactivada.",
"uploaddisabledtext": "A carga de ficheiros está desactivada.",
"hidetoc": "הסתרה",
"collapsible-collapse": "הסתרה",
"collapsible-expand": "הצגה",
+ "confirmable-confirm": "האם {{GENDER:$1|ברצונך}} להמשיך?",
+ "confirmable-yes": "כן",
+ "confirmable-no": "לא",
"thisisdeleted": "לשחזר או להציג $1?",
"viewdeleted": "להציג $1?",
"restorelink": "{{PLURAL:$1|גרסה מחוקה אחת|$1 גרסאות מחוקות}}",
"uploadwarning": "אזהרת העלאת קבצים",
"uploadwarning-text": "אנא שנו את תיאור הקובץ שלמטה ונסו שוב.",
"savefile": "שמירת קובץ",
- "uploadedimage": "העלה את הקובץ [[$1]]",
- "overwroteimage": "העלה גרסה חדשה של הקובץ [[$1]]",
"uploaddisabled": "העלאת קבצים מבוטלת.",
"copyuploaddisabled": "העלאת קבצים מכתובת URL מבוטלת.",
"uploaddisabledtext": "אפשרות העלאת הקבצים מבוטלת.",
"logentry-rights-rights": "$1 {{GENDER:$2|שינה|שינתה}} את ההרשאות של $3 מ$4 ל$5‏",
"logentry-rights-rights-legacy": "$1 {{GENDER:$2|שינה|שינתה}} את ההרשאות של $3",
"logentry-rights-autopromote": "$1 קודם אוטומטית מ$4 ל$5",
+ "logentry-upload-upload": "$1 {{GENDER:$2|העלה|העלתה}} את $3",
+ "logentry-upload-overwrite": "$1 {{GENDER:$2|העלה|העלתה}} גרסה חדשה של $3",
+ "logentry-upload-revert": "$1 {{GENDER:$2|העלה|העלתה}} את $3",
"rightsnone": "(כלום)",
"feedback-bugornote": "אם אתם מוכנים לתאר בעיה טכנית בפרטים, אנא [$1 דווחו באג].\nאחרת, תוכלו להשתמש בטופס הפשוט שלהלן. הערתכם תתווסף לדף \"[$3 $2]\", יחד עם שם המשתמש שלכם.",
"feedback-subject": "נושא:",
"Malafaya",
"Thakurji",
"아라",
- "Soul Train"
+ "Soul Train",
+ "Filipinayzd"
]
},
"tog-underline": "Jorr ke niche line khicho:",
"talkpagelinktext": "Baat",
"specialpage": "Khaas Panna",
"personaltools": "Aapan aujaar",
- "postcomment": "Nawaa section",
"articlepage": "Content waala panna ke dekho",
"talk": "Salah",
"views": "Bichar",
"externaldberror": "Koi bahaari database authentication error hai, nai to aap ke bahaari account badle ke adhikar nai hai.",
"login": "Log in karo",
"nav-login-createaccount": "Log in karo/ nawaa account banao",
- "loginprompt": "Login kare ke khatir {{SITENAME}} cookies ke laabu kare ke chaahi.",
"userlogin": "Log in karo/ nawaa account banao",
"userloginnocreate": "Log in karo",
"logout": "Log out",
"saveprefs": "Save karo",
"restoreprefs": "Sab default settings ke pahile jaise karo (sab vibhag me)",
"prefs-editing": "Badaltaa hai",
- "rows": "Line:",
+ "rows": "Taytay:",
"columns": "Column:",
"searchresultshead": "Khojo",
"stub-threshold": "Threshold ke khatir <a href=\"#\" class=\"stub\">stub link</a> formatting (bytes):",
"uploadwarning": "Upload ke baare me chetauni",
"uploadwarning-text": "Meharbani kar ke file ke baaare me aur jankari ke niche badal ke aur fir se kosis karo.",
"savefile": "File ke save karo",
- "uploadedimage": "\"[[$1]]\" ke upload kar dewa gae",
- "overwroteimage": "\"[[$1]]\" ke nawaa version ke upload karaa gais hai",
"uploaddisabled": "Uploads ke disable kar dewa gais hai",
"copyuploaddisabled": "URL se upload kare pe rok lagae dewa gais hae.",
"uploaddisabledtext": "File uploads ke disable kar dewa gais hai.",
"watchlist-details": "{{PLURAL:$1|$1 panna|$1 panna}} pe dhyan dewa jae hai, baat waala panna ke chhorr ke.",
"wlheader-enotif": "E-mail notification ke enable kar dewa gais hai.",
"wlheader-showupdated": "Panna jiske aap ke pichhla visit ke ke baad badal dewa gais hia ke '''bold''' me dekhawa jaawe hai.",
+ "wlnote": "Niche ke {{PLURAL:$1|pahile waala badlao hai| pahile '''$1''' badlao hai}} pichhle {{PLURAL:$2|ghanta|'''$2''' ghanta}} me as of $3, $4..",
"wlshowlast": "Pichhla $1 ghanta $2 din $3 ke dekhao",
"watchlist-options": "Dhyan suchi ke options",
"watching": "Dekhtaa...",
"uploadwarning": "Feltöltési figyelmeztetés",
"uploadwarning-text": "Kérlek módosítsd a fájl leírását alább, majd próbáld újra.",
"savefile": "Fájl mentése",
- "uploadedimage": "„[[$1]]” felküldve",
- "overwroteimage": "feltöltötte a(z) „[[$1]]” fájl új változatát",
"uploaddisabled": "Feltöltések kikapcsolva",
"copyuploaddisabled": "A feltöltés URL alapján le van tiltva.",
"uploaddisabledtext": "A fájlfeltöltés nem engedélyezett.",
"listgrouprights-addgroup-self-all": "az összes csoportot hozzáadhatja a saját fiókjához",
"listgrouprights-removegroup-self-all": "az összes csoporból eltávolíthatja a saját fiókját",
"listgrouprights-namespaceprotection-namespace": "Névtér",
- "trackingcategories-nodesc": "Nincs leírás.",
+ "trackingcategories-nodesc": "Nem található leírás.",
"trackingcategories-disabled": "A kategória le van tiltva",
"mailnologin": "Nincs feladó",
"mailnologintext": "Ahhoz hogy másoknak e-mailt küldhess, [[Special:UserLogin|be kell jelentkezned]] és meg kell adnod egy érvényes e-mail címet a [[Special:Preferences|beállításaidban]].",
"uploadwarning": "Advertimento de incargamento",
"uploadwarning-text": "Per favor modifica le description del file ci infra e reproba.",
"savefile": "Salveguardar file",
- "uploadedimage": "incargava \"[[$1]]\"",
- "overwroteimage": "incargava un nove version de \"[[$1]]\"",
"uploaddisabled": "Incargamento de files disactivate",
"copyuploaddisabled": "Incargamento per URL disactivate.",
"uploaddisabledtext": "Le incargamento de files es disactivate.",
"uploadwarning": "Ballaag ti panagikarga",
"uploadwarning-text": "Pangngaasi a baliwam ti deskripsion ti papeles dita baba ken padasen manen.",
"savefile": "Idulin ti papeles",
- "uploadedimage": "naikarga ti \"[[$1]]\"",
- "overwroteimage": "nagikarga ti baro a bersion ti \"[[$1]]\"",
"uploaddisabled": "Nabaldado dagiti panagikarga.",
"copyuploaddisabled": "Nabaldado ti panagikarga babaen ti URL.",
"uploaddisabledtext": "Nabaldado dagiti panagikarga ti papeles.",
"uploadwarning": "Avviso di caricamento",
"uploadwarning-text": "Per favore modifica qui sotto la descrizione del file e prova di nuovo.",
"savefile": "Salva file",
- "uploadedimage": "ha caricato \"[[$1]]\"",
- "overwroteimage": "ha caricato una nuova versione di \"[[$1]]\"",
"uploaddisabled": "Il caricamento dei file è disabilitato.",
"copyuploaddisabled": "Il caricamento tramite URL è disabilitato.",
"uploaddisabledtext": "Il caricamento dei file non è attivo.",
"file-exists-duplicate": "Бұл файл келесі {{PLURAL:$1|файлдың|файлдарының}} телнұсқасы:",
"uploadwarning": "Жүктеу жөнінде құлақтандыру",
"savefile": "Файлды сақтау",
- "uploadedimage": "«[[$1]]» файлын жүктеді",
- "overwroteimage": "«[[$1]]» деген файлдың жаңа нұсқасын жүктеді",
"uploaddisabled": "Жүктеу өшірілген",
"copyuploaddisabled": "URL арқылы жүктеу өшірілген.",
"uploaddisabledtext": "Файл жүктеу өшірілген.",
"uploadwarning": "올리기 경고",
"uploadwarning-text": "아래의 파일 설명을 수정하고 다시 시도해 주세요.",
"savefile": "파일 저장",
- "uploadedimage": "사용자가 \"[[$1]]\" 파일을 올렸습니다.",
- "overwroteimage": "사용자가 \"[[$1]]\" 파일의 새 판을 올렸습니다.",
"uploaddisabled": "올리기 비활성화됨",
"copyuploaddisabled": "URL로 파일 올리기가 비활성화되어 있습니다.",
"uploaddisabledtext": "파일 올리기 기능이 비활성화되어 있습니다.",
"undeletedrevisions-files": "{{PLURAL:$1|판 1개|판 $1개}}와 {{PLURAL:$2|파일 1개|파일 $2개}}를 되살렸습니다",
"undeletedfiles": "{{PLURAL:$1|파일 1개|파일 $1개}}를 되살렸습니다",
"cannotundelete": "되살리는 데 실패했습니다:\n$1",
- "undeletedpage": "'''$1 문서를 되살렸습니다.'''\n\n[[Special:Log/delete|삭제 기록]]에서 최근의 삭제와 되살리기 기록을 볼 수 있습니다.",
+ "undeletedpage": "<strong>$1 문서를 되살렸습니다.</strong>\n\n[[Special:Log/delete|삭제 기록]]에서 최근의 삭제 및 되살리기 기록을 볼 수 있습니다.",
"undelete-header": "최근에 삭제한 문서에 대한 기록은 [[Special:Log/delete|여기]]에서 볼 수 있습니다.",
"undelete-search-title": "삭제된 문서 검색",
"undelete-search-box": "삭제된 문서 검색",
"uploadwarning": "Warnung beim Huhlade",
"uploadwarning-text": "Donn onge dä Täx övver di Dattei ändere, un versöhg_et norr_ens.",
"savefile": "Datei avspeichere",
- "uploadedimage": "hät huhjelade: „[[$1]]“",
- "overwroteimage": "hät en neue Version huhjelade vun: „[[$1]]“",
"uploaddisabled": "Huhlade jesperrt",
"copyuploaddisabled": "Et Huhlaade us URLs es afjeschalldt",
"uploaddisabledtext": "Et Huhlade es jesperrt.",
"fileexists-forbidden": "Medyayek bi vê navî heye; xêra xwe şonda here û vê medyayê bi navekî din barbike.\n[[File:$1|thumb|center|$1]]",
"uploadwarning": "Hişyariya barkirinê",
"savefile": "Dosyayê tomar bike",
- "uploadedimage": "\"[[$1]]\" hate barkirin",
- "overwroteimage": "versiyonekî nû ya \"[[$1]]\" hate barkirin",
"uploaddisabled": "Barkirin hatîye qedexekirin",
"uploaddisabledtext": "Barkirinê data'yan hatiye qedexekirin.",
"uploadvirus": "Di vê data'yê da vîrûsek heye! Înformasyon: $1",
"large-file": "Suasum est ut fasciculi $1 magnitudine non excedant; magnitudo huius fasciculi est $2.",
"uploadwarning": "Monitus imponendi",
"savefile": "Servare fasciculum",
- "uploadedimage": "imposuit \"[[$1]]\"",
"uploaddisabled": "Fasciculos imponere prohibitum est",
"uploaddisabledtext": "Fasciculos imponere prohibitum est.",
"uploadvirus": "Fasciculi huic est virus! Singula: $1",
"uploadwarning": "Opgepasst",
"uploadwarning-text": "Ännert d'Beschreiwung hei ënnedrënner w.e.g. a versicht et nach eng Kéier.",
"savefile": "Fichier späicheren",
- "uploadedimage": "huet \"[[$1]]\" eropgelueden",
- "overwroteimage": "huet eng nei Versioun vun \"[[$1]]\" eropgelueden",
"uploaddisabled": "Pardon, d'Eropluede vu Fichieren ass ausgeschalt.",
"copyuploaddisabled": "D'Eroplueden iwwer URL ass desaktivéiert.",
"uploaddisabledtext": "D'Eropluede vu Fichieren ass ausgeschalt.",
"logentry-rights-rights": "$1 {{GENDER:$2|huet}} d'Gruppen zou deenen de Benotzer $3 gehéiert vu(n) $4 op $5 geännert",
"logentry-rights-rights-legacy": "$1 {{GENDER:$2|huet}} d'Gruppen zou deenen de Benotzer $3 gehéiert geännert",
"logentry-rights-autopromote": "De Benotzer $1 {{GENDER:$2|krut}} d'Benotzerrechter automatesch vu(n) $4 op $5 geännert",
+ "logentry-upload-upload": "$1 huet $3 {{GENDER:$2|eropgelueden}}",
+ "logentry-upload-overwrite": "$1 huet eng nei Versioun vu(n) $3 {{GENDER:$2|eropgelueden}}",
+ "logentry-upload-revert": "$1 huet $3 {{GENDER:$2|eropgelueden}}",
"rightsnone": "(keen)",
"feedback-bugornote": "Wann Dir bereet sidd fir en technesche Problem am Detail ze beschreiwen da [$1 mellt w.e.g. e Feeler (Bug)].\nSoss kënnt Dir den einfache Formulär hei drënner benotzen. Är Bemierkung gëtt op d'Säit \"[$3 $2]\" derbäigesat, zesumme mat Ärem Benotzernumm an dem Numm vum Browser deen Dir benotzt.",
"feedback-subject": "Sujet:",
"tog-watchdefault": "بلگیا و فایلایی که مه ویرایشت کمه اضاف کو د سیل برگم",
"tog-watchmoves": "بلگیاو فایلیایی که مه جاوه جا کمه د سیل برگم اضاف کو",
"tog-watchdeletion": "بلگیا و فایلایی که مه پاک کمه اضاف کو د سیل برگم",
+ "tog-watchrollback": "همه بلگه یا نه د جایی که مه د سیل برگم می کم اضاف کو.",
"tog-minordefault": "همه ویرایشتیا کؤچک نه وا پیش فرض بیئن نشو دار کو.",
"tog-previewontop": "پیش سیل نه دما جعوه ویرایشت نشو بیئه",
"tog-previewonfirst": "پیش سیل نه د اولین ویرایشت نشو بیئه",
"mainpage-description": "سرآسونه",
"policy-url": "پروجه:خط و مش",
"portal": "درآسونه کومله یکی",
- "portal-url": "پرÙ\88جÙ\87:تÙ\84Ú¯ه کومله یکی",
+ "portal-url": "پرÙ\88جÙ\87:سرآسÙ\88Ù\86ه کومله یکی",
"privacy": "رهبرد رازداری",
"privacypage": "پروجه: خط مشی راز واداشتن",
"badaccess": "خطا :اجازه بئیر",
"protectedpagetext": "دای بلگه نبوئه ویرایشت یا کاریا هنی بکید",
"viewsourcetext": "شما تونیت سرچشمه ای بلگه نه بوینیت و دش ورداریت:",
"viewyourtext": "شما تونیت سرچشمه ویرایشتیا تونه ای د بلگه بوینیت و دشو ورداریت",
+ "protectedinterface": "ای بلگه سی نرم افزار د ای ویکی نیسسه آماده می که، و د .\nسی اضاف کردن یا آلشت دئن د همه ویکی یا لطفا [//translatewiki.net/ translatewiki.net] نه به کار بؤریت، ولات نشین کنی پروجه ویکی وارسگر.",
+ "editinginterface": "<strong>زئنار دئن:</strong> شما داریت بلگه ای نه که سی بیه ویرایشت می کید.",
+ "cascadeprotected": "ای بلگه د ویرایشت محافظت بیه سی یه که {{جمی:$1|وه بلگه یه |ونو بلگه یان}} که ها دش د :\n$2",
+ "namespaceprotected": "شما حقی سی ویرایشت بلگه یایی که هان د نومجا <strong>$1</strong> ناریت.",
+ "customcssprotected": "شما سی ویرایشت ای بلگه سی اس اس اجازه ناریت سی یه که میزونکاری دونسمنیا شخصی یه کاریار هنی ها د وه.",
+ "customjsprotected": "شما سی ویرایشت ای بلگه جاوا اسکریپت اجازه ناریت سی یه که میزونکاری دونسمنیا شخصی یه کاریار هنی ها د وه.",
"mycustomcssprotected": "شما حق ناریت ای بلگه سی اس اس نه ویرایشت بکید",
"mycustomjsprotected": "شما حق ناریت ای بلگه جاوا اسکریپت نه ویرایشت بکید",
"myprivateinfoprotected": "شما حق ناریت دونسمنیا خصوصی نه ویرایشت بکید",
"mypreferencesprotected": "شما حق ناریت ویجگی یا هنی تونه ویرایشت بکید",
"ns-specialprotected": "بلگیا ویجه نتونن ویرایشت بوئن",
+ "titleprotected": "ای دیارگر د دروس بیئن وه دس [[کاریار:$1|$1]].\n نهاگری بیه.\nدلیلش ونه\"<em>$2</em>\".",
+ "filereadonlyerror": "نبوئه جانیا \"$1\" آلشت بکیتو سی یه که اماییه گه \"$2\" فقط د حال و بال حننیه.\n\nدیوونداری که یه نه قلف کرده موئه د واشکافت \"$3\" بکیتو.",
"invalidtitle-knownnamespace": "نوم نامعتور سی نوم جا \"$2\" و نیسه \"$3\"",
"invalidtitle-unknownnamespace": "نوم نامعتور سی شماره نومجا ناشناس $1 و نیسه \"$2\"",
"exception-nologin": "نبوئه وارد بوئيد",
+ "exception-nologin-text": "شما وارد [[ویجه:وامین اومائن کاریار|وامین اومائن]] بوئیت سی یه تونستویت که د ای بلگه یا کنشت دسرسی داشتویت.",
"exception-nologin-text-manual": "خواهشمنیدم که $1 تونسه بوئه د ای بلگه دسرسی داشتوه یا کاری انجوم بیئه.",
+ "virus-badscanner": "سازواره گن:ویروس ناشناس:<em>$1</em>",
"virus-scanfailed": "زل بیئن شکست حرد($1)",
"virus-unknownscanner": "ويروس كش ناآشگار",
+ "logouttext": "<strong>شما هنی نریتته وه در.</strong>\n\nد ویرتو با که ویرگه نهو انجومیارتو نه پاکسا نکیت، سی یه پاره ای د بلگه یا ممکنه جوری نشو دئه بوئن چی یه که منیستی شما هنی هایین وامین.",
"welcomeuser": "خوش اومايت،$1!",
+ "welcomecreation-msg": "حساوتو دروس بیه.\nد ویرتو نروئه که{{نوم دیارگه}} [[Special:Preferences|preferences]] خوتونه آلشت بکیت",
"yourname": "نوم کاریاری:",
"userlogin-yourname": "نوم كاروری",
"userlogin-yourname-ph": "نوم کاریاری تو نه وارد بكيد",
"userlogin-signwithsecure": "د وصل بيئن امن استفاده كو",
"yourdomainname": "پوشگیر شما:",
"password-change-forbidden": "شما نتونید پاسوردیانه د ای ویکی آلشت بکید",
+ "externaldberror": "اشتوایی د ارتواط وا رسینه گا پیش اومائه یا ینه که شما اجازه وه هنگوم سازی حساو خارجی تونه ناریت.",
"login": "اومائن",
"nav-login-createaccount": " اومائن د سيستم/راس كردن حساو",
"userlogin": " اومائن د سيستم/راس كردن حساو",
"noname": "شما یه گل نوم کاروری خو ناریت",
"loginsuccesstitle": "اومائن د سيستم موفق بی",
"loginsuccess": "شما ایسه وارد بیته {{SITENAME}} د دعنوان \"$1\".'",
- "nosuchuser": "چنی کاروری و نوم \"$1\" نئیش.\nنوم کاروری وه حرفیا حساس هئ.\nروشت نیسنن تونه وارسی بکید،یا [[ویجه:وامین اومائن کارور/ثوت نام کردن|یه گل حساو تازه راس بکید]].",
+ "nosuchuser": "چنی کاریاری و نوم \"$1\" نئیش.\nنوم کاریاری وه حرفیا حساس هئ.\nروشت نیسنن تونه وارسی بکید،یا [[ویجه:وامین اومائن کاریار/ثوت نام کردن|یه گل حساو تازه راس بکید]].",
"nosuchusershort": "چنو کاروری وا ای نوم $1 نی ئیش.\nنیسنن تونه دوواره نئری بکیتو",
"nouserspecified": "شما باید یه نوم کارور اختصاص بئیتو",
"login-userblocked": "کارور قلف بیه.وامین اومائن اجازه نی ئن",
"passwordremindertitle": "پاسورد موقت تازه سی {{SITENAME}}",
"noemail": "هیچ نشونی ایمیلی سی کارور $1 ضفط نبیه.",
"noemailcreate": "شما باید یه نشونی نومه معتور فراهم بکید",
+ "passwordsent": "یه گل پاسورد هنی سی تیرنشون انجانامه ای که \"$1\" واش ثوت نام کرده بی کل بیه.\nخواهش میکیم هنی رویئت وامین و اوسه بئریتش.",
+ "blocked-mailpassword": "نها آی پی شما سی ویرایشت گرته بیه، و",
"mailerror": "خطا داره کل موئه:$1",
"emailauthenticated": "نشونی انجومانامه تونه د $2 سی 3$ مئکم بیه.",
"emailconfirmlink": "نشونی ايملتو نه محكم بكيد",
"yourtext": "متن شما",
"storedversion": "دوواره دیئن انبار بیه.",
"yourdiff": "فرخيا",
- "templatesused": "{{جمی:$1|قالو|قالویا}}د ای بلگه استفاده بیه:",
- "templatesusedpreview": "{{جمی:$1|قالو|قالویا}}استفاده بیه د ای پیش سیل:",
- "templatesusedsection": "{{جمی:$1|قالو|قالویا}} استفاده بیه د ای بخش:",
+ "templatesused": "{{جمی:$1|چوئه|چوئه یا}}د ای بلگه استفاده بیه:",
+ "templatesusedpreview": "{{جمی:$1|چوئه|چوئه یا}}استفاده بیه د ای پیش سیل:",
+ "templatesusedsection": "{{جمی:$1|چوئه|چوئه یا}} استفاده بیه د ای بخش:",
"template-protected": "(حمايت بيه)",
"template-semiprotected": "(نيم-حفاظت بيه)",
"hiddencategories": "ای بلگه يه اندوم د{{PLURAL:$1|1 hidden category|$1 hidden categories}}: هئ",
- "nocreatetext": "{{نوم مالگه}} سی راس کردن بلگه یا تازه محدود بیه.\nشما تونید روئیت وادما و بلگه ای که هئیش ویرایشت بکید ، یا [[ویجه:وامین اومائن کارور|بیایت وامین یا یه گل حساو بسازیت]].",
+ "nocreatetext": "{{نوم مالگه}} سی راس کردن بلگه یا تازه محدود بیه.\nشما تونید روئیت وادما و بلگه ای که هئیش ویرایشت بکید ، یا [[ویجه:وامین اومائن کاریار|بیایت وامین یا یه گل حساو بسازیت]].",
"nocreate-loggedin": "شما حق ناریت که بلگه یا تازه نه راس بکید.",
"sectioneditnotsupported-title": "ویرایشت بخش حمایت نبوئه",
"sectioneditnotsupported-text": "ویرایشت بشقی د ای بلگه نئیش.",
"searchresults": "نتيجه يا پی جوری",
"searchresults-title": "نتيجه يا پی جوری سی \"$1\"",
"titlematches": "عنوان بلگه مطاوقت داره",
+ "textmatches": "هومسازی نیسسه بلگه.",
+ "notextmatches": "نیسسه بلگه هومسازی ناره",
"prevn": "وادما {{PLURAL:$1|$1}}",
"nextn": "نيايی {{PLURAL:$1|$1}}",
"prevn-title": "پيشتر $1 {{PLURAL:$1|نتيجه|نتيجيا}}",
"searchprofile-images-tooltip": "بگرد سی فايليا",
"searchprofile-everything-tooltip": "همه محتوا نه پی جوری كو (شاملا بلگيا چك چنه)",
"searchprofile-advanced-tooltip": "نوم جايا نوم ديار بگرد",
- "search-result-size": "$1 ({{جمی:$2|بی واچه يل|واچه تكی|واچه يل|$2 واچه يل|$2 واچه}})",
+ "search-result-size": "$1 ({{جمی:$2|1 کلیمه|$2 کلیمه یا}})",
"search-result-category-size": "{{جمی:$1|1 اندوم|$1 اندومیا}} ({{جمی:$2|1 زیردسه|$2 زیردسه یا}}, {{جمی:$3|1 جانیا|$3 جانیایا}}",
"search-redirect": "(ورگشتن $1)",
"search-section": "(بشق $1)",
"prefs-rc": "آلشتیا تازه باو",
"prefs-watchlist": "سیل برگ",
"prefs-watchlist-days": "روزیا نه د سیل برگ نشو دئه بو:",
+ "prefs-watchlist-days-max": "$1 بیشترونه {{جمی:$1|روز|روزیا}}",
"prefs-watchlist-edits-max": "شماره بیشترونه:1000",
"prefs-misc": "شيوسن",
"prefs-resetpass": "پاسورد نه آلشت بكيت",
"stub-threshold-disabled": "د كار ونن",
"recentchangesdays": "روزیا آلشتیا تازه باو نه نشو بیه:",
"recentchangesdays-max": "$1 بیشترونه {{جمی:$1|روز|روزیا}}",
+ "recentchangescount": "انازه ویرایشتیایی که دیاری می که:",
"prefs-help-recentchangescount": "یه شامل آلشتیا تازه،ویرگاریا بلگه و پهرستنومه یا هئ.",
"savedprefs": "ویجه گیا هنی تو اماییه بیه.",
"timezonelegend": "وخت راساگه",
"localtime": "وخت ولاتی:",
"timezoneuseserverdefault": "وخت راساگه",
+ "timezoneuseoffset": "هنی",
"servertime": "وخت سرور:",
"guesstimezone": "وا جاگرد پر بوئه",
"timezoneregion-africa": "افرقا",
"prefs-i18n": "جهون ولاتمنی",
"prefs-signature": "امضا",
"prefs-dateformat": "شلک وخت",
+ "prefs-timeoffset": "جا وه جایی زمونی",
"prefs-advancedediting": "گزینه یا عمومی",
"prefs-editor": "ويرايشتگر",
"prefs-preview": "پیش سیل",
"prefs-advancedwatchlist": "گزینه یا پیشکرده",
"prefs-displayrc": "گزینه یا نه نشو بیه",
"prefs-displaywatchlist": "گزینه یا نه نشو بیه",
+ "prefs-tokenwatchlist": "نشو",
"prefs-diffs": "فرخیا",
"email-address-validity-valid": "نشونی ایمیل دیار بیه خوئه",
"email-address-validity-invalid": "یه گل نشونی ایمیل خو وارد بکید",
+ "userrights": "حقوق دیوونداری کاریار",
"userrights-lookup-user": "دسه یا کاروری نه دیوون داری بکیت",
"userrights-user-editname": "نوم كاروری ته وارد كو",
"editusergroup": "ویرایشت گرویا کاروری",
"group-bureaucrat": "بروکراتیا",
"group-all": "(همه)",
"group-user-member": "{{جنس:$1|کارور}}",
+ "group-autoconfirmed-member": "{{جنس:$1|کاریار خودانجومکار}}",
"group-bot-member": "{{حنس:$1|بوت}}",
"group-sysop-member": "{{جنس:$1|مدیر}}",
"group-bureaucrat-member": "{{جنس:$1|بروکرات}}",
"grouppage-user": "{{ns:project}}:کاروریا",
+ "grouppage-autoconfirmed": "{{ns:project}}:کاریار خودانجومکار",
"grouppage-bot": "{{ns:project}}:بوت یا",
+ "grouppage-sysop": "{{ns:project}}:دیوونداریا",
"grouppage-bureaucrat": "{{ns:project}}:دیوونداریا",
"right-read": "حنن بلگیا",
"right-edit": "ویرایشت بلگیا",
+ "right-createpage": "بلگه یا نه راس بکیت(ونو که دشو بلگه یا چک چنه نئ)",
"right-createtalk": "بلگه یا چک چنه نه راس بکید",
"right-createaccount": "یه گل حساو کاروری تازه راس بکیت",
"right-move": "بلگه یا جا وه جا کو",
"right-move-subpages": "بلگه یا و زیر بلگه یا شونه جا وه جا کو",
"right-move-rootuserpages": "بلگه یا ریشه ای کارور نه جا وه جا کو",
+ "right-move-categorypages": "دسه بلگه یا نه جا وه جا بکیت",
"right-movefile": "فایلیا نه جا وه جا کو",
"right-suppressredirect": "اوسه که بلگه یا د بین رئتنه هیچ واگردونی سی بلگه یا سرچشمه دروس نبیه",
"right-upload": "سوار کردن فايلا",
"right-upload_by_url": "سوار کرد فایلیا د یو آر ال",
"right-writeapi": "د نیسنن ای پی آی استفاده بکید",
"right-delete": "بلگیا نه پاکسا کو",
+ "right-bigdelete": "بلگه یایی که ویرگار گپی دارن پاکسا بکیت",
"right-browsearchive": "بلگه یا پاک بیه نه پی جوری کو",
"right-undelete": "ای بلگه نه حذف نكيد",
"right-suppressionlog": "دیئن پهرستنومه یا خصوصی",
+ "right-block": "کاریاریا هنی د ویرایشت منع بوئن",
+ "right-blockemail": "کاریار نه د کل کردن انجومانامه منع کو",
"right-unblockself": "خوشه قلف نکید",
"right-editinterface": "راوط کارور نه ویرایشت کو",
"right-editusercssjs": "فایلیا جاوا اسکریپت و سی اس اس کاروریا هنی نه ویرایشت کو",
"action-createpage": "راس کردن بلگیا",
"action-createtalk": "بلگه یا چک چنه نه راس بکید",
"action-createaccount": "حساو ای کارور نه راس بکید",
+ "action-history": "ویرگار ای بلگه نه بوینیت",
"action-minoredit": "ای ویرایشت نه چی یه حیرده ویرایشت نشو بیئت",
"action-move": "لی بلگه جا وه جا کو",
"action-move-subpages": "ای بلگه و زیر بلگه یاشه جا وه جا بکید",
"recentchanges-label-minor": "يه ويرايشت كؤچكيه",
"recentchanges-label-bot": "ای ويرايشت نه يه بوت انجوم ديئه",
"recentchanges-label-unpatrolled": "ای ويرايشت هنی تيه واداشت نبيه",
+ "recentchanges-label-plusminus": "انازه بلگه وه شمار ای بایتیا آلشت کرده.",
"recentchanges-legend-heading": "'''میراث:'''",
"recentchanges-legend-newpage": "{{int:recentchanges-label-newpage}} (همچنو بوینیت [[ویجه:بلگیا تازه|نوم گه بلگیا تازه]])",
"rcnotefrom": "د هار آلشتیا د $2 هیئن(د بال د $1 نشون دئه بیه)",
"uploadnologin": "وارد نبیه",
"uploadnologintext": "لطفن $1 سی سوارکرد جانیایا.",
"uploaderror": "خطا د سوار کردن",
+ "upload-permitted": "جورا جانیا مجاز:$1.",
+ "upload-preferred": "جورا جانیا مجاز:$1.",
+ "upload-prohibited": "جورا جانیا مجاز:$1.",
"uploadlogpage": "سوارکرد",
"filename": "نوم فایل",
"filedesc": "چكسته",
"filestatus": "حال و بال کپی رایت",
"filesource": "سرچشمه:",
"ignorewarnings": "د هر زنهار تیه پوشی کو",
+ "filename-toolong": "نوم جانیا شایت گپتر د 240 بایت نبا.",
"badfilename": "نوم جانیا د \"$1\" آلشت بیه.",
"empty-file": "فایلی که دئی ته حالی بیه.",
"file-too-large": "فایلی که دئی ته فره گپ بی.",
"filename-tooshort": "نوم فایل فره کؤچکه.",
+ "filetype-banned": "چنی جانیا قدقه بیه.",
"illegal-filename": "نوم فایل اجاره ندئه بیه.",
"unknown-error": "یه گل خطا نادیار ری ون کرده.",
+ "tmp-create-error": "نبوئه جانیا موقتی نه راس بکیتو.",
+ "tmp-write-error": "خطا د نیسنن جانیا موقتی.",
+ "uploadwarning": "هشدار سوارکرد",
"savefile": "جانیا نه اماییه کو",
- "uploadedimage": "سوارکرد\"[[$1]]\"",
- "overwroteimage": "یه گل نسقه تازه د \"[[$1]]\" سوار بیه",
"uploaddisabled": "سوار کردن د کار نئ.",
"copyuploaddisabled": "سوار کردن وا یو آر ال د کار نئ.",
"uploaddisabledtext": "سوار کرد فایلیا د کار نئ.",
"uploadinvalidxml": "ایکس ام الی که سوار بیه نبوئه نوتیج با.",
+ "uploadvirus": "د ای جانیا ویروس هئ!\nجزیات:$1",
"upload-source": "سرچشمه فایل",
"sourcefilename": "سرچشمه نوم جانیا:",
"sourceurl": "سرچشمه يو آر ال:",
"destfilename": "نوم فایل مقصد:",
+ "upload-maxfilesize": "بیشترونه انازه جانیا:$1",
"watchthisupload": "ای جانیا نه بوینیت",
"upload-success-subj": "سوار کرد خوش سرانجوم",
"upload-success-msg": "سوارکرد شما سی [$2] خوو بی.وه د ایچه هئش:[[:{{ns:file}}:$1]]",
"upload-failure-subj": "مشگل د سوارکردن",
"upload-failure-msg": "یه گل مشلگل د سوارکردتو سی [$2] بی:$1",
+ "upload-warning-subj": "هشدار سوارکرد",
"upload-proto-error": "پروتکل نادروس",
"upload-file-error": "خطا مینونه",
"upload-misc-error": "خطا سوار کرد ناشناخته",
"upload-too-many-redirects": "ای یو آر ال د ورگیرنه واگردونیا فرئی هئ",
+ "upload-http-error": "یه گل خطا اچ تی تی پی پیش اومائه:$1",
"upload-copy-upload-invalid-domain": "ورداشتن سوارکردیا د ای پوشگئر د دسرس نئ.",
"backend-fail-notexists": "فایل $1 وجود ناره.",
+ "backend-fail-invalidpath": "\"$1\" ره خوئی سی امائیه کردن نئ.",
"backend-fail-delete": "نبوئه جانیا $1 پاکسا بوئه",
"backend-fail-describe": "نبوئه گپ دونسمنیا سی جانیا\"$1\" آلشت بوئه.",
+ "backend-fail-alreadyexists": "جانیا \"$1\" ایسه هیئش.",
"backend-fail-store": "نبوئه جانیا \"$1\" د \"$2\" امبار بوئه.",
+ "backend-fail-copy": "نبوئه جانیا $1 د $2 ورداشته بوئه",
"backend-fail-move": "نبوئه جانیا \"$1\" د \"$2\" جا وه جا بوئه",
"backend-fail-opentemp": "نبوئه جانیا موقتی وا بوئه.",
"backend-fail-writetemp": "نبوئه د جانیا موقتی چی بنیسیت.",
+ "backend-fail-closetemp": "نبوئه جانیا موقتی بسته با.",
"backend-fail-read": "نبوئه جانیا\"$1\" حنه بوئه.",
+ "backend-fail-create": "نبوئه د جانیا\"$1\" نوشته با.",
"lockmanager-fail-closelock": "نبوئه قلف جانیا سی \"$1\" بسه بوئه.",
"lockmanager-fail-openlock": "نبوئه قلف جانیا سی \"$1\" وا بوئه.",
+ "uploadstash": "اماییه جا سوارکرد",
+ "uploadstash-clear": "پاک کردن جانیایا اماییه بیه",
+ "uploadstash-nofiles": "شما هیژ جانیا اماییه بیه ای ناریت.",
"uploadstash-refresh": "نومه گه جانیایا نه د نو تازه کو",
+ "invalid-chunk-offset": "جا وه جایی نامعتور برشت",
"img-auth-accessdenied": "دسرسی منع بی",
"img-auth-nofile": "فایل $1 وجود ناره.",
"http-invalid-url": "یو آر ال نامعتور:$1",
"license-header": "د شكل ليسانس دار بيئن",
"nolicense": "هیچی انتخاو نبیه",
"license-nopreview": "(پیش سیل د دسرس نئ)",
- "upload_source_file": "(یه گل فایل د انجومیار تو)",
+ "upload_source_file": "(یه گل جانیا د انجومیار تو انتخاو بکیت)",
"listfiles-delete": "پاکسا کردن",
"listfiles-summary": "ای بلگه یا ویجه همه جانیایا سوار بیه نه نشو می ئین.",
"listfiles_search_for": "پی جوری سی نوم رسانه:",
"imagelinks": "استفاده د فايل",
"linkstoimage": "دمال بيه {{PLURAL:$1|ديس ونيا بلگه|$1 ديس ون بلگيا}} دای فایل:",
"nolinkstoimage": "ایچه هیژ بلگه ای سی هوم پیوند بیئن وا ای فایل نی",
- "morelinkstoimage": " [[ویجه:چه هوم پیوندی ها ایچه/$1|هوم پیوندیا هنی]]سی ای فایل بونیت.",
+ "morelinkstoimage": " [[ویجه:چه هوم پیوندی ها ایچه/$1|هوم پیوندیا هنی]]سی ای جانیا نه بونیت.",
"linkstoimage-redirect": "$1 (واگردونی جانیا) $2",
"sharedupload": "ای جانیا که د $1 هئ شایت د پروجه یا هنی استفاده بیه.",
"sharedupload-desc-here": "فایلی که د $1 شایت د مئن پروجیا هنی استفاده بیه.\nتوضی دباره[$2 file description page] د هار نشو دئئه بیه",
"filepage-nofile": "چنو فایلی وا ای نوم نئ.",
"uploadnewversion-linktext": "یه گل نسقه تازه د ای جانیا سوار بکید",
"shared-repo-from": "د $1",
+ "filerevert": "د سرگرتن سی $1",
+ "filerevert-legend": "د سرگرتن جانیا",
"filerevert-comment": "دليل:",
"filerevert-submit": "ورگنین",
"filedelete": "$1 پاکسا کو",
"doubleredirects": "واگردونیا دوتایی",
"double-redirect-fixed-move": "[[$1]]جا وه جا بیه .\nوه خودکارونه وه روز بیه و ایسه وه د[[$2]] واگردونی بیه.",
"double-redirect-fixer": "تعمیر کننه واگردونی",
+ "brokenredirects": "واگردونیا بی سرانجوم",
"brokenredirectstext": "واگردونیا نهاتر د بلگه یایی که وجود نارن هوم پیوند بینه.",
"brokenredirects-edit": "ویرایشت",
"brokenredirects-delete": "پاكسا كردن",
"withoutinterwiki": "بلگه یایی که هوم پیوند زون نارن",
"withoutinterwiki-legend": "پیشون",
"withoutinterwiki-submit": "نشون دائن",
- "nbytes": "$1{{جمی:$1|كلی|بايت|بايت}}",
- "ncategories": "{{جمی:$1|دسه|دسه يا}}",
+ "fewestrevisions": "بلگه یایی که کمتری وانئری نه دارن",
+ "nbytes": "$1{{جمی:$1|بايت|بایتیا}}",
+ "ncategories": "$1{{جمی:$1|دسه|دسه يا}}",
"ninterwikis": "$1 {{جمی:$1|مئن ویکی|مئن ویکیا}}",
"nlinks": "$1 {{جمی:$1|هوم پیوند|هوم پیوندیا}}",
"nmembers": "$1 {{PLURAL:$1|اندوم|اندوميا}}",
"nmemberschanged": "$1 → $2 {{جمی:$2|اندوم|اندومیا}}",
+ "nrevisions": "$1 {{جمس:$1|وانئری|وانئریا}}",
"nviews": "$1 {{جمی:$1|دیئن|دیئنیا}}",
"nimagelinks": "$1 {{جمی:$1|بلگه|بلگيا}} استفاده بیه",
"ntransclusions": "$1 {{جمی:$1|بلگه|بلگيا}} استفاده بیه",
+ "specialpage-empty": "نتیجه ای د ای گزارشت نئ.",
"lonelypages": "بلگه یا تک منه",
"uncategorizedpages": "بلگه یا دسه بنی نبیه",
"uncategorizedcategories": "دسه یا دسه بنی نبیه",
"wantedtemplates": "قالویا حاستنی",
"mostlinked": "بلگه یا که بیشتر هوم پیوند بینه",
"mostlinkedcategories": "دسه یایی که بیشتر هوم پیوند بیه",
- "mostlinkedtemplates": "قالویایی که بیشتر هوم پیوند بینه",
+ "mostlinkedtemplates": "چوئه یایی که بیشتر هوم پیوند بینه",
"mostcategories": "بلگه یا که بیشتر دسه بنی بینه",
"mostimages": "فایلیایی که بیشتر هوم پیوند بینه",
+ "mostinterwikis": "بلگه یایی که بیشتری مینجا ویکی نه دارن",
+ "mostrevisions": "بلگه یایی که بیشتری وانئری نه دارن",
"prefixindex": "همه بلگيا وا پيشون",
"shortpages": "بلگه یا کؤچک",
"longpages": "بلگه یا گپ",
"deadendpages": "بلگه یا نابود بیئنی",
"protectedpages": "بلگه یا حفاظت بيه",
"protectedpages-noredirect": "واگردونیا قام بیه",
+ "protectedpages-timestamp": "سردیس گات",
"protectedpages-page": "بلگه",
"protectedpages-expiry": "تموم بیه آ",
"protectedpages-performer": "کارور حفاظت بیه",
"protectedpages-unknown-performer": "کارور ناشناس",
"listusers": "نوم گه کارور",
"listusers-editsonly": "فقط کاروریایی که ویرایشت می کن نشو بیه",
+ "listusers-creationsort": "سرجاخودگری د اساس گات دروس بیین",
+ "listusers-desc": "سرجاخودگری د اساس گپ د کؤچک",
+ "usereditcount": "$1{{جمی:$1|ویرایشت|ویرایشتیا}}",
"usercreated": "{{جنسیت:$3|راس بیه}}د $1 at $2",
"newpages": "بلگيا نو",
"newpages-username": "نوم كاروری:",
"booksources": "سرچشمه يل كتاو",
"booksources-search-legend": "پی جوری سی سرچشمه یا کتاو",
"booksources-go": "رو",
+ "specialloguserlabel": "انجومکار:",
"log": "نیسنن رخ ونیا",
"all-logs-page": "همه پهرستنومه یا عمومی",
"allpages": "همه بلگيا",
"nextpage": "بلگه نهایی($1)",
"prevpage": "بلگه دمایی($1)",
+ "allpagesfrom": "بلگه یای که د شرو بینه نشو بیه:",
+ "allpagesto": "بلگه یایی که د تموم بینه نشو بیه.",
"allarticles": "همه بلگيا",
+ "allinnamespace": "همه بلگه یا($1 نوم جا)",
"allpagessubmit": "رو",
+ "allpagesprefix": "بلگه یایی که پس نوم دارن نشو بیه:",
"allpagesbadtitle": "عنوان بلگه حاسته بیه معتور نی،یا یه گل مئن زونی یا مئن ویکی عنوان غلطه.\nیه شایت شومل یکی با یا بیشتر کاراکتریا نبوئه که سی ای موضوعیا استفاده بوئن",
+ "allpages-bad-ns": "{{نوم دیارگه}} د ای نوم جا نئ \"$1\".",
"allpages-hide-redirects": "واگردونیا قام بیه",
"cachedspecial-refresh-now": "دیئن آخری.",
"categories": "دسه يا",
+ "special-categories-sort-count": "سرجاخودگری د اساس شمارشت",
+ "special-categories-sort-abc": "سرجاخودگری د اساس الفبا",
"deletedcontributions": "هومیاریا پاکسا بیه کارور",
"deletedcontributions-title": "هومیاریا پاک بیه کارور",
"sp-deletedcontributions-contribs": "هومیاریا",
+ "linksearch": "هوم پیوند پی جوری خارجی",
+ "linksearch-pat": "سازه یار پی جوری:",
"linksearch-ns": "نوم جا:",
"linksearch-ok": "پی جوری",
"linksearch-line": "$1 داره د $2 هوم پیوند بوئه",
+ "listusersfrom": "کاریاریایی که د شرو بینه نشو بیه:",
"listusers-submit": "نشو دئن",
"listusers-noresult": "هیچ کاروری پیدا نبی",
"listusers-blocked": "(قلف بيه)",
"activeusers": "نوم گه کاروریا کارکو",
+ "activeusers-from": "کاریاریایی که د شرو بینه نشو بیه:",
"activeusers-hidebots": "بوتیا قام کو",
"activeusers-hidesysops": "دیوون داریا نه قام کو",
"activeusers-noresult": "هیچ کاروری پیدا نبی",
+ "listgrouprights": "حقوق گرو کاریاری",
+ "listgrouprights-key": "Legend:\n* <span class=\"listgrouprights-granted\">دئه بیه د سمت راست</span>\n* <span class=\"listgrouprights-revoked\">انجوم شیو بیه د سمت راست</span>",
"listgrouprights-group": "دسه",
"listgrouprights-rights": "حقوقیا",
+ "listgrouprights-helppage": "هومیاری:حقوق گرو",
"listgrouprights-members": "(نوم گه اندومیا)",
+ "listgrouprights-addgroup": "{{جمی:$2|گرویا|گرویا}} اضاف بکیتو: $1",
+ "listgrouprights-removegroup": "{{جمی:$2|گرویا|گرویا}} ورداریت: $1",
"listgrouprights-addgroup-all": "همه گرویا نه اضاف کو",
"listgrouprights-removegroup-all": "همه گرویا نه وردار",
"listgrouprights-addgroup-self": " {{جمی:$2|گروه|گرویا}} نه د حساو: $1 اضاف کو",
+ "listgrouprights-removegroup-self": "{{جمی:$2|گرویا|گرویا}} نه د حساو ورداریت: $1",
+ "listgrouprights-addgroup-self-all": "همه گرویا نه د حساو خوشو اضاف بکیت",
+ "listgrouprights-removegroup-self-all": "همه گرویا نه د حساو خوشو ورداریت",
+ "listgrouprights-namespaceprotection-namespace": "نوم جا",
+ "trackingcategories-name": "نوم پیغوم",
+ "trackingcategories-disabled": "دسه ناکشتگر بیه",
"mailnologin": "هیپچ نشونی یی کل نبیه",
"emailuser": "ای كارور نه ايميل كو",
"emailuser-title-target": "ایمیل سی ای {{جنس:$1|کارور}}",
"defemailsubject": "{{نوم سیل جا}} ایمیل د کارور \"$1\"",
"usermaildisabled": "ایمیل کارور د کار افتائه",
"noemailtitle": "هیچ نشونی ایمیلی نئ",
+ "emailtarget": "یه گل نوم کاریاری سی پذریشتگر وارد بکیت",
"emailusername": "نوم كاروری:",
"emailusernamesubmit": "دئن",
"emailfrom": "د:",
"emailccsubject": " پیغومتو سی $1:$2 ورداشته بی",
"emailsent": "ایمیل کل بیه",
"emailsenttext": "پیغوم ایمیلی تو کل بیه.",
+ "usermessage-summary": "رئتن د سامونه پیغوم",
"usermessage-editor": "پیغوم فرسن سیستم",
"watchlist": "سیل برگ",
"mywatchlist": "سیل برگ",
"watchlistfor2": "سي $1 $2",
+ "nowatchlist": "شما هیچی د سیل برگ خوتو ناریت",
"watchnologin": "وارد نبیه",
+ "addwatch": "اضاف کردن د سیل برگ",
+ "removewatch": "جا وه جا کردن د سیل برگ",
+ "removedwatchtext": "بلگه\"[[:$1]]\" د [[Special:سیل برگ|سیل برگ خوتو]] جا وه جا بیه.",
+ "removedwatchtext-short": "بلگه \"$1\" د سیل برگ جا وه جا بیه.",
"watch": "سيل كردن",
"watchthispage": "ديئن ای بلگه",
"unwatch": "ديه نبيه",
"unwatchthispage": "واداشتن دیئن",
"notanarticle": "مینونه هیچ بلگه ای نئ",
+ "notvisiblerev": "آخری وانئری که د دس یه کاریار هنی انجوم بیه پاکسا بیه.",
"watchlist-details": "{{جمی:$1|$1 بلگه|$1 بلگیا}} د سیل برگتو هیش بلگه قسه کردن نی .",
"wlheader-enotif": "وارسیاری ایمیل فعال بیه.",
"wlheader-showupdated": "بلگه یایی که د آخرین کرتی که شما دشو دیئن کردیته آلشت بینه د <strong>توپر</strong>نشون دئه بینه",
"deleteotherreason": "دليليا هنی:",
"deletereasonotherlist": "دلیل هنی",
"deletereason-dropdown": "* دلیلیا پاکسا کردن رسم بیه\n** اسپم\n** خراوکاری\n** رعایت نبین کپی رایت\n** درحاست نیسنه\n** نهاورگشت شکست حرده",
+ "delete-edit-reasonlist": "دلیلیا پاکسا کردنه نه ویرایشت بکید",
"rollbacklink": "ورگشتن",
"sessionfailure-title": "شکست حردن نشینگه",
"protectlogpage": "حفاظت کردن",
"modifiedarticleprotection": "ریتراز حفاظت د \"[[$1]]\" آلشت بیه",
"protect-title": "ریتراز حفاظت د \"$1\" آلشت بیه",
"prot_1movedto2": "[[$1]] د [[$2]] جا وه جا بی",
+ "protectcomment": "دلیل:",
"protect-default": "همه کاروریا اجازه دارن",
"protect-othertime": "وخت هنی:",
+ "protect-othertime-op": "گات هنی",
+ "protect-otherreason-op": "دلیل هنی",
"protect-expiry-options": "1 ساعت:1 ساعت,1 روز:1 روز,1 هفته:1 هفته,2 هفته:2 هفته,1 ما:1 ما,3 ما:3 ما,6 ما:6 ما,1 سال:1 سال,بی حساو:بی حساو",
"restriction-type": "دسرسی:",
+ "minimum-size": "انازه کمترونه",
+ "maximum-size": "انازه بیشترونه",
+ "pagesize": "(بایتیا)",
"restriction-edit": "ويرايشت",
"restriction-move": "جاوه جا بوئيت",
"restriction-create": "راس كردن",
"whatlinkshere-filters": "فيلتريا",
"block": "منع کارور",
"blockip": "منع کارور",
+ "ipaddressorusername": "نوم نشون آی پی يا نوم كاروری:",
"ipbreason": "دليل:",
+ "ipbemailban": "نهاگرتن کاریار د کل کردن انجومانامه",
"ipbother": "وخت هنی:",
"ipboptions": "2 ساعتیا:2 ساعت,1 رو:1 رو,3 روزا:3 رو,1 هفته:1 هفته,2 هفته یا:2 هفته,1 ما:1 ما,3 ما:3 میا,6 ما:6 مایا,1 سال:1سال,بی حساو:بی حساو",
"ipbhidename": "نوم کاروری نه سی ویرایشت یا و نوم گه یا قام کو",
+ "ipb-disableusertalk": "نها ای کاریار نه اوسه که میها د بلگه چک چنه ش ویرایشت بکه و وه قلف بیه بئر",
"unblockip": "کارور منع نبیه",
"blocklist": "كاروريا منع بيه",
"ipblocklist": "كاروريا منع بيه",
"unblocklink": "بی قطی",
"change-blocklink": "اجازه نديئن سی آلشت",
"contribslink": "هومكاری",
+ "emaillink": "انجومانامه نه کل کو",
"blocklogpage": "قلف",
"blocklogentry": " [[$1]] وا یه گل وخت تموم بیئن $2 و $3 قلف بیه",
"block-log-flags-nocreate": "حساو راس کردن عاجز بیه.",
"block-log-flags-nousertalk": "نبوئه بلگه چک چنه خوتونه ویرایشت بکید",
+ "proxyblocker": "قلف کننه پروکسی",
"lockdb": "قلف کردن رسینه گا",
"unlockconfirm": "هره، مه واقعند میهام که رسینه گا وا بوئه.",
+ "lockbtn": "قلف کردن رسینه گا",
"unlockbtn": "رسینه گا قلف نبیه",
"lockdbsuccesssub": "رسینه گا د خوئی قلف بیه",
"move-page": "$1 جا وه جا کو",
+ "move-page-legend": "بلگه نه جا وه جا کو",
"movenotallowed": "شما وه جا وه جا کردن بلگه دسرسی ناریت",
"movenotallowedfile": "شما وه جا وه جا کردن جانیایا دسرسی ناریت",
"movepagebtn": "بلگه جا وه جا کو",
+ "pagemovedsub": "د خوئی جا وه جا بیه",
"movepage-moved-redirect": "یه گل واگردونی دروس بیه.",
"movelogpage": "جاوه جا کردن",
"movelogpagetext": "د هار یه گل نوم گه د جا وه جایی یا بلگه هئ",
+ "movereason": "دلیل:",
"revertmove": "لرستن",
"delete_and_move": "پاکسا و جا وه جا بوئه",
"export": "وه صحرا ديئن بلگيا",
+ "export-addcat": "اضاف کو",
+ "export-addns": "اضاف كو",
"export-download": "ذخیره کردن جانیا",
+ "export-templates": "شامل چوئه یا",
+ "allmessages": "سامونه پیغومیا",
"allmessagesname": "نوم",
"allmessagesdefault": "سفارشت متنی پيش فرض",
+ "allmessages-filter-legend": "فیلتر",
+ "allmessages-filter-all": "همه",
+ "allmessages-filter-modified": "آلشت بیه",
+ "allmessages-prefix": "فیلتر بیه وا نهاون:",
"allmessages-language": "زون:",
"allmessages-filter-submit": "رو",
+ "allmessages-filter-translate": "والرن",
"thumbnail-more": "گپ كردن",
"filemissing": "گم بیئن جانیا",
"thumbnail_error": "خطا د راس بیئن بن کلئکی:$1",
"watchlisttools-edit": "سیل برگ بوینیتو و ویرایشت بکید",
"watchlisttools-raw": "سیل برگ نه ردیفی ویرایشت کو",
"duplicate-defaultsort": "زنهار کلیت پیش فرض جور بیه $2 تازه ای یا کلید پیش فرض جوربیه $1 رد بیه.",
+ "version-antispam": "نهاگرتن هرزنومه",
"version-ext-license": "ليسانس",
"version-ext-colheader-version": "نسقه",
"version-ext-colheader-license": "ليسانس",
"uploadwarning": "Augšupielādes brīdinājums",
"uploadwarning-text": "Lūdzu, pārveido zemāk esošo faila aprakstu un mēģini vēlreiz.",
"savefile": "Saglabāt failu",
- "uploadedimage": "augšupielādēja \"[[$1]]\"",
- "overwroteimage": "augšupielādēta jauna \"[[$1]]\" versija",
"uploaddisabled": "Augšupielāde atslēgta",
"copyuploaddisabled": "URL augšupielādes nav atļautas.",
"uploaddisabledtext": "Failu augšupielāde ir atslēgta.",
"uploadwarning": "慎焉!",
"uploadwarning-text": "改下檔述再試之。",
"savefile": "存之",
- "uploadedimage": "進獻\"[[$1]]\"",
- "overwroteimage": "新置「[[$1]]」矣",
"uploaddisabled": "進獻已阻",
"copyuploaddisabled": "由URL之貢被禁也。",
"uploaddisabledtext": "檔之貢被禁也。",
"uploadwarning": "उपारोपण चेतौनी",
"uploadwarning-text": "कृपा कऽ नीचाँ देल संचिका वर्णनकेँ संशोधित करू आ फेरसँ प्रयास करू।",
"savefile": "संचिका संरक्षण करू",
- "uploadedimage": "अपलोड भेल \"[[$1]]\"",
- "overwroteimage": "एकर \"[[$1]]\" नव संस्करण उपारोपित भेल।",
"uploaddisabled": "उपारोपण सभ अशक्त कएल गेल।",
"copyuploaddisabled": "सार्वत्रिक विभव संकेत उपारोपण अशक्त कएल गेल।",
"uploaddisabledtext": "संचिका उपारोपण सभ अशक्त अछि।",
"pool-timeout": "Пигонь кирдемась учи пякстаманц",
"pool-queuefull": "Тяряфнемада вельф лама",
"pool-errorunknown": "Аф содаф эльбятькс",
+ "pool-servererror": "Пърдафкс лувома лезкссь аф сатови ($1).",
"aboutsite": "{{SITENAME}} колга",
"aboutpage": "Project:Колга",
- "copyright": "Сёрматфсь ули кода мумс $1-са.",
+ "copyright": "Сёрматфсь ули кода мумс $1са, къда илякс апак аст.",
"copyrightpage": "{{ns:project}}:Копияма видекст",
"currentevents": "Мезе тяса моли",
"currentevents-url": "Project:Мезе тяса моли",
"nospecialpagetext": "<strong>Аш стама башка лопа.</strong>\n\nВанк [[Special:SpecialPages|{{int:specialpages}}]].",
"error": "Эльбятькс",
"databaseerror": "Датабаза эльбятькс",
+ "databaseerror-text": "Содамошинь паргонь вешемста лиссь эльбятькс.\nУлема, програмонь лездомбяльсь аржиясь.",
"laggedslavemode": "Шарфтк мяльце: Тя лопась, улема, сирелгодсь.",
"readonly": "Датабазась пякстаф",
"enterlockreason": "Сёрматк тязк пякстама туфтал тонь арьсемацень мархта эли няфтть тяса мъзярда ули кода пякстамать валхтомс.",
"file-deleted-duplicate": "Файлсь сяка кода файл ([[:$1]]) нардафоль. Ванк файлонь нардама историянц сонь одукс тонгоманза инголе.",
"uploadwarning": "Тонгодемань инголе кардама",
"savefile": "Ванфтомс файл",
- "uploadedimage": "тонгозь \"[[$1]]\"",
- "overwroteimage": "тонгозь \"[[$1]]\" од верзиенц",
"uploaddisabled": "Тонгодемать лоткозь",
"uploaddisabledtext": "Файл тонгодемась лоткаф.",
"uploadscripted": "Тя файлса ащи HTML эли програм, конат аф морафтовихть интернет полатксть вельде.",
"uploadwarning": "Предупредување при подигање",
"uploadwarning-text": "Изменете го описот на податотеката подолу и обидете се повторно.",
"savefile": "Зачувај податотека",
- "uploadedimage": "подигнато „[[$1]]“",
- "overwroteimage": "подигнато нова верзија на „[[$1]]“",
"uploaddisabled": "Забрана за подигања",
"copyuploaddisabled": "Подигањето од URL е оневозможено.",
"uploaddisabledtext": "Подигањето на податотеки е оневозможено.",
"logentry-rights-rights": "$1 {{GENDER:$2|го измени}} групното членство на $3 од $4 во $5",
"logentry-rights-rights-legacy": "$1 {{GENDER:$2|го измени}} групното членство во $3",
"logentry-rights-autopromote": "$1 автоматски {{GENDER:$2|унапреден|унапредена}} од $4 во $5",
+ "logentry-upload-upload": "$1 {{GENDER:$2|ја подигна}} $3",
+ "logentry-upload-overwrite": "$1 {{GENDER:$2|подигна}} нова верзија на $3",
+ "logentry-upload-revert": "$1 {{GENDER:$2|ја подигна}} $3",
"rightsnone": "(нема)",
"feedback-bugornote": "Ако сте спремни подробно да го опишете техничкиот проблем, тогаш [$1 пријавете грешка]. \nВо спротивно, послужете се со едноставниот образец подолу. Вашиот коментар ќе стои на страницата „[$3 $2]“, заедно со корисничкото име и прелистувачот што го користите.",
"feedback-subject": "Наслов:",
"uploadwarning": "അപ്ലോഡ് മുന്നറിയിപ്പ്",
"uploadwarning-text": "ദയവായി താഴെയുള്ള പ്രമാണ വിവരണങ്ങൾ പുതുക്കി വീണ്ടും ശ്രമിക്കുക.",
"savefile": "പ്രമാണം കാത്ത് സൂക്ഷിക്കുക",
- "uploadedimage": "\"[[$1]]\" അപ്ലോഡ് ചെയ്തു.",
- "overwroteimage": "\"[[$1]]\" എന്ന പ്രമാണത്തിന്റെ പുതിയ പതിപ്പ് അപ്ലോഡ് ചെയ്തിരിക്കുന്നു",
"uploaddisabled": "അപ്ലോഡുകൾ പ്രവർത്തനരഹിതമാക്കിയിരിക്കുന്നു.",
"copyuploaddisabled": "യൂ.ആർ.എൽ. വഴിയുള്ള അപ്ലോഡ് നിർജ്ജീവമാക്കിയിരിക്കുന്നു.",
"uploaddisabledtext": "പ്രമാണം അപ്ലോഡ് ചെയ്യുന്നതു സാദ്ധ്യമല്ലാതാക്കിയിരിക്കുന്നു.",
"badfilename": "Iáⁿ-siōng ê miâ í-keng kái chò \"$1\".",
"uploadwarning": "Upload kéng-kò",
"savefile": "Pó-chûn tóng-àn",
- "uploadedimage": "thoân \"[[$1]]\" chiūⁿ-bāng",
"uploaddisabled": "Pháiⁿ-sè, sàng chiūⁿ-bāng ê kong-lêng bô khui.",
"sourcefilename": "Tóng-àn goân miâ:",
"destfilename": "Tóng-àn sin miâ:",
"uploadwarning": "Opplastingsadvarsel",
"uploadwarning-text": "Vennligst endre filbeskrivelsen nedenfor og prøv igjen.",
"savefile": "Lagre fil",
- "uploadedimage": "lastet opp «[[$1]]»",
- "overwroteimage": "last opp en ny versjon av «[[$1]]»",
"uploaddisabled": "Opplastingsfunksjonen er slått av",
"copyuploaddisabled": "Opplasting via nettadresse deaktivert.",
"uploaddisabledtext": "Opplasting er slått av.",
"uploadwarning": "Waorschuwing",
"uploadwarning-text": "Pas de bestaandsbeschrieving hieronder an en probeer t opniej",
"savefile": "Bestaand opslaon",
- "uploadedimage": "Op-estuurd: [[$1]]",
- "overwroteimage": "Nieje versie van \"[[$1]]\" op-estuurd",
"uploaddisabled": "t Opsturen van bestaanden is uutezet.",
"copyuploaddisabled": "t Opsturen van bestaanden via n webadres is uutezet.",
"uploaddisabledtext": "t Opsturen van bestaanden is uutezet.",
"uploadwarning": "उर्ध्वभरण चेतावनी",
"uploadwarning-text": "कृपया तल फाइलको वर्णन परिवर्तन गर्नुहोस र पुन: प्रयास गर्नुहोस् ।",
"savefile": "फाइल बचत गर्नुहोस्",
- "uploadedimage": "उर्ध्वभरण(upload) गरियो \"[[$1]]\"",
- "overwroteimage": " \"[[$1]]\"को एउटा नयाँ संस्करण उर्ध्वभरण गरियो",
"uploaddisabled": "उर्ध्वभरण अक्षम पारिएकोछ",
"copyuploaddisabled": " URL प्रयोग गरी उर्ध्वभरण निश्कृय पारिएको छ।",
"uploaddisabledtext": "फाइल उर्ध्वभरण अक्षम पारिएकोछ",
"uploadwarning": "Uploadwaarschuwing",
"uploadwarning-text": "Pas de onderstaande bestandsbeschrijving aan en probeer het daarna opnieuw.",
"savefile": "Bestand opslaan",
- "uploadedimage": "heeft \"[[$1]]\" geüpload",
- "overwroteimage": "heeft een nieuwe versie van \"[[$1]]\" toegevoegd",
"uploaddisabled": "Uploaden is uitgeschakeld",
"copyuploaddisabled": "Het uploaden van bestanden via een URL is uitgeschakeld.",
"uploaddisabledtext": "Het uploaden van bestanden is uitgeschakeld.",
"uploadwarning": "Opplastingsåtvaring",
"uploadwarning-text": "Ver venleg og endra filskildringa nedanfor og prøv på nytt",
"savefile": "Lagre fil",
- "uploadedimage": "lasta opp «[[$1]]»",
- "overwroteimage": "lasta opp ein ny versjon av «[[$1]]»",
"uploaddisabled": "Beklagar, funksjonen for opplasting er deaktivert på denne nettenaren.",
"copyuploaddisabled": "Opplasting gjennom URL er slege av.",
"uploaddisabledtext": "Filopplasting er slått av.",
"hidetoc": "ukryj",
"collapsible-collapse": "Zwiń",
"collapsible-expand": "Rozwiń",
+ "confirmable-confirm": "Jesteś {{GENDER:$1|pewny|pewna}}?",
+ "confirmable-yes": "Tak",
+ "confirmable-no": "Nie",
"thisisdeleted": "Pokazać lub odtworzyć $1?",
"viewdeleted": "Zobacz $1",
"restorelink": "{{PLURAL:$1|jedną usuniętą wersję|$1 usunięte wersje|$1 usuniętych wersji}}",
"uploadwarning": "Ostrzeżenie o przesyłaniu",
"uploadwarning-text": "Zmień poniższy opis pliku i spróbuj ponownie.",
"savefile": "Zapisz plik",
- "uploadedimage": "przesłał [[$1]]",
- "overwroteimage": "przesłano nową wersję pliku „[[$1]]“",
"uploaddisabled": "Przesyłanie plików wyłączone",
"copyuploaddisabled": "Przesyłanie poprzez podanie adres URL jest wyłączone.",
"uploaddisabledtext": "Możliwość przesyłania plików została wyłączona.",
"uploadwarning": "Avis che i soma dapress a carié",
"uploadwarning-text": "Për piasì, ch'a modìfica la descrission ëd l'archivi sì-sota e ch'a preuva torna.",
"savefile": "Salvé l'archivi",
- "uploadedimage": "a l'ha carià \"[[$1]]\"",
- "overwroteimage": "a l'ha carìa na version neuva ëd \"[[$1]]\"",
"uploaddisabled": "Càrich blocà.",
"copyuploaddisabled": "Ël càrich për mojen ëd n'adrëssa dl'aragnà a l'é disabilità.",
"uploaddisabledtext": "La possibilità ëd carié dj'archivi a l'é staita disabilità.",
"uploadwarning": "Aviso de envio",
"uploadwarning-text": "Modifique a descrição do arquivo abaixo e tente novamente.",
"savefile": "Salvar arquivo",
- "uploadedimage": "enviou \"[[$1]]\"",
- "overwroteimage": "enviou uma nova versão de \"[[$1]]\"",
"uploaddisabled": "Envio de arquivos desativado.",
"copyuploaddisabled": "O upload por URL encontra-se desativado.",
"uploaddisabledtext": "O envio de arquivos encontra-se desativado.",
"uploadwarning": "Aviso de envio",
"uploadwarning-text": "Modifique a descrição do ficheiro abaixo e tente novamente, por favor.",
"savefile": "Gravar ficheiro",
- "uploadedimage": "carregou \"[[$1]]\"",
- "overwroteimage": "enviou uma nova versão de \"[[$1]]\"",
"uploaddisabled": "Carregamentos desativados",
"copyuploaddisabled": "Carregamento por URL desativado.",
"uploaddisabledtext": "O carregamento de ficheiros está desativado.",
"logentry-rights-rights": "$1 modificou os privilégios do utilizador $3 de $4 para $5",
"logentry-rights-rights-legacy": "$1 alterou os grupos de $3",
"logentry-rights-autopromote": "$1 foi automaticamente {{GENDER:$2|promovido|promovida}} de $4 a $5",
+ "logentry-upload-upload": "$1 {{GENDER:$2|carregou}} $3",
+ "logentry-upload-overwrite": "$1 {{GENDER:$2|carregou}} uma nova versão de $3",
+ "logentry-upload-revert": "$1 {{GENDER:$2|carregou}} $3",
"rightsnone": "(nenhum)",
"feedback-bugornote": "Se está pronto para descrever um problema técnico em detalhe, por favor, [$1 comunique o defeito].\nCaso contrário, pode facilmente usar o formulário abaixo. O seu comentário será adicionado à página \"[$3 $2]\", junto com o seu nome de utilizador e o navegador que está a usar.",
"feedback-subject": "Assunto:",
"hidetoc": "This is the link used to hide the table of contents\n\n{{Identical|Hide}}",
"collapsible-collapse": "{{Doc-actionlink}}\nThis is the link used to collapse a collapsible element. (used as plaintext. No wikitext or html is parsed.)\n\nSee also:\n* {{msg-mw|Collapsible-expand}}\n{{Identical|Collapse}}",
"collapsible-expand": "{{Doc-actionlink}}\nThis is the link used to expand a collapsible element (used as plaintext. No wikitext or html is parsed.)\n\nSee also:\n* {{msg-mw|Collapsible-collapse}}\n\nSee the following example:\n{{Identical|Expand}}",
+ "confirmable-confirm": "Question asking the user to confirm a potentially uncancellable action.\n\"Yes\" and \"No\" buttons are displayed beside it.\n\nSee also:\n* {{msg-mw|confirmable-yes}}\n* {{msg-mw|confirmable-no}}",
+ "confirmable-yes": "{{Doc-actionlink}}\nText of a button that will confirm triggering of a potentially uncancellable action.\n\nSee also:\n* {{msg-mw|confirmable-confirm}}\n* {{msg-mw|confirmable-no}}",
+ "confirmable-no": "{{Doc-actionlink}}\nText of a button that will cancel triggering of a potentially uncancellable action.\n\nSee also:\n* {{msg-mw|confirmable-confirm}}\n* {{msg-mw|confirmable-yes}}",
"thisisdeleted": "Message shown on a deleted page when the user has the undelete right. Parameters:\n* $1 - a link to [[Special:Undelete]], with {{msg-mw|restorelink}} as the text\nSee also:\n* {{msg-mw|viewdeleted}}",
"viewdeleted": "Message shown on a deleted page when the user does not have the undelete right (but has the deletedhistory right).\n\nParameters:\n* $1 - a link to [[Special:Undelete]], with {{msg-mw|restorelink}} as the text\nSee also:\n* {{msg-mw|thisisdeleted}}",
"restorelink": "This text is always displayed in conjunction with the {{msg-mw|thisisdeleted}} message (View or restore $1?). The user will see\nView or restore <nowiki>{{PLURAL:$1|one deleted edit|$1 deleted edits}}</nowiki>? i.e ''View or restore one deleted edit?'' or\n''View or restore n deleted edits?''",
"preferences-summary": "{{doc-specialpagesummary|preferences}}",
"mypreferences": "Action link label that leads to [[Special:Preferences]]; appears in the top menu (e.g. \"Username Talk Preferences Watchlist Contributions Log out\").\n\nSee also:\n* {{msg-mw|Mypreferences}}\n* {{msg-mw|Accesskey-pt-preferences}}\n* {{msg-mw|Tooltip-pt-preferences}}\n{{Identical|Preferences}}",
"prefs-edits": "In user preferences.",
- "prefsnologintext2": "Parameters:\n* $1 - a link to [[Special:UserLogin]] with {{msg-mw|loginreqlink}} as link description",
+ "prefsnologintext2": "Showed on Special:Userlogin when user tries to access their preferences before logging in",
"prefs-skin": "Used in user preferences.\n{{Identical|Skin}}",
"skin-preview": "{{doc-actionlink}}\nThe link beside each skin name in [[Special:Preferences|your user preferences]], tab \"skin\".\n{{Identical|Preview}}",
"datedefault": "Used as checkbox label in [[Special:Preferences#mw-prefsection-datetime|user preferences]], {{msg-mw|prefs-datetime}} tab.\n\nThis message indicates {{msg-mw|prefs-dateformat}} is default (= not specified).",
"uploadwarning": "Used as section header in [[Special:Upload]].",
"uploadwarning-text": "Used in [[Special:Upload]].",
"savefile": "When uploading a file",
- "uploadedimage": "This is the text of an entry in the [[Special:Log|upload log]] (and Recent Changes), after hour (and date, only in the Upload log) and user name. $1 is the name of the file uploaded.",
- "overwroteimage": "This is the text of an entry in the [[Special:Log|upload log]] (and Recent Changes), after hour (and date, only in the Upload log) and user name. $1 is the name of the file uploaded.",
+ "uploadedimage": "{{ignored}}This is ''logentry'' message only used on IRC. $1 is the name of the file uploaded.",
+ "overwroteimage": "{{ignored}}This is ''logentry'' message only used on IRC. $1 is the name of the file uploaded.",
"uploaddisabled": "Title of the [[Special:Upload]] page when upload is disabled.\n\nSee also:\n* {{msg-mw|Copyuploaddisabled}}",
"copyuploaddisabled": "See also:\n* {{msg-mw|Uploaddisabled}}",
"uploaddisabledtext": "Parameters:\n* $1 - (Optional) the name of the target file. See r22243 and [[bugzilla:8818|bug 8818]].",
"mywatchlist": "Link at the upper right corner of the screen.\n\nSee also:\n* {{msg-mw|Mywatchlist}}\n* {{msg-mw|Accesskey-pt-watchlist}}\n* {{msg-mw|Tooltip-pt-watchlist}}\n{{Identical|Watchlist}}",
"watchlistfor2": "Subtitle on [[Special:Watchlist]].\nParameters:\n* $1 - Username of current user\n* $2 - Tool links (View relevant changes | View and edit watchlist | Edit raw watchlist)\n{{Identical|For $1}}",
"nowatchlist": "Displayed when there is no pages in the watchlist.",
- "watchlistanontext": "Parameters:\n* $1 - a link to [[Special:UserLogin]] with {{msg-mw|loginreqlink}} as link description",
+ "watchlistanontext": "Shown on Special:Userlogin when user tries to access their watchlist before logging in",
"watchnologin": "Used as error page title.\n\nThe error message for this title is:\n* {{msg-mw|Watchnologintext}}\n{{Identical|Not logged in}}",
"addwatch": "Link to a dialog box, displayed at the end of the list of categories at the foot of each page.\n\nSee also:\n* {{msg-mw|Removewatch}}",
"addedwatchtext": "Explanation shown when clicking on the {{msg-mw|Watch}} tab. Parameters:\n* $1 - page title\nSee also:\n* {{msg-mw|Addedwatch}}",
"excontent": "Automated deletion reason when deleting a page for admins. Parameters:\n* $1 - content before deletion",
"excontentauthor": "Automated deletion reason when deleting a page for admins providing that the page has one author only.\n\nParameters:\n* $1 - content before deletion\n* $2 - username",
"exbeforeblank": "Automated deletion reason when deleting a page for admins providing that the page was blanked before deletion.\n\nParameters:\n* $1 - content before blanking",
- "delete-confirm": "Used as page title. Parameters:\n* $1 - the page title",
+ "delete-confirm": "Used as page title. Parameters:\n* $1 - the page title\n{{Identical|Delete}}",
"delete-legend": "{{Identical|Delete}}",
"historywarning": "Warning when about to delete a page that has history.\n\nFollowed by a link which points to the history page.\n\nParameters:\n* $1 - the <b>approximate</b> number of revisions that the page has, the message should not claim to give an exact count",
"confirmdeletetext": "Introduction shown when deleting a page.\n\nRefers to {{msg-mw|Policy-url}}.",
"logentry-rights-rights": "* $1 - username\n* $2 - (see below)\n* $3 - username\n* $4 - list of user groups or {{msg-mw|Rightsnone}}\n* $5 - list of user groups or {{msg-mw|Rightsnone}}\n----\n{{Logentry|[[Special:Log/rights]]}}",
"logentry-rights-rights-legacy": "* $1 - username\n* $2 - (see below)\n* $3 - username\n----\n{{Logentry|[[Special:Log/rights]]}}",
"logentry-rights-autopromote": "* $1 - username\n* $2 - (see below)\n* $3 - (see below)\n* $4 - comma separated list of old user groups or {{msg-mw|Rightsnone}}\n* $5 - comma separated list of new user groups\n----\n{{Logentry|[[Special:Log/rights]]}}",
+ "logentry-upload-upload": "{{Logentry|[[Special:Log/upload]]}}",
+ "logentry-upload-overwrite": "{{Logentry|[[Special:Log/upload]]}}",
+ "logentry-upload-revert": "{{Logentry|[[Special:Log/upload]]}}",
"rightsnone": "Default rights for registered users.\n\n{{Identical|None}}",
"revdelete-logentry": "{{RevisionDelete}}\nThis is the message for the log entry in [[Special:Log/delete]] when changing visibility restrictions for page revisions.\n\nFollowed by the message {{msg-mw|revdelete-log-message}} in brackets.\n\nPreceded by the name of the user doing this task.\n\nParameters:\n* $1 - the page name\nSee also:\n* {{msg-mw|Logdelete-logentry}}",
"logdelete-logentry": "{{RevisionDelete}}\nThis is the message for the log entry in [[Special:Log/delete]] when changing visibility restrictions for log events.\n\nFollowed by the message {{msg-mw|logdelete-log-message}} in brackets.\n\nPreceded by the name of the user who did this task.\n\nParameters:\n* $1 - the log name in brackets\nSee also:\n* {{msg-mw|Revdelete-logentry}}",
"action-pagelang": "{{Doc-action|pagelang}}",
"log-name-pagelang": "Display entry for log name for changes in page language in Special:Log.",
"log-description-pagelang": "Display description for log name for changes in page language in Special:Log.",
- "logentry-pagelang-pagelang": "{{Logentry}}\nAdditional parameters:\n* $4 - old language code, or \"[def]\" (hard-coded)\n* $5 - new language code, or \"[def]\" (hard-coded)"
+ "logentry-pagelang-pagelang": "{{Logentry}}\nAdditional parameters:\n* $4 - old language code, or \"[def]\" (hard-coded)\n* $5 - new language code, or \"[def]\" (hard-coded)",
+ "default-skin-not-found": "Message shown when the default skin for this MediaWiki installation can not be found.\n\nParameters:\n* $1: skin identifier for the default skin\n* $2: list of installed skins, composed using {{msg-mw|default-skin-not-found-row-enabled}} and {{msg-mw|default-skin-not-found-row-disabled}}\n* $3: code snippet to use to enable installed skins",
+ "default-skin-not-found-no-skins": "Message shown when the default skin for this MediaWiki installation can not be found and the installation has no skins at all.\n\nParameters:\n* $1: name of the default skin",
+ "default-skin-not-found-row-enabled": "One row of the list of installed skins shown as a part of {{msg-mw|default-skin-not-found}}, for an enabled skin.\n\nParameters:\n* $1: skin identifier\n$2: human-readable skin name",
+ "default-skin-not-found-row-disabled": "One row of the list of installed skins shown as a part of {{msg-mw|default-skin-not-found}}, for a disabled skin.\n\nParameters:\n* $1: skin identifier\n$2: human-readable skin name"
}
"uploadwarning": "Avertizare la trimiterea fișierului",
"uploadwarning-text": "Vă rugăm să modificați descrierea fișierului mai jos și să încercați din nou.",
"savefile": "Salvează fișierul",
- "uploadedimage": "a trimis [[$1]]",
- "overwroteimage": "încărcat o versiune nouă a fișierului \"[[$1]]\"",
"uploaddisabled": "Ne pare rău, trimiterea de imagini este dezactivată.",
"copyuploaddisabled": "Trimiterea prin URL este dezactivată.",
"uploaddisabledtext": "Încărcările de fișiere sunt dezactivate.",
"logentry-rights-rights": "$1 {{GENDER:$2|a schimbat}} apartenența la grup pentru $3 de la $4 la $5",
"logentry-rights-rights-legacy": "$1 {{GENDER:$2|a schimbat}} apartenența la grup pentru $3",
"logentry-rights-autopromote": "$1 {{GENDER:$2|a fost promovat|a fost promovată}} în mod automat de la $4 la $5",
+ "logentry-upload-upload": "$1 {{GENDER:$2|a încărcat}} $3",
+ "logentry-upload-overwrite": "$1 {{GENDER:$2|a încărcat}} o nouă versiune pentru $3",
+ "logentry-upload-revert": "$1 {{GENDER:$2|a încărcat}} $3",
"rightsnone": "(niciunul)",
"feedback-bugornote": "Dacă sunteți pregătit să descrieți o problemă tehnică în detaliu vă rugăm să [$1 raportați un bug].\nÎn caz contrar, puteți utiliza formularul de mai jos. Comentariul dumneavoastră va fi adăugat pe pagina „[$3 $2]”, împreună cu numele de utilizator și numele navigatorului pe care îl folosiți.",
"feedback-subject": "Subiect:",
"uploadwarning": "Предупреждение",
"uploadwarning-text": "Пожалуйста, измените представленное ниже описание файла и попробуйте ещё раз.",
"savefile": "Записать файл",
- "uploadedimage": "загрузил «[[$1]]»",
- "overwroteimage": "загружена новая версия «[[$1]]»",
"uploaddisabled": "Загрузка запрещена",
"copyuploaddisabled": "Загрузка по URL отключена.",
"uploaddisabledtext": "Загрузка файлов отключена.",
"logentry-rights-rights": "$1 {{GENDER:$2|изменил|изменила}} членство в группах для $3 с $4 на $5",
"logentry-rights-rights-legacy": "$1 {{GENDER:$2|изменил|изменила}} членство в группах для $3",
"logentry-rights-autopromote": "$1 был{{GENDER:$2||а}} автоматически переведен{{GENDER:$2||а}} из $4 в $5",
+ "logentry-upload-upload": "$1 загрузил{{GENDER:$2||а}} $3",
+ "logentry-upload-overwrite": "$1 загрузил{{GENDER:$2||а}} новую версию $3",
+ "logentry-upload-revert": "$1 загрузил{{GENDER:$2||а}} $3",
"rightsnone": "(нет)",
"feedback-bugornote": "Если вы готовы подробно описать техническую проблему, пожалуйста, [$1 сообщите об ошибке].\nВ противном случае вы можете использовать данную простую форму. Ваш комментарий будет добавлен на страницу «[$3 $2]» вместе с вашим именем участника и используемым браузером.",
"feedback-subject": "Тема:",
"badfilename": "Su nùmene de su file est stadu cunvertidu in \"$1\".",
"uploadwarning": "Avvisu de carrigamentu",
"savefile": "Sarva file",
- "uploadedimage": "carrigadu \"[[$1]]\"",
"upload-source": "File de orìgine",
"sourcefilename": "Nùmene de su file de orìgine:",
"sourceurl": "Diretzione originària:",
"uploadwarning": "Opozorilo!",
"uploadwarning-text": "Prosimo, spremenite opis datoteke spodaj in poskusite ponovno.",
"savefile": "Shrani datoteko",
- "uploadedimage": "je naložil(-a) datoteko »[[$1]]«",
- "overwroteimage": "je naložil(-a) novo različico datoteke »[[$1]]«",
"uploaddisabled": "Nalaganje je onemogočeno",
"copyuploaddisabled": "Nalaganje preko URL je onemogočeno",
"uploaddisabledtext": "Nalaganje datotek je onemogočeno.",
"logentry-rights-rights": "$1 je {{GENDER:$2|spremenil|spremenila|spremenil(-a)}} uporabniške pravice uporabnika $3 z $4 na $5",
"logentry-rights-rights-legacy": "$1 je {{GENDER:$2|spremenil|spremenila|spremenil(-a)}} uporabniške pravice uporabnika $3",
"logentry-rights-autopromote": "$1 je {{GENDER:$2|bil samodejno povišan|bila samodejno povišana|bil(-a) samodejno povišan(-a)}} z $4 na $5",
+ "logentry-upload-upload": "$1 je {{GENDER:$2|naložil|naložila|naložil(-a)}} $3",
+ "logentry-upload-overwrite": "$1 je {{GENDER:$2|naložil|naložila|naložil(-a)}} novo različico $3",
+ "logentry-upload-revert": "$1 je {{GENDER:$2|naložil|naložila|naložil(-a)}} $3",
"rightsnone": "(nobeno)",
"feedback-bugornote": "Če ste pripravljeni podrobno opisati tehnično težavo, vložite [$1 poročilo o hrošču].\nV nasprotnem primeru lahko uporabite preprost obrazec spodaj. Vašo pripombo bomo dodali na stran »[$3 $2]«, skupaj z vašim uporabniškim imenom in podatkom o brskalniku, ki ga uporabljate.",
"feedback-subject": "Zadeva:",
"uploadwarning": "Упозорење при отпремању",
"uploadwarning-text": "Измените опис датотеке и покушајте поново.",
"savefile": "Сачувај датотеку",
- "uploadedimage": "је послао „[[$1]]“",
- "overwroteimage": "је послао нову верзију датотеке „[[$1]]“",
"uploaddisabled": "Отпремање је онемогућено.",
"copyuploaddisabled": "Слање путем URL адресе је онемогућено.",
"uploaddisabledtext": "Отпремање датотека је онемогућено.",
"uploadwarning": "Upozorenje pri otpremanju",
"uploadwarning-text": "Izmenite opis datoteke i pokušajte ponovo.",
"savefile": "Sačuvaj datoteku",
- "uploadedimage": "je poslao „[[$1]]“",
- "overwroteimage": "je poslao novu verziju datoteke „[[$1]]“",
"uploaddisabled": "Otpremanje je onemogućeno.",
"copyuploaddisabled": "Slanje putem URL adrese je onemogućeno.",
"uploaddisabledtext": "Otpremanje datoteka je onemogućeno.",
"uploadwarning": "Uppladdningsvarning",
"uploadwarning-text": "Var god och ändra filbeskrivningen nedanför och försök igen.",
"savefile": "Spara fil",
- "uploadedimage": "laddade upp \"[[$1]]\"",
- "overwroteimage": "laddade upp ny version av \"[[$1]]\"",
"uploaddisabled": "Uppladdningsfunktionen är avstängd",
"copyuploaddisabled": "Uppladdning med URL avstängt.",
"uploaddisabledtext": "Uppladdning av filer är avstängd.",
"logentry-rights-rights": "$1 {{GENDER:$2|ändrade}} gruppmedlemskapet för $3 från $4 till $5",
"logentry-rights-rights-legacy": "$1 {{GENDER:$2|ändrade}} gruppmedlemskapet för $3",
"logentry-rights-autopromote": "$1 {{GENDER:$2|befordrades}} automatiskt från $4 till $5",
+ "logentry-upload-upload": "$1 {{GENDER:$2|laddade upp}} $3",
+ "logentry-upload-overwrite": "$1 {{GENDER:$2|laddade upp}} en ny version av $3",
+ "logentry-upload-revert": "$1 {{GENDER:$2|laddade upp}} $3",
"rightsnone": "(inga)",
"feedback-bugornote": "Om du är redo att beskriva ett tekniskt problem detaljerat, var god [$1 rapporterar en bugg].\nAnnars kan du använda det enkla formuläret nedan. Din kommentar kommer att läggas till på sidan \"[$3 $2]\", tillsammans med ditt användarnamn och vilken webbläsare du använder.",
"feedback-subject": "Ämne:",
"file-deleted-duplicate": "Identyczny plik jak tyn plik ([[:$1]]) zostoł wyćepany. Sprowdź historyja wyćepań tamtygo plika ńim wćepńesz go nazod.",
"uploadwarning": "Uostřežyńe uo wćepywańu",
"savefile": "Spamjyntej plik",
- "uploadedimage": "wćepano \"[[$1]]\"",
- "overwroteimage": "wćepano nowszo wersyjo \"[[$1]]\"",
"uploaddisabled": "Wćepywanie sam plikůw je zawarte",
"uploaddisabledtext": "Wćepywańe plikůw je zawarte.",
"uploadscripted": "Tyn plik zawjyro kod HTML abo skrypt kery može zostać felerńe zinterpretowany bez přyglůndarka internetowo.",
"uploadwarning": "பதிவேற்றல் எச்சரிக்கை",
"uploadwarning-text": "கீழுள்ள கோப்புச் சுருக்கத்தை மாற்றி விட்டு மீண்டும் சமர்ப்பியுங்கள்",
"savefile": "கோப்பைச் சேமி",
- "uploadedimage": "\"[[$1]]\" பதிவேற்றப்பட்டது",
- "overwroteimage": "\"[[$1]]\" கோப்பின் புதிய பதிப்பை பதிவேற்று",
"uploaddisabled": "பதிவேற்றம் செயலிழக்கச் செய்யப்பட்டுள்ளது",
"copyuploaddisabled": "URL வழியாக தகவலேற்றல் முடக்கப்பட்டுள்ளது.",
"uploaddisabledtext": "கோப்பு பதிவேற்றங்கள் செயலிழக்கச் செய்யப்பட்டுள்ளன.",
"uploadwarning": "คำเตือนการอัปโหลด",
"uploadwarning-text": "กรุณาแก้ไขคำอธิบายไฟล์ด้านล่างนี้ แล้วลองใหม่อีกครั้ง",
"savefile": "บันทึกไฟล์",
- "uploadedimage": "อัปโหลด \"[[$1]]\"",
- "overwroteimage": "อัปโหลดรุ่นใหม่ของ \"[[$1]]\"",
"uploaddisabled": "ปิดใช้งานการอัปโหลด",
"copyuploaddisabled": "ปิดใช้งานการอัปโหลดโดยยูอาร์แอล",
"uploaddisabledtext": "ปิดใช้งานการอัปโหลดไฟล์",
"versionrequiredtext": "Bu sayfayı kullanmak için MediaWiki'nin $1 sürümü gerekmektedir. [[Special:Version|Sürüm sayfasına]] bakınız.",
"ok": "Tamam",
"pagetitle-view-mainpage": "{{SITENAME}}",
+ "backlinksubtitle": "←$1",
"retrievedfrom": "\"$1\" adresinden alındı.",
"youhavenewmessages": "$1 {{PLURAL:$3|var}} ($2).",
"youhavenewmessagesfromusers": "{{PLURAL:$3|Başka bir kullanıcıdan|$3 kullanıcıdan}} $1 var ($2).",
"uploadwarning": "Yükleme uyarısı",
"uploadwarning-text": "Lütfen aşağıdaki dosya açıklamasını değiştirin ve tekrar deneyin.",
"savefile": "Dosyayı kaydet",
- "uploadedimage": "Yüklenen: \"[[$1]]\"",
- "overwroteimage": "\"[[$1]]\" resminin yeni sürümü yüklenmiştir",
"uploaddisabled": "Geçici olarak şu anda herhangi bir dosya yüklenmez. Biraz sonra bir daha deneyiniz.",
"copyuploaddisabled": "URL ile yükleme devre dışı.",
"uploaddisabledtext": "Dosya yüklemeleri devredışı bırakılmıştır.",
"uploadwarning": "Попередження",
"uploadwarning-text": "Будь ласка, змініть наданий нижче опис файлу і спробуйте ще раз.",
"savefile": "Зберегти файл",
- "uploadedimage": "завантажив «[[$1]]»",
- "overwroteimage": "завантажив нову версію «[[$1]]»",
"uploaddisabled": "Завантаження заборонене",
"copyuploaddisabled": "Завантаження через URL вимкнене.",
"uploaddisabledtext": "Можливість завантаження файлів відключена.",
"logentry-rights-rights": "$1 {{GENDER:$1|змінив|змінила}} членство в групах для $3 із $4 на $5",
"logentry-rights-rights-legacy": "$1 {{GENDER:$1|змінив|змінила}} членство в групах для $3",
"logentry-rights-autopromote": "$1 було автоматично переведено із $4 в $5",
+ "logentry-upload-upload": "$1 {{GENDER:$2|завантажив|завантажила}} $3",
+ "logentry-upload-overwrite": "$1 {{GENDER:$2|завантажив|завантажила}} нову версію $3",
+ "logentry-upload-revert": "$1 {{GENDER:$2|завантажив|завантажила}} $3",
"rightsnone": "(нема)",
"feedback-bugornote": "Якщо ви готові описати технічні проблеми в деталях, будь ласка, [$1 повідомте про помилку].\nАбо можете використати форму нижче. Ваш коментар буде додано на сторінку \"[$3 $2]\", разом з іменем користувача.",
"feedback-subject": "Тема:",
"uploadwarning": "Cảnh báo!",
"uploadwarning-text": "Xin hãy chỉnh sửa miêu tả tập tin ở dưới và thử lại.",
"savefile": "Lưu tập tin",
- "uploadedimage": "đã tải “[[$1]]” lên",
- "overwroteimage": "đã tải lên một phiên bản mới của “[[$1]]”",
"uploaddisabled": "Chức năng tải lên đã bị khóa.",
"copyuploaddisabled": "Chức năng tải lên từ địa chỉ URL đã bị tắt.",
"uploaddisabledtext": "Chức năng tải tập tin đã bị tắt.",
"windows-nonascii-filename": "箇wiki弗支持文件名用特別個字符。",
"uploadwarning": "上载警告",
"savefile": "保存文件",
- "uploadedimage": "上传 \"[[$1]]\"",
"sourcefilename": "源文件:",
"destfilename": "目标文件名:",
"watchthisupload": "關注箇文件",
"uploadwarning": "אַרויפֿלאָדן וואָרענונג",
"uploadwarning-text": "זײַט אַזוי גוט מאדיפֿיצירן די טעקע באַשרייבונג און פרובירט נאכאַמאָל.",
"savefile": "אױפֿהיטן טעקע",
- "uploadedimage": "אַרױפֿגעלאָדן \"[[$1]]\"",
- "overwroteimage": "אַרויפֿגעלאָדן א נײַע ווערסיע פון \"[[$1]]\"",
"uploaddisabled": "אַרויפֿלאָדן טעקעס מבוטל",
"copyuploaddisabled": "ארויפלאדן דורך URL אומאקטיווירט",
"uploaddisabledtext": "אַרויפֿלאָדן טעקעס נישט דערמעגלעכט.",
"아라",
"Mywood",
"Impersonator 1",
- "Duolaimi"
+ "Duolaimi",
+ "TianyinLee"
]
},
"tog-underline": "链接下划线:",
"mainpage": "首页",
"mainpage-description": "首页",
"policy-url": "Project:方针",
- "portal": "社å\8cºä¸\93页",
+ "portal": "社å\8cºä¸»页",
"portal-url": "Project:社区专页",
"privacy": "隐私权政策",
"privacypage": "Project:隐私权政策",
"showdiff": "显示更改",
"blankarticle": "<strong>警告</strong>:您创建的页面是空白的。如果您再次点击“{{int:savearticle}}”,您将真的创建没有任何内容的页面。",
"anoneditwarning": "<strong>警告:</strong>您没有登录。您的IP地址将被记录在该页面的编辑历史中。",
- "anonpreviewwarning": "''你没有登录。保存会记录你的IP地址于该页面的编辑历史中。''",
+ "anonpreviewwarning": "<em>你没有登录。保存会记录你的IP地址于该页面的编辑历史中。</em>",
"missingsummary": "'''提示:'''你没有提供编辑摘要。如果你再次点击“{{int:savearticle}}”,你的编辑将不带编辑摘要保存。",
"missingcommenttext": "请在下面输入评论。",
"missingcommentheader": "'''提示:''' 您还没有为此评论提供一个标题。如果您再次点击“{{int:savearticle}}”,您的编辑将不带标题保存。",
"uploadwarning": "上传警告",
"uploadwarning-text": "请修改下面的文件说明并重试。",
"savefile": "保存文件",
- "uploadedimage": "上传“[[$1]]”",
- "overwroteimage": "上传“[[$1]]”的新版本",
"uploaddisabled": "上传己停用。",
"copyuploaddisabled": "URL上传已停用。",
"uploaddisabledtext": "文件上传已停用。",
"logentry-rights-rights": "$1{{GENDER:$2|更改}}$3的用户组自$4至$5",
"logentry-rights-rights-legacy": "$1更改$3的用户组",
"logentry-rights-autopromote": "$1被自动地{{GENDER:$2|提升}}自$4至$5",
+ "logentry-upload-upload": "$1{{GENDER:$2|上传了}}$3",
+ "logentry-upload-overwrite": "$1{{GENDER:$2|上传了}}$3的新版本",
+ "logentry-upload-revert": "$1{{GENDER:$2|上传了}}$3",
"rightsnone": "(无)",
"feedback-bugornote": "如果你准备好详细描述一个技术问题,请[$1 报告bug]。或者你可以使用下面的简单表格。你的评论将被添加至页面“[$3 $2]”,附有你的用户名。",
"feedback-subject": "主题:",
"uploadwarning": "上傳警告",
"uploadwarning-text": "請修改以下的檔案描述並重試。",
"savefile": "儲存檔案",
- "uploadedimage": "已上傳 \"[[$1]]\"",
- "overwroteimage": "已上傳新版本的 \"[[$1]]\"",
"uploaddisabled": "己停用上傳。",
"copyuploaddisabled": "己停用使用 URL 上傳。",
"uploaddisabledtext": "已停用檔案上傳。",
*
*/
+$digitTransformTable = array();
+
+$separatorTransformTable = array(
+ '.' => ',',
+ ',' => '.'
+);
+
$fallback = 'ar';
--- Add indexes to the mime types in image for use on Special:MIMEsearch,
+-- Add indexes to the MIME types in image for use on Special:MIMEsearch,
-- changes a query like
--
-- SELECT img_name FROM image WHERE img_major_mime = "image" AND img_minor_mime = "svg";
}
}
if ( $mime ) {
- # Use custom handling to serve files with a known mime type
+ # Use custom handling to serve files with a known MIME type
# This way we can serve things like .svg files that the built-in
# PHP webserver doesn't understand.
# ;) Nicely enough we just happen to bundle a mime.types file
--- /dev/null
+<?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
+ * @author Aaron Schulz
+ */
+
+require_once __DIR__ . '/Maintenance.php';
+
+class FindMissingFiles extends Maintenance {
+ function __construct() {
+ parent::__construct();
+
+ $this->mDescription = 'Find registered files with no corresponding file.';
+ $this->addOption( 'start', 'Starting file name', false, true );
+ $this->setBatchSize( 200 );
+ }
+
+ function execute() {
+ $lastName = $this->getOption( 'start', '' );
+
+ $repo = RepoGroup::singleton()->getLocalRepo();
+ $dbr = $repo->getSlaveDB();
+ $be = $repo->getBackend();
+
+ do {
+ $res = $dbr->select( 'image',
+ 'img_name',
+ array( "img_name >= " . $dbr->addQuotes( $lastName ) ),
+ __METHOD__,
+ array( 'ORDER BY' => 'img_name', 'LIMIT' => $this->mBatchSize )
+ );
+
+ // Check if any of these files are missing...
+ $pathsByName = array();
+ foreach ( $res as $row ) {
+ $file = $repo->newFile( $row->img_name );
+ $pathsByName[$row->img_name] = $file->getPath();
+ $lastName = $row->img_name;
+ }
+ $be->preloadFileStat( array( 'srcs' => $pathsByName ) );
+ foreach ( $pathsByName as $path ) {
+ if ( $be->fileExists( array( 'src' => $path ) ) === false ) {
+ $this->output( "$path\n" );
+ }
+ }
+
+ // Find all missing old versions of any of the files in this batch...
+ if ( count( $pathsByName ) ) {
+ $ores = $dbr->select( 'oldimage',
+ array( 'oi_name', 'oi_archive_name' ),
+ array( 'oi_name' => array_keys( $pathsByName ) ),
+ __METHOD__
+ );
+ foreach ( $ores as $row ) {
+ if ( !strlen( $row->oi_archive_name ) ) {
+ continue; // broken row
+ }
+ $file = $repo->newFromArchiveName( $row->oi_name, $row->oi_archive_name );
+ $path = $file->getPath();
+ if ( $be->fileExists( array( 'src' => $path ) ) === false ) {
+ $this->output( "$path\n" );
+ }
+ }
+ }
+ } while ( $res->numRows() >= $this->mBatchSize );
+ }
+}
+
+$maintClass = 'FindMissingFiles';
+require_once RUN_MAINTENANCE_IF_MAIN;
"../../resources/src/jquery/jquery.checkboxShiftClick.js",
"../../resources/src/jquery/jquery.client.js",
"../../resources/src/jquery/jquery.colorUtil.js",
+ "../../resources/src/jquery/jquery.confirmable.js",
"../../resources/src/jquery/jquery.footHovzer.js",
"../../resources/src/jquery/jquery.getAttrs.js",
"../../resources/src/jquery/jquery.hidpi.js",
$this->addOption(
'mime',
- '(Inefficient!) Only refresh files with this mime type. Can accept wild-card image/*',
+ '(Inefficient!) Only refresh files with this MIME type. Can accept wild-card image/*',
false,
true
);
if ( !$wgUser ) {
$this->error( "Invalid username", true );
}
- $archive = new PageArchive( $title );
+ $archive = new PageArchive( $title, RequestContext::getMain()->getConfig() );
$this->output( "Undeleting " . $title->getPrefixedDBkey() . '...' );
$archive->undelete( array(), $reason );
$this->output( "done\n" );
'jquery.colorUtil' => array(
'scripts' => 'resources/src/jquery/jquery.colorUtil.js',
),
+ 'jquery.confirmable' => array(
+ 'scripts' => array(
+ 'resources/src/jquery/jquery.confirmable.js',
+ 'resources/src/jquery/jquery.confirmable.mediawiki.js',
+ ),
+ 'messages' => array(
+ 'confirmable-confirm',
+ 'confirmable-yes',
+ 'confirmable-no',
+ ),
+ 'styles' => 'resources/src/jquery/jquery.confirmable.css',
+ 'dependencies' => 'mediawiki.jqueryMsg',
+ ),
// Use mediawiki.cookie in new code, rather than jquery.cookie.
'jquery.cookie' => array(
'scripts' => 'resources/lib/jquery/jquery.cookie.js',
"Xiaomingyan",
"Yfdyh000",
"Zhangjintao",
- "乌拉跨氪"
+ "乌拉跨氪",
+ "Great Brightstar"
]
},
"ooui-outline-control-move-down": "下移项",
"ooui-outline-control-move-up": "上移项",
"ooui-outline-control-remove": "删除项",
"ooui-toolbar-more": "更多",
- "ooui-dialog-message-accept": "好",
+ "ooui-dialog-message-accept": "确定",
"ooui-dialog-message-reject": "取消",
"ooui-dialog-process-error": "发生一些错误",
"ooui-dialog-process-dismiss": "解除",
/*!
- * OOjs UI v0.1.0-pre (dd294dc785)
+ * OOjs UI v0.1.0-pre (0e50d2e336)
* https://www.mediawiki.org/wiki/OOjs_UI
*
* Copyright 2011–2014 OOjs Team and other contributors.
* Released under the MIT license
* http://oojs.mit-license.org
*
- * Date: 2014-07-30T23:10:53Z
+ * Date: 2014-08-06T12:56:55Z
*/
.oo-ui-dialog-content > .oo-ui-window-head,
.oo-ui-dialog-content > .oo-ui-window-body,
/*!
- * OOjs UI v0.1.0-pre (dd294dc785)
+ * OOjs UI v0.1.0-pre (0e50d2e336)
* https://www.mediawiki.org/wiki/OOjs_UI
*
* Copyright 2011–2014 OOjs Team and other contributors.
* Released under the MIT license
* http://oojs.mit-license.org
*
- * Date: 2014-07-30T23:10:53Z
+ * Date: 2014-08-06T12:56:55Z
*/
.oo-ui-dialog-content > .oo-ui-window-head,
.oo-ui-dialog-content > .oo-ui-window-body,
/*!
- * OOjs UI v0.1.0-pre (dd294dc785)
+ * OOjs UI v0.1.0-pre (0e50d2e336)
* https://www.mediawiki.org/wiki/OOjs_UI
*
* Copyright 2011–2014 OOjs Team and other contributors.
* Released under the MIT license
* http://oojs.mit-license.org
*
- * Date: 2014-07-30T23:10:53Z
+ * Date: 2014-08-06T12:56:55Z
*/
( function ( OO ) {
// Properties
this.loading = null;
this.config = config;
+ this.dir = null;
// Initialize
this.$element
win = this.$element.prop( 'contentWindow' );
doc = win.document;
- // Figure out directionality:
+ // Cache directionality
this.dir = OO.ui.Element.getDir( this.$element ) || 'ltr';
// Initialize contents
doc.write(
'<!doctype html>' +
'<html>' +
- '<body class="oo-ui-frame-content oo-ui-' + this.dir + '" dir="' + this.dir + '">' +
+ '<body class="oo-ui-frame-content oo-ui-' + this.getDir() + '" dir="' + this.getDir() + '">' +
'</body>' +
'</html>'
);
return this;
};
+/**
+ * Get the directionality of the frame
+ *
+ * @return {string} Directionality, 'ltr' or 'rtl'
+ */
+OO.ui.Frame.prototype.getDir = function () {
+ return this.dir;
+};
+
/**
* Container for elements.
*
/*!
- * OOjs UI v0.1.0-pre (dd294dc785)
+ * OOjs UI v0.1.0-pre (0e50d2e336)
* https://www.mediawiki.org/wiki/OOjs_UI
*
* Copyright 2011–2014 OOjs Team and other contributors.
* Released under the MIT license
* http://oojs.mit-license.org
*
- * Date: 2014-07-30T23:10:53Z
+ * Date: 2014-08-06T12:56:55Z
*/
/* Textures */
--- /dev/null
+.jquery-confirmable-button {
+ /* Automatically flipped */
+ margin-left: 1ex;
+}
+
+.jquery-confirmable-wrapper {
+ /* Line breaks within the interface text are unpleasant */
+ white-space: nowrap;
+ /* Hiding the original text when it slides to the left */
+ overflow: hidden;
+}
+
+.jquery-confirmable-wrapper,
+.jquery-confirmable-element,
+.jquery-confirmable-interface {
+ /* We need inline-block to be able to size the elements and calculate their dimensions */
+ display: inline-block;
+ /* inline-block elements in this context align to baseline by default */
+ vertical-align: bottom;
+}
+
+.jquery-confirmable-element {
+ transition: margin 250ms cubic-bezier(0.2, 0.8, 0.2, 0.8);
+}
+
+.jquery-confirmable-interface {
+ transition: width 250ms cubic-bezier(0.2, 0.8, 0.2, 0.8);
+}
--- /dev/null
+/**
+ * jQuery confirmable plugin
+ *
+ * Released under the MIT License.
+ *
+ * @author Bartosz Dziewoński
+ *
+ * @class jQuery.plugin.confirmable
+ */
+( function ( $ ) {
+ var identity = function ( data ) {
+ return data;
+ };
+
+ /**
+ * Enable inline confirmation for given clickable element (like `<a />` or `<button />`).
+ *
+ * An additional inline confirmation step being shown before the default action is carried out on
+ * click.
+ *
+ * Calling `.confirmable( { handler: function () { … } } )` will fire the handler only after the
+ * confirmation step.
+ *
+ * The element will have the `jquery-confirmable-element` class added to it when it's clicked for
+ * the first time, which has `white-space: nowrap;` and `display: inline-block;` defined in CSS.
+ * If the computed values for the element are different when you make it confirmable, you might
+ * encounter unexpected behavior.
+ *
+ * @param {Object} [options]
+ * @param {string} [options.events='click'] Events to hook to.
+ * @param {Function} [options.wrapperCallback] Callback to fire when preparing confirmable
+ * interface. Receives the interface jQuery object as the only parameter.
+ * @param {Function} [options.buttonCallback] Callback to fire when preparing confirmable buttons.
+ * It is fired separately for the 'Yes' and 'No' button. Receives the button jQuery object as
+ * the first parameter and 'yes' or 'no' as the second.
+ * @param {Function} [options.handler] Callback to fire when the action is confirmed (user clicks
+ * the 'Yes' button).
+ * @param {string} [options.i18n] Text to use for interface elements.
+ * @param {string} [options.i18n.confirm] Text to use for the confirmation question.
+ * @param {string} [options.i18n.yes] Text to use for the 'Yes' button.
+ * @param {string} [options.i18n.no] Text to use for the 'No' button.
+ *
+ * @chainable
+ */
+ $.fn.confirmable = function ( options ) {
+ options = $.extend( true, {}, $.fn.confirmable.defaultOptions, options || {} );
+
+ return this.on( options.events, function ( e ) {
+ var $element, $text, $buttonYes, $buttonNo, $wrapper, $interface, $elementClone,
+ interfaceWidth, elementWidth, rtl, positionOffscreen, positionRestore, sideMargin;
+
+ $element = $( this );
+
+ if ( $element.data( 'jquery-confirmable-button' ) ) {
+ // We're running on a clone of this element that represents the 'Yes' or 'No' button.
+ // (This should never happen for the 'No' case unless calling code does bad things.)
+ return;
+ }
+
+ // Only prevent native event handling. Stopping other JavaScript event handlers
+ // is impossible because they might have already run (we have no control over the order).
+ e.preventDefault();
+
+ rtl = $element.css( 'direction' ) === 'rtl';
+ if ( rtl ) {
+ positionOffscreen = { position: 'absolute', right: '-9999px' };
+ positionRestore = { position: '', right: '' };
+ sideMargin = 'marginRight';
+ } else {
+ positionOffscreen = { position: 'absolute', left: '-9999px' };
+ positionRestore = { position: '', left: '' };
+ sideMargin = 'marginLeft';
+ }
+
+ if ( $element.hasClass( 'jquery-confirmable-element' ) ) {
+ $wrapper = $element.closest( '.jquery-confirmable-wrapper' );
+ $interface = $wrapper.find( '.jquery-confirmable-interface' );
+ $text = $interface.find( '.jquery-confirmable-text' );
+ $buttonYes = $interface.find( '.jquery-confirmable-button-yes' );
+ $buttonNo = $interface.find( '.jquery-confirmable-button-no' );
+
+ interfaceWidth = $interface.data( 'jquery-confirmable-width' );
+ elementWidth = $element.data( 'jquery-confirmable-width' );
+ } else {
+ $elementClone = $element.clone( true );
+ $element.addClass( 'jquery-confirmable-element' );
+
+ elementWidth = $element.width();
+ $element.data( 'jquery-confirmable-width', elementWidth );
+
+ $wrapper = $( '<span>' )
+ .addClass( 'jquery-confirmable-wrapper' );
+ $element.wrap( $wrapper );
+
+ // Build the mini-dialog
+ $text = $( '<span>' )
+ .addClass( 'jquery-confirmable-text' )
+ .text( options.i18n.confirm );
+
+ // Clone original element along with event handlers to easily replicate its behavior.
+ // We could fiddle with .trigger() etc., but that is troublesome especially since
+ // Safari doesn't implement .click() on <a> links and jQuery follows suit.
+ $buttonYes = $elementClone.clone( true )
+ .addClass( 'jquery-confirmable-button jquery-confirmable-button-yes' )
+ .data( 'jquery-confirmable-button', true )
+ .text( options.i18n.yes );
+ if ( options.handler ) {
+ $buttonYes.on( options.events, options.handler );
+ }
+ $buttonYes = options.buttonCallback( $buttonYes, 'yes' );
+
+ // Clone it without any events and prevent default action to represent the 'No' button.
+ $buttonNo = $elementClone.clone( false )
+ .addClass( 'jquery-confirmable-button jquery-confirmable-button-no' )
+ .data( 'jquery-confirmable-button', true )
+ .text( options.i18n.no )
+ .on( options.events, function ( e ) {
+ $element.css( sideMargin, 0 );
+ $interface.css( 'width', 0 );
+ e.preventDefault();
+ } );
+ $buttonNo = options.buttonCallback( $buttonNo, 'no' );
+
+ // Prevent memory leaks
+ $elementClone.remove();
+
+ $interface = $( '<span>' )
+ .addClass( 'jquery-confirmable-interface' )
+ .append( $text, $buttonYes, $buttonNo );
+ $interface = options.wrapperCallback( $interface );
+
+ // Render offscreen to measure real width
+ $interface.css( positionOffscreen );
+ // Insert it in the correct place while we're at it
+ $element.after( $interface );
+ interfaceWidth = $interface.width();
+ $interface.data( 'jquery-confirmable-width', interfaceWidth );
+ $interface.css( positionRestore );
+
+ // Hide to animate the transition later
+ $interface.css( 'width', 0 );
+ }
+
+ // Hide element, show interface. This triggers both transitions.
+ // In a timeout to trigger the 'width' transition.
+ setTimeout( function () {
+ $element.css( sideMargin, -elementWidth );
+ $interface.css( 'width', interfaceWidth );
+ }, 1 );
+ } );
+ };
+
+ /**
+ * Default options. Overridable primarily for internationalisation handling.
+ * @property {Object} defaultOptions
+ */
+ $.fn.confirmable.defaultOptions = {
+ events: 'click',
+ wrapperCallback: identity,
+ buttonCallback: identity,
+ handler: null,
+ i18n: {
+ confirm: 'Are you sure?',
+ yes: 'Yes',
+ no: 'No'
+ }
+ };
+}( jQuery ) );
--- /dev/null
+/*!
+ * jQuery confirmable plugin customization for MediaWiki
+ *
+ * This file serves to inject our localised messages into it.
+ */
+
+( function ( mw, $ ) {
+ $.fn.confirmable.defaultOptions.i18n = {
+ confirm: mw.message( 'confirmable-confirm', mw.user ).text(),
+ yes: mw.message( 'confirmable-yes' ).text(),
+ no: mw.message( 'confirmable-no' ).text()
+ };
+}( mediaWiki, jQuery ) );
colspan,
headerCount,
longestTR,
- matrixRowIndex,
- matrixColumnIndex,
exploded,
$tableHeaders = $( [] ),
$tableRows = $( 'thead:eq(0) > tr', table );
// Loop through all the dom cells of the thead
$tableRows.each( function ( rowIndex, row ) {
$.each( row.cells, function ( columnIndex, cell ) {
+ var matrixRowIndex,
+ matrixColumnIndex;
+
rowspan = Number( cell.rowSpan );
colspan = Number( cell.colSpan );
#mw-createaccount-join {
margin-left: 0.75em;
- /* Separate from background image */
- box-shadow: 4px 4px 4px 4px rgba(255, 255, 255, 1);
width: auto;
display: inline-block;
}
width: 100%;
padding: .3em .3em .3em .6em;
display: block;
+ vertical-align: middle;
// Override user agent stylesheet properties. Instead use parent element.
color: inherit;
font-family: inherit;
.mw-ui-input-large {
margin-top: 0;
margin-bottom: 0;
+
+ // When two large inputs are together, we make them flush by hiding one of the borders
& + .mw-ui-input-large {
- border-top-width: 0;
+ margin-top: -1px;
+ }
+ // When focusing, make the input relative to raise it above any attached inputs to unhide its borders
+ &:focus {
+ position: relative;
}
}
*
* @param {string|Array} modules Either the name of a module, array of modules,
* or a URL of an external script or style
- * @param {string} [type='text/javascript'] mime-type to use if calling with a URL of an
+ * @param {string} [type='text/javascript'] MIME type to use if calling with a URL of an
* external script or style; acceptable values are "text/css" and
* "text/javascript"; if no type is provided, text/javascript is assumed.
* @param {boolean} [async] Whether to load modules asynchronously.
/**
* Display a notification message to the user.
*
- * @param {HTMLElement|jQuery|mw.Message|string} message
+ * @param {HTMLElement|HTMLElement[]|jQuery|mw.Message|string} message
* @param {Object} options The options to use for the notification.
* See #defaults for details.
* @return {mw.Notification} Notification object
ua = navigator.userAgent;
}
- // MediaWiki JS or jQuery is known to have issues with:
+ // Browsers with outdated or limited JavaScript engines get the no-JS experience
return !(
- // Internet Explorer < 6
- ( ua.indexOf( 'MSIE' ) !== -1 && parseFloat( ua.split( 'MSIE' )[1] ) < 6 ) ||
+ // Internet Explorer < 7
+ ( ua.indexOf( 'MSIE' ) !== -1 && parseFloat( ua.split( 'MSIE' )[1] ) < 7 ) ||
// Firefox < 3
( ua.indexOf( 'Firefox/' ) !== -1 && parseFloat( ua.split( 'Firefox/' )[1] ) < 3 ) ||
// BlackBerry < 6
/*
!/common/
-!/MonoBook/
-!/Vector/
!/.gitignore
+++ /dev/null
-== GNU GENERAL PUBLIC LICENSE ==
-
-Version 2, June 1991
-
-Copyright (C) 1989, 1991 Free Software Foundation, Inc.
-51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
-Everyone is permitted to copy and distribute verbatim copies
-of this license document, but changing it is not allowed.
-
-=== Preamble ===
-
-The licenses for most software are designed to take away your
-freedom to share and change it. By contrast, the GNU General Public
-License is intended to guarantee your freedom to share and change free
-software--to make sure the software is free for all its users. This
-General Public License applies to most of the Free Software
-Foundation's software and to any other program whose authors commit to
-using it. (Some other Free Software Foundation software is covered by
-the GNU Library General Public License instead.) You can apply it to
-your programs, too.
-
-When we speak of free software, we are referring to freedom, not
-price. Our General Public Licenses are designed to make sure that you
-have the freedom to distribute copies of free software (and charge for
-this service if you wish), that you receive source code or can get it
-if you want it, that you can change the software or use pieces of it
-in new free programs; and that you know you can do these things.
-
-To protect your rights, we need to make restrictions that forbid
-anyone to deny you these rights or to ask you to surrender the rights.
-These restrictions translate to certain responsibilities for you if you
-distribute copies of the software, or if you modify it.
-
-For example, if you distribute copies of such a program, whether
-gratis or for a fee, you must give the recipients all the rights that
-you have. You must make sure that they, too, receive or can get the
-source code. And you must show them these terms so they know their
-rights.
-
-We protect your rights with two steps: (1) copyright the software, and
-(2) offer you this license which gives you legal permission to copy,
-distribute and/or modify the software.
-
-Also, for each author's protection and ours, we want to make certain
-that everyone understands that there is no warranty for this free
-software. If the software is modified by someone else and passed on, we
-want its recipients to know that what they have is not the original, so
-that any problems introduced by others will not reflect on the original
-authors' reputations.
-
-Finally, any free program is threatened constantly by software
-patents. We wish to avoid the danger that redistributors of a free
-program will individually obtain patent licenses, in effect making the
-program proprietary. To prevent this, we have made it clear that any
-patent must be licensed for everyone's free use or not licensed at all.
-
-The precise terms and conditions for copying, distribution and
-modification follow.
-
-== TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION ==
-
-'''0.''' This License applies to any program or other work which contains
-a notice placed by the copyright holder saying it may be distributed
-under the terms of this General Public License. The "Program", below,
-refers to any such program or work, and a "work based on the Program"
-means either the Program or any derivative work under copyright law:
-that is to say, a work containing the Program or a portion of it,
-either verbatim or with modifications and/or translated into another
-language. (Hereinafter, translation is included without limitation in
-the term "modification".) Each licensee is addressed as "you".
-
-Activities other than copying, distribution and modification are not
-covered by this License; they are outside its scope. The act of
-running the Program is not restricted, and the output from the Program
-is covered only if its contents constitute a work based on the
-Program (independent of having been made by running the Program).
-Whether that is true depends on what the Program does.
-
-'''1.''' You may copy and distribute verbatim copies of the Program's
-source code as you receive it, in any medium, provided that you
-conspicuously and appropriately publish on each copy an appropriate
-copyright notice and disclaimer of warranty; keep intact all the
-notices that refer to this License and to the absence of any warranty;
-and give any other recipients of the Program a copy of this License
-along with the Program.
-
-You may charge a fee for the physical act of transferring a copy, and
-you may at your option offer warranty protection in exchange for a fee.
-
-'''2.''' You may modify your copy or copies of the Program or any portion
-of it, thus forming a work based on the Program, and copy and
-distribute such modifications or work under the terms of Section 1
-above, provided that you also meet all of these conditions:
-
- '''a)''' You must cause the modified files to carry prominent notices
- stating that you changed the files and the date of any change.
-
- '''b)''' You must cause any work that you distribute or publish, that in
- whole or in part contains or is derived from the Program or any
- part thereof, to be licensed as a whole at no charge to all third
- parties under the terms of this License.
-
- '''c)''' If the modified program normally reads commands interactively
- when run, you must cause it, when started running for such
- interactive use in the most ordinary way, to print or display an
- announcement including an appropriate copyright notice and a
- notice that there is no warranty (or else, saying that you provide
- a warranty) and that users may redistribute the program under
- these conditions, and telling the user how to view a copy of this
- License. (Exception: if the Program itself is interactive but
- does not normally print such an announcement, your work based on
- the Program is not required to print an announcement.)
-
-These requirements apply to the modified work as a whole. If
-identifiable sections of that work are not derived from the Program,
-and can be reasonably considered independent and separate works in
-themselves, then this License, and its terms, do not apply to those
-sections when you distribute them as separate works. But when you
-distribute the same sections as part of a whole which is a work based
-on the Program, the distribution of the whole must be on the terms of
-this License, whose permissions for other licensees extend to the
-entire whole, and thus to each and every part regardless of who wrote it.
-
-Thus, it is not the intent of this section to claim rights or contest
-your rights to work written entirely by you; rather, the intent is to
-exercise the right to control the distribution of derivative or
-collective works based on the Program.
-
-In addition, mere aggregation of another work not based on the Program
-with the Program (or with a work based on the Program) on a volume of
-a storage or distribution medium does not bring the other work under
-the scope of this License.
-
-'''3.''' You may copy and distribute the Program (or a work based on it,
-under Section 2) in object code or executable form under the terms of
-Sections 1 and 2 above provided that you also do one of the following:
-
- '''a)''' Accompany it with the complete corresponding machine-readable
- source code, which must be distributed under the terms of Sections
- 1 and 2 above on a medium customarily used for software interchange; or,
-
- '''b)''' Accompany it with a written offer, valid for at least three
- years, to give any third party, for a charge no more than your
- cost of physically performing source distribution, a complete
- machine-readable copy of the corresponding source code, to be
- distributed under the terms of Sections 1 and 2 above on a medium
- customarily used for software interchange; or,
-
- '''c)''' Accompany it with the information you received as to the offer
- to distribute corresponding source code. (This alternative is
- allowed only for noncommercial distribution and only if you
- received the program in object code or executable form with such
- an offer, in accord with Subsection b above.)
-
-The source code for a work means the preferred form of the work for
-making modifications to it. For an executable work, complete source
-code means all the source code for all modules it contains, plus any
-associated interface definition files, plus the scripts used to
-control compilation and installation of the executable. However, as a
-special exception, the source code distributed need not include
-anything that is normally distributed (in either source or binary
-form) with the major components (compiler, kernel, and so on) of the
-operating system on which the executable runs, unless that component
-itself accompanies the executable.
-
-If distribution of executable or object code is made by offering
-access to copy from a designated place, then offering equivalent
-access to copy the source code from the same place counts as
-distribution of the source code, even though third parties are not
-compelled to copy the source along with the object code.
-
-'''4.''' You may not copy, modify, sublicense, or distribute the Program
-except as expressly provided under this License. Any attempt
-otherwise to copy, modify, sublicense or distribute the Program is
-void, and will automatically terminate your rights under this License.
-However, parties who have received copies, or rights, from you under
-this License will not have their licenses terminated so long as such
-parties remain in full compliance.
-
-'''5.''' You are not required to accept this License, since you have not
-signed it. However, nothing else grants you permission to modify or
-distribute the Program or its derivative works. These actions are
-prohibited by law if you do not accept this License. Therefore, by
-modifying or distributing the Program (or any work based on the
-Program), you indicate your acceptance of this License to do so, and
-all its terms and conditions for copying, distributing or modifying
-the Program or works based on it.
-
-'''6.''' Each time you redistribute the Program (or any work based on the
-Program), the recipient automatically receives a license from the
-original licensor to copy, distribute or modify the Program subject to
-these terms and conditions. You may not impose any further
-restrictions on the recipients' exercise of the rights granted herein.
-You are not responsible for enforcing compliance by third parties to
-this License.
-
-'''7.''' If, as a consequence of a court judgment or allegation of patent
-infringement or for any other reason (not limited to patent issues),
-conditions are imposed on you (whether by court order, agreement or
-otherwise) that contradict the conditions of this License, they do not
-excuse you from the conditions of this License. If you cannot
-distribute so as to satisfy simultaneously your obligations under this
-License and any other pertinent obligations, then as a consequence you
-may not distribute the Program at all. For example, if a patent
-license would not permit royalty-free redistribution of the Program by
-all those who receive copies directly or indirectly through you, then
-the only way you could satisfy both it and this License would be to
-refrain entirely from distribution of the Program.
-
-If any portion of this section is held invalid or unenforceable under
-any particular circumstance, the balance of the section is intended to
-apply and the section as a whole is intended to apply in other
-circumstances.
-
-It is not the purpose of this section to induce you to infringe any
-patents or other property right claims or to contest validity of any
-such claims; this section has the sole purpose of protecting the
-integrity of the free software distribution system, which is
-implemented by public license practices. Many people have made
-generous contributions to the wide range of software distributed
-through that system in reliance on consistent application of that
-system; it is up to the author/donor to decide if he or she is willing
-to distribute software through any other system and a licensee cannot
-impose that choice.
-
-This section is intended to make thoroughly clear what is believed to
-be a consequence of the rest of this License.
-
-'''8.''' If the distribution and/or use of the Program is restricted in
-certain countries either by patents or by copyrighted interfaces, the
-original copyright holder who places the Program under this License
-may add an explicit geographical distribution limitation excluding
-those countries, so that distribution is permitted only in or among
-countries not thus excluded. In such case, this License incorporates
-the limitation as if written in the body of this License.
-
-'''9.''' The Free Software Foundation may publish revised and/or new versions
-of the General Public License from time to time. Such new versions will
-be similar in spirit to the present version, but may differ in detail to
-address new problems or concerns.
-
-Each version is given a distinguishing version number. If the Program
-specifies a version number of this License which applies to it and "any
-later version", you have the option of following the terms and conditions
-either of that version or of any later version published by the Free
-Software Foundation. If the Program does not specify a version number of
-this License, you may choose any version ever published by the Free Software
-Foundation.
-
-'''10.''' If you wish to incorporate parts of the Program into other free
-programs whose distribution conditions are different, write to the author
-to ask for permission. For software which is copyrighted by the Free
-Software Foundation, write to the Free Software Foundation; we sometimes
-make exceptions for this. Our decision will be guided by the two goals
-of preserving the free status of all derivatives of our free software and
-of promoting the sharing and reuse of software generally.
-
-=== NO WARRANTY ===
-
-'''11.''' BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
-FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
-OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
-PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
-OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
-MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
-TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
-PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
-REPAIR OR CORRECTION.
-
-'''12.''' IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
-WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
-REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
-INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
-OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
-TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
-YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
-PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
-POSSIBILITY OF SUCH DAMAGES.
-
- '''END OF TERMS AND CONDITIONS'''
-
-== How to Apply These Terms to Your New Programs ==
-
-If you develop a new program, and you want it to be of the greatest
-possible use to the public, the best way to achieve this is to make it
-free software which everyone can redistribute and change under these terms.
-
-To do so, attach the following notices to the program. It is safest
-to attach them to the start of each source file to most effectively
-convey the exclusion of warranty; and each file should have at least
-the "copyright" line and a pointer to where the full notice is found.
-
- <one line to give the program's name and a brief idea of what it does.>
-
- Copyright (C) <year> <name of author>
-
- 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
-
-
-Also add information on how to contact you by electronic and paper mail.
-
-If the program is interactive, make it output a short notice like this
-when it starts in an interactive mode:
-
- Gnomovision version 69, Copyright (C) year name of author
- Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
- This is free software, and you are welcome to redistribute it
- under certain conditions; type `show c' for details.
-
-The hypothetical commands `show w' and `show c' should show the appropriate
-parts of the General Public License. Of course, the commands you use may
-be called something other than `show w' and `show c'; they could even be
-mouse-clicks or menu items--whatever suits your program.
-
-You should also get your employer (if you work as a programmer) or your
-school, if any, to sign a "copyright disclaimer" for the program, if
-necessary. Here is a sample; alter the names:
-
- Yoyodyne, Inc., hereby disclaims all copyright interest in the program
- `Gnomovision' (which makes passes at compilers) written by James Hacker.
-
- <signature of Ty Coon>, 1 April 1989
-
- Ty Coon, President of Vice
-
-This General Public License does not permit incorporating your program into
-proprietary programs. If your program is a subroutine library, you may
-consider it more useful to permit linking proprietary applications with the
-library. If this is what you want to do, use the GNU Library General
-Public License instead of this License.
+++ /dev/null
-/* 6.0 - only fixes */
-/* content area */
-/* workaround for various ie float bugs */
-div#column-content {
- float: none;
- margin-left: 0;
- height: 1%;
-}
-
-div#column-content div#content {
- margin-left: 12.2em;
- margin-top: 3em;
- height: 1%;
-}
-
-.rtl div#column-content div#content {
- margin-right: 12.2em;
- margin-left: 0;
-}
-
-div#column-one {
- position: absolute;
- top: 0;
- left: 0;
- z-index: 4;
-}
-
-.rtl div#column-one {
- left: auto;
- right: 0;
-}
-
-div#footer {
- margin-left: 13.6em;
- border-left: 1px solid #fabd23;
-}
-
-.rtl div#footer {
- margin-left: 0;
- margin-right: 13.6em;
- border-left: none;
- border-right: 1px solid #fabd23;
-}
-
-/* float/negative margin brokenness */
-* html div#footer {
- margin-top: 0;
-}
-
-* html div#column-content {
- display: inline;
- margin-bottom: 0;
-}
-
-/* the tabs */
-
-#p-cactions {
- z-index: 3;
-}
-
-#p-cactions li {
- padding-bottom: 0 !important;
- border: none;
- background-color: transparent;
- cursor: default;
- float: none !important;
-}
-
-#p-cactions li a {
- display: inline-block !important;
- vertical-align: top;
- padding-bottom: 0;
- border: solid #aaa;
- border-width: 1px 1px 0;
-}
-
-#p-cactions li.selected a {
- border-color: #fabd23;
- padding-bottom: 0.17em;
-}
-
-#p-cactions li a:hover {
- padding-bottom: 0.17em;
-}
-
-#p-navigation a {
- display: inline-block;
- width: 100%;
-}
-
-#portal-personaltools {
- padding-bottom: 0.1em;
-}
-
-.rtl a.feedlink {
- background-position: right;
- padding-right: 0;
- padding-left: 16px;
-}
-
-/* show the hand */
-#p-logo a,
-#p-logo a:hover {
- cursor: pointer;
-}
-
-div.visualClear {
- width: 100%;
- line-height: 0;
-}
-
-textarea {
- width: 96%;
-}
-
-#catlinks,
-div.tright,
-div.tleft {
- position: relative;
-}
-
-/* bug 12846 */
-body.rtl #preftoc a, body.rtl #preftoc a:active {
- float: left;
-}
+++ /dev/null
-/* 7.0 - only fixes */
-/* content area */
-/* workaround for various ie float bugs */
-
-/* This bit is needed to make links clickable... WTF */
-div#column-content div#content {
- margin-left: 12.2em;
- margin-top: 3em;
- height: 1%;
-}
-
-.rtl div#column-content div#content {
- margin-right: 12.2em;
- margin-left: 0;
-}
-
-.rtl div#column-one {
- /* For some reason it tries to inherit the padding-top into every div,
- * and I can't figure out how to get it back off.
- * Margin works correctly for this use, though.
- */
- padding-top: 0;
- margin-top: 160px;
-}
-
-/* These elements also have padding-left: 20px; in main.css, but in RTL mode this is flipped.
- * That's good in normal browsers, but in IE7 it needs to not be flipped for some daft reason.
- * Also clear the right margin (originally margin-left: 1em)
- */
-li#pt-userpage, li#pt-anonuserpage, li#pt-login {
- padding-left: 20px;
- margin-right: 0;
-}
-
-.rtl a.feedlink {
- background-position: right;
- padding-right: 0;
- padding-left: 16px;
-}
-
-/* the tabs */
-
-#p-cactions {
- z-index: 3;
-}
-
-#p-cactions li {
- padding-bottom: 0 !important;
- border: none;
- background-color: transparent;
- cursor: default;
- float: none !important;
-}
-
-#p-cactions li a {
- display: inline-block !important;
- vertical-align: top;
- padding-bottom: 0;
- border: solid #aaa;
- border-width: 1px 1px 0;
-}
-
-#p-cactions li.selected a {
- border-color: #fabd23;
- padding-bottom: 0.17em;
-}
-
-#p-cactions li a:hover {
- padding-bottom: 0.17em;
-}
-
-#p-navigation a {
- display: inline-block;
- width: 100%;
-}
-
-#portal-personaltools {
- padding-bottom: 0.1em;
-}
-
-textarea {
- width: 96%;
-}
-
-/*
-#catlinks,
-div.tright,
-div.tleft {
- position: relative;
-}
-*/
-
-div#footer li {
- /* Work around bug with inline <li> tags with right margins and nowrap */
- margin-right: 0;
-}
+++ /dev/null
-<?php
-/**
- * MonoBook nouveau.
- *
- * Translated from gwicke's previous TAL template version to remove
- * dependency on PHPTAL.
- *
- * 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
- * @ingroup Skins
- */
-
-$wgExtensionCredits['skin'][] = array(
- 'path' => __FILE__,
- 'name' => 'MonoBook',
- 'namemsg' => 'skinname-monobook',
- 'descriptionmsg' => 'monobook-desc',
- 'url' => 'https://www.mediawiki.org/wiki/Skin:MonoBook',
- 'author' => array( 'Gabriel Wicke', '...' ),
- 'license-name' => 'GPLv2+',
-);
-
-// Register files
-$wgAutoloadClasses['SkinMonoBook'] = __DIR__ . '/SkinMonoBook.php';
-$wgAutoloadClasses['MonoBookTemplate'] = __DIR__ . '/MonoBookTemplate.php';
-$wgMessagesDirs['MonoBook'] = __DIR__ . '/i18n';
-
-// Register skin
-$wgValidSkinNames['monobook'] = 'MonoBook';
-
-// Register modules
-$wgResourceModules['skins.monobook.styles'] = array(
- 'styles' => array(
- 'main.css' => array( 'media' => 'screen' ),
- ),
- 'remoteSkinPath' => 'MonoBook',
- 'localBasePath' => __DIR__,
-);
+++ /dev/null
-<?php
-/**
- * MonoBook nouveau.
- *
- * Translated from gwicke's previous TAL template version to remove
- * dependency on PHPTAL.
- *
- * 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
- * @ingroup Skins
- */
-
-/**
- * @ingroup Skins
- */
-class MonoBookTemplate extends BaseTemplate {
-
- /**
- * Template filter callback for MonoBook skin.
- * Takes an associative array of data set from a SkinTemplate-based
- * class, and a wrapper for MediaWiki's localization database, and
- * outputs a formatted page.
- *
- * @access private
- */
- function execute() {
- // Suppress warnings to prevent notices about missing indexes in $this->data
- wfSuppressWarnings();
-
- $this->html( 'headelement' );
- ?><div id="globalWrapper">
- <div id="column-content">
- <div id="content" class="mw-body-primary" role="main">
- <a id="top"></a>
- <?php
- if ( $this->data['sitenotice'] ) {
- ?>
- <div id="siteNotice"><?php
- $this->html( 'sitenotice' )
- ?></div><?php
- }
- ?>
-
- <h1 id="firstHeading" class="firstHeading" lang="<?php
- $this->data['pageLanguage'] =
- $this->getSkin()->getTitle()->getPageViewLanguage()->getHtmlCode();
- $this->text( 'pageLanguage' );
- ?>"><span dir="auto"><?php $this->html( 'title' ) ?></span></h1>
-
- <div id="bodyContent" class="mw-body">
- <div id="siteSub"><?php $this->msg( 'tagline' ) ?></div>
- <div id="contentSub"<?php
- $this->html( 'userlangattributes' ) ?>><?php $this->html( 'subtitle' )
- ?></div>
- <?php if ( $this->data['undelete'] ) { ?>
- <div id="contentSub2"><?php $this->html( 'undelete' ) ?></div>
- <?php
-}
- ?><?php
- if ( $this->data['newtalk'] ) {
- ?>
- <div class="usermessage"><?php $this->html( 'newtalk' ) ?></div>
- <?php
- }
- ?>
- <div id="jump-to-nav" class="mw-jump"><?php
- $this->msg( 'jumpto' )
- ?> <a href="#column-one"><?php
- $this->msg( 'jumptonavigation' )
- ?></a><?php
- $this->msg( 'comma-separator' )
- ?><a href="#searchInput"><?php
- $this->msg( 'jumptosearch' )
- ?></a></div>
-
- <!-- start content -->
- <?php $this->html( 'bodytext' ) ?>
- <?php
- if ( $this->data['catlinks'] ) {
- $this->html( 'catlinks' );
- }
- ?>
- <!-- end content -->
- <?php
- if ( $this->data['dataAfterContent'] ) {
- $this->html( 'dataAfterContent'
- );
- }
- ?>
- <div class="visualClear"></div>
- </div>
- </div>
- </div>
- <div id="column-one"<?php $this->html( 'userlangattributes' ) ?>>
- <h2><?php $this->msg( 'navigation-heading' ) ?></h2>
- <?php $this->cactions(); ?>
- <div class="portlet" id="p-personal" role="navigation">
- <h3><?php $this->msg( 'personaltools' ) ?></h3>
-
- <div class="pBody">
- <ul<?php $this->html( 'userlangattributes' ) ?>>
- <?php foreach ( $this->getPersonalTools() as $key => $item ) { ?>
- <?php echo $this->makeListItem( $key, $item ); ?>
-
- <?php
-}
- ?>
- </ul>
- </div>
- </div>
- <div class="portlet" id="p-logo" role="banner">
- <?php
- echo Html::element( 'a', array(
- 'href' => $this->data['nav_urls']['mainpage']['href'],
- 'style' => "background-image: url({$this->data['logopath']});" )
- + Linker::tooltipAndAccesskeyAttribs( 'p-logo' ) ); ?>
-
- </div>
- <?php
- $this->renderPortals( $this->data['sidebar'] );
- ?>
- </div><!-- end of the left (by default at least) column -->
- <div class="visualClear"></div>
- <?php
- $validFooterIcons = $this->getFooterIcons( "icononly" );
- $validFooterLinks = $this->getFooterLinks( "flat" ); // Additional footer links
-
- if ( count( $validFooterIcons ) + count( $validFooterLinks ) > 0 ) {
- ?>
- <div id="footer" role="contentinfo"<?php $this->html( 'userlangattributes' ) ?>>
- <?php
- $footerEnd = '</div>';
- } else {
- $footerEnd = '';
- }
-
- foreach ( $validFooterIcons as $blockName => $footerIcons ) {
- ?>
- <div id="f-<?php echo htmlspecialchars( $blockName ); ?>ico">
- <?php foreach ( $footerIcons as $icon ) { ?>
- <?php echo $this->getSkin()->makeFooterIcon( $icon ); ?>
-
- <?php
-}
- ?>
- </div>
- <?php
- }
-
- if ( count( $validFooterLinks ) > 0 ) {
- ?>
- <ul id="f-list">
- <?php
- foreach ( $validFooterLinks as $aLink ) {
- ?>
- <li id="<?php echo $aLink ?>"><?php $this->html( $aLink ) ?></li>
- <?php
- }
- ?>
- </ul>
- <?php
- }
-
- echo $footerEnd;
- ?>
-
- </div>
- <?php
- $this->printTrail();
- echo Html::closeElement( 'body' );
- echo Html::closeElement( 'html' );
- wfRestoreWarnings();
- } // end of execute() method
-
- /*************************************************************************************************/
-
- /**
- * @param array $sidebar
- */
- protected function renderPortals( $sidebar ) {
- if ( !isset( $sidebar['SEARCH'] ) ) {
- $sidebar['SEARCH'] = true;
- }
- if ( !isset( $sidebar['TOOLBOX'] ) ) {
- $sidebar['TOOLBOX'] = true;
- }
- if ( !isset( $sidebar['LANGUAGES'] ) ) {
- $sidebar['LANGUAGES'] = true;
- }
-
- foreach ( $sidebar as $boxName => $content ) {
- if ( $content === false ) {
- continue;
- }
-
- if ( $boxName == 'SEARCH' ) {
- $this->searchBox();
- } elseif ( $boxName == 'TOOLBOX' ) {
- $this->toolbox();
- } elseif ( $boxName == 'LANGUAGES' ) {
- $this->languageBox();
- } else {
- $this->customBox( $boxName, $content );
- }
- }
- }
-
- function searchBox() {
- global $wgUseTwoButtonsSearchForm;
- ?>
- <div id="p-search" class="portlet" role="search">
- <h3><label for="searchInput"><?php $this->msg( 'search' ) ?></label></h3>
-
- <div id="searchBody" class="pBody">
- <form action="<?php $this->text( 'wgScript' ) ?>" id="searchform">
- <input type='hidden' name="title" value="<?php $this->text( 'searchtitle' ) ?>"/>
- <?php echo $this->makeSearchInput( array( "id" => "searchInput" ) ); ?>
-
- <?php
- echo $this->makeSearchButton(
- "go",
- array( "id" => "searchGoButton", "class" => "searchButton" )
- );
-
- if ( $wgUseTwoButtonsSearchForm ) {
- ?> 
- <?php echo $this->makeSearchButton(
- "fulltext",
- array( "id" => "mw-searchButton", "class" => "searchButton" )
- );
- } else {
- ?>
-
- <div><a href="<?php
- $this->text( 'searchaction' )
- ?>" rel="search"><?php $this->msg( 'powersearch-legend' ) ?></a></div><?php
- } ?>
-
- </form>
-
- <?php $this->renderAfterPortlet( 'search' ); ?>
- </div>
- </div>
- <?php
- }
-
- /**
- * Prints the cactions bar.
- * Shared between MonoBook and Modern
- */
- function cactions() {
- ?>
- <div id="p-cactions" class="portlet" role="navigation">
- <h3><?php $this->msg( 'views' ) ?></h3>
-
- <div class="pBody">
- <ul><?php
- foreach ( $this->data['content_actions'] as $key => $tab ) {
- echo '
- ' . $this->makeListItem( $key, $tab );
- } ?>
-
- </ul>
- <?php $this->renderAfterPortlet( 'cactions' ); ?>
- </div>
- </div>
- <?php
- }
-
- /*************************************************************************************************/
- function toolbox() {
- ?>
- <div class="portlet" id="p-tb" role="navigation">
- <h3><?php $this->msg( 'toolbox' ) ?></h3>
-
- <div class="pBody">
- <ul>
- <?php
- foreach ( $this->getToolbox() as $key => $tbitem ) {
- ?>
- <?php echo $this->makeListItem( $key, $tbitem ); ?>
-
- <?php
- }
- wfRunHooks( 'MonoBookTemplateToolboxEnd', array( &$this ) );
- wfRunHooks( 'SkinTemplateToolboxEnd', array( &$this, true ) );
- ?>
- </ul>
- <?php $this->renderAfterPortlet( 'tb' ); ?>
- </div>
- </div>
- <?php
- }
-
- /*************************************************************************************************/
- function languageBox() {
- if ( $this->data['language_urls'] !== false ) {
- ?>
- <div id="p-lang" class="portlet" role="navigation">
- <h3<?php $this->html( 'userlangattributes' ) ?>><?php $this->msg( 'otherlanguages' ) ?></h3>
-
- <div class="pBody">
- <ul>
- <?php foreach ( $this->data['language_urls'] as $key => $langlink ) { ?>
- <?php echo $this->makeListItem( $key, $langlink ); ?>
-
- <?php
-}
- ?>
- </ul>
-
- <?php $this->renderAfterPortlet( 'lang' ); ?>
- </div>
- </div>
- <?php
- }
- }
-
- /*************************************************************************************************/
- /**
- * @param string $bar
- * @param array|string $cont
- */
- function customBox( $bar, $cont ) {
- $portletAttribs = array(
- 'class' => 'generated-sidebar portlet',
- 'id' => Sanitizer::escapeId( "p-$bar" ),
- 'role' => 'navigation'
- );
-
- $tooltip = Linker::titleAttrib( "p-$bar" );
- if ( $tooltip !== false ) {
- $portletAttribs['title'] = $tooltip;
- }
- echo ' ' . Html::openElement( 'div', $portletAttribs );
- $msgObj = wfMessage( $bar );
- ?>
-
- <h3><?php echo htmlspecialchars( $msgObj->exists() ? $msgObj->text() : $bar ); ?></h3>
- <div class='pBody'>
- <?php
- if ( is_array( $cont ) ) {
- ?>
- <ul>
- <?php
- foreach ( $cont as $key => $val ) {
- ?>
- <?php echo $this->makeListItem( $key, $val ); ?>
-
- <?php
- }
- ?>
- </ul>
- <?php
- } else {
- # allow raw HTML block to be defined by extensions
- print $cont;
- }
-
- $this->renderAfterPortlet( $bar );
- ?>
- </div>
- </div>
- <?php
- }
-} // end of class
+++ /dev/null
-<?php
-/**
- * MonoBook nouveau.
- *
- * Translated from gwicke's previous TAL template version to remove
- * dependency on PHPTAL.
- *
- * 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
- * @ingroup Skins
- */
-
-/**
- * Inherit main code from SkinTemplate, set the CSS and template filter.
- * @ingroup Skins
- */
-class SkinMonoBook extends SkinTemplate {
- /** Using MonoBook. */
- public $skinname = 'monobook';
- public $stylename = 'MonoBook';
- public $template = 'MonoBookTemplate';
-
- /**
- * @param OutputPage $out
- */
- function setupSkinUserCss( OutputPage $out ) {
- parent::setupSkinUserCss( $out );
-
- $out->addModuleStyles( array( 'mediawiki.skinning.interface', 'skins.monobook.styles' ) );
-
- // TODO: Migrate all of these
- $out->addStyle( $this->stylename . '/IE60Fixes.css', 'screen', 'IE 6' );
- $out->addStyle( $this->stylename . '/IE70Fixes.css', 'screen', 'IE 7' );
- }
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Bresta"
- ]
- },
- "monobook.css": "/* CSS i vednosun këtu ka me i prekë shfrytëzuesit e dukjes Monobook */",
- "monobook.js": "/* Çdo JavaScript këtu ka me u ngarkue për shfrytëzuesit që përdorin dukjen MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Juanpabl"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* Os estilos CSS colocaus aquí s'aplicarán ta totz os usuarios que faigan servir l'apariencia Monobook */",
- "monobook.js": "/* O codigo Javascript que se meta aquí será cargau por os usuarios faigan servir l'apariencia MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Meno25"
- ]
- },
- "skinname-monobook": "مونوبوك",
- "monobook.css": "/* الأنماط المتراصة CSS المعروضة هنا ستؤثر على مستخدمي واجهة مونوبوك */",
- "monobook.js": "/* أي جافاسكريبت هنا سيتم تحميلها للمستخدمين الذين يستعملون واجهة مونوبوك */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Meno25"
- ]
- },
- "skinname-monobook": "مونوبوك",
- "monobook.css": "/* الأنماط المتراصة CSS المعروضة هنا ستؤثر على مستخدمى واجهة مونوبوك */",
- "monobook.js": "/* أى جافاسكريبت هنا ح تتحمل لليوزرز اللى بيستعملو واجهة مونوبوك */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Xuacu"
- ]
- },
- "monobook-desc": "El tema clásicu de MediaWiki dende 2004, llamáu asina pola foto en blanco y negro d'un llibru nel fondu de la páxina",
- "monobook.css": "/* Los CSS allugaos equí afeutarán a los usuarios del aspeutu Monobook */",
- "monobook.js": "/* Cualesquier JavaScript que tea equí se cargará pa los usuarios del aspeutu MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Vago",
- "Vugar 1981"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* Burada yerləşən CSS Monobook skin istifadəçilərinə tətbiq olunur */",
- "monobook.js": "/* Burada MonoBook skin istifadəçiləri üçün istənilən JavaScript yüklənəcək */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Mostafadaneshvar"
- ]
- },
- "skinname-monobook": "منوبوک",
- "monobook.css": "/* CSS که اداننت کابران پوست مونوبوک تاثیر کننت */",
- "monobook.js": "/* جاوا اسکریپت ادان فقط په کابرانی که چه پوست منوبوک استفاده کننت بار بیت. */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Filipinayzd"
- ]
- },
- "monobook.css": "/* an CSS na pigbugtak digdi makakaapektar sa mga parágamit kan Monobook skin */",
- "monobook.js": "/* Deprecado; gamiton an [[MediaWiki:common.js]] */"
-}
+++ /dev/null
-{
- "skinname-monobook": "Монакніга"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Yury Tarasievich",
- "Mikalai Udodau"
- ]
- },
- "skinname-monobook": "Манабук",
- "monobook-desc": "Класічная вокладка MediaWiki з 2004 года, названая ў гонар чорна-белай фатаграфіі кнігі ў фоне старонкі",
- "monobook.css": "/* CSS, упісаны сюды, будзе дзейнічаць на браўзер кожнага чытача з актыўнай світай Monobook */",
- "monobook.js": "/* Any JavaScript here will be loaded for users using the MonoBook skin */"
-}
+++ /dev/null
-{
- "skinname-monobook": "Монобук",
- "monobook.css": "/* Чрез редактиране на този файл можете да промените облика Монобук */",
- "monobook.js": "/* Остаряла страница; използвайте [[MediaWiki:Common.js]] */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Aftab1995"
- ]
- },
- "skinname-monobook": "মনোবুক"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Fulup"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* Talvezout a raio ar CSS lakaet amañ evit implijerien ar gwiskadur Monobook */",
- "monobook.js": "/* Kement JavaScript amañ a vo karget evit an implijerien a ra gant ar gwiskadur MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "CERminator",
- "Kal-El"
- ]
- },
- "skinname-monobook": "MonoKnjiga",
- "monobook.css": "/* CSS umetnut ovdje uticat će na korisnike koji koriste Monobook skin */",
- "monobook.js": "/* Bilo koja JavaScript će biti učitana za sve korisnike koji koriste MonoBook skin */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Martorell",
- "Toniher"
- ]
- },
- "monobook-desc": "El tema clàssic de MediaWiki des del 2004, que rep el nom d'una foto en blanc i negre d'un llibre en el fons de la pàgina.",
- "monobook.css": "/* Editeu aquest fitxer per personalitzar l'aparença del monobook per a tot el lloc sencer */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Умар"
- ]
- },
- "monobook.css": "/* Чуйиллина йолу кхузе CSS хир ю лелош масхьа Monobook чохь */",
- "monobook.js": "/* Кхузе чу язийна йолу JavaScript код, чу ера ю, массо MonoBook хатl лелош болу декъашхошна */"
-}
+++ /dev/null
-{
- "skinname-monobook": "مۆنۆ"
-}
+++ /dev/null
-{
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* monobook темасынынъ аярларыны (настройкаларыны) денъиштирмек ичюн бу ерини денъиштиринъиз. Бутюн сайтта тесирли олур. */"
-}
+++ /dev/null
-{
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* monobook temasınıñ ayarlarını (nastroykalarını) deñiştirmek içün bu yerini deñiştiriñiz. Bütün saytta tesirli olur. */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Danny B.",
- "Li-sung",
- "Mormegil"
- ]
- },
- "monobook-desc": "Klasický vzhled MediaWiki od roku 2004, pojmenovaný po černobílé fotografii knihy v pozadí stránky",
- "monobook.css": "/* Zde uvedené CSS bude ovlivňovat pouze styl „Monobook“ */",
- "monobook.js": "/* JavaScript pro uživatele používající vzhled MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Peter Alberti",
- "Christian List"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook-desc": "Den klassiske MediaWiki hud siden 2004, opkaldt efter det sort-hvide foto af en bog i baggrunden af siderne",
- "monobook.css": "/** CSS inkluderet her vil være aktivt for brugere af Monobook-temaet . */",
- "monobook.js": "/* JavaScript i denne fil vil indlæses for brugere af udseendet MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Geitost",
- "Metalhead64"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook-desc": "Ergänzt die klassische MediaWiki-Benutzeroberfläche seit 2004, benannt nach dem Schwarzweißfoto eines Buches im Seitenhintergrund",
- "monobook.css": "/* Das folgende CSS wird für Benutzer der MonoBook-Benutzeroberfläche geladen */",
- "monobook.js": "/* Das folgende JavaScript wird für Benutzer der Monobook-Benutzeroberfläche geladen. */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Erdemaslancan"
- ]
- },
- "skinname-monobook": "MonoBook"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Michawiki",
- "Nepl1"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* How zaměstnjony CSS wustatkujo se na wužywarje monobook-šata */",
- "monobook.js": "/* Slědujucy JavaScript zacytajo se za wužywarjow, kótarež skin MonoBook wužywaju */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Dead3y3"
- ]
- },
- "monobook.css": "/* Το τοποθετημένο εδώ CSS θα επηρεάσει χρήστες του Monobook skin */",
- "monobook.js": "/* Οποιοσδήποτε κώδικας JavaScript εδώ θα φορτωθεί για χρήστες που χρησιμοποιούν το MonoBook skin */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": []
- },
- "skinname-monobook": "MonoBook",
- "monobook-desc": "The classic MediaWiki skin since 2004, named after the black-and-white photo of a book in the page background",
- "monobook.css": "/* CSS placed here will affect users of the MonoBook skin */",
- "monobook.js": "/* Any JavaScript here will be loaded for users using the MonoBook skin */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Objectivesea"
- ]
- },
- "skinname-monobook": "Librejo",
- "monobook.css": "/* La jena CSS influos la paĝaspekton por uzantoj de la Libreja temo. */",
- "monobook.js": "/* La jena Ĝavaskripto ŝargiĝos por uzantoj de la Libreja temo. */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Sanbec",
- "Vivaelcelta",
- "Fitoschido"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook-desc": "El tema clásico de MediaWiki desde 2004, cuyo nombre viene de la foto en blanco y negro de un libro en el fondo",
- "monobook.css": "/* El CSS colocado en esta página afectará a los usuarios que usen la apariencia \"MonoBook\" */",
- "monobook.js": "/* El código JavaScript que se ponga aquí será cargado por los usuarios de la apariencia MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Pikne"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* Siin asuv kaskaadilaadistik puudutab kõiki MonoBooki-kujunduse kasutajaid. */",
- "monobook.js": "/* Siin asuv JavaScript laaditakse MonoBooki-kujunduse kasutajate jaoks. */"
-}
+++ /dev/null
-{
- "monobook.css": "/* Hemen idatzitako CSS kodeak Monobook itxuran bakarrik izango du eragina */"
-}
+++ /dev/null
-{
- "monobook.js": "/* Antigu; gasta [[MediaWiki:common.js]] */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Reza1615"
- ]
- },
- "skinname-monobook": "مونوبوک",
- "monobook-desc": "پوسته کلاسیک مدیاویکی از سال ۲۰۰۴ از عکس سیاه و سفید در زمینه صفحه کتاب نام گرفت",
- "monobook.css": "/* دستورات این بخش کاربرانی را که از پوستهٔ مونوبوک استفاده کنند تحت تاثیر قرار میدهند. */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Crt"
- ]
- },
- "skinname-monobook": "Monobook",
- "monobook.css": "/* Tämä sivu sisältää Monobook-ulkoasua muuttavia tyylejä. */",
- "monobook.js": "/* Tämän sivun JavaScript-koodi liitetään Monobook-tyyliin */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Gomoko",
- "Verdy p"
- ]
- },
- "skinname-monobook": "Monobook",
- "monobook-desc": "L’habillage classique de MédiaWiki depuis 2004, nommé d’après la photo en noir et blanc d’un livre dans l’arrière-plan de la page",
- "monobook.css": "/* Le CSS placé ici affectera les utilisateurs de l’habillage Monobook. */",
- "monobook.js": "/* Tout JavaScript ici sera chargé avec les pages accédées par les utilisateurs de l’habillage MonoBook uniquement. */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "ChrisPtDe"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* Lo code CSS betâ ique afècterat los usanciérs de l’habelyâjo « MonoBook ». */",
- "monobook.js": "/* Tot code JavaScript betâ ique serat chargiê per los usanciérs de l’habelyâjo « MonoBook ». */"
-}
+++ /dev/null
-{
- "monobook.css": "/* modifiche chest file par personalizâ la skin monobook par dut il sît */"
-}
+++ /dev/null
-{
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* athraigh an comhad seo chun an craiceann MonoBook a athrú don suíomh ar fad */"
-}
+++ /dev/null
-{
- "monobook.css": "/* 个首𠮶 CSS 会碍到正用Monobook皮肤𠮶用户 */",
- "monobook.js": "/* 伓再使用;请用[[MediaWiki:common.js]] */"
-}
+++ /dev/null
-{
- "monobook.css": "/* 箇首嗰 CSS 會礙到正用Monobook皮膚嗰用戶 */",
- "monobook.js": "/* 伓再使用;請用[[MediaWiki:common.js]] */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "GunChleoc"
- ]
- },
- "monobook-desc": "Craiceann MediaWiki clasaigeach o 2004 a chaidh ainmeachadh a-rèir dealbh de leabhar ann an dubh 's geal air cùlaibh nan duilleagan"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Toliño",
- "Xosé"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook-desc": "A aparencia clásica de MediaWiki desde 2004; recibe o seu nome pola foto en branco e negro dun libro que aparece no fondo das páxinas",
- "monobook.css": "/* O CSS que se coloque aquí afectará a quen use a aparencia Monobook */",
- "monobook.js": "/* Calquera JavaScript que haxa aquí será cargado para os usuarios que usen a aparencia MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Hakka"
- ]
- },
- "monobook.css": "/* Chhṳ́-chhu ke CSS chiông-voi yáng-hióng sṳ́-yung Monobook mien-pán ke yung-fu */",
- "monobook.js": "/* Yí-kîn put-chai sṳ́-yung; chhiáng-yung [[MediaWiki:common.js]] */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Rotemliss",
- "Amire80"
- ]
- },
- "skinname-monobook": "מונובוק",
- "monobook-desc": "העיצוב הקלאסי של מדיה־ויקי מ־2004, שנקרא על שם הצילום השחור־לבן של ספר ברקע",
- "monobook.css": "/* הסגנונות הנכתבים כאן ישפיעו על העיצוב MonoBook בלבד */",
- "monobook.js": "/* כל סקריפט JavaScript שנכתב כאן ירוץ רק עבור המשתמשים בעיצוב Monobook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Kaustubh",
- "Siddhartha Ghai"
- ]
- },
- "monobook-desc": "2004 से मीडियाविकि की क्लासिक त्वचा, जिसका नाम पृष्ठभूमि में पुस्तक के इकरंगा चित्र से पड़ा।",
- "monobook.css": "/* यहां रखी गई css मोनोबुक त्वचा का इस्तेमाल करने वाले सभी सदस्योंपर असर करेगी */",
- "monobook.js": "/* यहाँ पर दी गई जावास्क्रिप्ट मोनोबुक त्वचा का प्रयोग कर रहे सदस्यों के लिए लोड होगी */"
-}
+++ /dev/null
-{
- "skinname-monobook": "MonoBook",
- "monobook.css": "/** Ovdje idu izmjene monobook stylesheeta */",
- "monobook.js": "/* Ne rabi se više; molimo rabite [[MediaWiki:common.js]] */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Michawiki"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* CSS wobdźěłać, zo by so skin „monobook” za wšěčh wužiwarjow tutoho skina priměrił */",
- "monobook.js": "/* Slědowacy JavaScript začita so za wužiwarjow, kotřiž šat MonoBook wužiwaja */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Dani"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* Az ide elhelyezett CSS hatással lesz a Monobook felület használóira */",
- "monobook.js": "/* A Monobook felületet használó szerkesztők számára betöltendő JavaScriptek */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Teak"
- ]
- },
- "skinname-monobook": "ՄիաԳիրք",
- "monobook.css": "/* Այստեղ տեղադրված CSS կոդը կկիրառվի Monobook տեսքի վրա*/",
- "monobook.js": "/* Հնացած է. օգտագործեք [[MediaWiki:common.js]] */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "McDutchie"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook-desc": "Le apparentia classic de MediaWiki depost 2004, nominate assi pro le imagine in nigro e blanco (\"mono\") de un libro (\"book\") in le fundo del pagina.",
- "monobook.css": "/* Le CSS placiate hic afficera le usatores del apparentia MonoBook */",
- "monobook.js": "/* Omne JavaScript hic se executara pro le usatores del apparentia MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Iwan Novirion",
- "Rex",
- "Arifin.wijaya"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook-desc": "Kulit MediaWiki klasik sejak tahun 2004, dinamai foto hitam-putih dari buku di latar belakang halaman",
- "monobook.css": "/* CSS yang ada di sini akan diterapkan pada kulit Monobook. */",
- "monobook.js": "/* Semua JavaScript di sini akan dimuatkan untuk para pengguna yang menggunakan kulit MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Lam-ang"
- ]
- },
- "monobook-desc": "Ti klasiko a kudil ti MediaWiki manipud idi 2004, nanaganan manipud ti nangisit-ken-puraw a retrato ti libro iti likudan ti panid"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "לערי ריינהארט"
- ]
- },
- "skinname-monobook": "EinBók",
- "monobook.css": "/* Það sem sett er hingað er bætt við Monobook stilsniðið fyrir allan vefinn */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Beta16",
- "Darth Kule"
- ]
- },
- "monobook-desc": "La skin classica di MediaWiki dal 2004, prende il nome dall'immagine in bianco e nero del libro usata come sfondo della pagina",
- "monobook.css": "/* Gli stili CSS inseriti qui si applicano agli utenti che usano la skin Monobook */",
- "monobook.js": "/* Il codice JavaScript inserito qui viene caricato dagli utenti che usano la skin MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Fryed-peach",
- "青子守歌"
- ]
- },
- "skinname-monobook": "モノブック",
- "monobook.css": "/* ここに記述したCSSはモノブック外装の利用者に影響します */",
- "monobook.js": "/* ここにあるすべてのJavaScriptは、モノブック外装を使用している利用者に対して読み込まれます */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Alsandro",
- "David1010"
- ]
- },
- "skinname-monobook": "მონობუკი",
- "monobook.css": "/* აქ ჩასმული CSS გავლენას იქონიებს Monobook ინტერფეისის მომხმარებლებზე */"
-}
+++ /dev/null
-{
- "skinname-monobook": "دارا كىتاپ (monobook)",
- "monobook.css": "/* مىندا ورنالاستىرىلعان CSS تەك «دارا كىتاپ» (monobook) مانەرىن پايدالانۋشىلارىنا ىقپال ەتەدى */",
- "monobook.js": "/* مىنداعى JavaScript تەك «دارا كىتاپ» (monobook) مانەرىن پايدالانۋشىلار ٴۇشىن جەگىلەدى */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Arystanbek"
- ]
- },
- "skinname-monobook": "Жеке кітап (monobook)",
- "monobook.css": "/* Мында орналастырылған CSS тек «Дара кітап» (monobook) мәнерін пайдаланушыларына ықпал етеді */",
- "monobook.js": "/* Мындағы JavaScript тек «Дара кітап» (monobook) мәнерін пайдаланушылар үшін жегіледі */"
-}
+++ /dev/null
-{
- "skinname-monobook": "Dara kitap (monobook)",
- "monobook.css": "/* Mında ornalastırılğan CSS tek «Dara kitap» (monobook) mänerin paýdalanwşılarına ıqpal etedi */",
- "monobook.js": "/* Mındağı JavaScript tek «Dara kitap» (monobook) mänerin paýdalanwşılar üşin jegiledi */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "វ័ណថារិទ្ធ"
- ]
- },
- "skinname-monobook": "សៀវភៅឯក",
- "monobook.css": "/* CSS បានដាក់ទីនេះនឹងមានអនុភាពលើអ្នកប្រើប្រាស់នៃសំបក Monobook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "아라"
- ]
- },
- "skinname-monobook": "모노북",
- "monobook-desc": "문서 배경에서 책의 흑백 사진을 이른, 2004년 이후의 고전 미디어위키 스킨",
- "monobook.css": "/* 이 CSS 설정은 모노북 스킨을 사용하는 사용자에게 적용됩니다 */",
- "monobook.js": "/* 이 자바스크립트 설정은 모노북 스킨을 사용하는 사용자에게 적용됩니다 */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Къарачайлы"
- ]
- },
- "skinname-monobook": "Моно-китаб"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Purodha"
- ]
- },
- "skinname-monobook": "MonoBoch",
- "monobook.css": "/* CSS heh aan dä Stell wirrek nur op de Ovverflääsch „Monobooch“ */",
- "monobook.js": "/* De JavaSkrippte fun hee krijje alle Sigge met de Ovverflääsch \"Monnobooch\" jescheck */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Krinkle"
- ]
- },
- "monobook.css": "/* CSS placed here will affect users of the Monobook skin */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Robby"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook-desc": "De klassesche Look vu MediaWiki zanter 2004, benannt no der Schwaarzwäissfoto vun engem Buch am Hannergrond vun der Säit",
- "monobook.css": "/* Dës CSS huet nëmmen Afloss op de Skin ''Monobook'' */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Garas"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* Čia įdėtas CSS bus rodomas Monobook išvaizdos naudotojams */",
- "monobook.js": "/* Šis JavaScript bus įkeltas tik „MonoBook“ išvaizdos naudotojams. */"
-}
+++ /dev/null
-{
- "skinname-monobook": "單書",
- "monobook.css": "/* 此之 CSS 用於單書面之簿也 */",
- "monobook.js": "/* 此之JavaScript將載於用單書面之簿 */"
-}
+++ /dev/null
-{
- "monobook.css": "/* Ovay ity rakitra ity raha hampiasa takilan'angaly (stylesheet) anao manokana amin'ny wiki iray manontolo */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Iwan Novirion"
- ]
- },
- "skinname-monobook": "MonoBook"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Bjankuloski06"
- ]
- },
- "skinname-monobook": "Монобук",
- "monobook-desc": "Класичното руво на МедијаВики од 2004 г., наречена по црнобелата слика на книга во позадината",
- "monobook.css": "/* Тука поставениот CSS ќе се применува врз корисниците на рувото „Монобук“ */",
- "monobook.js": "/* Тука поставениот JavaScript ќе им се вчитува на корисниците што го користат рувото „Монобук“ */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Praveenp"
- ]
- },
- "skinname-monobook": "മോണോബുക്ക്",
- "monobook.css": "/* ഇവിടെ നൽകുന്ന സി.എസ്.എസ്. മോണോബുക്ക് ദൃശ്യരൂപം ഉപയോഗിക്കുന്നവർക്ക് ബാധകമായിരിക്കും */",
- "monobook.js": "/* ഇവിടെ നൽകുന്ന ജാവാസ്ക്രിപ്റ്റ് മോണോബുക്ക് ദൃശ്യരൂപം ഉപയോഗിക്കുന്നവർക്ക് ബാധകമായിരിക്കും */"
-}
+++ /dev/null
-{
- "skinname-monobook": "मोनोबुक"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Anakmalaysia",
- "Pizza1016"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook-desc": "Kulit MediaWiki yang klasik sejak tahun 2004, dinamakan selepas foto hitam-dan-putih sebuah buku dalam belakang laman.",
- "monobook.css": "/* CSS yang terletak di sini akan mempengaruhi pengguna kulit Monobook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Giangian15"
- ]
- },
- "skinname-monobook": "Monobook",
- "monobook.css": "/* CSS li tpoġġa hawnhekk se jaffetwa dawk l-utenti li jagħmlu użu mill-iskin ''Monobook'' */",
- "monobook.js": "/* Kull ''JavaScript'' hawnhekk jiġi mniżżel għal dawk l-utenti li qegħdin jagħmlu użu mill-iskin ''Monobook'' */"
-}
+++ /dev/null
-{
- "skinname-monobook": "Lhibro"
-}
+++ /dev/null
-{
- "@metadata": [],
- "skinname-monobook": "Monobook",
- "monobook-desc": "Den klassiske MediaWiki-drakten fra 2004, oppkalt etter svarthvittbildet av en bok som brukes som bakgrunnsbilde",
- "monobook.css": "/* CSS i denne fila vil gjelde alle som bruker drakta Monobook */",
- "monobook.js": "/* Javascript i denne fila vil gjelde for brukere av drakta Monobook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Servien"
- ]
- },
- "skinname-monobook": "Monobook"
-}
+++ /dev/null
-{
- "monobook.css": "/* disse Datei ännern üm de Monobook-Stilvörlaag för de ganze Siet antopassen */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "सरोज कुमार ढकाल"
- ]
- },
- "skinname-monobook": "मोनोबुक",
- "monobook.css": "/* यहाँ राखिएको CSS ले मोनोबुक स्किनको प्रयोगकर्ताहरुलाई प्रभावित गर्ने छ */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Eukesh"
- ]
- },
- "monobook.css": "/* थन तःगु CSS नं मोनोबुक स्किनया छ्य्लामितेत असर याइ */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Siebrand",
- "Sjoerddebruin"
- ]
- },
- "skinname-monobook": "Monobook",
- "monobook-desc": "De klassieke MediaWiki-vormgeving sinds 2004, genoemd naar de zwart-witfoto van een boek op de achtergrond van de pagina",
- "monobook.css": "/* CSS die hier wordt geplaatst heeft alleen invloed op de skin Monobook */",
- "monobook.js": "/* JavaScript die hier wordt geplaatst heeft alleen invloed op gebruikers die de skin Monobook gebruiken */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Eirik",
- "Frokor",
- "Njardarlogar"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* CSS-tekst som vert plassert her, endrar utsjånaden til sidedrakta Monobook */",
- "monobook.js": "/* Javascript i denne fila vil gjelde for brukarar av drakta Monobook */"
-}
+++ /dev/null
-{
- "skinname-monobook": "NaaltsoosŁáa'ígíí"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Cedric31"
- ]
- },
- "skinname-monobook": "Monobook",
- "monobook.css": "/* Lo CSS plaçat aicí afectarà los utilizaires del skin Monobook */",
- "monobook.js": "/* Tot JavaScript aicí serà cargat amb las paginas accedidas pels utilizaires de l’abilhatge MonoBook unicament. */"
-}
+++ /dev/null
-{
- "skinname-monobook": "Моно-чиныг"
-}
+++ /dev/null
-{
- "skinname-monobook": "ਮੋਨੋਬੁੱਕ"
-}
+++ /dev/null
-{
- "monobook.css": "/* CSS a mikabit keni miapectuan la reng gagamit king Monobook a pabalat */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Wikipeeta"
- ]
- },
- "monobook.css": "/* CSS opp dise Sted wirtjt opp daut Monobook-Skin */",
- "monobook.js": "/* Daut neachste JavaScript woat fe Brucka mett Monobook-Skin jelode */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Sp5uhe",
- "Matma Rex"
- ]
- },
- "skinname-monobook": "Książka",
- "monobook-desc": "Klasyczna skórka MediaWiki, stworzona w 2004 roku, nazwana od czarno-białego zdjęcia książki w tle strony",
- "monobook.css": "/* Umieszczony tutaj kod CSS wpłynie na wygląd skórki Książka */",
- "monobook.js": "/* Umieszczony tutaj kod JavaScript zostanie załadowany wyłącznie przez użytkowników korzystających ze skórki Książka */"
-}
+++ /dev/null
-{
- "monobook.css": "/* cangé st'archivi-sì për modifiché la formatassion dël sit antregh */",
- "monobook.js": "/* Ës messagi-sì as dovrìa pa pì dovrelo; a sò pòst ch'a dòvra [[MediaWiki:common.js]] */"
-}
+++ /dev/null
-{
- "skinname-monobook": "مونوبوک"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Fabsouza1"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook-desc": "A skin clássica do MediaWiki desde 2004, assim chamada depois de uma foto preto-e-branco de um livro colocada plano de fundo da página",
- "monobook.css": "/* o código CSS colocado aqui terá efeito nos usuários do tema Monobook */",
- "monobook.js": "/* Qualquer JavaScript aqui colocado afetará os usuários do skin MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Hamilton Abreu",
- "Fúlvio",
- "Vitorvicentevalente"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook-desc": "O tema clássico do MediaWiki desde 2004, tendo este nome sido atribuído devido a uma imagem a preto-e-branco de um livro no plano de fundo da página",
- "monobook.css": "/* Código CSS colocado aqui afectará os utilizadores do tema Monobook */",
- "monobook.js": "/* Código Javascript colocado aqui será carregado para utilizadores do tema Monobook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Meno25",
- "Umherirrender",
- "Matma Rex"
- ]
- },
- "skinname-monobook": "{{optional}}",
- "monobook-desc": "{{desc|what=skin|name=MonoBook|url=https://www.mediawiki.org/wiki/Skin:MonoBook}}",
- "monobook.css": "{{optional}}\nCSS applied to users using MonoBook skin.",
- "monobook.js": "{{optional}}\nJS for users using MonoBook skin."
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "AlimanRuna"
- ]
- },
- "monobook.css": "/* Kayman churasqa CSS nisqaqa Monobook qaratam hukchanqa tukuy internet tiyanapaq */",
- "monobook.js": "/* Ima kaypi qillqamusqa JavaScript nisqa wakichi qillqapas MonoBook nisqata llamk'achiq ruraqkunapaq chaqnasqa kanqa */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Gion-andri"
- ]
- },
- "monobook.css": "/* editescha quest file per adattar il skin momobook per l'entira pagina */",
- "monobook.js": ""
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Firilacroco"
- ]
- },
- "skinname-monobook": "Monobook",
- "monobook.css": "/* modificați acest fișier pentru a adapta înfățișarea monobook-ului pentru tot situl*/"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Joetaras"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* 'U CSS ca se iacchie aqquà 'u 'ndrucane le utinde d'a masckere Monobook */",
- "monobook.js": "/* Ogne JavaScript aqquà avène carecate pe le utinde ca ausane 'a masckere MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "AlexSm",
- "Kaganer",
- "Okras"
- ]
- },
- "monobook-desc": "Классическая тема оформления MediaWiki, созданная в 2004 году и названая в честь чёрно-белой фотографии книги с фонового изображения страницы",
- "monobook.css": "/* Размещённый здесь CSS будет применяться к теме оформления Monobook */",
- "monobook.js": "/* Размещённый здесь код JavaScript будет загружаться пользователям, использующим тему оформления MonoBook */"
-}
+++ /dev/null
-{
- "skinname-monobook": "पुस्तक"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "HalanTul"
- ]
- },
- "monobook.css": "/* Манна оҥоһуллубут CSS Monobook диэн скиҥҥа туһаныллыа */",
- "monobook.js": "/* Эргэрбит; маны туһан:[[MediaWiki:common.js]] */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Santu",
- "Sarvaturi",
- "Tonyfroio"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* Li stili CSS nziriti ccà s'àpplicanu a l'utenti chi usanu la skin Monobook */",
- "monobook.js": "/* Lu còdici JavaScript nzirutu ccà veni carricatu di l'utenti c'ùsanu la skin MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "නන්දිමිතුරු"
- ]
- },
- "monobook.css": "/* මෙහි CSS බහාලීම ඒකායන ඡවිය භාවිතා කරන පරිශීලකයන් හට බලපෑම් සිදු කල හැක */",
- "monobook.js": "/* මෙහි ඕනෑම ජාවාස්ක්රිප්ට් එකක් ඒකායන ඡවිය භාවිතා කරන පරිශීලකයන්හට ප්රවේශනය කෙරේ */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Helix84",
- "Rudko"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* Tu umiestnené CSS bude ovplyvňovať používateľov štýlu Monobook */",
- "monobook.js": "/* Tu sa nachádzajúci JavaScript sa načíta používateľom vzhľadu Monobook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Dori"
- ]
- },
- "monobook.css": "/* redaktoni këtë faqe për të përshtatur pamjen Monobook për tëra faqet tuaja */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Rancher"
- ]
- },
- "skinname-monobook": "Монобук",
- "monobook.css": "/* CSS постављен овде ће утицати на све кориснике теме „Монобук“ */",
- "monobook.js": "/* Јаваскрипт постављен овде ће се учитати за све оне који користе тему „Монобук“ */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Rancher"
- ]
- },
- "skinname-monobook": "Monobuk",
- "monobook.css": "/* CSS postavljen ovde će uticati na sve korisnike teme „Monobuk“ */",
- "monobook.js": "/* Javaskript postavljen ovde će se učitati za sve one koji koriste temu „Monobuk“ */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Maartenvdbent"
- ]
- },
- "monobook.css": "/* Littikschrieuwen nit twinge */",
- "monobook.js": "/* Ferallerd; benutsje insteede deerfon [[MediaWiki:common.js]] */"
-}
+++ /dev/null
-{
- "monobook.css": "/* édit koropak ieu pikeun nyaluyukeun kulit ''monobook'' pikeun sakabéh situs */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Lejonel",
- "Lokal Profil",
- "Skalman"
- ]
- },
- "skinname-monobook": "Monobook",
- "monobook-desc": "Det klassiska MediaWiki-utseendet sedan 2004, uppkallad efter det svart-vita foto på en bok som syns i bakgrunden på sidan.",
- "monobook.css": "/* CSS som skrivs här kommer att påverka alla användare av skalet Monobook */",
- "monobook.js": "/* JavaScript här kommer att laddas för dem som använder skalet Monobook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Veeven"
- ]
- },
- "skinname-monobook": "మోనోబుక్"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Manop",
- "Octahedron80"
- ]
- },
- "skinname-monobook": "โมโนบุ๊ก",
- "monobook.css": "/* สไตล์ชีตในหน้านี้จะส่งผลแก่ผู้ใช้ที่ใช้สกินโมโนบุ๊ก */",
- "monobook.js": "/* จาวาสคริปต์ใด ๆ ในหน้านี้จะถูกโหลดให้แก่ผู้ใช้ที่ใช้สกินโมโนบุ๊ก */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "AnakngAraw",
- "Sky Harbor"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* Ang CSS na inilagay dito ay makakaapekto sa mga tagagamit ng pabalat na Monobook */",
- "monobook.js": "/* Ang anumang JavaScript dito ay ikakarga para sa mga tagagamit na gumagamit ng pabalat na MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Dbl2010"
- ]
- },
- "monobook.css": "/* Buraya konulacak CSS kodu tüm Monobook teması kullanan tüm kullanıcılarda etkin olur */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ильнар"
- ]
- },
- "skinname-monobook": "Китап"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Don Alessandro"
- ]
- },
- "skinname-monobook": "Kitap"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Sborsody"
- ]
- },
- "skinname-monobook": "МоноБук"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Arlin"
- ]
- },
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* CSS placed here will affect users of the Monobook skin */",
- "monobook.js": "/* Any JavaScript here will be loaded for users using the MonoBook skin */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Dim Grits",
- "Matma Rex",
- "Ата"
- ]
- },
- "skinname-monobook": "Моно-книга",
- "monobook-desc": "Класична тема оформлення MediaWiki з 2004 року, названа за чорно-білим фото книги на фоні сторінки",
- "monobook.css": "/* Розміщений тут CSS буде застосовуватися до всіх тем оформлення Monobook */",
- "monobook.js": "/* Розміщений тут код JavaScript буде завантажений для всіх користувачів, що використовують тему оформлення Моно-книга */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Игорь Бродский"
- ]
- },
- "skinname-monobook": "MonoBook"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Minh Nguyen"
- ]
- },
- "monobook-desc": "Giao diện MediaWiki cổ điển năm 2004, được đặt tên theo bức hình nền cuốn sách đen trắng",
- "monobook.css": "/* Mã CSS đặt ở đây sẽ ảnh hưởng đến thành viên sử dụng giao diện MonoBook */",
- "monobook.js": "/* Mã JavaScript tại đây sẽ được tải khi người dùng sử dụng giao diện MonoBook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Silvicola"
- ]
- },
- "monobook.css": "/* CSS hiir beâjflusd nôr dii Monobook-schelfn. Wen'd ale uf ôômôôl beâjflusn wilsch, muâsch an MediaWiki:Common.css was ändârn. */"
-}
+++ /dev/null
-{
- "monobook.css": "/* El CSS isio pepladöl otefon gebanis padafomäta: Monobook */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Võrok"
- ]
- },
- "monobook.css": "/* Taa lehe pääl om Monobook-vällänägemist muutvit kujonduisi. */",
- "monobook.js": "/* Olõi soovitõt; pruugiq [[MediaWiki:common.js]] */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Srtxg"
- ]
- },
- "monobook.css": "/* li côde CSS metou chal serè eployî pa tos les uzeus eployant l' pea «monobook» */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ibou"
- ]
- },
- "monobook.css": "/* CSS yiñ def fii dañuy am ay njeexit ci jëfandikukatu col gu Monobook. */",
- "monobook.js": "/*Bépp JavaScript buñ fi duggal jëfandikukat yiy jëfandikoo col gu Monobook keppa koy yeb. */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "פוילישער"
- ]
- },
- "skinname-monobook": "מאנאבוק",
- "monobook.css": "/* סטייל דא געלייגט וועט באאיינפלוסן דעם Monobook סקין */"
-}
+++ /dev/null
-{
- "skinname-monobook": "MonoBook",
- "monobook.css": "/* 響呢度放 CSS 碼去改用戶用嘅 Monobook 畫面 */",
- "monobook.js": "/* 響每一次個頁面載入時,用 Monobook 畫面嘅用戶都會載入呢度任何嘅JavaScript */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Xiaomingyan",
- "Cwek",
- "Liuxinyu970226"
- ]
- },
- "monobook-desc": "自2004年就出现的经典MediaWiki皮肤,命名依据一本书中某页面的黑白照片背景",
- "monobook.css": "/* 放置于这里的CSS将影响使用MonoBook皮肤的用户 */",
- "monobook.js": "/* 这里的任何JavaScript将为使用MonoBook皮肤的用户加载 */"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Cwlin0416"
- ]
- },
- "monobook-desc": "MediaWiki 自 2004 年以來的經典外觀,根據頁面背景的書本黑白照命名",
- "monobook.css": "/* 此 CSS 會影響使用 Monobook 介面外觀的使用者 */",
- "monobook.js": "/* 此 JavaScript 會用於使用 Monobook 介面外觀使用者 */"
-}
+++ /dev/null
-/*
-** MediaWiki 'monobook' style sheet for CSS2-capable browsers.
-** Copyright Gabriel Wicke - http://wikidev.net/
-** License: GPL (http://www.gnu.org/copyleft/gpl.html)
-**
-** Loosely based on http://www.positioniseverything.net/ordered-floats.html by Big John
-** and the Plone 2.0 styles, see http://plone.org/ (Alexander Limi,Joe Geldart & Tom Croucher,
-** Michael Zeltner and Geir Bækholt)
-** All you guys rock :)
-*/
-
-div#column-content {
- width: 100%;
- float: right;
- margin: 0 0 .6em -12.2em;
- padding: 0;
-}
-
-div#content {
- margin: 2.8em 0 0 12.2em;
- padding: 1em;
- position: relative;
- z-index: 2;
-}
-
-div#column-one {
- padding-top: 160px;
-}
-
-/* Hide, but keep accessible for screen-readers */
-#column-one h2 {
- position: absolute;
- top: -9999px;
-}
-
-div#content {
- background: white;
- color: black;
- border: 1px solid #aaa;
- border-right: none;
- line-height: 1.5em;
-}
-
-/* the left column width is specified in class .portlet */
-
-/* Font size:
-** We take advantage of keyword scaling- browsers won't go below 9px
-** More at http://www.w3.org/2003/07/30-font-size
-** http://style.cleverchimp.com/font_size_intervals/altintervals.html
-*/
-
-body {
- font: x-small sans-serif;
- /* @embed */
- background: #f9f9f9 url(headbg.jpg) 0 0 no-repeat;
- color: black;
- margin: 0;
- padding: 0;
- direction: ltr; /* Needed for RTL flipping */
- unicode-bidi: embed;
-}
-
-/* scale back up to a sane default */
-div#globalWrapper {
- font-size: 127%;
- width: 100%;
- margin: 0;
- padding: 0;
-}
-
-/* general styles */
-a {
- color: #002bb8;
-}
-
-a:visited {
- color: #5a3696;
-}
-
-a.new,
-#p-personal a.new {
- color: #cc2200;
-}
-
-ul {
- list-style-type: square;
- /* @embed */
- list-style-image: url(bullet.gif);
-}
-
-input.historysubmit {
- padding: 0 .3em .3em .3em !important;
- font-size: 94%;
- cursor: pointer;
- height: 1.7em !important;
- margin-left: 1.6em;
-}
-
-pre, .mw-code {
- line-height: 1.1em;
-}
-
-#firstHeading {
- padding-top: 0;
-}
-
-/*
-** the main content area
-*/
-
-#siteNotice {
- font-size: 95%;
- padding: 0 0.9em;
-}
-
-#localNotice {
- margin: 0;
-}
-
-#siteNotice p {
- margin: 0;
- padding: 0;
-}
-
-/*
-** classes for special content elements like town boxes
-** intended to be referenced directly from the wiki src
-*/
-
-/*
-** User styles
-*/
-/* table standards */
-table.rimage {
- float: right;
- position: relative;
- margin-left: 1em;
- margin-bottom: 1em;
- text-align: center;
-}
-
-/*
-** edit views etc
-*/
-.special li {
- line-height: 1.4em;
- margin: 0;
- padding: 0;
-}
-
-/*
-** keep the whitespace in front of the ^=, hides rule from konqueror
-** this is css3, the validator doesn't like it when validating as css2
-*/
-#bodyContent a.external {
- /* @embed */
- background: url(external-ltr.png) center right no-repeat;
- padding-right: 13px;
-}
-
-#bodyContent a.external[href ^="https://"],
-.link-https {
- /* @embed */
- background: url(lock_icon.gif) center right no-repeat;
- padding-right: 16px;
-}
-
-#bodyContent a.external[href ^="mailto:"],
-.link-mailto {
- /* @embed */
- background: url(mail_icon.gif) center right no-repeat;
- padding-right: 18px;
-}
-
-#bodyContent a.external[href ^="news:"] {
- /* @embed */
- background: url(news_icon.png) center right no-repeat;
- padding-right: 18px;
-}
-
-#bodyContent a.external[href ^="ftp://"],
-.link-ftp {
- /* @embed */
- background: url(file_icon.gif) center right no-repeat;
- padding-right: 18px;
-}
-
-#bodyContent a.external[href ^="irc://"],
-#bodyContent a.external[href ^="ircs://"],
-.link-irc {
- /* @embed */
- background: url(discussionitem_icon.gif) center right no-repeat;
- padding-right: 18px;
-}
-
-#bodyContent a.external[href $=".ogg"], #bodyContent a.external[href $=".OGG"],
-#bodyContent a.external[href $=".mid"], #bodyContent a.external[href $=".MID"],
-#bodyContent a.external[href $=".midi"], #bodyContent a.external[href $=".MIDI"],
-#bodyContent a.external[href $=".mp3"], #bodyContent a.external[href $=".MP3"],
-#bodyContent a.external[href $=".wav"], #bodyContent a.external[href $=".WAV"],
-#bodyContent a.external[href $=".wma"], #bodyContent a.external[href $=".WMA"],
-.link-audio {
- /* @embed */
- background: url(audio.png) center right no-repeat;
- padding-right: 13px;
-}
-
-#bodyContent a.external[href $=".ogm"], #bodyContent a.external[href $=".OGM"],
-#bodyContent a.external[href $=".avi"], #bodyContent a.external[href $=".AVI"],
-#bodyContent a.external[href $=".mpeg"], #bodyContent a.external[href $=".MPEG"],
-#bodyContent a.external[href $=".mpg"], #bodyContent a.external[href $=".MPG"],
-.link-video {
- /* @embed */
- background: url(video.png) center right no-repeat;
- padding-right: 13px;
-}
-
-#bodyContent a.external[href $=".pdf"], #bodyContent a.external[href $=".PDF"],
-#bodyContent a.external[href *=".pdf#"], #bodyContent a.external[href *=".PDF#"],
-#bodyContent a.external[href *=".pdf?"], #bodyContent a.external[href *=".PDF?"],
-.link-document {
- /* @embed */
- background: url(document.png) center right no-repeat;
- padding-right: 12px;
-}
-
-/* Interwiki Styling */
-#bodyContent a.extiw,
-#bodyContent a.extiw:active {
- color: #36b;
-}
-
-/* External links */
-#bodyContent a.external {
- color: #36b;
-}
-
-/*
-** Structural Elements
-*/
-
-/*
-** general portlet styles (elements in the quickbar)
-*/
-.portlet {
- border: none;
- margin: 0 0 .5em;
- padding: 0;
- float: none;
- width: 11.6em;
- overflow: hidden;
-}
-
-.portlet h3 {
- background: transparent;
- padding: 0 1em 0 .5em;
- display: inline;
- height: 1em;
- text-transform: lowercase;
- font-size: 91%;
- font-weight: normal;
- white-space: nowrap;
-}
-
-.pBody {
- font-size: 95%;
- background-color: white;
- color: black;
- border-collapse: collapse;
- border: 1px solid #aaa;
- padding: 0 .8em .3em .5em;
-}
-
-/* allows .pBody styles to wrap around content added via BaseTemplateAfterPortlet hook */
-.pBody:after {
- content: '';
- clear: both;
- display: block;
-}
-
-.portlet ul {
- line-height: 1.5em;
- font-size: 95%;
-}
-
-.portlet li {
- padding: 0;
- margin: 0;
-}
-
-/*
-** Logo properties
-*/
-
-#p-logo {
- top: 0;
- left: 0;
- position: absolute; /*needed to use z-index */
- z-index: 3;
- height: 155px;
- width: 12em;
- overflow: visible;
-}
-
-#p-logo h3 {
- display: none;
-}
-
-#p-logo a,
-#p-logo a:hover {
- display: block;
- height: 155px;
- width: 12.2em;
- background-repeat: no-repeat;
- background-position: 35% 50% !important;
- text-decoration: none;
-}
-
-/*
-** Search portlet
-*/
-#p-search {
- position: relative;
- z-index: 3;
-}
-
-input.searchButton {
- margin-top: 1px;
- font-size: 95%;
-}
-
-#searchGoButton {
- padding-left: .5em;
- padding-right: .5em;
- font-weight: bold;
-}
-
-#searchInput {
- width: 10.9em;
- margin: 0;
- font-size: 95%;
-}
-
-#p-search .pBody {
- padding: .5em .4em .4em .4em;
- text-align: center;
-}
-
-#p-search #searchform div div {
- margin-top: .4em;
- font-size: 95%;
-}
-
-/*
-** the personal toolbar
-*/
-#p-personal {
- position: absolute;
- left: 0;
- top: 0;
- z-index: 3;
-}
-
-#p-personal {
- width: 100%;
- white-space: nowrap;
- padding: 0;
- margin: 0;
- border: none;
- background: none;
- overflow: visible;
- line-height: 1.2em;
-}
-
-#p-personal h3 {
- display: none;
-}
-
-#p-personal .portlet,
-#p-personal .pBody {
- z-index: 0;
- padding: 0;
- margin: 0;
- border: none;
- overflow: visible;
- background: none;
-}
-
-/* this is the ul contained in the portlet */
-#p-personal ul {
- border: none;
- line-height: 1.4em;
- color: #2f6fab;
- padding: 0 2em 0 3em;
- margin: 0;
- text-align: right;
- list-style-type: none;
- list-style-image: none;
- z-index: 0;
- background: none;
- cursor: default;
-}
-
-#p-personal li {
- z-index: 0;
- border: none;
- padding: 0;
- display: inline;
- color: #2f6fab;
- margin-left: 1em;
- line-height: 1.2em;
- background: none;
-}
-
-#p-personal li a {
- text-decoration: none;
- color: #005896;
- padding-bottom: .2em;
- background: none;
-}
-
-#p-personal li a:hover {
- background-color: white;
- padding-bottom: .2em;
- text-decoration: none;
-}
-
-#p-personal li.active a:hover {
- background-color: transparent;
-}
-
-/* The icon in front of the username / login link */
-li#pt-userpage,
-li#pt-anonuserpage,
-li#pt-login {
- /* @embed */
- background: url(user.gif) top left no-repeat;
- padding-left: 20px;
-}
-
-#p-personal ul {
- text-transform: lowercase;
-}
-
-/* Don't lowercase username or IP addresses (IPv6) */
-li#pt-userpage,
-li#pt-anonuserpage {
- text-transform: none;
-}
-
-#p-personal li.active {
- font-weight: bold;
-}
-
-/*
-** the page-related actions- page/talk, edit etc
-*/
-#p-cactions {
- position: absolute;
- top: 1.3em;
- left: 11.5em;
- margin: 0;
- white-space: nowrap;
- width: 76%;
- line-height: 1.1em;
- overflow: visible;
- background: none;
- border-collapse: collapse;
- padding-left: 1em;
- font-size: 95%;
-}
-
-#p-cactions ul {
- list-style-type: none;
- list-style-image: none;
-}
-
-#p-cactions li {
- display: inline;
- border: 1px solid #aaa;
- border-bottom: none;
- padding: 0 0 1em 0;
- margin: 0 .3em 0 0;
- overflow: visible;
- background: white;
-}
-
-#p-cactions li.selected {
- border-color: #fabd23;
- font-weight: bold;
-}
-
-#p-cactions li a {
- background-color: #fbfbfb;
- color: #002bb8;
- border: none;
- padding: 0 .8em .3em;
- position: relative;
- z-index: 0;
- margin: 0;
- text-decoration: none;
-}
-
-#p-cactions li.selected a {
- z-index: 3;
- background-color: white;
-}
-
-#p-cactions .new a {
- color: #ba0000;
-}
-
-#p-cactions li a:hover {
- z-index: 3;
- text-decoration: none;
- background-color: white;
-}
-
-#p-cactions h3 {
- display: none;
-}
-
-#p-cactions li.istalk {
- margin-right: 0;
-}
-
-#p-cactions li.istalk a {
- padding-right: .5em;
-}
-
-#p-cactions #ca-addsection a {
- padding-left: .4em;
- padding-right: .4em;
-}
-
-/* offsets to distinguish the tab groups */
-li#ca-talk {
- margin-right: 1.6em;
-}
-
-li#ca-watch,
-li#ca-unwatch,
-li#ca-varlang-0,
-li#ca-print {
- margin-left: 1.6em;
-}
-
-#p-cactions .pBody {
- font-size: 1em;
- background-color: transparent;
- color: inherit;
- border-collapse: inherit;
- border: 0;
- padding: 0;
-}
-
-#p-cactions li a {
- text-transform: lowercase;
-}
-
-#p-lang {
- position: relative;
- z-index: 3;
-}
-
-/* Override text-transform on languages where capitalization is significant */
-.capitalize-all-nouns .portlet h3,
-.capitalize-all-nouns #p-personal ul,
-.capitalize-all-nouns #p-cactions ul li a {
- text-transform: none;
-}
-
-/* TODO: #t-iscite is only used by the Cite extension, come up with some
- * system which allows extensions to add to this file on the fly
- */
-#t-ispermalink, #t-iscite {
- color: #999;
-}
-
-/*
-** footer
-*/
-div#footer {
- background-color: white;
- border-top: 1px solid #fabd23;
- border-bottom: 1px solid #fabd23;
- margin: .6em 0 1em 0;
- overflow: hidden;
- padding: .4em 0 .3em 0;
- text-align: center;
- font-size: 90%;
-}
-
-div#footer li {
- display: inline;
- margin: 0 1.3em;
-}
-
-#f-poweredbyico, #f-copyrightico {
- margin: 0 8px;
- position: relative;
- top: -2px; /* Bump it up just a tad */
-}
-
-#f-poweredbyico {
- float: right;
- height: 1%;
-}
-
-#f-copyrightico {
- float: left;
- height: 1%;
-}
-
-.mw-htmlform-submit {
- font-weight: bold;
- padding-left: .3em;
- padding-right: .3em;
- margin-right: 2em;
-}
-
-/* js pref toc */
-#preftoc {
- margin: 0;
- padding: 0;
- width: 100%;
- clear: both;
-}
-
-#preftoc li {
- background-color: #f0f0f0;
- color: #000;
-}
-
-#preftoc li {
- margin: 1px -2px 1px 2px;
- float: left;
- padding: 2px 0 3px 0;
- border: 1px solid #fff;
- border-right-color: #716f64;
- border-bottom: 0;
- position: relative;
- white-space: nowrap;
- list-style-type: none;
- list-style-image: none;
- z-index: 3;
-}
-
-#preftoc li.selected {
- font-weight: bold;
- background-color: #f9f9f9;
- border: 1px solid #aaa;
- border-bottom: none;
- cursor: default;
- top: 1px;
- padding-top: 2px;
- margin-right: -3px;
-}
-
-#preftoc > li.selected {
- top: 2px;
-}
-
-#preftoc a,
-#preftoc a:active {
- display: block;
- color: #000;
- padding: 0 .7em;
- position: relative;
- text-decoration: none;
-}
-
-#preftoc li.selected a {
- cursor: default;
- text-decoration: none;
-}
-
-#preferences {
- margin: 0;
- border: 1px solid #aaa;
- clear: both;
- padding: 1.5em;
- background-color: #F9F9F9;
-}
-
-.prefsection {
- border: none;
- padding: 0;
- margin: 0;
-}
-
-.prefsection legend {
- font-weight: bold;
-}
-
-.prefsection table, .prefsection legend {
- background-color: #F9F9F9;
-}
-
-.mainLegend {
- display: none;
-}
-
-td.htmlform-tip {
- font-size: x-small;
- padding: .2em 2em;
- color: #666;
-}
-
-.preferences-login {
- clear: both;
- margin-bottom: 1.5em;
-}
-
-.prefcache {
- font-size: 90%;
- margin-top: 2em;
-}
-
-#userloginprompt, #languagelinks {
- font-size: 85%;
-}
-
-#login-sectiontip {
- font-size: 85%;
- line-height: 1.2;
- padding-top: 2em;
-}
-
-#userloginlink a, #wpLoginattempt, #wpCreateaccount {
- font-weight: bold;
-}
-
-/**
- * This was originally added by Gabriel Wicke in r3681 (committed on 25 May 2004)
- * with the commit message "tweaks to page history".
- * Unlike the other IE/Mac fixes that used to be present here, this seems to get
- * applied on more modern browsers, so let's keep it here until someone has the
- * time to properly test it out.
- */
-#pagehistory li.selected {
- position: relative;
-}
-
-.redirectText {
- font-size: 150%;
- margin: 5px;
-}
-
-div.patrollink {
- clear: both;
-}
-
-.sharedUploadNotice {
- font-style: italic;
-}
-
-span.updatedmarker {
- color: black;
- background-color: #0f0;
-}
-
-.editExternally {
- border: 1px solid gray;
- background-color: #ffffff;
- padding: 3px;
- margin-top: 0.5em;
- float: left;
- font-size: small;
- text-align: center;
-}
-
-.editExternallyHelp {
- font-style: italic;
- color: gray;
-}
-
-.toggle {
- margin-left: 2em;
- text-indent: -2em;
-}
-
-/* @bug 1714 */
-input#wpSave,
-input#wpDiff {
- margin-right: 0.33em;
-}
-
-#wpSave {
- font-weight: bold;
-}
-
-/* noarticletext */
-div.noarticletext {
- border: 1px solid #ccc;
- background: #fff;
- padding: .2em 1em;
- color: #000;
-}
-
-div#searchTargetContainer {
- left: 10px;
- top: 10px;
- width: 90%;
- background: white;
-}
-
-div#searchTarget {
- padding: 3px;
- margin: 5px;
- background: #F0F0F0;
- border: solid 1px blue;
-}
-
-div#searchTarget ul li {
- list-style-type: none;
- list-style-image: none;
-}
-
-div#searchTarget ul li:before {
- color: orange;
- content: "\00BB \0020";
-}
-
-div#searchTargetHide {
- float: right;
- border: solid 1px black;
- background: #DCDCDC;
- padding: 2px;
-}
-
-#powersearch p {
- margin-top: 0;
-}
-
-div.multipageimagenavbox {
- border: solid 1px silver;
- padding: 4px;
- margin: 1em;
- background: #f0f0f0;
-}
-
-div.multipageimagenavbox div.thumb {
- border: none;
- margin-left: 2em;
- margin-right: 2em;
-}
-
-div.multipageimagenavbox hr {
- margin: 6px;
-}
-
-table.multipageimage td {
- text-align: center;
-}
-
-.templatesUsed {
- margin-top: 1.5em;
-}
-
-.mw-summary-preview {
- margin: 0.1em 0;
-}
-
-/* Friendlier slave lag warnings */
-div.mw-lag-warn-normal,
-div.mw-lag-warn-high {
- padding: 3px;
- text-align: center;
- margin: 3px auto;
-}
-
-div.mw-lag-warn-normal {
- border: 1px solid #FFCC66;
- background-color: #FFFFCC;
-}
-
-div.mw-lag-warn-high {
- font-weight: bold;
- border: 2px solid #FF0033;
- background-color: #FFCCCC;
-}
-
-.MediaTransformError {
- background-color: #ccc;
- padding: 0.1em;
-}
-
-.MediaTransformError td {
- text-align: center;
- vertical-align: middle;
- font-size: 90%;
-}
-
-/* Sometimes people don't want personal tools to be lowercase! */
-.no-text-transform {
- text-transform: none;
-}
-
-/* Tooltips are outside of the normal body code, so this helps make the size of the text sensible */
-.tipsy {
- font-size: 127%;
-}
-
-/* mediawiki.notification */
-.skin-monobook .mw-notification {
- box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.125);
-}
+++ /dev/null
-== GNU GENERAL PUBLIC LICENSE ==
-
-Version 2, June 1991
-
-Copyright (C) 1989, 1991 Free Software Foundation, Inc.
-51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
-Everyone is permitted to copy and distribute verbatim copies
-of this license document, but changing it is not allowed.
-
-=== Preamble ===
-
-The licenses for most software are designed to take away your
-freedom to share and change it. By contrast, the GNU General Public
-License is intended to guarantee your freedom to share and change free
-software--to make sure the software is free for all its users. This
-General Public License applies to most of the Free Software
-Foundation's software and to any other program whose authors commit to
-using it. (Some other Free Software Foundation software is covered by
-the GNU Library General Public License instead.) You can apply it to
-your programs, too.
-
-When we speak of free software, we are referring to freedom, not
-price. Our General Public Licenses are designed to make sure that you
-have the freedom to distribute copies of free software (and charge for
-this service if you wish), that you receive source code or can get it
-if you want it, that you can change the software or use pieces of it
-in new free programs; and that you know you can do these things.
-
-To protect your rights, we need to make restrictions that forbid
-anyone to deny you these rights or to ask you to surrender the rights.
-These restrictions translate to certain responsibilities for you if you
-distribute copies of the software, or if you modify it.
-
-For example, if you distribute copies of such a program, whether
-gratis or for a fee, you must give the recipients all the rights that
-you have. You must make sure that they, too, receive or can get the
-source code. And you must show them these terms so they know their
-rights.
-
-We protect your rights with two steps: (1) copyright the software, and
-(2) offer you this license which gives you legal permission to copy,
-distribute and/or modify the software.
-
-Also, for each author's protection and ours, we want to make certain
-that everyone understands that there is no warranty for this free
-software. If the software is modified by someone else and passed on, we
-want its recipients to know that what they have is not the original, so
-that any problems introduced by others will not reflect on the original
-authors' reputations.
-
-Finally, any free program is threatened constantly by software
-patents. We wish to avoid the danger that redistributors of a free
-program will individually obtain patent licenses, in effect making the
-program proprietary. To prevent this, we have made it clear that any
-patent must be licensed for everyone's free use or not licensed at all.
-
-The precise terms and conditions for copying, distribution and
-modification follow.
-
-== TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION ==
-
-'''0.''' This License applies to any program or other work which contains
-a notice placed by the copyright holder saying it may be distributed
-under the terms of this General Public License. The "Program", below,
-refers to any such program or work, and a "work based on the Program"
-means either the Program or any derivative work under copyright law:
-that is to say, a work containing the Program or a portion of it,
-either verbatim or with modifications and/or translated into another
-language. (Hereinafter, translation is included without limitation in
-the term "modification".) Each licensee is addressed as "you".
-
-Activities other than copying, distribution and modification are not
-covered by this License; they are outside its scope. The act of
-running the Program is not restricted, and the output from the Program
-is covered only if its contents constitute a work based on the
-Program (independent of having been made by running the Program).
-Whether that is true depends on what the Program does.
-
-'''1.''' You may copy and distribute verbatim copies of the Program's
-source code as you receive it, in any medium, provided that you
-conspicuously and appropriately publish on each copy an appropriate
-copyright notice and disclaimer of warranty; keep intact all the
-notices that refer to this License and to the absence of any warranty;
-and give any other recipients of the Program a copy of this License
-along with the Program.
-
-You may charge a fee for the physical act of transferring a copy, and
-you may at your option offer warranty protection in exchange for a fee.
-
-'''2.''' You may modify your copy or copies of the Program or any portion
-of it, thus forming a work based on the Program, and copy and
-distribute such modifications or work under the terms of Section 1
-above, provided that you also meet all of these conditions:
-
- '''a)''' You must cause the modified files to carry prominent notices
- stating that you changed the files and the date of any change.
-
- '''b)''' You must cause any work that you distribute or publish, that in
- whole or in part contains or is derived from the Program or any
- part thereof, to be licensed as a whole at no charge to all third
- parties under the terms of this License.
-
- '''c)''' If the modified program normally reads commands interactively
- when run, you must cause it, when started running for such
- interactive use in the most ordinary way, to print or display an
- announcement including an appropriate copyright notice and a
- notice that there is no warranty (or else, saying that you provide
- a warranty) and that users may redistribute the program under
- these conditions, and telling the user how to view a copy of this
- License. (Exception: if the Program itself is interactive but
- does not normally print such an announcement, your work based on
- the Program is not required to print an announcement.)
-
-These requirements apply to the modified work as a whole. If
-identifiable sections of that work are not derived from the Program,
-and can be reasonably considered independent and separate works in
-themselves, then this License, and its terms, do not apply to those
-sections when you distribute them as separate works. But when you
-distribute the same sections as part of a whole which is a work based
-on the Program, the distribution of the whole must be on the terms of
-this License, whose permissions for other licensees extend to the
-entire whole, and thus to each and every part regardless of who wrote it.
-
-Thus, it is not the intent of this section to claim rights or contest
-your rights to work written entirely by you; rather, the intent is to
-exercise the right to control the distribution of derivative or
-collective works based on the Program.
-
-In addition, mere aggregation of another work not based on the Program
-with the Program (or with a work based on the Program) on a volume of
-a storage or distribution medium does not bring the other work under
-the scope of this License.
-
-'''3.''' You may copy and distribute the Program (or a work based on it,
-under Section 2) in object code or executable form under the terms of
-Sections 1 and 2 above provided that you also do one of the following:
-
- '''a)''' Accompany it with the complete corresponding machine-readable
- source code, which must be distributed under the terms of Sections
- 1 and 2 above on a medium customarily used for software interchange; or,
-
- '''b)''' Accompany it with a written offer, valid for at least three
- years, to give any third party, for a charge no more than your
- cost of physically performing source distribution, a complete
- machine-readable copy of the corresponding source code, to be
- distributed under the terms of Sections 1 and 2 above on a medium
- customarily used for software interchange; or,
-
- '''c)''' Accompany it with the information you received as to the offer
- to distribute corresponding source code. (This alternative is
- allowed only for noncommercial distribution and only if you
- received the program in object code or executable form with such
- an offer, in accord with Subsection b above.)
-
-The source code for a work means the preferred form of the work for
-making modifications to it. For an executable work, complete source
-code means all the source code for all modules it contains, plus any
-associated interface definition files, plus the scripts used to
-control compilation and installation of the executable. However, as a
-special exception, the source code distributed need not include
-anything that is normally distributed (in either source or binary
-form) with the major components (compiler, kernel, and so on) of the
-operating system on which the executable runs, unless that component
-itself accompanies the executable.
-
-If distribution of executable or object code is made by offering
-access to copy from a designated place, then offering equivalent
-access to copy the source code from the same place counts as
-distribution of the source code, even though third parties are not
-compelled to copy the source along with the object code.
-
-'''4.''' You may not copy, modify, sublicense, or distribute the Program
-except as expressly provided under this License. Any attempt
-otherwise to copy, modify, sublicense or distribute the Program is
-void, and will automatically terminate your rights under this License.
-However, parties who have received copies, or rights, from you under
-this License will not have their licenses terminated so long as such
-parties remain in full compliance.
-
-'''5.''' You are not required to accept this License, since you have not
-signed it. However, nothing else grants you permission to modify or
-distribute the Program or its derivative works. These actions are
-prohibited by law if you do not accept this License. Therefore, by
-modifying or distributing the Program (or any work based on the
-Program), you indicate your acceptance of this License to do so, and
-all its terms and conditions for copying, distributing or modifying
-the Program or works based on it.
-
-'''6.''' Each time you redistribute the Program (or any work based on the
-Program), the recipient automatically receives a license from the
-original licensor to copy, distribute or modify the Program subject to
-these terms and conditions. You may not impose any further
-restrictions on the recipients' exercise of the rights granted herein.
-You are not responsible for enforcing compliance by third parties to
-this License.
-
-'''7.''' If, as a consequence of a court judgment or allegation of patent
-infringement or for any other reason (not limited to patent issues),
-conditions are imposed on you (whether by court order, agreement or
-otherwise) that contradict the conditions of this License, they do not
-excuse you from the conditions of this License. If you cannot
-distribute so as to satisfy simultaneously your obligations under this
-License and any other pertinent obligations, then as a consequence you
-may not distribute the Program at all. For example, if a patent
-license would not permit royalty-free redistribution of the Program by
-all those who receive copies directly or indirectly through you, then
-the only way you could satisfy both it and this License would be to
-refrain entirely from distribution of the Program.
-
-If any portion of this section is held invalid or unenforceable under
-any particular circumstance, the balance of the section is intended to
-apply and the section as a whole is intended to apply in other
-circumstances.
-
-It is not the purpose of this section to induce you to infringe any
-patents or other property right claims or to contest validity of any
-such claims; this section has the sole purpose of protecting the
-integrity of the free software distribution system, which is
-implemented by public license practices. Many people have made
-generous contributions to the wide range of software distributed
-through that system in reliance on consistent application of that
-system; it is up to the author/donor to decide if he or she is willing
-to distribute software through any other system and a licensee cannot
-impose that choice.
-
-This section is intended to make thoroughly clear what is believed to
-be a consequence of the rest of this License.
-
-'''8.''' If the distribution and/or use of the Program is restricted in
-certain countries either by patents or by copyrighted interfaces, the
-original copyright holder who places the Program under this License
-may add an explicit geographical distribution limitation excluding
-those countries, so that distribution is permitted only in or among
-countries not thus excluded. In such case, this License incorporates
-the limitation as if written in the body of this License.
-
-'''9.''' The Free Software Foundation may publish revised and/or new versions
-of the General Public License from time to time. Such new versions will
-be similar in spirit to the present version, but may differ in detail to
-address new problems or concerns.
-
-Each version is given a distinguishing version number. If the Program
-specifies a version number of this License which applies to it and "any
-later version", you have the option of following the terms and conditions
-either of that version or of any later version published by the Free
-Software Foundation. If the Program does not specify a version number of
-this License, you may choose any version ever published by the Free Software
-Foundation.
-
-'''10.''' If you wish to incorporate parts of the Program into other free
-programs whose distribution conditions are different, write to the author
-to ask for permission. For software which is copyrighted by the Free
-Software Foundation, write to the Free Software Foundation; we sometimes
-make exceptions for this. Our decision will be guided by the two goals
-of preserving the free status of all derivatives of our free software and
-of promoting the sharing and reuse of software generally.
-
-=== NO WARRANTY ===
-
-'''11.''' BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
-FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
-OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
-PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
-OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
-MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
-TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
-PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
-REPAIR OR CORRECTION.
-
-'''12.''' IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
-WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
-REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
-INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
-OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
-TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
-YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
-PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
-POSSIBILITY OF SUCH DAMAGES.
-
- '''END OF TERMS AND CONDITIONS'''
-
-== How to Apply These Terms to Your New Programs ==
-
-If you develop a new program, and you want it to be of the greatest
-possible use to the public, the best way to achieve this is to make it
-free software which everyone can redistribute and change under these terms.
-
-To do so, attach the following notices to the program. It is safest
-to attach them to the start of each source file to most effectively
-convey the exclusion of warranty; and each file should have at least
-the "copyright" line and a pointer to where the full notice is found.
-
- <one line to give the program's name and a brief idea of what it does.>
-
- Copyright (C) <year> <name of author>
-
- 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
-
-
-Also add information on how to contact you by electronic and paper mail.
-
-If the program is interactive, make it output a short notice like this
-when it starts in an interactive mode:
-
- Gnomovision version 69, Copyright (C) year name of author
- Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
- This is free software, and you are welcome to redistribute it
- under certain conditions; type `show c' for details.
-
-The hypothetical commands `show w' and `show c' should show the appropriate
-parts of the General Public License. Of course, the commands you use may
-be called something other than `show w' and `show c'; they could even be
-mouse-clicks or menu items--whatever suits your program.
-
-You should also get your employer (if you work as a programmer) or your
-school, if any, to sign a "copyright disclaimer" for the program, if
-necessary. Here is a sample; alter the names:
-
- Yoyodyne, Inc., hereby disclaims all copyright interest in the program
- `Gnomovision' (which makes passes at compilers) written by James Hacker.
-
- <signature of Ty Coon>, 1 April 1989
-
- Ty Coon, President of Vice
-
-This General Public License does not permit incorporating your program into
-proprietary programs. If your program is a subroutine library, you may
-consider it more useful to permit linking proprietary applications with the
-library. If this is what you want to do, use the GNU Library General
-Public License instead of this License.
+++ /dev/null
-<?php
-/**
- * Vector - Modern version of MonoBook with fresh look and many usability
- * improvements.
- *
- * 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
- * @ingroup Skins
- */
-
-/**
- * SkinTemplate class for Vector skin
- * @ingroup Skins
- */
-class SkinVector extends SkinTemplate {
- public $skinname = 'vector';
- public $stylename = 'Vector';
- public $template = 'VectorTemplate';
-
- protected static $bodyClasses = array( 'vector-animateLayout' );
-
- /**
- * Initializes output page and sets up skin-specific parameters
- * @param OutputPage $out Object to initialize
- */
- public function initPage( OutputPage $out ) {
- global $wgLocalStylePath;
-
- parent::initPage( $out );
-
- // Append CSS which includes IE only behavior fixes for hover support -
- // this is better than including this in a CSS file since it doesn't
- // wait for the CSS file to load before fetching the HTC file.
- $min = $this->getRequest()->getFuzzyBool( 'debug' ) ? '' : '.min';
- $out->addHeadItem( 'csshover',
- '<!--[if lt IE 7]><style type="text/css">body{behavior:url("' .
- htmlspecialchars( $wgLocalStylePath ) .
- "/{$this->stylename}/csshover{$min}.htc\")}</style><![endif]-->"
- );
-
- $out->addModules( array( 'skins.vector.js' ) );
- }
-
- /**
- * Loads skin and user CSS files.
- * @param OutputPage $out
- */
- function setupSkinUserCss( OutputPage $out ) {
- parent::setupSkinUserCss( $out );
-
- $styles = array( 'mediawiki.skinning.interface', 'skins.vector.styles' );
- wfRunHooks( 'SkinVectorStyleModules', array( $this, &$styles ) );
- $out->addModuleStyles( $styles );
- }
-
- /**
- * Adds classes to the body element.
- *
- * @param OutputPage $out
- * @param array &$bodyAttrs Array of attributes that will be set on the body element
- */
- function addToBodyAttributes( $out, &$bodyAttrs ) {
- if ( isset( $bodyAttrs['class'] ) && strlen( $bodyAttrs['class'] ) > 0 ) {
- $bodyAttrs['class'] .= ' ' . implode( ' ', static::$bodyClasses );
- } else {
- $bodyAttrs['class'] = implode( ' ', static::$bodyClasses );
- }
- }
-}
+++ /dev/null
-<?php
-/**
- * Vector - Modern version of MonoBook with fresh look and many usability
- * improvements.
- *
- * 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
- * @ingroup Skins
- */
-
-$wgExtensionCredits['skin'][] = array(
- 'path' => __FILE__,
- 'name' => 'Vector',
- 'namemsg' => 'skinname-vector',
- 'descriptionmsg' => 'vector-skin-desc',
- 'url' => 'https://www.mediawiki.org/wiki/Skin:Vector',
- 'author' => array( 'Trevor Parscal', 'Roan Kattouw', '...' ),
- 'license-name' => 'GPLv2+',
-);
-
-// Register files
-$wgAutoloadClasses['SkinVector'] = __DIR__ . '/SkinVector.php';
-$wgAutoloadClasses['VectorTemplate'] = __DIR__ . '/VectorTemplate.php';
-$wgMessagesDirs['Vector'] = __DIR__ . '/i18n';
-
-// Register skin
-$wgValidSkinNames['vector'] = 'Vector';
-
-// Register modules
-$wgResourceModules['skins.vector.styles'] = array(
- 'styles' => array(
- 'screen.less' => array( 'media' => 'screen' ),
- 'screen-hd.less' => array( 'media' => 'screen and (min-width: 982px)' ),
- ),
- 'remoteSkinPath' => 'Vector',
- 'localBasePath' => __DIR__,
-);
-$wgResourceModules['skins.vector.js'] = array(
- 'scripts' => array(
- 'collapsibleTabs.js',
- 'vector.js',
- ),
- 'position' => 'top',
- 'dependencies' => array(
- 'jquery.throttle-debounce',
- 'jquery.tabIndex',
- ),
- 'remoteSkinPath' => 'Vector',
- 'localBasePath' => __DIR__,
-);
-
-// Apply module customizations
-$wgResourceModuleSkinStyles['vector'] = array(
- 'jquery.tipsy' => 'skinStyles/jquery.tipsy.less',
- 'jquery.ui.core' => array(
- 'skinStyles/jquery.ui/jquery.ui.core.css',
- 'skinStyles/jquery.ui/jquery.ui.theme.css',
- ),
- 'jquery.ui.accordion' => 'skinStyles/jquery.ui/jquery.ui.accordion.css',
- 'jquery.ui.autocomplete' => 'skinStyles/jquery.ui/jquery.ui.autocomplete.css',
- 'jquery.ui.button' => 'skinStyles/jquery.ui/jquery.ui.button.css',
- 'jquery.ui.datepicker' => 'skinStyles/jquery.ui/jquery.ui.datepicker.css',
- 'jquery.ui.dialog' => 'skinStyles/jquery.ui/jquery.ui.dialog.css',
- 'jquery.ui.progressbar' => 'skinStyles/jquery.ui/jquery.ui.progressbar.css',
- 'jquery.ui.resizable' => 'skinStyles/jquery.ui/jquery.ui.resizable.css',
- 'jquery.ui.selectable' => 'skinStyles/jquery.ui/jquery.ui.selectable.css',
- 'jquery.ui.slider' => 'skinStyles/jquery.ui/jquery.ui.slider.css',
- 'jquery.ui.tabs' => 'skinStyles/jquery.ui/jquery.ui.tabs.css',
- 'mediawiki.notification' => 'skinStyles/mediawiki.notification.less',
- 'mediawiki.special' => 'skinStyles/mediawiki.special.less',
- 'mediawiki.special.preferences' => 'skinStyles/mediawiki.special.preferences.less',
- 'remoteSkinPath' => 'Vector',
- 'localBasePath' => __DIR__,
-);
+++ /dev/null
-<?php
-/**
- * Vector - Modern version of MonoBook with fresh look and many usability
- * improvements.
- *
- * 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
- * @ingroup Skins
- */
-
-/**
- * QuickTemplate class for Vector skin
- * @ingroup Skins
- */
-class VectorTemplate extends BaseTemplate {
- /* Functions */
-
- /**
- * Outputs the entire contents of the (X)HTML page
- */
- public function execute() {
- global $wgVectorUseIconWatch;
-
- // Build additional attributes for navigation urls
- $nav = $this->data['content_navigation'];
-
- if ( $wgVectorUseIconWatch ) {
- $mode = $this->getSkin()->getUser()->isWatched( $this->getSkin()->getRelevantTitle() )
- ? 'unwatch'
- : 'watch';
-
- if ( isset( $nav['actions'][$mode] ) ) {
- $nav['views'][$mode] = $nav['actions'][$mode];
- $nav['views'][$mode]['class'] = rtrim( 'icon ' . $nav['views'][$mode]['class'], ' ' );
- $nav['views'][$mode]['primary'] = true;
- unset( $nav['actions'][$mode] );
- }
- }
-
- $xmlID = '';
- foreach ( $nav as $section => $links ) {
- foreach ( $links as $key => $link ) {
- if ( $section == 'views' && !( isset( $link['primary'] ) && $link['primary'] ) ) {
- $link['class'] = rtrim( 'collapsible ' . $link['class'], ' ' );
- }
-
- $xmlID = isset( $link['id'] ) ? $link['id'] : 'ca-' . $xmlID;
- $nav[$section][$key]['attributes'] =
- ' id="' . Sanitizer::escapeId( $xmlID ) . '"';
- if ( $link['class'] ) {
- $nav[$section][$key]['attributes'] .=
- ' class="' . htmlspecialchars( $link['class'] ) . '"';
- unset( $nav[$section][$key]['class'] );
- }
- if ( isset( $link['tooltiponly'] ) && $link['tooltiponly'] ) {
- $nav[$section][$key]['key'] =
- Linker::tooltip( $xmlID );
- } else {
- $nav[$section][$key]['key'] =
- Xml::expandAttributes( Linker::tooltipAndAccesskeyAttribs( $xmlID ) );
- }
- }
- }
- $this->data['namespace_urls'] = $nav['namespaces'];
- $this->data['view_urls'] = $nav['views'];
- $this->data['action_urls'] = $nav['actions'];
- $this->data['variant_urls'] = $nav['variants'];
-
- // Reverse horizontally rendered navigation elements
- if ( $this->data['rtl'] ) {
- $this->data['view_urls'] =
- array_reverse( $this->data['view_urls'] );
- $this->data['namespace_urls'] =
- array_reverse( $this->data['namespace_urls'] );
- $this->data['personal_urls'] =
- array_reverse( $this->data['personal_urls'] );
- }
- // Output HTML Page
- $this->html( 'headelement' );
- ?>
- <div id="mw-page-base" class="noprint"></div>
- <div id="mw-head-base" class="noprint"></div>
- <div id="content" class="mw-body" role="main">
- <a id="top"></a>
-
- <?php
- if ( $this->data['sitenotice'] ) {
- ?>
- <div id="siteNotice"><?php $this->html( 'sitenotice' ) ?></div>
- <?php
- }
- ?>
- <h1 id="firstHeading" class="firstHeading" lang="<?php
- $this->data['pageLanguage'] =
- $this->getSkin()->getTitle()->getPageViewLanguage()->getHtmlCode();
- $this->text( 'pageLanguage' );
- ?>"><span dir="auto"><?php $this->html( 'title' ) ?></span></h1>
- <?php $this->html( 'prebodyhtml' ) ?>
- <div id="bodyContent" class="mw-body-content">
- <?php
- if ( $this->data['isarticle'] ) {
- ?>
- <div id="siteSub"><?php $this->msg( 'tagline' ) ?></div>
- <?php
- }
- ?>
- <div id="contentSub"<?php
- $this->html( 'userlangattributes' )
- ?>><?php $this->html( 'subtitle' ) ?></div>
- <?php
- if ( $this->data['undelete'] ) {
- ?>
- <div id="contentSub2"><?php $this->html( 'undelete' ) ?></div>
- <?php
- }
- ?>
- <?php
- if ( $this->data['newtalk'] ) {
- ?>
- <div class="usermessage"><?php $this->html( 'newtalk' ) ?></div>
- <?php
- }
- ?>
- <div id="jump-to-nav" class="mw-jump">
- <?php $this->msg( 'jumpto' ) ?>
- <a href="#mw-navigation"><?php
- $this->msg( 'jumptonavigation' )
- ?></a><?php
- $this->msg( 'comma-separator' )
- ?>
- <a href="#p-search"><?php $this->msg( 'jumptosearch' ) ?></a>
- </div>
- <?php $this->html( 'bodycontent' ) ?>
- <?php
- if ( $this->data['printfooter'] ) {
- ?>
- <div class="printfooter">
- <?php $this->html( 'printfooter' ); ?>
- </div>
- <?php
- }
- ?>
- <?php
- if ( $this->data['catlinks'] ) {
- ?>
- <?php
- $this->html( 'catlinks' );
- ?>
- <?php
- }
- ?>
- <?php
- if ( $this->data['dataAfterContent'] ) {
- ?>
- <?php
- $this->html( 'dataAfterContent' );
- ?>
- <?php
- }
- ?>
- <div class="visualClear"></div>
- <?php $this->html( 'debughtml' ); ?>
- </div>
- </div>
- <div id="mw-navigation">
- <h2><?php $this->msg( 'navigation-heading' ) ?></h2>
-
- <div id="mw-head">
- <?php $this->renderNavigation( 'PERSONAL' ); ?>
- <div id="left-navigation">
- <?php $this->renderNavigation( array( 'NAMESPACES', 'VARIANTS' ) ); ?>
- </div>
- <div id="right-navigation">
- <?php $this->renderNavigation( array( 'VIEWS', 'ACTIONS', 'SEARCH' ) ); ?>
- </div>
- </div>
- <div id="mw-panel">
- <div id="p-logo" role="banner"><a style="background-image: url(<?php
- $this->text( 'logopath' )
- ?>);" href="<?php
- echo htmlspecialchars( $this->data['nav_urls']['mainpage']['href'] )
- ?>" <?php
- echo Xml::expandAttributes( Linker::tooltipAndAccesskeyAttribs( 'p-logo' ) )
- ?>></a></div>
- <?php $this->renderPortals( $this->data['sidebar'] ); ?>
- </div>
- </div>
- <div id="footer" role="contentinfo"<?php $this->html( 'userlangattributes' ) ?>>
- <?php
- foreach ( $this->getFooterLinks() as $category => $links ) {
- ?>
- <ul id="footer-<?php
- echo $category
- ?>">
- <?php
- foreach ( $links as $link ) {
- ?>
- <li id="footer-<?php
- echo $category
- ?>-<?php
- echo $link
- ?>"><?php
- $this->html( $link )
- ?></li>
- <?php
- }
- ?>
- </ul>
- <?php
- }
- ?>
- <?php $footericons = $this->getFooterIcons( "icononly" );
- if ( count( $footericons ) > 0 ) {
- ?>
- <ul id="footer-icons" class="noprint">
- <?php
- foreach ( $footericons as $blockName => $footerIcons ) {
- ?>
- <li id="footer-<?php
- echo htmlspecialchars( $blockName ); ?>ico">
- <?php
- foreach ( $footerIcons as $icon ) {
- ?>
- <?php
- echo $this->getSkin()->makeFooterIcon( $icon );
- ?>
-
- <?php
- }
- ?>
- </li>
- <?php
- }
- ?>
- </ul>
- <?php
- }
- ?>
- <div style="clear:both"></div>
- </div>
- <?php $this->printTrail(); ?>
-
- </body>
-</html>
- <?php
- }
-
- /**
- * Render a series of portals
- *
- * @param array $portals
- */
- protected function renderPortals( $portals ) {
- // Force the rendering of the following portals
- if ( !isset( $portals['SEARCH'] ) ) {
- $portals['SEARCH'] = true;
- }
- if ( !isset( $portals['TOOLBOX'] ) ) {
- $portals['TOOLBOX'] = true;
- }
- if ( !isset( $portals['LANGUAGES'] ) ) {
- $portals['LANGUAGES'] = true;
- }
- // Render portals
- foreach ( $portals as $name => $content ) {
- if ( $content === false ) {
- continue;
- }
-
- switch ( $name ) {
- case 'SEARCH':
- break;
- case 'TOOLBOX':
- $this->renderPortal( 'tb', $this->getToolbox(), 'toolbox', 'SkinTemplateToolboxEnd' );
- break;
- case 'LANGUAGES':
- if ( $this->data['language_urls'] !== false ) {
- $this->renderPortal( 'lang', $this->data['language_urls'], 'otherlanguages' );
- }
- break;
- default:
- $this->renderPortal( $name, $content );
- break;
- }
- }
- }
-
- /**
- * @param string $name
- * @param array $content
- * @param null|string $msg
- * @param null|string|array $hook
- */
- protected function renderPortal( $name, $content, $msg = null, $hook = null ) {
- if ( $msg === null ) {
- $msg = $name;
- }
- $msgObj = wfMessage( $msg );
- ?>
- <div class="portal" role="navigation" id='<?php
- echo Sanitizer::escapeId( "p-$name" )
- ?>'<?php
- echo Linker::tooltip( 'p-' . $name )
- ?> aria-labelledby='<?php echo Sanitizer::escapeId( "p-$name-label" ) ?>'>
- <h3<?php
- $this->html( 'userlangattributes' )
- ?> id='<?php
- echo Sanitizer::escapeId( "p-$name-label" )
- ?>'><?php
- echo htmlspecialchars( $msgObj->exists() ? $msgObj->text() : $msg );
- ?></h3>
-
- <div class="body">
- <?php
- if ( is_array( $content ) ) {
- ?>
- <ul>
- <?php
- foreach ( $content as $key => $val ) {
- ?>
- <?php echo $this->makeListItem( $key, $val ); ?>
-
- <?php
- }
- if ( $hook !== null ) {
- wfRunHooks( $hook, array( &$this, true ) );
- }
- ?>
- </ul>
- <?php
- } else {
- ?>
- <?php
- echo $content; /* Allow raw HTML block to be defined by extensions */
- }
-
- $this->renderAfterPortlet( $name );
- ?>
- </div>
- </div>
- <?php
- }
-
- /**
- * Render one or more navigations elements by name, automatically reveresed
- * when UI is in RTL mode
- *
- * @param array $elements
- */
- protected function renderNavigation( $elements ) {
- global $wgVectorUseSimpleSearch;
-
- // If only one element was given, wrap it in an array, allowing more
- // flexible arguments
- if ( !is_array( $elements ) ) {
- $elements = array( $elements );
- // If there's a series of elements, reverse them when in RTL mode
- } elseif ( $this->data['rtl'] ) {
- $elements = array_reverse( $elements );
- }
- // Render elements
- foreach ( $elements as $name => $element ) {
- switch ( $element ) {
- case 'NAMESPACES':
- ?>
- <div id="p-namespaces" role="navigation" class="vectorTabs<?php
- if ( count( $this->data['namespace_urls'] ) == 0 ) {
- echo ' emptyPortlet';
- }
- ?>" aria-labelledby="p-namespaces-label">
- <h3 id="p-namespaces-label"><?php $this->msg( 'namespaces' ) ?></h3>
- <ul<?php $this->html( 'userlangattributes' ) ?>>
- <?php
- foreach ( $this->data['namespace_urls'] as $link ) {
- ?>
- <li <?php
- echo $link['attributes']
- ?>><span><a href="<?php
- echo htmlspecialchars( $link['href'] )
- ?>" <?php
- echo $link['key']
- ?>><?php
- echo htmlspecialchars( $link['text'] )
- ?></a></span></li>
- <?php
- }
- ?>
- </ul>
- </div>
- <?php
- break;
- case 'VARIANTS':
- ?>
- <div id="p-variants" role="navigation" class="vectorMenu<?php
- if ( count( $this->data['variant_urls'] ) == 0 ) {
- echo ' emptyPortlet';
- }
- ?>" aria-labelledby="p-variants-label">
- <?php
- // Replace the label with the name of currently chosen variant, if any
- $variantLabel = $this->getMsg( 'variants' )->text();
- foreach ( $this->data['variant_urls'] as $link ) {
- if ( stripos( $link['attributes'], 'selected' ) !== false ) {
- $variantLabel = $link['text'];
- break;
- }
- }
- ?>
- <h3 id="p-variants-label"><span
- style="display: block;" <?php /* Temporary WMF deployment hack, to be removed before 1.24 release */ ?>
- ><?php echo htmlspecialchars( $variantLabel ) ?></span><a href="#"></a></h3>
-
- <div class="menu">
- <ul>
- <?php
- foreach ( $this->data['variant_urls'] as $link ) {
- ?>
- <li<?php
- echo $link['attributes']
- ?>><a href="<?php
- echo htmlspecialchars( $link['href'] )
- ?>" lang="<?php
- echo htmlspecialchars( $link['lang'] )
- ?>" hreflang="<?php
- echo htmlspecialchars( $link['hreflang'] )
- ?>" <?php
- echo $link['key']
- ?>><?php
- echo htmlspecialchars( $link['text'] )
- ?></a></li>
- <?php
- }
- ?>
- </ul>
- </div>
- </div>
- <?php
- break;
- case 'VIEWS':
- ?>
- <div id="p-views" role="navigation" class="vectorTabs<?php
- if ( count( $this->data['view_urls'] ) == 0 ) {
- echo ' emptyPortlet';
- }
- ?>" aria-labelledby="p-views-label">
- <h3 id="p-views-label"><?php $this->msg( 'views' ) ?></h3>
- <ul<?php
- $this->html( 'userlangattributes' )
- ?>>
- <?php
- foreach ( $this->data['view_urls'] as $link ) {
- ?>
- <li<?php
- echo $link['attributes']
- ?>><span><a href="<?php
- echo htmlspecialchars( $link['href'] )
- ?>" <?php
- echo $link['key']
- ?>><?php
- // $link['text'] can be undefined - bug 27764
- if ( array_key_exists( 'text', $link ) ) {
- echo array_key_exists( 'img', $link )
- ? '<img src="' . $link['img'] . '" alt="' . $link['text'] . '" />'
- : htmlspecialchars( $link['text'] );
- }
- ?></a></span></li>
- <?php
- }
- ?>
- </ul>
- </div>
- <?php
- break;
- case 'ACTIONS':
- ?>
- <div id="p-cactions" role="navigation" class="vectorMenu<?php
- if ( count( $this->data['action_urls'] ) == 0 ) {
- echo ' emptyPortlet';
- }
- ?>" aria-labelledby="p-cactions-label">
- <h3 id="p-cactions-label"><span><?php
- $this->msg( 'vector-more-actions' )
- ?></span><a href="#"></a></h3>
-
- <div class="menu">
- <ul<?php $this->html( 'userlangattributes' ) ?>>
- <?php
- foreach ( $this->data['action_urls'] as $link ) {
- ?>
- <li<?php
- echo $link['attributes']
- ?>>
- <a href="<?php
- echo htmlspecialchars( $link['href'] )
- ?>" <?php
- echo $link['key'] ?>><?php echo htmlspecialchars( $link['text'] )
- ?></a>
- </li>
- <?php
- }
- ?>
- </ul>
- </div>
- </div>
- <?php
- break;
- case 'PERSONAL':
- ?>
- <div id="p-personal" role="navigation" class="<?php
- if ( count( $this->data['personal_urls'] ) == 0 ) {
- echo ' emptyPortlet';
- }
- ?>" aria-labelledby="p-personal-label">
- <h3 id="p-personal-label"><?php $this->msg( 'personaltools' ) ?></h3>
- <ul<?php $this->html( 'userlangattributes' ) ?>>
- <?php
- $personalTools = $this->getPersonalTools();
- foreach ( $personalTools as $key => $item ) {
- echo $this->makeListItem( $key, $item );
- }
- ?>
- </ul>
- </div>
- <?php
- break;
- case 'SEARCH':
- ?>
- <div id="p-search" role="search">
- <h3<?php $this->html( 'userlangattributes' ) ?>>
- <label for="searchInput"><?php $this->msg( 'search' ) ?></label>
- </h3>
-
- <form action="<?php $this->text( 'wgScript' ) ?>" id="searchform">
- <?php
- if ( $wgVectorUseSimpleSearch ) {
- ?>
- <div id="simpleSearch">
- <?php
- } else {
- ?>
- <div>
- <?php
- }
- ?>
- <?php
- echo $this->makeSearchInput( array( 'id' => 'searchInput' ) );
- echo Html::hidden( 'title', $this->get( 'searchtitle' ) );
- // We construct two buttons (for 'go' and 'fulltext' search modes),
- // but only one will be visible and actionable at a time (they are
- // overlaid on top of each other in CSS).
- // * Browsers will use the 'fulltext' one by default (as it's the
- // first in tree-order), which is desirable when they are unable
- // to show search suggestions (either due to being broken or
- // having JavaScript turned off).
- // * The mediawiki.searchSuggest module, after doing tests for the
- // broken browsers, removes the 'fulltext' button and handles
- // 'fulltext' search itself; this will reveal the 'go' button and
- // cause it to be used.
- echo $this->makeSearchButton(
- 'fulltext',
- array( 'id' => 'mw-searchButton', 'class' => 'searchButton mw-fallbackSearchButton' )
- );
- echo $this->makeSearchButton(
- 'go',
- array( 'id' => 'searchButton', 'class' => 'searchButton' )
- );
- ?>
- </div>
- </form>
- </div>
- <?php
-
- break;
- }
- }
- }
-}
+++ /dev/null
-/**
- * Collapsible tabs jQuery Plugin
- */
-( function ( $ ) {
- var rtl = $( 'html' ).attr( 'dir' ) === 'rtl';
- $.fn.collapsibleTabs = function ( options ) {
- // return if the function is called on an empty jquery object
- if ( !this.length ) {
- return this;
- }
- // Merge options into the defaults
- var settings = $.extend( {}, $.collapsibleTabs.defaults, options );
-
- this.each( function () {
- var $el = $( this );
- // add the element to our array of collapsible managers
- $.collapsibleTabs.instances = ( $.collapsibleTabs.instances.length === 0 ?
- $el : $.collapsibleTabs.instances.add( $el ) );
- // attach the settings to the elements
- $el.data( 'collapsibleTabsSettings', settings );
- // attach data to our collapsible elements
- $el.children( settings.collapsible ).each( function () {
- $.collapsibleTabs.addData( $( this ) );
- } );
- } );
-
- // if we haven't already bound our resize handler, bind it now
- if ( !$.collapsibleTabs.boundEvent ) {
- $( window ).on( 'resize', $.debounce( 500, function () {
- $.collapsibleTabs.handleResize();
- } ) );
- $.collapsibleTabs.boundEvent = true;
- }
-
- // call our resize handler to setup the page
- $.collapsibleTabs.handleResize();
- return this;
- };
- $.collapsibleTabs = {
- instances: [],
- boundEvent: null,
- defaults: {
- expandedContainer: '#p-views ul',
- collapsedContainer: '#p-cactions ul',
- collapsible: 'li.collapsible',
- shifting: false,
- expandCondition: function ( eleWidth ) {
- // If there are at least eleWidth + 1 pixels of free space, expand.
- // We add 1 because .width() will truncate fractional values but .offset() will not.
- return $.collapsibleTabs.calculateTabDistance() >= eleWidth + 1;
- },
- collapseCondition: function () {
- // If there's an overlap, collapse.
- return $.collapsibleTabs.calculateTabDistance() < 0;
- }
- },
- addData: function ( $collapsible ) {
- var settings = $collapsible.parent().data( 'collapsibleTabsSettings' );
- if ( settings ) {
- $collapsible.data( 'collapsibleTabsSettings', {
- expandedContainer: settings.expandedContainer,
- collapsedContainer: settings.collapsedContainer,
- expandedWidth: $collapsible.width(),
- prevElement: $collapsible.prev()
- } );
- }
- },
- getSettings: function ( $collapsible ) {
- var settings = $collapsible.data( 'collapsibleTabsSettings' );
- if ( !settings ) {
- $.collapsibleTabs.addData( $collapsible );
- settings = $collapsible.data( 'collapsibleTabsSettings' );
- }
- return settings;
- },
- handleResize: function () {
- $.collapsibleTabs.instances.each( function () {
- var $el = $( this ),
- data = $.collapsibleTabs.getSettings( $el );
-
- if ( data.shifting ) {
- return;
- }
-
- // if the two navigations are colliding
- if ( $el.children( data.collapsible ).length > 0 && data.collapseCondition() ) {
-
- $el.trigger( 'beforeTabCollapse' );
- // move the element to the dropdown menu
- $.collapsibleTabs.moveToCollapsed( $el.children( data.collapsible + ':last' ) );
- }
-
- // if there are still moveable items in the dropdown menu,
- // and there is sufficient space to place them in the tab container
- if ( $( data.collapsedContainer + ' ' + data.collapsible ).length > 0 &&
- data.expandCondition( $.collapsibleTabs.getSettings( $( data.collapsedContainer ).children(
- data.collapsible + ':first' ) ).expandedWidth ) ) {
- //move the element from the dropdown to the tab
- $el.trigger( 'beforeTabExpand' );
- $.collapsibleTabs
- .moveToExpanded( data.collapsedContainer + ' ' + data.collapsible + ':first' );
- }
- } );
- },
- moveToCollapsed: function ( ele ) {
- var outerData, expContainerSettings, target,
- $moving = $( ele );
-
- outerData = $.collapsibleTabs.getSettings( $moving );
- if ( !outerData ) {
- return;
- }
- expContainerSettings = $.collapsibleTabs.getSettings( $( outerData.expandedContainer ) );
- if ( !expContainerSettings ) {
- return;
- }
- expContainerSettings.shifting = true;
-
- // Remove the element from where it's at and put it in the dropdown menu
- target = outerData.collapsedContainer;
- $moving.css( 'position', 'relative' )
- .css( ( rtl ? 'left' : 'right' ), 0 )
- .animate( { width: '1px' }, 'normal', function () {
- var data, expContainerSettings;
- $( this ).hide();
- // add the placeholder
- $( '<span class="placeholder" style="display: none;"></span>' ).insertAfter( this );
- $( this ).detach().prependTo( target ).data( 'collapsibleTabsSettings', outerData );
- $( this ).attr( 'style', 'display: list-item;' );
- data = $.collapsibleTabs.getSettings( $( ele ) );
- if ( data ) {
- expContainerSettings = $.collapsibleTabs.getSettings( $( data.expandedContainer ) );
- if ( expContainerSettings ) {
- expContainerSettings.shifting = false;
- $.collapsibleTabs.handleResize();
- }
- }
- } );
- },
- moveToExpanded: function ( ele ) {
- var data, expContainerSettings, $target, expandedWidth,
- $moving = $( ele );
-
- data = $.collapsibleTabs.getSettings( $moving );
- if ( !data ) {
- return;
- }
- expContainerSettings = $.collapsibleTabs.getSettings( $( data.expandedContainer ) );
- if ( !expContainerSettings ) {
- return;
- }
- expContainerSettings.shifting = true;
-
- // grab the next appearing placeholder so we can use it for replacing
- $target = $( data.expandedContainer ).find( 'span.placeholder:first' );
- expandedWidth = data.expandedWidth;
- $moving.css( 'position', 'relative' ).css( ( rtl ? 'right' : 'left' ), 0 ).css( 'width', '1px' );
- $target.replaceWith(
- $moving
- .detach()
- .css( 'width', '1px' )
- .data( 'collapsibleTabsSettings', data )
- .animate( { width: expandedWidth + 'px' }, 'normal', function () {
- $( this ).attr( 'style', 'display: block;' );
- var data, expContainerSettings;
- data = $.collapsibleTabs.getSettings( $( this ) );
- if ( data ) {
- expContainerSettings = $.collapsibleTabs.getSettings( $( data.expandedContainer ) );
- if ( expContainerSettings ) {
- expContainerSettings.shifting = false;
- $.collapsibleTabs.handleResize();
- }
- }
- } )
- );
- },
- /**
- * Returns the amount of horizontal distance between the two tabs groups
- * (#left-navigation and #right-navigation), in pixels. If negative, this
- * means that the tabs overlap, and the value is the width of overlapping
- * parts.
- *
- * Used in default expandCondition and collapseCondition.
- *
- * @return {Numeric} distance/overlap in pixels
- */
- calculateTabDistance: function () {
- var $leftTab, $rightTab, leftEnd, rightStart;
-
- // In RTL, #right-navigation is actually on the left and vice versa.
- // Hooray for descriptive naming.
- if ( !rtl ) {
- $leftTab = $( '#left-navigation' );
- $rightTab = $( '#right-navigation' );
- } else {
- $leftTab = $( '#right-navigation' );
- $rightTab = $( '#left-navigation' );
- }
-
- leftEnd = $leftTab.offset().left + $leftTab.width();
- rightStart = $rightTab.offset().left;
-
- return rightStart - leftEnd;
- }
- };
-
-}( jQuery ) );
+++ /dev/null
-/* Animate between standard and high definition layouts */
-body.vector-animateLayout {
- div#content,
- div#footer,
- #left-navigation {
- .transition(margin-left 250ms, padding 250ms;);
- }
-
- #p-logo {
- .transition(left 250ms);
- }
-
- #mw-panel {
- .transition(padding-right 250ms);
- }
-
- #p-search {
- .transition(margin-right 250ms);
- }
-
- #p-personal {
- .transition(right 250ms);
- }
-
- #mw-head-base {
- .transition(margin-left 250ms);
- }
-}
+++ /dev/null
-/*
- * Any rules which should not be flipped automatically in right-to-left situations should be
- * prepended with @noflip in a comment block.
- *
- * This stylesheet employs a few CSS trick to accomplish compatibility with a wide range of web
- * browsers. The most common trick is to use some styles in IE6 only. This is accomplished by using
- * a rule that makes things work in IE6, and then following it with a rule that begins with
- * "html > body" or use a child selector ">", which is ignored by IE6 because it does not support
- * the child selector. You can spot this by looking for the "OVERRIDDEN BY COMPLIANT BROWSERS" and
- * "IGNORED BY IE6" comments.
- */
-@import "mediawiki.mixins";
-
-/* Framework */
-html {
- font-size: @html-font-size;
-}
-html,
-body {
- height: 100%;
- margin: 0;
- padding: 0;
- font-family: @content-font-family;
-}
-body {
- background-color: @menu-background-color;
-}
-
-/* Content */
-div#content {
- margin-left: 10em;
- padding: @content-padding;
- /* Border on top, left, and bottom side */
- border: 1px solid @content-border-color;
- border-right-width: 0;
- /* Merge the border with tabs' one (in their background image) */
- margin-top: -1px;
- background-color: @body-background-color;
- color: @content-font-color;
- direction: ltr;
-
- .mw-editsection,
- .mw-editsection-like {
- font-family: @content-font-family;
- }
-
- p {
- line-height: inherit;
- margin: 0.5em 0;
- }
-
- h1,
- h2,
- #firstHeading {
- font-family: @content-heading-font-family;
- line-height: @heading-line-height;
- margin-bottom: 0.25em;
- padding: 0;
- }
-
- h1,
- #firstHeading {
- font-size: @content-heading-font-size;
- }
-
- h2 {
- font-size: 1.5em;
- margin-top: 1em;
- }
-
- h3,
- h4,
- h5,
- h6 {
- line-height: @content-line-height;
- margin-top: 0.3em;
- margin-bottom: 0;
- padding-bottom: 0;
- }
-
- h3 {
- font-size: 1.17em;
- }
-
- h3,
- h4 {
- font-weight: bold;
- }
-
- h4,
- h5,
- h6 {
- font-size: 100%; /* (reset) */
- }
-
- #toc h2,
- .toc h2 {
- font-size: 100%; /* (reset) */
- font-family: @content-font-family;
- }
-}
-
-/* Hide empty portlets */
-div.emptyPortlet {
- display: none;
-}
-
-ul {
- list-style-type: disc;
- .list-style-image('images/bullet-icon.png');
-}
-
-pre, .mw-code {
- line-height: 1.3em;
-}
-
-/* Site Notice (includes notices from CentralNotice extension) */
-#siteNotice {
- font-size: 0.8em;
-}
-
-.redirectText {
- font-size: 140%;
-}
-
-.redirectMsg img {
- vertical-align: text-bottom;
-}
-
-.mw-body-content {
- position: relative;
- line-height: @content-line-height;
- font-size: @content-font-size;
-}
+++ /dev/null
-@import "mediawiki.mixins.less";
-// External links
-#content {
- .external {
- background-position: center right;
- background-repeat: no-repeat;
- .background-image-svg('images/external-link-ltr-icon.svg', 'images/external-link-ltr-icon.png');
- padding-right: 13px;
- }
-}
+++ /dev/null
-/* Footer */
-div#footer {
- margin-left: 10em;
- margin-top: 0;
- padding: 0.75em;
- direction: ltr;
-
- ul {
- list-style-type: none;
- list-style-image: none;
- margin: 0;
- padding: 0;
-
- li {
- margin: 0;
- padding: 0;
- padding-top: 0.5em;
- padding-bottom: 0.5em;
- color: #333;
- font-size: 0.7em;
- }
- }
-
- #footer-icons {
- float: right;
-
- li {
- float: left;
- margin-left: 0.5em;
- line-height: 2em;
- text-align: right;
- }
- }
-
- #footer-info {
- li {
- line-height: 1.4em;
- }
- }
-
- #footer-places {
- li {
- float: left;
- margin-right: 1em;
- line-height: 2em;
- }
- }
-}
-
-body.ltr {
- div#footer {
- #footer-places {
- /* @noflip */
- float: left;
- }
- }
-}
+++ /dev/null
-@import "mediawiki.mixins";
-@import "personalMenu";
-@import "search";
-@import "tabs";
-
-/* Hide, but keep accessible for screen-readers */
-#mw-navigation h2 {
- position: absolute;
- top: -9999px;
-}
-
-/* Head */
-#mw-page-base {
- height: 5em;
- background-position: bottom left;
- background-repeat: repeat-x;
- /* This image is only a fallback (for IE 6-9), so we do not @embed it. */
- background-image: url('images/page-fade.png');
- .vertical-gradient(@body-background-color, @menu-background-color, 50%, 100%);
- background-color: @body-background-color;
-}
-
-#mw-head-base {
- margin-top: -5em;
- margin-left: 10em;
- height: 5em;
-}
-
-div#mw-head {
- position: absolute;
- top: 0;
- right: 0;
- width: 100%;
-
- h3 {
- margin: 0;
- padding: 0;
- }
-}
-
-/* Navigation Containers */
-#left-navigation {
- float: left;
- margin-left: 10em;
- margin-top: 2.5em;
- /* When right nav would overlap left nav, it's placed below it
- (normal CSS floats behavior). This rule ensures that no empty space
- is shown between them due to right nav's margin-top. Page layout
- is still broken, but at least the nav overlaps only the page title
- instead of half the content. */
- margin-bottom: -2.5em;
- /* IE 6 double-margin bug fix */
- display: inline;
-}
-
-#right-navigation {
- float: right;
- margin-top: 2.5em;
-}
-
-/* Logo */
-#p-logo {
- position: absolute;
- top: -160px;
- left: 0;
- width: 10em;
- height: 160px;
-
- a {
- display: block;
- width: 10em;
- height: 160px;
- background-repeat: no-repeat;
- background-position: center center;
- text-decoration: none;
- }
-}
-
-/* Panel */
-div#mw-panel {
- font-size: @menu-main-font-size;
- position: absolute;
- top: 160px;
- padding-top: 1em;
- width: 10em;
- left: 0;
-
- div.portal {
- margin: 0 0.6em 0 0.7em;
- padding: 0.25em 0;
- direction: ltr;
- background-position: top left;
- background-repeat: no-repeat;
- .background-image('images/portal-break.png');
-
- h3 {
- font-size: @menu-main-heading-font-size;
- color: @menu-main-heading-color;
- font-weight: normal;
- margin: 0;
- padding: @menu-main-heading-padding;
- cursor: default;
- border: none;
- }
-
- div.body {
- margin: @menu-main-body-margin;
- padding-top: 0;
-
- ul {
- list-style-type: none;
- list-style-image: none;
- margin: 0;
- padding: @menu-main-body-padding;
-
- li {
- line-height: 1.125em;
- margin: 0;
- padding: 0.25em 0;
- font-size: @menu-main-body-font-size;
- word-wrap: break-word;
-
- a {
- color: @menu-main-body-link-color;
- &:visited {
- color: @menu-main-body-link-visited-color;
- }
- }
- }
- }
- }
-
- &.first {
- background-image: none;
- margin-top: 0;
- h3 {
- display: none;
- }
- div.body {
- margin-left: 0.5em;
- }
- }
- }
-}
+++ /dev/null
-/* Personal */
-#p-personal {
- position: absolute;
- top: 0.33em;
- right: 0.75em;
- /* Display on top of page tabs - bugs 37158, 48078 */
- z-index: 100;
-
- h3 {
- display: none;
- }
-
- ul {
- list-style-type: none;
- list-style-image: none;
- margin: 0;
- padding-left: 10em; /* Keep from overlapping logo */
- }
-
- li {
- line-height: 1.125em;
- /* @noflip */
- float: left;
- margin-left: 0.75em;
- margin-top: 0.5em;
- font-size: @menu-personal-font-size;
- white-space: nowrap;
- }
-}
-
-/* Icon for Usernames */
-#pt-userpage,
-#pt-anonuserpage,
-#pt-login {
- background-position: left top;
- background-repeat: no-repeat;
- /* SVG support using a transparent gradient to guarantee cross-browser
- * compatibility (browsers able to understand gradient syntax support also SVG) */
- .background-image-svg('images/user-icon.svg', 'images/user-icon.png');
- padding-left: 15px !important;
-}
+++ /dev/null
-/* Search */
-#p-search {
- /* @noflip */
- float: left;
- margin-right: 0.5em;
- margin-left: 0.5em;
-
- h3 {
- display: none;
- }
-
- form,
- input {
- margin: 0;
- margin-top: 0.4em;
- }
-}
-
-div#simpleSearch {
- display: block;
- width: 14em;
- height: 1.4em;
- margin-top: 0.65em;
- position: relative;
- min-height: 1px; /* Gotta trigger hasLayout for IE7 */
- border: solid 1px #aaa;
- color: black;
- background-color: white;
- .background-image('images/search-fade.png');
- background-position: top left;
- background-repeat: repeat-x;
-
- // Styles for both the search input and the button
- input {
- position: absolute;
- margin: 0;
- padding: 0;
- border: 0;
- background-color: transparent;
- color: black;
- }
-
- // The search input
- #searchInput {
- top: 0;
- left: 0;
- width: 90%;
- padding: 0.2em 0 0.2em 0.2em;
- font-size: 13px;
- direction: ltr;
-
- &:focus {
- outline: none;
- }
-
- // These rules MAY NOT be merged because of how CSS requires browsers
- // to parse unrecognized selectors!
- // Note these rules ensure that placeholder text can be distinguished from
- // standard text. In browsers which make this distinction clear these rules
- // are not necessary.
- // For inputs that use jquery.placeholder.js e.g. IE9-
- &.placeholder {
- color: #999;
- }
- // Distinguish placeholder text in IE10+
- &:-ms-input-placeholder {
- color: #999;
- }
- // Distinguish placeholder text in Firefox 18-
- &:-moz-placeholder {
- color: #999;
- }
-
- // Undo the styles Webkit browsers apply to type=search fields,
- // we provide our own
- -webkit-appearance: textfield;
-
- &::-webkit-search-decoration,
- &::-webkit-search-cancel-button,
- &::-webkit-search-results-button,
- &::-webkit-search-results-decoration {
- -webkit-appearance: textfield;
- }
- }
-
- // The buttons. They are displayed in the same position, and if both are
- // present the fulltext search one obscures the 'Go' one.
- #searchButton,
- #mw-searchButton {
- top: 0;
- right: 0;
- width: 10%;
- height: 100%;
- cursor: pointer;
- /* Hide button text and replace it with the image. */
- /* This would be 100% if not for Firefox shenanigans (bug 60900). */
- text-indent: 200%;
- /* Needed to make IE6 respect the text-indent. */
- line-height: 1;
- /* Opera 12 on RTL flips the text in a funny way without this. */
- /* @noflip */
- direction: ltr;
- white-space: nowrap;
- overflow: hidden;
- .background-image-svg('images/search-ltr.svg', 'images/search-ltr.png');
- background-position: center center;
- background-repeat: no-repeat;
- }
-
- #mw-searchButton {
- z-index: 1;
- }
-}
+++ /dev/null
-/*
-Styling for namespace tabs (page, discussion) and views (read, edit, view history, watch and other actions)
-*/
-
-/* Navigation Labels */
-div.vectorTabs h3 {
- display: none;
-}
-
-/* Namespaces and Views */
-div.vectorTabs {
- /* @noflip */
- float: left;
- height: 2.5em;
- .background-image('images/tab-break.png');
- background-position: bottom left;
- background-repeat: no-repeat;
- padding-left: 1px;
-
- ul {
- /* @noflip */
- float: left;
- height: 100%;
- list-style-type: none;
- list-style-image: none;
- margin: 0;
- padding: 0;
- .background-image('images/tab-break.png');
- background-position: right bottom;
- background-repeat: no-repeat;
-
- li {
- /* @noflip */
- float: left;
- line-height: 1.125em;
- /* For IE6, overridden later to display:block by modern browsers */
- display: inline-block;
- height: 100%;
- margin: 0;
- padding: 0;
- background-color: #f3f3f3;
- .background-image('images/tab-normal-fade.png');
- background-position: bottom left;
- background-repeat: repeat-x;
- white-space: nowrap;
- }
-
- /* IGNORED BY IE6 which doesn't support child selector */
- > li {
- display: block;
- }
- }
-
- li {
- &.new {
- a,
- a:visited{
- color: #a55858;
- }
- }
-
- &.selected {
- .background-image('images/tab-current-fade.png');
- a,
- a:visited{
- color: #333;
- text-decoration: none;
- }
- }
-
- &.icon {
- a {
- background-position: bottom right;
- background-repeat: no-repeat;
- }
- }
-
- a {
- /* For IE6, overridden later to display:block by modern browsers */
- display: inline-block;
- height: 1.9em;
- padding-left: 0.5em;
- padding-right: 0.5em;
- color: @menu-link-color;
- cursor: pointer;
- font-size: 0.8em;
- }
-
- /* Ignored by IE6 which doesn't support child selector */
- > a {
- display: block;
- }
- }
-
- span {
- display: inline-block;
- .background-image('images/tab-break.png');
- background-position: bottom right;
- background-repeat: no-repeat;
-
- a {
- /* For IE6, overridden later to display:block by modern browsers */
- display: inline-block;
- padding-top: 1.25em;
- }
-
- /* Ignored by IE6 which doesn't support child selector */
- > a {
- /* @noflip */
- float: left;
- display: block;
- }
- }
-}
-
-/* Variants and Actions */
-div.vectorMenu {
- /* @noflip */
- direction: ltr;
- /* @noflip */
- float: left;
- cursor: pointer;
- position: relative;
-}
-
-body.rtl div.vectorMenu {
- /* @noflip */
- direction: rtl;
-}
-
-div#mw-head div.vectorMenu h3 {
- /* @noflip */
- float: left;
- .background-image('images/tab-break.png');
- background-repeat: no-repeat;
- background-position: bottom right;
- margin-left: -1px;
- font-size: 1em;
- height: 2.5em;
- // This effectively moves the "background border" outside of the element to act like a real
- // border. It is necessary for the dropdown (div.vectorMenu div.menu) to align well.
- padding-right: 1px;
- margin-right: -1px;
-}
-
-// The "Variants" menu has a really funny structure
-// Temporary WMF deployment hack, to be removed before 1.24 release
-div#mw-head div.vectorMenu#p-variants {
- #p-variants-label span {
- display: none;
- }
-
- #mw-vector-current-variant {
- display: inline-block;
- float: left;
- padding-right: 20px;
- font-size: 0.8em;
- padding-left: 0.5em;
- padding-top: 1.375em;
- font-weight: normal;
- border: none;
- background-image: none;
- }
-}
-
-div.vectorMenu h3 span {
- display: block;
- font-size: 0.8em;
- padding-left: 0.7em;
- padding-top: 1.375em;
- margin-right: 20px;
- font-weight: normal;
- color: @menu-main-heading-color;
-}
-
-div.vectorMenu h3 a {
- position: absolute;
- top: 0;
- right: 0;
- width: 20px;
- height: 2.5em;
- .background-image-svg('images/arrow-down-icon.svg', 'images/arrow-down-icon.png');
- background-position: 100% 70%;
- background-repeat: no-repeat;
- .transition(background-position 250ms);
-}
-
-div.vectorMenu.menuForceShow h3 a {
- background-position: 100% 100%;
-}
-
-div.vectorMenuFocus h3 a {
- .background-image-svg('images/arrow-down-focus-icon.svg', 'images/arrow-down-focus-icon.png');
-}
-
-div.vectorMenu div.menu {
- // Match the width of the dropdown "heading" (the tab)
- min-width: 100%;
- position: absolute;
- top: 2.5em;
- left: -1px;
- background-color: white;
- border: solid 1px silver;
- border-top-width: 0;
- clear: both;
- text-align: left;
- display: none;
-}
-
-/* Enable forcing showing of the menu for accessibility */
-div.vectorMenu:hover div.menu,
-div.vectorMenu.menuForceShow div.menu {
- display: block;
-}
-
-div.vectorMenu ul {
- list-style-type: none;
- list-style-image: none;
- padding: 0;
- margin: 0;
- text-align: left;
-}
-
-/* Fixes old versions of FireFox */
-div.vectorMenu ul,
-x:-moz-any-link {
- min-width: 5em;
-}
-
-/* Returns things back to normal in modern versions of FireFox */
-div.vectorMenu ul,
-x:-moz-any-link,
-x:default {
- min-width: 0;
-}
-
-div.vectorMenu li {
- padding: 0;
- margin: 0;
- text-align: left;
- line-height: 1em;
-}
-
-/* OVERRIDDEN BY COMPLIANT BROWSERS */
-div.vectorMenu li a {
- display: inline-block;
- padding: 0.5em;
- white-space: nowrap;
- color: @menu-link-color;
- cursor: pointer;
- font-size: 0.8em;
-}
-
-/* IGNORED BY IE6 */
-div.vectorMenu li > a {
- display: block;
-}
-
-div.vectorMenu li.selected a,
-div.vectorMenu li.selected a:visited {
- color: #333;
- text-decoration: none;
-}
-
-@import 'watchstar.less';
+++ /dev/null
-@import "mediawiki.mixins.rotation"
-
-/* Watch/Unwatch Icon Styling */
-#ca-unwatch.icon a,
-#ca-watch.icon a {
- margin: 0;
- padding: 0;
- display: block;
- width: 26px;
- /* This hides the text but shows the background image */
- padding-top: 3.1em;
- margin-top: 0;
- /* Only applied in IE6 */
- margin-top: -0.8em !ie;
- height: 0;
- overflow: hidden;
- background-position: 5px 60%;
-}
-#ca-unwatch.icon a {
- .background-image-svg('images/unwatch-icon.svg', 'images/unwatch-icon.png');
-}
-#ca-watch.icon a {
- .background-image-svg('images/watch-icon.svg', 'images/watch-icon.png');
-}
-#ca-unwatch.icon a:hover,
-#ca-unwatch.icon a:focus {
- .background-image-svg('images/unwatch-icon-hl.svg', 'images/unwatch-icon-hl.png');
-}
-#ca-watch.icon a:hover,
-#ca-watch.icon a:focus {
- .background-image-svg('images/watch-icon-hl.svg', 'images/watch-icon-hl.png');
-}
-#ca-unwatch.icon a.loading,
-#ca-watch.icon a.loading {
- .background-image-svg('images/watch-icon-loading.svg', 'images/watch-icon-loading.png');
- .rotation(700ms);
- /* Suppress the hilarious rotating focus outline on Firefox */
- outline: none;
- cursor: default;
- pointer-events: none;
- background-position: 50% 60%;
- -webkit-transform-origin: 50% 57%;
- transform-origin: 50% 57%;
-}
-#ca-unwatch.icon a span,
-#ca-watch.icon a span {
- display: none;
-}
+++ /dev/null
-<public:attach event="ondocumentready" onevent="CSSHover()" />
-<script>
-/**
- * Whatever:hover - V3.11
- * ------------------------------------------------------------
- * Author - Peter Nederlof, http://www.xs4all.nl/~peterned
- * License - http://creativecommons.org/licenses/LGPL/2.1
- *
- * Special thanks to Sergiu Dumitriu, http://purl.org/net/sergiu,
- * for fixing the expression loop.
- *
- * Whatever:hover is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2.1 of the License, or (at your option) any later version.
- *
- * Whatever:hover 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
- * Lesser General Public License for more details.
- *
- * howto: body { behavior:url("csshover3.htc"); }
- * ------------------------------------------------------------
- */
-
-window.CSSHover = (function(){
-
- // regular expressions, used and explained later on.
- var REG_INTERACTIVE = /(^|\s)((([^a]([^ ]+)?)|(a([^#.][^ ]+)+)):(hover|active|focus))/i;
- var REG_AFFECTED = /(.*?)\:(hover|active|focus)/i;
- var REG_PSEUDO = /[^:]+:([a-z\-]+).*/i;
- var REG_SELECT = /(\.([a-z0-9_\-]+):[a-z]+)|(:[a-z]+)/gi;
- var REG_CLASS = /\.([a-z0-9_\-]*on(hover|active|focus))/i;
- var REG_MSIE = /msie (5|6|7)/i;
- var REG_COMPAT = /backcompat/i;
-
- // property mapping, real css properties must be used in order to clear expressions later on...
- // Uses obscure css properties that no-one is likely to use. The properties are borrowed to
- // set an expression, and are then restored to the most likely correct value.
- var Properties = {
- index: 0,
- list: ['text-kashida', 'text-kashida-space', 'text-justify'],
- get: function() {
- return this.list[(this.index++)%this.list.length];
- }
- };
-
- // camelize is used to convert css properties from (eg) text-kashida to textKashida
- var camelize = function(str) {
- return str.replace(/-(.)/mg, function(result, match){
- return match.toUpperCase();
- });
- };
-
- /**
- * Local CSSHover object
- * --------------------------
- */
-
- var CSSHover = {
-
- // array of CSSHoverElements, used to unload created events
- elements: [],
-
- // buffer used for checking on duplicate expressions
- callbacks: {},
-
- // init, called once ondomcontentready via the exposed window.CSSHover function
- init:function() {
- // don't run in IE8 standards; expressions don't work in standards mode anyway,
- // and the stuff we're trying to fix should already work properly
- if(!REG_MSIE.test(navigator.userAgent) && !REG_COMPAT.test(window.document.compatMode)) {
- return;
- }
-
- // start parsing the existing stylesheets
- var sheets = window.document.styleSheets, l = sheets.length;
- for(var i=0; i<l; i++) {
- this.parseStylesheet(sheets[i]);
- }
- },
-
- // called from init, parses individual stylesheets
- parseStylesheet:function(sheet) {
- // check sheet imports and parse those recursively
- if(sheet.imports) {
- try {
- var imports = sheet.imports;
- var l = imports.length;
- for(var i=0; i<l; i++) {
- this.parseStylesheet(sheet.imports[i]);
- }
- } catch(securityException){
- // trycatch for various possible errors
- }
- }
-
- // interate the sheet's rules and send them to the parser
- try {
- var rules = sheet.rules;
- var r = rules.length;
- for(var j=0; j<r; j++) {
- this.parseCSSRule(rules[j], sheet);
- }
- } catch(someException){
- // trycatch for various errors, most likely accessing the sheet's rules.
- }
- },
-
- // magic starts here ...
- parseCSSRule:function(rule, sheet) {
-
- // The sheet is used to insert new rules into, this must be the same sheet the rule
- // came from, to ensure that relative paths keep pointing to the right location.
-
- // only parse a rule if it contains an interactive pseudo.
- var select = rule.selectorText;
- if(REG_INTERACTIVE.test(select)) {
- var style = rule.style.cssText;
-
- // affected elements are found by truncating the selector after the interactive pseudo,
- // eg: "div li:hover" >> "div li"
- var affected = REG_AFFECTED.exec(select)[1];
-
- // that pseudo is needed for a classname, and defines the type of interaction (focus, hover, active)
- // eg: "li:hover" >> "onhover"
- var pseudo = select.replace(REG_PSEUDO, 'on$1');
-
- // the new selector is going to use that classname in a new css rule,
- // since IE6 doesn't support multiple classnames, this is merged into one classname
- // eg: "li:hover" >> "li.onhover", "li.folder:hover" >> "li.folderonhover"
- var newSelect = select.replace(REG_SELECT, '.$2' + pseudo);
-
- // the classname is needed for the events that are going to be set on affected nodes
- // eg: "li.folder:hover" >> "folderonhover"
- var className = REG_CLASS.exec(newSelect)[1];
-
- // no need to set the same callback more than once when the same selector uses the same classname
- var hash = affected + className;
- if(!this.callbacks[hash]) {
-
- // affected elements are given an expression under a borrowed css property, because fake properties
- // can't have their expressions cleared. Different properties are used per pseudo, to avoid
- // expressions from overwriting eachother. The expression does a callback to CSSHover.patch,
- // rerouted via the exposed window.CSSHover function.
- var property = Properties.get();
- var atRuntime = camelize(property);
-
- // because the expression is added to the stylesheet, and styles are always applied to html that is
- // dynamically added to the dom, the expression will also trigger for those new elements (provided
- // they are selected by the affected selector).
- sheet.addRule(affected, property + ':expression(CSSHover(this, "'+pseudo+'", "'+className+'", "'+atRuntime+'"))');
-
- // hash it, so an identical selector/class combo does not duplicate the expression
- this.callbacks[hash] = true;
- }
-
- // duplicate expressions need not be set, but the style could differ
- sheet.addRule(newSelect, style);
- }
- },
-
- // called via the expression, patches individual nodes
- patch:function(node, type, className, property) {
-
- // restores the borrowed css property to the value of its immediate parent, clearing
- // the expression so that it's not repeatedly called.
- try {
- var value = node.parentNode.currentStyle[property];
- node.style[property] = value;
- } catch(e) {
- // the above reset should never fail, but just in case, clear the runtimeStyle if it does.
- // this will also stop the expression.
- node.runtimeStyle[property] = '';
- }
-
- // just to make sure, also keep track of patched classnames locally on the node
- if(!node.csshover) {
- node.csshover = [];
- }
-
- // and check for it to prevent duplicate events with the same classname from being set
- if(!node.csshover[className]) {
- node.csshover[className] = true;
-
- // create an instance for the given type and class
- var element = new CSSHoverElement(node, type, className);
-
- // and store that instance for unloading later on
- this.elements.push(element);
- }
-
- // returns a dummy value to the expression
- return type;
- },
-
- // unload stuff onbeforeunload
- unload:function() {
- try {
-
- // remove events
- var l = this.elements.length;
- for(var i=0; i<l; i++) {
- this.elements[i].unload();
- }
-
- // and set properties to null
- this.elements = [];
- this.callbacks = {};
-
- } catch (e) {
- }
- }
- };
-
- /**
- * CSSHoverElement
- * --------------------------
- */
-
- // the event types associated with the interactive pseudos
- var CSSEvents = {
- onhover: { activator: 'onmouseenter', deactivator: 'onmouseleave' },
- onactive: { activator: 'onmousedown', deactivator: 'onmouseup' },
- onfocus: { activator: 'onfocus', deactivator: 'onblur' }
- };
-
- // CSSHoverElement constructor, called via CSSHover.patch
- function CSSHoverElement(node, type, className) {
-
- // the CSSHoverElement patches individual nodes by manually applying the events that should
- // have fired by the css pseudoclasses, eg mouseenter and mouseleave for :hover.
-
- this.node = node;
- this.type = type;
- var replacer = new RegExp('(^|\\s)'+className+'(\\s|$)', 'g');
-
- // store event handlers for removal onunload
- this.activator = function(){ node.className += ' ' + className; };
- this.deactivator = function(){ node.className = node.className.replace(replacer, ' '); };
-
- // add the events
- node.attachEvent(CSSEvents[type].activator, this.activator);
- node.attachEvent(CSSEvents[type].deactivator, this.deactivator);
- }
-
- CSSHoverElement.prototype = {
- // onbeforeunload, called via CSSHover.unload
- unload:function() {
-
- // remove events
- this.node.detachEvent(CSSEvents[this.type].activator, this.activator);
- this.node.detachEvent(CSSEvents[this.type].deactivator, this.deactivator);
-
- // and set properties to null
- this.activator = null;
- this.deactivator = null;
- this.node = null;
- this.type = null;
- }
- };
-
- // add the unload to the onbeforeunload event
- window.attachEvent('onbeforeunload', function(){
- CSSHover.unload();
- });
-
- /**
- * Public hook
- * --------------------------
- */
-
- return function(node, type, className, property) {
- if(node) {
- // called via the css expression; patches individual nodes
- return CSSHover.patch(node, type, className, property);
- } else {
- // called ondomcontentready via the public:attach node
- CSSHover.init();
- }
- };
-
-})();
-</script>
\ No newline at end of file
+++ /dev/null
-<public:attach event="ondocumentready" onevent="CSSHover()" />
-<script>
-/**
- * Whatever:hover - V3.11
- * http://www.xs4all.nl/~peterned/
- *
- * Copyright (c) 2009 Peter Nederlof
- * Licensed under the LGPL license
- * http://creativecommons.org/licenses/LGPL/2.1
- */
-window.CSSHover=(function(){var m=/(^|\s)((([^a]([^ ]+)?)|(a([^#.][^ ]+)+)):(hover|active|focus))/i;var n=/(.*?)\:(hover|active|focus)/i;var o=/[^:]+:([a-z\-]+).*/i;var p=/(\.([a-z0-9_\-]+):[a-z]+)|(:[a-z]+)/gi;var q=/\.([a-z0-9_\-]*on(hover|active|focus))/i;var s=/msie (5|6|7)/i;var t=/backcompat/i;var u={index:0,list:['text-kashida','text-kashida-space','text-justify'],get:function(){return this.list[(this.index++)%this.list.length]}};var v=function(c){return c.replace(/-(.)/mg,function(a,b){return b.toUpperCase()})};var w={elements:[],callbacks:{},init:function(){if(!s.test(navigator.userAgent)&&!t.test(window.document.compatMode)){return}var a=window.document.styleSheets,l=a.length;for(var i=0;i<l;i++){this.parseStylesheet(a[i])}},parseStylesheet:function(a){if(a.imports){try{var b=a.imports;var l=b.length;for(var i=0;i<l;i++){this.parseStylesheet(a.imports[i])}}catch(securityException){}}try{var c=a.rules;var r=c.length;for(var j=0;j<r;j++){this.parseCSSRule(c[j],a)}}catch(someException){}},parseCSSRule:function(a,b){var c=a.selectorText;if(m.test(c)){var d=a.style.cssText;var e=n.exec(c)[1];var f=c.replace(o,'on$1');var g=c.replace(p,'.$2'+f);var h=q.exec(g)[1];var i=e+h;if(!this.callbacks[i]){var j=u.get();var k=v(j);b.addRule(e,j+':expression(CSSHover(this, "'+f+'", "'+h+'", "'+k+'"))');this.callbacks[i]=true}b.addRule(g,d)}},patch:function(a,b,c,d){try{var f=a.parentNode.currentStyle[d];a.style[d]=f}catch(e){a.runtimeStyle[d]=''}if(!a.csshover){a.csshover=[]}if(!a.csshover[c]){a.csshover[c]=true;var g=new CSSHoverElement(a,b,c);this.elements.push(g)}return b},unload:function(){try{var l=this.elements.length;for(var i=0;i<l;i++){this.elements[i].unload()}this.elements=[];this.callbacks={}}catch(e){}}};var x={onhover:{activator:'onmouseenter',deactivator:'onmouseleave'},onactive:{activator:'onmousedown',deactivator:'onmouseup'},onfocus:{activator:'onfocus',deactivator:'onblur'}};function CSSHoverElement(a,b,c){this.node=a;this.type=b;var d=new RegExp('(^|\\s)'+c+'(\\s|$)','g');this.activator=function(){a.className+=' '+c};this.deactivator=function(){a.className=a.className.replace(d,' ')};a.attachEvent(x[b].activator,this.activator);a.attachEvent(x[b].deactivator,this.deactivator)}CSSHoverElement.prototype={unload:function(){this.node.detachEvent(x[this.type].activator,this.activator);this.node.detachEvent(x[this.type].deactivator,this.deactivator);this.activator=null;this.deactivator=null;this.node=null;this.type=null}};window.attachEvent('onbeforeunload',function(){w.unload()});return function(a,b,c,d){if(a){return w.patch(a,b,c,d)}else{w.init()}}})();
-</script>
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Temuri rajavi"
- ]
- },
- "vector-action-move": "Ахьӡ аҧсахра",
- "vector-view-create": "Арҿиара",
- "vector-view-edit": "Ариашамҭа",
- "vector-view-history": "Аҭоурых",
- "vector-view-view": "Аҧхьара",
- "vector-view-viewsource": "Ахәаҧшра"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Fadli Idris",
- "Si Gam Acèh"
- ]
- },
- "vector-action-addsection": "Tamah bhaih",
- "vector-action-delete": "Sampôh",
- "vector-action-move": "Pupinah",
- "vector-action-protect": "Peulindông",
- "vector-action-undelete": "Bateuë sampôh",
- "vector-action-unprotect": "Gantoe neulindông",
- "vector-view-create": "Peugöt",
- "vector-view-edit": "Andam",
- "vector-view-history": "Eu riwayat",
- "vector-view-view": "Beuët",
- "vector-view-viewsource": "Eu nè"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Adamsa123",
- "Amire80",
- "Celekan",
- "Siklawy"
- ]
- },
- "vector-action-addsection": "1офтхьабз",
- "vector-action-delete": "ЛъэкӀ",
- "vector-action-move": "Хьы",
- "vector-action-protect": "Иухъумэ",
- "vector-action-undelete": "Умылъэк1",
- "vector-action-unprotect": "Умыухъумэ",
- "vector-view-create": "Игъэхъу",
- "vector-view-edit": "Гъэтэрэзыжь",
- "vector-view-history": "Тарихъым eплъ",
- "vector-view-view": "Едж",
- "vector-view-viewsource": "Еплъ лъапсэм"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Csisc",
- "Malekbr"
- ]
- },
- "vector-action-addsection": "أضف موضوعا",
- "vector-action-delete": "احذف",
- "vector-action-move": "انقل",
- "vector-action-protect": "احم",
- "vector-action-undelete": "استرجع الحذف",
- "vector-action-unprotect": "غير الحماية",
- "vector-view-create": "أنشئ",
- "vector-view-edit": "Baddel",
- "vector-view-history": "Warri l'historique",
- "vector-view-view": "Aqra",
- "vector-view-viewsource": "اعرض المصدر"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Byeboer",
- "Naudefj"
- ]
- },
- "vector-action-addsection": "Nuwe onderwerp",
- "vector-action-delete": "Skrap",
- "vector-action-move": "Skuif",
- "vector-action-protect": "Beskerm",
- "vector-action-undelete": "Ontskrap",
- "vector-action-unprotect": "Wysig beskerming",
- "vector-view-create": "Skep",
- "vector-view-edit": "Wysig",
- "vector-view-history": "Wys geskiedenis",
- "vector-view-view": "Lees",
- "vector-view-viewsource": "Wys bronteks",
- "vector-more-actions": "Meer"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Bresta"
- ]
- },
- "vector.css": "/* CSSi i vednosun këtu ka me i prekë shfrytëzuesit e dukjes Vector */",
- "vector.js": "/* Çdo JavaScript këtu ka me u ngarkue për shfrytëzuesit që përdorin dukjen Vector */",
- "vector-action-addsection": "Shto temë",
- "vector-action-delete": "Fshij",
- "vector-action-move": "Zhvendos",
- "vector-action-protect": "Mbroj",
- "vector-action-undelete": "Kthe fshimjen mbrapsht",
- "vector-action-unprotect": "Hiq mbrojtjen",
- "vector-view-create": "Krijo",
- "vector-view-edit": "Redakto",
- "vector-view-history": "Shih historinë",
- "vector-view-view": "Lexo",
- "vector-view-viewsource": "Shih kodin"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Codex Sinaiticus",
- "Elfalem",
- "Hinstein",
- "Teferra"
- ]
- },
- "vector-action-addsection": "ርዕስ ጨምር",
- "vector-action-delete": "አጥፋ",
- "vector-action-move": "ለማዛወር",
- "vector-action-protect": "ለመቆለፍ",
- "vector-action-undelete": "አታጥፋ",
- "vector-action-unprotect": "አለመቆለፍ",
- "vector-view-create": "አዲስ ፍጠር",
- "vector-view-edit": "አርም",
- "vector-view-history": "ታሪኩን አሳይ",
- "vector-view-view": "ለማንበብ",
- "vector-view-viewsource": "ጥሬ ኮድ ለመመልከት",
- "vector-more-actions": "ተጨማሪ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Juanpabl"
- ]
- },
- "skinname-vector": "Vector",
- "vector.css": "/* Os estilos CSS colocaus aquí s'aplicarán ta totz os usuarios que faigan servir l'apariencia Vector */",
- "vector.js": "/* Qualsiquier codigo Javascript escrito aquí se cargará ta totz os usuarios que usen a piel Vector */",
- "vector-action-addsection": "Adhibir nueva sección",
- "vector-action-delete": "Borrar",
- "vector-action-move": "Tresladar",
- "vector-action-protect": "Protecher",
- "vector-action-undelete": "Restaurar",
- "vector-action-unprotect": "Cambiar protección",
- "vector-view-create": "Creyar",
- "vector-view-edit": "Editar",
- "vector-view-history": "Amostrar l'historial",
- "vector-view-view": "Leyer",
- "vector-view-viewsource": "Veyer o codigo fuent"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Gott wisst"
- ]
- },
- "vector-action-addsection": "Besettan mearcunge",
- "vector-action-delete": "Forlēosan",
- "vector-action-move": "Wegan",
- "vector-action-protect": "Beorgan",
- "vector-action-undelete": "Scieppan tramet eft",
- "vector-action-unprotect": "Andwendan beorgunge",
- "vector-view-create": "Scieppan",
- "vector-view-edit": "Adihtan",
- "vector-view-history": "Stǣr",
- "vector-view-view": "Rǣdan",
- "vector-view-viewsource": "Sēon fruman"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Abanima",
- "Calak",
- "Meno25",
- "Mido",
- "OsamaK",
- "أحمد",
- "زكريا"
- ]
- },
- "skinname-vector": "فكتور",
- "vector.css": "/* الأنماط المتراصة CSS المعروضة هنا ستؤثر على مستخدمي واجهة فكتور */",
- "vector.js": "/* أي جافاسكريبت هنا سيتم تحميلها للمستخدمين الذين يستعملون واجهة فكتور */",
- "vector-action-addsection": "أضف موضوعا",
- "vector-action-delete": "احذف",
- "vector-action-move": "انقل",
- "vector-action-protect": "احم",
- "vector-action-undelete": "ألغ الحذف",
- "vector-action-unprotect": "غير الحماية",
- "vector-view-create": "أنشئ",
- "vector-view-edit": "عدل",
- "vector-view-history": "اعرض التاريخ",
- "vector-view-view": "اقرأ",
- "vector-view-viewsource": "اعرض المصدر",
- "vector-more-actions": "مزيد"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "334a",
- "Basharh",
- "Michaelovic"
- ]
- },
- "vector-action-addsection": "ܐܘܣܦ ܡܠܘܐܐ",
- "vector-action-delete": "ܫܘܦ",
- "vector-action-move": "ܫܢܝ",
- "vector-action-protect": "ܛܪ",
- "vector-action-undelete": "ܠܐ ܫܘܦ",
- "vector-action-unprotect": "ܫܚܠܦ ܢܛܝܪܘܬܐ",
- "vector-view-create": "ܒܪܝ",
- "vector-view-edit": "ܫܚܠܦ",
- "vector-view-history": "ܚܙܝ ܬܫܥܝܬܐ",
- "vector-view-view": "ܩܪܝ",
- "vector-view-viewsource": "ܚܙܝ ܡܒܘܥܐ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Clerc",
- "Fiestoforo"
- ]
- },
- "vector-action-addsection": "Püñamtun dungu",
- "vector-action-delete": "Liftun",
- "vector-action-move": "Wiñamün",
- "vector-action-protect": "Nürüfkünun",
- "vector-action-undelete": "Wüñoñamümün",
- "vector-action-unprotect": "Kalekünun Nürüfkünun",
- "vector-view-create": "Dewman",
- "vector-view-edit": "Kümeelün",
- "vector-view-history": "Pengelün rupañmael",
- "vector-view-view": "Chillkatun",
- "vector-view-viewsource": "Kimam chew küpan chi wirin"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ooswesthoesbes"
- ]
- },
- "vector-view-edit": "Imeakie"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Bachounda",
- "Oldstoneage"
- ]
- },
- "vector-action-addsection": "زيد موضوع",
- "vector-action-delete": "امحي",
- "vector-action-move": "حول",
- "vector-action-protect": "بروجي",
- "vector-action-undelete": "ردّ كيما كان",
- "vector-action-unprotect": "بدّل الـحماية",
- "vector-view-create": "أصنع",
- "vector-view-edit": "بدل",
- "vector-view-history": "روح للتاريخي",
- "vector-view-view": "أقرى",
- "vector-view-viewsource": "شوف المصدر"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Enzoreg",
- "Zanatos"
- ]
- },
- "vector-action-addsection": "Zid topic",
- "vector-action-delete": "Suprimi",
- "vector-action-move": "Neqel",
- "vector-action-protect": "Ḫami",
- "vector-action-undelete": "rja lhadf",
- "vector-action-unprotect": "Ḫiyed l-ḫimaya",
- "vector-view-create": "Ĥṫareĝ",
- "vector-view-edit": "Ĝedel",
- "vector-view-history": "Ṫariĥ l-fiċyé",
- "vector-view-view": "Qra",
- "vector-view-viewsource": "Ċof l-masdar"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ghaly",
- "Meno25",
- "Ramsis II"
- ]
- },
- "vector.css": "/* CSS اللى هنا حتأثر على اليوزرز اللى بيستخدموا واجهة فكتور */",
- "vector.js": "/* اى جافاسكريبت هنا حتتحمل لكل يوزر بيستخدم واجهة فكتور */",
- "vector-action-addsection": "ضيف موضوع",
- "vector-action-delete": "مسح",
- "vector-action-move": "نقل",
- "vector-action-protect": "حمايه",
- "vector-action-undelete": "الغى المسح",
- "vector-action-unprotect": "غير الحمايه",
- "vector-view-create": "اعمل",
- "vector-view-edit": "تعديل",
- "vector-view-history": "استعراض التاريخ",
- "vector-view-view": "قرايه",
- "vector-view-viewsource": "استعراض المصدر"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Bishnu Saikia",
- "Chaipau",
- "Gitartha.bordoloi"
- ]
- },
- "vector-action-addsection": "বিষয় যোগ",
- "vector-action-delete": "বিলোপ কৰক",
- "vector-action-move": "স্থানান্তৰ কৰক",
- "vector-action-protect": "সুৰক্ষিত কৰক",
- "vector-action-undelete": "পুনৰুদ্ধাৰ কৰক",
- "vector-action-unprotect": "সুৰক্ষা সলনি কৰক",
- "vector-view-create": "সৃষ্টি কৰক",
- "vector-view-edit": "সম্পাদনা",
- "vector-view-history": "ইতিহাস চাওক",
- "vector-view-view": "পঢ়ক",
- "vector-view-viewsource": "উৎস চাওক",
- "vector-more-actions": "অধিক"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Icemandeaf"
- ]
- },
- "skinname-vector": "M509x575S10e20494x425S14a20493x459S16d20492x478S1fb20494x502S17620493x525S11a20493x545",
- "vector-skin-desc": "M535x520S19a00507x481S19a08465x481S22f14465x506S22f04509x506 M515x598S18d20494x403S17620499x432S11920493x452S17620499x482S14720500x502S17620499x528S17620499x548S14020485x568 M521x508S1f748479x493S1f740501x493 M532x517S15a16505x505S2880f468x484S20e00491x495S1821d503x492 M534x547S2ff00482x483S10001513x517S2e305488x487 S38700463x496 M535x536S20300516x521S20308470x521S26500516x502S26510470x502S14c30511x465S14c38465x465 M526x522S15a56499x510S11520503x479S20e00489x496S26a02474x489 M520x540S37606481x460S15a40508x513S28801499x491S20500488x492",
- "vector.css": "/* M509x529S16d20492x471S20320493x495S20320493x514 M535x523S14c50508x492S14c58469x492S22520503x477S22520465x477 M525x525S10004510x475S22a04511x510S1000c476x475S22a14477x510 M534x518S2ff00482x483S15a10522x486S2b700514x458 M521x532S10609498x496S10621487x512S21100500x483S2df20479x468 M526x522S15a56499x510S11520503x479S20e00489x496S26a02474x489 M521x508S1f748479x493S1f740501x493 M509x575S10e20494x425S14a20493x459S16d20492x478S1fb20494x502S17620493x525S11a20493x545 M517x524S15a02484x477S15a20489x484S21100504x492S22a04504x509 */",
- "vector.js": "/* M520x523S1f540480x477S2a204497x495 M519x527S19220498x489S2a20c482x473S20320498x512 M525x525S10004510x475S22a04511x510S1000c476x475S22a14477x510 M534x518S2ff00482x483S15a10522x486S2b700514x458 M524x539S14402493x485S1440a486x461S22b00508x509S22b10476x483 M536x521S2ff00482x483S10011515x491S28108515x461 M526x522S15a56499x510S11520503x479S20e00489x496S26a02474x489 M509x575S10e20494x425S14a20493x459S16d20492x478S1fb20494x502S17620493x525S11a20493x545 M517x524S15a02484x477S15a20489x484S21100504x492S22a04504x509 */",
- "vector-action-addsection": "M532x517S15a16505x505S2880f468x484S20e00491x495S1821d503x492 M522x522S15a37478x479S10041485x492S20600500x492",
- "vector-action-delete": "M527x532S1ea40473x511S1f540512x478S22a07497x504S2f700512x468",
- "vector-action-move": "M552x509S18520488x494S18528449x494S26626522x492",
- "vector-action-protect": "M512x519S15a19488x482S15a11489x482S20600488x508",
- "vector-action-undelete": "M515x538S15a0a486x463S10050500x467S2330b485x516S20e00491x501 M527x532S1ea40473x511S1f540512x478S22a07497x504S2f700512x468",
- "vector-action-unprotect": "M521x532S10609498x496S10621487x512S21100500x483S2df20479x468 M512x519S15a19488x482S15a11489x482S20600488x508",
- "vector-view-create": "M532x519S20302493x485S2030a489x502S21100509x504S26900516x482S26910468x501",
- "vector-view-edit": "M521x532S10609498x496S10621487x512S21100500x483S2df20479x468",
- "vector-view-history": "M525x524S2ff00482x483S10e00507x494S26500511x474 M514x523S11541487x478S22f04489x509",
- "vector-view-view": "M513x540S15a06486x459S10e50494x474S22b04493x510",
- "vector-view-viewsource": "M525x524S2ff00482x483S10e00507x494S26500511x474 M509x545S16d20492x456S17620493x480S10120493x497S14a20494x530",
- "vector-more-actions": "M526x508S18510501x493S18518475x493"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Esbardu",
- "Xuacu"
- ]
- },
- "vector-skin-desc": "Versión moderna de MonoBook, con un aspeutu frescu y munchos ameyoramientos d'usabilidá",
- "vector.css": "/* Los CSS allugaos equí afeutarán a los usuarios del aspeutu Vector */",
- "vector.js": "/* Cualesquier JavaScript que tea equí se cargará pa los usuarios del aspeutu Vector */",
- "vector-action-addsection": "Amestar seición",
- "vector-action-delete": "Desaniciar",
- "vector-action-move": "Treslladar",
- "vector-action-protect": "Protexer",
- "vector-action-undelete": "Restaurar",
- "vector-action-unprotect": "Camudar la proteición",
- "vector-view-create": "Crear",
- "vector-view-edit": "Editar",
- "vector-view-history": "Ver historial",
- "vector-view-view": "Lleer",
- "vector-view-viewsource": "Ver fonte",
- "vector-more-actions": "Más"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Умар"
- ]
- },
- "vector-view-edit": "Хисизабизе"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Wikimistusik"
- ]
- },
- "vector-action-addsection": "Loplekura va detce",
- "vector-action-delete": "Sulara",
- "vector-action-move": "Arrundara",
- "vector-action-protect": "Nendara",
- "vector-view-create": "Redura",
- "vector-view-edit": "Betara",
- "vector-view-history": "Wira va izvot",
- "vector-view-view": "Belira",
- "vector-view-viewsource": "klitawira"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "AZISS",
- "Arystanbek",
- "Gulmammad",
- "Sortilegus",
- "Vago",
- "Vugar 1981",
- "Wertuose"
- ]
- },
- "skinname-vector": "Vector",
- "vector.css": "/* Burada yerləşən CSS Vector istifadəçilərinə tətbiq olunur */",
- "vector.js": "/* Burada Vector skin istifadəçiləri üçün istənilən JavaScript yüklənəcək */",
- "vector-action-addsection": "Mövzu əlavə et",
- "vector-action-delete": "Sil",
- "vector-action-move": "Adını dəyişdir",
- "vector-action-protect": "Mühafizə et",
- "vector-action-undelete": "Bərpa et",
- "vector-action-unprotect": "Mühafizəni kənarlaşdır",
- "vector-view-create": "Yarat",
- "vector-view-edit": "Redaktə",
- "vector-view-history": "Tarixçəyə bax",
- "vector-view-view": "Oxu",
- "vector-view-viewsource": "Mənbəyə bax",
- "vector-more-actions": "Daha"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "E THP",
- "Ebrahimi-amir",
- "Mousa"
- ]
- },
- "vector-action-addsection": "قوْنو آرتیر",
- "vector-action-delete": "سیل",
- "vector-action-move": "داشی",
- "vector-action-protect": "قوْرو",
- "vector-action-undelete": "سیلمگی قایتار",
- "vector-action-unprotect": "قوْروماغی دَییشدیر",
- "vector-view-create": "یارات",
- "vector-view-edit": "دَییشدیر",
- "vector-view-history": "گئچمیشه باخ",
- "vector-view-view": "اوْخو",
- "vector-view-viewsource": "قایناغا باخ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Assele",
- "Haqmar"
- ]
- },
- "skinname-vector": "Векторлы",
- "vector-action-addsection": "Тема өҫтәргә",
- "vector-action-delete": "Юйырға",
- "vector-action-move": "Исемен үҙгәртергә",
- "vector-action-protect": "Һаҡларға",
- "vector-action-undelete": "Тергеҙергә",
- "vector-action-unprotect": "Һаҡлауҙы үҙгәртергә",
- "vector-view-create": "Яһау",
- "vector-view-edit": "Үҙгәртергә",
- "vector-view-history": "Тарихты ҡарау",
- "vector-view-view": "Уҡыу",
- "vector-view-viewsource": "Сығанаҡты ҡарарға"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Adi Mayndra",
- "BASAbali"
- ]
- },
- "vector-action-addsection": "imbuhin indik wacana",
- "vector-action-delete": "ngapus",
- "vector-action-move": "kisidang",
- "vector-action-protect": "nyaga",
- "vector-view-create": "ngawe",
- "vector-view-edit": "mecikang",
- "vector-view-history": "indik sane lintang",
- "vector-view-view": "Waca",
- "vector-view-viewsource": "cingak witnyane"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Bua333",
- "Mucalexx"
- ]
- },
- "vector-action-addsection": "An Obschnitt dazua doa",
- "vector-action-delete": "Leschn",
- "vector-action-move": "Vaschiabm",
- "vector-action-protect": "Schitzn",
- "vector-action-undelete": "Wiederherstön",
- "vector-action-unprotect": "freigeem",
- "vector-view-create": "Aufbaun",
- "vector-view-edit": "Werkln",
- "vector-view-history": "Gschicht oschaugn",
- "vector-view-view": "Lesn",
- "vector-view-viewsource": "Quejtext ozoagn"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Daniel Harahap",
- "WBT003Bugari",
- "WBT006Hendra",
- "WBT009Anju"
- ]
- },
- "vector-action-addsection": "Bagian na imbaru",
- "vector-action-delete": "Sesa",
- "vector-action-move": "Pahusor",
- "vector-action-protect": "Ramoti",
- "vector-action-undelete": "unang sesa",
- "vector-action-unprotect": "Uba parlindungan",
- "vector-view-create": "Tompa",
- "vector-view-edit": "Paubah",
- "vector-view-history": "Patudu andorang na",
- "vector-view-view": "Jaha",
- "vector-view-viewsource": "Ida haroanna"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Mostafadaneshvar",
- "RigiMahnoor"
- ]
- },
- "vector-action-addsection": "هور کتن عنوان",
- "vector-action-delete": "زورگ",
- "vector-action-move": "جاه په جاه",
- "vector-action-protect": "حفاظت",
- "vector-action-undelete": "ترینگ",
- "vector-action-unprotect": "پروتکشنء ٹگل بدئ",
- "vector-view-create": "شرکتن",
- "vector-view-edit": "اصلاح",
- "vector-view-history": "چارتن تاریح",
- "vector-view-view": "وانتن",
- "vector-view-viewsource": "پیشدارگ بن جاه",
- "vector-more-actions": "گیشتر"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Filipinayzd",
- "Geopoet"
- ]
- },
- "vector-action-addsection": "Idagdag an topic",
- "vector-action-delete": "puráon",
- "vector-action-move": "Ibalyó",
- "vector-action-protect": "Protektaran",
- "vector-action-undelete": "Bawion sa pagkapara",
- "vector-action-unprotect": "Ribayan an proteksyon",
- "vector-view-create": "Magmukna",
- "vector-view-edit": "Liwatón",
- "vector-view-history": "Tanawon sa historiya",
- "vector-view-view": "Basáha",
- "vector-view-viewsource": "Hilingón an ginikánan"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "EugeneZelenko",
- "Red Winged Duck",
- "Wizardist"
- ]
- },
- "skinname-vector": "Вэктар",
- "vector-action-addsection": "Дадаць тэму",
- "vector-action-delete": "Выдаліць",
- "vector-action-move": "Перанесьці",
- "vector-action-protect": "Абараніць",
- "vector-action-undelete": "Аднавіць",
- "vector-action-unprotect": "Зьмяніць абарону",
- "vector-view-create": "Стварыць",
- "vector-view-edit": "Рэдагаваць",
- "vector-view-history": "Паказаць гісторыю",
- "vector-view-view": "Чытаць",
- "vector-view-viewsource": "Паказаць крыніцу",
- "vector-more-actions": "Болей"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Mikalai Udodau",
- "Yury Tarasievich",
- "Дзяніс Тутэйшы",
- "Хомелка"
- ]
- },
- "vector-skin-desc": "Сучасная версія вокладкі Манабук, з абноўленым відам і шматлікімі зручнымі паляпшэннямі",
- "vector-action-addsection": "Дадаць тэму",
- "vector-action-delete": "Сцерці",
- "vector-action-move": "Перанесці",
- "vector-action-protect": "Ахова",
- "vector-action-undelete": "Аднавіць",
- "vector-action-unprotect": "Змяніць ахову",
- "vector-view-create": "Стварыць",
- "vector-view-edit": "Правіць",
- "vector-view-history": "Паказаць гісторыю",
- "vector-view-view": "Чытаць",
- "vector-view-viewsource": "Паказаць зыходны тэкст",
- "vector-more-actions": "Яшчэ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Naval Scene"
- ]
- },
- "vector-action-delete": "Ngapus",
- "vector-action-move": "Pindahin",
- "vector-action-undelete": "Balikin nyang keapus",
- "vector-view-create": "Bikin"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Borislav",
- "DCLXVI",
- "Spiritia"
- ]
- },
- "vector-action-addsection": "Добавяне на тема",
- "vector-action-delete": "Изтриване",
- "vector-action-move": "Преместване",
- "vector-action-protect": "Защита",
- "vector-action-undelete": "Възстановяване",
- "vector-action-unprotect": "Промяна на защитата",
- "vector-view-create": "Създаване",
- "vector-view-edit": "Редактиране",
- "vector-view-history": "История",
- "vector-view-view": "Преглед",
- "vector-view-viewsource": "Преглед на кода"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ganesh",
- "Nepaboy"
- ]
- },
- "vector-action-addsection": "विषय जोड़ीं",
- "vector-action-delete": "मिटाईं",
- "vector-action-move": "स्थांतरण",
- "vector-action-protect": "संरक्षित करीं",
- "vector-action-undelete": "मत मिटाईं",
- "vector-action-unprotect": "सुरक्षा बदलीं",
- "vector-view-create": "बनाईं",
- "vector-view-edit": "सम्पादन",
- "vector-view-history": "इतिहास देखीं",
- "vector-view-view": "पढ़ीं",
- "vector-view-viewsource": "स्त्रोत देखीं"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Sotiale"
- ]
- },
- "vector-action-move": "Muv",
- "vector-view-history": "Lukluk histri",
- "vector-view-view": "Rid"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ezagren",
- "J Subhi"
- ]
- },
- "vector-action-addsection": "Tambahi tupik",
- "vector-action-delete": "Hapus",
- "vector-action-move": "Pindahakan",
- "vector-action-protect": "Lindungi",
- "vector-action-undelete": "Pawalangan pahapusan",
- "vector-action-unprotect": "Palindungan",
- "vector-view-create": "Ulah",
- "vector-view-edit": "Babak",
- "vector-view-history": "Tiringi halam",
- "vector-view-view": "Baca",
- "vector-view-viewsource": "Tiringi asal mula"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Amadouyoro.thiam"
- ]
- },
- "vector-view-view": "Kalan"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Aftab1995",
- "Bellayet",
- "Leemon2010",
- "Nasir8891",
- "Tauhid16",
- "Wikitanvir"
- ]
- },
- "skinname-vector": "ভেক্টর",
- "vector-action-addsection": "বিষয় যোগ",
- "vector-action-delete": "অপসারণ",
- "vector-action-move": "স্থানান্তর",
- "vector-action-protect": "সুরক্ষা",
- "vector-action-undelete": "পুনরুদ্ধার",
- "vector-action-unprotect": "সুরক্ষা পরিবর্তন",
- "vector-view-create": "তৈরি",
- "vector-view-edit": "সম্পাদনা",
- "vector-view-history": "ইতিহাস",
- "vector-view-view": "পড়ুন",
- "vector-view-viewsource": "উৎস দেখুন",
- "vector-more-actions": "আরও"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Freeyak",
- "Phurbutsering"
- ]
- },
- "vector-action-addsection": "བརྗོད་གཞི་ཁ་སྣོན།",
- "vector-action-delete": "སུབས།",
- "vector-action-move": "སྤོར་བ།",
- "vector-action-protect": "འགོག་སྲུང།",
- "vector-action-undelete": "མི་བསུབས་",
- "vector-action-unprotect": "སྲུང་སྐྱོབ་གློད་པ།",
- "vector-view-create": "གསར་བཟོ།",
- "vector-view-edit": "རྩོམ་སྒྲིག",
- "vector-view-history": "ལོ་རྒྱུས་ལ་ལྟ་བ།",
- "vector-view-view": "ཀློག་པ།",
- "vector-view-viewsource": "ཁུངས་ལ་ལྟ་བ།"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Usingha"
- ]
- },
- "vector-action-addsection": "বিষয় তিলকর",
- "vector-action-delete": "পুসে বেলা",
- "vector-action-move": "থেইকর",
- "vector-action-protect": "লুকর",
- "vector-action-undelete": "নাপুসি",
- "vector-action-unprotect": "লুকরানিহান সিলকর",
- "vector-view-create": "হঙকরিক",
- "vector-view-edit": "পতানি",
- "vector-view-history": "ইতিহাস চেইক",
- "vector-view-view": "পাকরিক",
- "vector-view-viewsource": "সোর্স চেইক"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Fulup",
- "Y-M D"
- ]
- },
- "skinname-vector": "Vektor",
- "vector.css": "/* Talvezout a raio ar CSS lakaet amañ evit implijerien ar gwiskadur Vektor */",
- "vector.js": "/* Kement JavaScript amañ a vo karget evit an implijerien a ra gant ar gwiskadur Vektor */",
- "vector-action-addsection": "Rannbennad nevez",
- "vector-action-delete": "Diverkañ",
- "vector-action-move": "Adenvel",
- "vector-action-protect": "Gwareziñ",
- "vector-action-undelete": "Diziverkañ",
- "vector-action-unprotect": "Cheñch gwarez",
- "vector-view-create": "Krouiñ",
- "vector-view-edit": "Kemmañ",
- "vector-view-history": "Gwelet an istor",
- "vector-view-view": "Lenn",
- "vector-view-viewsource": "Sellet ouzh tarzh an destenn",
- "vector-more-actions": "Muioc'h"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Imdadb"
- ]
- },
- "vector-action-addsection": "Púskun sarhál",
- "vector-action-delete": "Mesa",
- "vector-action-move": "Surif",
- "vector-action-protect": "Rakk",
- "vector-view-create": "Biná",
- "vector-view-edit": "Radbadal",
- "vector-view-history": "Lekav e ur",
- "vector-view-view": "Xuán",
- "vector-view-viewsource": "Bumpad e ur"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "CERminator",
- "DzWiki",
- "KWiki",
- "Edinwiki"
- ]
- },
- "vector-action-addsection": "Dodaj temu",
- "vector-action-delete": "Izbriši",
- "vector-action-move": "Preusmjeri",
- "vector-action-protect": "Zaštiti",
- "vector-action-undelete": "Vrati obrisano",
- "vector-action-unprotect": "Promijeni zaštitu",
- "vector-view-create": "Napravi",
- "vector-view-edit": "Uredi",
- "vector-view-history": "Pregled historije",
- "vector-view-view": "Čitanje",
- "vector-view-viewsource": "Pogledaj izvor",
- "vector-more-actions": "Više"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Filipinayzd"
- ]
- },
- "vector-action-delete": "Puraon",
- "vector-action-move": "Ilipat",
- "vector-action-protect": "Protektaran",
- "vector-action-undelete": "Ibalik",
- "vector-action-unprotect": "Ribayan a proteksyon",
- "vector-view-create": "Gumibo",
- "vector-view-edit": "Balyowan",
- "vector-view-history": "Baydon a kasaysayan",
- "vector-view-view": "Basahon",
- "vector-view-viewsource": "Baydon a ginikanan",
- "vector-more-actions": "Dakul pa"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Kurniasan"
- ]
- },
- "vector-action-move": "Paléccé'",
- "vector-view-create": "Ebbu",
- "vector-view-edit": "Padéccéng",
- "vector-view-view": "Baca",
- "vector-view-viewsource": "Ita sumber"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Bjargal",
- "Elvonudinium"
- ]
- },
- "vector-action-addsection": "Һэдэб нэмэхэ",
- "vector-action-delete": "Усадхаха",
- "vector-action-move": "Зөөхэ",
- "vector-view-create": "Үүдхэхэ",
- "vector-view-edit": "Заһабарилха",
- "vector-view-history": "Түүхые хараха",
- "vector-view-view": "Уншаха",
- "vector-view-viewsource": "эшэ үндэһэндэнь хандаха"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Aleator",
- "Anskar",
- "Calak",
- "Paucabot",
- "Ssola",
- "Vriullop",
- "Toniher"
- ]
- },
- "vector-skin-desc": "Versió moderna del MonoBook amb un nou aspesctes i moltes millores en la usabilitat",
- "vector-action-addsection": "Nova secció",
- "vector-action-delete": "Esborra",
- "vector-action-move": "Reanomena",
- "vector-action-protect": "Protegeix",
- "vector-action-undelete": "Restaura",
- "vector-action-unprotect": "Desprotegeix",
- "vector-view-create": "Crea",
- "vector-view-edit": "Modifica",
- "vector-view-history": "Mostra l'historial",
- "vector-view-view": "Mostra",
- "vector-view-viewsource": "Mostra el codi",
- "vector-more-actions": "Més"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Yejianfei"
- ]
- },
- "vector-action-addsection": "加話題",
- "vector-action-delete": "刪掉咯",
- "vector-action-move": "移動",
- "vector-action-protect": "保護",
- "vector-action-undelete": "取消刪除",
- "vector-action-unprotect": "改變保護",
- "vector-view-create": "創建",
- "vector-view-edit": "修改",
- "vector-view-history": "看歷史",
- "vector-view-view": "讀",
- "vector-view-viewsource": "看源代碼"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Sasan700",
- "Умар"
- ]
- },
- "skinname-vector": "Векторан",
- "vector-action-addsection": "ТӀетоха хьедар",
- "vector-action-delete": "ДӀаяккха",
- "vector-action-move": "ЦӀе хийца",
- "vector-action-protect": "Гlаролла дé",
- "vector-action-undelete": "МеттахӀоттае",
- "vector-action-unprotect": "ГӀароллех къаста",
- "vector-view-create": "Кхоллар",
- "vector-view-edit": "Нисъе",
- "vector-view-history": "АгӀона хийцамаш",
- "vector-view-view": "Éшар",
- "vector-view-viewsource": "Билглонашка хьажа",
- "vector-more-actions": "Кхин"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Jordz"
- ]
- },
- "vector-action-addsection": "Pagdugang og topiko",
- "vector-action-delete": "Papasa",
- "vector-action-move": "Ibalhin",
- "vector-action-protect": "Protektahi",
- "vector-action-undelete": "Ayaw papasa",
- "vector-action-unprotect": "Ayaw protektahi",
- "vector-view-create": "Himoa",
- "vector-view-edit": "Usba",
- "vector-view-history": "Tan-awa ang kaagi",
- "vector-view-view": "Basaha",
- "vector-view-viewsource": "Tan-awa ang ginikanan"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Asoxor",
- "Calak"
- ]
- },
- "skinname-vector": "ڤێکتۆر",
- "vector-action-addsection": "بابەت دابنێ",
- "vector-action-delete": "بیسڕەوە",
- "vector-action-move": "بیگوازەوە",
- "vector-action-protect": "بیپارێزە",
- "vector-action-undelete": "سڕینەوە بگەڕێنەوە",
- "vector-action-unprotect": "پاراستن بگۆڕە",
- "vector-view-create": "دروستکردن",
- "vector-view-edit": "دەستکاریی بکە",
- "vector-view-history": "مێژووەکەی ببینە",
- "vector-view-view": "بیخوێنەوە",
- "vector-view-viewsource": "سەرچاوەکەی ببینە",
- "vector-more-actions": "زیاتر"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Paulu"
- ]
- },
- "vector-action-addsection": "Aghjunghje discussione",
- "vector-action-delete": "Supprimà",
- "vector-action-move": "Cullucà",
- "vector-action-protect": "Pruteghje",
- "vector-action-unprotect": "Cambià a prutezzione",
- "vector-view-create": "Creà",
- "vector-view-edit": "Mudificà",
- "vector-view-history": "Vede a cronolugia",
- "vector-view-view": "Leghje",
- "vector-view-viewsource": "Vede a surghjente"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Capisano",
- "Oxyzen"
- ]
- },
- "vector-action-addsection": "Magdugang sang topiko",
- "vector-action-delete": "Panason",
- "vector-action-move": "Isdogon",
- "vector-action-protect": "Protektahan",
- "vector-action-undelete": "Indi pag panason",
- "vector-action-unprotect": "Islan ang proteksyon",
- "vector-view-create": "Ubrahon",
- "vector-view-edit": "Bag-uhon",
- "vector-view-history": "Ipakita ang kasaysayan",
- "vector-view-view": "Basahon",
- "vector-view-viewsource": "Lantawon ang ginhalinan"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Don Alessandro"
- ]
- },
- "vector-action-addsection": "Мевзу къош",
- "vector-action-delete": "Ёкъ эт",
- "vector-action-move": "Адыны денъиштир",
- "vector-action-protect": "Къорчала",
- "vector-action-undelete": "Янъыдан ярат",
- "vector-action-unprotect": "Къорчалавны денъиштир",
- "vector-view-create": "Ярат",
- "vector-view-edit": "Денъиштир",
- "vector-view-history": "Кечмишини косьтер",
- "vector-view-view": "Окъу",
- "vector-view-viewsource": "Менба кодуны косьтер"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Don Alessandro"
- ]
- },
- "vector-action-addsection": "Mevzu qoş",
- "vector-action-delete": "Yoq et",
- "vector-action-move": "Adını deñiştir",
- "vector-action-protect": "Qorçala",
- "vector-action-undelete": "Yañıdan yarat",
- "vector-action-unprotect": "Qorçalavnı deñiştir",
- "vector-view-create": "Yarat",
- "vector-view-edit": "Deñiştir",
- "vector-view-history": "Keçmişini köster",
- "vector-view-view": "Oqu",
- "vector-view-viewsource": "Menba kodunı köster"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Mormegil"
- ]
- },
- "skinname-vector": "Vektor",
- "vector-skin-desc": "Moderní verze MonoBooku s novějším vzhledem a vylepšenou použitelností",
- "vector.css": "/* Zde uvedené CSS bude ovlivňovat pouze styl „Vektor“ */",
- "vector.js": "/* JavaScript pro uživatele používající vzhled „Vektor“ */",
- "vector-action-addsection": "Přidat téma",
- "vector-action-delete": "Smazat",
- "vector-action-move": "Přesunout",
- "vector-action-protect": "Zamknout",
- "vector-action-undelete": "Obnovit",
- "vector-action-unprotect": "Změnit zámek",
- "vector-view-create": "Založit",
- "vector-view-edit": "Editovat",
- "vector-view-history": "Zobrazit historii",
- "vector-view-view": "Číst",
- "vector-view-viewsource": "Zobrazit zdrojový kód",
- "vector-more-actions": "Další"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Kaszeba",
- "Kuvaly"
- ]
- },
- "vector-action-addsection": "Dodôj témã",
- "vector-action-delete": "Rëmôj",
- "vector-action-move": "Przeniesë",
- "vector-action-protect": "Zazychrëjë",
- "vector-action-undelete": "Doprowôdzë nazôd",
- "vector-action-unprotect": "Òdzychrëjë",
- "vector-view-create": "Ùsôdzë",
- "vector-view-edit": "Edicëjô",
- "vector-view-history": "Historëjô lopka",
- "vector-view-view": "Czëtôj",
- "vector-view-viewsource": "Zdrojowi tekst"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "ОйЛ"
- ]
- },
- "vector-action-addsection": "новꙑ бєсѣдꙑ чѧсти сътворѥниѥ",
- "vector-action-delete": "поничьжєниѥ",
- "vector-action-move": "прѣимєнованиѥ",
- "vector-action-protect": "ꙁабранѥниѥ",
- "vector-action-unprotect": "иꙁмѣни ꙁабранѥниꙗ обраꙁъ",
- "vector-view-create": "сътворѥниѥ",
- "vector-view-edit": "исправи",
- "vector-view-history": "їсторїꙗ",
- "vector-view-view": "чьтѥниѥ",
- "vector-view-viewsource": "страницѧ источьнъ обраꙁъ",
- "vector-more-actions": "вѧщє"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Chavash",
- "FLAGELLVM DEI"
- ]
- },
- "vector-action-addsection": "Тема хуш",
- "vector-action-delete": "Кăларса пăрах",
- "vector-action-move": "Ятне улăштар",
- "vector-action-protect": "Хӳтĕле",
- "vector-view-create": "Çĕннине ту",
- "vector-view-edit": "Тӳрлет",
- "vector-view-history": "Кун-çул",
- "vector-view-view": "Вула",
- "vector-view-viewsource": "пуçламăш текста пăх"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Lloffiwr"
- ]
- },
- "vector-action-addsection": "Ychwanegu adran",
- "vector-action-delete": "Dileu",
- "vector-action-move": "Symud",
- "vector-action-protect": "Diogelu",
- "vector-action-undelete": "Adfer",
- "vector-action-unprotect": "Newid y diogelwch",
- "vector-view-create": "Dechrau",
- "vector-view-edit": "Golygu",
- "vector-view-history": "Gweld yr hanes",
- "vector-view-view": "Darllen",
- "vector-view-viewsource": "Dangos côd y dudalen",
- "vector-more-actions": "Rhagor"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Byrial",
- "Christian List",
- "Peter Alberti"
- ]
- },
- "vector-skin-desc": "Moderne version af MonoBook med frisk udseende og mange forbedringer af brugervenligheden",
- "vector-action-addsection": "Nyt emne",
- "vector-action-delete": "Slet",
- "vector-action-move": "Flyt",
- "vector-action-protect": "Beskyt",
- "vector-action-undelete": "Gendan",
- "vector-action-unprotect": "Ændr beskyttelse",
- "vector-view-create": "Opret",
- "vector-view-edit": "Redigér",
- "vector-view-history": "Se historik",
- "vector-view-view": "Læs",
- "vector-view-viewsource": "Se kilden",
- "vector-more-actions": "Mere"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Kghbln",
- "Metalhead64",
- "The Evil IP address",
- "Umherirrender"
- ]
- },
- "skinname-vector": "Vector",
- "vector-skin-desc": "Moderne Version von Monobook mit frischem Aussehen und vielen Verbesserungen an der Benutzerfreundlichkeit",
- "vector.css": "/* Das folgende CSS wird für Benutzer der Vector-Benutzeroberfläche geladen. Für allgemeingültige Benutzeroberflächen-Anpassungen bitte [[MediaWiki:Common.css]] bearbeiten. */",
- "vector.js": "/* Das folgende JavaScript wird für Benutzer der Vector-Benutzeroberfläche geladen. Allgemeingültiges JavaScript bitte in [[MediaWiki:Common.js]] eintragen. */",
- "vector-action-addsection": "Abschnitt hinzufügen",
- "vector-action-delete": "Löschen",
- "vector-action-move": "Verschieben",
- "vector-action-protect": "Schützen",
- "vector-action-undelete": "Wiederherstellen",
- "vector-action-unprotect": "Seitenschutz ändern",
- "vector-view-create": "Erstellen",
- "vector-view-edit": "Bearbeiten",
- "vector-view-history": "Versionsgeschichte",
- "vector-view-view": "Lesen",
- "vector-view-viewsource": "Quelltext anzeigen",
- "vector-more-actions": "Mehr"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Asmen",
- "Calak",
- "Erdemaslancan",
- "Mirzali"
- ]
- },
- "skinname-vector": "Vektor",
- "vector-action-addsection": "Mewzu vıraze",
- "vector-action-delete": "Bestere",
- "vector-action-move": "Bere",
- "vector-action-protect": "Bışevekne",
- "vector-action-undelete": "Esterıtışi peyser bıgê",
- "vector-action-unprotect": "Starkerdışi bıvurne",
- "vector-view-create": "Vıraze",
- "vector-view-edit": "Bıvurne",
- "vector-view-history": "Tarixê pele bıvêne",
- "vector-view-view": "Bıwane",
- "vector-view-viewsource": "Çımey bıvêne",
- "vector-more-actions": "Zêde"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Michawiki"
- ]
- },
- "vector-action-addsection": "Temu pśidaś",
- "vector-action-delete": "Wulašowaś",
- "vector-action-move": "Pśesunuś",
- "vector-action-protect": "Šćitaś",
- "vector-action-undelete": "Wótnowiś",
- "vector-action-unprotect": "Šćit změniś",
- "vector-view-create": "Napóraś",
- "vector-view-edit": "Wobźěłaś",
- "vector-view-history": "Wersije a awtory",
- "vector-view-view": "Cytaś",
- "vector-view-viewsource": "Žrědło se woglědaś"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "FRANCIS5091",
- "FRANELYA"
- ]
- },
- "vector-action-addsection": "Ruhangai piboboroson",
- "vector-action-delete": "Pugaso",
- "vector-action-move": "Poundoliho",
- "vector-action-protect": "Tingoligai",
- "vector-action-undelete": "Kada pugaso",
- "vector-action-unprotect": "Alanai tingolig",
- "vector-view-create": "Pomonsoi",
- "vector-view-edit": "Idito",
- "vector-view-history": "Intaai susuyan",
- "vector-view-view": "Basao",
- "vector-view-viewsource": "Intaai wowonod"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ushau97"
- ]
- },
- "vector-action-addsection": "ޚިޔާލެއް އިތުރުކުރައްވާ",
- "vector-action-delete": "ފޮހެލައްވާ",
- "vector-action-move": "ތަން ބަދަލުކުރައްވާ",
- "vector-action-protect": "ދިފާޢުކުރައްވާ",
- "vector-action-unprotect": "ދިފާޢުކުރުން ބަދަލުކުރައްވާ",
- "vector-view-create": "ފަށްޓަވާ",
- "vector-view-edit": "އުނިއިތުރު ގެންނަވާ",
- "vector-view-history": "ޞަފްޙާގެ ތާރީޚް",
- "vector-view-view": "ކިޔުއްވާ",
- "vector-view-viewsource": "މަސްދަރު ބައްލަވާ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Natsubee"
- ]
- },
- "vector-action-delete": "Tutui",
- "vector-action-move": "Ɖɔli eƒe nɔƒe",
- "vector-view-create": "Dze egɔme",
- "vector-view-edit": "Trɔ asi le eŋu",
- "vector-view-history": "Kpɔ xoxoawo",
- "vector-view-view": "Xlẽ",
- "vector-view-viewsource": "Kpɔ alesi woŋlɔe"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Lévi"
- ]
- },
- "vector-action-addsection": "Zûnta discusiòun",
- "vector-action-delete": "Scanşèla",
- "vector-action-move": "Spôsta",
- "vector-action-protect": "Prutēz",
- "vector-action-undelete": "Fà al recóper",
- "vector-action-unprotect": "Câmbia la prutesiòun",
- "vector-view-create": "Invèinta",
- "vector-view-edit": "Mudéfica",
- "vector-view-history": "Guêrda la stôria",
- "vector-view-view": "Lēş",
- "vector-view-viewsource": "Guêrda la surzéia",
- "vector-more-actions": "Êter"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Calak",
- "Crazymadlover",
- "Evropi",
- "Omnipaedista",
- "Protnet",
- "ZaDiak"
- ]
- },
- "vector.css": "/* Το τοποθετημένο εδώ CSS θα επηρεάσει χρήστες του Vector skin */",
- "vector.js": "/* Οποιοσδήποτε κώδικας JavaScript εδώ θα φορτωθεί για χρήστες που χρησιμοποιούν το Vector skin */",
- "vector-action-addsection": "Προσθήκη θέματος",
- "vector-action-delete": "Διαγραφή",
- "vector-action-move": "Μετακίνηση",
- "vector-action-protect": "Προστασία",
- "vector-action-undelete": "Επαναφορά",
- "vector-action-unprotect": "Αλλαγή προστασίας",
- "vector-view-create": "Δημιουργία",
- "vector-view-edit": "Επεξεργασία",
- "vector-view-history": "Προβολή ιστορικού",
- "vector-view-view": "Ανάγνωση",
- "vector-view-viewsource": "Προβολή κώδικα",
- "vector-more-actions": "Περισσότερα"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": []
- },
- "skinname-vector": "Vector",
- "vector-skin-desc": "Modern version of MonoBook with fresh look and many usability improvements",
- "vector.css": "/* CSS placed here will affect users of the Vector skin */",
- "vector.js": "/* Any JavaScript here will be loaded for users using the Vector skin */",
- "vector-action-addsection": "Add topic",
- "vector-action-delete": "Delete",
- "vector-action-move": "Move",
- "vector-action-protect": "Protect",
- "vector-action-undelete": "Undelete",
- "vector-action-unprotect": "Change protection",
- "vector-view-create": "Create",
- "vector-view-edit": "Edit",
- "vector-view-history": "View history",
- "vector-view-view": "Read",
- "vector-view-viewsource": "View source",
- "vector-more-actions": "More"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "KuboF",
- "Objectivesea",
- "Yekrats"
- ]
- },
- "skinname-vector": "Vektoro",
- "vector.css": "/* La jena CSS influos la paĝaspekton por uzantoj de la Vektora temo. */",
- "vector.js": "/* La jena Ĝavaskripto ŝargiĝos por uzantoj de la Vektora temo. */",
- "vector-action-addsection": "Aldoni temon",
- "vector-action-delete": "Forigi",
- "vector-action-move": "Alinomigi",
- "vector-action-protect": "Protekti",
- "vector-action-undelete": "Malforigi",
- "vector-action-unprotect": "Ŝanĝi protektadon",
- "vector-view-create": "Krei",
- "vector-view-edit": "Redakti",
- "vector-view-history": "Vidi historion",
- "vector-view-view": "Legi",
- "vector-view-viewsource": "Vidi fonton",
- "vector-more-actions": "Pli"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "XanaG"
- ]
- },
- "vector-view-edit": "Editar",
- "vector-view-history": "Ver historial",
- "vector-view-view": "Leer"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Armando-Martin",
- "Crazymadlover",
- "Dalton2",
- "Fitoschido",
- "Locos epraix",
- "Manuelt15",
- "MarcoAurelio",
- "Miguel2706",
- "Platonides",
- "Vivaelcelta"
- ]
- },
- "skinname-vector": "Vector",
- "vector-skin-desc": "Versión moderna de MonoBook, con un aspecto actualizado y muchas mejoras de usabilidad",
- "vector.css": "/* El CSS colocado en esta página afectará a los usuarios que usen la apariencia \"Vector\" */",
- "vector.js": "/* Cualquier código JavaScript escrito aquí se cargará para todos los usuarios que usen la apariencia Vector */",
- "vector-action-addsection": "Sección nueva",
- "vector-action-delete": "Borrar",
- "vector-action-move": "Trasladar",
- "vector-action-protect": "Proteger",
- "vector-action-undelete": "Restaurar",
- "vector-action-unprotect": "Cambiar protección",
- "vector-view-create": "Crear",
- "vector-view-edit": "Editar",
- "vector-view-history": "Ver historial",
- "vector-view-view": "Leer",
- "vector-view-viewsource": "Ver código",
- "vector-more-actions": "Más"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "82-145"
- ]
- },
- "vector-action-move": "Atra cimirtuq",
- "vector-view-view": "Naaqe"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ker",
- "Pikne",
- "WikedKentaur"
- ]
- },
- "skinname-vector": "Vektor",
- "vector-skin-desc": "MonoBooki uuem versioon värskema väljanägemise ja mitme kasutajasõbralikuma täiendusega",
- "vector.css": "/* Siin asuv kaskaadilaadistik puudutab kõiki Vektori-kujunduse kasutajaid. */",
- "vector.js": "/* Siin asuv JavaScript laaditakse kõigi Vektori-kujunduse kasutajate jaoks. */",
- "vector-action-addsection": "Lisa teema",
- "vector-action-delete": "Kustuta",
- "vector-action-move": "Teisalda",
- "vector-action-protect": "Kaitse",
- "vector-action-undelete": "Taasta",
- "vector-action-unprotect": "Muuda kaitset",
- "vector-view-create": "Loo",
- "vector-view-edit": "Muuda",
- "vector-view-history": "Näita ajalugu",
- "vector-view-view": "Vaata",
- "vector-view-viewsource": "Vaata lähteteksti",
- "vector-more-actions": "Veel"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Unai Fdz. de Betoño",
- "Xabier Armendaritz",
- "Fitoschido"
- ]
- },
- "vector-action-addsection": "Gehitu atala",
- "vector-action-delete": "Ezabatu",
- "vector-action-move": "Mugitu",
- "vector-action-protect": "Babestu",
- "vector-action-undelete": "Berreskuratu",
- "vector-action-unprotect": "Babesa aldatu",
- "vector-view-create": "Sortu",
- "vector-view-edit": "Aldatu",
- "vector-view-history": "Ikusi historia",
- "vector-view-view": "Irakurri",
- "vector-view-viewsource": "Kodea ikusia",
- "vector-more-actions": "Gehiago"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Better"
- ]
- },
- "vector-action-addsection": "Añiil tema",
- "vector-action-delete": "Esborral",
- "vector-action-move": "Mual",
- "vector-action-protect": "Protegel",
- "vector-action-undelete": "Esborral",
- "vector-action-unprotect": "Esprotegel",
- "vector-view-create": "Crial",
- "vector-view-edit": "Eital",
- "vector-view-history": "Guipal estorial",
- "vector-view-view": "Leyel",
- "vector-view-viewsource": "Guipal cóigu"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Calak",
- "Ebraminio",
- "Huji",
- "Reza1615",
- "Zack90"
- ]
- },
- "skinname-vector": "برداری",
- "vector-skin-desc": "نسخه مدرن منوبوک با نگاه تازه و بهبود قابلیت استفاده",
- "vector-action-addsection": "افزودن بخش",
- "vector-action-delete": "حذف",
- "vector-action-move": "انتقال",
- "vector-action-protect": "محافظت",
- "vector-action-undelete": "احیا",
- "vector-action-unprotect": "تغییر سطح حفاظت",
- "vector-view-create": "ایجاد",
- "vector-view-edit": "ویرایش",
- "vector-view-history": "نمایش تاریخچه",
- "vector-view-view": "خواندن",
- "vector-view-viewsource": "نمایش مبدأ",
- "vector-more-actions": "بیشتر"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ibrahima"
- ]
- },
- "vector-action-addsection": "Ɓeydi toɓɓere",
- "vector-action-move": "Dirtin",
- "vector-view-create": "Sos",
- "vector-view-edit": "Taƴto",
- "vector-view-history": "Yiyto aslol",
- "vector-view-view": "Tar",
- "vector-view-viewsource": "Yiyto ɗaɗol"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Crt",
- "Nedergard",
- "Nike",
- "Pxos"
- ]
- },
- "vector.css": "/* Tämä sivu sisältää Vector-ulkoasua muuttavia tyylejä. */",
- "vector.js": "/* Tämän sivun JavaScript-koodi liitetään Vector-tyyliin */",
- "vector-action-addsection": "Lisää aihe",
- "vector-action-delete": "Poista",
- "vector-action-move": "Siirrä",
- "vector-action-protect": "Suojaa",
- "vector-action-undelete": "Palauta",
- "vector-action-unprotect": "Muuta suojausta",
- "vector-view-create": "Luo",
- "vector-view-edit": "Muokkaa",
- "vector-view-history": "Näytä historia",
- "vector-view-view": "Lue",
- "vector-view-viewsource": "Näytä lähdekoodi",
- "vector-more-actions": "Muut"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Mestos"
- ]
- },
- "vector-action-addsection": "Lissää aine",
- "vector-action-delete": "Ota poies",
- "vector-action-move": "Siirä",
- "vector-action-protect": "Suojaa",
- "vector-action-undelete": "Pane takashiin",
- "vector-action-unprotect": "Muuta suojaa",
- "vector-view-create": "Luo",
- "vector-view-edit": "Mookkaa",
- "vector-view-history": "Näytä histuuria",
- "vector-view-view": "Lue",
- "vector-view-viewsource": "Näytä lähekooti"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Diupwijk",
- "EileenSanda"
- ]
- },
- "vector-action-addsection": "Nýtt evni",
- "vector-action-delete": "Strika",
- "vector-action-move": "Flyt",
- "vector-action-protect": "Friða",
- "vector-action-undelete": "Endurstovna",
- "vector-action-unprotect": "Broyt verju",
- "vector-view-create": "Stovna",
- "vector-view-edit": "Rætta",
- "vector-view-history": "Vís søgu",
- "vector-view-view": "Les",
- "vector-view-viewsource": "Vís keldu",
- "vector-more-actions": "Meira"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Akeron",
- "Crochet.david",
- "DavidL",
- "Gomoko",
- "Jean-Frédéric",
- "Od1n"
- ]
- },
- "skinname-vector": "Vector",
- "vector-skin-desc": "Version moderne de MonoBook avec un aspect rajeuni et beaucoup d’améliorations ergonomiques",
- "vector.css": "/* Le CSS placé ici affectera les utilisateurs de l’habillage Vector. */",
- "vector.js": "/* Tout code JavaScript placé ici sera chargé pour les utilisateurs de l’habillage Vector */",
- "vector-action-addsection": "Ajouter un sujet",
- "vector-action-delete": "Supprimer",
- "vector-action-move": "Renommer",
- "vector-action-protect": "Protéger",
- "vector-action-undelete": "Rétablir",
- "vector-action-unprotect": "Changer la protection",
- "vector-view-create": "Créer",
- "vector-view-edit": "Modifier",
- "vector-view-history": "Historique",
- "vector-view-view": "Lire",
- "vector-view-viewsource": "Voir la source",
- "vector-more-actions": "Plus"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ebe123"
- ]
- },
- "vector-action-delete": "Supprimer",
- "vector-action-protect": "Protéger"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "ChrisPtDe"
- ]
- },
- "skinname-vector": "Vèctor",
- "vector.css": "/* Lo code CSS betâ ique afècterat los usanciérs de l’habelyâjo « Vèctor ». */",
- "vector.js": "/* Tot code JavaScript betâ ique serat chargiê per los usanciérs de l’habelyâjo « Vèctor ». */",
- "vector-action-addsection": "Apondre na chousa",
- "vector-action-delete": "Suprimar",
- "vector-action-move": "Dèplaciér",
- "vector-action-protect": "Protègiér",
- "vector-action-undelete": "Refâre",
- "vector-action-unprotect": "Changiér la protèccion",
- "vector-view-create": "Fâre",
- "vector-view-edit": "Changiér",
- "vector-view-history": "Vêre l’historico",
- "vector-view-view": "Liére",
- "vector-view-viewsource": "Vêre lo tèxto sôrsa"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Murma174",
- "Pyt"
- ]
- },
- "vector-skin-desc": "Modern werjuun faan Monobook mä frisk skak an föl muar mögelkhaiden",
- "vector-action-addsection": "Nei kirew began",
- "vector-action-delete": "Strik",
- "vector-action-move": "Fersküüw",
- "vector-action-protect": "Seekre",
- "vector-action-undelete": "Weder iinstel",
- "vector-action-unprotect": "Sidjenseekerhaid",
- "vector-view-create": "Maage",
- "vector-view-edit": "Bewerke",
- "vector-view-history": "Ferluup uunluke",
- "vector-view-view": "Lees",
- "vector-view-viewsource": "Kweltekst uunluke",
- "vector-more-actions": "Muar"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Klenje",
- "Tocaibon"
- ]
- },
- "vector-action-addsection": "Gnove sezion",
- "vector-action-delete": "Elimine",
- "vector-action-move": "Môf",
- "vector-action-protect": "Protêç",
- "vector-action-undelete": "Recupere",
- "vector-action-unprotect": "Gambie la protezion",
- "vector-view-create": "Cree",
- "vector-view-edit": "Cambie",
- "vector-view-history": "Cjale il storic",
- "vector-view-view": "Lei",
- "vector-view-viewsource": "Cjale risultive"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Kening Aldgilles",
- "SK-luuut"
- ]
- },
- "vector-action-delete": "Fuortsmite",
- "vector-action-move": "Werneam",
- "vector-action-protect": "Beskermje",
- "vector-action-undelete": "Tebeksette",
- "vector-action-unprotect": "Beskerming fuorthelje",
- "vector-view-create": "Oanmeitsje",
- "vector-view-edit": "Wizigje",
- "vector-view-history": "Skiednis sjen litte",
- "vector-view-view": "Lês",
- "vector-view-viewsource": "Besjoch de boarne"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Kscanne",
- "Kwekubo",
- "Moydow"
- ]
- },
- "skinname-vector": "Veicteoir",
- "vector-action-addsection": "Cuir topaic leis",
- "vector-action-delete": "Scrios",
- "vector-action-move": "Athainmnigh",
- "vector-action-protect": "Glasáil",
- "vector-action-undelete": "Díscrios",
- "vector-action-unprotect": "Díghlasáil",
- "vector-view-create": "Cruthaigh",
- "vector-view-edit": "Athraigh an lch seo",
- "vector-view-history": "Féach ar stair",
- "vector-view-view": "Léigh",
- "vector-view-viewsource": "Féach ar fhoinse"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Cuman",
- "Emperyan"
- ]
- },
- "vector-view-edit": "Diiştir",
- "vector-view-view": "Oku"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Liangent",
- "Xiaomingyan"
- ]
- },
- "vector-action-addsection": "添主题",
- "vector-action-delete": "删吥",
- "vector-action-move": "移吥",
- "vector-action-protect": "护到",
- "vector-action-undelete": "望下删吥𠮶页面",
- "vector-action-unprotect": "更改保护",
- "vector-view-create": "创建",
- "vector-view-edit": "编辑",
- "vector-view-history": "望下历史",
- "vector-view-view": "读",
- "vector-view-viewsource": "望下原始码"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Symane"
- ]
- },
- "vector-action-addsection": "添主題",
- "vector-action-delete": "刪吥",
- "vector-action-move": "移吥",
- "vector-action-protect": "護到",
- "vector-action-undelete": "望下刪吥嗰頁面",
- "vector-action-unprotect": "解除保護",
- "vector-view-create": "創建",
- "vector-view-edit": "編輯",
- "vector-view-history": "望下歷史",
- "vector-view-view": "讀",
- "vector-view-viewsource": "望下原始碼"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Akerbeltz",
- "GunChleoc"
- ]
- },
- "vector-skin-desc": "Tionndadh ùr-nodha de MonoBook le dreach ùr air 's iomadh leasachadh air a sho-chleachdachd",
- "vector-action-addsection": "Cuir ris cuspair",
- "vector-action-delete": "Sguab às",
- "vector-action-move": "Gluais",
- "vector-action-protect": "Dìon",
- "vector-action-undelete": "Neo-dhèan an sguabadh às",
- "vector-action-unprotect": "Atharraich an dìon",
- "vector-view-create": "Cruthaich",
- "vector-view-edit": "Deasaich",
- "vector-view-history": "Seall an eachdraidh",
- "vector-view-view": "Leugh",
- "vector-view-viewsource": "Seall an tùs",
- "vector-more-actions": "Barrachd"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Elisardojm",
- "Toliño",
- "Vivaelcelta"
- ]
- },
- "vector-skin-desc": "Versión moderna da aparencia MonoBook, cun aspecto fresco e moitas melloras na usabilidade",
- "vector.css": "/* O CSS que se coloque aquí afectará a quen use a aparencia Vector */",
- "vector.js": "/* Calquera JavaScript que haxa aquí será cargado para os usuarios que usen a aparencia Vector */",
- "vector-action-addsection": "Nova sección",
- "vector-action-delete": "Borrar",
- "vector-action-move": "Mover",
- "vector-action-protect": "Protexer",
- "vector-action-undelete": "Restaurar",
- "vector-action-unprotect": "Cambiar a protección",
- "vector-view-create": "Crear",
- "vector-view-edit": "Editar",
- "vector-view-history": "Ver o historial",
- "vector-view-view": "Ler",
- "vector-view-viewsource": "Ver o código fonte",
- "vector-more-actions": "Máis"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Darshan kandolkar",
- "Pooja tople",
- "Sanket.prabhu26",
- "Supriya kankumbikar"
- ]
- },
- "vector-action-addsection": "माथाळो दियात",
- "vector-action-delete": "काडून उडयात",
- "vector-action-move": "दुसरेकडे व्हरात",
- "vector-action-protect": "राख",
- "vector-view-create": "निर्माण कर",
- "vector-view-edit": "बदल",
- "vector-view-history": "इतिहास पळेयात",
- "vector-view-view": "वाचचें",
- "vector-view-viewsource": "उगम पळेयात"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Isidore Dantas",
- "The Discoverer"
- ]
- },
- "vector-action-addsection": "Vixoi zodd",
- "vector-action-delete": "Kadd",
- "vector-action-move": "Zago bodol",
- "vector-action-protect": "Rakh",
- "vector-view-create": "Roch",
- "vector-view-edit": "Sudar",
- "vector-view-history": "Itihas polloi",
- "vector-view-view": "Vach",
- "vector-view-viewsource": "Mull polloi",
- "vector-more-actions": "Anik"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Crazymadlover",
- "Omnipaedista"
- ]
- },
- "vector-action-addsection": "Θέμα προστιθέναι",
- "vector-action-delete": "Σβεννύναι",
- "vector-action-move": "Κινεῖν",
- "vector-action-protect": "Φυλάττειν",
- "vector-action-undelete": "Ἀποκαθιστάναι",
- "vector-action-unprotect": "Ἄλλαξον τὴν φύλαξιν",
- "vector-view-create": "Ποιεῖν",
- "vector-view-edit": "Μεταγράφειν",
- "vector-view-history": "Ἱστορίαν ὁρᾶν",
- "vector-view-view": "Ἀναγνῶναι",
- "vector-view-viewsource": "Ὁρᾶν τὴν πηγήν"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Als-Holder"
- ]
- },
- "vector-action-addsection": "Abschnitt zuefiege",
- "vector-action-delete": "Lesche",
- "vector-action-move": "Verschiebe",
- "vector-action-protect": "Schitze",
- "vector-action-undelete": "Widerhärstelle",
- "vector-action-unprotect": "Syteschutz ändere",
- "vector-view-create": "Aalege",
- "vector-view-edit": "Bearbeite",
- "vector-view-history": "Versionsgschicht",
- "vector-view-view": "Läse",
- "vector-view-viewsource": "Quälltext aaluege"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Aritra",
- "Ashok modhvadia",
- "Dsvyas"
- ]
- },
- "vector-action-addsection": "નવી ચર્ચા",
- "vector-action-delete": "રદ કરો",
- "vector-action-move": "ખસેડો",
- "vector-action-protect": "સુરક્ષિત કરો",
- "vector-action-undelete": "રદ કરેલું પાછું વાળો",
- "vector-action-unprotect": "સુરક્ષા બદલો",
- "vector-view-create": "બનાવો",
- "vector-view-edit": "ફેરફાર કરો",
- "vector-view-history": "ઇતિહાસ જુઓ",
- "vector-view-view": "વાંચો",
- "vector-view-viewsource": "સ્રોત જુઓ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Maor X"
- ]
- },
- "vector-action-delete": "Ojuichajaa",
- "vector-action-move": "Ansülaa",
- "vector-action-protect": "Eisalajaa",
- "vector-view-create": "Akumajaa",
- "vector-view-edit": "Anaataa",
- "vector-view-history": "Achikii a'wanajaayamaajatü",
- "vector-view-view": "Aashaje'eraa",
- "vector-view-viewsource": "Anüliaa eejeetülee"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "MacTire02",
- "Shimmin Beg"
- ]
- },
- "vector-action-addsection": "Cur cooish noa rish",
- "vector-action-delete": "Scryss",
- "vector-action-move": "Scugh",
- "vector-action-protect": "Coadee",
- "vector-action-undelete": "Jee-scryss",
- "vector-action-unprotect": "Caghlaa coadey",
- "vector-view-create": "Croo",
- "vector-view-edit": "Reagh",
- "vector-view-history": "Jeeagh er shennaghys",
- "vector-view-view": "Lhaih",
- "vector-view-viewsource": "Jeeagh er bun"
-}
+++ /dev/null
-{
- "vector-action-delete": "Soke",
- "vector-action-move": "Gusarwa",
- "vector-action-protect": "A kare",
- "vector-view-create": "Ƙirƙira"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Anson2812",
- "Jetlag"
- ]
- },
- "vector-action-addsection": "加入話題",
- "vector-action-delete": "刪除",
- "vector-action-move": "移動",
- "vector-action-protect": "保護",
- "vector-action-undelete": "恢復",
- "vector-action-unprotect": "更改保護",
- "vector-view-create": "建立",
- "vector-view-edit": "編寫",
- "vector-view-history": "查看歷史",
- "vector-view-view": "閱讀",
- "vector-view-viewsource": "查看源碼"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Kolonahe"
- ]
- },
- "vector-action-addsection": "Hoʻohui kumuhana",
- "vector-action-delete": "Holoi",
- "vector-action-move": "E hoʻoneʻe",
- "vector-action-protect": "E hoʻomalu",
- "vector-action-undelete": "Holoiʻole",
- "vector-action-unprotect": "E hoʻololi i ka hoʻomalu",
- "vector-view-create": "Haku",
- "vector-view-edit": "Hoʻololi",
- "vector-view-history": "Nānā i ka mōʻaukala",
- "vector-view-view": "Heluhelu",
- "vector-view-viewsource": "Nānā i ke kumu"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Amire80",
- "Rotemliss"
- ]
- },
- "skinname-vector": "וקטור",
- "vector-skin-desc": "גרסה מודרנית של מונובוק עם מראה רענן והרבה שיפורי שמישות",
- "vector.css": "/* הסגנונות הנכתבים כאן ישפיעו על העיצוב Vector בלבד */",
- "vector.js": "/* כל סקריפט JavaScript שנכתב כאן ירוץ רק עבור המשתמשים בעיצוב Vector */",
- "vector-action-addsection": "הוספת נושא",
- "vector-action-delete": "מחיקה",
- "vector-action-move": "העברה",
- "vector-action-protect": "הגנה",
- "vector-action-undelete": "ביטול מחיקה",
- "vector-action-unprotect": "שינוי הגנה",
- "vector-view-create": "יצירה",
- "vector-view-edit": "עריכה",
- "vector-view-history": "הצגת היסטוריה",
- "vector-view-view": "קריאה",
- "vector-view-viewsource": "הצגת מקור",
- "vector-more-actions": "עוד"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Siddhartha Ghai",
- "आलोक",
- "रोहित रावत"
- ]
- },
- "vector-action-addsection": "विषय जोड़ें",
- "vector-action-delete": "हटाएँ",
- "vector-action-move": "स्थानांतरण करें",
- "vector-action-protect": "सुरक्षित करें",
- "vector-action-undelete": "हटाना वापस लें",
- "vector-action-unprotect": "सुरक्षा बदलें",
- "vector-view-create": "बनाएँ",
- "vector-view-edit": "सम्पादन",
- "vector-view-history": "इतिहास देखें",
- "vector-view-view": "पढ़ें",
- "vector-view-viewsource": "स्रोत देखें",
- "vector-more-actions": "अधिक"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Girmitya",
- "Thakurji"
- ]
- },
- "vector-action-addsection": "Topic jorro",
- "vector-action-delete": "Mitao",
- "vector-action-move": "Naam badlo",
- "vector-action-protect": "Bachao",
- "vector-action-undelete": "Pahile jaise karo",
- "vector-action-unprotect": "Surakchha ke badlo",
- "vector-view-create": "Banao",
- "vector-view-edit": "Badlo",
- "vector-view-history": "Itihaas dekho",
- "vector-view-view": "Parrho",
- "vector-view-viewsource": "Source dekho"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Anjoeli9806"
- ]
- },
- "vector-action-addsection": "Magdugang sang topiko",
- "vector-action-delete": "Panason",
- "vector-action-move": "Saylohon",
- "vector-action-protect": "Pangapinan",
- "vector-action-undelete": "Dulaon ang pagpanas",
- "vector-action-unprotect": "Ilisan ang pagpangapin",
- "vector-view-create": "Himuon",
- "vector-view-edit": "Ilisan",
- "vector-view-history": "Lantawon ang kasaysayan",
- "vector-view-view": "Magbasa",
- "vector-view-viewsource": "Lantawon ang ginhalinan"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ex13",
- "Tivek"
- ]
- },
- "vector-action-addsection": "Dodaj temu",
- "vector-action-delete": "Izbriši",
- "vector-action-move": "Premjesti",
- "vector-action-protect": "Zaštiti",
- "vector-action-undelete": "Vrati",
- "vector-action-unprotect": "Promijeni zaštitu",
- "vector-view-create": "Započni",
- "vector-view-edit": "Uredi",
- "vector-view-history": "Vidi stare izmjene",
- "vector-view-view": "Čitaj",
- "vector-view-viewsource": "Vidi izvor"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Paul Beppler"
- ]
- },
- "vector-action-addsection": "Abschnitt hinzufüche",
- "vector-action-delete": "Lösche",
- "vector-action-move": "Verschiebe",
- "vector-action-protect": "Schütz",
- "vector-action-undelete": "Wiederherstelle",
- "vector-action-unprotect": "Seiteschutz ännre",
- "vector-view-create": "Erstell",
- "vector-view-edit": "Beoorbeite",
- "vector-view-history": "Versionsgeschicht",
- "vector-view-view": "Lese",
- "vector-view-viewsource": "Quelltext oonzeiche"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Michawiki"
- ]
- },
- "vector-action-addsection": "Temu přidać",
- "vector-action-delete": "wušmórnyć",
- "vector-action-move": "přesunyć",
- "vector-action-protect": "škitać",
- "vector-action-undelete": "Wobnowić",
- "vector-action-unprotect": "Škit wotstronić",
- "vector-view-create": "Wutworić",
- "vector-view-edit": "Wobdźěłać",
- "vector-view-history": "Stawizny",
- "vector-view-view": "Čitać",
- "vector-view-viewsource": "Žórło sej wobhladać",
- "vector-more-actions": "Wjace"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "YulouCN"
- ]
- },
- "vector-view-edit": "增改",
- "vector-view-history": "履歷",
- "vector-view-view": "讀"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Boukman",
- "Internoob",
- "Masterches"
- ]
- },
- "vector-action-addsection": "Ajoute yon sijè",
- "vector-action-delete": "Efase",
- "vector-action-move": "Chanje non",
- "vector-action-protect": "Pwoteje",
- "vector-action-undelete": "Retabli",
- "vector-action-unprotect": "Pa pwoteje",
- "vector-view-create": "Kreye",
- "vector-view-edit": "Modifye",
- "vector-view-history": "Gade istorik",
- "vector-view-view": "Li",
- "vector-view-viewsource": "Wè kòd tèks sa a"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Tacsipacsi"
- ]
- },
- "vector-action-addsection": "Új téma nyitása",
- "vector-action-delete": "Törlés",
- "vector-action-move": "Átnevezés",
- "vector-action-protect": "Lapvédelem",
- "vector-action-undelete": "Visszaállítás",
- "vector-action-unprotect": "Védelem módosítása",
- "vector-view-create": "Létrehozás",
- "vector-view-edit": "Szerkesztés",
- "vector-view-history": "Laptörténet",
- "vector-view-view": "Olvasás",
- "vector-view-viewsource": "A lap forrása"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Bdamokos",
- "Dani",
- "Dj",
- "Misibacsi",
- "Tacsipacsi",
- "Tgr"
- ]
- },
- "vector.css": "/* Az ide elhelyezett CSS hatással lesz a Vector felület használóira */",
- "vector.js": "/* A Vector felületet használó szerkesztők számára betöltendő JavaScriptek */",
- "vector-action-addsection": "Új téma nyitása",
- "vector-action-delete": "Törlés",
- "vector-action-move": "Átnevezés",
- "vector-action-protect": "Lapvédelem",
- "vector-action-undelete": "Visszaállítás",
- "vector-action-unprotect": "Védelem módosítása",
- "vector-view-create": "Létrehozás",
- "vector-view-edit": "Szerkesztés",
- "vector-view-history": "Laptörténet",
- "vector-view-view": "Olvasás",
- "vector-view-viewsource": "A lap forrása",
- "vector-more-actions": "Több"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Teak",
- "Vadgt",
- "Xelgen",
- "Arman musikyan"
- ]
- },
- "skinname-vector": "Սովորական",
- "vector-action-addsection": "Ավելացնել քննարկում",
- "vector-action-delete": "Ջնջել",
- "vector-action-move": "Տեղափոխել այս էջը",
- "vector-action-protect": "Պաշտպանել",
- "vector-action-undelete": "Վերականգնել",
- "vector-action-unprotect": "Փոխել պաշտպանումը",
- "vector-view-create": "Ստեղծել",
- "vector-view-edit": "Խմբագրել",
- "vector-view-history": "Դիտել պատմությունը",
- "vector-view-view": "Կարդալ",
- "vector-view-viewsource": "Դիտել ելատեքստը",
- "vector-more-actions": "Ավելին"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "McDutchie"
- ]
- },
- "vector-skin-desc": "Version moderne de MonoBook con aspecto rejuvenescite e multe meliorationes de usabilitate.",
- "vector.css": "/* Le CSS placiate hic afficera le usatores del apparentia Vector */",
- "vector.js": "/* Omne JavaScript hic se executara pro le usatores del apparentia Vector */",
- "vector-action-addsection": "Adder topico",
- "vector-action-delete": "Deler",
- "vector-action-move": "Renominar",
- "vector-action-protect": "Proteger",
- "vector-action-undelete": "Restaurar",
- "vector-action-unprotect": "Cambiar protection",
- "vector-view-create": "Crear",
- "vector-view-edit": "Modificar",
- "vector-view-history": "Vider historia",
- "vector-view-view": "Leger",
- "vector-view-viewsource": "Vider texto fonte",
- "vector-more-actions": "Plus"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Arifin.wijaya",
- "Bennylin",
- "Farras",
- "Iwan Novirion",
- "Rex"
- ]
- },
- "skinname-vector": "Vektor",
- "vector-skin-desc": "Versi modern dari MonoBook dengan tampilan segar dan banyak perbaikan kegunaan",
- "vector.css": "/* CSS nan ado di siko diterapkan pado kulik Vektor. */",
- "vector.js": "/* Semua JavaScript di sini akan dimuatkan untuk para pengguna yang menggunakan kulit Vector */",
- "vector-action-addsection": "Bagian baru",
- "vector-action-delete": "Hapus",
- "vector-action-move": "Pindahkan",
- "vector-action-protect": "Lindungi",
- "vector-action-undelete": "Pembatalan penghapusan",
- "vector-action-unprotect": "Ubah perlindungan",
- "vector-view-create": "Buat",
- "vector-view-edit": "Sunting",
- "vector-view-history": "Versi terdahulu",
- "vector-view-view": "Baca",
- "vector-view-viewsource": "Lihat sumber",
- "vector-more-actions": "Lainnya"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Makuba",
- "Renan"
- ]
- },
- "vector.css": "/* CSS colocat ci va afectar usatores de pelle Vector */",
- "vector.js": "/* Alquel JavaScript ci va esser cargat por usatores que usa li pelle Vector */",
- "vector-action-addsection": "Adjunter tema",
- "vector-action-delete": "Deleter",
- "vector-action-move": "Mover",
- "vector-action-protect": "Gardar",
- "vector-action-undelete": "Restituer",
- "vector-action-unprotect": "Desgardar",
- "vector-view-create": "Crear",
- "vector-view-edit": "Redacter",
- "vector-view-history": "Historie de versiones",
- "vector-view-view": "Leer",
- "vector-view-viewsource": "Vider fonte"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ukabia"
- ]
- },
- "vector-action-addsection": "Tinyé Okwu",
- "vector-action-delete": "Kàcha",
- "vector-action-move": "Páfụ",
- "vector-action-protect": "Cẹdolu",
- "vector-action-undelete": "Á gbàkashikwà",
- "vector-action-unprotect": "Nchẹdo mgbanwe",
- "vector-view-create": "Ké",
- "vector-view-edit": "Mèzi",
- "vector-view-history": "Zí ịta",
- "vector-view-view": "Gụ́",
- "vector-view-viewsource": "Zi mkpurụ"
-}
+++ /dev/null
-{
- "vector-view-edit": "Suqusiqpaa"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Lam-ang",
- "Saluyot"
- ]
- },
- "vector-skin-desc": "Modernno a bersion ti MonoBook nga addaan iti baro a langa ken adu kadagiti naserbi a panagpasayaat",
- "vector-action-addsection": "Agnayon ti topiko",
- "vector-action-delete": "Ikkaten",
- "vector-action-move": "Iyalis",
- "vector-action-protect": "Salakniban",
- "vector-action-undelete": "Isubli ti inikkat",
- "vector-action-unprotect": "Sukatan ti salaknib",
- "vector-view-create": "Agaramid",
- "vector-view-edit": "Urnosen",
- "vector-view-history": "Kitaen ti pakasaritaan",
- "vector-view-view": "Basaen",
- "vector-view-viewsource": "Kitaen ti taudan",
- "vector-more-actions": "Adu pay"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Amire80",
- "Sapral Mikail"
- ]
- },
- "vector-action-addsection": "БӀагал тӀатоха",
- "vector-action-delete": "ДӀадаккха",
- "vector-action-move": "ЦӀи хувца",
- "vector-action-protect": "Лораде",
- "vector-action-undelete": "Юхаоттаде",
- "vector-action-unprotect": "Лорам хувца",
- "vector-view-create": "Кхолларле",
- "vector-view-edit": "Хувцам",
- "vector-view-history": "Искар",
- "vector-view-view": "Дешар",
- "vector-view-viewsource": "Зембакхама бӀаргтассам"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Malafaya"
- ]
- },
- "vector-action-addsection": "Adjuntar topiko",
- "vector-action-delete": "Efacar",
- "vector-action-move": "Movar",
- "vector-action-protect": "Protektar",
- "vector-action-undelete": "Rekuperar",
- "vector-action-unprotect": "Desprotektar",
- "vector-view-create": "Krear",
- "vector-view-edit": "Redaktar",
- "vector-view-history": "Vidar versionaro",
- "vector-view-view": "Lektar",
- "vector-view-viewsource": "Vidar fonto"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Friðrik Bragi Dýrfjörð",
- "Maxí",
- "Snævar",
- "Ævar Arnfjörð Bjarmason"
- ]
- },
- "vector-action-addsection": "Bæta við umræðu",
- "vector-action-delete": "Eyða",
- "vector-action-move": "Færa",
- "vector-action-protect": "Vernda",
- "vector-action-undelete": "Hætta við eyðingu",
- "vector-action-unprotect": "Breyta verndunarstigi",
- "vector-view-create": "Skapa",
- "vector-view-edit": "Breyta",
- "vector-view-history": "Breytingaskrá",
- "vector-view-view": "Lesa",
- "vector-view-viewsource": "Sýna frumkóða"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Beta16",
- "Darth Kule",
- "Gianfranco",
- "Melos",
- "Pietrodn"
- ]
- },
- "vector-skin-desc": "Versione moderna del MonoBook con un'aspetto nuovo e molti miglioramenti dell'usabilità",
- "vector.css": "/* Gli stili CSS inseriti qui si applicano agli utenti che usano la skin Vector */",
- "vector.js": "/* Il codice JavaScript inserito qui viene caricato dagli utenti che usano la skin Vector */",
- "vector-action-addsection": "Aggiungi discussione",
- "vector-action-delete": "Cancella",
- "vector-action-move": "Sposta",
- "vector-action-protect": "Proteggi",
- "vector-action-undelete": "Ripristina",
- "vector-action-unprotect": "Cambia la protezione",
- "vector-view-create": "Crea",
- "vector-view-edit": "Modifica",
- "vector-view-history": "Cronologia",
- "vector-view-view": "Leggi",
- "vector-view-viewsource": "Visualizza sorgente",
- "vector-more-actions": "Altro"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Aig mest ei varasta"
- ]
- },
- "vector-view-view": "Lukkiia"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Fryed-peach",
- "Marine-Blue",
- "Penn Station",
- "Shirayuki",
- "Whym",
- "青子守歌"
- ]
- },
- "skinname-vector": "ベクター",
- "vector.css": "/* ここに記述したCSSはベクター外装の利用者に影響します */",
- "vector.js": "/* ここにあるすべてのJavaScriptは、ベクター外装を使用している利用者に対して読み込まれます */",
- "vector-action-addsection": "話題追加",
- "vector-action-delete": "削除",
- "vector-action-move": "移動",
- "vector-action-protect": "保護",
- "vector-action-undelete": "復元",
- "vector-action-unprotect": "保護再設定",
- "vector-view-create": "作成",
- "vector-view-edit": "編集",
- "vector-view-history": "履歴表示",
- "vector-view-view": "閲覧",
- "vector-view-viewsource": "ソースを閲覧",
- "vector-more-actions": "その他"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Hazard-SJ",
- "Yocahuna"
- ]
- },
- "vector-action-addsection": "Ad tapik",
- "vector-action-delete": "Diliit",
- "vector-action-move": "Muuv",
- "vector-action-protect": "Protek",
- "vector-action-undelete": "Andiliit",
- "vector-action-unprotect": "Neu protektian",
- "vector-view-create": "Kriet",
- "vector-view-edit": "Hedit",
- "vector-view-history": "Vyuu ischri",
- "vector-view-view": "Riid",
- "vector-view-viewsource": "Vyuu Suos"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Gleki"
- ]
- },
- "vector-action-addsection": "jmina la'e se casnu",
- "vector-action-delete": "vimcu",
- "vector-action-move": "stika lo cmene",
- "vector-action-protect": "bandu",
- "vector-view-create": "zbasu",
- "vector-view-edit": "stika",
- "vector-view-history": "lo ckupau citri",
- "vector-view-view": "tcidu",
- "vector-view-viewsource": "cpacu lo krasi",
- "vector-more-actions": "ji'a"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Pras"
- ]
- },
- "vector-action-addsection": "Tambah topik",
- "vector-action-delete": "Busak",
- "vector-action-move": "Pindhahna",
- "vector-action-protect": "Reksa",
- "vector-action-undelete": "Batalna pambusakan",
- "vector-action-unprotect": "Owahi pangreksan",
- "vector-view-create": "Gawé",
- "vector-view-edit": "Sunting",
- "vector-view-history": "Sajarah kaca",
- "vector-view-view": "Waca",
- "vector-view-viewsource": "Pirsani sumber"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Alsandro",
- "David1010",
- "გიორგიმელა"
- ]
- },
- "skinname-vector": "ვექტორული",
- "vector.css": "/* აქ ჩასმული CSS გამოყენებული იქნება ვექტორული გაფორმების თემაში */",
- "vector-action-addsection": "თემის ჩამატება",
- "vector-action-delete": "წაშლა",
- "vector-action-move": "გადატანა",
- "vector-action-protect": "დაცვა",
- "vector-action-undelete": "აღდგენა",
- "vector-action-unprotect": "დაცვის შეცვლა",
- "vector-view-create": "შექმნა",
- "vector-view-edit": "რედაქტირება",
- "vector-view-history": "ისტორია",
- "vector-view-view": "შემოწმებული სტატია",
- "vector-view-viewsource": "წყაროს ხილვა",
- "vector-more-actions": "მეტი"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Atabek"
- ]
- },
- "vector-action-addsection": "Tema qosıw",
- "vector-action-delete": "O'shiriw",
- "vector-action-move": "Ko'shiriw",
- "vector-action-protect": "Qorg'aw",
- "vector-action-undelete": "Qayta tiklew",
- "vector-action-unprotect": "Qorg'awdı o'zgertiw",
- "vector-view-create": "Jaratıw",
- "vector-view-edit": "O'zgertiw",
- "vector-view-history": "Tariyxın ko'riw",
- "vector-view-view": "Oqıw",
- "vector-view-viewsource": "Deregin ko'riw"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Mmistmurt"
- ]
- },
- "vector-action-addsection": "Rnud ameggay",
- "vector-action-delete": "Mḥu",
- "vector-action-move": "Smimeḍ",
- "vector-action-protect": "Mmesten",
- "vector-action-undelete": "Uɣaled",
- "vector-action-unprotect": "Beddel amesten",
- "vector-view-create": "Snulfu",
- "vector-view-edit": "Ẓẓiẓreg",
- "vector-view-history": "Ẓeṛ amazray",
- "vector-view-view": "Ɣer",
- "vector-view-viewsource": "Ẓer aɣbalu"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Bogups",
- "Тамэ Балъкъэрхэ"
- ]
- },
- "vector-action-addsection": "Теухугъуэ щӀэуэ щӀэдзэн",
- "vector-action-delete": "Ихын",
- "vector-action-move": "ЦӀэр хъуэжын",
- "vector-action-protect": "Хъумэн",
- "vector-action-undelete": "ЗыфӀэгъэувэжын",
- "vector-action-unprotect": "Хъумэныр техыжын",
- "vector-view-create": "ЩӀын",
- "vector-view-edit": "Гъэтэрэзын",
- "vector-view-history": "Тхыдэм еплъын",
- "vector-view-view": "Еджэн",
- "vector-view-viewsource": "КъызхэкӀам еплъын"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Rkupsala"
- ]
- },
- "vector-action-delete": "Kufwa",
- "vector-action-move": "Nata",
- "vector-action-protect": "Keba",
- "vector-view-create": "Tunga",
- "vector-view-edit": "Soba",
- "vector-view-history": "Tala bansoba",
- "vector-view-view": "Tânga"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Rachitrali"
- ]
- },
- "vector-action-addsection": "نوغ موضوع",
- "vector-action-delete": "بوغاوے",
- "vector-action-move": "منتقل کورے",
- "vector-action-protect": "محفوظ کورے",
- "vector-action-undelete": "اچی انگیے",
- "vector-action-unprotect": "غیر محفوظ",
- "vector-view-create": "ساوزاوے",
- "vector-view-edit": "ایڈٹ کورے",
- "vector-view-history": "تاریخچہ",
- "vector-view-view": "راوے",
- "vector-view-viewsource": "مسودہ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Stephenwanjau"
- ]
- },
- "vector-action-delete": "Futa"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Mirzali"
- ]
- },
- "vector-action-addsection": "Mewzu ilawe ke",
- "vector-action-delete": "Bestere",
- "vector-action-move": "Bere",
- "vector-action-protect": "Bısevekne",
- "vector-action-undelete": "Esterıtene peyser bıcê",
- "vector-action-unprotect": "Rake",
- "vector-view-create": "Vıraze",
- "vector-view-edit": "Bıvurne",
- "vector-view-history": "Tarixi basne",
- "vector-view-view": "Bıwane",
- "vector-view-viewsource": "Çımey bıvêne"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Arystanbek",
- "Daniyar",
- "GaiJin",
- "Kaztrans"
- ]
- },
- "vector-action-addsection": "Тақырып қосу",
- "vector-action-delete": "Жою",
- "vector-action-move": "Атауын өзгерту",
- "vector-action-protect": "Қорғау",
- "vector-action-undelete": "Жоймау",
- "vector-action-unprotect": "Қорғанысын өзгерту",
- "vector-view-create": "Бастау",
- "vector-view-edit": "Өңдеу",
- "vector-view-history": "Өңделу тарихы",
- "vector-view-view": "Оқу",
- "vector-view-viewsource": "Қайнарын қарау",
- "vector-more-actions": "Тағы"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Iketsi",
- "Qaqqalik"
- ]
- },
- "vector-action-addsection": "Imm. nutaaq",
- "vector-action-move": "Nuuguk",
- "vector-view-create": "Pilersiguk",
- "vector-view-edit": "Aaqqissoruk",
- "vector-view-history": "Oqalutt.",
- "vector-view-view": "Takuuk",
- "vector-view-viewsource": "Toqqavia takuuk"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "គីមស៊្រុន",
- "វ័ណថារិទ្ធ"
- ]
- },
- "skinname-vector": "វ៉ិចទ័រ",
- "vector.css": "/* CSS បានដាក់ទីនេះនឹងមានអនុភាពលើអ្នកប្រើប្រាស់នៃសំបក Vector */",
- "vector-action-addsection": "បន្ថែមប្រធានបទ",
- "vector-action-delete": "លុបចោល",
- "vector-action-move": "ប្តូរទីតាំង",
- "vector-action-protect": "ការពារ",
- "vector-action-undelete": "ឈប់លុបចោល",
- "vector-action-unprotect": "ប្ដូរការការពារ",
- "vector-view-create": "បង្កើត",
- "vector-view-edit": "កែប្រែ",
- "vector-view-history": "មើលប្រវត្តិ",
- "vector-view-view": "អាន",
- "vector-view-viewsource": "មើលកូដ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ktkaushik",
- "Nayvik",
- "VASANTH S.N."
- ]
- },
- "vector-action-addsection": "ವಿಷಯ ಸೇರಿಸಿ",
- "vector-action-delete": "ಅಳಿಸು",
- "vector-action-move": "ಸ್ಥಳಾಂತರಿಸಿ",
- "vector-action-protect": "ಸಂರಕ್ಷಿಸು",
- "vector-action-undelete": "ಅಳಿಸಬೇಡ",
- "vector-action-unprotect": "ರಕ್ಷಣೆಯನ್ನು ಬದಲಾವಣೆ",
- "vector-view-create": "ಸೃಷ್ಟಿಸು",
- "vector-view-edit": "ಸಂಪಾದಿಸಿ",
- "vector-view-history": "ಇತಿಹಾಸವನ್ನು ನೋಡಿ",
- "vector-view-view": "ಓದು",
- "vector-view-viewsource": "ಆಕರ ವೀಕ್ಷಿಸು"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "ITurtle",
- "Kwj2772",
- "아라"
- ]
- },
- "skinname-vector": "벡터",
- "vector-skin-desc": "모노북 스킨을 사용할 때 사용자 인터페이스를 향상합니다",
- "vector.css": "/* 이 CSS 설정은 벡터 스킨을 사용하는 사용자에게 적용됩니다 */",
- "vector.js": "/* 이 자바스크립트 설정은 벡터 스킨을 사용하는 사용자에게 적용됩니다 */",
- "vector-action-addsection": "새 주제",
- "vector-action-delete": "삭제",
- "vector-action-move": "옮기기",
- "vector-action-protect": "보호",
- "vector-action-undelete": "삭제 취소",
- "vector-action-unprotect": "보호 설정 바꾸기",
- "vector-view-create": "만들기",
- "vector-view-edit": "편집",
- "vector-view-history": "역사 보기",
- "vector-view-view": "읽기",
- "vector-view-viewsource": "원본 보기",
- "vector-more-actions": "더 보기"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Enye Lav"
- ]
- },
- "vector-action-delete": "Чышкыны",
- "vector-view-view": "Лыддьöтны"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Iltever",
- "Къарачайлы"
- ]
- },
- "skinname-vector": "Вектор",
- "vector-action-addsection": "Джангы тема къош",
- "vector-action-delete": "Кетер",
- "vector-action-move": "Атын ауушдур",
- "vector-action-protect": "Джакъла",
- "vector-action-undelete": "Къайтар",
- "vector-action-unprotect": "Джакълауну тюрлендир",
- "vector-view-create": "Къура",
- "vector-view-edit": "Тюрлендир",
- "vector-view-history": "Тарихи",
- "vector-view-view": "Окъу",
- "vector-view-viewsource": "Кодха къара",
- "vector-more-actions": "Энтда"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Protostar"
- ]
- },
- "vector-action-addsection": "Add tòpik",
- "vector-action-delete": "Delet",
- "vector-action-move": "Muf",
- "vector-action-protect": "Protèkt",
- "vector-view-create": "Kreat",
- "vector-view-edit": "Chenj",
- "vector-view-history": "Luk historia",
- "vector-view-view": "Rid",
- "vector-view-viewsource": "Luk dhi sòrs"
-}
+++ /dev/null
-{
- "vector-view-edit": "تَرتیٖب دِیُن",
- "vector-view-view": "پَرُن"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Purodha"
- ]
- },
- "skinname-vector": "Vektor",
- "vector.css": "/* CSS heh aan dä Stell wirrek nur op de Ovverflääsch „Vector“ */",
- "vector.js": "/* De JavaSkrippte fun hee krijje alle Sigge met de Ovverflääsch \"Vector\" jescheck */",
- "vector-action-addsection": "Ne neue Afschnet onge draan!",
- "vector-action-delete": "Fottschmiiße!",
- "vector-action-move": "Ömnänne!",
- "vector-action-protect": "Schöze!",
- "vector-action-undelete": "Zerökholle!",
- "vector-action-unprotect": "Schoz ändere!",
- "vector-view-create": "Neu Schriive!",
- "vector-view-edit": "Ändere!",
- "vector-view-history": "Versione zeije!",
- "vector-view-view": "Lesse!",
- "vector-view-viewsource": "Wikitex aanlooere!"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ferhengvan",
- "Gomada"
- ]
- },
- "vector-action-addsection": "Mijarekê lê zêde bike",
- "vector-action-delete": "Jê bibe",
- "vector-action-move": "Nav biguherîne",
- "vector-action-protect": "Biparêze",
- "vector-action-undelete": "Jê nebe",
- "vector-action-unprotect": "Parastinê rake",
- "vector-view-create": "Çêke",
- "vector-view-edit": "Biguherîne",
- "vector-view-history": "Dîrokê bibîne",
- "vector-view-view": "Bixwîne",
- "vector-view-viewsource": "Çavkaniyan bibîne"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Comp1089"
- ]
- },
- "vector-action-move": "Ним вежны",
- "vector-view-edit": "Вежны",
- "vector-view-view": "Лыддьыны"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Kernoweger",
- "Kw-Moon",
- "Nrowe"
- ]
- },
- "vector-action-addsection": "Keworra testen",
- "vector-action-delete": "Dilea",
- "vector-action-move": "Gwaya",
- "vector-action-protect": "Difres",
- "vector-action-undelete": "Disdhilea",
- "vector-action-unprotect": "Chanjya difresans",
- "vector-view-create": "Gwruthyl",
- "vector-view-edit": "Chanjya",
- "vector-view-history": "Gweles an istori",
- "vector-view-view": "Redya",
- "vector-view-viewsource": "Gweles an bennfenten"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Chorobek",
- "Growingup",
- "Ztimur",
- "Викиней"
- ]
- },
- "vector-action-addsection": "Тема кошуу",
- "vector-action-delete": "Өчүрүү",
- "vector-action-move": "Аталышын өзгөртүү",
- "vector-action-protect": "Коргоо",
- "vector-action-undelete": "Калыбына келтирүү",
- "vector-action-unprotect": "Коргоону өзгөртүү",
- "vector-view-create": "Түзүү",
- "vector-view-edit": "Оңдоо",
- "vector-view-history": "Тарыхын кароо",
- "vector-view-view": "Окуу",
- "vector-view-viewsource": "Кайнарын кароо"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "UV"
- ]
- },
- "vector-action-addsection": "Partem novam addere",
- "vector-action-delete": "Delere",
- "vector-action-move": "Movere",
- "vector-action-protect": "Protegere",
- "vector-action-undelete": "Restituere",
- "vector-action-unprotect": "Protectionem mutare",
- "vector-view-create": "Creare",
- "vector-view-edit": "Recensere",
- "vector-view-history": "Historiam inspicere",
- "vector-view-view": "Legere",
- "vector-view-viewsource": "Fontem inspicere",
- "vector-more-actions": "Plus"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Universal Life"
- ]
- },
- "vector-action-addsection": "Ajustar sujeto",
- "vector-action-delete": "Efassar",
- "vector-action-move": "Taşirear",
- "vector-action-protect": "Guadrar",
- "vector-action-undelete": "Traer atrás",
- "vector-action-unprotect": "Trocar proteksyon",
- "vector-view-create": "Criar",
- "vector-view-edit": "Trocar",
- "vector-view-history": "Ver la istoria",
- "vector-view-view": "Meldar",
- "vector-view-viewsource": "Ver su manadero"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Robby"
- ]
- },
- "vector-skin-desc": "Modern Versioun vu Monobook mat frëschem Look a ville Verbesserunge vun der Benotzerfrëndlechkeet",
- "vector-action-addsection": "Sujet derbäisetzen",
- "vector-action-delete": "Läschen",
- "vector-action-move": "Réckelen",
- "vector-action-protect": "Spären",
- "vector-action-undelete": "Restauréieren",
- "vector-action-unprotect": "Spär änneren",
- "vector-view-create": "Uleeën",
- "vector-view-edit": "Änneren",
- "vector-view-history": "Versioune weisen",
- "vector-view-view": "Liesen",
- "vector-view-viewsource": "Quellcode weisen",
- "vector-more-actions": "Méi"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Lezgia",
- "Migraghvi",
- "Namik",
- "Soul Train"
- ]
- },
- "vector-action-addsection": "Тема алава авун",
- "vector-action-delete": "Алудун",
- "vector-action-move": "ТӀвар эхцигун",
- "vector-action-protect": "Хуьн",
- "vector-action-undelete": "ТуькӀуьр хъувун",
- "vector-action-unprotect": "Хуьн дегишарун",
- "vector-view-create": "ТуькӀуьрун",
- "vector-view-edit": "Дуьзарин",
- "vector-view-history": "Тарихдиз килигун",
- "vector-view-view": "КӀелун",
- "vector-view-viewsource": "Чешме къалурун"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Kizito"
- ]
- },
- "vector-action-addsection": "Tandikawo emboozi endala",
- "vector-action-delete": "Gyawo olupapula luno",
- "vector-action-move": "Simbuliza",
- "vector-action-protect": "Ssiba",
- "vector-action-undelete": "Zawo",
- "vector-action-unprotect": "Kyusa ebikugizo",
- "vector-view-create": "Lukolewo",
- "vector-view-edit": "Kyusa",
- "vector-view-history": "Ennanda ya fayiro eno",
- "vector-view-view": "Soma",
- "vector-view-viewsource": "Kebera obulambike obw'ennono obw'olupapula luno"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ooswesthoesbes"
- ]
- },
- "vector-action-addsection": "Voog köpke toe",
- "vector-action-delete": "Ewegsjaffe",
- "vector-action-move": "Verplaats",
- "vector-action-protect": "Besjirm",
- "vector-action-undelete": "Plaats trök",
- "vector-action-unprotect": "Anger beveiliging",
- "vector-view-create": "Maak aan",
- "vector-view-edit": "Bewirk",
- "vector-view-history": "Bekiek de gesjiedenis",
- "vector-view-view": "Laes",
- "vector-view-viewsource": "Bekiek bróntèks"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Gastaz",
- "Giromin Cangiaxo"
- ]
- },
- "vector-action-addsection": "Azónzi discusción",
- "vector-action-delete": "Scancella",
- "vector-action-move": "Mescia",
- "vector-action-protect": "Protezi",
- "vector-action-undelete": "Recuppera",
- "vector-action-unprotect": "Cangia a proteçion",
- "vector-view-create": "Crea",
- "vector-view-edit": "Càngia",
- "vector-view-history": "Fanni védde a Stöia",
- "vector-view-view": "Lêzi",
- "vector-view-viewsource": "Veddi a sorgénte"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Warbola"
- ]
- },
- "vector-action-addsection": "Pangid jūrõ tēma",
- "vector-action-delete": "Kištāntõgid jarā",
- "vector-action-move": "Vīž jarā",
- "vector-action-protect": "Kaitsõmi",
- "vector-view-create": "Lūo",
- "vector-view-edit": "Redigīer",
- "vector-view-history": "Nägţ istōrijõ",
- "vector-view-view": "Vaņ",
- "vector-view-viewsource": "Vaņ ovāt tekstõ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Insübrich",
- "Ninonino"
- ]
- },
- "vector-action-addsection": "Giunta argument",
- "vector-action-delete": "Scancela",
- "vector-action-move": "Sposta",
- "vector-action-protect": "Prutegg",
- "vector-action-undelete": "Recüpera",
- "vector-action-unprotect": "Càmbia la protesiù",
- "vector-view-create": "Crea",
- "vector-view-edit": "Mudifega",
- "vector-view-history": "Varda la storia",
- "vector-view-view": "Legg",
- "vector-view-viewsource": "Varda el codes",
- "vector-more-actions": "Amò"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Eruedin",
- "Moyogo"
- ]
- },
- "vector-action-addsection": "Kobakisa mpɔ̂",
- "vector-action-delete": "Kolímwisa",
- "vector-action-move": "Kobóngola nkómbó",
- "vector-action-protect": "Kobátela",
- "vector-action-undelete": "Kolímwisa tɛ̂",
- "vector-action-unprotect": " Kobátela tɛ̂",
- "vector-view-create": "Kokela",
- "vector-view-edit": "Kobɔngisa",
- "vector-view-history": "Komɔ́nisa mokóló",
- "vector-view-view": "Kotánga",
- "vector-view-viewsource": "Komɔ́nisa mosólo"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Mogoeilor"
- ]
- },
- "vector-action-addsection": "موضوع اضاف بكيد",
- "vector-action-delete": "پاکسا کردن",
- "vector-action-move": "جاوه جا بوئيت",
- "vector-action-protect": "حمايت بكيد",
- "vector-action-undelete": "حذف نبيئني",
- "vector-action-unprotect": "حمايت آلشت بكيد",
- "vector-view-create": "راس كردن",
- "vector-view-edit": "ويرايشت",
- "vector-view-history": "ديئن ويرگار",
- "vector-view-view": "حنن",
- "vector-view-viewsource": "سرچشمه نه بوينيت"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Garas",
- "Homo",
- "Matasg",
- "Perkunas"
- ]
- },
- "skinname-vector": "Vektorinė",
- "vector-action-addsection": "Pridėti temą",
- "vector-action-delete": "Ištrinti",
- "vector-action-move": "Pervardyti",
- "vector-action-protect": "Užrakinti",
- "vector-action-undelete": "Atkurti",
- "vector-action-unprotect": "Keisti apsaugą",
- "vector-view-create": "Kurti",
- "vector-view-edit": "Redaguoti",
- "vector-view-history": "Istorija",
- "vector-view-view": "Skaityti",
- "vector-view-viewsource": "Žiūrėti kodą"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Dark Eagle"
- ]
- },
- "vector-action-addsection": "Dalikt padaļu",
- "vector-action-delete": "Iztreit",
- "vector-action-move": "Puorceļt",
- "vector-action-protect": "Apsorguot",
- "vector-action-unprotect": "Puormeit apsardzeibu",
- "vector-view-edit": "Pataiseit",
- "vector-view-history": "Viesture",
- "vector-view-view": "Vērtīs"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "RMizo"
- ]
- },
- "vector-action-addsection": "Thupui belhna",
- "vector-action-delete": "Paihna",
- "vector-action-move": "Sawnna",
- "vector-action-protect": "Venhimna",
- "vector-action-undelete": "Lak kir lehna",
- "vector-action-unprotect": "Venhimna dinhmun tidanglam rawh",
- "vector-view-create": "Siamna",
- "vector-view-edit": "Siamţhatna",
- "vector-view-history": "Hunhlui-chanchin",
- "vector-view-view": "Chhiarna",
- "vector-view-viewsource": "A hnar enna"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "علی ساکی لرستانی"
- ]
- },
- "vector-view-history": "دیئن تاریخچه",
- "vector-view-view": "هوندن"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Marozols",
- "Papuass"
- ]
- },
- "vector-action-addsection": "Jauna sadaļa",
- "vector-action-delete": "Dzēst",
- "vector-action-move": "Pārvietot",
- "vector-action-protect": "Aizsargāt",
- "vector-action-undelete": "Atjaunot",
- "vector-action-unprotect": "Mainīt aizsardzību",
- "vector-view-create": "Izveidot",
- "vector-view-edit": "Labot",
- "vector-view-history": "Hronoloģija",
- "vector-view-view": "Skatīt",
- "vector-view-viewsource": "Aplūkot kodu",
- "vector-more-actions": "Vairāk"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Justincheng12345"
- ]
- },
- "skinname-vector": "動力",
- "vector.css": "/* 此之 CSS 用於動力面之簿也 */",
- "vector.js": "/* 此之JavaScript將載於用動力面之簿 */",
- "vector-action-addsection": "入題",
- "vector-action-delete": "刪",
- "vector-action-move": "遷",
- "vector-action-protect": "緘",
- "vector-action-undelete": "覽刪",
- "vector-action-unprotect": "啟",
- "vector-view-create": "立",
- "vector-view-edit": "纂",
- "vector-view-history": "覽史",
- "vector-view-view": "閱",
- "vector-view-viewsource": "覽源"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Bombola",
- "Ceas08",
- "Erdemaslancan"
- ]
- },
- "vector-action-delete": "Jili",
- "vector-action-move": "Tori",
- "vector-action-protect": "İçvi",
- "vector-view-create": "dokʼidi",
- "vector-view-edit": "Doktiri",
- "vector-view-view": "İǩitxi"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ggajendra",
- "Umeshberma"
- ]
- },
- "skinname-vector": "सदिश",
- "vector-action-addsection": "विचार-बिन्दु जोड़ू",
- "vector-action-delete": "मेटाउ",
- "vector-action-move": "घसकाउ",
- "vector-action-protect": "रक्षण करू",
- "vector-action-undelete": "आपस लाउ",
- "vector-action-unprotect": "सुरक्षा बदलू",
- "vector-view-create": "बनाउ",
- "vector-view-edit": "सम्पादन करू",
- "vector-view-history": "इतिहास देखू",
- "vector-view-view": "पढ़ू",
- "vector-view-viewsource": "जड़ि देखू"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "StefanusRA"
- ]
- },
- "vector-action-addsection": "Nambah topik",
- "vector-action-delete": "Busek",
- "vector-action-move": "Pindah",
- "vector-action-protect": "Reksa",
- "vector-action-undelete": "Batalna pambusakan",
- "vector-action-unprotect": "Owahi pangreksan",
- "vector-view-create": "Gawe",
- "vector-view-edit": "Sunting",
- "vector-view-history": "Sajarah kaca",
- "vector-view-view": "Waca",
- "vector-view-viewsource": "Deleng sumbere"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Numulunj pilgae"
- ]
- },
- "vector-action-addsection": "Поладомс мезень колга корхтамс",
- "vector-action-delete": "Нардамс",
- "vector-action-move": "Шашфтомс",
- "vector-action-protect": "Араламс",
- "vector-action-undelete": "Мърдафтомс",
- "vector-action-unprotect": "Араламать полафтомс",
- "vector-view-create": "Тиемс",
- "vector-view-edit": "Петнемс",
- "vector-view-history": "История няфтемс",
- "vector-view-view": "Морафтомс",
- "vector-view-viewsource": "Лисьма няфтемс"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Jagwar"
- ]
- },
- "vector-action-addsection": "Hanampy lohahevitra",
- "vector-action-delete": "Fafana",
- "vector-action-move": "Hanolo anarana",
- "vector-action-protect": "Arovy",
- "vector-action-undelete": "Avereno",
- "vector-action-unprotect": "Hanala ny fiarovana",
- "vector-view-create": "Foronona",
- "vector-view-edit": "Hanova",
- "vector-view-history": "Hijery ny tantara",
- "vector-view-view": "Hamaky",
- "vector-view-viewsource": "Hijery fango"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Azim",
- "Sergey Ivanov",
- "Сай",
- "Санюн Вадик"
- ]
- },
- "vector-action-addsection": "У ӱжашым тӱҥалаш",
- "vector-action-delete": "Шӧраш",
- "vector-action-move": "Лӱмым вашталташ",
- "vector-action-protect": "Тӧрлатымаш деч аралаш",
- "vector-action-undelete": "Шӧрымым пӧртылаш",
- "vector-action-unprotect": "Оролым вашталташ",
- "vector-view-create": "Ышташ",
- "vector-view-edit": "Тӧрлаташ",
- "vector-view-history": "Эртымгорным ончалаш",
- "vector-view-view": "Лудаш",
- "vector-view-viewsource": "Тӱҥалтыш текстым ончалаш"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Piwaiwaka"
- ]
- },
- "vector-view-view": "Tirohia"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Amqui"
- ]
- },
- "vector-action-move": "Ejigliwsit",
- "vector-view-create": "Etlitoq",
- "vector-view-view": "Egiljet"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Iwan Novirion",
- "Luthfi94",
- "VoteITP"
- ]
- },
- "skinname-vector": "Vektor",
- "vector-action-addsection": "Bagian baru",
- "vector-action-delete": "Hapuih",
- "vector-action-move": "Pindahkan",
- "vector-action-protect": "Linduangkan",
- "vector-action-undelete": "Pambatalan pangapuihan",
- "vector-action-unprotect": "Tuka palinduangan",
- "vector-view-create": "Buek",
- "vector-view-edit": "Suntiang",
- "vector-view-history": "Riwayaik",
- "vector-view-view": "Baco",
- "vector-view-viewsource": "Caliak sumber"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Bjankuloski06",
- "Brest"
- ]
- },
- "skinname-vector": "Векторско",
- "vector-skin-desc": "Современа верзија на рувото МоноБук со свеж изглед и многу подобрувања на употребливоста",
- "vector.css": "/* Тука поставениот CSS се однесува на корисниците на рувото „Векторско“ */",
- "vector.js": "/* Тука поставениот JavaScript ќе им се вчитува на корисниците што го користат рувото „Векторско“ */",
- "vector-action-addsection": "Додај тема",
- "vector-action-delete": "Избриши",
- "vector-action-move": "Премести",
- "vector-action-protect": "Заштити",
- "vector-action-undelete": "Врати",
- "vector-action-unprotect": "Измени заштита",
- "vector-view-create": "Создај",
- "vector-view-edit": "Уреди",
- "vector-view-history": "Историја",
- "vector-view-view": "Читај",
- "vector-view-viewsource": "Извор",
- "vector-more-actions": "Повеќе"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Anoopan",
- "Praveenp"
- ]
- },
- "skinname-vector": "വെക്റ്റർ",
- "vector.css": "/* ഇവിടെ നൽകുന്ന സി.എസ്.എസ്. വെക്റ്റർ ദൃശ്യരൂപത്തിനു ബാധകമായിരിക്കും*/",
- "vector.js": "/*ഇവിടെ നൽകുന്ന ജാവാസ്ക്രിപ്റ്റ് വെക്റ്റർ ദൃശ്യരൂപം ഉപയോഗിക്കുന്ന ഉപയോക്താക്കൾക്ക് ബാധകമായിരിക്കും*/",
- "vector-action-addsection": "വിഷയം ചേർക്കുക",
- "vector-action-delete": "മായ്ക്കുക",
- "vector-action-move": "തലക്കെട്ട് മാറ്റുക",
- "vector-action-protect": "സംരക്ഷിക്കുക",
- "vector-action-undelete": "മായ്ക്കപ്പെട്ടത് പുനഃസ്ഥാപിക്കുക",
- "vector-action-unprotect": "സംരക്ഷണത്തിൽ മാറ്റംവരുത്തുക",
- "vector-view-create": "സൃഷ്ടിക്കുക",
- "vector-view-edit": "തിരുത്തുക",
- "vector-view-history": "നാൾവഴി കാണുക",
- "vector-view-view": "വായിക്കുക",
- "vector-view-viewsource": "മൂലരൂപം കാണുക",
- "vector-more-actions": "കൂടുതൽ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Chinneeb",
- "MongolWiki",
- "Wisdom"
- ]
- },
- "vector-action-addsection": "Сэдэв нэмэх",
- "vector-action-delete": "Устгах",
- "vector-action-move": "Зөөх",
- "vector-action-protect": "Хамгаалах",
- "vector-action-undelete": "Үл устгах",
- "vector-action-unprotect": "Хамгаалалтаа солих",
- "vector-view-create": "Үүсгэх",
- "vector-view-edit": "Засварлах",
- "vector-view-history": "Түүх",
- "vector-view-view": "Унших",
- "vector-view-viewsource": "Кодыг харах"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Minggantu"
- ]
- },
- "vector-action-delete": "Dabgire",
- "vector-action-move": "Guribure",
- "vector-action-protect": "Karmara",
- "vector-view-create": "Ilibure",
- "vector-view-edit": "banjibume arara",
- "vector-view-history": "ere šu wen i suduri be baicara",
- "vector-view-view": "hūlara",
- "vector-view-viewsource": "da šu wen be baicara"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Kaajawa",
- "V.narsikar"
- ]
- },
- "skinname-vector": "सदिश",
- "vector-action-addsection": "विषय जोडा",
- "vector-action-delete": "वगळा",
- "vector-action-move": "स्थानांतरण",
- "vector-action-protect": "सुरक्षित करा",
- "vector-action-undelete": "वगळलेले पुनर्स्थापित करा",
- "vector-action-unprotect": "सुरक्षितता बदला",
- "vector-view-create": "तयार करा",
- "vector-view-edit": "संपादन",
- "vector-view-history": "इतिहास पहा",
- "vector-view-view": "वाचा",
- "vector-view-viewsource": "स्रोत पहा",
- "vector-more-actions": "अधिक"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Amdf"
- ]
- },
- "vector-action-delete": "Карангдаш",
- "vector-action-move": "Лӹмӹм вашталташ",
- "vector-action-protect": "Ӹшӹклӓш",
- "vector-view-create": "Ӹштӓш",
- "vector-view-edit": "Тӧрлӹмӓш",
- "vector-view-history": "Историм анжымаш",
- "vector-view-view": "Лыдмаш",
- "vector-view-viewsource": "Сек пӹтӓриш кодым анжалаш"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Anakmalaysia",
- "Aurora",
- "Pizza1016"
- ]
- },
- "skinname-vector": "Vector",
- "vector-skin-desc": "Versi MonoBook yang moden dengan rupa yang segar dan banyak pembaikan kepada kegunaan.",
- "vector.css": "/* CSS yang terletak di sini akan mempengaruhi pengguna kulit Vector */",
- "vector.js": "/ * Sebarang JavaScript di sini akan dimuatkan untuk pengguna-pengguna yang menggunakan kulit Vector * /",
- "vector-action-addsection": "Buka topik",
- "vector-action-delete": "Hapus",
- "vector-action-move": "Pindah",
- "vector-action-protect": "Lindung",
- "vector-action-undelete": "Nyahhapus",
- "vector-action-unprotect": "Ubah perlindungan",
- "vector-view-create": "Cipta",
- "vector-view-edit": "Sunting",
- "vector-view-history": "Lihat sejarah",
- "vector-view-view": "Baca",
- "vector-view-viewsource": "Lihat sumber",
- "vector-more-actions": "Lain"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Chrisportelli",
- "Leli Forte"
- ]
- },
- "vector-action-addsection": "Żid diskussjoni",
- "vector-action-delete": "Ħassar",
- "vector-action-move": "Mexxi",
- "vector-action-protect": "Ipproteġi",
- "vector-action-undelete": "Irkupra",
- "vector-action-unprotect": "Biddel il-protezzjoni",
- "vector-view-create": "Oħloq",
- "vector-view-edit": "Editja",
- "vector-view-history": "Ara l-kronoloġija",
- "vector-view-view": "Aqra",
- "vector-view-viewsource": "Ara s-sors",
- "vector-more-actions": "Aktar"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Mahali syarifuddin"
- ]
- },
- "vector-view-view": "Baco",
- "vector-view-viewsource": "Jingok sumber"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Lionslayer",
- "Myanmars"
- ]
- },
- "vector-action-addsection": "အကြောင်းအရာအသစ် ထပ်ထည့်ရန်",
- "vector-action-delete": "ဖျက်ပါ",
- "vector-action-move": "ရွှေ့ပါ",
- "vector-action-protect": "ထိမ်းသိမ်းပါ",
- "vector-action-undelete": "မဖျက်တော့ရန်",
- "vector-action-unprotect": "ကာကွယ်ခြင်းကို ပြောင်းလဲရန်",
- "vector-view-create": "စတင်ရေးသားရန်",
- "vector-view-edit": "ပြင်ရန်",
- "vector-view-history": "ရာဇဝင်ကြည့်ရန်",
- "vector-view-view": "ဖတ်ရန်",
- "vector-view-viewsource": "ရင်းမြစ်ကို ကြည့်ရန်"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Botuzhaleny-sodamo"
- ]
- },
- "vector-action-addsection": "Поладомс мезде кортамс",
- "vector-action-delete": "Нардамс",
- "vector-action-move": "Печтевтемс",
- "vector-action-protect": "Аравтомс ванстомас",
- "vector-action-undelete": "Вельмевтемс нардазенть",
- "vector-action-unprotect": "Полавтомс ванстоманзо",
- "vector-view-create": "Теемс-Шкамс",
- "vector-view-edit": "Витнемс-петнемс",
- "vector-view-history": "Ваномс юронзо-путовксонзо",
- "vector-view-view": "Ловномс",
- "vector-view-viewsource": "Ваномс косто саезь"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Mjbmr",
- "محک"
- ]
- },
- "vector-action-addsection": "ترنه گپ بزوئن",
- "vector-action-delete": "پاک هاکردن",
- "vector-action-move": "دکش هاکردن",
- "vector-action-protect": "زلفن بزوئن",
- "vector-action-undelete": "دباره بنویشته بیّن",
- "vector-action-unprotect": "زلفن عوض هاکردن",
- "vector-view-create": "بساتن",
- "vector-view-edit": "دچیین",
- "vector-view-history": "تاریخچه ره بَدیین",
- "vector-view-view": "بخوندستن",
- "vector-view-viewsource": "ونه منبع ره هارشائن"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ricardo gs"
- ]
- },
- "vector-action-delete": "Ticpolōz",
- "vector-action-move": "Ticzacāz",
- "vector-action-protect": "Ticquīxtīz",
- "vector-view-create": "Ticchīhuāz",
- "vector-view-edit": "Ticpatlāz",
- "vector-view-history": "Tlahcuilōlli tlahcuilōlloh",
- "vector-view-view": "Tāmapōhuaz",
- "vector-view-viewsource": "Tiquittāz in mēyalli"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ianbu"
- ]
- },
- "vector-action-addsection": "Ke chi̍t-ê toān-lo̍h",
- "vector-action-delete": "Thâi",
- "vector-action-move": "Sóa khì",
- "vector-action-protect": "Pó-hō·",
- "vector-action-undelete": "chhú-siau thâi tiàu",
- "vector-action-unprotect": "kái pó-hō·",
- "vector-view-create": "Khai-sí siá",
- "vector-view-edit": "Siu-kái",
- "vector-view-history": "khoàⁿ le̍k-sú",
- "vector-view-view": "Tha̍k",
- "vector-view-viewsource": "Khoàⁿ goân-sú lōe-iông",
- "vector-more-actions": "閣看"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Chelin"
- ]
- },
- "vector-action-addsection": "Aggiunge chiacchierata",
- "vector-action-delete": "Scancèlla",
- "vector-action-move": "Spusta",
- "vector-action-protect": "Prutegge",
- "vector-action-undelete": "Ripristina",
- "vector-action-unprotect": "Càgna prutezzione",
- "vector-view-create": "Cria",
- "vector-view-edit": "Càgna",
- "vector-view-history": "Vere cronologgia",
- "vector-view-view": "Legge",
- "vector-view-viewsource": "Vere sorgente"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Danmichaelo",
- "Event",
- "Nghtwlkr"
- ]
- },
- "vector-skin-desc": "Moderne versjon av MonoBook med et friskt utseende og mange bruksforbedringer",
- "vector-action-addsection": "Nytt emne",
- "vector-action-delete": "Slett",
- "vector-action-move": "Flytt",
- "vector-action-protect": "Beskytt",
- "vector-action-undelete": "Gjenopprett",
- "vector-action-unprotect": "Endre beskyttelse",
- "vector-view-create": "Opprett",
- "vector-view-edit": "Rediger",
- "vector-view-history": "Vis historikk",
- "vector-view-view": "Les",
- "vector-view-viewsource": "Vis kilden",
- "vector-more-actions": "Mer"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Servien"
- ]
- },
- "vector-action-addsection": "Niej onderwarp",
- "vector-action-delete": "Vortdoon",
- "vector-action-move": "Herneumen",
- "vector-action-protect": "Beveiligen",
- "vector-action-undelete": "Weerummeplaotsen",
- "vector-action-unprotect": "Beveiliging wiezigen",
- "vector-view-create": "Anmaken",
- "vector-view-edit": "Bewarken",
- "vector-view-history": "Geschiedenisse bekieken",
- "vector-view-view": "Lezen",
- "vector-view-viewsource": "Brontekste bekieken",
- "vector-more-actions": "Meer"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Slomox",
- "Zylbath"
- ]
- },
- "vector-action-addsection": "Thema tofögen",
- "vector-action-delete": "Wegdoon",
- "vector-action-move": "Schuven",
- "vector-action-protect": "Schulen",
- "vector-action-undelete": "Wedderhalen",
- "vector-action-unprotect": "Siedenschuul ännern",
- "vector-view-create": "Opstellen",
- "vector-view-edit": "Ännern",
- "vector-view-history": "Historie bekieken",
- "vector-view-view": "Lesen",
- "vector-view-viewsource": "Borntext bekieken"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Bhawani Gautam",
- "RajeshPandey",
- "सरोज कुमार ढकाल"
- ]
- },
- "skinname-vector": "भेक्टर",
- "vector.css": "/* यहाँ राखिएको CSS ले भेक्टर स्किनको प्रयोगकर्ताहरुलाई प्रभावित गर्ने छ */",
- "vector-action-addsection": "विषय थप्नुहोस",
- "vector-action-delete": "हटाउने",
- "vector-action-move": "सार्ने",
- "vector-action-protect": "सुरक्षित गर्ने",
- "vector-action-undelete": "हटाएको रद्द गर्ने",
- "vector-action-unprotect": "सुरक्षा परिवर्तन गर्ने",
- "vector-view-create": "सृजना गर्ने",
- "vector-view-edit": "सम्पादन",
- "vector-view-history": "इतिहास हेर्ने",
- "vector-view-view": "पढ्ने",
- "vector-view-viewsource": "स्रोत हेर्ने"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Eukesh"
- ]
- },
- "vector-action-move": "संकादिसँ",
- "vector-view-create": "दयेकादिसँ",
- "vector-view-edit": "सम्पादन",
- "vector-view-history": "इतिहास स्वयादिसँ",
- "vector-view-view": "ब्वनादिसँ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Calak",
- "Romaine",
- "SPQRobin",
- "Siebrand",
- "Troefkaart",
- "Sjoerddebruin"
- ]
- },
- "skinname-vector": "Vector",
- "vector-skin-desc": "Moderne versie van MonoBook met een fris uiterlijk en verbeteringen op het gebied van gebruiksvriendelijkheid",
- "vector.css": "/* CSS die hier wordt geplaatst heeft alleen invloed op de skin Vector */",
- "vector.js": "/* JavaScript die hier wordt geplaatst heeft alleen invloed op gebruikers die de skin Vector gebruiken */",
- "vector-action-addsection": "Kopje toevoegen",
- "vector-action-delete": "Verwijderen",
- "vector-action-move": "Hernoemen",
- "vector-action-protect": "Beveiligen",
- "vector-action-undelete": "Terugplaatsen",
- "vector-action-unprotect": "Beveiliging wijzigen",
- "vector-view-create": "Aanmaken",
- "vector-view-edit": "Bewerken",
- "vector-view-history": "Geschiedenis weergeven",
- "vector-view-view": "Lezen",
- "vector-view-viewsource": "Brontekst bekijken",
- "vector-more-actions": "Meer"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Gunnernett",
- "Njardarlogar"
- ]
- },
- "vector-action-addsection": "Nytt emne",
- "vector-action-delete": "Slett",
- "vector-action-move": "Flytt",
- "vector-action-protect": "Vern",
- "vector-action-undelete": "Gjenopprett",
- "vector-action-unprotect": "Endra vern",
- "vector-view-create": "Opprett",
- "vector-view-edit": "Endre",
- "vector-view-history": "Sjå historikken",
- "vector-view-view": "Les",
- "vector-view-viewsource": "Sjå kjelda",
- "vector-more-actions": "Meir"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Malafaya"
- ]
- },
- "vector-action-delete": "Ekarta",
- "vector-view-edit": "Modifika",
- "vector-view-view": "Lekte"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "WikiEoFrEn"
- ]
- },
- "vector-view-create": "Criyaer",
- "vector-view-edit": "Amendaer",
- "vector-view-view": "Luure"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Mohau"
- ]
- },
- "vector-action-addsection": "Lokela sererwa",
- "vector-action-delete": "Phumula",
- "vector-action-move": "Huduša",
- "vector-action-protect": "Lota",
- "vector-view-create": "Hlola",
- "vector-view-edit": "Fetola",
- "vector-view-history": "Laetša histori",
- "vector-view-view": "Bala",
- "vector-view-viewsource": "Lebelela mothopo"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Boulaur",
- "Cedric31"
- ]
- },
- "vector.css": "/* Lo CSS plaçat aicí afectarà los utilizaires de l’abilhatge Vector */",
- "vector.js": "/* Tot JavaScript aicí serà cargat amb las paginas accedidas pels utilizaires de l’abilhatge Vector unicament. */",
- "vector-action-addsection": "Apondre un subjècte",
- "vector-action-delete": "Suprimir",
- "vector-action-move": "Tornar nomenar",
- "vector-action-protect": "Protegir",
- "vector-action-undelete": "Restablir",
- "vector-action-unprotect": "Suprimir la proteccion",
- "vector-view-create": "Crear",
- "vector-view-edit": "Modificar",
- "vector-view-history": "Veire l'istoric",
- "vector-view-view": "Legir",
- "vector-view-viewsource": "Veire la font"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Jnanaranjan Sahu",
- "Psubhashish"
- ]
- },
- "vector-action-addsection": "ନୂଆ ଯୋଡ଼ନ୍ତୁ",
- "vector-action-delete": "ଲିଭାଇବେ",
- "vector-action-move": "ଘୁଞ୍ଚାଇବେ",
- "vector-action-protect": "କିଳିବେ",
- "vector-action-undelete": "ଲିଭାଇବେ ନାହିଁ",
- "vector-action-unprotect": "କିଳିବେ ନାହିଁ",
- "vector-view-create": "ତିଆରି କରନ୍ତୁ",
- "vector-view-edit": "ସମ୍ପାଦନା (Edit)",
- "vector-view-history": "ଇତିହାସ",
- "vector-view-view": "ପଢ଼ନ୍ତୁ",
- "vector-view-viewsource": "ସୋର୍ସ ଦେଖନ୍ତୁ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Amikeco",
- "Bouron"
- ]
- },
- "vector-action-addsection": "Нæуæг ныхас бакæнын",
- "vector-action-delete": "Схафын",
- "vector-action-move": "Ном ивын",
- "vector-action-protect": "Сæхгæнын",
- "vector-action-undelete": "Рацаразын",
- "vector-action-unprotect": "Ивын хъахъхъæд",
- "vector-view-create": "Скæнын",
- "vector-view-edit": "Ивын",
- "vector-view-history": "Истори",
- "vector-view-view": "Кæсын",
- "vector-view-viewsource": "Код кæсын"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Aalam",
- "Babanwalia",
- "Raj Singh",
- "TariButtar"
- ]
- },
- "vector-action-addsection": "ਵਿਸ਼ਾ ਜੋੜੋ",
- "vector-action-delete": "ਹਟਾਓ",
- "vector-action-move": "ਭੇਜੋ",
- "vector-action-protect": "ਸੁਰੱਖਿਆ",
- "vector-action-undelete": "ਹਟਾਉਣਾ-ਵਾਪਸ",
- "vector-action-unprotect": "ਸੁਰੱਖਿਆ ਬਦਲੋ",
- "vector-view-create": "ਬਣਾਓ",
- "vector-view-edit": "ਸੋਧੋ",
- "vector-view-history": "ਅਤੀਤ ਵੇਖੋ",
- "vector-view-view": "ਪੜ੍ਹੋ",
- "vector-view-viewsource": "ਸਰੋਤ ਵੇਖੋ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Katimawan2005",
- "Val2397"
- ]
- },
- "vector-action-addsection": "Dagdagan ing pisasabian",
- "vector-action-delete": "Buran",
- "vector-action-move": "Iyalis",
- "vector-action-protect": "Protectan/kambilan",
- "vector-action-undelete": "Isubli/iurung ya pangabura",
- "vector-action-unprotect": "Idayu ya panga-protecta",
- "vector-view-create": "Maglalang",
- "vector-view-edit": "Alilan",
- "vector-view-history": "Lawen ya ing amlat",
- "vector-view-view": "Basan",
- "vector-view-viewsource": "Lawen ya ing pikuanan"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Sahaquiel9102"
- ]
- },
- "vector-action-delete": "Cjũcj",
- "vector-action-move": "Quẽese'j",
- "vector-action-protect": "Pjupj",
- "vector-view-edit": "Yu'ptjej",
- "vector-view-view": "Lẽeĩ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Geoleplubo"
- ]
- },
- "vector-action-addsection": "Rajouter un sujeut",
- "vector-action-delete": "Défacer",
- "vector-action-move": "Canger ch'nom",
- "vector-action-protect": "Garantir",
- "vector-action-undelete": "N'poin défacher",
- "vector-action-unprotect": "Canger l'garantie",
- "vector-view-create": "Créer",
- "vector-view-edit": "Éditer",
- "vector-view-history": "Vir l'histoère",
- "vector-view-view": "Lire",
- "vector-view-viewsource": "Vir l'source"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Xqt"
- ]
- },
- "vector-action-delete": "Verwische",
- "vector-action-move": "Ziehe",
- "vector-action-protect": "Schitze",
- "vector-view-create": "Schtaerte",
- "vector-view-edit": "Ennere",
- "vector-view-history": "Gschicht zeige",
- "vector-view-view": "Lese"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Manuae"
- ]
- },
- "vector-action-addsection": "Abschnidd dzufiesche",
- "vector-action-delete": "Lesche",
- "vector-action-move": "Vaschiewe",
- "vector-action-protect": "Schidze",
- "vector-action-undelete": "Zriggbringe",
- "vector-view-create": "Õleesche",
- "vector-view-edit": "Drõ schaffe",
- "vector-view-history": "Dadaigschischd",
- "vector-view-view": "Lese",
- "vector-view-viewsource": "Gwelltegschd zaische"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Hemant wikikosh1"
- ]
- },
- "vector-view-create": "रचेतु"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "AmaryllisGardener"
- ]
- },
- "vector-view-history": "View histrei"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Matma Rex",
- "Sp5uhe"
- ]
- },
- "skinname-vector": "Wektor",
- "vector-skin-desc": "Odświeżona wersja skórki Książka, z nowym wyglądem i usprawnieniami",
- "vector.css": "/* Umieszczony tutaj kod CSS wpłynie na wygląd skórki Wektor */",
- "vector.js": "/* Umieszczony tutaj kod JavaScript zostanie załadowany wyłącznie przez użytkowników korzystających ze skórki Wektor */",
- "vector-action-addsection": "Dodaj temat",
- "vector-action-delete": "Usuń",
- "vector-action-move": "Przenieś",
- "vector-action-protect": "Zabezpiecz",
- "vector-action-undelete": "Odtwórz",
- "vector-action-unprotect": "Zmień zabezpieczenie",
- "vector-view-create": "Utwórz",
- "vector-view-edit": "Edytuj",
- "vector-view-history": "Wyświetl historię",
- "vector-view-view": "Czytaj",
- "vector-view-viewsource": "Tekst źródłowy",
- "vector-more-actions": "Więcej"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Borichèt"
- ]
- },
- "vector-action-addsection": "Gionté n'argoment",
- "vector-action-delete": "Scancelé",
- "vector-action-move": "Tramudé",
- "vector-action-protect": "Protege",
- "vector-action-undelete": "Arcuperé",
- "vector-action-unprotect": "Cangé la protession",
- "vector-view-create": "Creé",
- "vector-view-edit": "Modifiché",
- "vector-view-history": "Smon-e la stòria",
- "vector-view-view": "Lese",
- "vector-view-viewsource": "Vëdde la sorgiss"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Arslan",
- "Khalid Mahmood"
- ]
- },
- "vector-action-addsection": "مضمون پاؤ",
- "vector-action-delete": "مکاؤ",
- "vector-action-move": "ٹرو",
- "vector-action-protect": "بچاؤ",
- "vector-action-undelete": "واپس لیاؤ",
- "vector-action-unprotect": "تبدیلی بچاؤ",
- "vector-view-create": "بناؤ",
- "vector-view-edit": "لکھو",
- "vector-view-history": "تریخ وکھاؤ",
- "vector-view-view": "پڑھو",
- "vector-view-viewsource": "ویکھو"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Omnipaedista",
- "Sinopeus",
- "ZaDiak"
- ]
- },
- "vector-action-delete": "Σβήσον",
- "vector-action-move": "Ετεροχλάεμαν",
- "vector-action-protect": "Ασπάλιγμαν",
- "vector-action-undelete": "Κλώσιμον",
- "vector-action-unprotect": "Άνοιγμαν",
- "vector-view-create": "Ποίσον",
- "vector-view-edit": "Άλλαξον",
- "vector-view-history": "Τερέστεν ιστορίαν",
- "vector-view-view": "Δεάβασον",
- "vector-view-viewsource": "Τερέστεν κωδικόν"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "A R King"
- ]
- },
- "vector-action-addsection": "Yankwik temaj",
- "vector-action-delete": "Shikishti",
- "vector-action-move": "Shikijkwani",
- "vector-action-undelete": "Shalkwepa",
- "vector-view-create": "Shikchiwa",
- "vector-view-edit": "Shikpata",
- "vector-view-history": "Ken mupatak",
- "vector-view-view": "Shiamatachia",
- "vector-view-viewsource": "Shikita ne codigoj"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Nertiks",
- "Peteris"
- ]
- },
- "vector-action-delete": "Āupausinais",
- "vector-action-move": "Prapīdais",
- "vector-action-protect": "Kūnsteis",
- "vector-action-unprotect": "Etkūnteis",
- "vector-view-create": "Teīkeis",
- "vector-view-edit": "Redigīs",
- "vector-view-history": "Enwaidinnais istōrijan",
- "vector-view-view": "Skaitāis",
- "vector-view-viewsource": "Enwaidinnais appun"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ahmed-Najib-Biabani-Ibrahimkhel"
- ]
- },
- "skinname-vector": "وېکټور",
- "vector.css": "/* د CSS هره بڼه چې دلته ځای پر ځای کېږي هغه به د وېکټور د پوښ ټولو کارنانو لپاره کار کوي */",
- "vector.js": "/* د جاوا هر يو سکرېپټ چې دلته ځای پر ځای کېږي هغه به د وېکټور د پوښ ټولو کارنانو لپاره کار کوي */",
- "vector-action-addsection": "سرليکونه ورگډول",
- "vector-action-delete": "ړنگول",
- "vector-action-move": "لېږدول",
- "vector-action-protect": "ژغورل",
- "vector-action-undelete": "ناړنگول",
- "vector-action-unprotect": "ژغورنه بدلول",
- "vector-view-create": "جوړول",
- "vector-view-edit": "سمول",
- "vector-view-history": "پېښليک کتل",
- "vector-view-view": "لوستل",
- "vector-view-viewsource": "سرچينه کتل"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Cainamarques",
- "Diego Queiroz",
- "Giro720",
- "Helder.wiki",
- 555
- ]
- },
- "vector.js": "/* Qualquer JavaScript aqui colocado afetará os usuários do skin Vector */",
- "vector-action-addsection": "Adicionar tópico",
- "vector-action-delete": "Eliminar",
- "vector-action-move": "Mover",
- "vector-action-protect": "Proteger",
- "vector-action-undelete": "Restaurar",
- "vector-action-unprotect": "Alterar a proteção",
- "vector-view-create": "Criar",
- "vector-view-edit": "Editar",
- "vector-view-history": "Ver histórico",
- "vector-view-view": "Ler",
- "vector-view-viewsource": "Ver código-fonte",
- "vector-more-actions": "Mais"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Crazymadlover",
- "Giro720",
- "Hamilton Abreu",
- "Malafaya",
- "Vitorvicentevalente",
- "Waldir"
- ]
- },
- "skinname-vector": "Vector",
- "vector-skin-desc": "Versão moderna do MonoBook com um visual fresco e várias melhorias de usabilidade",
- "vector.css": "/* Código CSS colocado aqui afectará os utilizadores do tema Vector */",
- "vector.js": "/* Código Javascript colocado aqui será carregado para utilizadores do tema Vector */",
- "vector-action-addsection": "Adicionar tópico",
- "vector-action-delete": "Eliminar",
- "vector-action-move": "Mover",
- "vector-action-protect": "Proteger",
- "vector-action-undelete": "Restaurar",
- "vector-action-unprotect": "Alterar protecção",
- "vector-view-create": "Criar",
- "vector-view-edit": "Editar",
- "vector-view-history": "Ver histórico",
- "vector-view-view": "Ler",
- "vector-view-viewsource": "Ver fonte",
- "vector-more-actions": "Mais"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Darth Kule",
- "EugeneZelenko",
- "Lloffiwr",
- "Shirayuki",
- "Umherirrender",
- "Matma Rex"
- ]
- },
- "skinname-vector": "{{optional}}",
- "vector-skin-desc": "{{desc|what=skin|name=Vector|url=https://www.mediawiki.org/wiki/Skin:Vector}}",
- "vector.css": "{{optional}}",
- "vector.js": "{{optional}}",
- "vector-action-addsection": "Used in the Vector skin. See for example {{canonicalurl:Talk:Main_Page|useskin=vector}}",
- "vector-action-delete": "Used in the Vector skin, as the name of a tab at the top of the page. See for example {{canonicalurl:Main_Page|useskin=vector}}\n\n{{Identical|Delete}}",
- "vector-action-move": "Used in the Vector skin, on the tabs at the top of the page. See for example {{canonicalurl:Talk:Main_Page|useskin=vector}}\n\n{{Identical|Move}}",
- "vector-action-protect": "Tab at top of page, in vector skin\n\n{{Identical|Protect}}",
- "vector-action-undelete": "Tab at top of page, in vector skin.\n{{Identical|Undelete}}",
- "vector-action-unprotect": "Tab at top of page, in vector skin.\n{{Identical|Change protection}}",
- "vector-view-create": "Tab label in the Vector skin. See for example {{canonicalurl:Foo|useskin=vector}}\n{{Identical|Create}}",
- "vector-view-edit": "Tab label in the Vector skin. See for example {{canonicalurl:Main_Page|useskin=vector}}\n{{Identical|Edit}}",
- "vector-view-history": "Tab label in the Vector skin. See for example {{canonicalurl:Main_Page|useskin=vector}}\n{{Identical|View history}}",
- "vector-view-view": "Tab label in the Vector skin (verb). See for example {{canonicalurl:Main_Page|useskin=vector}}.\n{{Identical|Read}}",
- "vector-view-viewsource": "Tab label in the Vector skin.\n{{Identical|View source}}",
- "vector-more-actions": "Label in the Vector skin's menu for the less-important or rarer actions which are not shown as tabs (like moving the page, or for sysops deleting or protecting the page), as well as (for users with a narrow viewing window in their browser) the less-important tab actions which the user's browser is unable to fit in. {{Identical|More}}"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "AlimanRuna"
- ]
- },
- "vector-action-addsection": "Allwiyta yapay",
- "vector-action-delete": "Qulluy",
- "vector-action-move": "Astay",
- "vector-action-protect": "Amachay",
- "vector-action-undelete": "Qullusqata paqarichiy",
- "vector-action-unprotect": "Amachayta wakinchay",
- "vector-view-create": "Kamariy",
- "vector-view-edit": "Llamk'apuy",
- "vector-view-history": "Wiñay kawsayta qhaway",
- "vector-view-view": "Ñawiriy",
- "vector-view-viewsource": "Pukyu qillqata qhaway",
- "vector-more-actions": "Aswan"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Sylvain2803"
- ]
- },
- "vector-action-addsection": "Shuk mushuk rimanakuyta kallarina",
- "vector-action-delete": "Pichana",
- "vector-action-move": "Apakuna",
- "vector-action-protect": "Harkana",
- "vector-action-undelete": "Kutin wacharichina",
- "vector-action-unprotect": "Harkayta shukchina",
- "vector-view-create": "Kamarina",
- "vector-view-edit": "Killkana",
- "vector-view-history": "Wiñay kawsayta rikuna",
- "vector-view-view": "Killkakatina",
- "vector-view-viewsource": "Pukyu killkata rikuna"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Clerc",
- "MJohnsson"
- ]
- },
- "vector-action-delete": "horo'i",
- "vector-view-edit": "Haka titika"
-}
+++ /dev/null
-{
- "vector-action-addsection": "Zonta una cjacarèda",
- "vector-action-delete": "Scanzèla",
- "vector-action-move": "Chèmbia nòm",
- "vector-action-protect": "Metti-j una pruteziò",
- "vector-action-undelete": "Armett a post",
- "vector-action-unprotect": "Sbloca"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "MoubarikBelkasim"
- ]
- },
- "vector-action-move": "Smuṭṭi",
- "vector-view-create": "Seɣnu",
- "vector-view-edit": "Ẓṛeg",
- "vector-view-history": "Ẓeṛ amezruy",
- "vector-view-view": "Ɣeṛ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Gion-andri"
- ]
- },
- "vector-action-addsection": "Agiuntar chapitel",
- "vector-action-delete": "Stizzar",
- "vector-action-move": "Spustar",
- "vector-action-protect": "Bloccar",
- "vector-action-undelete": "Restituir",
- "vector-action-unprotect": "Midar la protecziun",
- "vector-view-create": "Crear",
- "vector-view-edit": "Modifitgar",
- "vector-view-history": "Cronologia",
- "vector-view-view": "Leger",
- "vector-view-viewsource": "Mussar il code"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Szonja"
- ]
- },
- "vector-action-addsection": "Tilja topikos",
- "vector-action-delete": "Tšuu nikki",
- "vector-action-undelete": "Tšuu paale",
- "vector-view-create": "Luona",
- "vector-view-edit": "Muoka",
- "vector-view-history": "Sik histores",
- "vector-view-view": "Draba",
- "vector-view-viewsource": "Sik navasiinako koodos"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "AdiJapan",
- "Danutz",
- "Firilacroco",
- "Minisarm",
- "Strainu"
- ]
- },
- "skinname-vector": "Vector",
- "vector.css": "/* CSS plasate aici vor afecta utilizatorii stilului Vector */",
- "vector-action-addsection": "Mesaj nou",
- "vector-action-delete": "Ștergere",
- "vector-action-move": "Redenumire",
- "vector-action-protect": "Protejare",
- "vector-action-undelete": "Recuperare",
- "vector-action-unprotect": "Modificare protecție",
- "vector-view-create": "Creare",
- "vector-view-edit": "Modificare",
- "vector-view-history": "Istoric",
- "vector-view-view": "Lectură",
- "vector-view-viewsource": "Sursă pagină",
- "vector-more-actions": "Mai mult"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Joetaras"
- ]
- },
- "skinname-vector": "Vettore",
- "vector.css": "/* 'U CSS ca se iacchie aqquà 'u 'ndrucane le utinde d'a masckere Vettore */",
- "vector.js": "/* Ogne JavaScript aqquà avène carecate pe le utinde ca ausane 'a masckere Vettore */",
- "vector-action-addsection": "Aggiunge 'na discussiona",
- "vector-action-delete": "Scangille",
- "vector-action-move": "Spuèste",
- "vector-action-protect": "Protegge",
- "vector-action-undelete": "Repristine",
- "vector-action-unprotect": "Cange 'a protezione",
- "vector-view-create": "Ccreje",
- "vector-view-edit": "Cange",
- "vector-view-history": "Vide 'u cunde",
- "vector-view-view": "Ligge",
- "vector-view-viewsource": "Vide 'u sorgende"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ignatus",
- "JenVan",
- "Kaganer",
- "Nemo bis",
- "Okras",
- "Александр Сигачёв"
- ]
- },
- "skinname-vector": "Векторное",
- "vector-skin-desc": "Современная версия MonoBook с обновлённым оформлением и многими улучшениями в юзабилити",
- "vector.css": "/* Размещённый здесь CSS будет применяться к векторной теме оформления */",
- "vector.js": "/* Размещённый здесь код JavaScript будет загружаться пользователям, использующим тему оформления Vector */",
- "vector-action-addsection": "Добавить тему",
- "vector-action-delete": "Удалить",
- "vector-action-move": "Переименовать",
- "vector-action-protect": "Защитить",
- "vector-action-undelete": "Восстановить",
- "vector-action-unprotect": "Изменить защиту",
- "vector-view-create": "Создание",
- "vector-view-edit": "Править",
- "vector-view-history": "История",
- "vector-view-view": "Читать",
- "vector-view-viewsource": "Просмотр разметки",
- "vector-more-actions": "Ещё"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Gazeb"
- ]
- },
- "vector-action-addsection": "Придати тему",
- "vector-action-delete": "Вымазати",
- "vector-action-move": "Переменовати",
- "vector-action-protect": "Всокотити",
- "vector-action-undelete": "Обновити",
- "vector-action-unprotect": "Змінити замок",
- "vector-view-create": "Створити",
- "vector-view-edit": "Едітовати",
- "vector-view-history": "Видїти історію",
- "vector-view-view": "Чітати",
- "vector-view-viewsource": "Видїти код"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "D'AroemenenZullenNiVergaan"
- ]
- },
- "vector-action-addsection": "Dimândari nauâ",
- "vector-view-history": "Veḑ istoricu"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Vogone"
- ]
- },
- "vector-action-move": "Imura",
- "vector-view-edit": "Hindura",
- "vector-view-history": "Reba amateka",
- "vector-view-view": "Soma"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Kyoww"
- ]
- },
- "vector-view-edit": "直すん",
- "vector-view-view": "読むん"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "NehalDaveND",
- "Shubha"
- ]
- },
- "vector-action-addsection": "विषयः योज्यताम्",
- "vector-action-delete": "अपाक्रियताम्",
- "vector-action-move": "शीर्षकं परिवर्त्यताम्",
- "vector-action-protect": "संरक्ष्यताम्",
- "vector-action-undelete": "नापाकृतं",
- "vector-action-unprotect": "संरक्षणं परिवर्तयतु",
- "vector-view-create": "सृज्यताम्",
- "vector-view-edit": "सम्पाद्यताम्",
- "vector-view-history": "इतिहासः दृश्यताम्",
- "vector-view-view": "पठ्यताम्",
- "vector-view-viewsource": "स्रोतः दृश्यताम्"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "HalanTul"
- ]
- },
- "vector-action-addsection": "Тиэмэ эбии",
- "vector-action-delete": "Сот",
- "vector-action-move": "Аатын уларыт",
- "vector-action-protect": "Уларыйбат гын",
- "vector-action-undelete": "Төннөр",
- "vector-action-unprotect": "Көмүскэлин уларыт",
- "vector-view-create": "Ай",
- "vector-view-edit": "Уларыт",
- "vector-view-history": "Устуоруйатын көрүү",
- "vector-view-view": "Ааҕыы",
- "vector-view-viewsource": "Бэлиэлэрин көрүү"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Albinus",
- "Samar88",
- "Srabony90"
- ]
- },
- "vector-action-addsection": "Asol katha joṛaome",
- "vector-action-delete": "Giḍi",
- "vector-action-move": "Ocoḱ́me",
- "vector-action-protect": "Bańcao",
- "vector-action-undelete": "Bań getgiḍi",
- "vector-action-unprotect": "Bodol rukhiyạ",
- "vector-view-create": "Tearme",
- "vector-view-edit": "So̠mpado̠n",
- "vector-view-history": "Jạṛ ńelme",
- "vector-view-view": "Paṛhaḱme",
- "vector-view-viewsource": "Ńamoḱaḱ ńelme"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "MooRePrabu"
- ]
- },
- "vector-view-view": "ꢗꢾꢮ꣄ꢣꢶ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Andria",
- "Marzedu",
- "Via maxima",
- "Uharteko"
- ]
- },
- "vector-action-addsection": "Giunghe cuntierra",
- "vector-action-delete": "Cantzella",
- "vector-action-move": "Move",
- "vector-action-protect": "Ampara",
- "vector-action-undelete": "Recùpera",
- "vector-view-create": "Crea",
- "vector-view-edit": "Càmbia",
- "vector-view-history": "Càstia istòria",
- "vector-view-view": "Leghe",
- "vector-view-viewsource": "Càstia testu codificadu",
- "vector-more-actions": "Prus"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Gmelfi",
- "Melos"
- ]
- },
- "vector-action-addsection": "Agghiunci argumentu",
- "vector-action-delete": "Elìmina",
- "vector-action-move": "Sposta",
- "vector-action-protect": "Pruteggi",
- "vector-action-undelete": "Riprìstina",
- "vector-action-unprotect": "Cancia la prutizzioni",
- "vector-view-create": "Crea",
- "vector-view-edit": "Cancia",
- "vector-view-history": "Talìa a storia",
- "vector-view-view": "Leggi",
- "vector-view-viewsource": "Talìa la fonti",
- "vector-more-actions": "Àutri cosi"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Avicennasis",
- "John Reid",
- "Omnipaedista"
- ]
- },
- "vector-action-addsection": "Eik topic",
- "vector-action-delete": "Delyte",
- "vector-action-move": "Muiv",
- "vector-action-protect": "Fend",
- "vector-action-undelete": "Ondelyte",
- "vector-action-unprotect": "Chynge protection",
- "vector-view-create": "Ceaut",
- "vector-view-edit": "Eedit",
- "vector-view-history": "See histerie",
- "vector-view-view": "Read",
- "vector-view-viewsource": "See Soorce"
-}
+++ /dev/null
-{
- "vector-action-delete": "ڊاھيو",
- "vector-action-move": "چوريو",
- "vector-action-protect": "تحفظيو",
- "vector-action-unprotect": "اڻتحفظيو",
- "vector-view-create": "سرجيو",
- "vector-view-edit": "سنواريو",
- "vector-view-viewsource": "ڪوڊ ڏسو"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Felis",
- "Jun Misugi"
- ]
- },
- "vector-action-addsection": "Aggiungì oggettu",
- "vector-action-delete": "Canzella",
- "vector-action-move": "Ippustha",
- "vector-action-protect": "Pruteggì",
- "vector-view-create": "Cria",
- "vector-view-edit": "Mudifigga",
- "vector-view-history": "Vèdi isthòria",
- "vector-view-view": "Leggi",
- "vector-view-viewsource": "Vèdi fonti"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Paraw2"
- ]
- },
- "vector-action-addsection": "بابەت تازە بدە سەری",
- "vector-action-delete": "بسڕەوە",
- "vector-action-move": "جیوەجی بکە",
- "vector-action-protect": "بپیەرێزەێ",
- "vector-view-create": "درسکردن",
- "vector-view-edit": "وێراشتەێ بکە",
- "vector-view-history": "دیرۆکەگەی بۊن",
- "vector-view-view": "بخوەنە",
- "vector-view-viewsource": "سەرچاوەگەێ بۊن"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Gálaniitoluodda",
- "Jeblad",
- "Trondtr"
- ]
- },
- "vector-action-addsection": "Lasit fáttá",
- "vector-action-delete": "Sihko",
- "vector-action-move": "Sirdde",
- "vector-action-protect": "Suodjal",
- "vector-action-undelete": "Máhcat",
- "vector-action-unprotect": "Rievdat suodjaleami",
- "vector-view-create": "Álggat",
- "vector-view-edit": "Rievdat",
- "vector-view-history": "Geahča historjjá",
- "vector-view-view": "Loga",
- "vector-view-viewsource": "Geahča gáldokoda"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Mdkidiri"
- ]
- },
- "vector-action-addsection": "Zîa mbênî lilö daä",
- "vector-action-delete": "Lungûla",
- "vector-action-move": "Sanzêe ïrï",
- "vector-action-protect": "Funga",
- "vector-action-undelete": "Kîri na nî",
- "vector-action-unprotect": "Sanzêe fungä",
- "vector-view-create": "Seka",
- "vector-view-edit": "Sepe",
- "vector-view-history": "Tanda mbai nî",
- "vector-view-view": "Dîko",
- "vector-view-viewsource": "Fa ligbî nî"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Hugo.arg"
- ]
- },
- "vector-action-addsection": "Pridietė tema",
- "vector-action-delete": "Trintė",
- "vector-action-move": "Parvadintė",
- "vector-action-protect": "Ožrakintė",
- "vector-action-undelete": "Atkortė",
- "vector-action-unprotect": "Keistė apsauga",
- "vector-view-create": "Sokortė",
- "vector-view-edit": "Taisītė",
- "vector-view-history": "Veizietė istuorėjė",
- "vector-view-view": "Skaitītė",
- "vector-view-viewsource": "Veizietė kuoda"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "OC Ripper"
- ]
- },
- "vector-action-addsection": "Dodaj temu",
- "vector-action-delete": "Brisanje",
- "vector-action-move": "Preusmjeri",
- "vector-action-protect": "Zaštiti",
- "vector-action-undelete": "Vrati obrisano",
- "vector-action-unprotect": "Promijeni zaštitu",
- "vector-view-create": "Napravi",
- "vector-view-edit": "Uredi",
- "vector-view-history": "Pregled historije",
- "vector-view-view": "Čitaj",
- "vector-view-viewsource": "Vidi izvor (source)"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Dalinanir"
- ]
- },
- "vector-action-addsection": "Zayd amli",
- "vector-action-delete": "Ḥiyd",
- "vector-action-move": "Smmatti",
- "vector-action-protect": "Ḥbu",
- "vector-action-undelete": "Rard may mayḥiydn",
- "vector-action-unprotect": "Ḥiyd aḥbu",
- "vector-view-create": "Skert",
- "vector-view-edit": "Ara",
- "vector-view-history": "Mel amzruy",
- "vector-view-view": "ɣr",
- "vector-view-viewsource": "Ẓr asagm"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Saiddzone"
- ]
- },
- "vector-action-protect": "ႁေႉၵင်ႈ",
- "vector-view-create": "သၢင်ႈ",
- "vector-view-edit": "မူၼ်ႉမႄး",
- "vector-view-history": "တူၺ်းပိုၼ်း",
- "vector-view-view": "လူတူၺ်း",
- "vector-view-viewsource": "တူၺ်း ငဝ်ႈငႃႇ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Thushara",
- "දසනැබළයෝ",
- "පසිඳු කාවින්ද",
- "සුරනිමල"
- ]
- },
- "vector-action-addsection": "මාතෘකාව එක්කරන්න",
- "vector-action-delete": "මකන්න",
- "vector-action-move": "ගෙනයන්න",
- "vector-action-protect": "ආරක්ෂණය",
- "vector-action-undelete": "මකාදැමීම අවලංගු කරන්න",
- "vector-action-unprotect": "ආරක්ෂණ තත්වය වෙනස් කරන්න",
- "vector-view-create": "තනන්න",
- "vector-view-edit": "සංස්කරණය",
- "vector-view-history": "ඉතිහාසය නරඹන්න",
- "vector-view-view": "කියවන්න",
- "vector-view-viewsource": "මූලාශ්රය නරඹන්න",
- "vector-more-actions": "තවත්"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Helix84",
- "Rudko",
- "Sudo77(new)"
- ]
- },
- "skinname-vector": "Vector",
- "vector.css": "/* Tu umiestnené CSS bude ovplyvňovať používateľov štýlu Vector */",
- "vector.js": "/* Tu sa nachádzajúci JavaScript sa načíta používateľom vzhľadu Vector */",
- "vector-action-addsection": "Pridať tému",
- "vector-action-delete": "Zmazať",
- "vector-action-move": "Presunúť",
- "vector-action-protect": "Zamknúť",
- "vector-action-undelete": "Obnoviť",
- "vector-action-unprotect": "Zmeniť stav ochrany",
- "vector-view-create": "Vytvoriť",
- "vector-view-edit": "Upraviť",
- "vector-view-history": "Zobraziť históriu",
- "vector-view-view": "Čítať",
- "vector-view-viewsource": "Zobraziť zdroj",
- "vector-more-actions": "Viac"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Dbc334",
- "Smihael",
- "Yerpo"
- ]
- },
- "vector-skin-desc": "Sodobna različica MonoBook s svežim videzom in mnogimi izboljšavami uporabnosti",
- "vector-action-addsection": "Dodaj temo",
- "vector-action-delete": "Izbriši",
- "vector-action-move": "Prestavi",
- "vector-action-protect": "Zaščiti",
- "vector-action-undelete": "Vrni",
- "vector-action-unprotect": "Spremeni zaščito",
- "vector-view-create": "Ustvari",
- "vector-view-edit": "Uredi",
- "vector-view-history": "Zgodovina",
- "vector-view-view": "Preberi",
- "vector-view-viewsource": "Izvorno besedilo",
- "vector-more-actions": "Več"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Przemub",
- "Schläsinger",
- "Timpul",
- "Äberlausitzer"
- ]
- },
- "vector-action-addsection": "Obschnitt hinzufiega",
- "vector-action-delete": "Läscha",
- "vector-action-move": "Verschieba",
- "vector-action-protect": "Schützen",
- "vector-action-undelete": "Wiederherstella",
- "vector-action-unprotect": "Freigahn",
- "vector-view-create": "Erstella",
- "vector-view-edit": "Bearbeita",
- "vector-view-history": "Versionsgeschichte",
- "vector-view-view": "Lessa",
- "vector-view-viewsource": "Quelltext siehn"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "ZQheert"
- ]
- },
- "vector-action-delete": "Lelei",
- "vector-action-move": "Palettei",
- "vector-view-create": "Bua'",
- "vector-view-edit": "edi'",
- "vector-view-view": "Bacai",
- "vector-view-viewsource": "Tilingi assala'na"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Maax"
- ]
- },
- "vector-action-addsection": "Hadal ku dar",
- "vector-action-delete": "Tirtir",
- "vector-action-move": "Wareeji",
- "vector-action-protect": "Difaac",
- "vector-action-undelete": "Ha tirtirin",
- "vector-action-unprotect": "Bedel difaacida",
- "vector-view-create": "Sameey",
- "vector-view-edit": "Wax ka bedel",
- "vector-view-history": "Itusi taariikhda",
- "vector-view-view": "Akhri",
- "vector-view-viewsource": "Itusi xogta"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Dasius",
- "GretaDoci",
- "MicroBoy",
- "Mikullovci11",
- "Olsi"
- ]
- },
- "vector-action-addsection": "Shto një temë",
- "vector-action-delete": "Grise",
- "vector-action-move": "Zhvendose",
- "vector-action-protect": "Mbroje",
- "vector-action-undelete": "Anullo fshirjen",
- "vector-action-unprotect": "Ndrysho mbrojtjen",
- "vector-view-create": "Krijo",
- "vector-view-edit": "Redakto",
- "vector-view-history": "Shiko historikun",
- "vector-view-view": "Lexo",
- "vector-view-viewsource": "Shiko tekstin",
- "vector-more-actions": "Më tepër..."
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Milicevic01",
- "Rancher",
- "Жељко Тодоровић",
- "Михајло Анђелковић"
- ]
- },
- "skinname-vector": "Векторско",
- "vector.css": "/* CSS постављен овде ће утицати на све кориснике теме „Векторско“ */",
- "vector.js": "/* Јаваскрипт постављен овде ће се учитати за све оне који користе тему „Векторско“ */",
- "vector-action-addsection": "Додај тему",
- "vector-action-delete": "Обриши",
- "vector-action-move": "Премести",
- "vector-action-protect": "Заштити",
- "vector-action-undelete": "Врати",
- "vector-action-unprotect": "Промени заштиту",
- "vector-view-create": "Направи",
- "vector-view-edit": "Уреди",
- "vector-view-history": "Историја",
- "vector-view-view": "Читај",
- "vector-view-viewsource": "Изворни код",
- "vector-more-actions": "Више"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Michaello",
- "Milicevic01",
- "Rancher",
- "Жељко Тодоровић"
- ]
- },
- "skinname-vector": "Vektorsko",
- "vector.css": "/* CSS postavljen ovde će uticati na sve korisnike teme „Vektorsko“ */",
- "vector.js": "/* Javaskript postavljen ovde će se učitati za sve one koji koriste temu „Vektorsko“ */",
- "vector-action-addsection": "Dodaj temu",
- "vector-action-delete": "Obriši",
- "vector-action-move": "Premesti",
- "vector-action-protect": "Zaštiti",
- "vector-action-undelete": "Vrati",
- "vector-action-unprotect": "Promeni zaštitu",
- "vector-view-create": "Napravi",
- "vector-view-edit": "Uredi",
- "vector-view-history": "Istorija",
- "vector-view-view": "Čitaj",
- "vector-view-viewsource": "Izvorni kod",
- "vector-more-actions": "Više"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Sibande"
- ]
- },
- "vector-action-addsection": "Ngeta sihloko",
- "vector-action-move": "Khweshisa",
- "vector-view-create": "Create",
- "vector-view-edit": "Hlela",
- "vector-view-history": "Bona umlandvo",
- "vector-view-view": "Fundza"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Pyt"
- ]
- },
- "vector-action-addsection": "Ousnit bietouföigje",
- "vector-action-delete": "Läskje",
- "vector-action-move": "Ferskuuwe",
- "vector-action-protect": "Skutsje",
- "vector-action-undelete": "Wierhäärstaale",
- "vector-action-unprotect": "Siedenskuts annerje",
- "vector-view-create": "Moakje",
- "vector-view-edit": "Beoarbaidje",
- "vector-view-history": "Versionsgeskichte",
- "vector-view-view": "Leese",
- "vector-view-viewsource": "Wältext bekiekje"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Kandar"
- ]
- },
- "vector-action-addsection": "Jieun jejer anyar",
- "vector-action-delete": "Hapus",
- "vector-action-move": "Pindahkeun",
- "vector-action-protect": "Konci",
- "vector-action-undelete": "Bolaykeun ngahapus",
- "vector-action-unprotect": "Robah protéksi",
- "vector-view-create": "Jieun",
- "vector-view-edit": "Édit",
- "vector-view-history": "Témbongkeun jujutan",
- "vector-view-view": "Baca",
- "vector-view-viewsource": "Témbongkeun sumber"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Martinwiss",
- "Najami",
- "Skalman",
- "WikiPhoenix",
- "Lokal Profil"
- ]
- },
- "skinname-vector": "Vector",
- "vector-skin-desc": "Modern version av MonoBook med ett nytt utseende och flera användarvänlighetsförbättringar",
- "vector.css": "/* CSS som skrivs här kommer att påverka alla användare av skalet Vector */",
- "vector.js": "/* JavaScript här kommer att laddas för dem som använder skalet Vector */",
- "vector-action-addsection": "Nytt ämne",
- "vector-action-delete": "Radera",
- "vector-action-move": "Flytta",
- "vector-action-protect": "Skrivskydda",
- "vector-action-undelete": "Återställ",
- "vector-action-unprotect": "Ändra skydd",
- "vector-view-create": "Skapa",
- "vector-view-edit": "Redigera",
- "vector-view-history": "Visa historik",
- "vector-view-view": "Visa",
- "vector-view-viewsource": "Visa källa",
- "vector-more-actions": "Mer"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Lloffiwr",
- "Muddyb Blast Producer"
- ]
- },
- "vector-action-addsection": "Weka mada",
- "vector-action-delete": "Futa",
- "vector-action-move": "Hamisha",
- "vector-action-protect": "Linda",
- "vector-action-undelete": "Rudisha",
- "vector-action-unprotect": "Badilisha ulinzi",
- "vector-view-create": "Anzisha",
- "vector-view-edit": "Hariri",
- "vector-view-history": "Fungua historia",
- "vector-view-view": "Soma",
- "vector-view-viewsource": "Tazama msimbo"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Britscher",
- "Gaj777",
- "Przemub"
- ]
- },
- "vector-action-addsection": "Nowo tajla",
- "vector-action-delete": "Wyćepej",
- "vector-action-move": "Przećep",
- "vector-action-protect": "Zawrzij",
- "vector-action-undelete": "Wćep",
- "vector-action-unprotect": "Uodymkńij",
- "vector-view-create": "Stwůrz",
- "vector-view-edit": "Sprowjej",
- "vector-view-history": "Uobocz gyszichta",
- "vector-view-view": "Czytej",
- "vector-view-viewsource": "Zdrzůdłowy tekst"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Mayooranathan",
- "Shanmugamp7",
- "Surya Prakash.S.A.",
- "TRYPPN"
- ]
- },
- "vector-action-addsection": "தலைப்பைச் சேர்",
- "vector-action-delete": "நீக்குக",
- "vector-action-move": "நகர்த்தவும்",
- "vector-action-protect": "காக்கவும்",
- "vector-action-undelete": "நீக்கத்தை நிறுத்து",
- "vector-action-unprotect": "காப்பை மாற்று",
- "vector-view-create": "உருவாக்கவும்",
- "vector-view-edit": "தொகு",
- "vector-view-history": "வரலாற்றைக் காட்டவும்",
- "vector-view-view": "படிக்கவும்",
- "vector-view-viewsource": "மூலத்தைக் காட்டவும்"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "NamwikiTL",
- "VASANTH S.N."
- ]
- },
- "vector-action-addsection": "ವಿಷಯ ಸೇರಾಲೆ",
- "vector-action-delete": "ದೆತ್ತ್ ಪಾಡ್ಲೆ",
- "vector-action-move": "ಸ್ಥಳಾಂತರ ಮಲ್ಪುಲೆ",
- "vector-action-protect": "ಸ೦ರಕ್ಷಿಸಾಲೆ",
- "vector-action-undelete": "ಮಾಜಾವಡೆ",
- "vector-action-unprotect": "ಬದಲಾವಣೆನ್ ರಕ್ಷಿಸಾಲೆ",
- "vector-view-create": " ಸುರು ಮಲ್ಪುಲೆ",
- "vector-view-edit": "ಸಂಪಾದನೆ ಮಲ್ಪುಲೆ",
- "vector-view-history": "ಇತಿಹಾಸೊನು ತೂಲೆ",
- "vector-view-view": "ಓದ್ಲೇ",
- "vector-view-viewsource": "ಮೂಲೊನು ತೂಲೆ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Chaduvari",
- "Kiranmayee",
- "Praveen Illa",
- "Ravichandra",
- "Veeven"
- ]
- },
- "skinname-vector": "వెక్టర్",
- "vector-action-addsection": "విషయాన్ని చేర్చు",
- "vector-action-delete": "తొలగించు",
- "vector-action-move": "తరలించు",
- "vector-action-protect": "సంరక్షించు",
- "vector-action-undelete": "తొలగింపును రద్దుచెయ్యి",
- "vector-action-unprotect": "సంరక్షణను మార్చు",
- "vector-view-create": "సృష్టించు",
- "vector-view-edit": "సవరించు",
- "vector-view-history": "చరిత్రను చూడండి",
- "vector-view-view": "చదువు",
- "vector-view-viewsource": "మూలాన్ని చూపించు",
- "vector-more-actions": "మరిన్ని"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "MF-Warburg"
- ]
- },
- "vector-action-protect": "Proteje",
- "vector-view-create": "Kria",
- "vector-view-edit": "Edita",
- "vector-view-history": "Haree istória",
- "vector-view-view": "Lee"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ibrahim"
- ]
- },
- "vector-action-addsection": "Иловаи унвон",
- "vector-action-delete": "Ҳазф",
- "vector-action-move": "Кӯчонидан",
- "vector-action-protect": "Муҳофизат",
- "vector-action-undelete": "Эҳё",
- "vector-action-unprotect": "Тағйири муҳофизат",
- "vector-view-create": "Эҷод",
- "vector-view-edit": "Вироиш",
- "vector-view-history": "Намоиши таърих",
- "vector-view-view": "Хондан",
- "vector-view-viewsource": "Намоиши манбаъ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Liangent"
- ]
- },
- "vector-action-addsection": "Ilovai unvon",
- "vector-action-delete": "Hazf",
- "vector-action-move": "Kūconidan",
- "vector-action-protect": "Muhofizat",
- "vector-action-undelete": "Ehjo",
- "vector-action-unprotect": "Ba dar ovardan az muhofizat",
- "vector-view-create": "Eçod",
- "vector-view-edit": "Viroiş",
- "vector-view-history": "Namoişi ta'rix",
- "vector-view-view": "Xondan",
- "vector-view-viewsource": "Namoişi manba'"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Horus",
- "Octahedron80",
- "Woraponboonkerd"
- ]
- },
- "skinname-vector": "เวกเตอร์",
- "vector.css": "/* สไตล์ชีตในหน้านี้จะส่งผลแก่ผู้ใช้ที่ใช้สกินเวกเตอร์ */",
- "vector.js": "/* จาวาสคริปต์ใด ๆ ในหน้านี้จะถูกโหลดให้แก่ผู้ใช้ที่ใช้สกินเวกเตอร์ */",
- "vector-action-addsection": "เพิ่มหัวข้อ",
- "vector-action-delete": "ลบ",
- "vector-action-move": "เปลี่ยนชื่อ",
- "vector-action-protect": "ล็อก",
- "vector-action-undelete": "กู้คืน",
- "vector-action-unprotect": "เปลี่ยนการล็อก",
- "vector-view-create": "สร้าง",
- "vector-view-edit": "แก้ไข",
- "vector-view-history": "ดูประวัติ",
- "vector-view-view": "อ่าน",
- "vector-view-viewsource": "ดูโค้ด",
- "vector-more-actions": "เพิ่มเติม"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Hanberke"
- ]
- },
- "vector-action-addsection": "Tema goş",
- "vector-action-delete": "Öçür",
- "vector-action-move": "Adyny üýtget",
- "vector-action-protect": "Goraga al",
- "vector-action-undelete": "Öçürmäni yzyna al",
- "vector-action-unprotect": "Goragy üýtget",
- "vector-view-create": "Döret",
- "vector-view-edit": "Üýtget",
- "vector-view-history": "Taryhy gör",
- "vector-view-view": "Oka",
- "vector-view-viewsource": "Çeşmäni gör"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "AnakngAraw",
- "Sky Harbor"
- ]
- },
- "skinname-vector": "Vector",
- "vector.css": "/* Ang inilagay na CSS dito ay makakaapekto sa mga tagagamit ng pabalat na Vector */",
- "vector.js": "/* Ang anumang JavaScript dito ay ikakarga para sa mga tagagamit na gumagamit ng pabalat na Vector */",
- "vector-action-addsection": "Magdagdag ng paksa",
- "vector-action-delete": "Burahin",
- "vector-action-move": "Ilipat",
- "vector-action-protect": "Ipagsanggalang",
- "vector-action-undelete": "Alisin ang pagbubura",
- "vector-action-unprotect": "Baguhin ang pagsasanggalang",
- "vector-view-create": "Likhain",
- "vector-view-edit": "Baguhin",
- "vector-view-history": "Tingnan ang kasaysayan",
- "vector-view-view": "Basahin",
- "vector-view-viewsource": "Tingnan ang pinagmulan"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Гусейн"
- ]
- },
- "vector-action-addsection": "Мывзу зијод кардеј",
- "vector-action-delete": "Рәдд кардеј",
- "vector-action-move": "Номи дәгиш кардеј",
- "vector-action-protect": "Мыдофијә кардеј",
- "vector-action-undelete": "Бәрпо кардеј",
- "vector-action-unprotect": "Мыдофијә дәгиш кардеј",
- "vector-view-create": "Офәјеј",
- "vector-view-edit": "Сәрост кардеј",
- "vector-view-history": "Тарых",
- "vector-view-view": "Һандемон",
- "vector-view-viewsource": "Дијә кардеј"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Iketsi",
- "Wantok"
- ]
- },
- "vector-action-delete": "Rausim",
- "vector-action-move": "Surikim",
- "vector-action-protect": "Tambuim",
- "vector-view-create": "Kirapim",
- "vector-view-edit": "Senisim",
- "vector-view-history": "Ol senis",
- "vector-view-view": "Rit",
- "vector-view-viewsource": "Lukim as tok"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Arystanbek",
- "Emperyan",
- "Joseph",
- "Stultiwikia",
- "Vito Genovese"
- ]
- },
- "vector-action-addsection": "Konu ekle",
- "vector-action-delete": "Sil",
- "vector-action-move": "Taşı",
- "vector-action-protect": "Koru",
- "vector-action-undelete": "Silinmeyi geri al",
- "vector-action-unprotect": "Korumayı değiştir",
- "vector-view-create": "Oluştur",
- "vector-view-edit": "Düzenle",
- "vector-view-history": "Geçmişi gör",
- "vector-view-view": "Oku",
- "vector-view-viewsource": "Kaynağı gör",
- "vector-more-actions": "Diğer"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ariyo"
- ]
- },
- "vector-action-addsection": "Maḥat Fusoqo ḥaṭo",
- "vector-action-delete": "Slag",
- "vector-action-move": "Mtaxar",
- "vector-action-protect": "Mastar",
- "vector-view-create": "Xlaq",
- "vector-view-edit": "Mşaḥlaf",
- "vector-view-history": "Maktabzabno",
- "vector-view-view": "Qray",
- "vector-view-viewsource": "Maḥway li aMabu³e."
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Thuvack"
- ]
- },
- "vector-action-addsection": "Veka nholoko ya mhaka",
- "vector-action-delete": "Sula",
- "vector-action-move": "Yi sa kunwana",
- "vector-action-protect": "Sirhelela",
- "vector-action-undelete": "Cinca kusula",
- "vector-action-unprotect": "Cinca kusirhelela",
- "vector-view-create": "Tumbuluxa",
- "vector-view-edit": "Lulamisa",
- "vector-view-history": "Languta matimu",
- "vector-view-view": "Hlaya",
- "vector-view-viewsource": "Languta xihlovo"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Don Alessandro",
- "Rinatus",
- "Ильнар",
- "Рашат Якупов"
- ]
- },
- "skinname-vector": "Сызымлы",
- "vector-action-addsection": "Яңа тема өстәү",
- "vector-action-delete": "Бетерү",
- "vector-action-move": "Күчерү",
- "vector-action-protect": "Яклау",
- "vector-action-undelete": "Кайтару",
- "vector-action-unprotect": "Яклауны үзгәртү",
- "vector-view-create": "Төзү",
- "vector-view-edit": "Үзгәртү",
- "vector-view-history": "Тарихын карау",
- "vector-view-view": "Уку",
- "vector-view-viewsource": "Чыганагын карау"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Don Alessandro"
- ]
- },
- "skinname-vector": "Sızımlı",
- "vector-action-addsection": "Yaña tema östäw",
- "vector-action-delete": "Beterü",
- "vector-action-move": "Küçerü",
- "vector-action-protect": "Yaqlaw",
- "vector-action-undelete": "Qaytaru",
- "vector-action-unprotect": "Yaqlawnı beterü",
- "vector-view-create": "Tözü",
- "vector-view-edit": "Üzgärtü",
- "vector-view-history": "Tarixın qaraw",
- "vector-view-view": "Uqu",
- "vector-view-viewsource": "Çığanağın qaraw"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Agilight",
- "Sborsody"
- ]
- },
- "skinname-vector": "Вектор",
- "vector-action-addsection": "Кол сөстү немелээри",
- "vector-action-delete": "Ырадыры",
- "vector-action-move": "Шимчээри",
- "vector-action-protect": "Камгалаары",
- "vector-action-undelete": "Эгидер",
- "vector-action-unprotect": "Камгалалды өскертири",
- "vector-view-create": "Чаяары",
- "vector-view-edit": "Эдер",
- "vector-view-history": "Төөгүнү көөрү",
- "vector-view-view": "Номчуур",
- "vector-view-viewsource": "Дөзү бижиин көөрү"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Moha",
- "Tifinaghes"
- ]
- },
- "skinname-vector": "Vector",
- "vector-action-addsection": "ⵔⵏⵓ ⴰⵙⵏⵜⵍ",
- "vector-action-delete": "ⵓⴽⵓⵙ",
- "vector-action-move": "ⵙⵎⵓⵜⵜⵉ",
- "vector-action-undelete": "ⵙⵙⵓⵖⴰⵍ ⵓⴽⵓⵙ",
- "vector-action-unprotect": "ⴱⴷⴷⴻⵍ ⵜⴰⵙⵜⴰⵏⵜ",
- "vector-view-create": "ⴰⵔⴰ",
- "vector-view-edit": "ⴱⴷⴷⴻⵍ",
- "vector-view-history": "ⵥⵕ ⴰⵎⵣⵔⵓⵢ",
- "vector-view-view": "ⵖⵔ",
- "vector-view-viewsource": "ⵥⵕ ⴰⵖⴱⴰⵍⵓ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Andrewboltachev"
- ]
- },
- "vector-action-addsection": "Выль темаез ватсано",
- "vector-action-delete": "Быдтоно",
- "vector-action-move": "Мукет интые выжтыны",
- "vector-action-protect": "Утьыны",
- "vector-view-create": "Кылдытоно",
- "vector-view-edit": "Тупатоно",
- "vector-view-history": "История",
- "vector-view-view": "Лыдӟоно",
- "vector-view-viewsource": "Кодзэ учкыны"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Arlin",
- "Sahran",
- "Tel'et"
- ]
- },
- "skinname-vector": "Vector",
- "vector.css": "/* CSS placed here will affect users of the Vector skin */",
- "vector.js": "/* Any JavaScript here will be loaded for users using the Vector skin */",
- "vector-action-addsection": "يېڭى تېما قوش",
- "vector-action-delete": "ئۆچۈر",
- "vector-action-move": "يۆتكە",
- "vector-action-protect": "قوغدا",
- "vector-action-undelete": "ئەسلىگە قايتۇر",
- "vector-action-unprotect": "قوغداش ئۆزگەرت",
- "vector-view-create": "قۇر",
- "vector-view-edit": "تەھرىر",
- "vector-view-history": "تارىخ كۆرسەت",
- "vector-view-view": "ئوقۇ",
- "vector-view-viewsource": "مەنبەنى كۆرسەت"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "AS",
- "Ahonc",
- "Base",
- "Calak",
- "Dim Grits",
- "NickK",
- "Prima klasy4na",
- "Тест",
- "Ата"
- ]
- },
- "skinname-vector": "Векторне",
- "vector-skin-desc": "Сучасна версія MonoBook зі свіжим виглядом і багатьма зручними покращеннями",
- "vector.css": "/* Розміщений тут CSS-код буде використаний в темі оформлення Векторне */",
- "vector.js": "/* Розміщений тут код JavaScript буде завантажений для всіх користувачів, що використовують векторну тему оформлення */",
- "vector-action-addsection": "Додати тему",
- "vector-action-delete": "Вилучити",
- "vector-action-move": "Перейменувати",
- "vector-action-protect": "Захистити",
- "vector-action-undelete": "Відновити",
- "vector-action-unprotect": "Зміна захисту",
- "vector-view-create": "Створити",
- "vector-view-edit": "Редагувати",
- "vector-view-history": "Переглянути історію",
- "vector-view-view": "Читати",
- "vector-view-viewsource": "Переглянути код",
- "vector-more-actions": "Ще"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Calak",
- "Istabani",
- "Noor2020",
- "Tahir mq",
- "محبوب عالم"
- ]
- },
- "vector-action-addsection": "نیا موضوع",
- "vector-action-delete": "حذف کرو",
- "vector-action-move": "منتقل کرو",
- "vector-action-protect": "محفوظ کرو",
- "vector-action-undelete": "بحال",
- "vector-action-unprotect": "تحفظ میں تبدیلی",
- "vector-view-create": "تخلیق",
- "vector-view-edit": "ترمیم",
- "vector-view-history": "تاریخ",
- "vector-view-view": "مطالعہ",
- "vector-view-viewsource": "مسودہ",
- "vector-more-actions": "زیادہ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Abdulla",
- "Arystanbek",
- "Casual",
- "CoderSI",
- "Sociologist"
- ]
- },
- "skinname-vector": "Vektor",
- "vector-action-addsection": "Mavzu qoʻshish",
- "vector-action-delete": "O‘chirish",
- "vector-action-move": "Ko‘chirish",
- "vector-action-protect": "Himoyalash",
- "vector-action-undelete": "Tiklash",
- "vector-action-unprotect": "Himoyalashni oʻzgartirish",
- "vector-view-create": "Yaratish",
- "vector-view-edit": "Tahrirlash",
- "vector-view-history": "Tarix",
- "vector-view-view": "Mutolaa",
- "vector-view-viewsource": "Manbasini koʻrish",
- "vector-more-actions": "Yana"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Alunardon90",
- "Candalua",
- "Frigotoni",
- "GatoSelvadego",
- "Vajotwo"
- ]
- },
- "vector-action-addsection": "Zonta discusion",
- "vector-action-delete": "Scanseła",
- "vector-action-move": "Sposta",
- "vector-action-protect": "Protezi",
- "vector-action-undelete": "Recupera",
- "vector-action-unprotect": "Canbia ła protesion",
- "vector-view-create": "Crea",
- "vector-view-edit": "Canbia",
- "vector-view-history": "Varda ła storia",
- "vector-view-view": "Lezi",
- "vector-view-viewsource": "Varda el testo"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Игорь Бродский"
- ]
- },
- "vector-action-addsection": "Ližada tem",
- "vector-action-delete": "Čuta poiš",
- "vector-action-move": "Udesnimitada",
- "vector-action-protect": "Kaita",
- "vector-action-undelete": "Pördutada",
- "vector-action-unprotect": "Toižetada kaičend",
- "vector-view-create": "Säta",
- "vector-view-edit": "Redaktiruida",
- "vector-view-history": "Kacta istorii",
- "vector-view-view": "Lugeda",
- "vector-view-viewsource": "Kacta purtkehe"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Minh Nguyen",
- "Vinhtantran",
- "Withoutaname"
- ]
- },
- "skinname-vector": "Vectơ",
- "vector-skin-desc": "Giao diện làm lại từ MonoBook có màu tươi và khả dụng hơn",
- "vector.css": "/* Mã CSS đặt ở đây sẽ ảnh hưởng đến thành viên sử dụng giao diện Vectơ */",
- "vector.js": "/* Mã JavaScript tại đây sẽ được tải khi người dùng sử dụng giao diện Vectơ */",
- "vector-action-addsection": "Thêm chủ đề",
- "vector-action-delete": "Xóa",
- "vector-action-move": "Di chuyển",
- "vector-action-protect": "Khóa",
- "vector-action-undelete": "Phục hồi",
- "vector-action-unprotect": "Đổi mức khóa",
- "vector-view-create": "Tạo",
- "vector-view-edit": "Sửa đổi",
- "vector-view-history": "Xem lịch sử",
- "vector-view-view": "Đọc",
- "vector-view-viewsource": "Xem mã nguồn",
- "vector-more-actions": "Khác"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "DasRakel"
- ]
- },
- "vector-action-delete": "Wegdoen",
- "vector-action-move": "Ernoemn",
- "vector-view-create": "Anmoakn",
- "vector-view-edit": "Bewerkn",
- "vector-view-history": "Geschiedenisse bekykn",
- "vector-view-view": "Leezn",
- "vector-view-viewsource": "Brontekst bekykn"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Silvicola"
- ]
- },
- "vector.css": "/* CSS hiir beâjflusd nôr dii Vector-schelfn. Wen'd ale uf ôômôôl beâjflusn wilsch, muâsch an MediaWiki:Common.css was ändârn. */",
- "vector-action-addsection": "Ân najn abschnid ôôfangn",
- "vector-action-delete": "Leschn",
- "vector-action-move": "Umdaafn",
- "vector-action-protect": "Schidsn",
- "vector-action-undelete": "Leschn riggängich machn",
- "vector-action-unprotect": "Schuds ufgeebn",
- "vector-view-create": "Ôôleechn",
- "vector-view-edit": "Bearbajdn",
- "vector-view-history": "Wärsjoonsfolche",
- "vector-view-view": "Leesn",
- "vector-view-viewsource": "Gwäl-dhägsd ôôgugn"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Malafaya"
- ]
- },
- "vector-action-addsection": "Lüükön yegädi",
- "vector-action-delete": "Moükön",
- "vector-action-move": "Topätükön",
- "vector-action-protect": "Jelön",
- "vector-action-undelete": "Sämoükön",
- "vector-action-unprotect": "Votükön jeli",
- "vector-view-create": "Jafön",
- "vector-view-edit": "Redakön",
- "vector-view-history": "Logön jenotemi",
- "vector-view-view": "Reidön",
- "vector-view-viewsource": "Logön fonäti"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Paivud"
- ]
- },
- "vector-action-addsection": "Vassõn teema",
- "vector-action-delete": "Pühi",
- "vector-action-move": "Liikut",
- "vector-action-protect": "Varjaa",
- "vector-view-create": "Loo cülci",
- "vector-view-edit": "Muuttaa",
- "vector-view-history": "Istori",
- "vector-view-view": "Lukõa",
- "vector-view-viewsource": "Lähtekoodi"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Võrok"
- ]
- },
- "vector-action-addsection": "Vahtsõ teema ülespandminõ",
- "vector-action-delete": "Kistudaq ärq",
- "vector-action-move": "Nõstaq ümbre",
- "vector-action-protect": "Kaidsaq",
- "vector-action-undelete": "Tiiq tagasi",
- "vector-action-unprotect": "Muudaq kaidsõt",
- "vector-view-create": "Luuq",
- "vector-view-edit": "Toimõndaq",
- "vector-view-history": "Näütäq aoluku",
- "vector-view-view": "Loeq",
- "vector-view-viewsource": "Kaeq lätteteksti"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Srtxg"
- ]
- },
- "vector-action-addsection": "Radjouter on sudjet",
- "vector-action-delete": "Disfacer",
- "vector-action-move": "Displaecî",
- "vector-action-protect": "Protedjî",
- "vector-action-undelete": "Rapexhî",
- "vector-action-unprotect": "Candjî l' protedjaedje",
- "vector-view-create": "Ahiver",
- "vector-view-edit": "Candjî",
- "vector-view-history": "Vey l' istwere",
- "vector-view-view": "Lére",
- "vector-view-viewsource": "Vey côde sourdant"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Harvzsf",
- "JinJian"
- ]
- },
- "vector-action-addsection": "Igdugang hin himangrawon",
- "vector-action-delete": "Para-a",
- "vector-action-move": "Balhina",
- "vector-action-protect": "Panalipda",
- "vector-action-undelete": "Igbalik an ginpara",
- "vector-action-unprotect": "Liwani an panalipod",
- "vector-view-create": "Himo-a",
- "vector-view-edit": "Igliwat",
- "vector-view-history": "Kitaa an kaagi",
- "vector-view-view": "Basaha",
- "vector-view-viewsource": "Kitaa an ginkuhaan",
- "vector-more-actions": "Damo pa"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ibou"
- ]
- },
- "vector-action-addsection": "Yokkuw tëriit",
- "vector-action-delete": "Far",
- "vector-action-move": "Tuddewaat",
- "vector-action-protect": "Aar",
- "vector-action-undelete": "Delloowaat",
- "vector-action-unprotect": "Aaradi",
- "vector-view-create": "Sos",
- "vector-view-edit": "Soppi",
- "vector-view-history": "Wone jaar-jaaram",
- "vector-view-view": "Jàng",
- "vector-view-viewsource": "Wone gongikuwaayam"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Benojan"
- ]
- },
- "vector-action-addsection": "加話題",
- "vector-action-delete": "刪",
- "vector-action-move": "移",
- "vector-action-protect": "保",
- "vector-action-undelete": "弗刪",
- "vector-action-unprotect": "换保护状态",
- "vector-view-create": "建",
- "vector-view-edit": "编",
- "vector-view-history": "望页史",
- "vector-view-view": "读",
- "vector-view-viewsource": "望源码"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Huuchin"
- ]
- },
- "vector-action-addsection": "Төриг немх",
- "vector-action-delete": "Һарһх",
- "vector-action-move": "Көндәх",
- "vector-action-protect": "Харсх",
- "vector-action-undelete": "Һарһх биш",
- "vector-action-unprotect": "Харсх биш",
- "vector-view-create": "Бүтәх",
- "vector-view-edit": "Чиклх",
- "vector-view-history": "Тууҗин хәләвр",
- "vector-view-view": "Умшлһн",
- "vector-view-viewsource": "Темдгллһнә хәләвр"
-}
+++ /dev/null
-{
- "vector-view-edit": "Tshintsha"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Kilavagora",
- "Lika2672",
- "Machirkholi"
- ]
- },
- "vector-action-addsection": "თემაშ მიშაძინა",
- "vector-action-delete": "ლასუა",
- "vector-action-move": "გინოღალა",
- "vector-action-protect": "თხილუა",
- "vector-view-create": "დორსხუაფა",
- "vector-view-edit": "რედაქტირაფა",
- "vector-view-history": "ისტორიაშ ძირაფა",
- "vector-view-view": "კითხირი",
- "vector-view-viewsource": "ქიძირე წყუ"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Joystick",
- "פוילישער"
- ]
- },
- "skinname-vector": "וועקטאר",
- "vector-skin-desc": "מאדערנע ווערסיע פון מאנאבוק מיט פרישן אויסזען און א סך באניצער־פריינדלעכקייט פארבעסערונגען",
- "vector.css": "/* CSS געשטעלט דא ווירקט נאר אויפן וועקטאר סקין */",
- "vector-action-addsection": "צושטעלן טעמע",
- "vector-action-delete": "אויסמעקן",
- "vector-action-move": "באַוועגן",
- "vector-action-protect": "שיצן",
- "vector-action-undelete": "מבטל זיין אויסמעקן",
- "vector-action-unprotect": "ענדערונג באַשיצונג",
- "vector-view-create": "שאַפֿן",
- "vector-view-edit": "רעדאַקטירן",
- "vector-view-history": "ווײַזן היסטאָריע",
- "vector-view-view": "לייענען",
- "vector-view-viewsource": "ווײַזן מקור",
- "vector-more-actions": "נאך"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Demmy"
- ]
- },
- "vector-action-addsection": "Àfikún orí-ọ̀rọ̀",
- "vector-action-delete": "Ìparẹ́",
- "vector-action-move": "Ìyípòdà",
- "vector-action-protect": "Àbò",
- "vector-action-undelete": "Ìmúkúrò ìparẹ́",
- "vector-action-unprotect": "Ìyípadà àbò",
- "vector-view-create": "Ṣ'èdá",
- "vector-view-edit": "Àtúnṣe",
- "vector-view-history": "Wo ìtàn",
- "vector-view-view": "Àwòkà",
- "vector-view-viewsource": "Wo àmìọ̀rọ̀"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ktchankt",
- "Waihorace"
- ]
- },
- "skinname-vector": "Vector",
- "vector.css": "/* 響呢度放 CSS 碼去改用戶用嘅域達畫面 */",
- "vector.js": "/* 響每一次個頁面載入時,用域達畫面嘅用戶都會載入呢度任何嘅JavaScript */",
- "vector-action-addsection": "加主題",
- "vector-action-delete": "剷走",
- "vector-action-move": "搬",
- "vector-action-protect": "保護",
- "vector-action-undelete": "取消剷走",
- "vector-action-unprotect": "改保護",
- "vector-view-create": "開",
- "vector-view-edit": "改",
- "vector-view-history": "睇吓歷史",
- "vector-view-view": "閱",
- "vector-view-viewsource": "睇吓原始碼",
- "vector-more-actions": "更多"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Biŋhai"
- ]
- },
- "vector-action-delete": "Ca",
- "vector-action-move": "Daen",
- "vector-action-protect": "Bauj",
- "vector-view-create": "Laeb",
- "vector-view-edit": "gaij",
- "vector-view-history": "Cazyawj lizsij"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Ooswesthoesbes"
- ]
- },
- "vector-action-addsection": "Voeg kopje toe",
- "vector-action-delete": "Wissen",
- "vector-action-move": "Verschuuf",
- "vector-action-protect": "Bescherm",
- "vector-action-undelete": "Plaets truhhe",
- "vector-action-unprotect": "Beveiligienge anpass'n",
- "vector-view-create": "Anmaeken",
- "vector-view-edit": "Bewerk",
- "vector-view-history": "Geschiedenisse bekiek'n",
- "vector-view-view": "Lezen",
- "vector-view-viewsource": "Brontekst bekieken"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Hydra",
- "Liangent",
- "Liuxinyu970226",
- "Xiaomingyan",
- "Cwek"
- ]
- },
- "vector-skin-desc": "提供清新的外观和许多可用性改进的现代版MonoBook",
- "vector.css": "/* 放置于这里的CSS将影响使用Vector皮肤的用户 */",
- "vector.js": "/* 这里的任何JavaScript将为使用Vector皮肤的用户加载 */",
- "vector-action-addsection": "添加话题",
- "vector-action-delete": "删除",
- "vector-action-move": "移动",
- "vector-action-protect": "保护",
- "vector-action-undelete": "还原",
- "vector-action-unprotect": "更改保护",
- "vector-view-create": "创建",
- "vector-view-edit": "编辑",
- "vector-view-history": "查看历史",
- "vector-view-view": "阅读",
- "vector-view-viewsource": "查看源代码",
- "vector-more-actions": "更多"
-}
+++ /dev/null
-{
- "@metadata": {
- "authors": [
- "Cwlin0416",
- "Justincheng12345",
- "Liuxinyu970226",
- "Mark85296341"
- ]
- },
- "vector-skin-desc": "現代版的 MonoBook,有著較新穎的外觀與許多使用性的改進",
- "vector.css": "/* 此 CSS 會影響使用 Vector 介面外觀的使用者 */",
- "vector.js": "/* 此 JavaScript 會用於使用 Vector 介面外觀使用者 */",
- "vector-action-addsection": "加入主題",
- "vector-action-delete": "刪除",
- "vector-action-move": "移動",
- "vector-action-protect": "保護",
- "vector-action-undelete": "取消刪除",
- "vector-action-unprotect": "變更保護",
- "vector-view-create": "建立",
- "vector-view-edit": "編輯",
- "vector-view-history": "檢視歷史",
- "vector-view-view": "閱讀",
- "vector-view-viewsource": "檢視原始碼",
- "vector-more-actions": "更多"
-}
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path d="M6.001 2.998l5.001 5-5.001 5z" fill="#797979"/></svg>
\ No newline at end of file
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path d="M9.999 13.002l-5.001-5 5.001-5z" fill="#797979"/></svg>
\ No newline at end of file
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" width="22" height="16"><path d="M15.502 6.001l-5 5.001-5-5.001z" fill="#929292"/></svg>
\ No newline at end of file
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" width="22" height="16"><path d="M15.502 6.001l-5 5.001-5-5.001z" fill="#797979"/></svg>
\ No newline at end of file
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path d="M13.002 6.001l-5 5.001-5-5.001z" fill="#797979"/></svg>
\ No newline at end of file
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" width="10" height="10"><g transform="translate(-826.429 -698.791)"><rect width="5.982" height="5.982" x="826.929" y="702.309" fill="#fff" stroke="#06c"/><g><path d="M831.194 698.791h5.234v5.391l-1.571 1.545-1.31-1.31-2.725 2.725-2.689-2.689 2.808-2.808-1.311-1.311z" fill="#06f"/><path d="M835.424 699.795l.022 4.885-1.817-1.817-2.881 2.881-1.228-1.228 2.881-2.881-1.851-1.851z" fill="#fff"/></g></g></svg>
\ No newline at end of file
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" width="10" height="10"><g transform="translate(-826.429 -698.791)"><rect width="5.982" height="5.982" x="-835.929" y="702.309" transform="scale(-1 1)" fill="#fff" stroke="#06c"/><g><path d="M831.663 698.791h-5.234v5.391l1.571 1.545 1.31-1.31 2.725 2.725 2.689-2.689-2.808-2.808 1.311-1.311z" fill="#06f"/><path d="M827.433 699.795l-.022 4.885 1.817-1.817 2.881 2.881 1.228-1.228-2.881-2.881 1.851-1.851z" fill="#fff"/></g></g></svg>
\ No newline at end of file
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" width="12" height="13"><g stroke-width="2" stroke="#6c6c6c" fill="none"><path d="M11.29 11.71l-4-4"/><circle cx="5" cy="5" r="4"/></g></svg>
\ No newline at end of file
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" width="12" height="13"><g stroke-width="2" stroke="#6c6c6c" fill="none"><path d="M.71 11.71l4-4"/><circle cx="7" cy="5" r="4"/></g></svg>
\ No newline at end of file
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16"><defs><linearGradient id="a"><stop offset="0" stop-color="#c2edff"/><stop offset=".5" stop-color="#68bdff"/><stop offset="1" stop-color="#fff"/></linearGradient><linearGradient x1="13.47" y1="14.363" x2="4.596" y2="3.397" id="b" xlink:href="#a" gradientUnits="userSpaceOnUse"/></defs><path d="M8.103 1.146l2.175 4.408 4.864.707-3.52 3.431.831 4.845-4.351-2.287-4.351 2.287.831-4.845-3.52-3.431 4.864-.707z" fill="url(#b)" stroke="#c8b250" stroke-width="0.9999199999999999"/></svg>
\ No newline at end of file
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16"><defs><linearGradient id="a"><stop offset="0" stop-color="#c2edff"/><stop offset=".5" stop-color="#68bdff"/><stop offset="1" stop-color="#fff"/></linearGradient><linearGradient x1="13.47" y1="14.363" x2="4.596" y2="3.397" id="b" xlink:href="#a" gradientUnits="userSpaceOnUse"/></defs><path d="M8.103 1.146l2.175 4.408 4.864.707-3.52 3.431.831 4.845-4.351-2.287-4.351 2.287.831-4.845-3.52-3.431 4.864-.707z" fill="url(#b)" stroke="#7cb5d1" stroke-width="0.9999199999999999"/></svg>
\ No newline at end of file
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="12" height="13.837"><defs><linearGradient id="e"><stop offset="0"/><stop offset="1" stop-opacity="0"/></linearGradient><linearGradient id="b"><stop offset="0" stop-color="#3b74bc"/><stop offset="1" stop-color="#2d5990"/></linearGradient><linearGradient id="c"><stop offset="0" stop-color="#fff"/><stop offset="1" stop-color="#c9c9c9"/></linearGradient><linearGradient id="a"><stop offset="0"/><stop offset="1" stop-opacity="0"/></linearGradient><linearGradient id="d"><stop offset="0" stop-color="#f4d9b1"/><stop offset="1" stop-color="#df9725"/></linearGradient><radialGradient cx="31.113" cy="19.009" r="8.662" fx="31.113" fy="19.009" id="f" xlink:href="#a" gradientUnits="userSpaceOnUse"/><radialGradient cx="28.09" cy="27.203" r="13.565" fx="28.09" fy="27.203" id="g" xlink:href="#b" gradientUnits="userSpaceOnUse" gradientTransform="matrix(1.298 0 0 .885 -8.359 4.94)"/><linearGradient x1="30.936" y1="29.553" x2="30.936" y2="35.803" id="h" xlink:href="#c" gradientUnits="userSpaceOnUse"/><radialGradient cx="31.113" cy="19.009" r="8.662" fx="31.113" fy="19.009" id="i" xlink:href="#a" gradientUnits="userSpaceOnUse"/><radialGradient cx="29.345" cy="17.064" r="9.162" fx="29.345" fy="17.064" id="j" xlink:href="#d" gradientUnits="userSpaceOnUse" gradientTransform="matrix(.788 0 0 .788 6.221 3.618)"/><linearGradient x1="20.662" y1="35.818" x2="22.627" y2="36.218" id="k" xlink:href="#e" gradientUnits="userSpaceOnUse" gradientTransform="matrix(.983 .182 -.182 .983 6.232 -2.651)"/><linearGradient x1="22.687" y1="36.39" x2="21.408" y2="35.74" id="l" xlink:href="#e" gradientUnits="userSpaceOnUse" gradientTransform="matrix(-.978 .21 .21 .978 55.11 -3.945)"/></defs><g color="#000"><path d="M39.775 19.009a8.662 8.662 0 1 1-17.324 0 8.662 8.662 0 1 1 17.324 0z" transform="matrix(.693 0 0 .374 -15.548 3.481)" fill="url(#f)" fill-rule="evenodd" overflow="visible"/><path d="M4.046 12.398h4.137c1.172 0 2.332-.43 2.758-1.655.404-1.163.069-3.378-2.551-5.171h-4.895c-2.62 1.655-2.947 3.917-2.344 5.24.614 1.347 1.655 1.586 2.896 1.586z" fill="url(#g)" fill-rule="evenodd" stroke="#204a87" stroke-linecap="round" stroke-linejoin="round" overflow="visible" stroke-width="0.39"/><path d="M4.321 6.193c1.241 1.103 1.793 5.102 1.793 5.102s.552-3.999 1.517-5.171l-3.309.069z" fill="url(#h)" fill-rule="evenodd" overflow="visible"/><path d="M5.21 6.607s-.839.648-.767 1.428c-.796-.702-.819-2.048-.819-2.048l1.586.62z" fill="#729fcf" fill-rule="evenodd" overflow="visible"/><path d="M4.018 11.992l4.092-.009c1.029 0 2.049-.377 2.422-1.453.355-1.022-.037-2.967-2.338-4.542l-4.495-.095c-2.301 1.453-2.747 3.441-2.208 4.697.538 1.256 1.324 1.393 2.526 1.401z" opacity=".215" stroke="#fff" stroke-linecap="round" stroke-linejoin="round" overflow="visible" fill="none" stroke-width="0.39"/><path d="M6.941 6.607s.839.648.767 1.428c.796-.702.819-2.048.819-2.048l-1.586.62z" fill="#729fcf" fill-rule="evenodd" overflow="visible"/><path d="M39.775 19.009a8.662 8.662 0 1 1-17.324 0 8.662 8.662 0 1 1 17.324 0z" transform="matrix(.39 0 0 .39 -6.138 -2.475)" fill="url(#i)" fill-rule="evenodd" overflow="visible"/><path d="M39.775 19.009a8.662 8.662 0 1 1-17.324 0 8.662 8.662 0 1 1 17.324 0z" fill="url(#j)" fill-rule="evenodd" stroke="#c17d11" stroke-linecap="round" stroke-linejoin="round" overflow="visible" transform="matrix(.39 0 0 .39 -6.089 -3.84)"/><path d="M39.775 19.009a8.662 8.662 0 1 1-17.324 0 8.662 8.662 0 1 1 17.324 0z" transform="matrix(.342 0 0 .342 -4.598 -2.929)" opacity=".196" stroke="#fff" stroke-width="1.14" stroke-linecap="round" stroke-linejoin="round" overflow="visible" fill="none"/><path d="M2.433 12.062c-.487-.213-.704-.725-.704-.725.328-1.587 1.451-2.748 1.451-2.748s-.889 2.5-.746 3.473z" opacity=".228" fill="url(#k)" fill-rule="evenodd" overflow="visible"/><path d="M9.806 11.728c.48-.227.704-.781.704-.781-.374-1.577-1.551-2.669-1.551-2.669s.961 2.474.847 3.45z" opacity=".228" fill="url(#l)" fill-rule="evenodd" overflow="visible"/></g></svg>
\ No newline at end of file
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path d="M8.103 1.146l2.175 4.408 4.864.707-3.52 3.431.831 4.845-4.351-2.287-4.351 2.287.831-4.845-3.52-3.431 4.864-.707z" fill="#fff" stroke="#c8b250" stroke-width="0.9999199999999999"/></svg>
\ No newline at end of file
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path d="M8.103 1.146l2.175 4.408 4.864.707-3.52 3.431.831 4.845-4.351-2.287-4.351 2.287.831-4.845-3.52-3.431 4.864-.707z" fill="#fff" stroke="#d1d1d1" stroke-width="0.9999199999999999"/></svg>
\ No newline at end of file
+++ /dev/null
-<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16"><path d="M8.103 1.146l2.175 4.408 4.864.707-3.52 3.431.831 4.845-4.351-2.287-4.351 2.287.831-4.845-3.52-3.431 4.864-.707z" fill="#fff" stroke="#7cb5d1" stroke-width="0.9999199999999999"/></svg>
\ No newline at end of file
+++ /dev/null
-/* Vector screen styles for high definition displays */
-
-@import "variables.less";
-
-div#content {
- margin-left: 11em;
- padding: 1.25em 1.5em 1.5em 1.5em;
-}
-#p-logo {
- left: @menu-main-logo-left;
-}
-div#footer {
- margin-left: 11em;
- padding: 1.25em;
-}
-#mw-panel {
- padding-left: 0.5em;
-}
-#p-search {
- margin-right: 1em;
-}
-#left-navigation {
- margin-left: 11em;
-}
-#p-personal {
- right: 1em;
-}
-#mw-head-base {
- margin-left: 11em;
-}
+++ /dev/null
-/* Vector screen styles */
-
-@import "variables.less";
-
-@import "components/common.less";
-@import "components/animations.less";
-@import "components/navigation.less";
-@import "components/footer.less";
-@import "components/externalLinks.less";
+++ /dev/null
-/* Tooltips are outside of the normal body code, so this helps make the size of the text sensible */
-.tipsy {
- font-size: 0.8em;
-}
+++ /dev/null
-/*!
- * jQuery UI Accordion 1.9.2
- * http://jqueryui.com
- *
- * Copyright 2012 jQuery Foundation and other contributors
- * Released under the MIT license.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Accordion#theming
- */
-.ui-accordion .ui-accordion-header { display: block; cursor: pointer; position: relative; margin-top: 2px; padding: .5em .5em .5em .7em; zoom: 1; }
-.ui-accordion .ui-accordion-icons { padding-left: 2.2em; }
-.ui-accordion .ui-accordion-noicons { padding-left: .7em; }
-.ui-accordion .ui-accordion-icons .ui-accordion-icons { padding-left: 2.2em; }
-.ui-accordion .ui-accordion-header .ui-accordion-header-icon { position: absolute; left: .5em; top: 50%; margin-top: -8px; }
-.ui-accordion .ui-accordion-content { padding: 1em 2.2em; border-top: 0; overflow: auto; zoom: 1; }
+++ /dev/null
-/* Autocomplete
-----------------------------------*/
-.ui-autocomplete { position: absolute; cursor: default; }
-.ui-autocomplete-loading { /* @embed */ background: white url('images/ui-anim_basic_16x16.gif') right center no-repeat; }
-
-/* workarounds */
-* html .ui-autocomplete { width:1px; } /* without this, the menu expands to 100% in IE6 */
-
-/* Menu
-----------------------------------*/
-.ui-menu {
- list-style:none;
- padding: 2px;
- margin: 0;
- display:block;
- float: left;
-}
-.ui-menu .ui-menu {
- margin-top: -3px;
-}
-.ui-menu .ui-menu-item {
- margin:0;
- padding: 0;
- zoom: 1;
- float: left;
- clear: left;
- width: 100%;
-}
-.ui-menu .ui-menu-item a {
- text-decoration:none;
- display:block;
- padding:.2em .4em;
- line-height:1.5;
- zoom:1;
-}
-.ui-menu .ui-menu-item a.ui-state-hover,
-.ui-menu .ui-menu-item a.ui-state-active {
- font-weight: normal;
- margin: -1px;
-}
+++ /dev/null
-/* Button
-----------------------------------*/
-
-.ui-button {
- display: inline-block;
- position: relative;
- padding: 0;
- margin-right: .1em;
- text-decoration: none !important;
- cursor: pointer;
- text-align: center;
- zoom: 1;
- overflow: visible; /* the overflow property removes extra width in IE */
-}
-
-/*button text element */
-.ui-button .ui-button-text {
- display: block;
- line-height: 1.4;
- text-shadow: 0 1px 1px #fff;
-}
-.ui-button-text-only .ui-button-text {
- padding: 0.3em 1em 0.25em 1em;
-}
-.ui-button-icon-only .ui-button-text,
-.ui-button-icons-only .ui-button-text {
- padding: 0.3em;
- text-indent: -9999999px;
-}
-.ui-button-text-icon-primary .ui-button-text,
-.ui-button-text-icons .ui-button-text {
- padding: 0.3em 1em 0.25em 2.1em;
-}
-.ui-button-text-icon-secondary .ui-button-text,
-.ui-button-text-icons .ui-button-text {
- padding: 0.3em 2.1em 0.25em 1em;
-}
-.ui-button-text-icons .ui-button-text {
- padding-left: 2.1em;
- padding-right: 2.1em;
-}
-
-/* no icon support for input elements, provide padding by default */
-input.ui-button {
- padding: 0.3em 1em;
-}
-
-/*button icon element(s) */
-.ui-button-icon-only .ui-icon,
-.ui-button-text-icon-primary .ui-icon,
-.ui-button-text-icon-secondary .ui-icon,
-.ui-button-text-icons .ui-icon,
-.ui-button-text-icon .ui-icon,
-.ui-button-icons-only .ui-icon {
- position: absolute;
- top: 50%;
- margin-top: -9px;
-}
-.ui-button-icon-only .ui-icon {
- left: 50%;
- margin-left: -8px;
-}
-.ui-button-text-icon-primary .ui-button-icon-primary,
-.ui-button-text-icon .ui-button-icon-primary,
-.ui-button-text-icons .ui-button-icon-primary,
-.ui-button-icons-only .ui-button-icon-primary {
- left: 0.5em;
-}
-.ui-button-text-icon-secondary .ui-button-icon-secondary,
-.ui-button-text-icon .ui-button-icon-secondary,
-.ui-button-text-icons .ui-button-icon-secondary,
-.ui-button-icons-only .ui-button-icon-secondary {
- right: 0.5em;
-}
-
-/*button sets*/
-.ui-buttonset {
- margin-right: 7px;
-}
-.ui-buttonset .ui-button {
- margin-left: 0;
- margin-right: -.4em;
-}
-
-/* workarounds */
-button.ui-button::-moz-focus-inner {
- border: 0;
- padding: 0; /* reset extra padding in Firefox */
-}
-/* Disables the annoying dashed border Firefox puts on active buttons */
-body button.ui-button::-moz-focus-inner {
- border: 0;
-}
-/* Give large buttons some extra padding */
-body .ui-button-large {
- padding: 5px;
-}
-/* Use white icons for colored buttons */
-.ui-button-green .ui-icon,
-.ui-button-blue .ui-icon,
-.ui-button-red .ui-icon,
-.ui-button-orange .ui-icon {
- /* @embed */
- background-image: url(images/ui-icons_ffffff_256x240.png) !important;
-}
-
-/* Corner radius */
-/* This is normally handled in jquery.ui.theme.css, but in our case, the corner
- styling of our buttons doesn't match our default widget corner styling */
-.ui-button.ui-corner-all,
-.ui-button.ui-corner-top,
-.ui-button.ui-corner-left,
-.ui-button.ui-corner-tl {
- border-top-left-radius: 4px;
-}
-.ui-button.ui-corner-all,
-.ui-button.ui-corner-top,
-
-.ui-button.ui-corner-right,
-.ui-button.ui-corner-tr {
- border-top-right-radius: 4px;
-}
-.ui-button.ui-corner-all,
-.ui-button.ui-corner-bottom,
-.ui-button.ui-corner-left,
-.ui-button.ui-corner-bl {
- border-bottom-left-radius: 4px;
-}
-.ui-button.ui-corner-all,
-.ui-button.ui-corner-bottom,
-.ui-button.ui-corner-right,
-.ui-button.ui-corner-br {
- border-bottom-right-radius: 4px;
-}
-
-body .ui-button {
- color: #2779aa;
- margin: 0.5em 0 0.5em 0.4em;
- border: 1px solid #aaa !important;
- background: #f0f0f0 !important;
- background: -moz-linear-gradient(top, #fff 0%, #ddd 90%) !important; /* FF3.6+ */
- background: -webkit-linear-gradient(top, #fff 0%, #ddd 90%) !important; /* Chrome10+, Safari5.1+ */
- background: -o-linear-gradient(top, #fff 0%, #ddd 90%) !important; /* Opera 11.10+ */
- background: -ms-linear-gradient(top, #fff 0%, #ddd 90%) !important; /* IE10+ */
- background: linear-gradient(to bottom, #fff 0%, #ddd 90%) !important;
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#dddddd', GradientType=0); /* IE6-8 */
- cursor: pointer;
- font-size: 1em;
- line-height: 1.4em;
- width: auto;
- overflow: visible;
- box-shadow: 0 1px 3px rgba(0,0,0,.2);
-}
-
-body .ui-button-icon-only {
- width: 2.2em;
-}
-
-body .ui-button-icons-only {
- width: 3.4em;
-}
-
-body .ui-button:hover {
- color: #2779aa;
- border-color: #bbb !important;
- background: #fff !important;
- background: -moz-linear-gradient(top, #fff 0%, #eee 90%) !important; /* FF3.6+ */
- background: -webkit-linear-gradient(top, #fff 0%, #eee 90%) !important; /* Chrome10+, Safari5.1+ */
- background: -o-linear-gradient(top, #fff 0%, #eee 90%) !important; /* Opera 11.10+ */
- background: -ms-linear-gradient(top, #fff 0%, #eee 90%) !important; /* IE10+ */
- background: linear-gradient(to bottom, #fff 0%, #eee 90%) !important;
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#eeeeee', GradientType=0); /* IE6-8 */
- box-shadow: 0 1px 3px rgba(0,0,0,.1);
-}
-body .ui-button:active,
-body .ui-button:focus {
- border-color: #8ad !important;
- box-shadow: 0 0 1px 1px rgba(167,215,249,.5);
-}
-body .ui-button:active {
- background: #e0e0e0 !important;
- background: -moz-linear-gradient(top, #f0f0f0 0%, #d0d0d0 90%) !important; /* FF3.6+ */
- background: -webkit-linear-gradient(top, #f0f0f0 0%, #d0d0d0 90%) !important; /* Chrome10+, Safari5.1+ */
- background: -o-linear-gradient(top, #f0f0f0 0%, #d0d0d0 90%) !important; /* Opera 11.10+ */
- background: -ms-linear-gradient(top, #f0f0f0 0%, #d0d0d0 90%) !important; /* IE10+ */
- background: linear-gradient(to bottom, #f0f0f0 0%, #d0d0d0 90%) !important;
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#f0f0f0', endColorstr='#d0d0d0', GradientType=0); /* IE6-8 */
-}
-
-/* Green buttons */
-body .ui-button-green,
-body .ui-button-green .ui-button-text {
- color: white;
- text-shadow: 0 -1px 1px #072;
-}
-body .ui-button.ui-button-green {
- border-color: #294 !important;
- background: #295 !important;
- background: -moz-linear-gradient(top, #3c8 0%, #295 90%) !important; /* FF3.6+ */
- background: -webkit-linear-gradient(top, #3c8 0%, #295 90%) !important; /* Chrome10+, Safari5.1+ */
- background: -o-linear-gradient(top, #3c8 0%, #295 90%) !important; /* Opera 11.10+ */
- background: -ms-linear-gradient(top, #3c8 0%, #295 90%) !important; /* IE10+ */
- background: linear-gradient(to bottom, #3c8 0%, #295 90%) !important;
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#33cc88', endColorstr='#229955', GradientType=0); /* IE6-8 */
- box-shadow: 0 1px 3px rgba(0,0,0,.3);
-}
-body .ui-button.ui-button-green:hover {
- background: #33a055 !important;
- background: -moz-linear-gradient(top, #44d388 0%, #33a055 90%) !important; /* FF3.6+ */
- background: -webkit-linear-gradient(top, #44d388 0%, #33a055 90%) !important; /* Chrome10+, Safari5.1+ */
- background: -o-linear-gradient(top, #44d388 0%, #33a055 90%) !important; /* Opera 11.10+ */
- background: -ms-linear-gradient(top, #44d388 0%, #33a055 90%) !important; /* IE10+ */
- background: linear-gradient(to bottom, #44d388 0%, #33a055 90%) !important;
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#44d388', endColorstr='#33a055', GradientType=0); /* IE6-8 */
- box-shadow: 0 1px 3px rgba(0,0,0,.25);
-}
-body .ui-button.ui-button-green:active,
-body .ui-button.ui-button-green:focus {
- border-color: #172 !important;
- box-shadow: 0 0 2px 2px rgba(167,215,249,.75);
-}
-body .ui-button.ui-button-green:active {
- background: #338855 !important;
- background: -moz-linear-gradient(top, #30c080 0%, #338855 90%) !important; /* FF3.6+ */
- background: -webkit-linear-gradient(top, #30c080 0%, #338855 90%) !important; /* Chrome10+, Safari5.1+ */
- background: -o-linear-gradient(top, #30c080 0%, #338855 90%) !important; /* Opera 11.10+ */
- background: -ms-linear-gradient(top, #30c080 0%, #338855 90%) !important; /* IE10+ */
- background: linear-gradient(to bottom, #30c080 0%, #338855 90%) !important;
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#30c080', endColorstr='#338855', GradientType=0); /* IE6-8 */
-}
-
-/* Blue buttons */
-body .ui-button-blue,
-body .ui-button-blue .ui-button-text {
- color: white;
- text-shadow: 0 -1px 1px #037;
-}
-body .ui-button.ui-button-blue {
- border-color: #468 !important;
- background: #36b !important;
- background: -moz-linear-gradient(top, #48e 0%, #36b 90%) !important; /* FF3.6+ */
- background: -webkit-linear-gradient(top, #48e 0%, #36b 90%) !important; /* Chrome10+, Safari5.1+ */
- background: -o-linear-gradient(top, #48e 0%, #36b 90%) !important; /* Opera 11.10+ */
- background: -ms-linear-gradient(top, #48e 0%, #36b 90%) !important; /* IE10+ */
- background: linear-gradient(to bottom, #48e 0%, #36b 90%) !important;
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#4488ee', endColorstr='#3366bb', GradientType=0); /* IE6-8 */
- box-shadow: 0 1px 3px rgba(0,0,0,.35);
-}
-body .ui-button.ui-button-blue:hover {
- background: #36c !important;
- background: -moz-linear-gradient(top, #59e 0%, #36c 90%) !important; /* FF3.6+ */
- background: -webkit-linear-gradient(top, #59e 0%, #36c 90%) !important; /* Chrome10+, Safari5.1+ */
- background: -o-linear-gradient(top, #59e 0%, #36c 90%) !important; /* Opera 11.10+ */
- background: -ms-linear-gradient(top, #59e 0%, #36c 90%) !important; /* IE10+ */
- background: linear-gradient(to bottom, #59e 0%, #36c 90%) !important;
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#5599ee', endColorstr='#3366cc', GradientType=0); /* IE6-8 */
-}
-body .ui-button.ui-button-blue:active,
-body .ui-button.ui-button-blue:focus {
- border-color: #357 !important;
- box-shadow: 0 0 2px 2px rgba(167,215,249,.75);
-}
-body .ui-button.ui-button-blue:active {
- background: #3060a0 !important;
- background: -moz-linear-gradient(top, #4080e0 0%, #3060a0 90%) !important; /* FF3.6+ */
- background: -webkit-linear-gradient(top, #4080e0 0%, #3060a0 90%) !important; /* Chrome10+, Safari5.1+ */
- background: -o-linear-gradient(top, #4080e0 0%, #3060a0 90%) !important; /* Opera 11.10+ */
- background: -ms-linear-gradient(top, #4080e0 0%, #3060a0 90%) !important; /* IE10+ */
- background: linear-gradient(to bottom, #4080e0 0%, #3060a0 90%) !important;
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#4080e0', endColorstr='#3060a0', GradientType=0); /* IE6-8 */
-}
-
-/* Red buttons */
-body .ui-button-red,
-body .ui-button-red .ui-button-text {
- color: white;
- text-shadow: 0 -1px 1px #700;
-}
-body .ui-button.ui-button-red {
- border-color: #944 !important;
- background: #a22 !important;
- background: -moz-linear-gradient(top, #d44 0%, #a22 90%) !important; /* FF3.6+ */
- background: -webkit-linear-gradient(top, #d44 0%, #a22 90%) !important; /* Chrome10+, Safari5.1+ */
- background: -o-linear-gradient(top, #d44 0%, #a22 90%) !important; /* Opera 11.10+ */
- background: -ms-linear-gradient(top, #d44 0%, #a22 90%) !important; /* IE10+ */
- background: linear-gradient(to bottom, #d44 0%, #a22 90%) !important;
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#dd4444', endColorstr='#aa2222', GradientType=0); /* IE6-8 */
- box-shadow: 0 1px 3px rgba(0,0,0,.35);
-}
-body .ui-button.ui-button-red:hover {
- border-color: #a44 !important;
- background: #b03333 !important;
- background: -moz-linear-gradient(top, #ee4646 0%, #b03333 90%) !important; /* FF3.6+ */
- background: -webkit-linear-gradient(top, #ee4646 0%, #b03333 90%) !important; /* Chrome10+, Safari5.1+ */
- background: -o-linear-gradient(top, #ee4646 0%, #b03333 90%) !important; /* Opera 11.10+ */
- background: -ms-linear-gradient(top, #ee4646 0%, #b03333 90%) !important; /* IE10+ */
- background: linear-gradient(to bottom, #ee4646 0%, #b03333 90%) !important;
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ee4646', endColorstr='#b03333', GradientType=0); /* IE6-8 */
- box-shadow: 0 1px 3px rgba(0,0,0,.3);
-}
-body .ui-button.ui-button-red:active,
-body .ui-button.ui-button-red:focus {
- border-color: #747 !important;
- box-shadow: 0 0 2px 2px rgba(167,215,249,.7);
-}
-body .ui-button.ui-button-red:active {
- background: #952020 !important;
- background: -moz-linear-gradient(top, #d04545 0%, #952020 90%) !important; /* FF3.6+ */
- background: -webkit-linear-gradient(top, #d04545 0%, #952020 90%) !important; /* Chrome10+, Safari5.1+ */
- background: -o-linear-gradient(top, #d04545 0%, #952020 90%) !important; /* Opera 11.10+ */
- background: -ms-linear-gradient(top, #d04545 0%, #952020 90%) !important; /* IE10+ */
- background: linear-gradient(to bottom, #d04545 0%, #952020 90%) !important;
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#d04545', endColorstr='#952020', GradientType=0); /* IE6-8 */
-}
-
-/* Disabled buttons */
-body .ui-button-green.disabled,
-body .ui-button-green.disabled:hover,
-body .ui-button-green.disabled:active,
-body .ui-button-green.disabled:focus,
-body .ui-button-blue.disabled,
-body .ui-button-blue.disabled:hover,
-body .ui-button-blue.disabled:active,
-body .ui-button-blue.disabled:focus,
-body .ui-button-red.disabled,
-body .ui-button-red.disabled:hover,
-body .ui-button-red.disabled:active,
-body .ui-button-red.disabled:focus,
-body .ui-button.disabled,
-body .ui-button.disabled:hover {
- color: #aaa;
- border-color: #ccc !important;
- background: #eee !important;
- background: -moz-linear-gradient(top, #f6f6f6 0%, #eee 90%) !important; /* FF3.6+ */
- background: -webkit-linear-gradient(top, #f6f6f6 0%, #eee 90%) !important; /* Chrome10+, Safari5.1+ */
- background: -o-linear-gradient(top, #f6f6f6 0%, #eee 90%) !important; /* Opera 11.10+ */
- background: -ms-linear-gradient(top, #f6f6f6 0%, #eee 90%) !important; /* IE10+ */
- background: linear-gradient(to bottom, #f6f6f6 0%, #eee 90%) !important;
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#f6f6f6', endColorstr='#eeeeee', GradientType=0); /* IE6-8 */
- box-shadow: 0 1px 3px rgba(0,0,0,0);
-}
-body .ui-button-green.disabled .ui-button-text,
-body .ui-button-blue.disabled .ui-button-text,
-body .ui-button-red.disabled .ui-button-text {
- color: #aaa;
- text-shadow: 0 1px 1px #fff;
-}
+++ /dev/null
-/*!
- * jQuery UI CSS Framework 1.9.2
- * http://jqueryui.com
- *
- * Copyright 2012 jQuery Foundation and other contributors
- * Released under the MIT license.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Theming/API
- */
-
-/* Layout helpers
-----------------------------------*/
-.ui-helper-hidden { display: none; }
-.ui-helper-hidden-accessible { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; }
-.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; }
-.ui-helper-clearfix:before, .ui-helper-clearfix:after { content: ""; display: table; }
-.ui-helper-clearfix:after { clear: both; }
-.ui-helper-clearfix { zoom: 1; }
-.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); }
-
-
-/* Interaction Cues
-----------------------------------*/
-.ui-state-disabled { cursor: default !important; }
-
-
-/* Icons
-----------------------------------*/
-
-/* states and images */
-.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; }
-
-
-/* Misc visuals
-----------------------------------*/
-
-/* Overlays */
-.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
+++ /dev/null
-/* Datepicker
-----------------------------------*/
-.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; }
-.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; }
-.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; }
-.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; }
-.ui-datepicker .ui-datepicker-prev { left:2px; }
-.ui-datepicker .ui-datepicker-next { right:2px; }
-.ui-datepicker .ui-datepicker-prev-hover { left:1px; }
-.ui-datepicker .ui-datepicker-next-hover { right:1px; }
-.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; }
-.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; }
-.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; padding:1px 0; }
-.ui-datepicker select.ui-datepicker-month-year {width: 100%;}
-.ui-datepicker select.ui-datepicker-month,
-.ui-datepicker select.ui-datepicker-year { width: 49%;}
-.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; }
-.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; }
-.ui-datepicker td { border: 0; padding: 1px; }
-.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; }
-.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .2em 0 0 0; padding: 0 .2em; border-top: 1px solid #DDDDDD; border-left: 0; border-right: 0; border-bottom: 0; }
-.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; }
-.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; }
-
-/* with multiple calendars */
-.ui-datepicker.ui-datepicker-multi { width:auto; }
-.ui-datepicker-multi .ui-datepicker-group { float:left; }
-.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; }
-.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; }
-.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; }
-.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; }
-.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; }
-.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; }
-.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; }
-.ui-datepicker-row-break { clear:both; width:100%; }
-
-/* RTL support */
-/* @noflip */ .ui-datepicker-rtl { direction: rtl; }
-/* @noflip */ .ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; }
-/* @noflip */ .ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; }
-/* @noflip */ .ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; }
-/* @noflip */ .ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; }
-/* @noflip */ .ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; }
-/* @noflip */ .ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; }
-/* @noflip */ .ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; }
-/* @noflip */ .ui-datepicker-rtl .ui-datepicker-group { float:right; }
-/* @noflip */ .ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
-/* @noflip */ .ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
-
-/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */
-.ui-datepicker-cover {
- display: none; /*sorry for IE5*/
- display/**/: block; /*sorry for IE5*/
- position: absolute; /*must have*/
- z-index: -1; /*must have*/
- filter: mask(); /*must have*/
- top: -4px; /*must have*/
- left: -4px; /*must have*/
- width: 200px; /*must have*/
- height: 200px; /*must have*/
-}
\ No newline at end of file
+++ /dev/null
-/* Dialog
-----------------------------------*/
-.ui-dialog { position: absolute; padding: 0; width: 300px; }
-.ui-dialog .ui-dialog-titlebar { padding: .75em; position: relative; }
-.ui-dialog .ui-dialog-title { float: left; margin: 0; }
-.ui-dialog .ui-dialog-titlebar-close { position: absolute; right: .75em; top: 50%; width: 19px; margin: -10px 0 0 0; padding: 1px; height: 18px; }
-.ui-dialog .ui-dialog-titlebar-close span { display: block; margin: 1px; }
-.ui-dialog .ui-dialog-titlebar-close:hover, .ui-dialog .ui-dialog-titlebar-close:focus { padding: 0; }
-.ui-dialog .ui-dialog-content { border: 0; padding: .5em 1em; background: none; overflow: auto; zoom: 1; }
-.ui-dialog .ui-dialog-buttonpane { text-align: left; border-width: 1px 0 0 0; background-image: none; margin: .5em 0 0 0; padding: .3em 1em .5em .4em; }
-.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { float: right; }
-.ui-dialog .ui-resizable-se { width: 14px; height: 14px; right: 3px; bottom: 3px; }
-.ui-draggable .ui-dialog-titlebar { cursor: move; }
-/* Customizations */
-body .ui-dialog .ui-dialog-titlebar-close:hover {
- text-decoration: none;
-}
-body .ui-dialog .ui-dialog-content .status-invalid input {
- border: 2px solid red;
- padding: 2px 1px;
-}
-body .ui-dialog .ui-dialog-titlebar {
- padding: 0.9em 1.4em 0.6em !important;
-}
-body .ui-dialog .ui-widget-header {
- /* @embed */
- background: #f0f0f0 url(images/titlebar-fade.png) repeat-x scroll 50% 100% !important;
-}
-/* FIXME: Should just update the icon sprite if we're keeping this X */
-body .ui-dialog .ui-icon-closethick {
- /* @embed */
- background: url(images/close.png) no-repeat 50% 50% !important;
-}
-body .ui-dialog .ui-dialog-buttonpane {
- margin-top: 0 !important;
- padding:0.3em 1.4em 0.5em 1.4em !important;
-}
+++ /dev/null
-/*!
- * jQuery UI Progressbar 1.9.2
- * http://jqueryui.com
- *
- * Copyright 2012 jQuery Foundation and other contributors
- * Released under the MIT license.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Progressbar#theming
- */
-.ui-progressbar { height:2em; text-align: left; overflow: hidden; }
-.ui-progressbar .ui-progressbar-value {margin: -1px; height:100%; }
\ No newline at end of file
+++ /dev/null
-/* Resizable
-----------------------------------*/
-.ui-resizable { position: relative;}
-.ui-resizable-handle { position: absolute;font-size: 0.1px;z-index: 99999; display: block;}
-.ui-resizable-disabled .ui-resizable-handle, .ui-resizable-autohide .ui-resizable-handle { display: none; }
-.ui-resizable-n { cursor: n-resize; height: 7px; width: 100%; top: -5px; left: 0; }
-.ui-resizable-s { cursor: s-resize; height: 7px; width: 100%; bottom: -5px; left: 0; }
-/* @noflip */
-.ui-resizable-e { cursor: e-resize; width: 7px; right: -5px; top: 0; height: 100%; }
-/* @noflip */
-.ui-resizable-w { cursor: w-resize; width: 7px; left: -5px; top: 0; height: 100%; }
-/* @noflip */
-.ui-resizable-se { cursor: se-resize; width: 12px; height: 12px; right: 1px; bottom: 1px; }
-/* @noflip */
-.ui-resizable-sw { cursor: sw-resize; width: 9px; height: 9px; left: -5px; bottom: -5px; }
-/* @noflip */
-.ui-resizable-nw { cursor: nw-resize; width: 9px; height: 9px; left: -5px; top: -5px; }
-/* @noflip */
-.ui-resizable-ne { cursor: ne-resize; width: 9px; height: 9px; right: -5px; top: -5px;}
\ No newline at end of file
+++ /dev/null
-/*!
- * jQuery UI Selectable 1.9.2
- * http://jqueryui.com
- *
- * Copyright 2012 jQuery Foundation and other contributors
- * Released under the MIT license.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Selectable#theming
- */
-.ui-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; }
+++ /dev/null
-/*!
- * jQuery UI Slider 1.9.2
- * http://jqueryui.com
- *
- * Copyright 2012 jQuery Foundation and other contributors
- * Released under the MIT license.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Slider#theming
- */
-.ui-slider { position: relative; text-align: left; }
-.ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; }
-.ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; background-position: 0 0; }
-
-.ui-slider-horizontal { height: .8em; }
-.ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; }
-.ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; }
-.ui-slider-horizontal .ui-slider-range-min { left: 0; }
-.ui-slider-horizontal .ui-slider-range-max { right: 0; }
-
-.ui-slider-vertical { width: .8em; height: 100px; }
-.ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; }
-.ui-slider-vertical .ui-slider-range { left: 0; width: 100%; }
-.ui-slider-vertical .ui-slider-range-min { bottom: 0; }
-.ui-slider-vertical .ui-slider-range-max { top: 0; }
\ No newline at end of file
+++ /dev/null
-/*!
- * jQuery UI Tabs 1.9.2
- * http://jqueryui.com
- *
- * Copyright 2012 jQuery Foundation and other contributors
- * Released under the MIT license.
- * http://jquery.org/license
- *
- * http://docs.jquery.com/UI/Tabs#theming
- */
-.ui-tabs { position: relative; padding: .2em; zoom: 1; } /* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */
-.ui-tabs .ui-tabs-nav { margin: 0; padding: .2em .2em 0; }
-.ui-tabs .ui-tabs-nav li { list-style: none; float: left; position: relative; top: 0; margin: 1px .2em 0 0; border-bottom: 0; padding: 0; white-space: nowrap; }
-.ui-tabs .ui-tabs-nav li a { float: left; padding: .5em 1em; text-decoration: none; }
-.ui-tabs .ui-tabs-nav li.ui-tabs-active { margin-bottom: -1px; padding-bottom: 1px; }
-.ui-tabs .ui-tabs-nav li.ui-tabs-active a, .ui-tabs .ui-tabs-nav li.ui-state-disabled a, .ui-tabs .ui-tabs-nav li.ui-tabs-loading a { cursor: text; }
-.ui-tabs .ui-tabs-nav li a, .ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-active a { cursor: pointer; } /* first selector in group seems obsolete, but required to overcome bug in Opera applying cursor: text overall if defined elsewhere... */
-.ui-tabs .ui-tabs-panel { display: block; border-width: 0; padding: 1em 1.4em; background: none; }
+++ /dev/null
-
-
-/*
-* jQuery UI CSS Framework
-* Copyright (c) 2010 AUTHORS.txt (http://jqueryui.com/about)
-* Dual licensed under the MIT (MIT-LICENSE.txt) and GPL (GPL-LICENSE.txt) licenses.
-* To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=sans-serif&fwDefault=normal&fsDefault=1.0em&cornerRadius=3px&bgColorHeader=ffffff&bgTextureHeader=03_highlight_soft.png&bgImgOpacityHeader=100&borderColorHeader=aed0ea&fcHeader=222222&iconColorHeader=72a7cf&bgColorContent=f2f5f7&bgTextureContent=04_highlight_hard.png&bgImgOpacityContent=100&borderColorContent=cccccc&fcContent=362b36&iconColorContent=72a7cf&bgColorDefault=d7ebf9&bgTextureDefault=04_highlight_hard.png&bgImgOpacityDefault=80&borderColorDefault=aed0ea&fcDefault=2779aa&iconColorDefault=3d80b3&bgColorHover=e4f1fb&bgTextureHover=03_highlight_soft.png&bgImgOpacityHover=100&borderColorHover=74b2e2&fcHover=0070a3&iconColorHover=2694e8&bgColorActive=f0f0f0&bgTextureActive=06_inset_hard.png&bgImgOpacityActive=100&borderColorActive=cccccc&fcActive=000000&iconColorActive=666666&bgColorHighlight=ffef8f&bgTextureHighlight=03_highlight_soft.png&bgImgOpacityHighlight=25&borderColorHighlight=f9dd34&fcHighlight=363636&iconColorHighlight=2e83ff&bgColorError=cd0a0a&bgTextureError=01_flat.png&bgImgOpacityError=15&borderColorError=cd0a0a&fcError=ffffff&iconColorError=ffffff&bgColorOverlay=000000&bgTextureOverlay=21_glow_ball.png&bgImgOpacityOverlay=100&opacityOverlay=50&bgColorShadow=000000&bgTextureShadow=01_flat.png&bgImgOpacityShadow=70&opacityShadow=20&thicknessShadow=7px&offsetTopShadow=-7px&offsetLeftShadow=-7px&cornerRadiusShadow=8px
-*/
-
-
-/* Component containers
-----------------------------------*/
-.ui-widget { font-family: sans-serif; font-size: 0.8em; }
-.ui-widget .ui-widget { font-size: 1em; }
-.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: sans-serif; font-size: 1em; }
-.ui-widget-content { border: 1px solid #cccccc; /* @embed */ background: #f2f5f7 url(images/ui-bg_highlight-hard_100_f2f5f7_1x100.png) 50% top repeat-x; color: #362b36; }
-.ui-widget-header { border-bottom: 1px solid #bbbbbb; line-height: 1em; /* @embed */ background: #ffffff url(images/ui-bg_highlight-soft_100_ffffff_1x100.png) 50% 50% repeat-x; color: #222222; font-weight: bold; }
-
-/* Interaction states
-----------------------------------*/
-.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #aed0ea; /* @embed */ background: #d7ebf9 url(images/ui-bg_highlight-hard_80_d7ebf9_1x100.png) 50% 50% repeat-x; font-weight: normal; color: #2779aa; }
-.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #2779aa; text-decoration: none; }
-.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #74b2e2; /* @embed */ background: #e4f1fb url(images/ui-bg_highlight-soft_100_e4f1fb_1x100.png) 50% 50% repeat-x; font-weight: normal; color: #0070a3; }
-.ui-state-hover a, .ui-state-hover a:hover { color: #0070a3; text-decoration: none; }
-.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #cccccc; background: #f0f0f0 /* @embed */ url(images/ui-bg_inset-hard_100_f0f0f0_1x100.png) 50% 50% repeat-x; font-weight: normal; color: #000000; }
-.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #000000; text-decoration: none; }
-.ui-widget :active { outline: none; }
-
-/* Interaction Cues
-----------------------------------*/
-.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {border: 1px solid #f9dd34; background: #ffef8f /* @embed */ url(images/ui-bg_highlight-soft_25_ffef8f_1x100.png) 50% top repeat-x; color: #363636; }
-.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636; }
-.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a; background: #cd0a0a /* @embed */ url(images/ui-bg_flat_15_cd0a0a_40x100.png) 50% 50% repeat-x; color: #ffffff; }
-.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #ffffff; }
-.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #ffffff; }
-.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; }
-.ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; }
-.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; }
-
-/* Icons
-----------------------------------*/
-
-/* states and images */
-.ui-icon { width: 16px; height: 16px; }
-.ui-icon, .ui-widget-content .ui-icon, .ui-widget-header .ui-icon { /* @embed */ background-image: url(images/ui-icons_72a7cf_256x240.png); }
-.ui-state-default .ui-icon { /* @embed */ background-image: url(images/ui-icons_3d80b3_256x240.png); }
-.ui-state-hover .ui-icon, .ui-state-focus .ui-icon { /* @embed */ background-image: url(images/ui-icons_2694e8_256x240.png); }
-.ui-state-active .ui-icon { /* @embed */ background-image: url(images/ui-icons_666666_256x240.png); }
-.ui-state-highlight .ui-icon { /* @embed */ background-image: url(images/ui-icons_2e83ff_256x240.png); }
-.ui-state-error .ui-icon, .ui-state-error-text .ui-icon { /* @embed */ background-image: url(images/ui-icons_ffffff_256x240.png); }
-
-/* positioning */
-.ui-icon-carat-1-n { background-position: 0 0; }
-.ui-icon-carat-1-ne { background-position: -16px 0; }
-.ui-icon-carat-1-e { background-position: -32px 0; }
-.ui-icon-carat-1-se { background-position: -48px 0; }
-.ui-icon-carat-1-s { background-position: -64px 0; }
-.ui-icon-carat-1-sw { background-position: -80px 0; }
-.ui-icon-carat-1-w { background-position: -96px 0; }
-.ui-icon-carat-1-nw { background-position: -112px 0; }
-.ui-icon-carat-2-n-s { background-position: -128px 0; }
-.ui-icon-carat-2-e-w { background-position: -144px 0; }
-.ui-icon-triangle-1-n { background-position: 0 -16px; }
-.ui-icon-triangle-1-ne { background-position: -16px -16px; }
-.ui-icon-triangle-1-e { background-position: -32px -16px; }
-.ui-icon-triangle-1-se { background-position: -48px -16px; }
-.ui-icon-triangle-1-s { background-position: -64px -16px; }
-.ui-icon-triangle-1-sw { background-position: -80px -16px; }
-.ui-icon-triangle-1-w { background-position: -96px -16px; }
-.ui-icon-triangle-1-nw { background-position: -112px -16px; }
-.ui-icon-triangle-2-n-s { background-position: -128px -16px; }
-.ui-icon-triangle-2-e-w { background-position: -144px -16px; }
-.ui-icon-arrow-1-n { background-position: 0 -32px; }
-.ui-icon-arrow-1-ne { background-position: -16px -32px; }
-.ui-icon-arrow-1-e { background-position: -32px -32px; }
-.ui-icon-arrow-1-se { background-position: -48px -32px; }
-.ui-icon-arrow-1-s { background-position: -64px -32px; }
-.ui-icon-arrow-1-sw { background-position: -80px -32px; }
-.ui-icon-arrow-1-w { background-position: -96px -32px; }
-.ui-icon-arrow-1-nw { background-position: -112px -32px; }
-.ui-icon-arrow-2-n-s { background-position: -128px -32px; }
-.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; }
-.ui-icon-arrow-2-e-w { background-position: -160px -32px; }
-.ui-icon-arrow-2-se-nw { background-position: -176px -32px; }
-.ui-icon-arrowstop-1-n { background-position: -192px -32px; }
-.ui-icon-arrowstop-1-e { background-position: -208px -32px; }
-.ui-icon-arrowstop-1-s { background-position: -224px -32px; }
-.ui-icon-arrowstop-1-w { background-position: -240px -32px; }
-.ui-icon-arrowthick-1-n { background-position: 0 -48px; }
-.ui-icon-arrowthick-1-ne { background-position: -16px -48px; }
-.ui-icon-arrowthick-1-e { background-position: -32px -48px; }
-.ui-icon-arrowthick-1-se { background-position: -48px -48px; }
-.ui-icon-arrowthick-1-s { background-position: -64px -48px; }
-.ui-icon-arrowthick-1-sw { background-position: -80px -48px; }
-.ui-icon-arrowthick-1-w { background-position: -96px -48px; }
-.ui-icon-arrowthick-1-nw { background-position: -112px -48px; }
-.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; }
-.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; }
-.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; }
-.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; }
-.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; }
-.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; }
-.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; }
-.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; }
-.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; }
-.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; }
-.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; }
-.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; }
-.ui-icon-arrowreturn-1-w { background-position: -64px -64px; }
-.ui-icon-arrowreturn-1-n { background-position: -80px -64px; }
-.ui-icon-arrowreturn-1-e { background-position: -96px -64px; }
-.ui-icon-arrowreturn-1-s { background-position: -112px -64px; }
-.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; }
-.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; }
-.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; }
-.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; }
-.ui-icon-arrow-4 { background-position: 0 -80px; }
-.ui-icon-arrow-4-diag { background-position: -16px -80px; }
-.ui-icon-extlink { background-position: -32px -80px; }
-.ui-icon-newwin { background-position: -48px -80px; }
-.ui-icon-refresh { background-position: -64px -80px; }
-.ui-icon-shuffle { background-position: -80px -80px; }
-.ui-icon-transfer-e-w { background-position: -96px -80px; }
-.ui-icon-transferthick-e-w { background-position: -112px -80px; }
-.ui-icon-folder-collapsed { background-position: 0 -96px; }
-.ui-icon-folder-open { background-position: -16px -96px; }
-.ui-icon-document { background-position: -32px -96px; }
-.ui-icon-document-b { background-position: -48px -96px; }
-.ui-icon-note { background-position: -64px -96px; }
-.ui-icon-mail-closed { background-position: -80px -96px; }
-.ui-icon-mail-open { background-position: -96px -96px; }
-.ui-icon-suitcase { background-position: -112px -96px; }
-.ui-icon-comment { background-position: -128px -96px; }
-.ui-icon-person { background-position: -144px -96px; }
-.ui-icon-print { background-position: -160px -96px; }
-.ui-icon-trash { background-position: -176px -96px; }
-.ui-icon-locked { background-position: -192px -96px; }
-.ui-icon-unlocked { background-position: -208px -96px; }
-.ui-icon-bookmark { background-position: -224px -96px; }
-.ui-icon-tag { background-position: -240px -96px; }
-.ui-icon-home { background-position: 0 -112px; }
-.ui-icon-flag { background-position: -16px -112px; }
-.ui-icon-calendar { background-position: -32px -112px; }
-.ui-icon-cart { background-position: -48px -112px; }
-.ui-icon-pencil { background-position: -64px -112px; }
-.ui-icon-clock { background-position: -80px -112px; }
-.ui-icon-disk { background-position: -96px -112px; }
-.ui-icon-calculator { background-position: -112px -112px; }
-.ui-icon-zoomin { background-position: -128px -112px; }
-.ui-icon-zoomout { background-position: -144px -112px; }
-.ui-icon-search { background-position: -160px -112px; }
-.ui-icon-wrench { background-position: -176px -112px; }
-.ui-icon-gear { background-position: -192px -112px; }
-.ui-icon-heart { background-position: -208px -112px; }
-.ui-icon-star { background-position: -224px -112px; }
-.ui-icon-link { background-position: -240px -112px; }
-.ui-icon-cancel { background-position: 0 -128px; }
-.ui-icon-plus { background-position: -16px -128px; }
-.ui-icon-plusthick { background-position: -32px -128px; }
-.ui-icon-minus { background-position: -48px -128px; }
-.ui-icon-minusthick { background-position: -64px -128px; }
-.ui-icon-close { background-position: -80px -128px; }
-.ui-icon-closethick { background-position: -96px -128px; }
-.ui-icon-key { background-position: -112px -128px; }
-.ui-icon-lightbulb { background-position: -128px -128px; }
-.ui-icon-scissors { background-position: -144px -128px; }
-.ui-icon-clipboard { background-position: -160px -128px; }
-.ui-icon-copy { background-position: -176px -128px; }
-.ui-icon-contact { background-position: -192px -128px; }
-.ui-icon-image { background-position: -208px -128px; }
-.ui-icon-video { background-position: -224px -128px; }
-.ui-icon-script { background-position: -240px -128px; }
-.ui-icon-alert { background-position: 0 -144px; }
-.ui-icon-info { background-position: -16px -144px; }
-.ui-icon-notice { background-position: -32px -144px; }
-.ui-icon-help { background-position: -48px -144px; }
-.ui-icon-check { background-position: -64px -144px; }
-.ui-icon-bullet { background-position: -80px -144px; }
-.ui-icon-radio-off { background-position: -96px -144px; }
-.ui-icon-radio-on { background-position: -112px -144px; }
-.ui-icon-pin-w { background-position: -128px -144px; }
-.ui-icon-pin-s { background-position: -144px -144px; }
-.ui-icon-play { background-position: 0 -160px; }
-.ui-icon-pause { background-position: -16px -160px; }
-.ui-icon-seek-next { background-position: -32px -160px; }
-.ui-icon-seek-prev { background-position: -48px -160px; }
-.ui-icon-seek-end { background-position: -64px -160px; }
-.ui-icon-seek-start { background-position: -80px -160px; }
-/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */
-.ui-icon-seek-first { background-position: -80px -160px; }
-.ui-icon-stop { background-position: -96px -160px; }
-.ui-icon-eject { background-position: -112px -160px; }
-.ui-icon-volume-off { background-position: -128px -160px; }
-.ui-icon-volume-on { background-position: -144px -160px; }
-.ui-icon-power { background-position: 0 -176px; }
-.ui-icon-signal-diag { background-position: -16px -176px; }
-.ui-icon-signal { background-position: -32px -176px; }
-.ui-icon-battery-0 { background-position: -48px -176px; }
-.ui-icon-battery-1 { background-position: -64px -176px; }
-.ui-icon-battery-2 { background-position: -80px -176px; }
-.ui-icon-battery-3 { background-position: -96px -176px; }
-.ui-icon-circle-plus { background-position: 0 -192px; }
-.ui-icon-circle-minus { background-position: -16px -192px; }
-.ui-icon-circle-close { background-position: -32px -192px; }
-.ui-icon-circle-triangle-e { background-position: -48px -192px; }
-.ui-icon-circle-triangle-s { background-position: -64px -192px; }
-.ui-icon-circle-triangle-w { background-position: -80px -192px; }
-.ui-icon-circle-triangle-n { background-position: -96px -192px; }
-.ui-icon-circle-arrow-e { background-position: -112px -192px; }
-.ui-icon-circle-arrow-s { background-position: -128px -192px; }
-.ui-icon-circle-arrow-w { background-position: -144px -192px; }
-.ui-icon-circle-arrow-n { background-position: -160px -192px; }
-.ui-icon-circle-zoomin { background-position: -176px -192px; }
-.ui-icon-circle-zoomout { background-position: -192px -192px; }
-.ui-icon-circle-check { background-position: -208px -192px; }
-.ui-icon-circlesmall-plus { background-position: 0 -208px; }
-.ui-icon-circlesmall-minus { background-position: -16px -208px; }
-.ui-icon-circlesmall-close { background-position: -32px -208px; }
-.ui-icon-squaresmall-plus { background-position: -48px -208px; }
-.ui-icon-squaresmall-minus { background-position: -64px -208px; }
-.ui-icon-squaresmall-close { background-position: -80px -208px; }
-.ui-icon-grip-dotted-vertical { background-position: 0 -224px; }
-.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; }
-.ui-icon-grip-solid-vertical { background-position: -32px -224px; }
-.ui-icon-grip-solid-horizontal { background-position: -48px -224px; }
-.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; }
-.ui-icon-grip-diagonal-se { background-position: -80px -224px; }
-
-
-/* Misc visuals
-----------------------------------*/
-
-/* Corner radius */
-.ui-corner-tl { border-top-left-radius: 0; }
-.ui-corner-tr { border-top-right-radius: 0; }
-.ui-corner-bl { border-bottom-left-radius: 0; }
-.ui-corner-br { border-bottom-right-radius: 0; }
-.ui-corner-top { border-top-left-radius: 0; border-top-right-radius: 0; }
-.ui-corner-bottom { border-bottom-left-radius: 0; border-bottom-right-radius: 0; }
-.ui-corner-right { border-top-right-radius: 0; border-bottom-right-radius: 0; }
-.ui-corner-left { border-top-left-radius: 0; border-bottom-left-radius: 0; }
-.ui-corner-all { border-radius: 0; }
-
-/* Overlays */
-.ui-widget-overlay { background: #000000; opacity: .75;filter:Alpha(Opacity=75); }
-.ui-widget-shadow { margin: -7px 0 0 -7px; padding: 7px; /* @embed */ background: #000000 url(images/ui-bg_flat_70_000000_40x100.png) 50% 50% repeat-x; opacity: .20;filter:Alpha(Opacity=20); border-radius: 8px; }
+++ /dev/null
-@import "../variables";
-
-/* mediawiki.notification */
-
-// This wrapper class is needed to ensure these rules have larger CSS
-// selector specificity than default styles
-.mediawiki {
- .mw-notification-area {
- font-size: 0.8em;
- }
-
- .mw-notification-area-layout {
- top: 7em;
- }
-
- .mw-notification {
- background-color: #fff;
- background-color: rgba(255, 255, 255, 0.93);
- padding: 0.75em 1.5em;
- border: solid 1px @content-border-color;
- border-radius: 0.75em;
- box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.125);
- }
-}
+++ /dev/null
-/**
- * Adjusts for decreased margin-bottom for h2 elements inside #content div
- * introduced in March / April 2014 typography update.
- */
-table.mw-specialpages-table {
- margin-top: 0;
-}
+++ /dev/null
-@import "mediawiki.mixins";
-@import "../variables";
-
-/**
- * The following code is highly modified from monobook. It would be nice if the
- * preftoc id was more human readable like preferences-toc for instance,
- * howerver this would require backporting the other skins.
- */
-
-#preftoc {
- /* Tabs */
- width: 100%;
- float: left;
- clear: both;
- margin: 0 !important;
- padding: 0 !important;
- .background-image('../images/preferences/break.png');
- background-position: bottom left;
- background-repeat: no-repeat;
-
- li {
- /* Tab */
- float: left;
- margin: 0;
- padding: 0;
- padding-right: 1px;
- height: 2.25em;
- white-space: nowrap;
- list-style-type: none;
- list-style-image: none;
- .background-image('../images/preferences/break.png');
- background-position: bottom right;
- background-repeat: no-repeat;
-
- /* Sadly, IE6 won't understand this */
- &:first-child {
- margin-left: 1px;
- }
-
- &.selected {
- a {
- .background-image('../images/preferences/fade.png');
- background-position: bottom;
- background-repeat: repeat-x;
- color: #333;
- text-decoration: none;
- }
- }
- }
-
- a,
- a:active {
- display: inline-block;
- position: relative;
- color: @menu-link-color;
- padding: 0.5em;
- text-decoration: none;
- background-image: none;
- font-size: 0.9em;
- }
-
- a:hover,
- a:focus {
- text-decoration: underline;
- }
-}
-
-#preferences {
- float: left;
- width: 100%;
- margin: 0;
- margin-top: -2px;
- clear: both;
- border: solid 1px #ccc;
- background-color: #fafafa;
-
- fieldset {
- border: none;
- border-top: solid 1px #ccc;
-
- &.prefsection {
- border: none;
- padding: 0;
- margin: 1em;
-
- legend.mainLegend {
- display: none;
- }
- }
- }
-
- legend {
- color: #666;
- }
-
- td {
- padding-left: 0.5em;
- padding-right: 0.5em;
- }
-
- div.mw-prefs-buttons {
- padding: 1em;
-
- input {
- margin-right: 0.25em;
- }
- }
-}
-
-.htmlform-tip {
- font-size: x-small;
- padding: .2em 2em;
- color: #666;
-}
+++ /dev/null
-@html-font-size: 100%;
-
-// Page content
-// FIXME: Use global variable since Echo and CentralNotice use this variable
-@content-border-color: #a7d7f9;
-// FIXME: Find an open font that works with this stack and is readable by Windows users
-@content-font-family: sans-serif;
-@content-font-color: #252525;
-@content-font-size: 0.875em;
-@content-line-height: 1.6;
-@content-padding: 1em;
-@content-heading-font-size: 1.8em;
-@content-heading-font-family: "Linux Libertine", Georgia, Times, serif;
-@body-background-color: #fff;
-@heading-line-height: 1.3;
-
-// Navigation
-@menu-background-color: #f6f6f6;
-
-// Common menu
-@menu-link-color: #0645ad;
-
-// Main menu
-@menu-main-font-size: inherit;
-
-@menu-main-heading-font-size: 0.75em;
-@menu-main-heading-padding: 0.25em 0 0.25em 0.25em;
-@menu-main-heading-color: #4d4d4d;
-
-@menu-main-body-font-size: 0.75em;
-@menu-main-body-link-color: #0645ad;
-@menu-main-body-link-visited-color: #0b0080;
-@menu-main-body-margin: 0 0 0 1.25em;
-@menu-main-body-padding: 0;
-
-@menu-main-logo-left: 0.5em;
-
-// Personal menu
-@menu-personal-font-size: 0.75em;
+++ /dev/null
-/**
- * Vector-specific scripts
- */
-jQuery( function ( $ ) {
- /**
- * Focus search input at the very end
- */
- $( '#searchInput' ).attr( 'tabindex', $( document ).lastTabIndex() + 1 );
-
- /**
- * Dropdown menu accessibility
- */
- $( 'div.vectorMenu' ).each( function () {
- var $el = $( this );
- $el.find( '> h3 > a' ).parent()
- .attr( 'tabindex', '0' )
- // For accessibility, show the menu when the h3 is clicked (bug 24298/46486)
- .on( 'click keypress', function ( e ) {
- if ( e.type === 'click' || e.which === 13 ) {
- $el.toggleClass( 'menuForceShow' );
- e.preventDefault();
- }
- } )
- // When the heading has focus, also set a class that will change the arrow icon
- .focus( function () {
- $el.find( '> a' ).addClass( 'vectorMenuFocus' );
- } )
- .blur( function () {
- $el.find( '> a' ).removeClass( 'vectorMenuFocus' );
- } )
- .find( '> a:first' )
- // As the h3 can already be focused there's no need for the link to be focusable
- .attr( 'tabindex', '-1' );
- } );
-
- /**
- * Sidebar
- */
- $( '#mw-panel > .portal:first' ).addClass( 'first' );
-
- /**
- * Collapsible tabs
- */
- var $cactions = $( '#p-cactions' ),
- $tabContainer = $( '#p-views ul' ),
- originalDropdownWidth = $cactions.width();
-
- // Bind callback functions to animate our drop down menu in and out
- // and then call the collapsibleTabs function on the menu
- $tabContainer
- .bind( 'beforeTabCollapse', function () {
- // If the dropdown was hidden, show it
- if ( $cactions.hasClass( 'emptyPortlet' ) ) {
- $cactions
- .removeClass( 'emptyPortlet' )
- .find( 'h3' )
- .css( 'width', '1px' ).animate( { 'width': originalDropdownWidth }, 'normal' );
- }
- } )
- .bind( 'beforeTabExpand', function () {
- // If we're removing the last child node right now, hide the dropdown
- if ( $cactions.find( 'li' ).length === 1 ) {
- $cactions.find( 'h3' ).animate( { 'width': '1px' }, 'normal', function () {
- $( this ).attr( 'style', '' )
- .parent().addClass( 'emptyPortlet' );
- });
- }
- } )
- .collapsibleTabs( {
- expandCondition: function ( eleWidth ) {
- // (This looks a bit awkward because we're doing expensive queries as late as possible.)
-
- var distance = $.collapsibleTabs.calculateTabDistance();
- // If there are at least eleWidth + 1 pixels of free space, expand.
- // We add 1 because .width() will truncate fractional values but .offset() will not.
- if ( distance >= eleWidth + 1 ) {
- return true;
- } else {
- // Maybe we can still expand? Account for the width of the "Actions" dropdown if the
- // expansion would hide it.
- if ( $cactions.find( 'li' ).length === 1 ) {
- return distance >= eleWidth + 1 - originalDropdownWidth;
- } else {
- return false;
- }
- }
- },
- collapseCondition: function () {
- // (This looks a bit awkward because we're doing expensive queries as late as possible.)
- // TODO The dropdown itself should probably "fold" to just the down-arrow (hiding the text)
- // if it can't fit on the line?
-
- // If there's an overlap, collapse.
- if ( $.collapsibleTabs.calculateTabDistance() < 0 ) {
- // But only if the width of the tab to collapse is smaller than the width of the dropdown
- // we would have to insert. An example language where this happens is Lithuanian (lt).
- if ( $cactions.hasClass( 'emptyPortlet' ) ) {
- return $tabContainer.children( 'li.collapsible:last' ).width() > originalDropdownWidth;
- } else {
- return true;
- }
- } else {
- return false;
- }
- }
- } );
-} );
+++ /dev/null
-/**
- * IE fixes javascript loaded by wikibits.js for IE <= 6.0
- */
-/*global isMSIE55:true, doneIETransform:true, doneIEAlphaFix:true */
-/*global hookit:true, fixalpha:true */
-( function ( mw, $ ) {
-
-var expandedURLs, hasClass;
-
-// Also returns true for IE6, 7, 8, 9 and 10. createPopup is removed in IE11.
-// Good thing this is only loaded for IE <= 6 by wikibits.
-// Might as well set it to true.
-isMSIE55 = ( window.showModalDialog && window.clipboardData && window.createPopup );
-doneIETransform = false;
-doneIEAlphaFix = false;
-
-hookit = function () {
- if ( !doneIETransform && document.getElementById && document.getElementById( 'bodyContent' ) ) {
- doneIETransform = true;
- fixalpha();
- }
-};
-
-if ( document.attachEvent ) {
- document.attachEvent( 'onreadystatechange', hookit );
-}
-
-// png alpha transparency fixes
-fixalpha = function ( logoId ) {
- // bg
- if ( isMSIE55 && !doneIEAlphaFix ) {
- var bg, imageUrl, linkFix, logoa, logospan, plogo;
- plogo = document.getElementById( logoId || 'p-logo' );
- if ( !plogo ) {
- return;
- }
-
- logoa = plogo.getElementsByTagName('a')[0];
- if ( !logoa ) {
- return;
- }
-
- bg = logoa.currentStyle.backgroundImage;
- imageUrl = bg.substring( 5, bg.length - 2 );
-
- doneIEAlphaFix = true;
-
- if ( imageUrl.substr( imageUrl.length - 4 ).toLowerCase() === '.png' ) {
- logospan = logoa.appendChild( document.createElement( 'span' ) );
-
- logoa.style.backgroundImage = 'none';
- logospan.style.filter = 'progid:DXImageTransform.Microsoft.AlphaImageLoader(src=' + imageUrl + ')';
- logospan.style.height = '100%';
- logospan.style.position = 'absolute';
- logospan.style.width = logoa.currentStyle.width;
- logospan.style.cursor = 'hand';
- // Center image with hack for IE5.5
- if ( document.documentElement.dir === 'rtl' ) {
- logospan.style.right = '50%';
- logospan.style.setExpression( 'marginRight', '"-" + (this.offsetWidth / 2) + "px"' );
- } else {
- logospan.style.left = '50%';
- logospan.style.setExpression( 'marginLeft', '"-" + (this.offsetWidth / 2) + "px"' );
- }
- logospan.style.top = '50%';
- logospan.style.setExpression( 'marginTop', '"-" + (this.offsetHeight / 2) + "px"' );
-
- linkFix = logoa.appendChild( logoa.cloneNode() );
- linkFix.style.position = 'absolute';
- linkFix.style.height = '100%';
- linkFix.style.width = '100%';
- }
- }
-};
-
-if ( isMSIE55 ) {
- // ondomready
- $( fixalpha );
-}
-
-// Expand links for printing
-hasClass = function ( classText, classWanted ) {
- var i = 0, classArr = classText.split(/\s/);
- for ( i = 0; i < classArr.length; i++ ) {
- if ( classArr[i].toLowerCase() === classWanted.toLowerCase() ) {
- return true;
- }
- }
- return false;
-};
-
-window.onbeforeprint = function () {
- var allLinks, contentEl, expandedLink, expandedText, i;
-
- expandedURLs = [];
- contentEl = document.getElementById( 'content' );
-
- if ( contentEl ) {
- allLinks = contentEl.getElementsByTagName( 'a' );
-
- for ( i = 0; i < allLinks.length; i++ ) {
- if ( hasClass( allLinks[i].className, 'external' ) && !hasClass( allLinks[i].className, 'free' ) ) {
- expandedLink = document.createElement( 'span' );
- expandedText = document.createTextNode( ' (' + allLinks[i].href + ')' );
- expandedLink.appendChild( expandedText );
- allLinks[i].parentNode.insertBefore( expandedLink, allLinks[i].nextSibling );
- expandedURLs[i] = expandedLink;
- }
- }
- }
-};
-
-window.onafterprint = function () {
- for ( var i = 0; i < expandedURLs.length; i++ ) {
- if ( expandedURLs[i] ) {
- expandedURLs[i].removeNode( true );
- }
- }
-};
-
-}( mediaWiki, jQuery ) );
var msg,
win = window,
ua = navigator.userAgent.toLowerCase(),
- isIE6 = ( /msie ([0-9]{1,}[\.0-9]{0,})/.exec( ua ) && parseFloat( RegExp.$1 ) <= 6.0 ),
onloadFuncts = [];
/**
return l;
};
-if ( isIE6 ) {
- win.importScriptURI( mw.config.get( 'stylepath' ) + '/common/IEFixes.js' );
-}
-
}( mediaWiki, jQuery ) );
public function testInLanguageThrows() {
wfMessage( 'foo' )->inLanguage( 123 );
}
+
+ public function keyProvider() {
+ return array(
+ 'string' => array(
+ 'key' => 'mainpage',
+ 'expected' => array( 'mainpage' ),
+ ),
+ 'single' => array(
+ 'key' => array( 'mainpage' ),
+ 'expected' => array( 'mainpage' ),
+ ),
+ 'multi' => array(
+ 'key' => array( 'mainpage-foo', 'mainpage-bar', 'mainpage' ),
+ 'expected' => array( 'mainpage-foo', 'mainpage-bar', 'mainpage' ),
+ ),
+ 'empty' => array(
+ 'key' => array(),
+ 'expected' => null,
+ 'exception' => 'InvalidArgumentException',
+ ),
+ 'null' => array(
+ 'key' => null,
+ 'expected' => null,
+ 'exception' => 'InvalidArgumentException',
+ ),
+ 'bad type' => array(
+ 'key' => 17,
+ 'expected' => null,
+ 'exception' => 'InvalidArgumentException',
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider keyProvider()
+ *
+ * @covers Message::getKey
+ */
+ public function testGetKey( $key, $expected, $exception = null ) {
+ if ( $exception ) {
+ $this->setExpectedException( $exception );
+ }
+
+ $msg = new Message( $key );
+ $this->assertEquals( $expected, $msg->getKeysToTry() );
+ $this->assertEquals( count( $expected ) > 1, $msg->isMultiKey() );
+ $this->assertContains( $msg->getKey(), $expected );
+ }
}
/**
* @dataProvider providerImproveTypeFromExtension
* @param $ext String File extension (no leading dot)
- * @param $oldMime String Initially detected mime
- * @param $expectedMime String Mime type after taking extension into account
+ * @param $oldMime String Initially detected MIME
+ * @param $expectedMime String MIME type after taking extension into account
*/
function testImproveTypeFromExtension( $ext, $oldMime, $expectedMime ) {
$actualMime = $this->mimeMagic->improveTypeFromExtension( $oldMime, $ext );
// Load module script only
array(
array( 'test.foo', ResourceLoaderModule::TYPE_SCRIPTS ),
- '<script src="http://127.0.0.1:8080/w/load.php?debug=false&lang=en&modules=test.foo&only=scripts&skin=vector&*"></script>
+ '<script src="http://127.0.0.1:8080/w/load.php?debug=false&lang=en&modules=test.foo&only=scripts&skin=fallback&*"></script>
'
),
// Load module styles only
// This also tests the order the modules are put into the url
array(
array( array( 'test.baz', 'test.foo', 'test.bar' ), ResourceLoaderModule::TYPE_STYLES ),
- '<link rel=stylesheet href="http://127.0.0.1:8080/w/load.php?debug=false&lang=en&modules=test.bar%2Cbaz%2Cfoo&only=styles&skin=vector&*">
+ '<link rel=stylesheet href="http://127.0.0.1:8080/w/load.php?debug=false&lang=en&modules=test.bar%2Cbaz%2Cfoo&only=styles&skin=fallback&*">
'
),
// Load private module (combined)
// Load module script with with ESI
array(
array( 'test.foo', ResourceLoaderModule::TYPE_SCRIPTS, true ),
- '<script><esi:include src="http://127.0.0.1:8080/w/load.php?debug=false&lang=en&modules=test.foo&only=scripts&skin=vector&*" /></script>
+ '<script><esi:include src="http://127.0.0.1:8080/w/load.php?debug=false&lang=en&modules=test.foo&only=scripts&skin=fallback&*" /></script>
'
),
// Load module styles with with ESI
array(
array( 'test.foo', ResourceLoaderModule::TYPE_STYLES, true ),
- '<style><esi:include src="http://127.0.0.1:8080/w/load.php?debug=false&lang=en&modules=test.foo&only=styles&skin=vector&*" /></style>
+ '<style><esi:include src="http://127.0.0.1:8080/w/load.php?debug=false&lang=en&modules=test.foo&only=styles&skin=fallback&*" /></style>
',
),
);
$this->setExpectedException( 'UserNotLoggedIn', $expected );
- if ( $reason === 'blank' && $title === 'blank' ) {
- $specialPage->requireLogin();
- } else {
- $specialPage->requireLogin( $reason, $title );
- }
+ // $specialPage->requireLogin( [ $reason [, $title ] ] )
+ call_user_func_array(
+ array( $specialPage, 'requireLogin' ),
+ array_filter( array( $reason, $title ) )
+ );
}
public function requireLoginAnonProvider() {
$lang = 'en';
- $msg = wfMessage( 'loginreqlink' )->inLanguage( $lang )->escaped();
- $loginLink = '<a href="/index.php?title=Special:UserLogin&returnto=Special%3AWatchlist"'
- . ' title="Special:UserLogin">' . $msg . '</a>';
-
- $expected1 = wfMessage( 'exception-nologin-text-manual' )
- ->params( $loginLink )->inLanguage( $lang )->text();
-
+ $expected1 = wfMessage( 'exception-nologin-text' )->inLanguage( $lang )->text();
$expected2 = wfMessage( 'about' )->inLanguage( $lang )->text();
return array(
array( $expected1, null, null ),
array( $expected2, 'about', null ),
- array( $expected2, wfMessage( 'about' ), null ),
array( $expected2, 'about', 'about' ),
- array( $expected2, 'about', wfMessage( 'about' ) ),
- array( $expected1, 'blank', 'blank' )
);
}
--- /dev/null
+<?php
+
+/**
+ * @covers ApiModuleManager
+ *
+ * @group API
+ * @group Database
+ * @group medium
+ */
+class ApiModuleManagerTest extends MediaWikiTestCase {
+
+ private function getModuleManager() {
+ $request = new FauxRequest();
+ $main = new ApiMain( $request );
+ return new ApiModuleManager( $main );
+ }
+
+ public function newApiLogin( $main, $action ) {
+ return new ApiLogin( $main, $action );
+ }
+
+ public function addModuleProvider() {
+ return array(
+ 'plain class' => array(
+ 'login',
+ 'action',
+ 'ApiLogin',
+ null,
+ ),
+
+ 'with factory' => array(
+ 'login',
+ 'action',
+ 'ApiLogin',
+ array( $this, 'newApiLogin' ),
+ ),
+
+ 'with closure' => array(
+ 'logout',
+ 'action',
+ 'ApiLogout',
+ function( ApiMain $main, $action ) {
+ return new ApiLogout( $main, $action );
+ },
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider addModuleProvider
+ */
+ public function testAddModule( $name, $group, $class, $factory = null ) {
+ $moduleManager = $this->getModuleManager();
+ $moduleManager->addModule( $name, $group, $class, $factory );
+
+ $this->assertTrue( $moduleManager->isDefined( $name, $group ), 'isDefined' );
+ $this->assertNotNull( $moduleManager->getModule( $name, $group, true ), 'getModule' );
+ }
+
+ public function addModulesProvider() {
+ return array(
+ 'empty' => array(
+ array(),
+ 'action',
+ ),
+
+ 'simple' => array(
+ array(
+ 'login' => 'ApiLogin',
+ 'logout' => 'ApiLogout',
+ ),
+ 'action',
+ ),
+
+ 'with factories' => array(
+ array(
+ 'login' => array(
+ 'class' => 'ApiLogin',
+ 'factory' => array( $this, 'newApiLogin' ),
+ ),
+ 'logout' => array(
+ 'class' => 'ApiLogout',
+ 'factory' => function( ApiMain $main, $action ) {
+ return new ApiLogout( $main, $action );
+ },
+ ),
+ ),
+ 'action',
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider addModulesProvider
+ */
+ public function testAddModules( array $modules, $group ) {
+ $moduleManager = $this->getModuleManager();
+ $moduleManager->addModules( $modules, $group );
+
+ foreach ( array_keys( $modules ) as $name ) {
+ $this->assertTrue( $moduleManager->isDefined( $name, $group ), 'isDefined' );
+ $this->assertNotNull( $moduleManager->getModule( $name, $group, true ), 'getModule' );
+ }
+ }
+
+ public function getModuleProvider() {
+ $modules = array(
+ 'feedrecentchanges' => 'ApiFeedRecentChanges',
+ 'feedcontributions' => array( 'class' => 'ApiFeedContributions' ),
+ 'login' => array(
+ 'class' => 'ApiLogin',
+ 'factory' => array( $this, 'newApiLogin' ),
+ ),
+ 'logout' => array(
+ 'class' => 'ApiLogout',
+ 'factory' => function( ApiMain $main, $action ) {
+ return new ApiLogout( $main, $action );
+ },
+ ),
+ );
+
+ return array(
+ 'legacy entry' => array(
+ $modules,
+ 'feedrecentchanges',
+ 'ApiFeedRecentChanges',
+ ),
+
+ 'just a class' => array(
+ $modules,
+ 'feedcontributions',
+ 'ApiFeedContributions',
+ ),
+
+ 'with factory' => array(
+ $modules,
+ 'login',
+ 'ApiLogin',
+ ),
+
+ 'with closure' => array(
+ $modules,
+ 'logout',
+ 'ApiLogout',
+ ),
+ );
+ }
+
+ /**
+ * @dataProvider getModuleProvider
+ */
+ public function testGetModule( $modules, $name, $expectedClass ) {
+ $moduleManager = $this->getModuleManager();
+ $moduleManager->addModules( $modules, 'test' );
+
+ // should return the right module
+ $module1 = $moduleManager->getModule( $name, null, false );
+ $this->assertInstanceOf( $expectedClass, $module1 );
+
+ // should pass group check (with caching disabled)
+ $module2 = $moduleManager->getModule( $name, 'test', true );
+ $this->assertNotNull( $module2 );
+
+ // should use cached instance
+ $module3 = $moduleManager->getModule( $name, null, false );
+ $this->assertSame( $module1, $module3 );
+
+ // should not use cached instance if caching is disabled
+ $module4 = $moduleManager->getModule( $name, null, true );
+ $this->assertNotSame( $module1, $module4 );
+ }
+
+ public function testGetModule_null() {
+ $modules = array(
+ 'login' => 'ApiLogin',
+ 'logout' => 'ApiLogout',
+ );
+
+ $moduleManager = $this->getModuleManager();
+ $moduleManager->addModules( $modules, 'test' );
+
+ $this->assertNull( $moduleManager->getModule( 'quux' ), 'unknown name' );
+ $this->assertNull( $moduleManager->getModule( 'login', 'bla' ), 'wrong group' );
+ }
+
+ public function testGetNames() {
+ $fooModules = array(
+ 'login' => 'ApiLogin',
+ 'logout' => 'ApiLogout',
+ );
+
+ $barModules = array(
+ 'feedcontributions' => array( 'class' => 'ApiFeedContributions' ),
+ 'feedrecentchanges' => array( 'class' => 'ApiFeedRecentChanges' ),
+ );
+
+ $moduleManager = $this->getModuleManager();
+ $moduleManager->addModules( $fooModules, 'foo' );
+ $moduleManager->addModules( $barModules, 'bar' );
+
+ $fooNames = $moduleManager->getNames( 'foo' );
+ $this->assertArrayEquals( array_keys( $fooModules ), $fooNames );
+
+ $allNames = $moduleManager->getNames();
+ $allModules = array_merge( $fooModules, $barModules );
+ $this->assertArrayEquals( array_keys( $allModules ), $allNames );
+ }
+
+ public function testGetNamesWithClasses() {
+ $fooModules = array(
+ 'login' => 'ApiLogin',
+ 'logout' => 'ApiLogout',
+ );
+
+ $barModules = array(
+ 'feedcontributions' => array( 'class' => 'ApiFeedContributions' ),
+ 'feedrecentchanges' => array( 'class' => 'ApiFeedRecentChanges' ),
+ );
+
+ $moduleManager = $this->getModuleManager();
+ $moduleManager->addModules( $fooModules, 'foo' );
+ $moduleManager->addModules( $barModules, 'bar' );
+
+ $fooNamesWithClasses = $moduleManager->getNamesWithClasses( 'foo' );
+ $this->assertArrayEquals( $fooModules, $fooNamesWithClasses );
+
+ $allNamesWithClasses = $moduleManager->getNamesWithClasses();
+ $allModules = array_merge( $fooModules, array(
+ 'feedcontributions' => 'ApiFeedContributions',
+ 'feedrecentchanges' => 'ApiFeedRecentChanges',
+ ) );
+ $this->assertArrayEquals( $allModules, $allNamesWithClasses );
+ }
+
+ public function testGetModuleGroup() {
+ $fooModules = array(
+ 'login' => 'ApiLogin',
+ 'logout' => 'ApiLogout',
+ );
+
+ $barModules = array(
+ 'feedcontributions' => array( 'class' => 'ApiFeedContributions' ),
+ 'feedrecentchanges' => array( 'class' => 'ApiFeedRecentChanges' ),
+ );
+
+ $moduleManager = $this->getModuleManager();
+ $moduleManager->addModules( $fooModules, 'foo' );
+ $moduleManager->addModules( $barModules, 'bar' );
+
+ $this->assertEquals( 'foo', $moduleManager->getModuleGroup( 'login' ) );
+ $this->assertEquals( 'bar', $moduleManager->getModuleGroup( 'feedrecentchanges' ) );
+ $this->assertNull( $moduleManager->getModuleGroup( 'quux' ) );
+ }
+
+ public function testGetGroups() {
+ $fooModules = array(
+ 'login' => 'ApiLogin',
+ 'logout' => 'ApiLogout',
+ );
+
+ $barModules = array(
+ 'feedcontributions' => array( 'class' => 'ApiFeedContributions' ),
+ 'feedrecentchanges' => array( 'class' => 'ApiFeedRecentChanges' ),
+ );
+
+ $moduleManager = $this->getModuleManager();
+ $moduleManager->addModules( $fooModules, 'foo' );
+ $moduleManager->addModules( $barModules, 'bar' );
+
+ $groups = $moduleManager->getGroups();
+ $this->assertArrayEquals( array( 'foo', 'bar' ), $groups );
+ }
+
+}
*
* @param string $fieldName name this would have in the upload form
* @param string $fileName name to title this
- * @param string $type mime type
+ * @param string $type MIME type
* @param string $filePath path where to find file contents
*
* @throws Exception
public function testPrefixes() {
$main = new ApiMain( new FauxRequest() );
$query = new ApiQuery( $main, 'foo', 'bar' );
- $modules = $query->getModuleManager()->getNamesWithClasses();
+ $moduleManager = $query->getModuleManager();
+
+ $modules = $moduleManager->getNames();
$prefixes = array();
- foreach ( $modules as $name => $class ) {
- /** @var ApiQueryBase $module */
- $module = new $class( $query, $name );
+ foreach ( $modules as $name ) {
+ $module = $moduleManager->getModule( $name );
+ $class = get_class( $module );
+
$prefix = $module->getModulePrefix();
if ( isset( $prefixes[$prefix] ) ) {
$this->fail( "Module prefix '{$prefix}' is shared between {$class} and {$prefixes[$prefix]}" );
/**
* @dataProvider providerMimeFiltering
* @param $par String subpage for special page
- * @param $major String Major mime type we expect to look for
- * @param $minor String Minor mime type we expect to look for
+ * @param $major String Major MIME type we expect to look for
+ * @param $minor String Minor MIME type we expect to look for
*/
function testMimeFiltering( $par, $major, $minor ) {
$this->page->run( $par );
--- /dev/null
+<?php
+/**
+ * Based on LanguageMlTest
+ * @author Joel Sahleen
+ * @copyright Copyright © 2014, Joel Sahleen
+ * @file
+ */
+
+/** Tests for MediaWiki languages/LanguageArq.php */
+class LanguageArqTest extends LanguageClassesTestCase {
+ /**
+ * @dataProvider provideNumber
+ * @covers Language::formatNum
+ */
+ public function testFormatNum( $result, $value ) {
+ $this->assertEquals( $result, $this->getLang()->formatNum( $value ) );
+ }
+
+ public static function provideNumber() {
+ return array(
+ array( '1.234.567', '1234567'),
+ array( '-12,89', -12.89 ),
+ );
+ }
+
+}
'</table>'
);
$table.tablesorter();
- assert.equal( 0,
- $table.find( '#A2' ).prop( 'headerIndex' ),
- 'A2 should be a sort header'
+ assert.equal( $table.find( '#A2' ).prop( 'headerIndex' ),
+ 0,
+ 'A2 should not be a sort header'
);
- assert.equal( 1, // should be 2
- $table.find( '#C1' ).prop( 'headerIndex' ),
+ assert.equal( $table.find( '#C1' ).prop( 'headerIndex' ),
+ 1,
'C1 should be a sort header, but will sort the wrong column'
);
} );
'</tbody></table>' );
$table.tablesorter();
- assert.equal( 2, $table.find( 'tr:eq(1) th:eq(1)').prop('headerIndex'), 'Incorrect index of sort header' );
+ assert.equal( $table.find( 'tr:eq(1) th:eq(1)').prop('headerIndex'),
+ 2,
+ 'Incorrect index of sort header' );
}
);
'Mozilla/5.0 (Macintosh; I; Intel Mac OS X 10_6_7; ru-ru) AppleWebKit/534.31+ (KHTML, like Gecko) Version/5.0.5 Safari/533.21.1',
// Opera 11+
'Opera/9.80 (Windows NT 6.1; U; ru) Presto/2.8.131 Version/11.10',
- // Internet Explorer 6+
- 'Mozilla/5.0 (compatible; MSIE 6.0; Windows NT 5.1)',
+ // Internet Explorer 7+
'Mozilla/5.0 (compatible; MSIE 7.0; Windows NT 6.0; en-US)',
'Mozilla/5.0 (compatible; MSIE 8.0; Windows NT 5.2; Trident/4.0; Media Center PC 4.0; SLCC1; .NET CLR 3.0.04320)',
'Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 7.1; Trident/5.0)',
'Mozilla/5.0 (Linux; U; Android 2.1; en-us; Nexus One Build/ERD62) AppleWebKit/530.17 (KHTML, like Gecko) Version/4.0 Mobile Safari/530.17'
],
// Supported: Uncompatible, serve basic content
- gradeB: [
- // Internet Explorer < 6
+ gradeC: [
+ // Internet Explorer < 7
'Mozilla/2.0 (compatible; MSIE 3.03; Windows 3.1)',
'Mozilla/4.0 (compatible; MSIE 4.01; Windows 95)',
'Mozilla/4.0 (compatible; MSIE 5.0; Windows 98;)',
'Mozilla/4.0 (compatible; MSIE 5.5; Windows NT)',
+ 'Mozilla/5.0 (compatible; MSIE 6.0; Windows NT 5.1)',
// Firefox < 3.6
'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.0.2) Gecko/20060308 Firefox/1.5.0.2',
'Mozilla/5.0 (X11; U; Linux i686; nl; rv:1.8.1.1) Gecko/20070311 Firefox/2.0.0.1',
);
} );
- QUnit.test( 'isCompatible( Grade B )', testcases.gradeB.length, function ( assert ) {
- $.each( testcases.gradeB, function ( i, ua ) {
+ QUnit.test( 'isCompatible( Grade C )', testcases.gradeC.length, function ( assert ) {
+ $.each( testcases.gradeC, function ( i, ua ) {
assert.strictEqual( isCompatible( ua ), false, ua );
}
);
define( 'MW_NO_OUTPUT_COMPRESSION', 1 );
require __DIR__ . '/includes/WebStart.php';
-// Don't use fancy mime detection, just check the file extension for jpg/gif/png
+// Don't use fancy MIME detection, just check the file extension for jpg/gif/png
$wgTrivialMimeDetection = true;
if ( defined( 'THUMB_HANDLER' ) ) {
return $params; // valid thumbnail URL (via extension or config)
}
- // FIXME: Files in the temp zone don't set a mime type, which means
+ // FIXME: Files in the temp zone don't set a MIME type, which means
// they don't have a handler. Which means we can't parse the param
// string. However, not a big issue as what good is a param string
// if you have no handler to make use of the param string and