File

repository/software/device-tab/device-software-list.component.ts

Implements

OnInit AfterContentInit OnDestroy

Metadata

Index

Properties
Methods
Inputs
Outputs
Accessors

Constructor

constructor(deviceSoftwareService: DeviceSoftwareService)
Parameters :
Name Type Optional
deviceSoftwareService DeviceSoftwareService No

Inputs

device
Type : IManagedObject
deviceSoftwareChanges
Type : DeviceSoftwareChange[]
filterCriteria$
Type : Observable<FilterCriteria>
Default value : of(null)
softwareList
Type : DeviceSoftware[]

Outputs

onListEmpty
Type : EventEmitter<boolean>
remove
Type : EventEmitter
update
Type : EventEmitter

Methods

isSoftwareGoingToBeChanged
isSoftwareGoingToBeChanged(software: DeviceSoftware)
Parameters :
Name Type Optional
software DeviceSoftware No
Returns : boolean
ngAfterContentInit
ngAfterContentInit()
Returns : void
ngOnDestroy
ngOnDestroy()
Returns : void
ngOnInit
ngOnInit()
Returns : void

Properties

alreadyInstalledMessage
Default value : gettext('This software is already installed on the device')
emptyList
Type : boolean
noSearchResults
Type : boolean
PRODUCT_EXPERIENCE
Default value : PRODUCT_EXPERIENCE_REPOSITORY_SHARED
showRemove
Type : boolean
showUpdate
Type : boolean
softwareItems$
Type : Observable<IResultList<DeviceSoftware>>
supportsSoftwareOperations
Default value : false

Accessors

softwareList
setsoftwareList(softwareList: DeviceSoftware[])
Parameters :
Name Type Optional
softwareList DeviceSoftware[] No
Returns : void
<c8y-list-group class="no-border-2nd-last">
  <c8y-li
    [ngClass]="{ disabled: isSoftwareGoingToBeChanged(software) }"
    *c8yFor="let software of softwareItems$"
  >
    <!-- SOFTWARE ICON -->
    <c8y-li-icon>
      <i c8yIcon="c8y-tools"></i>
    </c8y-li-icon>

    <c8y-li-body class="content-flex-20">
      <div title="{{ software.name }}" class="col-9">
        <p class="d-flex">
          <!-- SOFTWARE NAME -->
          <span class="text-truncate">
            {{ software.name }}
          </span>
          <!-- SOFTWARE TYPE-->
          <span class="text-truncate">
            <span class="label label-primary m-l-8">{{ software.softwareType }}</span>
          </span>
        </p>
        <!-- SOFTWARE VERSION -->
        <p class="d-flex a-i-center">
          <span class="text-truncate text-label-small m-r-4" translate>Version</span>
          <span class="text-truncate m-r-4" title="{{ software.version }}">
            {{ software.version }}
          </span>
          <i
            *ngIf="software.installed"
            c8yIcon="warning"
            class="text-warning a-s-center"
            [tooltip]="
              alreadyInstalledMessage
                | translate: { name: software.name, version: software.version }
            "
            container="body"
            placement="top"
            [delay]="500"
          ></i>
        </p>
      </div>

      <div
        *ngIf="supportsSoftwareOperations && (showUpdate || showRemove)"
        class="col-3 text-right m-0 flex-grow d-flex a-i-center"
      >
        <!-- UPDATE SOFTWARE -->
        <button
          class="btn btn-default btn-xs m-l-auto m-r-4"
          type="button"
          title="{{ 'Update`software,verb`' | translate }}"
          *ngIf="showUpdate && !isSoftwareGoingToBeChanged(software)"
          (click)="update.emit(software)"
          c8yProductExperience
          [actionName]="PRODUCT_EXPERIENCE.SOFTWARE.EVENTS.DEVICE_TAB"
          [actionData]="{
            component: PRODUCT_EXPERIENCE.SOFTWARE.COMPONENTS.DEVICE_SOFTWARE_LIST,
            action: PRODUCT_EXPERIENCE.SOFTWARE.ACTIONS.OPEN_UPDATE_SOFTWARE
          }"
        >
          {{ 'Update`software,verb`' | translate }}
        </button>

        <!-- REMOVE SOFTWARE -->
        <button
          class="btn btn-dot btn-dot--danger m-l-4"
          type="button"
          [attr.aria-label]="'Remove`software,verb`' | translate"
          tooltip="{{ 'Remove`software,verb`' | translate }}"
          placement="bottom"
          container="body"
          [delay]="500"
          c8yProductExperience
          [actionName]="PRODUCT_EXPERIENCE.SOFTWARE.EVENTS.DEVICE_TAB"
          [actionData]="{
            component: PRODUCT_EXPERIENCE.SOFTWARE.COMPONENTS.DEVICE_SOFTWARE_LIST,
            action: PRODUCT_EXPERIENCE.SOFTWARE.ACTIONS.DELETE_SOFTWARE
          }"
          *ngIf="showRemove && !isSoftwareGoingToBeChanged(software)"
          (click)="remove.emit(software)"
        >
          <i c8yIcon="minus-circle"></i>
        </button>
      </div>
    </c8y-li-body>
  </c8y-li>
</c8y-list-group>
<!-- NO SEARCH RESULTS STATE -->
<div class="card-block" *ngIf="noSearchResults || emptyList">
  <ng-content *ngIf="emptyList" select=".c8y-empty-state:not(.c8y-no-results-state)"></ng-content>
  <ng-content *ngIf="noSearchResults" select=".c8y-no-results-state"></ng-content>
</div>

results matching ""

    No results matching ""