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.
Fixes #39314.


git-svn-id: https://develop.svn.wordpress.org/trunk@39680 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
adamsilverstein 2017-01-05 03:02:39 +00:00
parent 9c509a1eae
commit b55c941b37

View File

@ -321,12 +321,17 @@
// Create the new getModel model. // Create the new getModel model.
getModel = new wp.api.models[ modelName ]( attributes ); getModel = new wp.api.models[ modelName ]( attributes );
// If we didnt have an embedded getModel, fetch the getModel data.
if ( ! getModel.get( embedCheckField ) ) { if ( ! getModel.get( embedCheckField ) ) {
getModel.fetch( { success: function( getModel ) { getModel.fetch( {
deferred.resolve( getModel ); success: function( getModel ) {
} } ); deferred.resolve( getModel );
},
error: function( getModel, response ) {
deferred.reject( response );
}
} );
} else { } else {
// Resolve with the embedded model.
deferred.resolve( getModel ); deferred.resolve( getModel );
} }
@ -392,12 +397,17 @@
// If we didnt have embedded getObjects, fetch the getObjects data. // If we didnt have embedded getObjects, fetch the getObjects data.
if ( _.isUndefined( getObjects.models[0] ) ) { if ( _.isUndefined( getObjects.models[0] ) ) {
getObjects.fetch( { success: function( getObjects ) { getObjects.fetch( {
success: function( getObjects ) {
// Add a helper 'parent_post' attribute onto the model. // Add a helper 'parent_post' attribute onto the model.
setHelperParentPost( getObjects, postId ); setHelperParentPost( getObjects, postId );
deferred.resolve( getObjects ); deferred.resolve( getObjects );
} } ); },
error: function( getModel, response ) {
deferred.reject( response );
}
} );
} else { } else {
// Add a helper 'parent_post' attribute onto the model. // Add a helper 'parent_post' attribute onto the model.