File

repository/software/list/add-software-modal.component.ts

Metadata

Index

Properties
Methods
Outputs

Constructor

constructor(modal: BsModalRef, repositoryService: RepositoryService, alert: AlertService)
Parameters :
Name Type Optional
modal BsModalRef No
repositoryService RepositoryService No
alert AlertService No

Outputs

saved
Type : EventEmitter<RepositoryCategory>

Methods

cancel
cancel()
Returns : void
getSoftwareResult
getSoftwareResult(searchStr: string)
Parameters :
Name Type Optional
searchStr string No
Returns : any
loadSoftwares
loadSoftwares()
Returns : void
ngOnDestroy
ngOnDestroy()
Returns : void
ngOnInit
ngOnInit()
Returns : void
onFile
onFile(dropped: PickedFiles)
Parameters :
Name Type Optional
dropped PickedFiles No
Returns : void
onSoftwareSelect
onSoftwareSelect(software: IManagedObject)
Parameters :
Name Type Optional
software IManagedObject No
Returns : void
Async save
save()
Returns : any
setInitialState
setInitialState()
Returns : void
successMsg
successMsg()
Returns : void

Properties

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>

results matching ""

    No results matching ""