@c8y/ngx-components
Version:
Angular modules for Cumulocity IoT applications
71 lines • 18.2 kB
JavaScript
import { Component, Input, ViewChild } from '@angular/core';
import { LpwanSetDeviceProtocolService } from './lpwan-set-device-protocol.service';
import { AlertService, gettext, PopoverConfirmComponent } from '@c8y/ngx-components';
import { pipe } from 'rxjs';
import { map } from 'rxjs/operators';
import { find } from 'lodash-es';
import * as i0 from "@angular/core";
import * as i1 from "./lpwan-set-device-protocol.service";
import * as i2 from "@c8y/ngx-components";
import * as i3 from "@angular/common";
import * as i4 from "@angular/forms";
export class LpwanAssignLnsConnectionsComponent {
constructor(lpwanService, alertService) {
this.lpwanService = lpwanService;
this.alertService = alertService;
this.buttons = [
{ label: gettext('Cancel'), action: () => Promise.reject() },
{ label: gettext('Re-register'), action: () => this.deviceReregister(), status: 'default' }
];
this.reRegisterMsg = gettext('To change provider connection, you need to re-register device first.');
this.filterConnection = pipe();
this.pattern = '';
}
async ngOnInit() {
await this.reload();
this.setConnectionPipe('');
}
setConnectionPipe(filterStr) {
this.pattern = filterStr;
this.filterConnection = pipe(map(connections => connections.filter(connection => (!this.currentConnection || this.currentConnection.name !== connection.name) &&
(!filterStr || connection.name.toLowerCase().indexOf(filterStr.toLowerCase()) > -1))));
}
async reload() {
this.loading = true;
this.newConnection = null;
try {
this.availableConnections = await this.lpwanService.getAvailableConnections(this.device);
this.currentConnection = find(this.availableConnections.data, {
name: this.device.c8y_LpwanDevice.lnsConnectionName
});
}
catch (ex) {
this.alertService.addServerFailure(ex);
}
finally {
this.loading = false;
}
}
togglePopover(popoverCfrm) {
popoverCfrm.show();
this.setConnectionPipe('');
}
deviceReregister() {
return new Promise(resolve => {
window.location.href = `#/deviceregistration`;
resolve(true);
});
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LpwanAssignLnsConnectionsComponent, deps: [{ token: i1.LpwanSetDeviceProtocolService }, { token: i2.AlertService }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: LpwanAssignLnsConnectionsComponent, selector: "set-lns-connections", inputs: { device: "device" }, viewQueries: [{ propertyName: "popoverConfirm", first: true, predicate: PopoverConfirmComponent, descendants: true, static: true }], ngImport: i0, template: "<div class=\"col-md-6\">\n <div class=\"form-group\">\n <label translate>Current connection</label>\n <p class=\"form-control-static\" *ngIf=\"!currentConnection\">\n {{ 'Connection is not set. Select connection for this device' | translate }}\n </p>\n <p class=\"form-control-static text-truncate\" *ngIf=\"currentConnection\" title=\"{{ currentConnection.name }}\">\n {{ currentConnection.name }}\n </p>\n </div>\n\n <c8y-form-group>\n <c8y-popover-confirm\n outsideClick=\"true\"\n containerClass=\"lns-connection-popover\"\n [message]=\"reRegisterMsg\"\n [buttons]=\"buttons\"\n [placement]=\"'bottom'\"\n ></c8y-popover-confirm>\n <c8y-typeahead\n *ngIf=\"!loading\"\n [(ngModel)]=\"newConnection\"\n placeholder=\"{{ 'Select new connection' | translate }}\"\n name=\"newConnection\"\n (onSearch)=\"setConnectionPipe($event)\"\n [allowFreeEntries]=\"false\"\n >\n <c8y-li\n *c8yFor=\"let connection of availableConnections; loadMore: 'hidden'; pipe: filterConnection\"\n class=\"p-l-8 p-r-8 c8y-list__item--link\"\n (click)=\"togglePopover(popoverConfirm)\"\n >\n <c8y-highlight [text]=\"connection.name\" [pattern]=\"pattern\"></c8y-highlight>\n </c8y-li>\n </c8y-typeahead>\n <c8y-messages\n ><c8y-message\n name=\"notExisting\"\n [text]=\"'Select one of the connections.' | translate\"\n ></c8y-message>\n </c8y-messages>\n </c8y-form-group>\n</div>\n", dependencies: [{ kind: "directive", type: i2.C8yTranslateDirective, selector: "[translate],[ngx-translate]" }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ForOfDirective, selector: "[c8yFor]", inputs: ["c8yForOf", "c8yForLoadMore", "c8yForPipe", "c8yForNotFound", "c8yForMaxIterations", "c8yForLoadingTemplate", "c8yForLoadNextLabel", "c8yForLoadingLabel", "c8yForRealtime", "c8yForRealtimeOptions", "c8yForComparator", "c8yForEnableVirtualScroll", "c8yForVirtualScrollElementSize", "c8yForVirtualScrollStrategy", "c8yForVirtualScrollContainerHeight"], outputs: ["c8yForCount", "c8yForChange", "c8yForLoadMoreComponent"] }, { kind: "component", type: i2.PopoverConfirmComponent, selector: "c8y-popover-confirm", inputs: ["buttons", "message", "title", "isOpen", "containerClass", "placement", "outsideClick", "adaptivePosition", "container"] }, { kind: "component", type: i2.HighlightComponent, selector: "c8y-highlight", inputs: ["pattern", "text", "elementClass", "shouldTrimPattern"] }, { kind: "component", type: i2.TypeaheadComponent, selector: "c8y-typeahead", inputs: ["required", "maxlength", "disabled", "allowFreeEntries", "placeholder", "displayProperty", "icon", "name", "autoClose", "hideNew", "container", "selected", "highlightFirstItem"], outputs: ["onSearch", "onIconClick"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.FormGroupComponent, selector: "c8y-form-group", inputs: ["hasError", "hasWarning", "hasSuccess", "novalidation", "status"] }, { kind: "directive", type: i2.MessageDirective, selector: "c8y-message", inputs: ["name", "text"] }, { kind: "component", type: i2.MessagesComponent, selector: "c8y-messages", inputs: ["show", "defaults", "helpMessage"] }, { kind: "component", type: i2.ListItemComponent, selector: "c8y-list-item, c8y-li", inputs: ["active", "highlighted", "emptyActions", "dense", "collapsed", "selectable"], outputs: ["collapsedChange"] }, { kind: "pipe", type: i2.C8yTranslatePipe, name: "translate" }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LpwanAssignLnsConnectionsComponent, decorators: [{
type: Component,
args: [{ selector: 'set-lns-connections', template: "<div class=\"col-md-6\">\n <div class=\"form-group\">\n <label translate>Current connection</label>\n <p class=\"form-control-static\" *ngIf=\"!currentConnection\">\n {{ 'Connection is not set. Select connection for this device' | translate }}\n </p>\n <p class=\"form-control-static text-truncate\" *ngIf=\"currentConnection\" title=\"{{ currentConnection.name }}\">\n {{ currentConnection.name }}\n </p>\n </div>\n\n <c8y-form-group>\n <c8y-popover-confirm\n outsideClick=\"true\"\n containerClass=\"lns-connection-popover\"\n [message]=\"reRegisterMsg\"\n [buttons]=\"buttons\"\n [placement]=\"'bottom'\"\n ></c8y-popover-confirm>\n <c8y-typeahead\n *ngIf=\"!loading\"\n [(ngModel)]=\"newConnection\"\n placeholder=\"{{ 'Select new connection' | translate }}\"\n name=\"newConnection\"\n (onSearch)=\"setConnectionPipe($event)\"\n [allowFreeEntries]=\"false\"\n >\n <c8y-li\n *c8yFor=\"let connection of availableConnections; loadMore: 'hidden'; pipe: filterConnection\"\n class=\"p-l-8 p-r-8 c8y-list__item--link\"\n (click)=\"togglePopover(popoverConfirm)\"\n >\n <c8y-highlight [text]=\"connection.name\" [pattern]=\"pattern\"></c8y-highlight>\n </c8y-li>\n </c8y-typeahead>\n <c8y-messages\n ><c8y-message\n name=\"notExisting\"\n [text]=\"'Select one of the connections.' | translate\"\n ></c8y-message>\n </c8y-messages>\n </c8y-form-group>\n</div>\n" }]
}], ctorParameters: () => [{ type: i1.LpwanSetDeviceProtocolService }, { type: i2.AlertService }], propDecorators: { device: [{
type: Input
}], popoverConfirm: [{
type: ViewChild,
args: [PopoverConfirmComponent, { static: true }]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lpwan-set-connections.component.js","sourceRoot":"","sources":["../../../protocol-lpwan/lpwan-set-connections.component.ts","../../../protocol-lpwan/lpwan-set-connections.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, ViewChild } from '@angular/core';\nimport { LpwanSetDeviceProtocolService } from './lpwan-set-device-protocol.service';\nimport {\n  AlertService,\n  ForOfFilterPipe,\n  gettext,\n  PopoverConfirmButtons,\n  PopoverConfirmComponent\n} from '@c8y/ngx-components';\nimport { IManagedObject, IResultList } from '@c8y/client';\nimport { pipe } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { find } from 'lodash-es';\nimport {\n  ActilityConnection,\n  SigfoxConnection\n} from './multiple-lns-connectors/multiple-lns-connector.model';\n\n@Component({\n  selector: 'set-lns-connections',\n  templateUrl: './lpwan-set-connections.component.html'\n})\nexport class LpwanAssignLnsConnectionsComponent implements OnInit {\n  loading: boolean;\n  @Input() device: IManagedObject;\n  buttons: PopoverConfirmButtons[] = [\n    { label: gettext('Cancel'), action: () => Promise.reject() },\n    { label: gettext('Re-register'), action: () => this.deviceReregister(), status: 'default' }\n  ];\n  reRegisterMsg = gettext('To change provider connection, you need to re-register device first.');\n  filterConnection: ForOfFilterPipe<ActilityConnection | SigfoxConnection> = pipe();\n  pattern = '';\n  @ViewChild(PopoverConfirmComponent, { static: true }) popoverConfirm: PopoverConfirmComponent;\n\n  newConnection: ActilityConnection | SigfoxConnection;\n  availableConnections: IResultList<ActilityConnection | SigfoxConnection>;\n  currentConnection: ActilityConnection | SigfoxConnection;\n\n  constructor(\n    private lpwanService: LpwanSetDeviceProtocolService,\n    private alertService: AlertService\n  ) {}\n  async ngOnInit() {\n    await this.reload();\n    this.setConnectionPipe('');\n  }\n\n  setConnectionPipe(filterStr: string) {\n    this.pattern = filterStr;\n    this.filterConnection = pipe(\n      map(connections =>\n        connections.filter(\n          connection =>\n            (!this.currentConnection || this.currentConnection.name !== connection.name) &&\n            (!filterStr || connection.name.toLowerCase().indexOf(filterStr.toLowerCase()) > -1)\n        )\n      )\n    );\n  }\n\n  async reload() {\n    this.loading = true;\n    this.newConnection = null;\n    try {\n      this.availableConnections = await this.lpwanService.getAvailableConnections(this.device);\n      this.currentConnection = find(this.availableConnections.data, {\n        name: this.device.c8y_LpwanDevice.lnsConnectionName\n      });\n    } catch (ex) {\n      this.alertService.addServerFailure(ex);\n    } finally {\n      this.loading = false;\n    }\n  }\n\n  togglePopover(popoverCfrm) {\n    popoverCfrm.show();\n    this.setConnectionPipe('');\n  }\n\n  deviceReregister() {\n    return new Promise(resolve => {\n      window.location.href = `#/deviceregistration`;\n      resolve(true);\n    });\n  }\n}\n","<div class=\"col-md-6\">\n  <div class=\"form-group\">\n    <label translate>Current connection</label>\n    <p class=\"form-control-static\" *ngIf=\"!currentConnection\">\n      {{ 'Connection is not set. Select connection for this device' | translate }}\n    </p>\n    <p class=\"form-control-static text-truncate\" *ngIf=\"currentConnection\" title=\"{{ currentConnection.name }}\">\n      {{ currentConnection.name }}\n    </p>\n  </div>\n\n  <c8y-form-group>\n    <c8y-popover-confirm\n      outsideClick=\"true\"\n      containerClass=\"lns-connection-popover\"\n      [message]=\"reRegisterMsg\"\n      [buttons]=\"buttons\"\n      [placement]=\"'bottom'\"\n    ></c8y-popover-confirm>\n    <c8y-typeahead\n      *ngIf=\"!loading\"\n      [(ngModel)]=\"newConnection\"\n      placeholder=\"{{ 'Select new connection' | translate }}\"\n      name=\"newConnection\"\n      (onSearch)=\"setConnectionPipe($event)\"\n      [allowFreeEntries]=\"false\"\n    >\n      <c8y-li\n        *c8yFor=\"let connection of availableConnections; loadMore: 'hidden'; pipe: filterConnection\"\n        class=\"p-l-8 p-r-8 c8y-list__item--link\"\n        (click)=\"togglePopover(popoverConfirm)\"\n      >\n        <c8y-highlight [text]=\"connection.name\" [pattern]=\"pattern\"></c8y-highlight>\n      </c8y-li>\n    </c8y-typeahead>\n    <c8y-messages\n      ><c8y-message\n        name=\"notExisting\"\n        [text]=\"'Select one of the connections.' | translate\"\n      ></c8y-message>\n    </c8y-messages>\n  </c8y-form-group>\n</div>\n"]}