import * as tslib_1 from "tslib";
import { Component, ContentChild, EventEmitter, HostListener, Output, ViewChild } from '@angular/core';
import { NavController } from '../../providers/nav-controller';
import { IonTabBar } from '../proxies';
import { IonRouterOutlet } from './ion-router-outlet';
var IonTabs = /** @class */ (function () {
function IonTabs(navCtrl) {
this.navCtrl = navCtrl;
this.ionTabsWillChange = new EventEmitter();
this.ionTabsDidChange = new EventEmitter();
}
/**
* @internal
*/
IonTabs.prototype.onPageSelected = function (detail) {
var stackId = detail.enteringView.stackId;
if (detail.tabSwitch && stackId !== undefined) {
if (this.tabBar) {
this.tabBar.selectedTab = stackId;
}
this.ionTabsWillChange.emit({ tab: stackId });
this.ionTabsDidChange.emit({ tab: stackId });
}
};
/**
* When a tab button is clicked, there are several scenarios:
* 1. If the selected tab is currently active (the tab button has been clicked
* again), then it should go to the root view for that tab.
*
* a. Get the saved root view from the router outlet. If the saved root view
* matches the tabRootUrl, set the route view to this view including the
* navigation extras.
* b. If the saved root view from the router outlet does
* not match, navigate to the tabRootUrl. No navigation extras are
* included.
*
* 2. If the current tab tab is not currently selected, get the last route
* view from the router outlet.
*
* a. If the last route view exists, navigate to that view including any
* navigation extras
* b. If the last route view doesn't exist, then navigate
* to the default tabRootUrl
*/
IonTabs.prototype.select = function (tabOrEvent) {
var isTabString = typeof tabOrEvent === 'string';
var tab = (isTabString) ? tabOrEvent : tabOrEvent.detail.tab;
var alreadySelected = this.outlet.getActiveStackId() === tab;
var tabRootUrl = this.outlet.tabsPrefix + "/" + tab;
/**
* If this is a nested tab, prevent the event
* from bubbling otherwise the outer tabs
* will respond to this event too, causing
* the app to get directed to the wrong place.
*/
if (!isTabString) {
tabOrEvent.stopPropagation();
}
if (alreadySelected) {
var activeStackId = this.outlet.getActiveStackId();
var activeView = this.outlet.getLastRouteView(activeStackId);
// If on root tab, do not navigate to root tab again
if (activeView.url === tabRootUrl) {
return;
}
var rootView = this.outlet.getRootView(tab);
var navigationExtras = rootView && tabRootUrl === rootView.url && rootView.savedExtras;
return this.navCtrl.navigateRoot(tabRootUrl, tslib_1.__assign({}, (navigationExtras), { animated: true, animationDirection: 'back' }));
}
else {
var lastRoute = this.outlet.getLastRouteView(tab);
/**
* If there is a lastRoute, goto that, otherwise goto the fallback url of the
* selected tab
*/
var url = lastRoute && lastRoute.url || tabRootUrl;
var navigationExtras = lastRoute && lastRoute.savedExtras;
return this.navCtrl.navigateRoot(url, tslib_1.__assign({}, (navigationExtras), { animated: true, animationDirection: 'back' }));
}
};
IonTabs.prototype.getSelected = function () {
return this.outlet.getActiveStackId();
};
IonTabs.ctorParameters = function () { return [
{ type: NavController }
]; };
tslib_1.__decorate([
ViewChild('outlet', { read: IonRouterOutlet, static: false })
], IonTabs.prototype, "outlet", void 0);
tslib_1.__decorate([
ContentChild(IonTabBar, { static: false })
], IonTabs.prototype, "tabBar", void 0);
tslib_1.__decorate([
Output()
], IonTabs.prototype, "ionTabsWillChange", void 0);
tslib_1.__decorate([
Output()
], IonTabs.prototype, "ionTabsDidChange", void 0);
tslib_1.__decorate([
HostListener('ionTabButtonClick', ['$event'])
], IonTabs.prototype, "select", null);
IonTabs = tslib_1.__decorate([
Component({
selector: 'ion-tabs',
template: "\n \n
\n \n
\n ",
styles: ["\n :host {\n display: flex;\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n\n flex-direction: column;\n\n width: 100%;\n height: 100%;\n\n contain: layout size style;\n z-index: $z-index-page-container;\n }\n .tabs-inner {\n position: relative;\n\n flex: 1;\n\n contain: layout size style;\n }"]
})
], IonTabs);
return IonTabs;
}());
export { IonTabs };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ion-tabs.js","sourceRoot":"ng://@ionic/angular/","sources":["directives/navigation/ion-tabs.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, EventEmitter, HostListener, Output, ViewChild } from '@angular/core';\n\nimport { NavController } from '../../providers/nav-controller';\nimport { IonTabBar } from '../proxies';\n\nimport { IonRouterOutlet } from './ion-router-outlet';\nimport { StackEvent } from './stack-utils';\n\n@Component({\n  selector: 'ion-tabs',\n  template: `\n    <ng-content select=\"[slot=top]\"></ng-content>\n    <div class=\"tabs-inner\">\n      <ion-router-outlet #outlet tabs=\"true\" (stackEvents)=\"onPageSelected($event)\"></ion-router-outlet>\n    </div>\n    <ng-content></ng-content>`,\n  styles: [`\n    :host {\n      display: flex;\n      position: absolute;\n      top: 0;\n      left: 0;\n      right: 0;\n      bottom: 0;\n\n      flex-direction: column;\n\n      width: 100%;\n      height: 100%;\n\n      contain: layout size style;\n      z-index: $z-index-page-container;\n    }\n    .tabs-inner {\n      position: relative;\n\n      flex: 1;\n\n      contain: layout size style;\n    }`\n  ]\n})\nexport class IonTabs {\n\n  @ViewChild('outlet', { read: IonRouterOutlet, static: false }) outlet: IonRouterOutlet;\n  @ContentChild(IonTabBar, { static: false }) tabBar: IonTabBar | undefined;\n\n  @Output() ionTabsWillChange = new EventEmitter<{ tab: string }>();\n  @Output() ionTabsDidChange = new EventEmitter<{ tab: string }>();\n\n  constructor(\n    private navCtrl: NavController,\n  ) { }\n\n  /**\n   * @internal\n   */\n  onPageSelected(detail: StackEvent) {\n    const stackId = detail.enteringView.stackId;\n    if (detail.tabSwitch && stackId !== undefined) {\n      if (this.tabBar) {\n        this.tabBar.selectedTab = stackId;\n      }\n      this.ionTabsWillChange.emit({ tab: stackId });\n      this.ionTabsDidChange.emit({ tab: stackId });\n    }\n  }\n\n  /**\n   * When a tab button is clicked, there are several scenarios:\n   * 1. If the selected tab is currently active (the tab button has been clicked\n   *    again), then it should go to the root view for that tab.\n   *\n   *   a. Get the saved root view from the router outlet. If the saved root view\n   *      matches the tabRootUrl, set the route view to this view including the\n   *      navigation extras.\n   *   b. If the saved root view from the router outlet does\n   *      not match, navigate to the tabRootUrl. No navigation extras are\n   *      included.\n   *\n   * 2. If the current tab tab is not currently selected, get the last route\n   *    view from the router outlet.\n   *\n   *   a. If the last route view exists, navigate to that view including any\n   *      navigation extras\n   *   b. If the last route view doesn't exist, then navigate\n   *      to the default tabRootUrl\n   */\n  @HostListener('ionTabButtonClick', ['$event'])\n  select(tabOrEvent: string | CustomEvent) {\n    const isTabString = typeof tabOrEvent === 'string';\n    const tab = (isTabString) ? tabOrEvent : (tabOrEvent as CustomEvent).detail.tab;\n    const alreadySelected = this.outlet.getActiveStackId() === tab;\n    const tabRootUrl = `${this.outlet.tabsPrefix}/${tab}`;\n\n    /**\n     * If this is a nested tab, prevent the event\n     * from bubbling otherwise the outer tabs\n     * will respond to this event too, causing\n     * the app to get directed to the wrong place.\n     */\n    if (!isTabString) {\n      (tabOrEvent as CustomEvent).stopPropagation();\n    }\n\n    if (alreadySelected) {\n      const activeStackId = this.outlet.getActiveStackId();\n      const activeView = this.outlet.getLastRouteView(activeStackId);\n\n      // If on root tab, do not navigate to root tab again\n      if (activeView.url === tabRootUrl) { return; }\n\n      const rootView = this.outlet.getRootView(tab);\n      const navigationExtras = rootView && tabRootUrl === rootView.url && rootView.savedExtras;\n      return this.navCtrl.navigateRoot(tabRootUrl, {\n        ...(navigationExtras),\n        animated: true,\n        animationDirection: 'back',\n      });\n    } else {\n      const lastRoute = this.outlet.getLastRouteView(tab);\n      /**\n       * If there is a lastRoute, goto that, otherwise goto the fallback url of the\n       * selected tab\n       */\n      const url = lastRoute && lastRoute.url || tabRootUrl;\n      const navigationExtras = lastRoute && lastRoute.savedExtras;\n\n      return this.navCtrl.navigateRoot(url, {\n        ...(navigationExtras),\n        animated: true,\n        animationDirection: 'back',\n      });\n    }\n  }\n\n  getSelected(): string | undefined {\n    return this.outlet.getActiveStackId();\n  }\n}\n"]}