Angular Material Side Bar with “Half” side mode

前端 未结 3 1874
迷失自我
迷失自我 2021-02-02 14:15

I am working on the dynamic side bar for our project, basically what we want to do is to set up a dynamic side bar when user click on the side bar it will spread when user click

相关标签:
3条回答
  • 2021-02-02 14:54

    There is a feature request for this https://github.com/angular/material2/issues/1728

    if you read the comments you'll also find a few examples on how to implement it yourself while it's not officialy available.

    0 讨论(0)
  • 2021-02-02 15:04

    I did this with a bit of CSS

        mat-sidenav:not(.mat-drawer-opened) {
        transform: translate3d(0, 0, 0) !important;
        visibility: visible !important;
        width: 60px !important;
        overflow: hidden;
      }
    

    So when the draw is NOT open, the width of the sidenav is 60px and not 0. Just enough to show your icons.

    OK, the next issue is that you'll need to hide a bunch of stuff like button name and other descriptive stuff, for me I need to change the height of the profile image and hide additional text. I did this in the same way as above using the :not selector:

      mat-sidenav:not(.mat-drawer-opened) div.leftNav div.navProfile img {
        width: 40px; margin: 16px 0 0px 0;
      }
      mat-sidenav:not(.mat-drawer-opened) .navTitle,
      mat-sidenav:not(.mat-drawer-opened) .profileTitle {
        display: none;
      }
    

    When collapsed I didn't want to show the button names so I wrapped the name in a *ngIf

     <span class="navName" *ngIf="opened">{{ page?.name }} </span>
    

    This should work, and it does but there is a problem. The ngIf is bound to the opened event and you will notice a delay when the event is firing (to account for it animation) to show your labels when the drawer is open.

    To fix this I had to delve into the api of sidenav and found an eventemitter call openedStart and closedStart. I created a new bool in the component class,

    showNavLabels: boolean;
    

    then bound the events to this bool in the HTML.

      <mat-sidenav class="sidenav" #sidenav mode="side" [(opened)]="opened"
          (openedStart)='showNavLabels = !showNavLabels'
          (closedStart)='showNavLabels = !showNavLabels' >
    

    I am sure there is better way as I am not that experienced with Angular yet.

    I hope it helps you out.

    0 讨论(0)
  • 2021-02-02 15:05

    Option 1: Generating Automatically:

    You can create a navigation component from templates provided by Material itself using 'Angular CLI component schematics'

    ng generate @angular/material:nav your-component-name
    

    The above command will generate a new component that includes a toolbar with the app name and a responsive side nav based on Material breakpoints. See more about angular material schematics here


    Option 2: Implementing Manually:

    To implement that, you just have to refer these two links:

    • Resizing Sidenav | Angular Material
    • Navigation List | Angular Material

    glance through the following code. Implementation will be something like this:

    <mat-drawer-container class="example-container mat-typography" autosize>
      <mat-drawer #drawer mode="side" disableClose="true" opened="true">
        <button mat-mini-fab (click)="isExpanded = !isExpanded" color="warn" style="margin: 10px;">
          <mat-icon aria-label="Menu">menu</mat-icon>
        </button>
    
        <mat-nav-list>
          <mat-list-item>
            <mat-icon mat-list-icon>person</mat-icon>
            <h4 mat-line *ngIf="isExpanded">Management A</h4>
          </mat-list-item>
          <mat-list-item>
            <mat-icon mat-list-icon>assignment</mat-icon>
            <h4 mat-line *ngIf="isExpanded">Management B</h4>
          </mat-list-item>
          <mat-list-item>
            <mat-icon mat-list-icon>domain</mat-icon>
            <h4 mat-line *ngIf="isExpanded">Management C</h4>
          </mat-list-item>
          <mat-list-item>
            <mat-icon mat-list-icon>folder_shared</mat-icon>
            <h4 mat-line *ngIf="isExpanded">Management X</h4>
          </mat-list-item>
        </mat-nav-list>
      </mat-drawer>
    
      <div class="example-sidenav-content">
        You cards and screen Contents goes here..
        Will be pushed towards right on expanding side navbar.
      </div>
    </mat-drawer-container>
    

    0 讨论(0)
提交回复
热议问题