repository/firmware/list/add-firmware-modal.component.ts
selector | c8y-add-firmware-software-modal |
templateUrl | add-firmware-modal.component.html |
Properties |
Methods |
Outputs |
constructor(modal: BsModalRef, repositoryService: RepositoryService, alert: AlertService)
|
||||||||||||
Parameters :
|
saved |
Type : EventEmitter<RepositoryCategory>
|
cancel |
cancel()
|
Returns :
void
|
getFirmwareResult | ||||||
getFirmwareResult(searchStr: string)
|
||||||
Parameters :
Returns :
any
|
loadFirmwares |
loadFirmwares()
|
Returns :
void
|
ngOnDestroy |
ngOnDestroy()
|
Returns :
void
|
ngOnInit |
ngOnInit()
|
Returns :
void
|
onFile | ||||||
onFile(dropped: PickedFiles)
|
||||||
Parameters :
Returns :
void
|
onFirmwareSelect | ||||||
onFirmwareSelect(firmware: IManagedObject)
|
||||||
Parameters :
Returns :
void
|
Async save |
save()
|
Returns :
any
|
setInitialState |
setInitialState()
|
Returns :
void
|
successMsg |
successMsg()
|
Returns :
void
|
firmwarePreselected |
Default value : false
|
firmwaresResult |
form |
Type : NgForm
|
Decorators :
@ViewChild('firmwareForm', {static: false})
|
model |
Type : ModalModel
|
Default value : {
selected: undefined,
version: undefined,
description: undefined,
deviceType: undefined,
binary: {
file: undefined,
url: undefined
}
}
|
onInput |
Type : BehaviorSubject<string>
|
Default value : new BehaviorSubject<string>('')
|
PRODUCT_EXPERIENCE |
Default value : PRODUCT_EXPERIENCE_REPOSITORY_SHARED
|
saving |
Default value : false
|
textForFirmwareUrlPopover |
Type : string
|
Default value : gettext(`Path for binaries can vary depending on device agent implementation, for example:
/firmware/binaries/firmware1.bin
https://firmware/binary/123
ftp://firmware/binary/123.tar.gz
`)
|
<div class="viewport-modal">
<div class="modal-header dialog-header">
<i [c8yIcon]="'c8y-firmware'"></i>
<div class="modal-title" translate id="addFirmwareModalTitle">Add firmware</div>
</div>
<div class="p-16 text-center separator-bottom" *ngIf="!firmwarePreselected">
<p class="text-medium text-16 m-0" translate>Select or create new firmware</p>
</div>
<form
class="d-contents"
autocomplete="off"
#firmwareForm="ngForm"
(ngSubmit)="firmwareForm.form.valid && save()"
>
<div class="modal-inner-scroll">
<div class="modal-body" id="addFirmwareModalDescription">
<div [hidden]="firmwarePreselected">
<c8y-form-group>
<label for="firmwareName" translate>Firmware</label>
<c8y-typeahead
[(ngModel)]="model.selected"
name="firmwareName"
placeholder="{{ 'Select or enter' | translate }}"
data-cy="add-firmware-modal--input-name"
(onSearch)="onInput.next($event)"
[required]="true"
>
<c8y-li
*c8yFor="
let firmware of firmwaresResult;
loadMore: 'auto';
notFound: notFoundTemplate
"
class="p-l-8 p-r-8 c8y-list__item--link"
(click)="onFirmwareSelect(firmware)"
[active]="model.selected === firmware"
>
<c8y-highlight
[text]="firmware.name || '--'"
[pattern]="onInput | async"
></c8y-highlight>
</c8y-li>
<ng-template #notFoundTemplate>
<c8y-li class="bg-level-2 p-8" *ngIf="(onInput | async)?.length > 0">
<span translate>No match found.</span>
<button
class="btn btn-primary btn-xs m-l-8"
type="button"
title="{{ 'Add new`firmware`' | translate }}"
translate
>
Add new`firmware`
</button>
</c8y-li>
</ng-template>
</c8y-typeahead>
</c8y-form-group>
<c8y-form-group>
<label for="firmwareDescription" translate>Description</label>
<input
id="firmwareDescription"
data-cy="add-firmware-modal--input-description"
class="form-control"
autocomplete="off"
name="description"
[(ngModel)]="model.description"
placeholder="{{ 'e.g. Firmware for hardware revision B' | translate }}"
[disabled]="model.selected?.id"
[required]="true"
/>
</c8y-form-group>
<c8y-form-group>
<label class="control-label" for="firmwareDeviceTypeFilter">
{{ 'Device type filter' | translate }}
<button
class="btn-help"
type="button"
[attr.aria-label]="'Help' | translate"
popover="{{
'If the filter is set, the firmware will show up for installation only for devices of that type. If no filter is set, it will be available for all devices.'
| translate
}}"
triggers="focus"
placement="right"
container="body"
></button>
</label>
<input
id="firmwareDeviceTypeFilter"
data-cy="add-firmware-modal--firmwareDeviceTypeFilter"
class="form-control"
name="firmwareDeviceTypeFilter"
[(ngModel)]="model.deviceType"
placeholder="{{ 'e.g.' | translate }} c8y_Linux"
[disabled]="model.selected?.id"
/>
</c8y-form-group>
</div>
<c8y-form-group>
<label for="firmwareVersion" translate>Version</label>
<input
id="firmwareVersion"
data-cy="add-firmware-modal--firmwareVersion"
class="form-control"
autocomplete="off"
name="version"
[(ngModel)]="model.version"
placeholder="{{ 'e.g.' | translate }} 1.0.0"
[required]="true"
/>
</c8y-form-group>
<c8y-form-group>
<div class="legend form-block m-t-40" translate>Firmware file</div>
<c8y-file-picker
[maxAllowedFiles]="1"
(onFilesPicked)="onFile($event)"
[fileUrlPopover]="textForFirmwareUrlPopover"
></c8y-file-picker>
</c8y-form-group>
</div>
</div>
<div class="modal-footer">
<button
class="btn btn-default"
type="button"
title="{{ 'Cancel' | translate }}"
data-cy="add-firmware-modal--cancel-btn"
(click)="cancel()"
[disabled]="saving"
translate
>
Cancel
</button>
<button
class="btn btn-primary"
type="submit"
title="{{ 'Add firmware' | translate }}"
[ngClass]="{ 'btn-pending': saving }"
[disabled]="
!firmwareForm.form.valid ||
firmwareForm.form.pristine ||
saving ||
(!model.binary?.url && !model.binary?.file)
"
[actionName]="PRODUCT_EXPERIENCE.FIRMWARE.EVENTS.REPOSITORY"
[actionData]="{
component: PRODUCT_EXPERIENCE.FIRMWARE.COMPONENTS.ADD_FIRMWARE_MODAL,
result:
firmwarePreselected || model.selected?.id
? PRODUCT_EXPERIENCE.FIRMWARE.RESULTS.ADD_FIRMWARE_VERSION
: PRODUCT_EXPERIENCE.FIRMWARE.RESULTS.ADD_FIRMWARE
}"
translate
c8yProductExperience
>
Add firmware
</button>
</div>
</form>
</div>