123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- import { Component, ComponentFactoryResolver, ElementRef, HostListener, Renderer, ViewChild, ViewContainerRef } from '@angular/core';
- import { Config } from '../../config/config';
- import { KEY_ESCAPE } from '../../platform/key';
- import { NavParams } from '../../navigation/nav-params';
- import { ViewController } from '../../navigation/view-controller';
- import { BLOCK_ALL, GestureController } from '../../gestures/gesture-controller';
- import { ModuleLoader } from '../../util/module-loader';
- /**
- * @hidden
- */
- export class PopoverCmp {
- constructor(_cfr, _elementRef, _renderer, _config, _navParams, _viewCtrl, gestureCtrl, moduleLoader) {
- this._cfr = _cfr;
- this._elementRef = _elementRef;
- this._renderer = _renderer;
- this._config = _config;
- this._navParams = _navParams;
- this._viewCtrl = _viewCtrl;
- this.moduleLoader = moduleLoader;
- this._gestureBlocker = gestureCtrl.createBlocker(BLOCK_ALL);
- this.d = _navParams.data.opts;
- _renderer.setElementClass(_elementRef.nativeElement, `popover-${_config.get('mode')}`, true);
- if (this.d.cssClass) {
- this.d.cssClass.split(' ').forEach(cssClass => {
- // Make sure the class isn't whitespace, otherwise it throws exceptions
- if (cssClass.trim() !== '')
- _renderer.setElementClass(_elementRef.nativeElement, cssClass, true);
- });
- }
- this.id = (++popoverIds);
- }
- ionViewPreLoad() {
- this._load(this._navParams.data.component);
- }
- _load(component) {
- if (component) {
- let cfr = this.moduleLoader.getComponentFactoryResolver(component);
- if (!cfr) {
- cfr = this._cfr;
- }
- const componentFactory = cfr.resolveComponentFactory(component);
- // ******** DOM WRITE ****************
- const componentRef = this._viewport.createComponent(componentFactory, this._viewport.length, this._viewport.parentInjector, []);
- this._viewCtrl._setInstance(componentRef.instance);
- this._enabled = true;
- // Subscribe to events in order to block gestures
- // TODO, should we unsubscribe? memory leak?
- this._viewCtrl.willEnter.subscribe(this._viewWillEnter.bind(this));
- this._viewCtrl.didLeave.subscribe(this._viewDidLeave.bind(this));
- }
- }
- _viewWillEnter() {
- this._gestureBlocker.block();
- }
- _viewDidLeave() {
- this._gestureBlocker.unblock();
- }
- _setCssClass(componentRef, className) {
- this._renderer.setElementClass(componentRef.location.nativeElement, className, true);
- }
- _bdClick() {
- if (this._enabled && this.d.enableBackdropDismiss) {
- return this._viewCtrl.dismiss(null, 'backdrop');
- }
- }
- _keyUp(ev) {
- if (this._enabled && ev.keyCode === KEY_ESCAPE && this._viewCtrl.isLast()) {
- this._bdClick();
- }
- }
- ngOnDestroy() {
- (void 0) /* assert */;
- this._gestureBlocker.destroy();
- }
- }
- PopoverCmp.decorators = [
- { type: Component, args: [{
- selector: 'ion-popover',
- template: '<ion-backdrop (click)="_bdClick()" [hidden]="!d.showBackdrop"></ion-backdrop>' +
- '<div class="popover-wrapper">' +
- '<div class="popover-arrow"></div>' +
- '<div class="popover-content">' +
- '<div class="popover-viewport">' +
- '<div #viewport nav-viewport></div>' +
- '</div>' +
- '</div>' +
- '</div>'
- },] },
- ];
- /** @nocollapse */
- PopoverCmp.ctorParameters = () => [
- { type: ComponentFactoryResolver, },
- { type: ElementRef, },
- { type: Renderer, },
- { type: Config, },
- { type: NavParams, },
- { type: ViewController, },
- { type: GestureController, },
- { type: ModuleLoader, },
- ];
- PopoverCmp.propDecorators = {
- '_viewport': [{ type: ViewChild, args: ['viewport', { read: ViewContainerRef },] },],
- '_keyUp': [{ type: HostListener, args: ['body:keyup', ['$event'],] },],
- };
- let popoverIds = -1;
- //# sourceMappingURL=popover-component.js.map
|