UNPKG

@c8y/ngx-components

Version:

Angular modules for Cumulocity IoT applications

96 lines 18.3 kB
import { Component, EventEmitter } from '@angular/core'; import { ActivatedRoute } from '@angular/router'; import { InventoryService, QueriesUtil } from '@c8y/client'; import { DataGridService, gettext } from '@c8y/ngx-components'; import { SERVICE_FRAGMENT, ServiceCommandService } from '@c8y/ngx-components/services/shared'; import { StatusOptionsService } from '../status-options'; import { LastUpdatedDateGridColumn, ServiceNameGridColumn, ServiceTypeGridColumn, StatusGridColumn } from './columns'; import * as i0 from "@angular/core"; import * as i1 from "@angular/router"; import * as i2 from "@c8y/client"; import * as i3 from "@c8y/ngx-components"; import * as i4 from "../status-options"; import * as i5 from "@c8y/ngx-components/services/shared"; import * as i6 from "@angular/common"; export class ServicesDeviceTabComponent { constructor(route, inventoryService, gridService, statusOptionsService, serviceCommand) { this.route = route; this.inventoryService = inventoryService; this.gridService = gridService; this.statusOptionsService = statusOptionsService; this.serviceCommand = serviceCommand; this.deviceId = this.route.snapshot.parent.data.contextData.id; this.sizeRequestDone = false; this.refresh$ = new EventEmitter(); this.pagination = { pageSize: 50, currentPage: 1 }; this.actionControls = []; this.columns = [ new StatusGridColumn(this.statusOptionsService), new ServiceNameGridColumn(), new ServiceTypeGridColumn(), new LastUpdatedDateGridColumn() ]; this.noResultsMessage = gettext('No results to display.'); this.noDataMessage = gettext('No services to display.'); this.noResultsSubtitle = gettext('Refine your search terms or check your spelling.'); this.queriesUtil = new QueriesUtil(); this.serverSideDataCallback = this.onDataSourceModifier.bind(this); this.sizeRequest = this.inventoryService .childAdditionsList(this.deviceId, { query: `type eq ${SERVICE_FRAGMENT}`, withTotalPages: true, pageSize: 1 }) .then(response => { this.sizeRequestDone = true; return response?.paging?.totalPages; }); } async onDataSourceModifier(dataSourceModifier) { const query = this.queriesUtil.buildQuery(this.queriesUtil.addAndFilter(this.gridService.getQueryObj(dataSourceModifier.columns), { type: SERVICE_FRAGMENT })); const dataRequest = this.inventoryService.childAdditionsList(this.deviceId, { query, withTotalPages: true, pageSize: dataSourceModifier.pagination.pageSize, currentPage: dataSourceModifier.pagination.currentPage }); const filtererdSizeRequest = this.inventoryService .childAdditionsList(this.deviceId, { query, withTotalPages: true, pageSize: 1 }) .then(response => response?.paging?.totalPages); const [dataResponse, size, filteredSize] = await Promise.all([ dataRequest, this.sizeRequest, filtererdSizeRequest ]); const { res, data, paging } = dataResponse; const commands = this.serviceCommand.getAllSupportedCommands(data); this.actionControls = this.serviceCommand.generateActionControls(commands); const serverSideDataResult = { res, data, paging, filteredSize, size }; return serverSideDataResult; } trackByName(_index, column) { return column.name; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ServicesDeviceTabComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.InventoryService }, { token: i3.DataGridService }, { token: i4.StatusOptionsService }, { token: i5.ServiceCommandService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ServicesDeviceTabComponent, selector: "c8y-services-device-tab", ngImport: i0, template: "<div class=\"content-fullpage\">\n <c8y-data-grid\n [title]=\"'Services' | translate\"\n [refresh]=\"refresh$\"\n [actionControls]=\"actionControls\"\n [pagination]=\"pagination\"\n [columns]=\"columns\"\n [infiniteScroll]=\"'auto'\"\n [serverSideDataCallback]=\"serverSideDataCallback\"\n >\n <c8y-ui-empty-state\n [icon]=\"stats?.size > 0 ? 'search' : 'c8y-tools'\"\n [title]=\"stats?.size > 0 ? (noResultsMessage | translate) : (noDataMessage | translate)\"\n [subtitle]=\"stats?.size > 0 ? (noResultsSubtitle | translate) : null\"\n *emptyStateContext=\"let stats; isLoading as isLoading\"\n [horizontal]=\"stats?.size > 0\"\n ></c8y-ui-empty-state>\n <ng-container *ngFor=\"let column of columns; trackBy: trackByName\">\n <c8y-column [name]=\"column.name\"></c8y-column>\n </ng-container>\n </c8y-data-grid>\n</div>\n", dependencies: [{ kind: "component", type: i3.EmptyStateComponent, selector: "c8y-ui-empty-state", inputs: ["icon", "title", "subtitle", "horizontal"] }, { kind: "directive", type: i3.EmptyStateContextDirective, selector: "[emptyStateContext]" }, { kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.ColumnDirective, selector: "c8y-column", inputs: ["name"] }, { kind: "component", type: i3.DataGridComponent, selector: "c8y-data-grid", inputs: ["title", "loadMoreItemsLabel", "loadingItemsLabel", "showSearch", "refresh", "columns", "rows", "pagination", "infiniteScroll", "serverSideDataCallback", "selectable", "singleSelection", "selectionPrimaryKey", "displayOptions", "actionControls", "bulkActionControls", "headerActionControls", "searchText", "configureColumnsEnabled", "showCounterWarning", "activeClassName", "expandableRows"], outputs: ["rowMouseOver", "rowMouseLeave", "rowClick", "onConfigChange", "onBeforeFilter", "onBeforeSearch", "onFilter", "itemsSelect", "onReload", "onAddCustomColumn", "onRemoveCustomColumn", "onColumnFilterReset", "onSort", "onPageSizeChange", "onColumnReordered", "onColumnVisibilityChange"] }, { kind: "pipe", type: i3.C8yTranslatePipe, name: "translate" }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ServicesDeviceTabComponent, decorators: [{ type: Component, args: [{ selector: 'c8y-services-device-tab', template: "<div class=\"content-fullpage\">\n <c8y-data-grid\n [title]=\"'Services' | translate\"\n [refresh]=\"refresh$\"\n [actionControls]=\"actionControls\"\n [pagination]=\"pagination\"\n [columns]=\"columns\"\n [infiniteScroll]=\"'auto'\"\n [serverSideDataCallback]=\"serverSideDataCallback\"\n >\n <c8y-ui-empty-state\n [icon]=\"stats?.size > 0 ? 'search' : 'c8y-tools'\"\n [title]=\"stats?.size > 0 ? (noResultsMessage | translate) : (noDataMessage | translate)\"\n [subtitle]=\"stats?.size > 0 ? (noResultsSubtitle | translate) : null\"\n *emptyStateContext=\"let stats; isLoading as isLoading\"\n [horizontal]=\"stats?.size > 0\"\n ></c8y-ui-empty-state>\n <ng-container *ngFor=\"let column of columns; trackBy: trackByName\">\n <c8y-column [name]=\"column.name\"></c8y-column>\n </ng-container>\n </c8y-data-grid>\n</div>\n" }] }], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.InventoryService }, { type: i3.DataGridService }, { type: i4.StatusOptionsService }, { type: i5.ServiceCommandService }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"services-device-tab.component.js","sourceRoot":"","sources":["../../../../services/services-device-tab/services-device-tab.component.ts","../../../../services/services-device-tab/services-device-tab.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter } from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { IManagedObject, InventoryService, IResultList, QueriesUtil } from '@c8y/client';\nimport {\n  ActionControl,\n  Column,\n  DataGridService,\n  DataSourceModifier,\n  gettext,\n  ServerSideDataResult\n} from '@c8y/ngx-components';\nimport {\n  Service,\n  SERVICE_FRAGMENT,\n  ServiceCommandService\n} from '@c8y/ngx-components/services/shared';\nimport { StatusOptionsService } from '../status-options';\nimport {\n  LastUpdatedDateGridColumn,\n  ServiceNameGridColumn,\n  ServiceTypeGridColumn,\n  StatusGridColumn\n} from './columns';\n\n@Component({\n  selector: 'c8y-services-device-tab',\n  templateUrl: 'services-device-tab.component.html'\n})\nexport class ServicesDeviceTabComponent {\n  deviceId: string | number = this.route.snapshot.parent.data.contextData.id;\n\n  sizeRequest: Promise<number>;\n  sizeRequestDone = false;\n\n  refresh$: EventEmitter<void> = new EventEmitter();\n  pagination = {\n    pageSize: 50,\n    currentPage: 1\n  };\n\n  actionControls: ActionControl[] = [];\n  columns: Column[] = [\n    new StatusGridColumn(this.statusOptionsService),\n    new ServiceNameGridColumn(),\n    new ServiceTypeGridColumn(),\n    new LastUpdatedDateGridColumn()\n  ];\n\n  serverSideDataCallback: any;\n\n  noResultsMessage = gettext('No results to display.');\n  noDataMessage = gettext('No services to display.');\n  noResultsSubtitle = gettext('Refine your search terms or check your spelling.');\n\n  private queriesUtil: QueriesUtil = new QueriesUtil();\n\n  constructor(\n    private route: ActivatedRoute,\n    private inventoryService: InventoryService,\n    private gridService: DataGridService,\n    private statusOptionsService: StatusOptionsService,\n    private serviceCommand: ServiceCommandService\n  ) {\n    this.serverSideDataCallback = this.onDataSourceModifier.bind(this);\n    this.sizeRequest = this.inventoryService\n      .childAdditionsList(this.deviceId, {\n        query: `type eq ${SERVICE_FRAGMENT}`,\n        withTotalPages: true,\n        pageSize: 1\n      })\n      .then(response => {\n        this.sizeRequestDone = true;\n        return response?.paging?.totalPages;\n      });\n  }\n\n  async onDataSourceModifier(\n    dataSourceModifier: DataSourceModifier\n  ): Promise<ServerSideDataResult> {\n    const query = this.queriesUtil.buildQuery(\n      this.queriesUtil.addAndFilter(this.gridService.getQueryObj(dataSourceModifier.columns), {\n        type: SERVICE_FRAGMENT\n      })\n    );\n\n    const dataRequest: Promise<IResultList<IManagedObject>> =\n      this.inventoryService.childAdditionsList(this.deviceId, {\n        query,\n        withTotalPages: true,\n        pageSize: dataSourceModifier.pagination.pageSize,\n        currentPage: dataSourceModifier.pagination.currentPage\n      });\n\n    const filtererdSizeRequest: Promise<number> = this.inventoryService\n      .childAdditionsList(this.deviceId, {\n        query,\n        withTotalPages: true,\n        pageSize: 1\n      })\n      .then(response => response?.paging?.totalPages);\n\n    const [dataResponse, size, filteredSize] = await Promise.all([\n      dataRequest,\n      this.sizeRequest,\n      filtererdSizeRequest\n    ]);\n\n    const { res, data, paging } = dataResponse;\n\n    const commands = this.serviceCommand.getAllSupportedCommands(data as unknown as Service[]);\n    this.actionControls = this.serviceCommand.generateActionControls(commands);\n\n    const serverSideDataResult: ServerSideDataResult = {\n      res,\n      data,\n      paging,\n      filteredSize,\n      size\n    };\n\n    return serverSideDataResult;\n  }\n\n  trackByName(_index, column: Column): string {\n    return column.name;\n  }\n}\n","<div class=\"content-fullpage\">\n  <c8y-data-grid\n    [title]=\"'Services' | translate\"\n    [refresh]=\"refresh$\"\n    [actionControls]=\"actionControls\"\n    [pagination]=\"pagination\"\n    [columns]=\"columns\"\n    [infiniteScroll]=\"'auto'\"\n    [serverSideDataCallback]=\"serverSideDataCallback\"\n  >\n    <c8y-ui-empty-state\n      [icon]=\"stats?.size > 0 ? 'search' : 'c8y-tools'\"\n      [title]=\"stats?.size > 0 ? (noResultsMessage | translate) : (noDataMessage | translate)\"\n      [subtitle]=\"stats?.size > 0 ? (noResultsSubtitle | translate) : null\"\n      *emptyStateContext=\"let stats; isLoading as isLoading\"\n      [horizontal]=\"stats?.size > 0\"\n    ></c8y-ui-empty-state>\n    <ng-container *ngFor=\"let column of columns; trackBy: trackByName\">\n      <c8y-column [name]=\"column.name\"></c8y-column>\n    </ng-container>\n  </c8y-data-grid>\n</div>\n"]}