github-pages-deploy-action/node_modules/rxjs/_esm2015/internal/operators/withLatestFrom.js
2020-03-06 22:45:40 -05:00

73 lines
2.2 KiB
JavaScript

import { OuterSubscriber } from '../OuterSubscriber';
import { subscribeToResult } from '../util/subscribeToResult';
export function withLatestFrom(...args) {
return (source) => {
let project;
if (typeof args[args.length - 1] === 'function') {
project = args.pop();
}
const observables = args;
return source.lift(new WithLatestFromOperator(observables, project));
};
}
class WithLatestFromOperator {
constructor(observables, project) {
this.observables = observables;
this.project = project;
}
call(subscriber, source) {
return source.subscribe(new WithLatestFromSubscriber(subscriber, this.observables, this.project));
}
}
class WithLatestFromSubscriber extends OuterSubscriber {
constructor(destination, observables, project) {
super(destination);
this.observables = observables;
this.project = project;
this.toRespond = [];
const len = observables.length;
this.values = new Array(len);
for (let i = 0; i < len; i++) {
this.toRespond.push(i);
}
for (let i = 0; i < len; i++) {
let observable = observables[i];
this.add(subscribeToResult(this, observable, observable, i));
}
}
notifyNext(outerValue, innerValue, outerIndex, innerIndex, innerSub) {
this.values[outerIndex] = innerValue;
const toRespond = this.toRespond;
if (toRespond.length > 0) {
const found = toRespond.indexOf(outerIndex);
if (found !== -1) {
toRespond.splice(found, 1);
}
}
}
notifyComplete() {
}
_next(value) {
if (this.toRespond.length === 0) {
const args = [value, ...this.values];
if (this.project) {
this._tryProject(args);
}
else {
this.destination.next(args);
}
}
}
_tryProject(args) {
let result;
try {
result = this.project.apply(this, args);
}
catch (err) {
this.destination.error(err);
return;
}
this.destination.next(result);
}
}
//# sourceMappingURL=withLatestFrom.js.map