Skip to content

Commit

Permalink
fix(nav): zIndex in overlays
Browse files Browse the repository at this point in the history
  • Loading branch information
manucorporat authored and adamdbradley committed Nov 16, 2016
1 parent 7201999 commit 70f8a8e
Show file tree
Hide file tree
Showing 5 changed files with 20 additions and 6 deletions.
3 changes: 2 additions & 1 deletion src/components/action-sheet/test/basic/app-module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -33,9 +33,10 @@ export class E2EPage {
}
},
{
text: 'Play',
text: 'Play (open modal)',
icon: 'arrow-dropright-circle',
handler: () => {
this.result = 'Play (open modal)';
let modal = this.modalCtrl.create(ModalPage);
modal.present();

Expand Down
2 changes: 1 addition & 1 deletion src/components/app/app-root.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ export const AppRootToken = new OpaqueToken('USERROOT');
'<div #modalPortal overlay-portal></div>' +
'<div #overlayPortal overlay-portal></div>' +
'<div #loadingPortal class="loading-portal" overlay-portal></div>' +
'<div #toastPortal class="toast-portal" overlay-portal></div>' +
'<div #toastPortal class="toast-portal" [overlay-portal]="10000"></div>' +
'<div class="click-block"></div>'
})
export class IonicApp extends Ion implements OnInit {
Expand Down
10 changes: 8 additions & 2 deletions src/components/nav/overlay-portal.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { ComponentFactoryResolver, Directive, ElementRef, forwardRef, Inject, NgZone, Optional, Renderer, ViewContainerRef } from '@angular/core';
import { ComponentFactoryResolver, Directive, ElementRef, forwardRef, Inject, Input, NgZone, Optional, Renderer, ViewContainerRef } from '@angular/core';

import { App } from '../app/app';
import { Config } from '../../config/config';
Expand All @@ -12,7 +12,7 @@ import { TransitionController } from '../../transitions/transition-controller';
* @private
*/
@Directive({
selector: '[overlay-portal]'
selector: '[overlay-portal]',
})
export class OverlayPortal extends NavControllerBase {
constructor(
Expand All @@ -38,4 +38,10 @@ export class OverlayPortal extends NavControllerBase {
app.viewDidLeave.subscribe(this.dismissPageChangeViews.bind(this));
}

@Input('overlay-portal')
set _overlayPortal(val: number) {
this._zIndexOffset = (val || 0);
}

}

1 change: 1 addition & 0 deletions src/navigation/nav-controller-base.ts
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ export class NavControllerBase extends Ion implements NavController {
_trnsTm: boolean = false;
_viewport: ViewContainerRef;
_views: ViewController[] = [];
_zIndexOffset: number = 0;

viewDidLoad: EventEmitter<any> = new EventEmitter();
viewWillEnter: EventEmitter<any> = new EventEmitter();
Expand Down
10 changes: 8 additions & 2 deletions src/navigation/nav-util.ts
Original file line number Diff line number Diff line change
Expand Up @@ -51,8 +51,15 @@ export function convertToViews(linker: DeepLinker, pages: any[]): ViewController
return views;
}

let portalZindex = 9999;

export function setZIndex(nav: NavControllerBase, enteringView: ViewController, leavingView: ViewController, direction: string, renderer: Renderer) {
if (enteringView) {
if (nav._isPortal) {
enteringView._setZIndex(nav._zIndexOffset + portalZindex, renderer);
portalZindex++;
return;
}

leavingView = leavingView || nav.getPrevious(enteringView);

Expand All @@ -65,7 +72,7 @@ export function setZIndex(nav: NavControllerBase, enteringView: ViewController,
}

} else {
enteringView._setZIndex(nav._isPortal ? PORTAL_ZINDEX : INIT_ZINDEX, renderer);
enteringView._setZIndex(INIT_ZINDEX + nav._zIndexOffset, renderer);
}
}
}
Expand Down Expand Up @@ -184,7 +191,6 @@ export enum ViewState {
}

export const INIT_ZINDEX = 100;
export const PORTAL_ZINDEX = 9999;

export const DIRECTION_BACK = 'back';
export const DIRECTION_FORWARD = 'forward';
Expand Down

0 comments on commit 70f8a8e

Please sign in to comment.