Can I make my mat-sidenav responsive using opened property or open() method and flex-layout responsive api?
Like <mat-sidenav #sidenav mode="side" opened="true" [fxFlex.xs]="sidenav.close()">
You could consider using @angular/flex-alyout ObservableMedia to watch for media/breakpoint changes and update the mode or other properties accordingly depending on the active media level. This done by subscribing to an injected ObservableMedia service instance and checking the active media level. You can then bind opened and mode properties of <md-sidenav> via one way [] binding to your class properties. This logic can be put into services and/or attribute directives if needed.
Using/updating the properties instead of applying CSS changes will ensure that the proper animations occur.
TS:
import { Component } from '@angular/core';
import { MediaChange, ObservableMedia } from "@angular/flex-layout";
@Component({ ... })
export class AppComponent  {
  mode: string = 'side';
  opened: boolean = true;
  constructor(private media: ObservableMedia) {
    this.media.subscribe((mediaChange: MediaChange) => {
      this.mode = this.getMode(mediaChange);
      // this.opened = this.getOpened(mediaChange);
    });
  }
  private getMode(mediaChange: MediaChange): string {
    // set mode based on a breakpoint
    if (this.media.isActive('gt-sm')) {
      return 'side';
    } else {
      return 'over';
    }
  }
  // open/close as needed
  private getOpened(mediaChange: MediaChange): string { }
}
HTML:
<md-sidenav-container class="example-container">
  <md-sidenav #sidenav class="example-sidenav" [opened]="opened" [mode]="mode">
    Jolly good!
  </md-sidenav>
  <div class="example-sidenav-content">
    <p>Sidenav content</p>
    <button type="button" md-button (click)="sidenav.open()">
      Open sidenav
    </button>
  </div>
</md-sidenav-container>
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