У меня есть требование обрабатывать список запросов параллельно с использованием forkJoin в Angular 5. Я взял ссылку по этой ссылке Rx JS recipes: 'forkJoin' с прогрессом завершения для массовых сетевых запросов в Angular
У меня есть одна проблема здесь. Я не могу точно определить, какой запрос был выполнен, но я могу получить количество запросов, которые были выполнены.
Может кто-нибудь сообщить мне, как узнать, какой именно запрос был выполнен?
Ниже приведен код
let Rx = window.Rx = window['rxjs'];
let {forkJoin, Subject, merge, of, defer, concat, throwError} = Rx;
let {ajax} = Rx.ajax;
let {map, filter, tap, takeLast, scan, startWith, mergeMap, finalize, ignoreElements} = Rx.operators;
console.clear();
function forkJoinWithProgress(arrayOfObservables) {
return defer(() => {
let counter = 0;
const percent$ = new Subject();
const modilefiedObservablesList = arrayOfObservables.map(
(item, index) => item.pipe(
finalize(() => {
const percentValue = ++counter * 100 / arrayOfObservables.length;
percent$.next(percentValue);
})
)
);
const finalResult$ = forkJoin(modilefiedObservablesList).pipe(
tap(() => {
percent$.next(100);
percent$.complete();
}
));
return of([finalResult$, percent$.asObservable()]);
})
}
const getUserDetails = userIdsList => {
const arrayOfObservables = userIdsList.map((userId, index) =>{
//if (index === 1) return throwError({message: 'Vah-vah!'}); // testin with error
return ajax('https://jsonplaceholder.typicode.com/comments/' + userId)
}
)
return forkJoinWithProgress(arrayOfObservables)
}
const result$ = getUserDetails([1, 2, 15]);
result$.pipe(
mergeMap(([finalResult, progress]) => merge(
progress.pipe(
tap((value) => console.log(`${value} completed`)),
ignoreElements()
),
finalResult
))
).subscribe(values => console.log(values), console.warn);