Add an abort class method to the Promise instance returned by wp.ajax.send().

Props westonruter.
Fixes #32628.


git-svn-id: https://develop.svn.wordpress.org/trunk@32747 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Scott Taylor 2015-06-13 14:29:42 +00:00
parent 2ac1bec5ca
commit 93e01e68b5

View File

@ -50,7 +50,8 @@ window.wp = window.wp || {};
* *
* @param {string} action The slug of the action to fire in WordPress. * @param {string} action The slug of the action to fire in WordPress.
* @param {object} data The data to populate $_POST with. * @param {object} data The data to populate $_POST with.
* @return {$.promise} A jQuery promise that represents the request. * @return {$.promise} A jQuery promise that represents the request,
* decorated with an abort() method.
*/ */
post: function( action, data ) { post: function( action, data ) {
return wp.ajax.send({ return wp.ajax.send({
@ -65,9 +66,11 @@ window.wp = window.wp || {};
* *
* @param {string} action The slug of the action to fire in WordPress. * @param {string} action The slug of the action to fire in WordPress.
* @param {object} options The options passed to jQuery.ajax. * @param {object} options The options passed to jQuery.ajax.
* @return {$.promise} A jQuery promise that represents the request. * @return {$.promise} A jQuery promise that represents the request,
* decorated with an abort() method.
*/ */
send: function( action, options ) { send: function( action, options ) {
var promise, deferred;
if ( _.isObject( action ) ) { if ( _.isObject( action ) ) {
options = action; options = action;
} else { } else {
@ -81,7 +84,7 @@ window.wp = window.wp || {};
context: this context: this
}); });
return $.Deferred( function( deferred ) { deferred = $.Deferred( function( deferred ) {
// Transfer success/error callbacks. // Transfer success/error callbacks.
if ( options.success ) if ( options.success )
deferred.done( options.success ); deferred.done( options.success );
@ -92,7 +95,7 @@ window.wp = window.wp || {};
delete options.error; delete options.error;
// Use with PHP's wp_send_json_success() and wp_send_json_error() // Use with PHP's wp_send_json_success() and wp_send_json_error()
$.ajax( options ).done( function( response ) { deferred.jqXHR = $.ajax( options ).done( function( response ) {
// Treat a response of `1` as successful for backwards // Treat a response of `1` as successful for backwards
// compatibility with existing handlers. // compatibility with existing handlers.
if ( response === '1' || response === 1 ) if ( response === '1' || response === 1 )
@ -105,7 +108,15 @@ window.wp = window.wp || {};
}).fail( function() { }).fail( function() {
deferred.rejectWith( this, arguments ); deferred.rejectWith( this, arguments );
}); });
}).promise(); });
promise = deferred.promise();
promise.abort = function() {
deferred.jqXHR.abort();
return this;
};
return promise;
} }
}; };