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