File

core/tabs/tabs-outlet.component.ts

Implements

OnDestroy AfterContentInit OnChanges

Metadata

Index

Properties
Methods
Inputs
HostBindings
Accessors

Constructor

constructor(router: Router, renderer: Renderer2, header: HeaderService, tabsService: TabsService)
Parameters :
Name Type Optional
router Router No
renderer Renderer2 No
header HeaderService No
tabsService TabsService No

Inputs

context
Type : any
hasHeader
Type : boolean
Default value : false

Identifies if the current view has a header element.

navigatorOpen
Type : boolean
Default value : false
orientation
Type : "vertical" | "horizontal"
Default value : 'vertical'
outletName
Type : string | undefined
tabs
Type : Tab[]
Default value : []

HostBindings

class.navigator-open
Type : boolean
class.page-tabs
Type : any
class.page-tabs-horizontal
Type : boolean
class.page-tabs-vertical
Type : boolean

Methods

isActive
isActive(tab: Tab)
Parameters :
Name Type Optional
tab Tab No
Returns : any
navigateTo
navigateTo(path)
Parameters :
Name Optional
path No
Returns : void
ngAfterContentInit
ngAfterContentInit()
Returns : void
ngOnChanges
ngOnChanges(changes: SimpleChanges)
Parameters :
Name Type Optional
changes SimpleChanges No
Returns : void
ngOnDestroy
ngOnDestroy()
Returns : void
ngOnInit
ngOnInit()
Returns : void
scroll
scroll(direction: "right" | "left")
Parameters :
Name Type Optional Default value
direction "right" | "left" No 'right'
Returns : void
trackByPath
trackByPath(index, tab: Tab)
Parameters :
Name Type Optional
index No
tab Tab No
Returns : any

Properties

showLeft
Default value : false
showRight
Default value : false

Accessors

isNavigatorOpen
getisNavigatorOpen()
hasTabs
gethasTabs()
isHorizontal
getisHorizontal()
isVertical
getisVertical()
<div
  class="tabContainer"
  [ngClass]="{ 'hidden-xs': !outletName }"
  #container
>
  <button
    class="tabs-slider tabs-slider-left"
    title="{{ 'Scroll to the left' | translate }}"
    type="button"
    #left
    *ngIf="showLeft || showRight"
    [disabled]="!showLeft"
    (click)="scroll('left')"
  >
    <i [c8yIcon]="'chevron-left'"></i>
  </button>
  <button
    class="tabs-slider tabs-slider-right"
    title="{{ 'Scroll to the right' | translate }}"
    type="button"
    #right
    *ngIf="showRight || showLeft"
    [disabled]="!showRight"
    (click)="scroll('right')"
  >
    <i [c8yIcon]="'chevron-right'"></i>
  </button>
  <ng-container *ngIf="!outletName">
    <div
      class="nav nav-tabs nav-tabsc8y"
      role="list"
      #tabsContainer
    >
      <ng-container *ngFor="let tab of tabs">
        <div
          role="listitem"
          [ngClass]="{ active: rla?.isActive }"
          *ngIf="!tab.component && !tab.hide"
        >
          <a
            [routerLink]="tab.path"
            routerLinkActive
            [queryParamsHandling]="'preserve'"
            #rla="routerLinkActive"
            [ngClass]="{ 'p-r-24': !tab.template && tab?.badge }"
            (click)="tab.onSelect?.emit()"
          >
            <i
              [c8yIcon]="tab?.icon"
              *ngIf="!tab.template && tab?.icon"
            ></i>
            <span
              title="{{ tab?.label | translate }}"
              *ngIf="!tab.template && !tab.component"
            >
              {{ tab?.label | translate }}
            </span>
            <span
              class="dashboard-template-marker"
              tooltip="{{ tab?.tooltipText | translate }}"
              placement="bottom"
              container="body"
              [adaptivePosition]="false"
              [delay]="300"
              *ngIf="!tab.template && tab?.badge"
            ></span>
          </a>
          <ng-container *ngTemplateOutlet="tab.template; injector: tab.injector"></ng-container>
        </div>
        <ng-container *ngComponentOutlet="tab.component; injector: tab.injector"></ng-container>
      </ng-container>
    </div>
  </ng-container>

  <div
    class="component-tabs nav nav-tabs nav-tabsc8y"
    *ngIf="outletName"
    #tabsContainer
  >
    <ng-container *ngFor="let tab of tabs; trackBy: trackByPath">
      <div
        [ngClass]="{ active: tab.isActive }"
        [routerLink]="tab.path"
        [routerLinkActive]="tab.path ? 'active' : ''"
        [queryParamsHandling]="'preserve'"
      >
        <a
          class="pointer"
          title="{{ tab?.label | translate }}"
          (click)="tab.onSelect?.emit()"
        >
          <i [c8yIcon]="tab?.icon"></i>
          <span>
            {{ tab?.label | translate }}
          </span>
        </a>
      </div>
    </ng-container>
  </div>
</div>

<div
  class="visible-xs mobile-tabs"
  *ngIf="!outletName"
>
  <ul class="list-unstyled d-flex m-b-0">
    <li class="c8y-select-wrapper flex-grow">
      <select
        (change)="navigateTo($event.target.value)"
        #select
      >
        <ng-container *ngFor="let tab of tabs">
          <option
            *ngIf="!tab.component"
            [value]="tab.path"
            [selected]="isActive(tab)"
          >
            {{ tab?.label | translate }}
          </option>
        </ng-container>
      </select>
    </li>
    <ng-container *ngFor="let tab of tabs">
      <ng-container *ngIf="tab.component">
        <ng-container
          *c8yComponentOutlet="tab.component; environmentInjector: tab.injector"
        ></ng-container>
      </ng-container>
    </ng-container>
  </ul>
</div>

results matching ""

    No results matching ""