fix(web worker): remove usages of deprecated zone API

Closes #5425
This commit is contained in:
Yegor Jbanov 2015-11-20 18:07:54 -08:00 committed by Yegor
parent 019cb41dd8
commit d59c20c315
3 changed files with 21 additions and 15 deletions

View File

@ -1,18 +1,20 @@
import {NgZone} from 'angular2/src/core/zone/ng_zone'; import {NgZone} from 'angular2/src/core/zone/ng_zone';
import {EventEmitter, ObservableWrapper} from 'angular2/src/facade/async';
export class MockNgZone extends NgZone { export class MockNgZone extends NgZone {
/** @internal */ /** @internal */
_onEventDone: () => void; _mockOnEventDone: EventEmitter<any>;
constructor() { super({enableLongStackTrace: false}); } constructor() {
super({enableLongStackTrace: false});
this._mockOnEventDone = new EventEmitter<any>(false);
}
get onEventDone() { return this._mockOnEventDone; }
run(fn: Function): any { return fn(); } run(fn: Function): any { return fn(); }
runOutsideAngular(fn: Function): any { return fn(); } runOutsideAngular(fn: Function): any { return fn(); }
overrideOnEventDone(fn: () => void, opt_waitForAsync: boolean = false): void { simulateZoneExit(): void { ObservableWrapper.callNext(this.onEventDone, null); }
this._onEventDone = fn;
}
simulateZoneExit(): void { this._onEventDone(); }
} }

View File

@ -45,12 +45,14 @@ abstract class GenericMessageBusSink implements MessageBusSink {
void attachToZone(NgZone zone) { void attachToZone(NgZone zone) {
_zone = zone; _zone = zone;
_zone.overrideOnEventDone(() { _zone.runOutsideAngular(() {
if (_messageBuffer.length > 0) { _zone.onEventDone.listen((_) {
sendMessages(_messageBuffer); if (_messageBuffer.length > 0) {
_messageBuffer.clear(); sendMessages(_messageBuffer);
} _messageBuffer.clear();
}, false); }
});
});
} }
void initChannel(String channelName, [bool runInZone = true]) { void initChannel(String channelName, [bool runInZone = true]) {

View File

@ -4,7 +4,7 @@ import {
MessageBusSink MessageBusSink
} from "angular2/src/web_workers/shared/message_bus"; } from "angular2/src/web_workers/shared/message_bus";
import {BaseException, WrappedException} from 'angular2/src/facade/exceptions'; import {BaseException, WrappedException} from 'angular2/src/facade/exceptions';
import {EventEmitter} from 'angular2/src/facade/async'; import {EventEmitter, ObservableWrapper} from 'angular2/src/facade/async';
import {StringMapWrapper} from 'angular2/src/facade/collection'; import {StringMapWrapper} from 'angular2/src/facade/collection';
import {Injectable} from "angular2/src/core/di"; import {Injectable} from "angular2/src/core/di";
import {NgZone} from 'angular2/src/core/zone/ng_zone'; import {NgZone} from 'angular2/src/core/zone/ng_zone';
@ -41,7 +41,9 @@ export class PostMessageBusSink implements MessageBusSink {
attachToZone(zone: NgZone): void { attachToZone(zone: NgZone): void {
this._zone = zone; this._zone = zone;
this._zone.overrideOnEventDone(() => this._handleOnEventDone(), false); this._zone.runOutsideAngular(() => {
ObservableWrapper.subscribe(this._zone.onEventDone, (_) => { this._handleOnEventDone(); });
});
} }
initChannel(channel: string, runInZone: boolean = true): void { initChannel(channel: string, runInZone: boolean = true): void {