File

repository/firmware/list/add-firmware-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
getFirmwareResult
getFirmwareResult(searchStr: string)
Parameters :
Name Type Optional
searchStr string No
Returns : any
loadFirmwares
loadFirmwares()
Returns : void
ngOnDestroy
ngOnDestroy()
Returns : void
ngOnInit
ngOnInit()
Returns : void
onFile
onFile(dropped: PickedFiles)
Parameters :
Name Type Optional
dropped PickedFiles No
Returns : void
onFirmwareSelect
onFirmwareSelect(firmware: IManagedObject)
Parameters :
Name Type Optional
firmware IManagedObject No
Returns : void
Async save
save()
Returns : any
setInitialState
setInitialState()
Returns : void
successMsg
successMsg()
Returns : void

Properties

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>

results matching ""

    No results matching ""