I'm trying to create a nested mat-menu items for my angular app. I got some solutions only where the nested options would appear as a pop-up, where i'm expecting it to be a drop-down where we could choose the menu lying under it when triggered.
I tried using the mat-sidenav-container and gave a few conditions to open the menu based on the condition
<mat-nav-list>
<mat-list-item (click)="showSubmenu = !showSubmenu" class="parent">
<span class="full-width" *ngIf="isExpanded ||
isShowing">Users</span>
<mat-icon mat-list-icon>supervisor_account</mat-icon>
<mat-icon class="menu-button" [ngClass]="{'rotated' :
showSubmenu}" *ngIf="isExpanded ||
isShowing">expand_more</maticon>
</mat-list-item>
<div class="submenu" [ngClass]="{'expanded' : showSubmenu}"
*ngIf="isShowing || isExpanded">
<div [routerLink]="['users']" routerLinkActive="active"
(click)="toggleSide()">Add Users</div>
</div>
</mat-nav-list>
``in the above code. i would like to nest Manage Users under Users list item``` and my .ts file follows:
showSubmenu: boolean = false;
isShowing = false;
showSubSubMenu: boolean = false;
isExpanded = true;
i would like the expected result to be like this (https://stackblitz.com/edit/material-sidenav-example?file=app%2Fsidenav-autosize-example.html)
I did try using the same element as in the above link, but i couldn't get it working. i might be doing a very silly mistake. Thanks in advance !!
You can implement a generic menu list item, Here is an example:
https://dynamic-nested-sidenav-menu.stackblitz.io
Here is a link to the source: https://stackblitz.com/edit/dynamic-nested-sidenav-menu?file=app%2Fmenu-list-item%2Fmenu-list-item.component.ts
I did it like this
<mat-nav-list>
<mat-accordion>
<mat-expansion-panel style="box-shadow: none">
<mat-expansion-panel-header style="margin-left: -8px">
<mat-panel-title> <mat-icon>code</mat-icon> Developers </mat-panel-title>
</mat-expansion-panel-header>
<a
mat-list-item
routerLink="test"
class="sidenav__list-item list-sub-item"
[routerLinkActive]="['active']"
(click)="handleClickEvent($event)"
>
<mat-icon>api</mat-icon>
<span style="padding-top: 11px;">Api Keys</span>
</a>
<a
mat-list-item
routerLink="test1"
class="sidenav__list-item list-sub-item"
[routerLinkActive]="['active']"
(click)="handleClickEvent($event)"
>
<mat-icon>webhook</mat-icon>
<span style="padding-top: 11px;">Web Hooks</span>
</a>
</mat-expansion-panel>
</mat-accordion>
</mat-nav-list>

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With