I have a use case where I have to call $http.post(request)
on batches of the input data.
For this, I created an array of requests. For each of them, I need to get the response of $http.post()
, append it to an existing array and pass it to a rendering function. I have to make the next call only when the previous one completes and since $http.post()
returns a promise (according to this), I am trying to do this using the reduce
function.
function callToHttpPost(request) {
return $http.post('someurl', request);
}
function outerFunc($scope, someId) {
let completeArray = [];
let arrayOfRequests = getRequestInBatches();
arrayOfRequests.reduce((promiseChain, currentRequest) => {
console.log(promiseChain);
return promiseChain.then((previousResponse) => {
completeArray.push.apply(completeArray, previousResponse.data);
render($scope, completeArray, someId);
return callToHttpPost(currentRequest);
});
}, Promise.resolve()).catch(e => errorHandler($scope, e, someId));
}
(I have referred MDN and this answer)
But this gives me TypeError: previousResponse is undefined
. The log statement shows the first promise as resolved (since it is the initial value passed to the reduce
function), but the other promises show up as rejected
due to this error. How can I resolve this?