repository/software/list/add-software-modal.component.ts
selector | c8y-add-software-software-modal |
templateUrl | add-software-modal.component.html |
Properties |
Methods |
Outputs |
constructor(modal: BsModalRef, repositoryService: RepositoryService, alert: AlertService)
|
||||||||||||
Parameters :
|
saved |
Type : EventEmitter<RepositoryCategory>
|
cancel |
cancel()
|
Returns :
void
|
getSoftwareResult | ||||||
getSoftwareResult(searchStr: string)
|
||||||
Parameters :
Returns :
any
|
loadSoftwares |
loadSoftwares()
|
Returns :
void
|
ngOnDestroy |
ngOnDestroy()
|
Returns :
void
|
ngOnInit |
ngOnInit()
|
Returns :
void
|
onFile | ||||||
onFile(dropped: PickedFiles)
|
||||||
Parameters :
Returns :
void
|
onSoftwareSelect | ||||||
onSoftwareSelect(software: IManagedObject)
|
||||||
Parameters :
Returns :
void
|
Async save |
save()
|
Returns :
any
|
setInitialState |
setInitialState()
|
Returns :
void
|
successMsg |
successMsg()
|
Returns :
void
|
form |
Type : NgForm
|
Decorators :
@ViewChild('softwareForm', {static: false})
|
model |
Type : ModalModel
|
Default value : {
selected: undefined,
version: undefined,
description: undefined,
deviceType: undefined,
softwareType: 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
|
softwarePreselected |
Default value : false
|
softwaresResult |
textForSoftwareUrlPopover |
Type : string
|
Default value : gettext(`Path for binaries can vary depending on device agent implementation, for example:
/software/binaries/software1.bin
https://software/binary/123
ftp://software/binary/123.tar.gz
`)
|
<div class="viewport-modal">
<div class="modal-header dialog-header">
<i [c8yIcon]="'c8y-tools'"></i>
<div class="modal-title" translate id="addSoftwareModalTitle">Add software</div>
</div>
<div class="p-16 text-center separator-bottom" *ngIf="!softwarePreselected">
<p class="text-medium text-16" translate>Select or create new software</p>
</div>
<form
class="d-contents"
autocomplete="off"
#softwareForm="ngForm"
(ngSubmit)="softwareForm.form.valid && save()"
>
<div class="modal-inner-scroll">
<div class="modal-body" id="addSoftwareModalDescription">
<div [hidden]="softwarePreselected">
<c8y-form-group>
<label for="softwareName" translate>Software</label>
<c8y-typeahead
[(ngModel)]="model.selected"
name="softwareName"
placeholder="{{ 'Select or enter' | translate }}"
(onSearch)="onInput.next($event)"
[required]="true"
>
<c8y-li
*c8yFor="
let software of softwaresResult;
loadMore: 'auto';
notFound: notFoundTemplate
"
class="p-l-8 p-r-8 c8y-list__item--link"
(click)="onSoftwareSelect(software)"
[active]="model.selected === software"
>
<c8y-highlight
[text]="software.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`software`' | translate }}"
>
{{ 'Add new`software`' | translate }}
</button>
</c8y-li>
</ng-template>
</c8y-typeahead>
</c8y-form-group>
<c8y-form-group>
<label for="softwareDescription" translate>Description</label>
<input
id="softwareDescription"
class="form-control"
autocomplete="off"
name="description"
[(ngModel)]="model.description"
placeholder="{{ 'e.g. Cloud connectivity software' | translate }}"
[disabled]="model.selected?.id"
[required]="true"
/>
</c8y-form-group>
<c8y-form-group>
<label class="control-label" for="softwareDeviceTypeFilter">
{{ 'Device type filter' | translate }}
<button
class="btn-help"
type="button"
[attr.aria-label]="'Help' | translate"
popover="{{
'If the filter is set, the software will show up for installation only for devices of that type. If no filter is set, it will be available for all devices.'
| translate
}}"
placement="right"
triggers="focus"
container="body"
></button>
</label>
<input
id="softwareDeviceTypeFilter"
class="form-control"
name="softwareDeviceTypeFilter"
[(ngModel)]="model.deviceType"
placeholder="{{ 'e.g.' | translate }} c8y_Linux"
[disabled]="model.selected?.id"
/>
</c8y-form-group>
<c8y-form-group>
<label for="softwareType" translate>Software type</label>
<c8y-software-type
name="softwareType"
[(ngModel)]="model.softwareType"
[disabled]="model.selected?.id"
></c8y-software-type>
</c8y-form-group>
</div>
<c8y-form-group>
<label for="softwareVersion" translate>Version</label>
<input
id="softwareVersion"
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>Software file</div>
<c8y-file-picker
[maxAllowedFiles]="1"
(onFilesPicked)="onFile($event)"
[fileUrlPopover]="textForSoftwareUrlPopover"
></c8y-file-picker>
</c8y-form-group>
</div>
</div>
<div class="modal-footer">
<button
class="btn btn-default"
type="button"
title="{{ 'Cancel' | translate }}"
(click)="cancel()"
[disabled]="saving"
>
{{ 'Cancel' | translate }}
</button>
<button
class="btn btn-primary"
type="submit"
title="{{ 'Add software' | translate }}"
[ngClass]="{ 'btn-pending': saving }"
[disabled]="
!softwareForm.form.valid ||
softwareForm.form.pristine ||
saving ||
(!model.binary?.url && !model.binary?.file)
"
c8yProductExperience
[actionName]="PRODUCT_EXPERIENCE.SOFTWARE.EVENTS.REPOSITORY"
[actionData]="{
component: PRODUCT_EXPERIENCE.SOFTWARE.COMPONENTS.ADD_SOFTWARE_MODAL,
result:
softwarePreselected || model.selected?.id
? PRODUCT_EXPERIENCE.SOFTWARE.RESULTS.ADD_SOFTWARE_VERSION
: PRODUCT_EXPERIENCE.SOFTWARE.RESULTS.ADD_SOFTWARE
}"
>
{{ 'Add software' | translate }}
</button>
</div>
</form>
</div>