import {Component, Directive, onInit} from 'angular2/src/core/annotations_impl/annotations'; import {View} from 'angular2/src/core/annotations_impl/view'; import {Parent} from 'angular2/src/core/annotations_impl/visibility'; import {Optional} from 'angular2/src/di/annotations_impl'; import {ElementRef} from 'angular2/src/core/compiler/element_ref'; import {Injector} from 'angular2/di'; import {ViewController} from '../view/view-controller'; @Component({ selector: 'ion-nav', properties: [ 'root' ], lifecycle: [onInit] }) @View({ template: '', directives: [PaneAnchor] }) export class Nav extends ViewController { constructor( @Optional() parentViewCtrl: ViewController, injector: Injector, elementRef: ElementRef ) { super(parentViewCtrl, injector, elementRef); } onInit() { this.push(this.root); } } @Directive({ selector: 'template[pane-anchor]' }) class PaneAnchor { constructor(@Parent() nav: Nav, elementRef: ElementRef) { nav.anchorElementRef(elementRef); } }