You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

app.component.ts 1.3KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. import {Component, OnInit, TemplateRef, ViewChild} from '@angular/core';
  2. import {MediaChange, ObservableMedia} from '@angular/flex-layout';
  3. import {CgBusyDefaults} from 'angular-busy2';
  4. @Component({
  5. selector: 'app-root',
  6. templateUrl: './app.component.html',
  7. styleUrls: ['./app.component.css']
  8. })
  9. export class AppComponent implements OnInit {
  10. title = 'Site Status';
  11. uiStatus = {
  12. sideMenu: {
  13. opened: false,
  14. mode: 'over'
  15. },
  16. toolbar: {
  17. displayMenuButton: true
  18. }
  19. };
  20. mediaWatcher = null;
  21. @ViewChild('cgBusyTemplate')
  22. private cgBusyTemplate: TemplateRef<any>;
  23. constructor(media: ObservableMedia, private busyDefaults: CgBusyDefaults) {
  24. this.mediaWatcher = media.subscribe((change: MediaChange) => {
  25. if (change.mqAlias === 'sm' || change.mqAlias === 'xs') {
  26. this.uiStatus.sideMenu.opened = false;
  27. this.uiStatus.sideMenu.mode = 'over';
  28. this.uiStatus.toolbar.displayMenuButton = true;
  29. } else {
  30. this.uiStatus.sideMenu.opened = true;
  31. this.uiStatus.sideMenu.mode = 'side';
  32. this.uiStatus.toolbar.displayMenuButton = false;
  33. }
  34. });
  35. }
  36. ngOnInit() {
  37. this.busyDefaults.templateRef = this.cgBusyTemplate;
  38. }
  39. }