source: trip-planner-front/node_modules/rxjs/_esm2015/internal/observable/bindNodeCallback.js@ 76712b2

Last change on this file since 76712b2 was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 3.2 KB
Line 
1import { Observable } from '../Observable';
2import { AsyncSubject } from '../AsyncSubject';
3import { map } from '../operators/map';
4import { canReportError } from '../util/canReportError';
5import { isScheduler } from '../util/isScheduler';
6import { isArray } from '../util/isArray';
7export function bindNodeCallback(callbackFunc, resultSelector, scheduler) {
8 if (resultSelector) {
9 if (isScheduler(resultSelector)) {
10 scheduler = resultSelector;
11 }
12 else {
13 return (...args) => bindNodeCallback(callbackFunc, scheduler)(...args).pipe(map(args => isArray(args) ? resultSelector(...args) : resultSelector(args)));
14 }
15 }
16 return function (...args) {
17 const params = {
18 subject: undefined,
19 args,
20 callbackFunc,
21 scheduler,
22 context: this,
23 };
24 return new Observable(subscriber => {
25 const { context } = params;
26 let { subject } = params;
27 if (!scheduler) {
28 if (!subject) {
29 subject = params.subject = new AsyncSubject();
30 const handler = (...innerArgs) => {
31 const err = innerArgs.shift();
32 if (err) {
33 subject.error(err);
34 return;
35 }
36 subject.next(innerArgs.length <= 1 ? innerArgs[0] : innerArgs);
37 subject.complete();
38 };
39 try {
40 callbackFunc.apply(context, [...args, handler]);
41 }
42 catch (err) {
43 if (canReportError(subject)) {
44 subject.error(err);
45 }
46 else {
47 console.warn(err);
48 }
49 }
50 }
51 return subject.subscribe(subscriber);
52 }
53 else {
54 return scheduler.schedule(dispatch, 0, { params, subscriber, context });
55 }
56 });
57 };
58}
59function dispatch(state) {
60 const { params, subscriber, context } = state;
61 const { callbackFunc, args, scheduler } = params;
62 let subject = params.subject;
63 if (!subject) {
64 subject = params.subject = new AsyncSubject();
65 const handler = (...innerArgs) => {
66 const err = innerArgs.shift();
67 if (err) {
68 this.add(scheduler.schedule(dispatchError, 0, { err, subject }));
69 }
70 else {
71 const value = innerArgs.length <= 1 ? innerArgs[0] : innerArgs;
72 this.add(scheduler.schedule(dispatchNext, 0, { value, subject }));
73 }
74 };
75 try {
76 callbackFunc.apply(context, [...args, handler]);
77 }
78 catch (err) {
79 this.add(scheduler.schedule(dispatchError, 0, { err, subject }));
80 }
81 }
82 this.add(subject.subscribe(subscriber));
83}
84function dispatchNext(arg) {
85 const { value, subject } = arg;
86 subject.next(value);
87 subject.complete();
88}
89function dispatchError(arg) {
90 const { err, subject } = arg;
91 subject.error(err);
92}
93//# sourceMappingURL=bindNodeCallback.js.map
Note: See TracBrowser for help on using the repository browser.