operations/bulk-operation-list-item/bulk-operation-list-item.component.ts
OnInit
OnChanges
selector | c8y-bulk-operation-list-item |
templateUrl | ./bulk-operation-list-item.component.html |
constructor(bulkOperationListItemService: BulkOperationListItemService, bulkOperationsService: BulkOperationsService, modal: ModalService, alert: AlertService, bsModalService: BsModalService)
|
||||||||||||||||||
Parameters :
|
bulkOperation |
Type : Partial<IOperationBulk>
|
detailsCollapsed |
Type : boolean
|
Default value : true
|
readOnly |
Type : boolean
|
Default value : false
|
reload |
Type : EventEmitter<any>
|
showFailedOperation |
Type : EventEmitter
|
allOperationsCreated |
allOperationsCreated()
|
Returns :
boolean
|
calculateFinishDateMs |
calculateFinishDateMs()
|
Returns :
number
|
Async cancelBulkOperation |
cancelBulkOperation()
|
Returns :
any
|
editSchedule |
editSchedule()
|
Returns :
void
|
getOperationStatusOptions |
getOperationStatusOptions()
|
Returns :
any
|
isStatusCanceled |
isStatusCanceled()
|
Returns :
boolean
|
isStatusExecutingOrExecutingWithError |
isStatusExecutingOrExecutingWithError()
|
Returns :
boolean
|
isStatusFailed |
isStatusFailed()
|
Returns :
boolean
|
isStatusScheduled |
isStatusScheduled()
|
Returns :
boolean
|
ngOnChanges | ||||||
ngOnChanges(changes: SimpleChanges)
|
||||||
Parameters :
Returns :
void
|
ngOnInit |
ngOnInit()
|
Returns :
void
|
openFailedOperation | ||||
openFailedOperation(failedParentId)
|
||||
Parameters :
Returns :
void
|
progressBarProgressFn |
progressBarProgressFn()
|
Returns :
number
|
retryFailedOperation |
retryFailedOperation()
|
Returns :
void
|
setProgressBar |
setProgressBar()
|
Returns :
void
|
Async setToSuccessful |
setToSuccessful()
|
Returns :
any
|
bsModalRef |
Type : BsModalRef
|
BULK_OPERATION_EVENT |
Default value : BULK_OPERATION_EVENT
|
BULK_OPERATION_STATUS_OPTIONS |
Type : OperationStatusOptionsMap
|
Default value : BULK_OPERATION_STATUS_OPTIONS
|
bulkOperationGeneralStatus |
Default value : OperationBulkGeneralStatus
|
Public bulkOperationListItemService |
Type : BulkOperationListItemService
|
finishDate |
Type : number
|
finishDatePopoverText |
Type : string
|
Default value : gettext(
'Approximate date, estimated based on the bulk operation settings.'
)
|
iconClass |
Type : string
|
listItem |
Type : ListItemComponent
|
Decorators :
@ViewChild('listItem', {static: true})
|
progressBarClass |
Type : string
|
Default value : 'progress'
|
progressBarColor |
Type : string
|
progressBarStatus |
Type : number
|
Default value : 0
|
refreshLoading |
Default value : false
|
<c8y-li
class="c8y-list__item--double-actions"
[ngClass]="{ 'c8y-list__item--no-expand': !detailsCollapsed }"
[collapsed]="detailsCollapsed"
#listItem
id="{{ bulkOperation.id }}"
>
<c8y-li-icon>
<i
[c8yIcon]="getOperationStatusOptions().icon"
[ngClass]="getOperationStatusOptions().styleClass"
[tooltip]="getOperationStatusOptions().label | translate"
></i>
</c8y-li-icon>
<div [ngClass]="{ 'content-flex-58': !readOnly, 'content-flex-50': readOnly }">
<div class="col-5">
<button
class="btn-clean"
type="button"
title="{{ bulkOperation.id }} - {{
bulkOperation.operationPrototype.description | translate
}}"
(click)="listItem.toggleCollapsed()"
>
<span class="text-truncate">
<strong class="text-muted m-r-4">{{ bulkOperation.id }}</strong>
{{ bulkOperation.operationPrototype.description | translate }}
</span>
</button>
</div>
<div class="flex-grow">
<div class="m-t-8 visible-xs"></div>
<hr *ngIf="isStatusCanceled(); else statusNotCanceled" class="m-t-16 m-b-0 visible-xs" />
<ng-template #statusNotCanceled>
<div
[class]="progressBarClass"
title="{{ progressBarStatus | c8yNumber: 'floor':'1.0-0' }}%"
>
<div
[class]="progressBarColor"
role="progressbar"
[attr.aria-label]="'Progress' | translate"
aria-valuenow="0"
aria-valuemin="0"
aria-valuemax="100"
[style.width.%]="progressBarStatus"
>
<span *ngIf="progressBarStatus !== 0">
{{ progressBarStatus | c8yNumber: 'floor':'1.0-0' }}%
</span>
</div>
</div>
</ng-template>
</div>
<div class="col-4">
<div class="p-t-8 visible-xs"></div>
<small *ngIf="bulkOperation.progress.successful > 0" class="m-r-8 icon-flex">
<i c8yIcon="check-circle" class="text-success m-r-4"></i>
<span
ngNonBindable
translate
[translateParams]="{ bulkOperationsCountSuccessful: bulkOperation.progress.successful }"
>
{{ bulkOperationsCountSuccessful }} successful
</span>
</small>
<small *ngIf="bulkOperation.progress.failed > 0" class="m-r-8 icon-flex">
<i c8yIcon="warning" class="text-danger m-r-4"></i>
<span
ngNonBindable
translate
[translateParams]="{ bulkOperationsCountFailed: bulkOperation.progress.failed }"
>
{{ bulkOperationsCountFailed }} failed
</span>
</small>
<small *ngIf="bulkOperation.progress.executing > 0" class="m-r-8 icon-flex">
<i c8yIcon="refresh" class="text-primary m-r-4"></i>
<span
ngNonBindable
translate
[translateParams]="{ bulkOperationsCountExecuting: bulkOperation.progress.executing }"
>
{{ bulkOperationsCountExecuting }} executing
</span>
</small>
<small *ngIf="bulkOperation.progress.pending > 0" class="m-r-8 icon-flex">
<i c8yIcon="clock-o" class="text-primary m-r-4"></i>
<span
ngNonBindable
translate
[translateParams]="{ bulkOperationsCountPending: bulkOperation.progress.pending }"
>
{{ bulkOperationsCountPending }} pending
</span>
</small>
</div>
</div>
<div class="c8y-list__item__footer">
<div class="m-r-16">
<span class="text-label-small m-r-4" translate>Start</span>
<small class="icon-flex">
<i c8yIcon="calendar" class="m-r-4"></i>
<span>
{{ bulkOperation.startDate | c8yDate }}
</span>
</small>
</div>
<div class="m-r-16" *ngIf="bulkOperationGeneralStatus.CANCELED !== bulkOperation.generalStatus">
<span class="text-label-small m-r-4" translate>Finish</span>
<small class="icon-flex">
<i c8yIcon="calendar" class="m-r-4"></i>
<span>{{ finishDate | c8yDate }}</span>
</small>
<button
class="btn-help btn-help--sm"
type="button"
[attr.aria-label]="'Help' | translate"
popover="{{ finishDatePopoverText | translate }}"
placement="right"
triggers="focus"
container="body"
*ngIf="isStatusScheduled() || isStatusExecutingOrExecutingWithError()"
></button>
</div>
</div>
<ng-container *ngIf="!readOnly">
<c8y-li-action
*ngIf="isStatusScheduled()"
label="{{ 'Edit schedule' | translate }}"
(click)="editSchedule()"
icon="pencil"
c8yProductExperience
[actionName]="BULK_OPERATION_EVENT"
></c8y-li-action>
<c8y-li-action
*ngIf="
isStatusScheduled() || (isStatusExecutingOrExecutingWithError() && !allOperationsCreated())
"
label="{{ 'Cancel bulk operation' | translate }}"
(click)="cancelBulkOperation()"
icon="remove"
c8yProductExperience
[actionName]="BULK_OPERATION_EVENT"
></c8y-li-action>
<c8y-li-action
*ngIf="isStatusFailed()"
label="{{ 'Retry failed operations' | translate }}"
(click)="retryFailedOperation()"
icon="repeat"
c8yProductExperience
[actionName]="BULK_OPERATION_EVENT"
></c8y-li-action>
<c8y-li-action
*ngIf="isStatusFailed()"
label="{{ 'Set operation to SUCCESSFUL' | translate }}"
(click)="setToSuccessful()"
icon="check-circle"
c8yProductExperience
[actionName]="BULK_OPERATION_EVENT"
></c8y-li-action>
</ng-container>
<c8y-li-collapse class="m-b-16">
<c8y-operation-details-tabs
*ngIf="!listItem.collapsed"
[operation]="bulkOperation"
[readOnly]="readOnly"
(onRetryFailedOperations)="retryFailedOperation()"
(showFailedOperation)="openFailedOperation($event)"
[bulkOperationModalDetailsService]="bulkOperationListItemService"
></c8y-operation-details-tabs>
</c8y-li-collapse>
</c8y-li>