diff options
author | Pierre Schmitz <pierre@archlinux.de> | 2011-06-22 11:28:20 +0200 |
---|---|---|
committer | Pierre Schmitz <pierre@archlinux.de> | 2011-06-22 11:28:20 +0200 |
commit | 9db190c7e736ec8d063187d4241b59feaf7dc2d1 (patch) | |
tree | 46d1a0dee7febef5c2d57a9f7b972be16a163b3d /skins/common/ajax.js | |
parent | 78677c7bbdcc9739f6c10c75935898a20e1acd9e (diff) |
update to MediaWiki 1.17.0
Diffstat (limited to 'skins/common/ajax.js')
-rw-r--r-- | skins/common/ajax.js | 196 |
1 files changed, 103 insertions, 93 deletions
diff --git a/skins/common/ajax.js b/skins/common/ajax.js index afcfa708..1cad75ed 100644 --- a/skins/common/ajax.js +++ b/skins/common/ajax.js @@ -1,167 +1,177 @@ // remote scripting library // (c) copyright 2005 modernmethod, inc -var sajax_debug_mode = false; -var sajax_request_type = "GET"; +window.sajax_debug_mode = false; +window.sajax_request_type = 'GET'; /** -* if sajax_debug_mode is true, this function outputs given the message into -* the element with id = sajax_debug; if no such element exists in the document, -* it is injected. -*/ -function sajax_debug(text) { + * if sajax_debug_mode is true, this function outputs given the message into + * the element with id = sajax_debug; if no such element exists in the document, + * it is injected. + */ +window.sajax_debug = function(text) { if (!sajax_debug_mode) return false; - var e= document.getElementById('sajax_debug'); + var e = document.getElementById( 'sajax_debug' ); - if (!e) { - e= document.createElement("p"); - e.className= 'sajax_debug'; - e.id= 'sajax_debug'; + if ( !e ) { + e = document.createElement( 'p' ); + e.className = 'sajax_debug'; + e.id = 'sajax_debug'; - var b= document.getElementsByTagName("body")[0]; + var b = document.getElementsByTagName( 'body' )[0]; - if (b.firstChild) b.insertBefore(e, b.firstChild); - else b.appendChild(e); + if ( b.firstChild ) { + b.insertBefore( e, b.firstChild ); + } else { + b.appendChild( e ); + } } - var m= document.createElement("div"); + var m = document.createElement( 'div' ); m.appendChild( document.createTextNode( text ) ); e.appendChild( m ); return true; -} +}; /** -* compatibility wrapper for creating a new XMLHttpRequest object. -*/ -function sajax_init_object() { - sajax_debug("sajax_init_object() called..") + * Compatibility wrapper for creating a new XMLHttpRequest object. + */ +window.sajax_init_object = function() { + sajax_debug( 'sajax_init_object() called..' ); var A; try { // Try the new style before ActiveX so we don't // unnecessarily trigger warnings in IE 7 when // set to prompt about ActiveX usage A = new XMLHttpRequest(); - } catch (e) { + } catch ( e ) { try { - A=new ActiveXObject("Msxml2.XMLHTTP"); - } catch (e) { + A = new ActiveXObject( 'Msxml2.XMLHTTP' ); + } catch ( e ) { try { - A=new ActiveXObject("Microsoft.XMLHTTP"); - } catch (oc) { - A=null; + A = new ActiveXObject( 'Microsoft.XMLHTTP' ); + } catch ( oc ) { + A = null; } } } - if (!A) - sajax_debug("Could not create connection object."); + if ( !A ) { + sajax_debug( 'Could not create connection object.' ); + } return A; -} +}; /** -* Perform an ajax call to mediawiki. Calls are handeled by AjaxDispatcher.php -* func_name - the name of the function to call. Must be registered in $wgAjaxExportList -* args - an array of arguments to that function -* target - the target that will handle the result of the call. If this is a function, -* if will be called with the XMLHttpRequest as a parameter; if it's an input -* element, its value will be set to the resultText; if it's another type of -* element, its innerHTML will be set to the resultText. -* -* Example: -* sajax_do_call('doFoo', [1, 2, 3], document.getElementById("showFoo")); -* -* This will call the doFoo function via MediaWiki's AjaxDispatcher, with -* (1, 2, 3) as the parameter list, and will show the result in the element -* with id = showFoo -*/ -function sajax_do_call(func_name, args, target) { + * Perform an AJAX call to MediaWiki. Calls are handled by AjaxDispatcher.php + * func_name - the name of the function to call. Must be registered in $wgAjaxExportList + * args - an array of arguments to that function + * target - the target that will handle the result of the call. If this is a function, + * if will be called with the XMLHttpRequest as a parameter; if it's an input + * element, its value will be set to the resultText; if it's another type of + * element, its innerHTML will be set to the resultText. + * + * Example: + * sajax_do_call( 'doFoo', [1, 2, 3], document.getElementById( 'showFoo' ) ); + * + * This will call the doFoo function via MediaWiki's AjaxDispatcher, with + * (1, 2, 3) as the parameter list, and will show the result in the element + * with id = showFoo + */ +window.sajax_do_call = function(func_name, args, target) { var i, x, n; var uri; var post_data; uri = wgServer + - ((wgScript == null) ? (wgScriptPath + "/index.php") : wgScript) + - "?action=ajax"; - if (sajax_request_type == "GET") { - if (uri.indexOf("?") == -1) - uri = uri + "?rs=" + encodeURIComponent(func_name); - else - uri = uri + "&rs=" + encodeURIComponent(func_name); - for (i = 0; i < args.length; i++) - uri = uri + "&rsargs[]=" + encodeURIComponent(args[i]); - //uri = uri + "&rsrnd=" + new Date().getTime(); + ( ( wgScript == null ) ? ( wgScriptPath + '/index.php' ) : wgScript ) + + '?action=ajax'; + if ( sajax_request_type == 'GET' ) { + if ( uri.indexOf( '?' ) == -1 ) { + uri = uri + '?rs=' + encodeURIComponent( func_name ); + } else { + uri = uri + '&rs=' + encodeURIComponent( func_name ); + } + for ( i = 0; i < args.length; i++ ) { + uri = uri + '&rsargs[]=' + encodeURIComponent( args[i] ); + } + //uri = uri + '&rsrnd=' + new Date().getTime(); post_data = null; } else { - post_data = "rs=" + encodeURIComponent(func_name); - for (i = 0; i < args.length; i++) - post_data = post_data + "&rsargs[]=" + encodeURIComponent(args[i]); + post_data = 'rs=' + encodeURIComponent( func_name ); + for ( i = 0; i < args.length; i++ ) { + post_data = post_data + '&rsargs[]=' + encodeURIComponent( args[i] ); + } } x = sajax_init_object(); - if (!x) { - alert("AJAX not supported"); + if ( !x ) { + alert( 'AJAX not supported' ); return false; } try { - x.open(sajax_request_type, uri, true); - } catch (e) { - if (window.location.hostname == "localhost") { - alert("Your browser blocks XMLHttpRequest to 'localhost', try using a real hostname for development/testing."); + x.open( sajax_request_type, uri, true ); + } catch ( e ) { + if ( window.location.hostname == 'localhost' ) { + alert( "Your browser blocks XMLHttpRequest to 'localhost', try using a real hostname for development/testing." ); } throw e; } - if (sajax_request_type == "POST") { - x.setRequestHeader("Method", "POST " + uri + " HTTP/1.1"); - x.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); + if ( sajax_request_type == 'POST' ) { + x.setRequestHeader( 'Method', 'POST ' + uri + ' HTTP/1.1' ); + x.setRequestHeader( 'Content-Type', 'application/x-www-form-urlencoded' ); } - x.setRequestHeader("Pragma", "cache=yes"); - x.setRequestHeader("Cache-Control", "no-transform"); + x.setRequestHeader( 'Pragma', 'cache=yes' ); + x.setRequestHeader( 'Cache-Control', 'no-transform' ); x.onreadystatechange = function() { - if (x.readyState != 4) + if ( x.readyState != 4 ) { return; + } - sajax_debug("received (" + x.status + " " + x.statusText + ") " + x.responseText); + sajax_debug( 'received (' + x.status + ' ' + x.statusText + ') ' + x.responseText ); - //if (x.status != 200) - // alert("Error: " + x.status + " " + x.statusText + ": " + x.responseText); + //if ( x.status != 200 ) + // alert( 'Error: ' + x.status + ' ' + x.statusText + ': ' + x.responseText ); //else if ( typeof( target ) == 'function' ) { target( x ); - } - else if ( typeof( target ) == 'object' ) { + } else if ( typeof( target ) == 'object' ) { if ( target.tagName == 'INPUT' ) { - if (x.status == 200) target.value= x.responseText; - //else alert("Error: " + x.status + " " + x.statusText + " (" + x.responseText + ")"); - } - else { - if (x.status == 200) target.innerHTML = x.responseText; - else target.innerHTML= "<div class='error'>Error: " + x.status + " " + x.statusText + " (" + x.responseText + ")</div>"; + if ( x.status == 200 ) { + target.value= x.responseText; + } + //else alert( 'Error: ' + x.status + ' ' + x.statusText + ' (' + x.responseText + ')' ); + } else { + if ( x.status == 200 ) { + target.innerHTML = x.responseText; + } else { + target.innerHTML = '<div class="error">Error: ' + x.status + + ' ' + x.statusText + ' (' + x.responseText + ')</div>'; + } } - } - else { - alert("bad target for sajax_do_call: not a function or object: " + target); + } else { + alert( 'bad target for sajax_do_call: not a function or object: ' + target ); } return; - } + }; - sajax_debug(func_name + " uri = " + uri + " / post = " + post_data); - x.send(post_data); - sajax_debug(func_name + " waiting.."); + sajax_debug( func_name + ' uri = ' + uri + ' / post = ' + post_data ); + x.send( post_data ); + sajax_debug( func_name + ' waiting..' ); delete x; return true; -} +}; /** * @return boolean whether the browser supports XMLHttpRequest */ -function wfSupportsAjax() { +window.wfSupportsAjax = function() { var request = sajax_init_object(); var supportsAjax = request ? true : false; delete request; return supportsAjax; -} - +}; |