@c8y/ngx-components
Version:
Angular modules for Cumulocity IoT applications
82 lines • 16.4 kB
JavaScript
import { Component, EventEmitter, Inject, signal } from '@angular/core';
import { ActivatedRoute, Router } from '@angular/router';
import { Permissions } from '@c8y/ngx-components';
import { delay, Subject, takeUntil, tap } from 'rxjs';
import { SUB_ASSETS_CONFIG } from './sub-assets.model';
import { SubAssetsService } from './sub-assets.service';
import * as i0 from "@angular/core";
import * as i1 from "@c8y/ngx-components";
import * as i2 from "./sub-assets.service";
import * as i3 from "@angular/router";
import * as i4 from "@angular/common";
import * as i5 from "./add-group/add-group.component";
import * as i6 from "./sub-assets-grid.component";
export class GroupsComponent {
constructor(permissions, subAssetsService, moduleConfig, activeRoute, router) {
this.permissions = permissions;
this.subAssetsService = subAssetsService;
this.moduleConfig = moduleConfig;
this.activeRoute = activeRoute;
this.router = router;
this.SHOW_ADD_GROUP = 'showAddGroup';
this.showAddGroup = signal(false);
this.refresh = new EventEmitter();
this.filterable = true;
this.sortable = true;
this.shouldDisableAddGroup = false;
this.columns = [];
this.destroyed = new Subject();
}
ngOnInit() {
if (!this.permissions.hasAnyRole([
Permissions.ROLE_INVENTORY_READ,
Permissions.ROLE_MANAGED_OBJECT_READ
])) {
this.sortable = false;
}
this.shouldDisableAddGroup = !this.subAssetsService.canCreateGroup();
this.columns = this.subAssetsService
.getDefaultColumns()
.filter(column => column.name !== 'alarms');
this.activeRoute.queryParamMap
.pipe(delay(50), // It allows seeing drawer animation.
takeUntil(this.destroyed), tap(params => this.showAddGroup.set(params.has(this.SHOW_ADD_GROUP))))
.subscribe();
}
onAddGroupClick() {
this.showAddGroup.set(!this.showAddGroup());
this.handleShowAddGroupQueryParam();
}
ngOnDestroy() {
this.destroyed.next();
this.destroyed.complete();
}
/**
* Updates the query parameter `showAddGroup` based on the value of `showAddGroup` property.
* - If `showAddGroup` is `true`, adds `showAddGroup=true` to the query parameters.
* - If `showAddGroup` is `false`, removes `showAddGroup` from the query parameters.
*/
handleShowAddGroupQueryParam() {
const currentParams = { ...this.activeRoute.snapshot.queryParams };
if (this.showAddGroup()) {
currentParams[this.SHOW_ADD_GROUP] = true;
}
else {
delete currentParams[this.SHOW_ADD_GROUP];
}
this.router.navigate([], {
relativeTo: this.activeRoute,
queryParams: currentParams
});
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: GroupsComponent, deps: [{ token: i1.Permissions }, { token: i2.SubAssetsService }, { token: SUB_ASSETS_CONFIG }, { token: i3.ActivatedRoute }, { token: i3.Router }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: GroupsComponent, selector: "c8y-groups-name", ngImport: i0, template: "<c8y-title>\n {{ moduleConfig.name | translate }}\n</c8y-title>\n\n<c8y-breadcrumb>\n <c8y-breadcrumb-item\n icon=\"c8y-group-open\"\n label=\"{{ moduleConfig.name | translate }}\"\n ></c8y-breadcrumb-item>\n</c8y-breadcrumb>\n\n<c8y-action-bar-item\n [placement]=\"'right'\"\n *ngIf=\"moduleConfig.showAddGroupBtn\"\n>\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Add group' | translate }}\"\n (click)=\"onAddGroupClick()\"\n [disabled]=\"shouldDisableAddGroup\"\n [attr.data-cy]=\"'groups-add-group-button'\"\n >\n <i\n class=\"m-r-4\"\n c8yIcon=\"plus-circle\"\n ></i>\n {{ 'Add group' | translate }}\n </button>\n</c8y-action-bar-item>\n\n<c8y-help\n src=\"/docs/device-management-application/grouping-devices/#grouping-devices\"\n *ngIf=\"moduleConfig.showGroupsContextHelp\"\n></c8y-help>\n\n<c8y-add-group\n [refresh]=\"refresh\"\n (onCancel)=\"onAddGroupClick()\"\n *ngIf=\"showAddGroup()\"\n></c8y-add-group>\n<c8y-sub-assets-grid\n class=\"content-fullpage d-flex d-col border-top border-bottom\"\n [refresh]=\"refresh\"\n [filterable]=\"filterable\"\n [sortable]=\"sortable\"\n [columns]=\"columns\"\n [columnsConfigKey]=\"'sub-assets-grid'\"\n [baseQuery]=\"moduleConfig.baseQuery\"\n></c8y-sub-assets-grid>\n", dependencies: [{ kind: "component", type: i1.ActionBarItemComponent, selector: "c8y-action-bar-item", inputs: ["placement", "priority", "itemClass", "injector", "groupId", "inGroupPriority"] }, { kind: "component", type: i1.BreadcrumbComponent, selector: "c8y-breadcrumb" }, { kind: "component", type: i1.BreadcrumbItemComponent, selector: "c8y-breadcrumb-item", inputs: ["icon", "translate", "label", "path", "injector"] }, { kind: "directive", type: i1.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i1.TitleComponent, selector: "c8y-title", inputs: ["pageTitleUpdate"] }, { kind: "component", type: i1.HelpComponent, selector: "c8y-help", inputs: ["src", "isCollapsed", "priority", "icon"] }, { kind: "component", type: i5.AddGroupComponent, selector: "c8y-add-group", inputs: ["currentGroupId", "refresh"], outputs: ["onDeviceQueryStringChange", "onCancel"] }, { kind: "component", type: i6.SubAssetsGridComponent, selector: "c8y-sub-assets-grid", inputs: ["parent-group", "refresh", "title", "emptyStateText", "loadingItemsLabel", "columnsConfigKey", "columns", "pagination", "actionControls", "selectable", "baseQuery", "bulkActionControls", "filterable", "sortable", "displayOptions"], outputs: ["onColumnsChange", "itemsSelect"] }, { kind: "pipe", type: i1.C8yTranslatePipe, name: "translate" }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: GroupsComponent, decorators: [{
type: Component,
args: [{ selector: 'c8y-groups-name', template: "<c8y-title>\n {{ moduleConfig.name | translate }}\n</c8y-title>\n\n<c8y-breadcrumb>\n <c8y-breadcrumb-item\n icon=\"c8y-group-open\"\n label=\"{{ moduleConfig.name | translate }}\"\n ></c8y-breadcrumb-item>\n</c8y-breadcrumb>\n\n<c8y-action-bar-item\n [placement]=\"'right'\"\n *ngIf=\"moduleConfig.showAddGroupBtn\"\n>\n <button\n class=\"btn btn-link\"\n title=\"{{ 'Add group' | translate }}\"\n (click)=\"onAddGroupClick()\"\n [disabled]=\"shouldDisableAddGroup\"\n [attr.data-cy]=\"'groups-add-group-button'\"\n >\n <i\n class=\"m-r-4\"\n c8yIcon=\"plus-circle\"\n ></i>\n {{ 'Add group' | translate }}\n </button>\n</c8y-action-bar-item>\n\n<c8y-help\n src=\"/docs/device-management-application/grouping-devices/#grouping-devices\"\n *ngIf=\"moduleConfig.showGroupsContextHelp\"\n></c8y-help>\n\n<c8y-add-group\n [refresh]=\"refresh\"\n (onCancel)=\"onAddGroupClick()\"\n *ngIf=\"showAddGroup()\"\n></c8y-add-group>\n<c8y-sub-assets-grid\n class=\"content-fullpage d-flex d-col border-top border-bottom\"\n [refresh]=\"refresh\"\n [filterable]=\"filterable\"\n [sortable]=\"sortable\"\n [columns]=\"columns\"\n [columnsConfigKey]=\"'sub-assets-grid'\"\n [baseQuery]=\"moduleConfig.baseQuery\"\n></c8y-sub-assets-grid>\n" }]
}], ctorParameters: () => [{ type: i1.Permissions }, { type: i2.SubAssetsService }, { type: undefined, decorators: [{
type: Inject,
args: [SUB_ASSETS_CONFIG]
}] }, { type: i3.ActivatedRoute }, { type: i3.Router }] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"groups.component.js","sourceRoot":"","sources":["../../../sub-assets/groups.component.ts","../../../sub-assets/groups.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, OnDestroy, OnInit, signal } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Column, Permissions } from '@c8y/ngx-components';\nimport { delay, Subject, takeUntil, tap } from 'rxjs';\nimport { SUB_ASSETS_CONFIG, SubAssetsConfig } from './sub-assets.model';\nimport { SubAssetsService } from './sub-assets.service';\n\n@Component({\n  selector: 'c8y-groups-name',\n  templateUrl: './groups.component.html'\n})\nexport class GroupsComponent implements OnInit, OnDestroy {\n  private SHOW_ADD_GROUP = 'showAddGroup';\n  showAddGroup = signal(false);\n  refresh: EventEmitter<void> = new EventEmitter();\n  filterable = true;\n  sortable = true;\n  shouldDisableAddGroup = false;\n  columns: Column[] = [];\n  destroyed: Subject<void> = new Subject();\n  constructor(\n    private permissions: Permissions,\n    private subAssetsService: SubAssetsService,\n    @Inject(SUB_ASSETS_CONFIG) public moduleConfig: SubAssetsConfig,\n    private activeRoute: ActivatedRoute,\n    private router: Router\n  ) {}\n\n  ngOnInit() {\n    if (\n      !this.permissions.hasAnyRole([\n        Permissions.ROLE_INVENTORY_READ,\n        Permissions.ROLE_MANAGED_OBJECT_READ\n      ])\n    ) {\n      this.sortable = false;\n    }\n    this.shouldDisableAddGroup = !this.subAssetsService.canCreateGroup();\n\n    this.columns = this.subAssetsService\n      .getDefaultColumns()\n      .filter(column => column.name !== 'alarms');\n\n    this.activeRoute.queryParamMap\n      .pipe(\n        delay(50), // It allows seeing drawer animation.\n        takeUntil(this.destroyed),\n        tap(params => this.showAddGroup.set(params.has(this.SHOW_ADD_GROUP)))\n      )\n      .subscribe();\n  }\n\n  onAddGroupClick() {\n    this.showAddGroup.set(!this.showAddGroup());\n    this.handleShowAddGroupQueryParam();\n  }\n\n  ngOnDestroy() {\n    this.destroyed.next();\n    this.destroyed.complete();\n  }\n\n  /**\n   * Updates the query parameter `showAddGroup` based on the value of `showAddGroup` property.\n   * - If `showAddGroup` is `true`, adds `showAddGroup=true` to the query parameters.\n   * - If `showAddGroup` is `false`, removes `showAddGroup` from the query parameters.\n   */\n  private handleShowAddGroupQueryParam() {\n    const currentParams = { ...this.activeRoute.snapshot.queryParams };\n\n    if (this.showAddGroup()) {\n      currentParams[this.SHOW_ADD_GROUP] = true;\n    } else {\n      delete currentParams[this.SHOW_ADD_GROUP];\n    }\n    this.router.navigate([], {\n      relativeTo: this.activeRoute,\n      queryParams: currentParams\n    });\n  }\n}\n","<c8y-title>\n  {{ moduleConfig.name | translate }}\n</c8y-title>\n\n<c8y-breadcrumb>\n  <c8y-breadcrumb-item\n    icon=\"c8y-group-open\"\n    label=\"{{ moduleConfig.name | translate }}\"\n  ></c8y-breadcrumb-item>\n</c8y-breadcrumb>\n\n<c8y-action-bar-item\n  [placement]=\"'right'\"\n  *ngIf=\"moduleConfig.showAddGroupBtn\"\n>\n  <button\n    class=\"btn btn-link\"\n    title=\"{{ 'Add group' | translate }}\"\n    (click)=\"onAddGroupClick()\"\n    [disabled]=\"shouldDisableAddGroup\"\n    [attr.data-cy]=\"'groups-add-group-button'\"\n  >\n    <i\n      class=\"m-r-4\"\n      c8yIcon=\"plus-circle\"\n    ></i>\n    {{ 'Add group' | translate }}\n  </button>\n</c8y-action-bar-item>\n\n<c8y-help\n  src=\"/docs/device-management-application/grouping-devices/#grouping-devices\"\n  *ngIf=\"moduleConfig.showGroupsContextHelp\"\n></c8y-help>\n\n<c8y-add-group\n  [refresh]=\"refresh\"\n  (onCancel)=\"onAddGroupClick()\"\n  *ngIf=\"showAddGroup()\"\n></c8y-add-group>\n<c8y-sub-assets-grid\n  class=\"content-fullpage d-flex d-col border-top border-bottom\"\n  [refresh]=\"refresh\"\n  [filterable]=\"filterable\"\n  [sortable]=\"sortable\"\n  [columns]=\"columns\"\n  [columnsConfigKey]=\"'sub-assets-grid'\"\n  [baseQuery]=\"moduleConfig.baseQuery\"\n></c8y-sub-assets-grid>\n"]}