mirror of
https://github.com/ionic-team/ionic-framework.git
synced 2025-08-19 03:32:21 +08:00
transition runs outside of angular
This commit is contained in:
@ -1,4 +1,4 @@
|
|||||||
import {Directive, View, ElementRef, Host, Optional, forwardRef, Injector} from 'angular2/angular2';
|
import {Directive, View, ElementRef, Host, Optional, forwardRef, Injector, NgZone} from 'angular2/angular2';
|
||||||
|
|
||||||
import {IonicComponent} from '../../config/annotations';
|
import {IonicComponent} from '../../config/annotations';
|
||||||
import {ViewController} from '../view/view-controller';
|
import {ViewController} from '../view/view-controller';
|
||||||
@ -22,9 +22,10 @@ export class Nav extends ViewController {
|
|||||||
constructor(
|
constructor(
|
||||||
@Optional() hostViewCtrl: ViewController,
|
@Optional() hostViewCtrl: ViewController,
|
||||||
injector: Injector,
|
injector: Injector,
|
||||||
elementRef: ElementRef
|
elementRef: ElementRef,
|
||||||
|
zone: NgZone
|
||||||
) {
|
) {
|
||||||
super(hostViewCtrl, injector, elementRef);
|
super(hostViewCtrl, injector, elementRef, zone);
|
||||||
}
|
}
|
||||||
|
|
||||||
onIonInit() {
|
onIonInit() {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import {Directive, Component, View, Host, ElementRef, forwardRef, Injector} from 'angular2/angular2';
|
import {Directive, Component, View, Host, ElementRef, forwardRef, Injector, NgZone} from 'angular2/angular2';
|
||||||
|
|
||||||
import {ViewController} from '../view/view-controller';
|
import {ViewController} from '../view/view-controller';
|
||||||
import {ViewItem} from '../view/view-item';
|
import {ViewItem} from '../view/view-item';
|
||||||
@ -29,12 +29,13 @@ export class Tab extends ViewController {
|
|||||||
constructor(
|
constructor(
|
||||||
@Host() tabs: Tabs,
|
@Host() tabs: Tabs,
|
||||||
elementRef: ElementRef,
|
elementRef: ElementRef,
|
||||||
injector: Injector
|
injector: Injector,
|
||||||
|
zone: NgZone
|
||||||
) {
|
) {
|
||||||
// A Tab is both a container of many views, and is a view itself.
|
// A Tab is both a container of many views, and is a view itself.
|
||||||
// A Tab is one ViewItem within it's Host Tabs (which extends ViewController)
|
// A Tab is one ViewItem within it's Host Tabs (which extends ViewController)
|
||||||
// A Tab is a ViewController for its child ViewItems
|
// A Tab is a ViewController for its child ViewItems
|
||||||
super(tabs, injector, elementRef);
|
super(tabs, injector, elementRef, zone);
|
||||||
this.tabs = tabs;
|
this.tabs = tabs;
|
||||||
|
|
||||||
this.childNavbar(true);
|
this.childNavbar(true);
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import {Component, Directive, View, Injector, NgFor, ElementRef, Optional, Host, forwardRef} from 'angular2/angular2';
|
import {Component, Directive, View, Injector, NgFor, ElementRef, Optional, Host, forwardRef, NgZone} from 'angular2/angular2';
|
||||||
|
|
||||||
import {ViewController} from '../view/view-controller';
|
import {ViewController} from '../view/view-controller';
|
||||||
import {ViewItem} from '../view/view-item';
|
import {ViewItem} from '../view/view-item';
|
||||||
@ -33,9 +33,10 @@ export class Tabs extends ViewController {
|
|||||||
@Optional() hostViewCtrl: ViewController,
|
@Optional() hostViewCtrl: ViewController,
|
||||||
@Optional() viewItem: ViewItem,
|
@Optional() viewItem: ViewItem,
|
||||||
injector: Injector,
|
injector: Injector,
|
||||||
elementRef: ElementRef
|
elementRef: ElementRef,
|
||||||
|
zone: NgZone
|
||||||
) {
|
) {
|
||||||
super(hostViewCtrl, injector, elementRef);
|
super(hostViewCtrl, injector, elementRef, zone);
|
||||||
|
|
||||||
// Tabs may also be an actual ViewItem which was navigated to
|
// Tabs may also be an actual ViewItem which was navigated to
|
||||||
// if Tabs is static and not navigated to within a ViewController
|
// if Tabs is static and not navigated to within a ViewController
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import {Compiler, ElementRef, Injector, bind} from 'angular2/angular2';
|
import {Compiler, ElementRef, Injector, bind, NgZone} from 'angular2/angular2';
|
||||||
import {DynamicComponentLoader} from 'angular2/src/core/compiler/dynamic_component_loader';
|
import {DynamicComponentLoader} from 'angular2/src/core/compiler/dynamic_component_loader';
|
||||||
import {AppViewManager} from 'angular2/src/core/compiler/view_manager';
|
import {AppViewManager} from 'angular2/src/core/compiler/view_manager';
|
||||||
|
|
||||||
@ -19,7 +19,8 @@ export class ViewController extends Ion {
|
|||||||
constructor(
|
constructor(
|
||||||
parentViewCtrl: ViewController,
|
parentViewCtrl: ViewController,
|
||||||
injector: Injector,
|
injector: Injector,
|
||||||
elementRef: ElementRef
|
elementRef: ElementRef,
|
||||||
|
zone: NgZone
|
||||||
) {
|
) {
|
||||||
let config = injector.get(IonicConfig);
|
let config = injector.get(IonicConfig);
|
||||||
super(elementRef, config);
|
super(elementRef, config);
|
||||||
@ -32,6 +33,7 @@ export class ViewController extends Ion {
|
|||||||
this.router = injector.get(IonicRouter);
|
this.router = injector.get(IonicRouter);
|
||||||
this.app = injector.get(IonicApp);
|
this.app = injector.get(IonicApp);
|
||||||
this.config = config;
|
this.config = config;
|
||||||
|
this.zone = zone;
|
||||||
|
|
||||||
this.router.addViewController(this);
|
this.router.addViewController(this);
|
||||||
|
|
||||||
@ -215,6 +217,8 @@ export class ViewController extends Ion {
|
|||||||
// wait for the new item to complete setup
|
// wait for the new item to complete setup
|
||||||
enteringItem.stage(() => {
|
enteringItem.stage(() => {
|
||||||
|
|
||||||
|
this.zone.runOutsideAngular(() => {
|
||||||
|
|
||||||
enteringItem.shouldDestroy = false;
|
enteringItem.shouldDestroy = false;
|
||||||
enteringItem.shouldCache = false;
|
enteringItem.shouldCache = false;
|
||||||
enteringItem.willEnter();
|
enteringItem.willEnter();
|
||||||
@ -253,14 +257,18 @@ export class ViewController extends Ion {
|
|||||||
leavingItem.didLeave();
|
leavingItem.didLeave();
|
||||||
|
|
||||||
// all done!
|
// all done!
|
||||||
|
this.zone.run(() => {
|
||||||
this.transitionComplete();
|
this.transitionComplete();
|
||||||
|
|
||||||
callback();
|
callback();
|
||||||
});
|
});
|
||||||
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
swipeBackStart() {
|
swipeBackStart() {
|
||||||
if (this.isTransitioning() || this.items.length < 2) {
|
if (this.isTransitioning() || this.items.length < 2) {
|
||||||
return;
|
return;
|
||||||
|
Reference in New Issue
Block a user