device-profile/device-tab-profile/device-tab-profile.component.ts
OnInit
OnDestroy
ProductExperienceEventSource
providers |
ManagedObjectRealtimeService
{
provide: PRODUCT_EXPERIENCE_EVENT_SOURCE, useExisting: forwardRef(() => DeviceTabProfileComponent)
}
|
selector | c8y-device-tab-profile |
templateUrl | ./device-tab-profile.component.html |
Properties |
Methods |
constructor(deviceRealtime: ManagedObjectRealtimeService, deviceProfileService: DeviceProfileService, route: ActivatedRoute, operationRealtime: OperationRealtimeService, alertService: AlertService)
|
||||||||||||||||||
Parameters :
|
Async createOperation |
createOperation()
|
Returns :
any
|
Async getDeviceProfilesAndUpdateProfileItems |
getDeviceProfilesAndUpdateProfileItems()
|
Returns :
any
|
ngOnDestroy |
ngOnDestroy()
|
Returns :
void
|
Async ngOnInit |
ngOnInit()
|
Returns :
any
|
selectProfile | ||||||
selectProfile(mo: DeviceProfile)
|
||||||
Parameters :
Returns :
void
|
setPipe | ||||||
setPipe(filterStr: string)
|
||||||
Parameters :
Returns :
void
|
updateProfileItems | ||||||
updateProfileItems(device, profile)
|
||||||
Parameters :
Returns :
void
|
configurationItems |
Type : ComparisonResult[]
|
Default value : []
|
device |
Type : IManagedObject
|
deviceProfiles |
Type : IResultList<IManagedObject>
|
Public deviceRealtime |
Type : ManagedObjectRealtimeService
|
filterPipe |
Type : ForOfFilterPipe
|
firmwareItems |
Type : ComparisonResult[]
|
Default value : []
|
operation |
Type : IOperation
|
pattern |
Type : string
|
Default value : ''
|
PRODUCT_EXPERIENCE |
Default value : PRODUCT_EXPERIENCE_DEVICE_PROFILE
|
productExperienceEvent |
Type : ProductExperienceEvent
|
Default value : {
eventName: PRODUCT_EXPERIENCE_DEVICE_PROFILE.EVENTS.DEVICE_TAB,
data: {
component: PRODUCT_EXPERIENCE_DEVICE_PROFILE.COMPONENTS.DEVICE_TAB_PROFILE
}
}
|
reloading |
Default value : false
|
selectedProfile |
Type : Partial<DeviceProfile>
|
softwareItems |
Type : ComparisonResult[]
|
Default value : []
|
<c8y-action-bar-item [placement]="'right'">
<button
class="btn btn-link"
title="{{ 'Reload' | translate }}"
type="button"
(click)="getDeviceProfilesAndUpdateProfileItems()"
>
<i c8yIcon="refresh" [ngClass]="{ 'icon-spin': reloading }"></i>
{{ 'Reload' | translate }}
</button>
</c8y-action-bar-item>
<c8y-action-bar-item [placement]="'right'">
<c8y-realtime-btn [service]="deviceRealtime"></c8y-realtime-btn>
</c8y-action-bar-item>
<div class="card card--grid--fullpage card--grid--fullpage card--grid grid__row--2-10--md">
<div class="card--grid grid__col--6-6--md">
<!-- AVAILABLE PROFILES -->
<div class="bg-level-0">
<div class="card-header separator">
<div class="card-title" translate>Device profile</div>
</div>
<div class="p-16">
<form #deviceProfileForm="ngForm">
<div class="input-group">
<c8y-typeahead
class="flex-grow"
name="selectProfile"
data-cy="device-tab-profile--select-device-profile"
[(ngModel)]="selectedProfile"
placeholder="{{ 'Select device profile' | translate }}"
(onSearch)="setPipe($event)"
[allowFreeEntries]="false"
>
<c8y-li
*c8yFor="let profile of deviceProfiles; pipe: filterPipe"
class="p-l-8 p-r-8 c8y-list__item--link"
(click)="selectProfile(profile); setPipe('')"
>
<c8y-highlight
[text]="profile.name || '--'"
[pattern]="pattern"
></c8y-highlight>
</c8y-li>
</c8y-typeahead>
<div class="input-group-btn">
<button
class="btn btn-primary"
(click)="createOperation()"
data-cy="device-tab-profile--Assign-device-profile-button"
title="{{ 'Assign device profile' | translate }}"
type="button"
[disabled]="!selectedProfile?.id"
c8yProductExperience
inherit
[actionData]="{ action: PRODUCT_EXPERIENCE.ACTIONS.ASSIGN_DEVICE_PROFILE }"
>
<span>{{ 'Assign device profile' | translate }}</span>
</button>
</div>
</div>
</form>
</div>
</div>
<!-- INSTALL PROFILE OPERATION -->
<div class="bg-level-1">
<div class="card-header separator">
<div class="card-title" translate>Currently installed</div>
</div>
<div class="card-block">
<c8y-operation-details
[operation]="operation"
c8yProductExperience
inherit
suppressDataOverriding
></c8y-operation-details>
</div>
</div>
</div>
<div class="card--grid__inner-scroll d-col no-align-items">
<div class="d-contents">
<!-- FIRMWARE -->
<c8y-device-tab-profile-detail
[sectionTitle]="'Firmware' | translate"
[sectionIcon]="'c8y-firmware'"
[emptyStateText]="'No firmware to display.' | translate"
[emptyStateDetails]="'No firmware assigned.' | translate"
[isProfileSelected]="!!selectedProfile"
[items]="firmwareItems"
[isEmpty]="!selectedProfile?.c8y_DeviceProfile?.firmware?.name"
class="d-contents"
></c8y-device-tab-profile-detail>
</div>
<div class="d-contents">
<!-- SOFTWARE -->
<c8y-device-tab-profile-detail
[sectionTitle]="'Software' | translate"
[sectionIcon]="'c8y-tools'"
[emptyStateText]="'No software to display.' | translate"
[emptyStateDetails]="'No software assigned.' | translate"
[isProfileSelected]="!!selectedProfile"
[items]="softwareItems"
[isEmpty]="
!selectedProfile?.c8y_DeviceProfile?.software ||
selectedProfile?.c8y_DeviceProfile?.software?.length === 0
"
class="d-contents"
></c8y-device-tab-profile-detail>
</div>
<div class="d-contents">
<!-- CONFIGURATION -->
<c8y-device-tab-profile-detail
[sectionTitle]="'Configuration' | translate"
[sectionIcon]="'gears'"
[emptyStateText]="'No configuration to display' | translate"
[emptyStateDetails]="'No configuration assigned' | translate"
[isProfileSelected]="!!selectedProfile"
[items]="configurationItems"
[isEmpty]="
!selectedProfile?.c8y_DeviceProfile?.configuration ||
selectedProfile?.c8y_DeviceProfile?.configuration?.length === 0
"
[showTextLabel]="false"
class="d-contents"
></c8y-device-tab-profile-detail>
</div>
<!-- fill in the remanining vertical space when empty -->
<div class="card--grid grid__col--6-6--md flex-grow">
<div class="bg-level-0"></div>
<div class="bg-level-1"></div>
</div>
</div>
</div>