File

operations/stepper-bulk-type-firmware/select-firmware.component.ts

Metadata

Index

Properties
Methods
Inputs
Outputs

Constructor

constructor(repositoryService: RepositoryService, bulkOpsService: BulkOperationsService, translate: TranslateService)
Parameters :
Name Type Optional
repositoryService RepositoryService No
bulkOpsService BulkOperationsService No
translate TranslateService No

Inputs

selected
Type : IManagedObject

Outputs

firmware
Type : EventEmitter<IManagedObject>

Methods

getBaseVersionsCount$
getBaseVersionsCount$(firmware: IManagedObject)
Decorators :
@memoize(undefined)
Parameters :
Name Type Optional
firmware IManagedObject No
Returns : Observable<number | string>
getDescriptionTitle
getDescriptionTitle(firmware: IManagedObject)
Parameters :
Name Type Optional
firmware IManagedObject No
Returns : string
getDeviceTypeTitle
getDeviceTypeTitle(firmware: IManagedObject)
Parameters :
Name Type Optional
firmware IManagedObject No
Returns : string
ngOnInit
ngOnInit()
Returns : void
selectFirmware
selectFirmware(selected: boolean, fw: IManagedObject)
Parameters :
Name Type Optional
selected boolean No
fw IManagedObject No
Returns : void

Properties

DD_LOW_COUNT
Type : number
Default value : 10
Readonly DESCRIPTION_NOT_AVAILABLE
Type : string
Default value : gettext('No description available.')
Readonly DEVICE_TYPE_NOT_AVAILABLE
Type : string
Default value : gettext('No device type available.')
elementCount
Type : number
Default value : 0
firmwares$
Type : Observable<IResultList<IManagedObject>>
Default value : this.textFilter$ .pipe(debounceTime(400), distinctUntilChanged()) .pipe( switchMap(text => this.getFirmwares(text)), tap(resp => { this.elementCount = resp.data ? resp.data.length : 0; }), shareReplay(1) )
isLegacy
Default value : this.repositoryService.isLegacyEntry.bind(this.repositoryService)
textFilter$
Type : BehaviorSubject<string>
Default value : new BehaviorSubject('')
<c8y-select-step-frame
  [header]="'Select firmware' | translate"
  [noResults]="(textFilter$ | async).length > 0 && elementCount === 0"
>
  <label
    class="sr-only"
    for="fFilter"
  >
    {{ 'Filter…' | translate }}
  </label>
  <div
    class="input-group input-group-search"
    filters
  >
    <input
      class="form-control"
      title="{{ 'Filter…' | translate }}"
      id="fFilter"
      placeholder="{{ 'Filter…' | translate }}"
      type="search"
      [ngModel]="textFilter$ | async"
      (ngModelChange)="textFilter$.next($event)"
    />
    <span class="input-group-addon">
      <i
        c8yIcon="search"
        *ngIf="(textFilter$ | async).length === 0"
      ></i>
      <i
        class="text-muted"
        c8yIcon="times"
        *ngIf="(textFilter$ | async).length > 0"
        (click)="textFilter$.next('')"
      ></i>
    </span>
  </div>
  <c8y-li
    class="hidden-sm hidden-xs m-r-8 m-l-8"
    header
  >
    <c8y-li-icon><i class="p-l-32 p-r-40"></i></c8y-li-icon>
    <c8y-li-body class="content-flex-40">
      <div class="col-3">
        <span
          class="text-truncate"
          title=" {{ 'Name' | translate }} "
        >
          {{ 'Name' | translate }}
        </span>
      </div>
      <div class="col-4">
        <span
          class="text-truncate"
          title="{{ 'Description' | translate }}"
        >
          {{ 'Description' | translate }}
        </span>
      </div>
      <div class="col-3">
        <span
          class="text-truncate"
          title="{{ 'Device type' | translate }}"
        >
          {{ 'Device type' | translate }}
        </span>
      </div>
      <div class="col-2">
        <span
          class="text-truncate"
          title="{{ 'Versions' | translate }}"
        >
          {{ 'Versions' | translate }}
        </span>
      </div>
    </c8y-li-body>
  </c8y-li>
  <c8y-list-group list>
    <c8y-li *c8yFor="let firmware of firmwares$ | async; let i = index; loadMore: 'auto'">
      <c8y-li-radio
        (onSelect)="selectFirmware($event, firmware)"
        [selected]="firmware === selected"
      ></c8y-li-radio>
      <c8y-li-icon>
        <i c8yIcon="c8y-firmware"></i>
      </c8y-li-icon>

      <c8y-li-body class="content-flex-40">
        <div class="col-3 m-b-xs-8">
          <div
            class="text-truncate"
            title="{{ firmware.name }}"
          >
            <c8y-highlight
              [text]="firmware.name"
              [pattern]="textFilter$ | async"
            ></c8y-highlight>
          </div>
        </div>
        <div class="col-4 m-b-xs-8">
          <div
            class="text-truncate"
            title="{{ getDescriptionTitle(firmware) }}"
          >
            <span
              class="text-label-small m-r-8 visible-xs visible-sm"
              translate
            >
              Description
            </span>
            <small *ngIf="firmware.description; else noDesc">
              {{ firmware.description }}
            </small>
            <ng-template #noDesc>
              <small>
                <em
                  class="text-muted"
                  translate
                >
                  No description available.
                </em>
              </small>
            </ng-template>
          </div>
        </div>
        <div class="col-3 m-b-xs-8">
          <div
            class="text-truncate"
            title="{{ 'Device type' | translate }}: {{ getDeviceTypeTitle(firmware) }}"
          >
            <span
              class="text-label-small m-r-8 visible-xs visible-sm"
              translate
            >
              Device type
            </span>
            <span *ngIf="firmware.c8y_Filter?.type; else noType">
              {{ firmware.c8y_Filter?.type }}
            </span>
            <ng-template #noType>
              <em
                class="text-muted"
                translate
              >
                Undefined`device type`
              </em>
            </ng-template>
          </div>
        </div>
        <div class="col-2">
          <span
            class="label label-warning m-l-auto-sm"
            *ngIf="isLegacy(firmware)"
          >
            <span translate>Legacy</span>
          </span>

          <span *ngIf="!isLegacy(firmware)">
            <span *ngIf="(getBaseVersionsCount$(firmware) | async) === null">
              <span class="label label-info">
                <i
                  class="icon-spin"
                  c8yIcon="circle-o-notch"
                ></i>
              </span>
            </span>
            <span *ngIf="(getBaseVersionsCount$(firmware) | async) !== null">
              <span [ngPlural]="getBaseVersionsCount$(firmware) | async">
                <ng-template ngPluralCase="=0">
                  <span class="label label-default">
                    <span translate>No versions</span>
                  </span>
                </ng-template>
                <ng-template ngPluralCase="=1">
                  <span
                    class="text-label-small m-r-8 visible-xs visible-sm"
                    translate
                  >
                    version
                  </span>
                  <span class="badge badge-info m-l-auto-sm">1</span>
                </ng-template>
                <ng-template ngPluralCase="other">
                  <span
                    class="text-label-small m-r-8 visible-xs visible-sm"
                    translate
                  >
                    versions
                  </span>
                  <span class="badge badge-info m-l-auto-sm">
                    {{ getBaseVersionsCount$(firmware) | async }}
                  </span>
                </ng-template>
              </span>
            </span>
          </span>
        </div>
      </c8y-li-body>
    </c8y-li>
  </c8y-list-group>
</c8y-select-step-frame>

results matching ""

    No results matching ""