import {DynamicComponentLoader, ElementRef, ComponentRef, onDestroy, DomRenderer} from 'angular2/angular2';
import {Component, Directive} from 'angular2/src/core/annotations_impl/annotations';
import {View} from 'angular2/src/core/annotations_impl/view';
import {Nav} from 'ionic/ionic';
import {raf, ready} from 'ionic/util/dom'
import {NavController, NavParams, NavbarTemplate, Navbar, Content} from 'ionic/ionic';
@Component({
selector: 'ion-modal-wrapper'
})
@View({
template: `
`
})
class ModalWrapper {
constructor(elementRef: ElementRef) {
this.element = elementRef.domElement;
console.log('element', this.element)
}
show() {
this.element.domElement.classList.add('active')
}
hide() {
this.element.domElement.classList.remove('active')
}
}
@Component({
selector: 'ion-modal'
})
@View({
template: `
`,
directives: [Nav],
})
export class Modal {
//compiler: Compiler;
constructor(loader: DynamicComponentLoader, domRenderer: DomRenderer, elementRef: ElementRef) {
this.componentLoader = loader;
this.domRenderer = domRenderer;
this.element = elementRef.domElement;
this.elementRef = elementRef;
this.initial = ModalFirstPage
}
static create() {
var m = new Modal();
return m;
}
show() {
console.log('Modal show');
return this.componentLoader.loadIntoNewLocation(Modal, this.elementRef).then((containerRef) => {
var modalEl = this.domRenderer.getHostElement(containerRef.hostView.render);
document.body.appendChild(modalEl);
raf(() => {
modalEl.classList.add('active');
});
console.log('Loaded into new location', containerRef, modalEl);
});
}
static show(loader: ComponentLoader, renderer: DomRenderer, elementRef: ElementRef) {
console.log('Showing modal');
var newModal = new Modal(loader, renderer, elementRef);
newModal.show();
return newModal;
}
}
@Component({selector: 'ion-view'})
@View({
template: `
First Page Header: {{ val }}
First Page: {{ val }}
`,
directives: [NavbarTemplate, Navbar, Content]
})
export class ModalFirstPage {
constructor(
nav: NavController
) {
this.nav = nav;
this.val = Math.round(Math.random() * 8999) + 1000;
}
push() {
this.nav.push(ModalSecondPage, { id: 8675309, myData: [1,2,3,4] }, { animation: 'ios' });
}
}
@Component({selector: 'ion-view'})
@View({
template: `
Second Page Header
`,
directives: [NavbarTemplate, Navbar, Content]
})
export class ModalSecondPage {
constructor(
nav: NavController,
params: NavParams
) {
this.nav = nav;
this.params = params;
console.log('Second page params:', params);
}
pop() {
this.nav.pop();
}
push() {
}
}