2006-03-22 04:33:07 +01:00
|
|
|
// AJAX Plugin
|
|
|
|
// Docs Here:
|
|
|
|
// http://jquery.com/docs/ajax/
|
|
|
|
|
2006-06-19 03:29:54 +02:00
|
|
|
/**
|
|
|
|
* Load HTML from a remote file and inject it into the DOM
|
|
|
|
*/
|
2006-07-10 05:20:56 +02:00
|
|
|
jQuery.fn.load = function( url, params, callback ) {
|
2006-03-23 22:13:20 +01:00
|
|
|
// I overwrote the event plugin's .load
|
|
|
|
// this won't happen again, I hope -John
|
2006-06-19 03:29:54 +02:00
|
|
|
if ( url && url.constructor == Function )
|
|
|
|
return this.bind("load", url);
|
|
|
|
|
|
|
|
// Default to a GET request
|
|
|
|
var type = "GET";
|
|
|
|
|
|
|
|
// If the second parameter was provided
|
|
|
|
if ( params ) {
|
|
|
|
// If it's a function
|
|
|
|
if ( params.constructor == Function ) {
|
|
|
|
// We assume that it's the callback
|
|
|
|
callback = params;
|
|
|
|
params = null;
|
|
|
|
|
|
|
|
// Otherwise, build a param string
|
|
|
|
} else {
|
2006-06-22 22:14:41 +02:00
|
|
|
params = jQuery.param( params );
|
2006-06-19 03:29:54 +02:00
|
|
|
type = "POST";
|
|
|
|
}
|
2006-03-23 22:13:20 +01:00
|
|
|
}
|
2006-06-19 03:29:54 +02:00
|
|
|
|
2006-03-23 22:13:20 +01:00
|
|
|
var self = this;
|
2006-06-19 03:29:54 +02:00
|
|
|
|
|
|
|
// Request the remote document
|
2006-06-22 22:14:41 +02:00
|
|
|
jQuery.ajax( type, url, params,function(res){
|
2006-06-19 03:29:54 +02:00
|
|
|
|
|
|
|
// Inject the HTML into all the matched elements
|
|
|
|
self.html(res.responseText).each(function(){
|
|
|
|
// If a callback function was provided
|
|
|
|
if ( callback && callback.constructor == Function )
|
|
|
|
// Execute it within the context of the element
|
2006-06-22 07:23:38 +02:00
|
|
|
callback.apply( self, [res.responseText] );
|
2006-06-19 03:29:54 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
// Execute all the scripts inside of the newly-injected HTML
|
|
|
|
$("script", self).each(function(){
|
|
|
|
eval( this.text || this.textContent || this.innerHTML || "");
|
2006-03-23 22:13:20 +01:00
|
|
|
});
|
2006-06-08 19:31:57 +02:00
|
|
|
|
2006-03-23 22:13:20 +01:00
|
|
|
});
|
2006-06-19 03:29:54 +02:00
|
|
|
|
2006-03-23 22:13:20 +01:00
|
|
|
return this;
|
2006-03-22 04:33:07 +01:00
|
|
|
};
|
2006-05-16 18:18:52 +02:00
|
|
|
|
2006-06-19 03:29:54 +02:00
|
|
|
// If IE is used, create a wrapper for the XMLHttpRequest object
|
2006-07-10 05:20:56 +02:00
|
|
|
if ( jQuery.browser.msie )
|
2006-06-19 03:29:54 +02:00
|
|
|
XMLHttpRequest = function(){
|
|
|
|
return new ActiveXObject(
|
2006-07-10 05:20:56 +02:00
|
|
|
navigator.userAgent.indexOf("MSIE 5") >= 0 ?
|
2006-06-19 03:29:54 +02:00
|
|
|
"Microsoft.XMLHTTP" : "Msxml2.XMLHTTP"
|
|
|
|
);
|
|
|
|
};
|
2006-06-08 19:31:57 +02:00
|
|
|
|
2006-06-19 03:29:54 +02:00
|
|
|
// Attach a bunch of functions for handling common AJAX events
|
2006-07-10 05:20:56 +02:00
|
|
|
new function(){
|
2006-06-23 00:25:03 +02:00
|
|
|
var e = "ajaxStart,ajaxStop,ajaxComplete,ajaxError,ajaxSuccess".split(',');
|
2006-06-19 03:29:54 +02:00
|
|
|
|
2006-07-10 05:20:56 +02:00
|
|
|
for ( var i = 0; i < e.length; i++ ) new function(){
|
2006-06-19 03:29:54 +02:00
|
|
|
var o = e[i];
|
2006-07-10 05:20:56 +02:00
|
|
|
jQuery.fn[o] = function(f){
|
|
|
|
return this.bind(o, f);
|
|
|
|
};
|
2006-06-19 03:29:54 +02:00
|
|
|
}
|
2006-07-17 03:49:55 +02:00
|
|
|
};
|
$.fn.formValues;
Gets form values and creates a key=>value array of the found values.
What's new?
- Only does this for ENABLED elements.
- Keeps the same order of the form.
- Optionally adds the button which is clicked (marks that name with an 'x' in the list)
example: $('#frmLogin').formValues('oButton');
$.fn.update (PREVIOUSLY: $.update, so beware!!!!)
Calls sURL with sAction (method) and sends the aValues. Puts the results from that call in the jQuery object and calls fCallback if provided.
What's new?
- Renamed $.update to $.fn.update, since it is more obvious to call $('someJQueryObject').update(...) then $.update($('someJQueryObject'), ...). It's also more jQuery-ish
- Added the method you want to use, since i used post before, now you can select between either GET or POST.
example: $('someJQueryObject').update('sURL', 'sAction', 'aValues', 'fCallback');
$.fn.serialize
Calls the form's action with the correct method and the serialized values. Optionally adds the button which is clicked if you provide it. When there are results, the fCallback function is called.
What's new?
- The entire function
example: $('someForm').serialize('sButton', 'fCallback');
2006-05-31 13:14:21 +02:00
|
|
|
|
2006-07-10 05:20:56 +02:00
|
|
|
jQuery.extend({
|
2006-05-17 20:04:46 +02:00
|
|
|
|
2006-07-10 05:20:56 +02:00
|
|
|
/**
|
|
|
|
* Load a remote page using a GET request
|
|
|
|
*/
|
|
|
|
get: function( url, data, callback, type ) {
|
|
|
|
if ( data.constructor == Function ) {
|
|
|
|
callback = data;
|
|
|
|
data = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( data )
|
|
|
|
url += "?" + jQuery.param(data);
|
|
|
|
|
|
|
|
// Build and start the HTTP Request
|
|
|
|
jQuery.ajax( "GET", url, null, function(r) {
|
|
|
|
if ( callback ) callback( jQuery.httpData(r,type) );
|
|
|
|
});
|
|
|
|
},
|
2006-06-19 03:29:54 +02:00
|
|
|
|
2006-07-10 05:20:56 +02:00
|
|
|
/**
|
|
|
|
* Load a remote page using a POST request.
|
|
|
|
*/
|
|
|
|
post: function( url, data, callback, type ) {
|
|
|
|
// Build and start the HTTP Request
|
|
|
|
jQuery.ajax( "POST", url, jQuery.param(data), function(r) {
|
|
|
|
if ( callback ) callback( jQuery.httpData(r,type) );
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A common wrapper for making XMLHttpRequests
|
|
|
|
*/
|
|
|
|
ajax: function( type, url, data, ret ) {
|
|
|
|
// If only a single argument was passed in,
|
|
|
|
// assume that it is a object of key/value pairs
|
|
|
|
if ( !url ) {
|
|
|
|
ret = type.complete;
|
|
|
|
var success = type.success;
|
|
|
|
var error = type.error;
|
|
|
|
data = type.data;
|
|
|
|
url = type.url;
|
|
|
|
type = type.type;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Watch for a new set of requests
|
|
|
|
if ( ! jQuery.active++ )
|
|
|
|
jQuery.event.trigger( "ajaxStart" );
|
|
|
|
|
|
|
|
// Create the request object
|
|
|
|
var xml = new XMLHttpRequest();
|
|
|
|
|
|
|
|
// Open the socket
|
|
|
|
xml.open(type || "GET", url, true);
|
|
|
|
|
|
|
|
// Set the correct header, if data is being sent
|
|
|
|
if ( data )
|
|
|
|
xml.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
|
|
|
|
|
|
|
|
// Set header so calling script knows that it's an XMLHttpRequest
|
|
|
|
xml.setRequestHeader("X-Requested-With", "XMLHttpRequest");
|
|
|
|
|
|
|
|
// Make sure the browser sends the right content length
|
|
|
|
if ( xml.overrideMimeType )
|
|
|
|
xml.setRequestHeader("Connection", "close");
|
|
|
|
|
|
|
|
// Wait for a response to come back
|
|
|
|
xml.onreadystatechange = function(){
|
|
|
|
// The transfer is complete and the data is available
|
|
|
|
if ( xml.readyState == 4 ) {
|
|
|
|
// Make sure that the request was successful
|
|
|
|
if ( jQuery.httpSuccess( xml ) ) {
|
2006-06-19 03:29:54 +02:00
|
|
|
|
2006-07-10 05:20:56 +02:00
|
|
|
// If a local callback was specified, fire it
|
|
|
|
if ( success ) success( xml );
|
|
|
|
|
|
|
|
// Fire the global callback
|
|
|
|
jQuery.event.trigger( "ajaxSuccess" );
|
2006-06-19 03:29:54 +02:00
|
|
|
|
2006-07-10 05:20:56 +02:00
|
|
|
// Otherwise, the request was not successful
|
|
|
|
} else {
|
|
|
|
// If a local callback was specified, fire it
|
|
|
|
if ( error ) error( xml );
|
|
|
|
|
|
|
|
// Fire the global callback
|
|
|
|
jQuery.event.trigger( "ajaxError" );
|
|
|
|
}
|
|
|
|
|
|
|
|
// The request was completed
|
|
|
|
jQuery.event.trigger( "ajaxComplete" );
|
|
|
|
|
|
|
|
// Handle the global AJAX counter
|
|
|
|
if ( ! --jQuery.active )
|
|
|
|
jQuery.event.trigger( "ajaxStop" );
|
|
|
|
|
|
|
|
// Process result
|
|
|
|
if ( ret ) ret(xml);
|
2006-07-17 06:57:07 +02:00
|
|
|
|
|
|
|
// Stop memory leaks
|
|
|
|
xml.onreadystatechange = function(){};
|
|
|
|
xml = null;
|
2006-06-19 03:29:54 +02:00
|
|
|
}
|
2006-07-17 06:57:07 +02:00
|
|
|
};
|
2006-07-10 05:20:56 +02:00
|
|
|
|
|
|
|
// Send the data
|
|
|
|
xml.send(data);
|
|
|
|
},
|
|
|
|
|
|
|
|
// Counter for holding the number of active queries
|
|
|
|
active: 0,
|
|
|
|
|
|
|
|
// Determines if an XMLHttpRequest was successful or not
|
|
|
|
httpSuccess: function(r) {
|
|
|
|
try {
|
|
|
|
return r.status ?
|
|
|
|
( r.status >= 200 && r.status < 300 ) || r.status == 304 :
|
|
|
|
location.protocol == "file:";
|
|
|
|
} catch(e){}
|
|
|
|
return false;
|
|
|
|
},
|
|
|
|
|
|
|
|
// Get the data out of an XMLHttpRequest.
|
|
|
|
// Return parsed XML if content-type header is "xml" and type is "xml" or omitted,
|
|
|
|
// otherwise return plain text.
|
|
|
|
httpData: function(r,type) {
|
|
|
|
var ct = r.getResponseHeader("content-type");
|
|
|
|
var xml = ( !type || type == "xml" ) && ct && ct.indexOf("xml") >= 0;
|
|
|
|
return xml ? r.responseXML : r.responseText;
|
|
|
|
},
|
|
|
|
|
|
|
|
// Serialize an array of form elements or a set of
|
|
|
|
// key/values into a query string
|
|
|
|
param: function(a) {
|
|
|
|
var s = [];
|
2006-06-19 03:29:54 +02:00
|
|
|
|
2006-07-10 05:20:56 +02:00
|
|
|
// If an array was passed in, assume that it is an array
|
|
|
|
// of form elements
|
2006-08-13 03:29:27 +02:00
|
|
|
if ( a.constructor == Array ) {
|
2006-07-10 05:20:56 +02:00
|
|
|
// Serialize the form elements
|
|
|
|
for ( var i = 0; i < a.length; i++ )
|
|
|
|
s.push( a[i].name + "=" + encodeURIComponent( a[i].value ) );
|
|
|
|
|
|
|
|
// Otherwise, assume that it's an object of key/value pairs
|
2006-08-13 03:29:27 +02:00
|
|
|
} else {
|
2006-07-10 05:20:56 +02:00
|
|
|
// Serialize the key/values
|
|
|
|
for ( var j in a )
|
|
|
|
s.push( j + "=" + encodeURIComponent( a[j] ) );
|
2006-08-13 03:29:27 +02:00
|
|
|
}
|
2006-07-10 05:20:56 +02:00
|
|
|
|
|
|
|
// Return the resulting serialization
|
|
|
|
return s.join("&");
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|