PATH:
usr
/
local
/
lib
/
node_modules
/
ghost-cli
/
node_modules
/
rxjs
/
src
/
internal
/
testing
import { Subject } from '../Subject'; import { Subscriber } from '../Subscriber'; import { Subscription } from '../Subscription'; import { Scheduler } from '../Scheduler'; import { TestMessage } from './TestMessage'; import { SubscriptionLog } from './SubscriptionLog'; import { SubscriptionLoggable } from './SubscriptionLoggable'; import { applyMixins } from '../util/applyMixins'; /** * We need this JSDoc comment for affecting ESDoc. * @ignore * @extends {Ignored} */ export class HotObservable<T> extends Subject<T> implements SubscriptionLoggable { public subscriptions: SubscriptionLog[] = []; scheduler: Scheduler; logSubscribedFrame: () => number; logUnsubscribedFrame: (index: number) => void; constructor(public messages: TestMessage[], scheduler: Scheduler) { super(); this.scheduler = scheduler; } /** @deprecated This is an internal implementation detail, do not use. */ _subscribe(subscriber: Subscriber<any>): Subscription { const subject: HotObservable<T> = this; const index = subject.logSubscribedFrame(); const subscription = new Subscription(); subscription.add(new Subscription(() => { subject.logUnsubscribedFrame(index); })); subscription.add(super._subscribe(subscriber)); return subscription; } setup() { const subject = this; const messagesLength = subject.messages.length; /* tslint:disable:no-var-keyword */ for (var i = 0; i < messagesLength; i++) { (() => { var message = subject.messages[i]; /* tslint:enable */ subject.scheduler.schedule( () => { message.notification.observe(subject); }, message.frame ); })(); } } } applyMixins(HotObservable, [SubscriptionLoggable]);
[-] SubscriptionLog.ts
[edit]
[+]
..
[-] HotObservable.ts
[edit]
[-] ColdObservable.ts
[edit]
[-] TestScheduler.ts
[edit]
[-] SubscriptionLoggable.ts
[edit]
[-] TestMessage.ts
[edit]