User:Js/urldecoder.js: Difference between revisions

Content deleted Content added
and support protocol relative
Maintenance: mw:RL/MGU - Updated deprecated module name
 
(7 intermediate revisions by 3 users not shown)
Line 1:
/*jshint strict: false, asi: true, eqeqeq: false, curly: false, laxbreak:true, forin:false, boss:true, funcscope:true, noempty: false */
if( wgAction=='edit' || wgAction=='submit' ) $(function(){
/*global mw, $, urlDecoderCustom, urlDecoderPrefixes, urlDecoderEngNames */
 
var btn = newToolbarBtn;
if( ! $.fn.textSelection ) mw.loader.load([ 'jquery.textSelection' ])
function addUrlDecoderButton(){
btn(
addFuncButton22(
'urlDecoder',
urlDecoderRun,
'//upload.wikimedia.org/wikipedia/commons/9/91/Link_go.png',
'Decode URL before cursor or all URLs in selected text',
window.urlDecoderKey)
);
})
 
/**/
 
 
function addFuncButton22(bId, bFunc, bIcon, bTitle, bKey){
 
mw.loader.using( [ 'user.options', 'jquery.textSelection', 'mediawiki.util' ], function () {
/* Check if view is in edit mode and that the required modules are available. Then, customize the toolbar . . . */
if ( mw.user.options.get('usebetatoolbar') ) {
if ( $.inArray( mw.config.get( 'wgAction' ), [ 'edit', 'submit' ] ) !== -1 ) {
mw.loader.using( 'ext.wikiEditor.toolbar', newToolbarBtn );
$( function unSecure(url) {
} else {
if ( mw.user.options.get('usebetatoolbar') ) {
oldToolbarBtn();
mw.loader.using( 'ext.wikiEditor.toolbar', newToolbarBtnaddUrlDecoderButton );
} else {
btn = oldToolbarBtn();
addUrlDecoderButton();
}
} );
}
// Add the customizations to LiquidThreads' edit toolbar, if available
mw.hook( 'ext.lqt.textareaCreated' ).add( addUrlDecoderButton );
} );
function newToolbarBtn(bId, bFunc, bIcon, bTitle){
var msg = {}; msg[bId] = bTitle; mw.messages.set(msg) // mw.usability.addMessages(msg) doesn't work
$('#wpTextbox1').wikiEditor('addToToolbar', {
section:'main', group:'insert', tools: {
Line 37 ⟶ 39:
icon: bIcon
}}})
 
}
 
function oldToolbarBtn(bId, bFunc, bIcon, bTitle, bKey){
 
var btn = $('<img class=mw-toolbar-custombutton id="' + bId + '">')
.attr({ src: bIcon, title: bTitle, alt: bTitle.substr(0,3) })
.css({ height:'20px', 'background-color':'#bce', border:'1px outset #bce', margin:'0 1px', cursor:'pointer'})
.click(bFunc)
.appendTo('#toolbar')
if( bKey ){
updateTooltipAccessKeys( btn[0] )
btn.attr({ accesskey: bKey, title: bTitle + ' ['+bKey+']' })
updateTooltipAccessKeys( btn[0] .updateTooltipAccessKeys();
}
}
}
/**/
 
 
 
 
Line 85 ⟶ 82:
 
var httpRegExp = '((?:https?:)?\\/\\/[^\\]\\[\\n\\r<>" ]+)' // any chars except []<>" and \n and spaces
var localPrefix = WMPrefixes( unSecuremw.config.get( 'wgServer' ).replace(/^\/\//,'http://') + mw.config.get( 'wgScript' ) )
var oldText, newText, isBeforeCursor, colonNS
 
var tbox = $('#wpTextbox1').focus()
oldText = tbox.textSelection( 'getSelection' )
var rx
 
 
if( oldText ){ //there was selection
 
var rx = RegExp('(\\[{0,2})' + httpRegExp + '([^\\]\\[\\n\\r]*?\\]\\]?)?', 'ig')
newText = oldText.replace(rx, simplifyMatched)
 
if( window.urlDecoderIntLinks ){
var ut = '(' + mw.config.get( 'wgFormattedNamespaces' )[3].replace(/ /g,'_') + '|user_talk)' //both localized and canonical 'user_talk'
ut = RegExp ('\\[\\[' + ut.toLowerCase() + ':[^#]+$', 'i')
newText = newText.replace(/\[\[[^\]\|\n]+/g, function(lnk){
Line 121 ⟶ 118:
 
//try to find http in oldText
var rx = new RegExp('(\\[{0,2})'+httpRegExp+'( +[^\\]\n]+)?\\]{0,2}$', 'i')
var ma = rx.exec( oldText ) // result: (whole string)' '[', 'http:...', ' name]'
if( !ma ) return
Line 153 ⟶ 150:
var trail = RegExp(
'['
+ ',;\\\\\.:!\\?' //trailing punctuation, per Parser.php
+ ( /\(/.test(url) ? '' : '\\)' ) //also closing bracket without opening bracket
+ ']+$'
Line 178 ⟶ 175:
 
var decodingFailed //need to skip some strange percent-encoded URIs
url = unSecure(url)
 
//percent-decoding
Line 207 ⟶ 203:
if( link ){
link = link.replace(/%(3f|26|22)/ig, decodeURIComponent) //decode ?&"
if( ( mw.config.get( 'wgNamespaceNumber' ) === 0 || mw.config.get( 'wgNamespaceNumber' ) === 14 ) && isBeforeCursor )
link = link.replace(/^:/,'') //probably user adding interwiki
return '[\' + '[' + link + (name?'|'+name:'') + ']]'
}
 
Line 227 ⟶ 223:
 
//add bugzilla to user-defined prefixes
window.urlDecoderPrefixes = $.extend( window.urlDecoderPrefixes,
{ 'https://bugzilla.wikimedia.org/show_bug.cgi?id=' : 'mediazilla' } )
 
Line 323 ⟶ 319:
return [proj, lang]
 
}
 
 
 
function unSecure(url){
var mm = /https:\/\/secure\.wikimedia\.org\/(\w+)\/(\w+)\/([^\]\|\n\r ]+)/i.exec( url )
if( !mm) return url
var ___domain = mm[1].toLowerCase(), sub = mm[2].toLowerCase()
 
if( ! wmDomainM[___domain] ) return url //___domain not recognized
if( ___domain == 'wikipedia' ) //handle some special cases
switch( sub ){
case 'mediawiki': sub = 'www'; ___domain = 'mediawiki'; break
case 'foundation': sub = ''; ___domain = 'wikimediafoundation'; break
case 'sources': sub = ''; ___domain = 'wikisource'; break
default:
if( wmSubDomains.test(sub) ) ___domain = 'wikimedia' // .../wikipedia/meta -> meta.wikimedia.org
//otherwise: consider it language: .../wikipedia/en
}
return 'https://' + (sub ? sub + '.' : '') + ___domain + '.org/' + mm[3]
}
 
Line 353 ⟶ 325:
if( ! colonNS ){ //define list of all possible category and file namespaces
var list = ['file', 'category'] //canonical aliases
//if(var !window.wgNamespaceIdsnamespaces )= returnmw.config.get( alert('Warning: wgNamespaceIds' not defined, old MediaWiki version?');
for( var name in wgNamespaceIdsnamespaces )
if( (wgNamespaceIdsnamespaces[name]==6 || wgNamespaceIdsnamespaces[name]==14) && $.inArray(name, list) == -1 )
list.push(name)
colonNS = RegExp( '^(' + list.join('|') + ') *:', 'i')