Files
2015-07-03 13:51:34 -05:00

196 lines
4.6 KiB
TypeScript

import {Component} from 'angular2/angular2';
import {IonicComponent, IonicView, IonicConfig, Platform} from 'ionic/ionic';
import {Modal, NavController, NavParams, Animation, ActionMenu} from 'ionic/ionic';
@Component({
selector: 'ion-app'
})
@IonicView({
templateUrl: 'main.html'
})
class MyAppCmp {
constructor(modal: Modal) {
this.modal = modal;
}
openModal() {
this.modal.open(ContactModal, {
enterAnimation: 'my-fade-in',
leaveAnimation: 'my-fade-out',
handle: 'my-awesome-modal'
});
}
}
@IonicView({
template: '<ion-nav [root]="rootView"></ion-nav>'
})
export class ContactModal {
constructor() {
this.rootView = ModalFirstPage;
}
}
@Component({
selector: 'ion-view'
})
@IonicView({
template: `
<ion-navbar *navbar><ion-title>First Page Header: {{ val }}</ion-title><ion-nav-items primary><button primary (click)="closeModal()">Close</button></ion-nav-items></ion-navbar>
<ion-content class="padding">
<p>First Page: {{ val }}</p>
<p>
<button primary (click)="push()">Push (Go to 2nd)</button>
</p>
<p>
<button primary (click)="openActionMenu()">Open Action Menu</button>
</p>
<p>
<button primary (click)="closeByHandeModal()">Close By Handle</button>
</p>
<f></f><f></f><f></f><f></f><f></f><f></f><f></f><f></f><f></f><f></f>
<f></f><f></f><f></f><f></f><f></f><f></f><f></f><f></f><f></f><f></f>
</ion-content>
`
})
export class ModalFirstPage {
constructor(
nav: NavController,
modal: Modal,
actionMenu: ActionMenu
) {
this.nav = nav;
this.val = Math.round(Math.random() * 8999) + 1000;
this.modal = modal;
this.actionMenu = actionMenu;
}
push() {
this.nav.push(ModalSecondPage, { id: 8675309, myData: [1,2,3,4] }, { animation: 'ios' });
}
closeModal() {
let modal = this.modal.get();
modal.close();
}
closeByHandeModal() {
let modal = this.modal.get('my-awesome-modal');
modal.close();
}
openActionMenu() {
this.actionMenu.open({
buttons: [
{ text: 'Share This' },
{ text: 'Move' }
],
destructiveText: 'Delete',
titleText: 'Modify your album',
cancelText: 'Cancel',
cancel: function() {
console.log('Canceled');
},
destructiveButtonClicked: () => {
console.log('Destructive clicked');
},
buttonClicked: function(index) {
console.log('Button clicked', index);
if(index == 1) { return false; }
return true;
}
}).then(actionMenuRef => {
this.actionMenuRef = actionMenuRef;
});
}
}
@Component({selector: 'ion-view'})
@IonicView({
template: `
<ion-navbar *navbar><ion-title>Second Page Header</ion-title></ion-navbar>
<ion-content class="padding">
<p>
<button primary (click)="nav.pop()">Pop (Go back to 1st)</button>
</p>
<f></f><f></f><f></f><f></f><f></f><f></f><f></f><f></f><f></f><f></f>
<f></f><f></f><f></f><f></f><f></f><f></f><f></f><f></f><f></f><f></f>
</ion-content>
`
})
export class ModalSecondPage {
constructor(
nav: NavController,
params: NavParams
) {
this.nav = nav;
this.params = params;
console.log('Second page params:', params);
}
}
export function main(ionicBootstrap) {
let myConfig = new IonicConfig();
// myConfig.setting('someKey', 'userConfig');
// myConfig.setting('ios', 'someKey', 'iosConfig');
// myConfig.setting('ipad', 'someKey', 'ipadConfig');
ionicBootstrap(MyAppCmp, myConfig).then(app => {
console.log('platforms', Platform.platforms());
console.log('mode', myConfig.setting('mode'));
console.log('core', Platform.is('core'))
console.log('cordova', Platform.is('cordova'))
console.log('mobile', Platform.is('mobile'))
console.log('ipad', Platform.is('ipad'))
console.log('iphone', Platform.is('iphone'))
console.log('phablet', Platform.is('phablet'))
console.log('tablet', Platform.is('tablet'))
console.log('ios', Platform.is('ios'))
console.log('android', Platform.is('android'))
console.log('windows phone', Platform.is('windowsphone'))
console.log('isRTL', app.isRTL())
console.log('lang', app.lang())
Platform.ready().then(() => {
console.log('Platform.ready')
});
});
}
class FadeIn extends Animation {
constructor(element) {
super(element);
this
.easing('ease')
.duration(450)
.fadeIn();
}
}
Animation.register('my-fade-in', FadeIn);
class FadeOut extends Animation {
constructor(element) {
super(element);
this
.easing('ease')
.duration(250)
.fadeOut();
}
}
Animation.register('my-fade-out', FadeOut);