File

src/app/@core/data/state.service.ts

Index

Properties
Methods

Constructor

constructor(directionService: NbLayoutDirectionService)
Parameters :
Name Type Optional
directionService NbLayoutDirectionService no

Methods

getLayoutStates
getLayoutStates()
Returns : Observable<any[]>
getSidebarStates
getSidebarStates()
Returns : Observable<any[]>
ngOnDestroy
ngOnDestroy()
Returns : void
onLayoutState
onLayoutState()
Returns : Observable<any>
onSidebarState
onSidebarState()
Returns : Observable<any>
setLayoutState
setLayoutState(state: any)
Parameters :
Name Type Optional
state any no
Returns : any
setSidebarState
setSidebarState(state: any)
Parameters :
Name Type Optional
state any no
Returns : any
Private updateSidebarIcons
updateSidebarIcons(direction: NbLayoutDirection)
Parameters :
Name Type Optional
direction NbLayoutDirection no
Returns : void

Properties

alive
alive:
Default value : true
Protected layouts
layouts: any
Type : any
Default value : [ { name: 'One Column', icon: 'nb-layout-default', id: 'one-column', selected: true, }, { name: 'Two Column', icon: 'nb-layout-two-column', id: 'two-column', }, { name: 'Center Column', icon: 'nb-layout-centre', id: 'center-column', }, ]
Protected layoutState$
layoutState$:
Default value : new BehaviorSubject(this.layouts[0])
Protected sidebars
sidebars: any
Type : any
Default value : [ { name: 'Sidebar at layout start', icon: 'nb-layout-sidebar-left', id: 'start', selected: true, }, { name: 'Sidebar at layout end', icon: 'nb-layout-sidebar-right', id: 'end', }, ]
Protected sidebarState$
sidebarState$:
Default value : new BehaviorSubject(this.sidebars[0])
import { Injectable, OnDestroy } from '@angular/core';
import { of as observableOf,  Observable,  BehaviorSubject } from 'rxjs';
import { takeWhile } from 'rxjs/operators';

import { NbLayoutDirectionService, NbLayoutDirection } from '@nebular/theme';

@Injectable()
export class StateService implements OnDestroy {

  protected layouts: any = [
    {
      name: 'One Column',
      icon: 'nb-layout-default',
      id: 'one-column',
      selected: true,
    },
    {
      name: 'Two Column',
      icon: 'nb-layout-two-column',
      id: 'two-column',
    },
    {
      name: 'Center Column',
      icon: 'nb-layout-centre',
      id: 'center-column',
    },
  ];

  protected sidebars: any = [
    {
      name: 'Sidebar at layout start',
      icon: 'nb-layout-sidebar-left',
      id: 'start',
      selected: true,
    },
    {
      name: 'Sidebar at layout end',
      icon: 'nb-layout-sidebar-right',
      id: 'end',
    },
  ];

  protected layoutState$ = new BehaviorSubject(this.layouts[0]);
  protected sidebarState$ = new BehaviorSubject(this.sidebars[0]);

  alive = true;

  constructor(directionService: NbLayoutDirectionService) {
    directionService.onDirectionChange()
      .pipe(takeWhile(() => this.alive))
      .subscribe(direction => this.updateSidebarIcons(direction));

    this.updateSidebarIcons(directionService.getDirection());
  }

  ngOnDestroy() {
    this.alive = false;
  }

  private updateSidebarIcons(direction: NbLayoutDirection) {
    const [ startSidebar, endSidebar ] = this.sidebars;
    const isLtr = direction === NbLayoutDirection.LTR;
    const startIconClass = isLtr ? 'nb-layout-sidebar-left' : 'nb-layout-sidebar-right';
    const endIconClass = isLtr ? 'nb-layout-sidebar-right' : 'nb-layout-sidebar-left';
    startSidebar.icon = startIconClass;
    endSidebar.icon = endIconClass;
  }

  setLayoutState(state: any): any {
    this.layoutState$.next(state);
  }

  getLayoutStates(): Observable<any[]> {
    return observableOf(this.layouts);
  }

  onLayoutState(): Observable<any> {
    return this.layoutState$.asObservable();
  }

  setSidebarState(state: any): any {
    this.sidebarState$.next(state);
  }

  getSidebarStates(): Observable<any[]> {
    return observableOf(this.sidebars);
  }

  onSidebarState(): Observable<any> {
    return this.sidebarState$.asObservable();
  }
}

results matching ""

    No results matching ""