REST API: Add error handling for fetch error in buildModelGetter
of wp-api.js.
When a call to a model getter method fails, reject the returned deferred object. Enables better handling of fetch errors. Props westonruter, adamsilverstein. Merges [39680] to the 4.7 branch. Fixes #39314. git-svn-id: https://develop.svn.wordpress.org/branches/4.7@39682 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
b8ee9d17c1
commit
ef8c306263
@ -321,12 +321,17 @@
|
||||
// Create the new getModel model.
|
||||
getModel = new wp.api.models[ modelName ]( attributes );
|
||||
|
||||
// If we didn’t have an embedded getModel, fetch the getModel data.
|
||||
if ( ! getModel.get( embedCheckField ) ) {
|
||||
getModel.fetch( { success: function( getModel ) {
|
||||
deferred.resolve( getModel );
|
||||
} } );
|
||||
getModel.fetch( {
|
||||
success: function( getModel ) {
|
||||
deferred.resolve( getModel );
|
||||
},
|
||||
error: function( getModel, response ) {
|
||||
deferred.reject( response );
|
||||
}
|
||||
} );
|
||||
} else {
|
||||
// Resolve with the embedded model.
|
||||
deferred.resolve( getModel );
|
||||
}
|
||||
|
||||
@ -392,12 +397,17 @@
|
||||
|
||||
// If we didn’t have embedded getObjects, fetch the getObjects data.
|
||||
if ( _.isUndefined( getObjects.models[0] ) ) {
|
||||
getObjects.fetch( { success: function( getObjects ) {
|
||||
getObjects.fetch( {
|
||||
success: function( getObjects ) {
|
||||
|
||||
// Add a helper 'parent_post' attribute onto the model.
|
||||
setHelperParentPost( getObjects, postId );
|
||||
deferred.resolve( getObjects );
|
||||
} } );
|
||||
// Add a helper 'parent_post' attribute onto the model.
|
||||
setHelperParentPost( getObjects, postId );
|
||||
deferred.resolve( getObjects );
|
||||
},
|
||||
error: function( getModel, response ) {
|
||||
deferred.reject( response );
|
||||
}
|
||||
} );
|
||||
} else {
|
||||
|
||||
// Add a helper 'parent_post' attribute onto the model.
|
||||
|
Loading…
Reference in New Issue
Block a user