From 52a98a101af6c29a33051d42c990e063922bc3d7 Mon Sep 17 00:00:00 2001 From: Manuel Mtz-Almeida Date: Tue, 13 Jun 2017 01:43:49 +0200 Subject: [PATCH] refactor(overlay): simplify focusOutActiveElement --- src/components/action-sheet/action-sheet-component.ts | 2 -- src/components/alert/alert-component.ts | 8 -------- src/components/app/app.ts | 3 +-- src/components/app/overlay-portal.ts | 4 +--- src/components/loading/loading-component.ts | 2 -- src/components/nav/nav.ts | 4 +--- src/components/nav/test/nav.spec.ts | 3 --- src/components/picker/picker-component.ts | 2 -- src/components/popover/popover-component.ts | 1 - src/components/tabs/tab.ts | 4 +--- src/components/toast/toast.ts | 1 + src/navigation/nav-controller-base.ts | 4 +--- src/util/mock-providers.ts | 7 ------- 13 files changed, 6 insertions(+), 39 deletions(-) diff --git a/src/components/action-sheet/action-sheet-component.ts b/src/components/action-sheet/action-sheet-component.ts index 7cbb802ce6b..052f77c981c 100644 --- a/src/components/action-sheet/action-sheet-component.ts +++ b/src/components/action-sheet/action-sheet-component.ts @@ -117,8 +117,6 @@ export class ActionSheetCmp { } ionViewDidEnter() { - this._plt.focusOutActiveElement(); - const focusableEle = this._elementRef.nativeElement.querySelector('button'); if (focusableEle) { focusableEle.focus(); diff --git a/src/components/alert/alert-component.ts b/src/components/alert/alert-component.ts index abb1771b18f..3a58732456e 100644 --- a/src/components/alert/alert-component.ts +++ b/src/components/alert/alert-component.ts @@ -194,18 +194,10 @@ export class AlertCmp { } ionViewDidLeave() { - this._plt.focusOutActiveElement(); this.gestureBlocker.unblock(); } - ionViewWillLeave() { - this._plt.focusOutActiveElement(); - } - ionViewDidEnter() { - // focus out of the active element - this._plt.focusOutActiveElement(); - // set focus on the first input or button in the alert // note that this does not always work and bring up the keyboard on // devices since the focus command must come from the user's touch event diff --git a/src/components/app/app.ts b/src/components/app/app.ts index 3b10041b9cf..0da00dbdaee 100644 --- a/src/components/app/app.ts +++ b/src/components/app/app.ts @@ -241,7 +241,6 @@ export class App { // TODO: move _setNav() to the earlier stages of NavController. _queueTrns() enteringView._setNav(portal); - opts.keyboardClose = false; opts.direction = DIRECTION_FORWARD; if (!opts.animation) { @@ -249,7 +248,7 @@ export class App { } enteringView.setLeavingOpts({ - keyboardClose: false, + keyboardClose: opts.keyboardClose, direction: DIRECTION_BACK, animation: enteringView.getTransitionName(DIRECTION_BACK), ev: opts.ev diff --git a/src/components/app/overlay-portal.ts b/src/components/app/overlay-portal.ts index 78b213efc35..e4db26d1ca7 100644 --- a/src/components/app/overlay-portal.ts +++ b/src/components/app/overlay-portal.ts @@ -5,7 +5,6 @@ import { Config } from '../../config/config'; import { DeepLinker } from '../../navigation/deep-linker'; import { DomController } from '../../platform/dom-controller'; import { GestureController } from '../../gestures/gesture-controller'; -import { Keyboard } from '../../platform/keyboard'; import { NavControllerBase } from '../../navigation/nav-controller-base'; import { Platform } from '../../platform/platform'; import { TransitionController } from '../../transitions/transition-controller'; @@ -22,7 +21,6 @@ export class OverlayPortal extends NavControllerBase { @Inject(forwardRef(() => App)) app: App, config: Config, plt: Platform, - keyboard: Keyboard, elementRef: ElementRef, zone: NgZone, renderer: Renderer, @@ -34,7 +32,7 @@ export class OverlayPortal extends NavControllerBase { domCtrl: DomController, errHandler: ErrorHandler ) { - super(null, app, config, plt, keyboard, elementRef, zone, renderer, cfr, gestureCtrl, transCtrl, linker, domCtrl, errHandler); + super(null, app, config, plt, elementRef, zone, renderer, cfr, gestureCtrl, transCtrl, linker, domCtrl, errHandler); this._isPortal = true; this._init = true; this.setViewport(viewPort); diff --git a/src/components/loading/loading-component.ts b/src/components/loading/loading-component.ts index a278cf60a9c..04551e6b182 100644 --- a/src/components/loading/loading-component.ts +++ b/src/components/loading/loading-component.ts @@ -79,8 +79,6 @@ export class LoadingCmp { } ionViewDidEnter() { - this._plt.focusOutActiveElement(); - // If there is a duration, dismiss after that amount of time if ( this.d && this.d.duration ) { this.durationTimeout = setTimeout(() => this.dismiss('backdrop'), this.d.duration); diff --git a/src/components/nav/nav.ts b/src/components/nav/nav.ts index c9c5c5a75a3..1aeba18973f 100644 --- a/src/components/nav/nav.ts +++ b/src/components/nav/nav.ts @@ -5,7 +5,6 @@ import { Config } from '../../config/config'; import { DeepLinker } from '../../navigation/deep-linker'; import { DomController } from '../../platform/dom-controller'; import { GestureController } from '../../gestures/gesture-controller'; -import { Keyboard } from '../../platform/keyboard'; import { Nav as INav } from '../../navigation/nav-interfaces'; import { NavController } from '../../navigation/nav-controller'; import { NavControllerBase } from '../../navigation/nav-controller-base'; @@ -66,7 +65,6 @@ export class Nav extends NavControllerBase implements AfterViewInit, RootNode, I app: App, config: Config, plt: Platform, - keyboard: Keyboard, elementRef: ElementRef, zone: NgZone, renderer: Renderer, @@ -77,7 +75,7 @@ export class Nav extends NavControllerBase implements AfterViewInit, RootNode, I domCtrl: DomController, errHandler: ErrorHandler ) { - super(parent, app, config, plt, keyboard, elementRef, zone, renderer, cfr, gestureCtrl, transCtrl, linker, domCtrl, errHandler); + super(parent, app, config, plt, elementRef, zone, renderer, cfr, gestureCtrl, transCtrl, linker, domCtrl, errHandler); if (viewCtrl) { // an ion-nav can also act as an ion-page within a parent ion-nav diff --git a/src/components/nav/test/nav.spec.ts b/src/components/nav/test/nav.spec.ts index 075213abdb4..d7c9420fc4a 100644 --- a/src/components/nav/test/nav.spec.ts +++ b/src/components/nav/test/nav.spec.ts @@ -1,7 +1,6 @@ import { Nav } from '../nav'; import { GestureController } from '../../../gestures/gesture-controller'; -import { Keyboard } from '../../../platform/keyboard'; import { mockApp, mockConfig, @@ -88,7 +87,6 @@ function getNav() { const app = mockApp(config, platform); const zone = mockZone(); const dom = mockDomController(platform); - const keyboard = new Keyboard(config, platform, zone, dom); const elementRef = mockElementRef(); const renderer = mockRenderer(); const componentFactoryResolver: any = null; @@ -101,7 +99,6 @@ function getNav() { app, config, platform, - keyboard, elementRef, zone, renderer, diff --git a/src/components/picker/picker-component.ts b/src/components/picker/picker-component.ts index 3bafcf4b494..2a745a09176 100644 --- a/src/components/picker/picker-component.ts +++ b/src/components/picker/picker-component.ts @@ -161,8 +161,6 @@ export class PickerCmp { } ionViewDidEnter() { - this._plt.focusOutActiveElement(); - let focusableEle = this._elementRef.nativeElement.querySelector('button'); if (focusableEle) { focusableEle.focus(); diff --git a/src/components/popover/popover-component.ts b/src/components/popover/popover-component.ts index 275f005627b..f03a0b3db08 100644 --- a/src/components/popover/popover-component.ts +++ b/src/components/popover/popover-component.ts @@ -67,7 +67,6 @@ export class PopoverCmp { } ionViewPreLoad() { - this._plt.focusOutActiveElement(); this._load(this._navParams.data.component); } diff --git a/src/components/tabs/tab.ts b/src/components/tabs/tab.ts index 416e7f49bff..0ca52f2df7e 100644 --- a/src/components/tabs/tab.ts +++ b/src/components/tabs/tab.ts @@ -6,7 +6,6 @@ import { DeepLinker } from '../../navigation/deep-linker'; import { DomController } from '../../platform/dom-controller'; import { GestureController } from '../../gestures/gesture-controller'; import { isTrueProperty } from '../../util/util'; -import { Keyboard } from '../../platform/keyboard'; import { Tab as ITab } from '../../navigation/nav-interfaces'; import { NavControllerBase } from '../../navigation/nav-controller-base'; import { NavOptions } from '../../navigation/nav-util'; @@ -255,7 +254,6 @@ export class Tab extends NavControllerBase implements ITab { app: App, config: Config, plt: Platform, - keyboard: Keyboard, elementRef: ElementRef, zone: NgZone, renderer: Renderer, @@ -268,7 +266,7 @@ export class Tab extends NavControllerBase implements ITab { errHandler: ErrorHandler ) { // A Tab is a NavController for its child pages - super(parent, app, config, plt, keyboard, elementRef, zone, renderer, cfr, gestureCtrl, transCtrl, linker, _dom, errHandler); + super(parent, app, config, plt, elementRef, zone, renderer, cfr, gestureCtrl, transCtrl, linker, _dom, errHandler); this.id = parent.add(this); this._tabsHideOnSubPages = config.getBoolean('tabsHideOnSubPages'); diff --git a/src/components/toast/toast.ts b/src/components/toast/toast.ts index f51b8409720..9fe370491ae 100644 --- a/src/components/toast/toast.ts +++ b/src/components/toast/toast.ts @@ -98,6 +98,7 @@ export class Toast extends ViewController { */ present(navOptions: NavOptions = {}): Promise { navOptions.disableApp = false; + navOptions.keyboardClose = false; return this._app.present(this, navOptions, PORTAL_TOAST); } diff --git a/src/navigation/nav-controller-base.ts b/src/navigation/nav-controller-base.ts index 48d07affb9f..020b3c9c941 100644 --- a/src/navigation/nav-controller-base.ts +++ b/src/navigation/nav-controller-base.ts @@ -12,7 +12,6 @@ import { GestureController } from '../gestures/gesture-controller'; import { isBlank, isNumber, isPresent, isTrueProperty, assert, removeArrayItem } from '../util/util'; import { isViewController, ViewController } from './view-controller'; import { Ion } from '../components/ion'; -import { Keyboard } from '../platform/keyboard'; import { NavController } from './nav-controller'; import { NavParams } from './nav-params'; import { Platform } from '../platform/platform'; @@ -63,7 +62,6 @@ export class NavControllerBase extends Ion implements NavController { public _app: App, public config: Config, public plt: Platform, - public _keyboard: Keyboard, elementRef: ElementRef, public _zone: NgZone, renderer: Renderer, @@ -760,7 +758,7 @@ export class NavControllerBase extends Ion implements NavController { if (opts.keyboardClose !== false) { // the keyboard is still open! // no problem, let's just close for them - this._keyboard.close(); + this.plt.focusOutActiveElement(); } } diff --git a/src/util/mock-providers.ts b/src/util/mock-providers.ts index 404d1368763..0b301bc4659 100644 --- a/src/util/mock-providers.ts +++ b/src/util/mock-providers.ts @@ -10,7 +10,6 @@ import { DomController } from '../platform/dom-controller'; import { GestureController } from '../gestures/gesture-controller'; import { Haptic } from '../tap-click/haptic'; import { IonicApp } from '../components/app/app-root'; -import { Keyboard } from '../platform/keyboard'; import { Menu } from '../components/menu/menu'; import { NavOptions } from '../navigation/nav-util'; import { NavControllerBase } from '../navigation/nav-controller-base'; @@ -403,7 +402,6 @@ export function mockNavController(): NavControllerBase { let app = mockApp(config, platform); let zone = mockZone(); let dom = mockDomController(platform); - let keyboard = new Keyboard(config, platform, zone, dom); let elementRef = mockElementRef(); let renderer = mockRenderer(); let componentFactoryResolver: any = null; @@ -415,7 +413,6 @@ export function mockNavController(): NavControllerBase { app, config, platform, - keyboard, elementRef, zone, renderer, @@ -447,7 +444,6 @@ export function mockNavController(): NavControllerBase { export function mockOverlayPortal(app: App, config: Config, plt: MockPlatform): OverlayPortal { let zone = mockZone(); let dom = mockDomController(plt); - let keyboard = new Keyboard(config, plt, zone, dom); let elementRef = mockElementRef(); let renderer = mockRenderer(); let componentFactoryResolver: any = null; @@ -460,7 +456,6 @@ export function mockOverlayPortal(app: App, config: Config, plt: MockPlatform): app, config, plt, - keyboard, elementRef, zone, renderer, @@ -480,7 +475,6 @@ export function mockTab(parentTabs: Tabs): Tab { let app = (parentTabs)._app || mockApp(config, platform); let zone = mockZone(); let dom = mockDomController(platform); - let keyboard = new Keyboard(config, platform, zone, dom); let elementRef = mockElementRef(); let renderer = mockRenderer(); let changeDetectorRef = mockChangeDetectorRef(); @@ -493,7 +487,6 @@ export function mockTab(parentTabs: Tabs): Tab { app, config, platform, - keyboard, elementRef, zone, renderer,