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:
parent
2ac1bec5ca
commit
93e01e68b5
@ -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;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user