-
Notifications
You must be signed in to change notification settings - Fork 13.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat(angular): use tabs without router #29786
Conversation
The latest updates on your projects. Learn more about Vercel for Git ↗︎
|
@@ -39,8 +41,29 @@ export abstract class IonTabs implements AfterContentInit, AfterContentChecked { | |||
|
|||
private tabBarSlot = 'bottom'; | |||
|
|||
private hasTab = false; | |||
private selectedTab?: any; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Using any
here is overriding the type signature of treating it as optionally defined (undefined
). This means you are missing out on potential errors on L203, L206 and L212.
I would recommend minimally updating the type signature to:
private selectedTab?: { tab: string };
and then handling those type errors that arise for the selectedTab
not being defined.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
} | ||
|
||
if (leavingTab?.tab !== selectedTab.tab) { | ||
if (leavingTab) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I believe this should be checking that the el
is defined, not the leavingTab
, since it will based on the check on L206.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
} | ||
|
||
private tabSwitch(): void { | ||
const selectedTab = this.selectedTab; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
~ These two lines could be minimized to:
const { selectedTab, leavingTab } = this;
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@@ -11,11 +11,13 @@ import { IonRouterOutlet } from './ion-router-outlet'; | |||
<ng-content select="[slot=top]"></ng-content> | |||
<div class="tabs-inner" #tabsInner> | |||
<ion-router-outlet | |||
*ngIf="tabs?.length === 0" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can tabs
be undefined? The type signature implies not.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
After reviewing it further, it seems that there isn't a moment that it would be undefined. No issues were found when removing the optional chain. f6132ca
@@ -11,11 +12,13 @@ import { IonRouterOutlet } from './router-outlet'; | |||
<ng-content select="[slot=top]"></ng-content> | |||
<div class="tabs-inner" #tabsInner> | |||
<ion-router-outlet | |||
*ngIf="tabs?.length === 0" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Similar feedback here if tabs
can be undefined.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
/** | ||
* Note: These must be redeclared on each child class since it needs | ||
* access to generated components such as IonRouterOutlet and IonTabBar. | ||
*/ | ||
abstract outlet: any; | ||
abstract tabBar: any; | ||
abstract tabBars: any; | ||
abstract tabs: any; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Minimally the type signature should be:
abstract tabs: QueryList<any>;
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Co-authored-by: Sean Perkins <13732623+sean-perkins@users.noreply.github.com>
Co-authored-by: Sean Perkins <13732623+sean-perkins@users.noreply.github.com>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Tested the latest dev build in:
- A new Angular tabs starter app (NgModule)
- A new Angular tabs starter app (Standalone)
- A new Angular tabs starter app with
ion-router-outlet
removed and<ion-tab>
components added containing only text content (NgModule) - A new Angular tabs starter app with
ion-router-outlet
removed and<ion-tab>
components added containing only text content (Standalone) - The Ionic Angular Conference App
Everything is working correctly. Great job on this! 🎉
Issue number: part of #25184
This PR does not completely close the issue since it only addresses the Angular portion. The other frameworks will be done through other PRs.
What is the current behavior?
Angular: Developers are defaulted to have
ion-router-outlet
whenion-tabs
is in their app. This means that developers are forced to tie their tabs to a router.What is the new behavior?
ion-tabs
can be used without a router outlet as long asion-tab
is a child./tabs-basic
Does this introduce a breaking change?
Developers who are still using
ion-tabs
withion-router-outlet
will not experience any changes. This feature PR introduces another option to useion-tabs
, no changes for the current implementation.Other information
Dev build: 8.2.8-dev.11724363936.1f6132ca