File
Index
Properties
|
|
Methods
|
|
Inputs
|
|
Outputs
|
|
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
|
|
getDeviceTypeTitle
|
getDeviceTypeTitle(firmware: IManagedObject)
|
Parameters :
Name |
Type |
Optional |
firmware |
IManagedObject
|
No
|
|
selectFirmware
|
selectFirmware(selected: boolean, fw: IManagedObject)
|
Parameters :
Name |
Type |
Optional |
selected |
boolean
|
No
|
fw |
IManagedObject
|
No
|
|
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>