ionic-angular
Version:
A powerful framework for building mobile and progressive web apps with JavaScript and Angular
107 lines • 4.65 kB
JavaScript
import { Component, ComponentFactoryResolver, ElementRef, HostListener, Renderer, ViewChild, ViewContainerRef } from '@angular/core';
import { KEY_ESCAPE } from '../../platform/key';
import { NavParams } from '../../navigation/nav-params';
import { ViewController } from '../../navigation/view-controller';
import { GESTURE_GO_BACK_SWIPE, GESTURE_MENU_SWIPE, GestureController } from '../../gestures/gesture-controller';
import { ModuleLoader } from '../../util/module-loader';
/**
* @hidden
*/
var ModalCmp = (function () {
function ModalCmp(_cfr, _renderer, _elementRef, _navParams, _viewCtrl, gestureCtrl, moduleLoader) {
this._cfr = _cfr;
this._renderer = _renderer;
this._elementRef = _elementRef;
this._navParams = _navParams;
this._viewCtrl = _viewCtrl;
this.moduleLoader = moduleLoader;
var opts = _navParams.get('opts');
(void 0) /* assert */;
this._gestureBlocker = gestureCtrl.createBlocker({
disable: [GESTURE_MENU_SWIPE, GESTURE_GO_BACK_SWIPE]
});
this._bdDismiss = opts.enableBackdropDismiss;
if (opts.cssClass) {
opts.cssClass.split(' ').forEach(function (cssClass) {
// Make sure the class isn't whitespace, otherwise it throws exceptions
if (cssClass.trim() !== '')
_renderer.setElementClass(_elementRef.nativeElement, cssClass, true);
});
}
}
ModalCmp.prototype.ionViewPreLoad = function () {
var component = this._navParams.data.component;
if (!component) {
console.warn('modal\'s page was not defined');
return;
}
var cfr = this.moduleLoader.getComponentFactoryResolver(component);
if (!cfr) {
cfr = this._cfr;
}
var componentFactory = cfr.resolveComponentFactory(component);
// ******** DOM WRITE ****************
var componentRef = this._viewport.createComponent(componentFactory, this._viewport.length, this._viewport.parentInjector, []);
this._setCssClass(componentRef, 'ion-page');
this._setCssClass(componentRef, 'show-page');
// Change the viewcontroller's instance to point the user provided page
// Lifecycle events will be sent to the new instance, instead of the modal's component
// we need to manually subscribe to them
this._viewCtrl._setInstance(componentRef.instance);
this._viewCtrl.willEnter.subscribe(this._viewWillEnter.bind(this));
this._viewCtrl.didLeave.subscribe(this._viewDidLeave.bind(this));
this._enabled = true;
};
ModalCmp.prototype._viewWillEnter = function () {
this._gestureBlocker.block();
};
ModalCmp.prototype._viewDidLeave = function () {
this._gestureBlocker.unblock();
};
ModalCmp.prototype._setCssClass = function (componentRef, className) {
this._renderer.setElementClass(componentRef.location.nativeElement, className, true);
};
ModalCmp.prototype._bdClick = function () {
if (this._enabled && this._bdDismiss) {
var opts = {
minClickBlockDuration: 400
};
return this._viewCtrl.dismiss(null, 'backdrop', opts);
}
};
ModalCmp.prototype._keyUp = function (ev) {
if (this._enabled && this._viewCtrl.isLast() && ev.keyCode === KEY_ESCAPE) {
this._bdClick();
}
};
ModalCmp.prototype.ngOnDestroy = function () {
(void 0) /* assert */;
this._gestureBlocker.destroy();
};
ModalCmp.decorators = [
{ type: Component, args: [{
selector: 'ion-modal',
template: '<ion-backdrop (click)="_bdClick()" [class.backdrop-no-tappable]="!_bdDismiss"></ion-backdrop>' +
'<div class="modal-wrapper">' +
'<div #viewport nav-viewport></div>' +
'</div>'
},] },
];
/** @nocollapse */
ModalCmp.ctorParameters = function () { return [
{ type: ComponentFactoryResolver, },
{ type: Renderer, },
{ type: ElementRef, },
{ type: NavParams, },
{ type: ViewController, },
{ type: GestureController, },
{ type: ModuleLoader, },
]; };
ModalCmp.propDecorators = {
'_viewport': [{ type: ViewChild, args: ['viewport', { read: ViewContainerRef },] },],
'_keyUp': [{ type: HostListener, args: ['body:keyup', ['$event'],] },],
};
return ModalCmp;
}());
export { ModalCmp };
//# sourceMappingURL=modal-component.js.map