@ -27,16 +27,14 @@ function call(options, callback) {
}
}
} ) ;
} ) ;
}
}
return reject ( err ) ;
return reject ( err ) ;
}
}
resolve ( data ) ;
resolve ( data ) ;
} ) ;
} ) ;
} ) ;
} ) ;
}
}
async function xhr ( options , cb ) {
async function xhr _async ( options ) {
// Normalize body based on type
// Normalize body based on type
const { url } = options ;
const { url } = options ;
delete options . url ;
delete options . url ;
@ -79,16 +77,20 @@ async function xhr(options, cb) {
if ( ! res . ok ) {
if ( ! res . ok ) {
if ( response ) {
if ( response ) {
return cb ( new Error ( isJSON ? response . status . message : response ) ) ;
throw new Error ( isJSON ? response . status . message : response ) ;
}
}
return cb ( new Error ( res . statusText ) ) ;
throw new Error ( res . statusText ) ;
}
}
cb ( null , (
return isJSON && response && response . hasOwnProperty ( 'status' ) && response . hasOwnProperty ( 'response' ) ?
isJSON && response && response . hasOwnProperty ( 'status' ) && response . hasOwnProperty ( 'response' ) ?
response . response :
response . response :
response ;
response
}
) ) ;
function xhr ( options , callback ) {
// then().catch() is not correct here because callback() is called twice when the first then() throws an exception.
// pass onfulfilled and onrejected here, as two parameters of Promise.prototype.then()
xhr _async ( options ) . then ( result => callback ( null , result ) , error => callback ( error ) ) ;
}
}
export function get ( route , data , onSuccess ) {
export function get ( route , data , onSuccess ) {